*{box-sizing:border-box}body{background-color:#f0f0f0;width:100vw;height:100vh;margin:0;overflow:hidden}#root{width:100%;height:100%}.app-container{width:100vw;height:100vh;position:relative}.canvas-container{z-index:1;position:absolute;inset:0}.ui-layer{z-index:9999;pointer-events:none;position:absolute;inset:0}.left-toolbar{pointer-events:auto;z-index:1001;background:#fff;border-radius:12px;flex-direction:column;gap:10px;width:70px;padding:10px;transition:width .3s cubic-bezier(.25,1,.5,1);display:flex;position:absolute;top:50%;left:20px;overflow:hidden;transform:translateY(-50%);box-shadow:0 10px 30px #0000001a}.left-toolbar:hover{width:210px}.left-toolbar button{cursor:pointer;color:#334155;background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:14px;width:100%;height:50px;padding:0 13px;transition:all .2s;display:flex}.left-toolbar button:hover{color:#0f172a;background:#f8fafc;border-color:#cbd5e1}.toolbar-icon-wrapper{flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.button-text{white-space:nowrap;opacity:0;pointer-events:none;font-family:Inter,system-ui,sans-serif;font-size:14px;font-weight:600;transition:opacity .2s,transform .2s;transform:translate(-10px)}.left-toolbar:hover .button-text{opacity:1;transition-delay:80ms;transform:translate(0)}.help-carousel-container{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;justify-content:center;align-items:center;width:100%;height:65vh;min-height:400px;display:flex;position:relative;overflow:hidden}.help-slide-placeholder{flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.help-carousel-image{object-fit:contain;max-width:100%;max-height:100%}.help-nav-arrow{color:#334155;cursor:pointer;z-index:10;background:#fff;border:1px solid #cbd5e1;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:all .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 4px 12px #0000001a}.help-nav-arrow:hover:not(:disabled){color:#0f172a;background:#f1f5f9;transform:translateY(-50%)scale(1.05)}.help-nav-arrow:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.help-nav-arrow.left{left:20px}.help-nav-arrow.right{right:20px}.help-pagination{justify-content:center;gap:12px;margin-top:25px;display:flex}.help-page-btn{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-family:Inter,sans-serif;font-size:14px;font-weight:700;transition:all .2s;display:flex}.help-page-btn:hover{color:#0f172a;background:#f8fafc;border-color:#cbd5e1}.help-page-btn.active{color:#fff;background:#3498db;border-color:#3498db;box-shadow:0 4px 10px #3498db40}.modal-overlay{pointer-events:auto;background:#0006;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.modal-content{background:#f9f9f9;border-radius:8px;width:700px;padding:20px;position:relative;box-shadow:0 10px 25px #0003}.close-button{cursor:pointer;position:absolute;top:10px;right:10px}.layout-split{gap:40px;margin-top:10px;display:flex}.left-col{flex-direction:column;flex:1;gap:20px;display:flex}.right-col{flex-direction:column;flex:1.2;justify-content:space-between;display:flex}.modal-body{gap:20px;margin-bottom:20px;display:flex}.color-grid{grid-template-columns:repeat(5,1fr);gap:10px;display:grid}.color-swatch{cursor:pointer;border-radius:4px;width:40px;height:40px}.properties-panel{flex-direction:column;gap:10px;display:flex}.modal-footer{justify-content:flex-end;gap:10px;display:flex}.context-menu{pointer-events:auto;z-index:1000;background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:12px;padding:15px 20px;display:flex;position:absolute;bottom:25px;left:50%;transform:translate(-50%);box-shadow:0 10px 30px #0000001a}.menu-row{color:#334155;justify-content:center;align-items:center;gap:12px;font-family:Inter,system-ui,sans-serif;font-size:14px;display:flex}.context-menu input[type=range]{accent-color:#3498db;cursor:pointer}.menu-btn{cursor:pointer;color:#334155;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:8px 14px;font-family:Inter,system-ui,sans-serif;font-size:14px;font-weight:600;transition:all .2s;display:flex}.menu-btn:hover{color:#0f172a;background:#f8fafc;border-color:#cbd5e1}.menu-btn.delete{color:#e74c3c;background:#fff5f5;border-color:#fbc4be}.menu-btn.delete:hover{background:#fceceb}.size-display{text-align:center;color:#0f172a;width:24px;font-size:16px;font-weight:700}.exit-inside-btn{color:#e74c3c;cursor:pointer;pointer-events:auto;z-index:1000;background:#fff;border:1px solid #fbc4be;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-family:Inter,system-ui,sans-serif;font-size:14px;font-weight:700;transition:all .2s;display:flex;position:absolute;top:20px;left:50%;transform:translate(-50%);box-shadow:0 10px 30px #0000001a}.inside-panel{pointer-events:auto;background:#fff;border:1px solid #e2e8f0;border-radius:12px;justify-content:space-between;align-items:center;gap:20px;padding:15px 20px;display:flex;box-shadow:0 10px 30px #0000001a}.panel-label{color:#334155;font-family:Inter,system-ui,sans-serif;font-size:14px;font-weight:600}.icon-btn{cursor:pointer;color:#334155;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:38px;height:38px;transition:all .2s;display:flex}.icon-btn:hover{color:#0f172a;background:#f8fafc;border-color:#cbd5e1}.icon-btn.tiny{width:32px;height:26px}.exit-inside-btn{color:#fff;cursor:pointer;pointer-events:auto;z-index:100;background:#e74c3c;border:none;border-radius:30px;padding:12px 24px;font-size:16px;font-weight:700;transition:background .2s;position:absolute;top:20px;left:50%;transform:translate(-50%);box-shadow:0 4px 15px #0000004d}.exit-inside-btn:hover{background:#c0392b}.inside-menu-container{z-index:100;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:absolute;bottom:20px;right:20px}.inside-panel{pointer-events:auto;background:#fff6;border:1px solid #0000001a;border-radius:8px;justify-content:space-between;align-items:center;gap:25px;padding:15px 25px;transition:background .2s ease-in-out;display:flex;box-shadow:0 4px 15px #0000001a}.inside-panel:hover{background:#fff}.panel-label{color:#444;font-size:18px}.move-grid{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.icon-btn{cursor:pointer;color:#333;background:0 0;border:1px solid #888;border-radius:4px;justify-content:center;align-items:center;width:34px;height:34px;font-size:18px;display:flex}.icon-btn:hover{background:#0000000d}.size-value{color:#666;text-align:center;width:20px;font-size:18px}.size-controls{flex-direction:column;gap:4px;display:flex}.icon-btn.tiny{width:28px;height:22px;font-size:14px}.modal-content-large{color:#0f172a;background:#fff;border:1px solid #e2e8f0;border-radius:16px;width:900px;padding:30px;font-family:Inter,system-ui,sans-serif;position:relative;box-shadow:0 20px 40px #00000026}.close-button{color:#94a3b8;cursor:pointer;background:0 0;border:none;font-size:20px;transition:color .2s;position:absolute;top:15px;right:15px}.close-button:hover{color:#0f172a}.preview-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;height:350px;position:relative;overflow:hidden}.preview-title{text-align:center;letter-spacing:1px;color:#64748b;z-index:10;width:100%;font-size:12px;font-weight:700;position:absolute;top:15px}.sketch-input{color:#334155;background:#fff;border:1px solid #cbd5e1;border-radius:8px;width:100%;padding:15px;font-family:Inter,system-ui,sans-serif;font-size:15px;font-weight:500;transition:all .2s}.sketch-input:focus{border-color:#3498db;outline:none;box-shadow:0 0 0 3px #3498db1a}.sketch-checkboxes{justify-content:space-between;padding:0 5px;display:flex}.sketch-checkboxes label{color:#334155;cursor:pointer;align-items:center;gap:8px;font-size:15px;font-weight:500;display:flex}.sketch-checkboxes input[type=checkbox]{cursor:pointer;accent-color:#3498db;width:18px;height:18px}.shape-cards{gap:15px;display:flex}.shape-card{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex:1;justify-content:center;align-items:center;height:120px;font-weight:600;transition:all .2s;display:flex}.shape-card:hover{color:#334155;background:#f8fafc;border-color:#cbd5e1;transform:translateY(-2px)}.shape-card.active{color:#2980b9;background:#f0f7ff;border:2px solid #3498db}.color-grid-large{grid-template-columns:repeat(6,1fr);gap:15px;margin-top:20px;margin-bottom:20px;display:grid}.color-swatch-circle{cursor:pointer;border:3px solid #0000;border-radius:50%;width:50px;height:50px;transition:transform .1s;box-shadow:0 2px 5px #0000001a}.color-swatch-circle.active{border-color:#3498db;transform:scale(1.1);box-shadow:0 0 0 2px #fff,0 0 0 4px #3498db}.btn-cancel,.btn-confirm{cursor:pointer;border:1px solid #0000;border-radius:8px;padding:12px 24px;font-size:15px;font-weight:600;transition:all .2s}.btn-cancel{color:#64748b;background:0 0}.btn-cancel:hover{color:#334155;background:#f1f5f9}.btn-confirm{color:#fff;background:#3498db;box-shadow:0 4px 12px #3498db33}.btn-confirm:hover{background:#2980b9;box-shadow:0 6px 15px #3498db4d}.preview-label{-webkit-backdrop-filter:blur(4px);color:#fff;letter-spacing:.5px;white-space:nowrap;-webkit-user-select:none;user-select:none;pointer-events:none;background:#0f0f0fbf;border:1px solid #ffffff26;border-radius:4px;padding:4px 6px;font-family:Inter,system-ui,sans-serif;font-size:8px;font-weight:600;box-shadow:0 4px 12px #0003}.player-bubble-container{cursor:pointer}.player-tooltip{color:#fff;white-space:nowrap;opacity:0;pointer-events:none;z-index:10000;background:#000000d9;border-radius:6px;padding:6px 12px;font-size:14px;font-weight:600;transition:all .2s cubic-bezier(.25,.8,.25,1);position:absolute;top:50%;right:55px;transform:translateY(-50%)translate(10px);box-shadow:0 4px 12px #00000026}.player-tooltip:after{content:"";border:5px solid #0000;border-left-color:#000000d9;border-right-width:0;position:absolute;top:50%;right:-5px;transform:translateY(-50%)}.player-bubble-container:hover .player-tooltip{opacity:1;transform:translateY(-50%)translate(0)}@media (width<=1366px){.modal-content-large{width:92vw!important;max-width:1000px!important}.layout-split{gap:16px!important}.color-grid-large{gap:10px!important}}@media (height<=800px){.modal-content-large{padding:18px 24px!important}.layout-split{gap:15px!important;margin-top:5px!important}.sketch-input{padding:10px 14px!important}.shape-card{height:64px!important}.shape-cards{gap:6px!important}.color-swatch-circle{width:42px!important;height:42px!important}.color-grid-large{margin-top:10px!important;margin-bottom:10px!important}.sketch-checkboxes{gap:10px!important;padding:14px!important}.sketch-checkboxes>div[style*=height]{height:110px!important}.left-toolbar button{gap:10px!important;height:42px!important}.left-toolbar{gap:6px!important}}.right-toolbar{pointer-events:auto;z-index:1001;opacity:.5;background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:8px;padding:8px;transition:opacity .25s;display:flex;position:absolute;bottom:25px;right:25px;box-shadow:0 10px 30px #0000001a}.right-toolbar:hover{opacity:1}.right-toolbar button{color:#475569;cursor:pointer;background:#fff;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;width:42px;height:42px;transition:all .2s;display:flex}.right-toolbar button:hover{color:#0f172a;background:#f8fafc;border-color:#cbd5e1}.dashboard-container{color:#0f172a;background-color:#f8fafc;width:100vw;height:100vh;font-family:Inter,system-ui,sans-serif;display:flex}.dash-sidebar{z-index:10;background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;width:260px;padding:30px 20px;display:flex}.dash-sidebar h2{color:#0f172a;letter-spacing:-.5px;margin-top:0;margin-bottom:40px;padding-left:10px;font-size:22px;font-weight:800}.dash-nav{flex-direction:column;gap:8px;display:flex}.dash-nav button{text-align:left;color:#64748b;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;font-size:15px;font-weight:600;transition:all .2s;display:flex}.dash-nav button:hover{color:#334155;background:#f1f5f9}.dash-nav button.active{color:#2980b9;background:#f0f7ff;border-color:#bae6fd}.dash-nav .logout-btn{color:#e74c3c;margin-top:auto}.dash-nav .logout-btn:hover{color:#c0392b;background:#fff5f5}.dash-content{flex:1;padding:50px;overflow-y:auto}.content-header{justify-content:space-between;align-items:center;max-width:1200px;margin-bottom:40px;display:flex}.content-header h1{letter-spacing:-.5px;margin:0;font-size:28px;font-weight:800}.board-list{flex-direction:column;gap:16px;max-width:1200px;display:flex}.board-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;min-height:160px;padding:0;transition:box-shadow .2s;display:flex;overflow:hidden;box-shadow:0 2px 8px #00000005}.board-card:hover{box-shadow:0 8px 24px #0000000f}.card-actions-left{gap:10px;width:100%;margin-top:auto;display:flex}.card-middle{flex-direction:column;flex:1;padding:20px 24px;display:flex}.card-middle h3{color:#0f172a;margin:0 0 8px;font-size:20px;font-weight:800}.card-right-menu{background:#fff;border-left:1px solid #e2e8f0;flex-direction:column;gap:2px;width:240px;padding:16px;display:flex}.menu-list-btn{text-align:left;color:#475569;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;align-items:center;gap:10px;padding:8px 10px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.menu-list-btn:hover{color:#0f172a;background:#f1f5f9}.menu-list-btn.danger{color:#e74c3c}.menu-list-btn.danger:hover{background:#fff5f5}.btn-primary{color:#fff;cursor:pointer;background:#3498db;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:14px;font-weight:600;transition:all .2s;display:flex;box-shadow:0 2px 8px #3498db33}.btn-primary:hover{background:#2980b9;box-shadow:0 4px 12px #3498db4d}.btn-outline{color:#64748b;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:8px;justify-content:center;align-items:center;padding:10px;transition:all .2s;display:flex}.btn-outline:hover{color:#0f172a;background:#f8fafc;border-color:#94a3b8}.btn-danger{color:#fff;cursor:pointer;background:#e74c3c;border:none;border-radius:8px;padding:10px 16px;font-size:14px;font-weight:600;box-shadow:0 2px 8px #e74c3c33}.btn-danger:hover{background:#c0392b}.switch{width:36px;height:20px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:#cbd5e1;border-radius:20px;transition:all .4s;position:absolute;inset:0}.slider:before{content:"";background-color:#fff;border-radius:50%;width:14px;height:14px;transition:all .4s;position:absolute;bottom:3px;left:3px;box-shadow:0 1px 2px #0000001a}input:checked+.slider{background-color:#3498db}input:checked+.slider:before{transform:translate(16px)}.form-modal-content{background:#fff;border:1px solid #e2e8f0;border-radius:16px;width:100%;max-width:600px;padding:35px;box-shadow:0 20px 40px #00000026}.form-modal-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;display:flex}.form-modal-header h2{color:#0f172a;margin:0;font-size:20px;font-weight:700}.modal-form-group{flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.modal-form-group label{color:#64748b;letter-spacing:.5px;text-transform:uppercase;font-size:13px;font-weight:700}.modal-form-group input[type=text],.modal-form-group input[type=password],.modal-form-group textarea{color:#334155;border:1px solid #cbd5e1;border-radius:8px;padding:14px;font-family:inherit;font-size:15px;font-weight:500;transition:all .2s}.modal-form-group input:focus,.modal-form-group textarea:focus{border-color:#3498db;outline:none;box-shadow:0 0 0 3px #3498db1a}.modal-form-group textarea{resize:vertical;min-height:100px}.modal-footer-actions{justify-content:flex-end;gap:15px;margin-top:35px;display:flex}@media (width<=1400px){.dash-sidebar{width:72px;padding:30px 14px;transition:width .25s cubic-bezier(.25,1,.5,1),padding .25s;overflow:hidden}.dash-sidebar:hover{width:260px;padding:30px 20px}.dash-sidebar h2{opacity:0;white-space:nowrap;transition:opacity .15s}.dash-sidebar:hover h2{opacity:1}.dash-nav button{justify-content:center;padding:12px;font-size:0;transition:font-size .2s,padding .2s}.dash-sidebar:hover .dash-nav button{justify-content:flex-start;padding:12px 16px;font-size:15px}.dash-content{padding:30px 24px}.content-header{margin-bottom:24px}}.auth-container{background-color:#f0f0f0;justify-content:center;align-items:center;width:100vw;height:100vh;font-family:sans-serif;display:flex}.auth-card{text-align:center;background:#eaeaea;border-radius:12px;width:100%;max-width:450px;padding:40px;box-shadow:0 15px 35px #00000026}.auth-card h1{color:#000;margin-top:0;margin-bottom:5px;font-size:32px}.auth-card h2{color:#666;margin-bottom:30px;font-size:18px;font-weight:400}.auth-form{flex-direction:column;gap:15px;display:flex}.name-row{gap:15px;display:flex}.auth-form input{box-sizing:border-box;background:#fff;border:2px solid #ccc;border-radius:6px;width:100%;padding:15px;font-size:16px}.auth-form input:focus{border-color:#000;outline:none}.auth-message{border-radius:6px;margin-bottom:20px;padding:15px;font-weight:700}.auth-message.error{color:#c0392b;background:#fdf0ef;border:1px solid #c0392b}.auth-message.success{color:#27ae60;background:#e8f8f5;border:1px solid #27ae60}.auth-toggle{color:#555;margin-top:25px;font-size:14px}.text-btn{color:#000;cursor:pointer;background:0 0;border:none;margin-left:5px;font-weight:700;text-decoration:underline}
