:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#fff;background-color:#0a0a0a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden}a{font-weight:500;color:#6366f1;text-decoration:none;transition:color .3s ease}a:hover{color:#8b5cf6}button{font-family:inherit;cursor:pointer}input,textarea{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#ffffff0d}::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}*{-webkit-tap-highlight-color:transparent}*:focus{outline:none!important}.error-message{padding:12px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#fca5a5;font-size:14px;text-align:center;margin-bottom:12px}.item-list-modal{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#1a1a1a;padding:20px;border-radius:10px;box-shadow:0 4px 12px #0000004d;width:300px;max-height:400px;overflow-y:auto}.items-list-modal-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:999;pointer-events:auto}.items-list-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999}.item-list-modal{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#1e1e2df2;border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:20px;width:340px;max-height:420px;overflow-y:auto;box-shadow:0 8px 32px #0006;animation:fadeInModal .2s ease}@keyframes fadeInModal{0%{opacity:0;transform:translate(-50%,-46%)}to{opacity:1;transform:translate(-50%,-50%)}}.modal-title{font-size:20px;font-weight:600;margin:0}.modal-item-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:14px;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center;gap:12px;transition:all .25s ease}.modal-item-card:hover{background:#ffffff14;transform:translateY(-2px);box-shadow:0 6px 20px #00000059}.modal-item-text{font-size:14px;color:#e5e5e5;flex:1}.modal-delete-btn{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:6px 10px;border-radius:6px;font-size:12px;transition:all .2s ease}.modal-delete-btn:hover{background:#ef444440}.modal-add-btn{margin-top:18px;width:100%;padding:12px;border-radius:8px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;font-size:14px;font-weight:600;transition:all .3s ease}.modal-add-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.modal-empty{opacity:.6;text-align:center;padding:12px 0;font-size:14px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:16px;gap:12px}.close-button{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:20px;color:#a0a0b0;padding:0}.prompt-modal-overlay{position:fixed;inset:0;z-index:1000}.prompt-modal{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#1a1a28f2;border:1px solid rgba(255,255,255,.1);border-radius:14px;width:340px;padding:22px;box-shadow:0 10px 30px #0006;animation:fadeInModal .2s ease}.prompt-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.prompt-modal-title{font-size:18px;font-weight:600;margin:0}.prompt-modal-message{margin-bottom:14px;color:#d1d5db;font-size:14px;line-height:1.5}.prompt-modal-input{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.prompt-modal-label{font-size:13px;color:#ffffffd9}.prompt-modal input[type=text]{padding:10px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:#fff;outline:none;transition:border .2s ease,box-shadow .2s ease}.prompt-modal input[type=text]:focus{border-color:#6366f1b3;box-shadow:0 0 0 3px #6366f126}.prompt-modal-actions{display:flex;justify-content:flex-end;gap:10px}.prompt-btn{padding:10px 14px;border-radius:8px;border:none;font-weight:600;font-size:14px;transition:all .2s ease}.prompt-btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.prompt-btn-primary:hover{box-shadow:0 8px 22px #6366f159;transform:translateY(-1px)}.prompt-btn-secondary{background:#ffffff14;color:#e5e7eb;border:1px solid rgba(255,255,255,.12)}.prompt-btn-secondary:hover{background:#ffffff1f}*{box-sizing:border-box}#root{width:100%;min-height:100vh}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0a0a0a,#1a1a2e);padding:20px}.login-container{background:#1e1e2de6;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:48px 40px;width:100%;max-width:420px;box-shadow:0 8px 32px #0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-header{text-align:center;margin-bottom:32px}.login-header h2{font-size:28px;font-weight:600;color:#fff;margin:0 0 8px}.login-header p{font-size:14px;color:#a0a0b0;margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:#e0e0e0}.form-group input{padding:12px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:14px;color:#fff;transition:all .3s ease}.form-group input:focus{outline:none;background:#ffffff14;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.form-group input::placeholder{color:#667}.login-button{padding:14px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;font-size:16px;font-weight:600;color:#fff;cursor:pointer;transition:all .3s ease;margin-top:8px}.login-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.login-button:active{transform:translateY(0)}.login-button:disabled{background:#6366f180;cursor:not-allowed;transform:none}.login-divider{text-align:center;margin:24px 0;color:#a0a0b0;font-size:14px}.login-toggle{text-align:center;font-size:14px;color:#a0a0b0}.login-toggle-link{color:#6366f1;text-decoration:none;font-weight:500;cursor:pointer;transition:color .3s ease}.login-toggle-link:hover{color:#8b5cf6;text-decoration:underline}.info-message{margin-top:-8px;padding:10px 12px;border-radius:10px;background:#10b98126;border:1px solid rgba(16,185,129,.35);color:#a7f3d0;font-size:14px}.code-button{margin-top:4px;padding:10px 12px;border-radius:8px;border:1px solid rgba(99,102,241,.4);background:#6366f11f;color:#dfe3ff;font-weight:600;cursor:pointer;transition:all .2s ease}@media(max-width:480px){.login-container{padding:32px 24px}.login-header h2{font-size:24px}}.dashboard-page{min-height:100vh;background:linear-gradient(135deg,#0a0a0a,#1a1a2e);padding-bottom:40px}.dashboard-header{background:#1e1e2dcc;border-bottom:1px solid rgba(255,255,255,.1);padding:16px 32px;display:flex;justify-content:space-between;align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:sticky;top:0;z-index:100}.dashboard-header-actions{display:flex;align-items:center;gap:12px}.dashboard-title{font-size:24px;font-weight:600;color:#fff;margin:0}.dashboard-user{display:flex;align-items:center;gap:12px;cursor:pointer;padding:8px 12px;border-radius:8px;transition:background .3s ease}.dashboard-user:hover{background:#ffffff0d}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:#fff;border:2px solid rgba(255,255,255,.2)}.user-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.admin-dashboard-button{padding:10px 14px;border-radius:8px;border:1px solid rgba(99,102,241,.4);background:#6366f11a;color:#c7d2fe;font-weight:600;cursor:pointer;transition:all .2s ease}.admin-dashboard-button:hover{background:#6366f12e;transform:translateY(-1px);box-shadow:0 6px 16px #6366f140}.dashboard-content{max-width:1400px;margin:0 auto;padding:40px 32px}.dashboard-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.dashboard-subtitle{font-size:20px;font-weight:600;color:#fff;margin:0}.create-canvas-button{padding:12px 24px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;font-size:14px;font-weight:600;color:#fff;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px}.create-canvas-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.canvases-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}.canvas-card{background:#1e1e2de6;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:20px;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;height:100%}.canvas-card:hover{border-color:#6366f180;box-shadow:0 8px 24px #0000004d}.canvas-card:has(.item-list-modal){transform:none!important;box-shadow:none!important;border:1px solid rgba(255,255,255,.1)!important}.canvas-thumbnail{width:100%;height:160px;background:linear-gradient(135deg,#6366f133,#8b5cf633);border-radius:8px;margin-bottom:16px;display:flex;align-items:center;justify-content:center;color:#ffffff4d;font-size:48px}.canvas-info{display:flex;flex-direction:column;gap:6px}.canvas-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.canvas-name{font-size:18px;font-weight:600;color:#fff;margin:0}.canvas-description{font-size:14px;color:#a0a0b0;margin:0;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.canvas-meta{font-size:12px;color:#667;margin-top:2px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.canvas-actions{display:flex;gap:8px;align-items:center;margin-top:auto}.canvas-action-button{padding:6px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;font-size:12px;color:#e0e0e0;cursor:pointer;transition:all .3s ease}.canvas-action-button:hover{background:#ffffff1a}.canvas-action-button.share{color:#6ee7b7;border-color:#10b9814d}.canvas-action-button.share:hover{background:#10b9811a}.canvas-action-button.delete{color:#fca5a5;border-color:#ef44444d}.canvas-action-button.delete:hover{background:#ef44441a}.canvas-role-tag{padding:4px 8px;border-radius:999px;background:#6366f124;border:1px solid rgba(99,102,241,.3);color:#c7d2fe;font-weight:700;font-size:11px}.canvas-role-tag.owner{background:#34d3992e;border:1px solid rgba(52,211,153,.35);color:#bbf7d0}.empty-state{text-align:center;padding:80px 20px;color:#a0a0b0}.empty-state-icon{font-size:64px;margin-bottom:16px;opacity:.3}.empty-state h3{font-size:20px;color:#e0e0e0;margin:0 0 8px}.empty-state p{font-size:14px;margin:0}@media(max-width:768px){.dashboard-header{padding:16px 20px}.dashboard-title{font-size:20px}.dashboard-content{padding:24px 20px}.dashboard-actions{flex-direction:column;align-items:flex-start;gap:16px}.canvases-grid{grid-template-columns:1fr}}.collaborator-item{display:flex;align-items:center;gap:10px}.collaborator-text{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.collaborator-badge{padding:4px 8px;border-radius:999px;background:#34d3992e;border:1px solid rgba(52,211,153,.35);color:#bbf7d0;font-size:11px;font-weight:700}.profile-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.profile-modal{background:#1e1e2df2;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:32px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0006}.profile-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.profile-modal-title{font-size:24px;font-weight:600;color:#fff;margin:0}.close-button{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:20px;color:#a0a0b0}.close-button:hover{background:#ffffff1a;color:#fff}.profile-avatar-section{display:flex;flex-direction:column;align-items:center;margin-bottom:32px}.profile-avatar-large{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:600;color:#fff;border:4px solid rgba(255,255,255,.2);margin-bottom:16px}.profile-avatar-large img{width:100%;height:100%;border-radius:50%;object-fit:cover}.avatar-actions{display:flex;gap:10px}.change-avatar-button{padding:8px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;font-size:14px;color:#e0e0e0;cursor:pointer;transition:all .3s ease}.change-avatar-button:hover{background:#ffffff1a}.change-avatar-button:disabled{opacity:.5;cursor:not-allowed}.remove-avatar-button{padding:8px 16px;background:#ef444414;border:1px solid rgba(239,68,68,.3);border-radius:6px;font-size:14px;color:#fca5a5;cursor:pointer;transition:all .3s ease}.remove-avatar-button:hover{background:#ef444429}.remove-avatar-button:disabled{opacity:.5;cursor:not-allowed}.profile-form{display:flex;flex-direction:column;gap:20px}.profile-form-group{display:flex;flex-direction:column;gap:8px}.profile-form-group label{font-size:14px;font-weight:500;color:#e0e0e0}.profile-form-group input{padding:12px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:14px;color:#fff;transition:all .3s ease}.profile-form-group input:disabled{opacity:.6;cursor:not-allowed}.profile-form-group input:not(:disabled):focus{outline:none;background:#ffffff14;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.profile-actions{display:flex;gap:12px;margin-top:8px}.profile-button{flex:1;padding:12px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.profile-button-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.profile-button-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.profile-button-primary:disabled{background:#6366f180;cursor:not-allowed;transform:none}.profile-button-secondary{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#e0e0e0}.profile-button-secondary:hover{background:#ffffff1a}.profile-button-danger{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.profile-button-danger:hover{background:#ef444433}.profile-info-text{font-size:12px;color:#667;margin-top:4px}.code-button{margin-top:6px;padding:10px 12px;border-radius:8px;border:1px solid rgba(99,102,241,.4);background:#6366f11f;color:#dfe3ff;font-weight:600;cursor:pointer;transition:all .2s ease}.code-button:hover{background:#6366f133}@media(max-width:480px){.profile-modal{padding:24px 20px}.profile-modal-title{font-size:20px}.profile-avatar-large{width:100px;height:100px;font-size:40px}}.admin-modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;z-index:1100}.admin-modal{background:#141623f2;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:24px;width:100%;max-width:1200px;height:90vh;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000073}.admin-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.admin-modal-header h2{margin:0;font-size:22px;color:#fff}.admin-subtitle{margin:4px 0 0;color:#9aa0ba;font-size:14px}.admin-columns{flex:1;min-height:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;align-items:stretch;overflow:hidden}.admin-panel{background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:12px;padding:16px;min-height:420px;height:100%;display:flex;flex-direction:column;position:relative;min-height:0}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.panel-header h3{margin:0;color:#fff;font-size:18px}.panel-hint{color:#7d829b;margin:4px 0 0;font-size:13px}.panel-filters{margin-top:8px;display:flex;align-items:center;gap:10px}.panel-search{width:100%;padding:10px 12px;border-radius:10px;border:1px solid rgba(99,102,241,.25);background:#0c0e18e6;color:#e8e9fb;font-size:14px;box-shadow:inset 0 0 0 1px #ffffff08;transition:border .2s ease,box-shadow .2s ease,transform .1s ease}.panel-search:focus{outline:none;border-color:#6366f199;box-shadow:0 0 0 3px #6366f12e;transform:translateY(-1px)}.panel-meta{padding:8px 12px;border-radius:10px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);color:#cfd4f3;font-weight:600;white-space:nowrap}.panel-body{flex:1;min-height:0;margin-top:10px;display:flex;flex-direction:column;gap:10px;overflow:hidden;position:relative}.panel-controls{display:flex;align-items:center;gap:10px;color:#9aa0ba;font-size:12px}.panel-control-label{text-transform:uppercase;letter-spacing:.04em;font-weight:600}.custom-select{position:relative;min-width:64px}.custom-select.disabled{opacity:.45;pointer-events:none}.custom-select-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:4px;padding:8px 10px;border-radius:10px;border:1px solid rgba(99,102,241,.25);background:radial-gradient(circle at 20% 20%,#6366f126,#0c0e18f2);color:#e8e9fb;cursor:pointer;transition:border .2s ease,transform .2s ease,box-shadow .2s ease}.custom-select-trigger:hover{border-color:#6366f173;transform:translateY(-1px);box-shadow:0 6px 18px #6366f140}.custom-select-trigger:disabled{cursor:not-allowed;transform:none;box-shadow:none}.custom-select-value{font-weight:700;font-size:14px}.custom-select-caret{font-size:10px;color:#c7d2fe}.custom-select-menu{position:absolute;top:calc(100% + 8px);right:0;background:#0e101cfa;border:1px solid rgba(255,255,255,.08);border-radius:10px;box-shadow:0 14px 40px #0000008c;min-width:96px;padding:6px;z-index:10}.custom-select-option{width:100%;text-align:left;padding:10px 12px;border:none;border-radius:8px;background:transparent;color:#e8e9fb;cursor:pointer;font-weight:600;transition:background .2s ease,color .2s ease,transform .1s ease}.custom-select-option:hover{background:#6366f124;color:#d3dbff;transform:translateY(-1px)}.custom-select-option.active{background:#6366f13d;border:1px solid rgba(99,102,241,.4);color:#fff}.admin-list{margin-top:4px;display:flex;flex-direction:column;gap:8px;flex:1;min-height:0;overflow-y:auto;padding-right:6px}.admin-list-item{background:#ffffff05;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:10px;display:flex;justify-content:space-between;align-items:center;gap:8px;cursor:pointer;transition:border .2s ease,transform .2s ease}.admin-list-item:hover{border-color:#6366f180;transform:translateY(-1px)}.admin-list-item.selected{border-color:#6366f1b3;box-shadow:0 6px 18px #6366f140}.admin-list-main{display:flex;align-items:center;gap:10px}.admin-avatar,.canvas-thumb{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:grid;place-items:center;font-weight:700;overflow:hidden;border:1px solid rgba(255,255,255,.08)}.admin-avatar img,.canvas-thumb img{width:100%;height:100%;object-fit:cover}.admin-list-text{display:flex;flex-direction:column;gap:4px;color:#e5e7f3;font-size:14px}.admin-list-text .muted{color:#7d829b;font-size:12px}.admin-row-actions{display:flex;align-items:center;gap:10px}.badge{background:#34d39926;color:#6ee7b7;padding:4px 8px;border-radius:999px;font-size:12px;border:1px solid rgba(52,211,153,.35)}.danger-link{border:1px solid rgba(239,68,68,.3);background:#ef44441a;color:#fca5a5;padding:6px 10px;border-radius:8px;cursor:pointer;transition:background .2s ease,border .2s ease}.danger-link:hover{background:#ef444433;border-color:#ef444466}.pagination{margin-top:12px;display:flex;align-items:center;gap:12px}.pagination-button{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#e5e7f3;padding:6px 12px;border-radius:8px;cursor:pointer;transition:background .2s ease,transform .2s ease}.pagination-button:hover{background:#ffffff14;transform:translateY(-1px)}.pagination-button:disabled{opacity:.4;cursor:not-allowed;transform:none}.pagination-text{color:#9aa0ba;font-size:13px}.panel-footer{margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.08);position:sticky;bottom:0;background:linear-gradient(180deg,#141623d9,#141623fa)}.panel-loading{position:absolute;inset:0;display:grid;place-items:center;background:#0e101ca6;color:#c7d2fe;font-weight:600;letter-spacing:.02em;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.admin-empty{text-align:center;padding:24px;color:#9aa0ba;background:#ffffff05;border:1px dashed rgba(255,255,255,.08);border-radius:12px;margin-top:12px}@media(max-width:720px){.admin-row-actions{flex-direction:column;align-items:flex-end}.admin-list-item{align-items:flex-start}}.canvas-page{min-height:100vh;background:radial-gradient(circle at 20% 20%,rgba(99,102,241,.08),transparent 30%),#0c0c14;color:#e5e7f3;display:flex;flex-direction:column;height:100vh;overflow:hidden}.canvas-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#141623e6;border-bottom:1px solid rgba(255,255,255,.08);gap:12px}.canvas-header h2{margin:0;font-size:20px;color:#fff}.canvas-subtitle{font-size:12px;color:#a0a3c3;margin-top:4px}.canvas-header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.canvas-status{font-size:12px;color:#c7d2fe}.canvas-status.ok{color:#86efac}.canvas-status.warn{color:#fca5a5}.canvas-exit{padding:8px 14px;border-radius:8px;border:1px solid rgba(239,68,68,.3);background:#ef444429;color:#fca5a5;cursor:pointer;outline:none}.canvas-exit:focus-visible{outline:none}.canvas-stage{flex:1;position:relative;padding:0;min-height:400px;display:flex;touch-action:none;overscroll-behavior:none}.canvas-stage canvas{width:100%;height:100%;border-radius:12px;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.02),transparent 40%),#10121ef2;border:1px solid rgba(255,255,255,.06);touch-action:none;outline:none;-webkit-tap-highlight-color:transparent}.canvas-overlay{position:absolute;inset:0;display:flex;align-items:flex-start;justify-content:flex-start;padding:16px;pointer-events:none}.canvas-overlay.hint{align-items:flex-end;padding-bottom:24px}.canvas-overlay-card{background:#0c0e18e6;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:10px 12px;box-shadow:0 10px 30px #00000073}.canvas-overlay-title{font-weight:700;font-size:13px;color:#fff}.canvas-overlay-text{margin-top:4px;font-size:12px;color:#cfd3e8}.presence-pills{margin-top:6px;display:flex;flex-wrap:wrap;gap:6px}.presence-pill{padding:4px 8px;border-radius:999px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);font-size:12px;color:#d8dcff}.canvas-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:#ffffff08;border:1px solid rgba(255,255,255,.08);padding:6px 10px;border-radius:10px}.tool-btn{border:1px solid rgba(255,255,255,.12);background:#ffffff0a;color:#e5e7f3;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:12px;outline:none}.tool-btn:focus-visible{outline:none}.tool-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.tool-btn.active{border-color:#6366f180;background:#6366f140;color:#fff;box-shadow:0 6px 18px #6366f140}.tool-field{display:flex;align-items:center;gap:6px;font-size:12px;color:#d1d5f0}.tool-field input[type=range]{width:140px}@media(max-width:640px){.canvas-header{flex-direction:column;align-items:flex-start;gap:8px}}
