@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap";.auth-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;display:flex;position:relative;overflow:hidden}.auth-page:before,.auth-page:after{content:"";filter:blur(120px);opacity:.4;border-radius:50%;animation:12s ease-in-out infinite alternate auth-float;position:absolute}.auth-page:before{background:linear-gradient(135deg,#7c5cff,#00d4ff);width:500px;height:500px;top:-150px;left:-100px}.auth-page:after{background:linear-gradient(135deg,#ff6bcb,#7c5cff);width:400px;height:400px;animation-delay:-6s;bottom:-100px;right:-80px}@keyframes auth-float{0%{transform:translate(0)scale(1)}to{transform:translate(40px,-30px)scale(1.1)}}.auth-card{z-index:1;background:var(--panel);border:1px solid var(--border);width:100%;max-width:420px;box-shadow:var(--elev), 0 0 80px #7c5cff0f;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;margin:20px;padding:40px 36px;position:relative}.auth-brand{text-align:center;margin-bottom:32px}.auth-brand-icon{background:linear-gradient(135deg,#7c5cff,#00d4ff);border-radius:14px;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 14px;display:flex;box-shadow:0 8px 24px #7c5cff4d}.auth-brand-icon svg{color:#fff;width:28px;height:28px}.auth-brand h1{color:var(--text);letter-spacing:-.3px;margin:0 0 4px;font-size:22px;font-weight:700}.auth-brand p{color:var(--muted);margin:0;font-size:13px}.auth-steps{justify-content:center;align-items:center;gap:8px;margin-bottom:28px;display:flex}.auth-step-dot{background:var(--border);border-radius:50%;width:8px;height:8px;transition:all .3s}.auth-step-dot.active{background:#7c5cff;transform:scale(1.25);box-shadow:0 0 8px #7c5cff80}.auth-step-dot.done{background:#22c55e}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-field label{color:var(--muted);text-transform:uppercase;letter-spacing:.6px;font-size:12px;font-weight:600}.auth-field input{width:100%;color:var(--text);background:var(--input-bg);border:1px solid var(--border);box-sizing:border-box;border-radius:10px;outline:none;padding:12px 14px;font-size:14px;transition:border-color .2s,box-shadow .2s}.auth-field input:focus{border-color:#7c5cff;box-shadow:0 0 0 3px #7c5cff2e}.auth-field input::placeholder{color:var(--muted);opacity:.6}.auth-name-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.auth-code-input{justify-content:center;gap:10px;margin:8px 0;display:flex}.auth-code-input input{text-align:center;width:48px;height:56px;color:var(--text);background:var(--input-bg);border:1.5px solid var(--border);caret-color:#7c5cff;border-radius:12px;outline:none;font-size:22px;font-weight:700;transition:border-color .2s,box-shadow .2s}.auth-code-input input:focus{border-color:#7c5cff;box-shadow:0 0 0 3px #7c5cff2e}.auth-btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px 20px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.auth-btn-primary{color:#fff;background:linear-gradient(135deg,#7c5cff,#6341e0);box-shadow:0 4px 16px #7c5cff4d}.auth-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px #7c5cff73}.auth-btn-primary:active:not(:disabled){transform:translateY(0)}.auth-btn-primary:disabled{opacity:.5;cursor:not-allowed}.auth-btn-google{background:var(--input-bg);color:var(--text);border:1px solid var(--border)}.auth-btn-google:hover{background:var(--panel2);border-color:var(--muted)}.auth-btn-google svg{width:18px;height:18px}.auth-divider{align-items:center;gap:12px;margin:4px 0;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-divider span{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:500}.auth-toggle{text-align:center;color:var(--muted);margin-top:8px;font-size:13px}.auth-toggle a{color:#7c5cff;cursor:pointer;font-weight:600;text-decoration:none;transition:color .2s}.auth-toggle a:hover{color:#9b82ff}.auth-forgot{text-align:right;margin-top:-8px}.auth-forgot a{color:#7c5cff;cursor:pointer;font-size:12px;font-weight:500;text-decoration:none}.auth-forgot a:hover{color:#9b82ff}.auth-error{color:#ef4444;text-align:center;background:#ef44441f;border:1px solid #ef444440;border-radius:8px;padding:10px 14px;font-size:13px;font-weight:500}.auth-success{color:#22c55e;text-align:center;background:#22c55e1f;border:1px solid #22c55e40;border-radius:8px;padding:10px 14px;font-size:13px;font-weight:500}.auth-spinner{border:2px solid #0000;border-top-color:currentColor;border-radius:50%;width:18px;height:18px;animation:.6s linear infinite auth-spin}@keyframes auth-spin{to{transform:rotate(360deg)}}.auth-loading-screen{background:var(--bg);min-height:100vh;color:var(--muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;font-size:14px;display:flex}.auth-loading-screen .auth-spinner{border-width:3px;border-top-color:#7c5cff;width:32px;height:32px}.auth-back{color:var(--muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin-bottom:12px;padding:0;font-size:13px;transition:color .2s;display:inline-flex}.auth-back:hover{color:var(--text)}.auth-back svg{width:16px;height:16px}@media (width<=480px){.auth-card{border-radius:16px;margin:12px;padding:28px 22px}.auth-code-input input{width:42px;height:50px;font-size:20px}}.access-denied-card{text-align:center;flex-direction:column;align-items:center;gap:14px;display:flex}.access-denied-icon{color:#ef4444;background:#ef44441f;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:4px;display:flex}.access-denied-icon svg{width:34px;height:34px}.access-denied-title{margin:0;font-size:1.5rem;font-weight:800}.access-denied-text{color:var(--muted);max-width:340px;margin:0;font-size:.92rem;line-height:1.55}.access-denied-btn{justify-content:center;align-items:center;gap:8px;width:auto;margin-top:6px;padding:11px 22px;display:inline-flex}@media (width<=480px){.auth-name-row{grid-template-columns:1fr!important;gap:12px!important}.auth-code-input{gap:6px!important}.auth-code-input input{width:38px!important;height:48px!important;font-size:18px!important}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#15151f;--panel:#1b1b2b;--panel2:#24243a;--accent:#7c5cff;--accent2:#22d3ee;--text:#eaeaf2;--muted:#8b8ca8;--stage-bg:#101019;--input-bg:#00000047;--border:#ffffff24;--hairline:#ffffff14;--overlay:#0000008c;--elev:0 10px 30px #00000073;--viewport-bg:#0d0d0d;--card-surface:#1c2233;--card-surface-2:#151a28;--card-ink:#eef1f8;--card-ink-soft:#eef1f89e;--card-hairline:#ffffff1a;--card-shadow:0 14px 40px #00000073}:root[data-mode=light]{--card-surface:#fff;--card-surface-2:#f8fafc;--card-ink:#0f172a;--card-ink-soft:#64748b;--card-hairline:#e2e8f0;--card-shadow:0 10px 30px #0f172a0f}html,body{overflow-x:hidden}body{background:var(--bg);color:var(--text);flex-direction:column;min-height:100vh;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;transition:background .35s,color .35s;display:flex}button{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;gap:6px;padding:7px 13px;font-family:inherit;font-size:.8rem;font-weight:600;transition:opacity .15s,transform .1s,box-shadow .2s,background .35s,color .35s,border-color .35s;display:inline-flex}button svg{width:14px;height:14px}button:active{transform:scale(.96)}button:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-secondary{background:var(--panel2);color:var(--text);border:1px solid var(--border);transition:background .35s,color .35s,border-color .2s}.btn-secondary:hover{border-color:var(--accent)}.btn-play{background:linear-gradient(135deg, var(--accent2), var(--accent));color:#fff;box-shadow:0 2px 14px color-mix(in srgb, var(--accent) 40%, transparent);border-radius:8px;padding:8px 22px;font-size:.9rem;transition:box-shadow .3s}.btn-play:hover{box-shadow:0 4px 20px color-mix(in srgb, var(--accent) 60%, transparent)}.btn-play-fs{color:#fff;background:linear-gradient(135deg,#10b981,#059669);border-radius:8px;padding:8px 18px;font-size:.9rem;transition:box-shadow .3s;box-shadow:0 2px 14px #10b98166}.btn-play-fs:hover{box-shadow:0 4px 20px #10b98199}.theme-pills{flex-wrap:wrap;justify-content:center;align-items:center;gap:5px;display:flex}.pill-sep{background:var(--border);align-self:stretch;width:1px;min-height:18px;margin:0 4px}.theme-pill{background:var(--panel2);border:1px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:20px;padding:4px 11px;font-size:.72rem;font-weight:600;transition:all .2s}.theme-pill:hover{border-color:var(--accent);opacity:.9}.theme-pill.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 10px color-mix(in srgb, var(--accent) 50%, transparent)}.style-pills{gap:4px;display:flex}.style-pill{background:var(--panel2);border:1px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:5px;padding:4px 10px;font-size:.72rem;font-weight:600;transition:all .2s}.style-pill:hover{border-color:var(--accent)}.style-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.workspace{flex:1;display:flex;overflow:hidden}.row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1000;background:#00000090;justify-content:center;align-items:center;animation:.15s fadeIn;display:none;position:fixed;inset:0}.modal-overlay.active{display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal{background:var(--panel);border:1px solid color-mix(in srgb, var(--accent) 30%, transparent);width:min(860px,95vw);max-height:82vh;box-shadow:var(--elev);border-radius:14px;animation:.2s slideUp;overflow-y:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}.modal-header{border-bottom:1px solid var(--hairline);background:var(--panel);z-index:1;justify-content:space-between;align-items:center;padding:16px 20px;font-size:.95rem;font-weight:700;display:flex;position:sticky;top:0}.modal-close{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 8px;font-size:1.1rem}.modal-close:hover{background:var(--hairline);color:var(--text)}.modal-content{background:var(--panel);border:1px solid var(--hairline);width:min(520px,95vw);max-height:88vh;box-shadow:var(--elev), 0 0 0 1px color-mix(in srgb, var(--accent) 7%, transparent);border-radius:18px;animation:.22s cubic-bezier(.4,0,.2,1) slideUp;overflow-y:auto}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-thumb{background:var(--panel2);border-radius:8px}.modal-content .modal-header{border-radius:18px 18px 0 0;padding:18px 22px}.modal-content .modal-header h2{font-size:1.05rem;font-weight:700}.user-form-modal .auth-form{gap:15px;padding:20px 22px 22px}.user-form-modal .auth-field input{border-radius:11px;padding:11px 13px;transition:border-color .18s,box-shadow .18s,background .18s}.account-settings-modal .account-tabs{margin-bottom:16px;padding:14px 22px 0}.account-settings-modal .account-tab-content{padding:0 22px 22px}.demo-grid{grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:12px;padding:16px;display:grid}.demo-card{background:var(--panel2);border:1px solid var(--hairline);cursor:pointer;text-align:center;border-radius:10px;flex-direction:column;gap:4px;padding:18px 14px;transition:all .2s;display:flex}.demo-card:hover{border-color:var(--accent);box-shadow:var(--elev);transform:translateY(-3px)}.demo-card-icon{margin-bottom:4px;font-size:2.4rem}.demo-card-title{font-size:.88rem;font-weight:700;line-height:1.2}.demo-card-desc{color:var(--muted);margin-top:2px;font-size:.7rem;line-height:1.4}.demo-card-meta{color:var(--accent);border-top:1px solid var(--hairline);margin-top:6px;padding-top:6px;font-size:.67rem;font-weight:600}@media (width>=769px) and (width<=1024px){.editor{width:240px;min-width:210px}header{gap:8px;padding:8px 14px}.btn-play,.btn-play-fs{padding:7px 14px;font-size:.8rem}}@media (width<=768px){header{gap:6px;padding:8px 10px}header h1{font-size:.8rem}.btn-back-dashboard span,.btn-back-dashboard{padding:5px 8px;font-size:.75rem}.header-btns{flex-wrap:nowrap;gap:4px;padding-bottom:2px;overflow-x:auto}.header-btns::-webkit-scrollbar{display:none}.btn-play,.btn-play-fs{border-radius:7px;padding:6px 10px;font-size:.75rem}.btn-secondary{padding:6px 8px;font-size:.75rem}.ui-mode-switch{flex-shrink:0}.workspace{flex-direction:column;overflow:hidden}.editor{border-right:none;border-top:1px solid var(--hairline);flex-shrink:0;order:2;height:auto;max-height:42vh;overflow:hidden;width:100%!important;min-width:100%!important;max-width:100%!important}.editor.collapsed{border-top:none!important;max-height:0!important;overflow:hidden!important}.stage-wrap{flex:1;order:1;width:100%;min-height:0}.stage-viewport{min-height:220px;padding:8px}}@media (width<=480px){header{gap:4px;padding:6px 8px}header h1,.btn-play .play-label-text,.btn-play-fs .play-label-text{display:none}.btn-play,.btn-play-fs{justify-content:center;min-width:36px;padding:6px 10px}.stage-viewport{min-height:180px;padding:4px}.editor{max-height:38vh}}#mainApp{flex-direction:column;flex:1;height:100dvh;display:flex;overflow:hidden}.dashboard-view{flex-direction:column;gap:40px;max-width:1200px;margin:0 auto;padding:40px 20px;animation:.4s ease-out dashFadeIn;display:flex;position:relative}@keyframes dashFadeIn{0%{opacity:0}to{opacity:1}}.dashboard-hero{text-align:center;margin-bottom:20px}.dashboard-logo{justify-content:center;align-items:center;gap:12px;margin-bottom:12px;display:flex}.dashboard-logo .logo-icon{width:42px;height:42px;color:var(--accent)}.dashboard-logo h1{margin:0;font-size:2.5rem}.dashboard-subtitle{color:var(--muted);max-width:600px;margin:0 auto;font-size:1.1rem}.dashboard-section{flex-direction:column;gap:20px;display:flex}.section-title{color:var(--text);align-items:center;gap:8px;margin:0;font-size:1.3rem;font-weight:700;display:flex}.section-title svg{color:var(--accent);width:20px;height:20px}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;display:grid}.project-card{background:var(--panel);border:1px solid var(--border);cursor:pointer;border-radius:16px;flex-direction:column;justify-content:space-between;min-height:180px;padding:20px;transition:transform .2s,border-color .2s,box-shadow .2s;display:flex;position:relative;box-shadow:0 4px 12px #0000001a}.project-card:hover{border-color:var(--accent);box-shadow:var(--elev);transform:translateY(-4px)}.project-card-meta{flex-direction:column;gap:8px;display:flex}.project-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin:0;padding-right:28px;font-size:1.1rem;font-weight:700;overflow:hidden}.project-badges{flex-wrap:wrap;gap:6px;display:flex}.project-badge{text-transform:uppercase;border-radius:6px;padding:3px 8px;font-size:.65rem;font-weight:700}.project-badge.theme-badge{background:var(--panel2);color:var(--accent);border:1px solid var(--border)}.project-badge.style-badge{background:var(--accent-alpha);color:var(--accent2)}.project-info{border-top:1px solid var(--hairline);justify-content:space-between;align-items:center;margin-top:15px;padding-top:15px;display:flex}.project-count{color:var(--muted);align-items:center;gap:4px;font-size:.78rem;display:flex}.project-count svg{width:14px;height:14px}.project-date{color:var(--muted);font-size:.7rem}.project-delete{color:var(--muted);cursor:pointer;z-index:10;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;padding:0;transition:background .2s,color .2s;display:flex;position:absolute;top:16px;right:16px}.project-delete:hover{color:#ef4444;background:#ef44441a}.project-delete svg{width:16px;height:16px}.project-card.new-project-card{border:2px dashed var(--border);box-shadow:none;background:0 0;justify-content:center;align-items:center;gap:12px}.project-card.new-project-card:hover{border-color:var(--accent);background:var(--panel)}.new-project-icon{background:var(--panel2);width:48px;height:48px;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;transition:transform .2s,background .2s;display:flex}.project-card.new-project-card:hover .new-project-icon{background:var(--accent);color:#fff;transform:scale(1.1)}.new-project-title{color:var(--text);font-size:1.05rem;font-weight:700}.btn-back-dashboard{margin-right:8px}.theme-dropdown{z-index:100;display:inline-block;position:relative}.theme-dropdown-trigger{background:var(--panel2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:8px;outline:none;align-items:center;gap:8px;padding:6px 14px;font-size:.8rem;font-weight:600;transition:all .2s ease-in-out;display:flex;box-shadow:0 2px 5px #0000001a}.theme-dropdown-trigger:hover:not(:disabled){border-color:var(--accent);background:var(--panel)}.theme-dropdown-trigger .chevron{opacity:.7;transition:transform .2s}.theme-dropdown-trigger .chevron.open{transform:rotate(180deg)}.theme-dropdown-menu{background:var(--panel);border:1px solid var(--border);z-index:210;border-radius:12px;flex-direction:column;gap:12px;width:280px;max-height:400px;padding:12px;display:flex;position:absolute;top:calc(100% + 6px);left:50%;overflow-y:auto;transform:translate(-50%);box-shadow:0 10px 30px #00000059}.theme-group-section{flex-direction:column;gap:6px;display:flex}.theme-group-title{text-transform:uppercase;color:var(--muted);letter-spacing:.08em;border-bottom:1px solid var(--hairline);padding-bottom:3px;padding-left:4px;font-size:.65rem;font-weight:800}.theme-group-options{grid-template-columns:1fr 1fr;gap:4px;display:grid}.theme-option{color:var(--text);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;justify-content:flex-start;align-items:center;gap:6px;width:100%;padding:5px 8px;font-size:.74rem;font-weight:500;transition:all .15s;display:flex}.theme-option:hover{background:var(--panel2);border-color:var(--hairline)}.theme-option.selected{background:color-mix(in srgb, var(--accent) 12%, transparent);border-color:var(--accent);color:var(--accent);font-weight:700}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}.toast{pointer-events:all;border:1px solid #0000;border-radius:10px;align-items:center;gap:10px;min-width:260px;max-width:420px;padding:12px 16px;font-size:.875rem;font-weight:500;animation:.25s cubic-bezier(.34,1.5,.64,1) both toastIn;display:flex;box-shadow:0 8px 32px #00000059}@keyframes toastIn{0%{opacity:0;transform:translate(40px)scale(.95)}to{opacity:1;transform:none}}.toast-icon{flex-shrink:0;width:18px;height:18px}.toast-msg{flex:1;line-height:1.4}.toast-close{cursor:pointer;opacity:.6;color:inherit;background:0 0;border:none;border-radius:4px;align-items:center;padding:2px;display:flex}.toast-close:hover{opacity:1}.toast-close svg{width:14px;height:14px}.toast-success{color:#bbf7d0;background:#14532d;border-color:#16a34a55}.toast-error{color:#fecaca;background:#450a0a;border-color:#dc262655}.toast-warning{color:#fed7aa;background:#431407;border-color:#ea580c55}.toast-info{color:#bfdbfe;background:#0c1a3b;border-color:#3b82f655}.modal-sm{width:min(440px,95vw)}.modal-body{flex-direction:column;gap:12px;padding:20px;display:flex}.modal-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.confirm-message{color:var(--muted);margin:0;font-size:.9rem;line-height:1.6}.field-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.field-input{border:1px solid var(--hairline);background:var(--panel2);width:100%;color:var(--text);box-sizing:border-box;border-radius:8px;padding:10px 12px;font-size:.925rem;transition:border-color .15s}.field-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 18%, transparent);outline:none}.field-input-error{border-color:#dc2626!important;box-shadow:0 0 0 3px #dc262626!important}.field-error{color:#f87171;margin:0;font-size:.8rem}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-size:.875rem;font-weight:600;transition:opacity .15s;display:inline-flex}.btn-primary:hover{opacity:.85}.btn-secondary{background:var(--panel2);color:var(--text);border:1px solid var(--hairline);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-size:.875rem;font-weight:600;transition:background .15s;display:inline-flex}.btn-secondary:hover{background:var(--hairline)}.btn-danger{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-size:.875rem;font-weight:600;transition:opacity .15s;display:inline-flex}.btn-danger:hover{opacity:.85}.card-customize-btn{color:#ffffffe6;cursor:pointer;opacity:0;z-index:20;letter-spacing:.03em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b8;border:1px solid #ffffff2e;border-radius:6px;align-items:center;gap:5px;padding:5px 10px;font-size:11px;font-weight:600;transition:opacity .18s,background .15s,border-color .15s;display:inline-flex;position:absolute;bottom:10px;right:10px}.stage-card:hover .card-customize-btn{opacity:1}.card-customize-btn:hover{border-color:var(--accent);background:#141428e6}.card-hover-actions{z-index:20;opacity:0;gap:6px;transition:opacity .18s;display:flex;position:absolute;bottom:10px;right:10px}.card-hover-actions .card-customize-btn{opacity:1;position:static}.layout-toolbar-btn{cursor:pointer;letter-spacing:.03em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid #fff3;border-radius:6px;align-items:center;gap:4px;padding:5px 10px;font-size:11px;font-weight:600;transition:opacity .15s;display:inline-flex}.stage-card.layout-editing{outline-offset:3px;border-radius:14px;outline:2px dashed #ffffff4d}.dashboard-user-section{z-index:100;position:absolute;top:40px;right:20px}.user-profile-btn{background:var(--panel);border:1px solid var(--border);cursor:pointer;color:var(--text);border-radius:30px;align-items:center;gap:10px;padding:6px 14px 6px 6px;font-family:inherit;font-size:14px;font-weight:500;transition:background .2s,border-color .2s,transform .2s;display:flex;box-shadow:0 4px 12px #00000014}.user-profile-btn:hover{background:var(--panel2);border-color:var(--muted);transform:translateY(-1px)}.user-avatar{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:600;display:flex;box-shadow:0 2px 8px #7c5cff4d}.user-name{white-space:nowrap;text-overflow:ellipsis;max-width:120px;overflow:hidden}.chevron-icon{width:16px;height:16px;color:var(--muted)}.user-dropdown-menu{background:var(--panel);border:1px solid var(--border);width:180px;box-shadow:var(--elev), 0 10px 40px #0000001f;border-radius:12px;flex-direction:column;gap:4px;padding:6px;animation:.2s ease-out slideDown;display:flex;position:absolute;top:calc(100% + 8px);right:0}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{width:100%;color:var(--text);text-align:left;white-space:nowrap;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:flex-start;align-items:center;gap:10px;padding:9px 12px;font-family:inherit;font-size:.85rem;font-weight:500;transition:background .15s,color .15s;display:flex}.dropdown-item:hover{background:var(--panel2)}.dropdown-item .item-icon{color:var(--muted);flex-shrink:0}.dropdown-item:hover .item-icon{color:var(--accent)}.dropdown-item.logout{color:#ef4444}.dropdown-item.logout:hover{background:#ef44441f}.dropdown-item.logout .item-icon{color:#ef4444}@media (width<=1024px){.dashboard-view{gap:28px;padding-top:80px}.dashboard-logo h1{font-size:2.2rem}.dashboard-subtitle{font-size:1.05rem}}@media (width<=768px){.dashboard-view{gap:24px;padding:80px 16px 32px}.dashboard-user-section{top:20px;right:16px}.dashboard-logo h1{font-size:2rem}.dashboard-logo .logo-icon{width:34px;height:34px}.dashboard-subtitle{font-size:1rem}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.project-card{min-height:150px;padding:16px}}@media (width<=480px){.user-profile-btn{border-radius:50%!important;padding:6px!important}.user-name,.chevron-icon{display:none}.user-dropdown-menu{width:200px}.dashboard-logo h1{font-size:1.6rem}.projects-grid{flex-direction:column;align-items:center;gap:16px;display:flex}.project-card{border-radius:16px;width:100%;max-width:340px;min-height:140px;padding:16px 20px}.project-title{text-align:left;padding-right:24px;font-size:1.05rem}.project-badge{padding:3px 8px;font-size:.65rem}.project-info{flex-direction:row;justify-content:space-between;align-items:center;gap:8px;margin-top:14px;padding-top:14px}.project-delete{width:28px;height:28px;top:12px;right:12px}.new-project-icon{width:44px;height:44px}.new-project-title{font-size:1.05rem}}.account-settings-modal{max-width:480px!important}.account-tabs{border-bottom:1px solid var(--border);gap:16px;margin-bottom:20px;display:flex}.tab-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:8px;padding:10px 4px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.tab-btn.active{color:#7c5cff;border-bottom-color:#7c5cff}:root{--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-8:32px;--sp-10:40px;--font-ui:"Inter", "Segoe UI", system-ui, -apple-system, sans-serif;--text-xs:.688rem;--text-sm:.75rem;--text-base:.8125rem;--text-md:.875rem;--text-lg:1rem;--text-xl:1.125rem;--r-sm:4px;--r-md:8px;--r-lg:12px;--r-xl:16px;--r-2xl:20px;--r-full:9999px;--shadow-sm:0 1px 3px #00000026, 0 1px 2px #0003;--shadow-md:0 4px 12px #00000040, 0 2px 6px #00000026;--shadow-lg:0 10px 30px #00000059, 0 4px 12px #0003;--shadow-xl:0 20px 50px #00000073, 0 8px 20px #00000040;--shadow-glow:0 0 0 1px color-mix(in srgb, var(--accent) 30%, transparent), 0 4px 20px color-mix(in srgb, var(--accent) 20%, transparent);--t-fast:.12s cubic-bezier(.4, 0, .2, 1);--t-base:.2s cubic-bezier(.4, 0, .2, 1);--t-slow:.35s cubic-bezier(.4, 0, .2, 1);--t-spring:.4s cubic-bezier(.34, 1.56, .64, 1);--topbar-h:52px;--left-w:280px;--left-w-collapsed:0px;--right-w:260px;--right-w-collapsed:0px;--studio-topbar:var(--panel);--studio-left:var(--panel);--studio-right:var(--panel);--studio-canvas:var(--viewport-bg);--accent-10:color-mix(in srgb, var(--accent) 10%, transparent);--accent-20:color-mix(in srgb, var(--accent) 20%, transparent);--accent-30:color-mix(in srgb, var(--accent) 30%, transparent)}#mainApp{font-family:var(--font-ui);background:var(--bg);height:100dvh;color:var(--text);flex-direction:column;display:flex;overflow:hidden}.studio-topbar{height:var(--topbar-h);background:var(--studio-topbar);border-bottom:1px solid var(--hairline);align-items:center;gap:var(--sp-2);padding:0 var(--sp-3);z-index:300;transition:background var(--t-slow), border-color var(--t-slow);flex-shrink:0;display:flex;position:relative}.topbar-back{align-items:center;gap:var(--sp-2);padding:var(--sp-1) var(--sp-3);border-radius:var(--r-md);color:var(--muted);font-size:var(--text-sm);cursor:pointer;transition:all var(--t-base);white-space:nowrap;font-weight:500;font-family:var(--font-ui);background:0 0;border:1px solid #0000;flex-shrink:0;display:flex}.topbar-back:hover{background:var(--panel2);border-color:var(--border);color:var(--text)}.topbar-back:active{transform:scale(.97)}.topbar-divider{background:var(--hairline);flex-shrink:0;width:1px;height:20px}.topbar-project-name{font-size:var(--text-md);color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex-shrink:1;max-width:200px;font-weight:600;overflow:hidden}.topbar-save-indicator{align-items:center;gap:var(--sp-1);font-size:var(--text-xs);color:var(--muted);opacity:0;transition:opacity var(--t-base);flex-shrink:0;display:flex}.topbar-save-indicator.visible{opacity:1}.topbar-save-indicator .save-dot{background:#10b981;border-radius:50%;width:6px;height:6px;animation:1.5s ease-in-out infinite save-pulse}@keyframes save-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.topbar-spacer{flex:1;min-width:0}.topbar-mode-switch{background:var(--panel2);border:1px solid var(--border);border-radius:var(--r-md);flex-shrink:0;align-items:center;gap:2px;padding:3px;display:flex}.topbar-mode-btn{color:var(--muted);cursor:pointer;width:26px;height:26px;transition:all var(--t-fast);font-family:var(--font-ui);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:0;display:flex}.topbar-mode-btn:hover{background:var(--hairline);color:var(--text)}.topbar-mode-btn.active{background:var(--accent);color:#fff}.topbar-mode-btn:active{transform:scale(.9)}.topbar-play-group{align-items:center;gap:var(--sp-2);flex-shrink:0;display:flex}.btn-topbar-play{align-items:center;gap:var(--sp-2);padding:7px var(--sp-4);border-radius:var(--r-md);background:linear-gradient(135deg, var(--accent2), var(--accent));color:#fff;font-size:var(--text-sm);cursor:pointer;font-weight:600;font-family:var(--font-ui);transition:all var(--t-base);box-shadow:0 2px 12px var(--accent-30);white-space:nowrap;border:none;flex-shrink:0;display:flex}.btn-topbar-play svg{width:13px;height:13px}.btn-topbar-play:hover:not(:disabled){box-shadow:0 4px 20px var(--accent-30);transform:translateY(-1px)}.btn-topbar-play:active{transform:scale(.97)}.btn-topbar-play:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}.btn-topbar-fullplay{align-items:center;gap:var(--sp-2);padding:7px var(--sp-3);border-radius:var(--r-md);color:#fff;font-size:var(--text-sm);cursor:pointer;font-weight:600;font-family:var(--font-ui);transition:all var(--t-base);white-space:nowrap;background:linear-gradient(135deg,#059669,#10b981);border:none;flex-shrink:0;display:flex;box-shadow:0 2px 12px #10b9814d}.btn-topbar-fullplay svg{width:13px;height:13px}.btn-topbar-fullplay:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #10b98173}.btn-topbar-fullplay:active{transform:scale(.97)}.btn-topbar-fullplay:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}.btn-topbar-stop{align-items:center;gap:var(--sp-2);padding:7px var(--sp-3);border-radius:var(--r-md);background:var(--panel2);color:var(--text);border:1px solid var(--border);font-size:var(--text-sm);cursor:pointer;font-weight:600;font-family:var(--font-ui);transition:all var(--t-base);flex-shrink:0;display:flex}.btn-topbar-stop svg{width:13px;height:13px}.btn-topbar-stop:hover:not(:disabled){color:#ef4444;background:#ef444414;border-color:#ef4444}.btn-topbar-stop:disabled{opacity:.45;cursor:not-allowed}.topbar-back svg{width:17px;height:17px}.topbar-mode-btn svg{width:15px;height:15px}.btn-topbar-play svg,.btn-topbar-fullplay svg,.btn-topbar-stop svg{width:16px;height:16px}.studio-workspace{flex:1;min-height:0;display:flex;overflow:hidden}.studio-left{background:var(--studio-left);border-right:1px solid var(--hairline);height:100%;transition:border-color var(--t-slow), background var(--t-slow);flex-direction:column;min-width:0;display:flex;overflow:hidden}.panel-wrap--left.collapsed .studio-left{border-right-color:#0000}.sleft-header{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--hairline);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.sleft-title{font-size:var(--text-sm);color:var(--text);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:var(--sp-2);font-weight:700;display:flex}.sleft-title svg{width:14px;height:14px;color:var(--accent)}.sleft-count{font-size:var(--text-xs);color:var(--muted);background:var(--panel2);border:1px solid var(--hairline);border-radius:var(--r-full);padding:1px 8px;font-weight:600}.sleft-io{gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--hairline);flex-shrink:0;display:flex}.sleft-io-btn{justify-content:center;align-items:center;gap:var(--sp-1);border-radius:var(--r-md);border:1px solid var(--hairline);color:var(--muted);font-size:var(--text-xs);cursor:pointer;transition:all var(--t-fast);font-weight:600;font-family:var(--font-ui);background:0 0;flex:1;padding:6px;display:flex}.sleft-io-btn svg{width:13px;height:13px}.sleft-io-btn:hover:not(:disabled){background:var(--accent-10);border-color:var(--accent);color:var(--accent)}.sleft-io-btn:disabled{opacity:.35;cursor:not-allowed}.sleft-cards{min-height:0;padding:var(--sp-2);overscroll-behavior:contain;flex-direction:column;flex:1;gap:0;display:flex;overflow-y:auto}.sleft-cards::-webkit-scrollbar{width:3px}.sleft-cards::-webkit-scrollbar-track{background:0 0}.sleft-cards::-webkit-scrollbar-thumb{background:var(--hairline);border-radius:3px}.sleft-cards::-webkit-scrollbar-thumb:hover{background:var(--border)}.sleft-empty{justify-content:center;align-items:center;gap:var(--sp-3);padding:var(--sp-10) var(--sp-4);text-align:center;color:var(--muted);flex-direction:column;display:flex}.sleft-empty-icon{border-radius:var(--r-xl);background:var(--panel2);width:48px;height:48px;color:var(--muted);opacity:.6;justify-content:center;align-items:center;display:flex}.sleft-empty-icon svg{width:22px;height:22px}.sleft-empty-title{font-size:var(--text-base);color:var(--text);opacity:.6;font-weight:600}.sleft-empty-desc{font-size:var(--text-sm);color:var(--muted);max-width:180px;line-height:1.5}.scard-item{border-radius:var(--r-md);border:1px solid var(--hairline);background:var(--panel2);transition:border-color var(--t-fast), background var(--t-fast), box-shadow var(--t-fast);cursor:pointer;flex-shrink:0;margin-bottom:2px;overflow:hidden}.scard-item:hover{border-color:var(--border)}.scard-item.active{border-color:var(--accent);background:var(--accent-10);box-shadow:0 0 0 1px var(--accent-20)}.scard-item:last-child{margin-bottom:0}.scard-header{align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-2) var(--sp-1) var(--sp-2);display:flex}.scard-rank{border-radius:var(--r-sm);background:var(--panel);border:1px solid var(--hairline);width:20px;height:20px;font-size:var(--text-xs);color:var(--muted);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.scard-color-swatch{cursor:pointer;width:16px;height:16px;transition:transform var(--t-fast);border:none;border-radius:3px;flex-shrink:0;padding:0}.scard-color-swatch:hover{transform:scale(1.2)}.scard-name-preview{font-size:var(--text-sm);color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-weight:600;overflow:hidden}.scard-value-preview{font-size:var(--text-xs);color:var(--accent);flex-shrink:0;font-weight:700}.scard-delete{border-radius:var(--r-sm);width:22px;height:22px;color:var(--muted);cursor:pointer;transition:all var(--t-fast);font-family:var(--font-ui);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.scard-delete svg{width:12px;height:12px}.scard-delete:hover{color:#ef4444;background:#ef44441f}.scard-expand-chevron{display:none}.scard-body{padding:0 var(--sp-2) var(--sp-2);gap:var(--sp-1);flex-direction:column;display:flex}.scard-field{align-items:center;gap:var(--sp-2);grid-template-columns:38px 1fr;display:grid}.scard-field label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:700}.scard-field input{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);font-size:var(--text-sm);padding:4px var(--sp-2);font-family:var(--font-ui);width:100%;transition:border-color var(--t-fast), box-shadow var(--t-fast);outline:none}.scard-field input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-20);background:var(--panel)}.scard-field input:disabled{opacity:.45;cursor:not-allowed}.scard-insert-zone{align-items:center;gap:var(--sp-2);height:20px;padding:0 var(--sp-2);opacity:0;transition:opacity var(--t-fast);cursor:pointer;flex-shrink:0;display:flex}.scard-item:hover+.scard-insert-zone,.scard-insert-zone:hover{opacity:1}.scard-insert-line{background:var(--accent);opacity:.5;border-radius:1px;flex:1;height:1px}.scard-insert-btn{border:1.5px solid var(--accent);background:var(--panel);width:16px;height:16px;color:var(--accent);cursor:pointer;transition:all var(--t-fast);font-size:12px;line-height:1;font-family:var(--font-ui);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.scard-insert-zone:hover .scard-insert-btn{background:var(--accent);color:#fff}.sleft-footer{border-top:1px solid var(--hairline);padding:var(--sp-2) var(--sp-3);gap:var(--sp-2);flex-shrink:0;display:flex}.sleft-clear-btn{align-items:center;gap:var(--sp-1);padding:7px var(--sp-3);border-radius:var(--r-md);border:1px solid var(--border);color:var(--muted);font-size:var(--text-sm);cursor:pointer;transition:all var(--t-fast);font-weight:600;font-family:var(--font-ui);background:0 0;flex-shrink:0;display:flex}.sleft-clear-btn svg{width:12px;height:12px}.sleft-clear-btn:hover:not(:disabled){color:#ef4444;background:#ef444414;border-color:#ef4444}.sleft-clear-btn:disabled{opacity:.35;cursor:not-allowed}.sleft-add-btn{justify-content:center;align-items:center;gap:var(--sp-2);border-radius:var(--r-md);background:linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 70%, var(--accent2)));color:#fff;font-size:var(--text-sm);cursor:pointer;transition:all var(--t-base);font-weight:700;font-family:var(--font-ui);box-shadow:0 2px 8px var(--accent-20);border:none;flex:1;padding:7px;display:flex}.sleft-add-btn svg{width:13px;height:13px}.sleft-add-btn:hover:not(:disabled){box-shadow:0 4px 16px var(--accent-30);transform:translateY(-1px)}.sleft-add-btn:active{transform:scale(.97)}.sleft-add-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}.studio-canvas-area{background:var(--studio-canvas);min-width:0;transition:background var(--t-slow);flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.studio-canvas-area:before{content:"";pointer-events:none;z-index:0;background-image:radial-gradient(circle,#ffffff0a 1px,#0000 1px);background-size:28px 28px;position:absolute;inset:0}[data-mode=light] .studio-canvas-area:before{background-image:radial-gradient(circle,#0000000f 1px,#0000 1px)}.studio-stage-viewport{z-index:1;width:100%;height:100%;padding:var(--sp-6);box-sizing:border-box;justify-content:center;align-items:center;display:flex;position:relative}:-webkit-any(.studio-stage-viewport:fullscreen,.studio-stage-viewport:-webkit-full-screen){background:#000!important;padding:0!important}:is(.studio-stage-viewport:fullscreen,.studio-stage-viewport:fullscreen){background:#000!important;padding:0!important}.studio-stage-viewport:fullscreen:before{display:none}.studio-stage-viewport:-webkit-full-screen:before{display:none}.stage-empty{justify-content:center;align-items:center;gap:var(--sp-4);color:var(--muted);pointer-events:none;z-index:5;flex-direction:column;animation:.4s ease-out fadeInUp;display:flex;position:absolute;inset:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.stage-empty-icon{border-radius:var(--r-xl);background:var(--panel);border:1px solid var(--hairline);opacity:.5;justify-content:center;align-items:center;width:64px;height:64px;display:flex}.stage-empty-icon svg{width:28px;height:28px}.stage-empty-title{font-size:var(--text-lg);color:var(--text);opacity:.4;font-weight:700}.stage-empty-sub{font-size:var(--text-sm);opacity:.4;text-align:center;line-height:1.5}.studio-right{background:var(--studio-right);border-left:1px solid var(--hairline);height:100%;transition:border-color var(--t-slow), background var(--t-slow);flex-direction:column;min-width:0;display:flex;overflow:hidden}.panel-wrap--right.collapsed .studio-right{border-left-color:#0000}.sright-tabs{border-bottom:1px solid var(--hairline);padding:var(--sp-2) var(--sp-2) 0;flex-shrink:0;gap:2px;display:flex}.sright-tab{padding:7px var(--sp-2) 8px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;cursor:pointer;transition:all var(--t-fast);font-size:9px;font-weight:700;font-family:var(--font-ui);border-radius:var(--r-sm) var(--r-sm) 0 0;background:0 0;border:none;border-bottom:2px solid #0000;flex-direction:column;flex:1;align-items:center;gap:3px;margin-bottom:-1px;display:flex}.sright-tab svg{width:14px;height:14px}.sright-tab:hover{color:var(--text);background:var(--hairline)}.sright-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:var(--accent-10)}.sright-content{min-height:0;padding:var(--sp-3);gap:var(--sp-4);overscroll-behavior:contain;flex-direction:column;flex:1;display:flex;overflow-y:auto}.sright-content::-webkit-scrollbar{width:3px}.sright-content::-webkit-scrollbar-track{background:0 0}.sright-content::-webkit-scrollbar-thumb{background:var(--hairline);border-radius:3px}.sprop-section{gap:var(--sp-3);flex-direction:column;display:flex}.sprop-section-title{font-size:var(--text-xs);color:var(--muted);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:var(--sp-2);padding-bottom:var(--sp-2);border-bottom:1px solid var(--hairline);font-weight:700;display:flex}.sprop-section-title svg{width:12px;height:12px;color:var(--accent)}.sprop-row{flex-direction:column;gap:5px;display:flex}.sprop-label{font-size:var(--text-xs);color:var(--muted);align-items:center;gap:var(--sp-1);font-weight:600;display:flex}.sprop-label svg{width:11px;height:11px}.sprop-select-wrap{position:relative}.sprop-select-trigger{align-items:center;gap:var(--sp-2);width:100%;padding:7px var(--sp-3);border-radius:var(--r-md);border:1px solid var(--border);background:var(--input-bg);color:var(--text);font-size:var(--text-sm);cursor:pointer;font-weight:500;font-family:var(--font-ui);transition:all var(--t-fast);text-align:left;display:flex}.sprop-select-trigger:hover:not(:disabled){border-color:var(--accent);background:var(--panel2)}.sprop-select-trigger:disabled{opacity:.45;cursor:not-allowed}.sprop-select-trigger .sprop-select-icon{opacity:.7;flex-shrink:0;width:13px;height:13px}.sprop-select-trigger .sprop-select-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.sprop-select-trigger .sprop-chevron{width:12px;height:12px;color:var(--muted);transition:transform var(--t-fast);flex-shrink:0}.sprop-select-trigger .sprop-chevron.open{transform:rotate(180deg)}.sprop-select-menu{background:var(--panel);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);z-index:500;max-height:260px;padding:var(--sp-1);animation:.15s ease-out dropIn;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}@keyframes dropIn{0%{opacity:0;transform:translateY(-6px)scale(.98)}to{opacity:1;transform:none}}.sprop-select-menu::-webkit-scrollbar{width:3px}.sprop-select-menu::-webkit-scrollbar-thumb{background:var(--hairline);border-radius:3px}.sprop-opt-group{margin-bottom:var(--sp-2)}.sprop-opt-group:last-child{margin-bottom:0}.sprop-opt-group-title{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;padding:4px var(--sp-2) 5px;border-bottom:1px solid var(--hairline);margin-bottom:3px;font-size:10px;font-weight:800}.sprop-opts-grid{grid-template-columns:1fr 1fr;gap:2px;display:grid}.sprop-opts-grid.single-col{grid-template-columns:1fr}.sprop-opt{align-items:center;gap:var(--sp-2);padding:6px var(--sp-2);border-radius:var(--r-sm);color:var(--text);font-size:var(--text-sm);cursor:pointer;transition:all var(--t-fast);font-weight:500;font-family:var(--font-ui);text-align:left;background:0 0;border:1px solid #0000;display:flex}.sprop-opt svg{opacity:.7;flex-shrink:0;width:12px;height:12px}.sprop-opt:hover{background:var(--panel2);border-color:var(--hairline)}.sprop-opt.selected{background:var(--accent-10);border-color:var(--accent);color:var(--accent);font-weight:600}.sprop-opt.selected svg{opacity:1}.sprop-colors-row{gap:var(--sp-2);align-items:center;display:flex}.sprop-color-item{flex-direction:column;flex:1;gap:4px;display:flex}.sprop-color-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:10px;font-weight:600}.sprop-color-wrap{align-items:center;gap:var(--sp-2);padding:6px var(--sp-2);border-radius:var(--r-md);border:1px solid var(--border);background:var(--input-bg);cursor:pointer;transition:border-color var(--t-fast);display:flex;position:relative}.sprop-color-wrap:hover{border-color:var(--accent)}.sprop-color-swatch{border-radius:var(--r-sm);cursor:pointer;border:1.5px solid #ffffff26;flex-shrink:0;width:20px;height:20px}.sprop-color-hex{font-size:var(--text-xs);color:var(--muted);font-family:SF Mono,Fira Code,monospace;font-weight:600}.sprop-color-input{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.studio-mobile-nav{z-index:200;padding:var(--sp-2) var(--sp-3) calc(var(--sp-2) + env(safe-area-inset-bottom,0px));background:var(--panel);border-top:1px solid var(--hairline);flex-shrink:0;justify-content:center;display:none}.mobile-nav-tabs{border-radius:var(--r-2xl);background:var(--panel2);border:1px solid var(--hairline);box-shadow:var(--shadow-md);gap:3px;padding:5px;display:inline-flex}.mobile-nav-tab{border-radius:var(--r-xl);width:66px;color:var(--muted);cursor:pointer;transition:background var(--t-fast), color var(--t-fast), transform var(--t-fast);font-size:10px;font-weight:600;font-family:var(--font-ui);background:0 0;border:none;flex-direction:column;flex:none;justify-content:center;align-items:center;gap:3px;padding:8px 4px;display:flex}.mobile-nav-tab svg{width:18px;height:18px}.mobile-nav-tab:active{transform:scale(.94)}.mobile-nav-tab.active{color:#fff;background:var(--accent);box-shadow:0 2px 10px var(--accent-30)}.mobile-dock{background:var(--panel);border-top:1px solid var(--hairline);flex-direction:column;flex:1;min-height:0;display:none;overflow:hidden}.mobile-dock-content{flex-direction:column;flex:1;min-height:0;animation:.26s cubic-bezier(.16,1,.3,1) dockContentIn;display:flex;overflow:hidden}@keyframes dockContentIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.mobile-dock-content{animation:none}}.mobile-dock-content .studio-left,.mobile-dock-content .studio-right{border:none;height:100%}.panel-wrap{flex-shrink:0;position:relative;overflow:visible}.panel-wrap--left{width:var(--left-w);transition:width .32s cubic-bezier(.4,0,.2,1)}.panel-wrap--left.collapsed{width:0}.panel-wrap--right{width:var(--right-w);transition:width .32s cubic-bezier(.4,0,.2,1)}.panel-wrap--right.collapsed{width:0}.panel-wrap .studio-left,.panel-wrap .studio-right{width:100%;position:relative}.panel-edge-tab{z-index:210;background:var(--panel);border:1px solid var(--hairline);width:28px;height:58px;color:var(--muted);cursor:pointer;font-family:var(--font-ui);letter-spacing:.07em;text-transform:uppercase;transition:background var(--t-base), border-color var(--t-base), color var(--t-base), box-shadow var(--t-base);flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:0;font-size:8px;font-weight:700;display:flex;position:absolute;top:20px}.panel-edge-tab svg{flex-shrink:0;width:15px;height:15px}.panel-edge-tab span{writing-mode:vertical-lr;text-orientation:mixed;letter-spacing:.1em;opacity:.65;font-size:8px}.panel-edge-tab:hover{background:var(--panel2);border-color:var(--accent);color:var(--accent);box-shadow:var(--shadow-md)}.panel-edge-tab:active{transform:scaleX(.9)}.panel-tab-chevron{transition:transform .28s cubic-bezier(.4,0,.2,1)}.panel-edge-tab--left{border-radius:0 var(--r-md) var(--r-md) 0;border-left:none;left:auto;right:-28px;box-shadow:3px 0 10px #0000002e}.panel-wrap--left:not(.collapsed) .panel-tab-chevron{transform:rotate(0)}.panel-wrap--left.collapsed .panel-tab-chevron{transform:rotate(180deg)}.panel-edge-tab--right{border-radius:var(--r-md) 0 0 var(--r-md);border-right:none;left:-28px;right:auto;box-shadow:-3px 0 10px #0000002e}.panel-wrap--right:not(.collapsed) .panel-tab-chevron{transform:rotate(0)}.panel-wrap--right.collapsed .panel-tab-chevron{transform:rotate(180deg)}[data-mode=light] .panel-edge-tab{background:#fff;border-color:#e2e8f0}[data-mode=light] .panel-edge-tab--left{box-shadow:3px 0 10px #0f172a17}[data-mode=light] .panel-edge-tab--right{box-shadow:-3px 0 10px #0f172a17}[data-mode=light] .panel-edge-tab:hover{border-color:var(--accent);background:#f8fafc}.panel-scrim{display:none}@media (width<=1024px){.studio-workspace{position:relative}.panel-wrap{z-index:150;background:var(--bg);height:100%;position:absolute;top:0;bottom:0}.panel-wrap:not(.collapsed){box-shadow:var(--shadow-xl)}.panel-wrap--left{left:0}.panel-wrap--right{right:0}.panel-scrim{background:var(--overlay);z-index:140;animation:overlayIn var(--t-base);display:block;position:fixed;inset:0}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.panel-edge-tab{width:34px;height:64px}.scard-delete{width:30px;height:30px}.scard-color-swatch{width:20px;height:20px}.sleft-io-btn{padding:9px}.card-action-btn{padding:6px 10px;font-size:12px}.card-action-btn svg{width:12px;height:12px}}@media (width>=901px) and (width<=1024px){:root{--left-w:300px;--right-w:280px}.topbar-project-name{max-width:220px}}@media (width>=768px) and (width<=900px){:root{--left-w:270px;--right-w:260px}.topbar-project-name{max-width:170px}.btn-topbar-fullplay span{display:none}.btn-topbar-fullplay{padding:7px 10px}}@media (width<=767px){:root{--topbar-h:48px}.panel-wrap,.panel-scrim{display:none}.studio-workspace{flex-direction:column}.studio-canvas-area{min-height:0;padding:var(--sp-3) var(--sp-3) 0;flex:0 auto;align-items:flex-start}.studio-mobile-nav{display:flex}.mobile-dock{min-height:200px;display:flex}.mobile-dock-content .sleft-cards,.mobile-dock-content .sright-content{-webkit-overflow-scrolling:touch}.studio-stage-viewport{aspect-ratio:16/9;width:100%;height:auto;max-height:40vh;padding:var(--sp-2)}.topbar-back{padding:var(--sp-1) var(--sp-2);min-height:40px}.topbar-back span{display:none}.topbar-project-name{max-width:120px;font-size:var(--text-sm)}.topbar-mode-switch,.btn-topbar-fullplay,.btn-topbar-play span,.btn-topbar-stop span{display:none}.btn-topbar-play,.btn-topbar-stop{min-width:44px;min-height:44px;padding:8px 12px}.topbar-panel-toggle{display:none}.scard-header{padding:var(--sp-3) var(--sp-3) var(--sp-2);min-height:44px}.scard-delete{width:36px;height:36px}.scard-color-swatch{width:24px;height:24px}.scard-field input{font-size:var(--text-base);min-height:40px;padding:10px 12px}.scard-expand-chevron{width:18px;height:18px;color:var(--muted);transition:transform var(--t-fast);flex-shrink:0;display:block}.scard-item.expanded .scard-expand-chevron{color:var(--accent);transform:rotate(180deg)}.scard-body{opacity:0;max-height:0;transition:max-height var(--t-base), opacity var(--t-base), padding var(--t-base);padding-top:0;padding-bottom:0;overflow:hidden}.scard-item.expanded .scard-body{opacity:1;max-height:320px;padding-bottom:var(--sp-2)}.sleft-io-btn{min-height:44px;padding:11px}.sleft-add-btn,.sleft-clear-btn{min-height:46px}.sright-tabs{padding-top:var(--sp-2)}.sright-tab{padding:12px var(--sp-2);min-height:48px;font-size:10px}.sprop-section{padding:0 var(--sp-1)}.sprop-select-trigger{padding:11px var(--sp-3);min-height:44px}.sprop-color-swatch{width:32px;height:32px}.card-action-btn{justify-content:center;width:38px;height:38px;padding:10px}.card-action-btn svg{width:18px;height:18px}.card-action-btn span{display:none}.layout-toolbar-btn{justify-content:center;width:38px;height:38px;padding:10px}.layout-toolbar-btn svg{width:18px;height:18px}.layout-toolbar-btn span{display:none}}@media (width<=480px){.topbar-project-name{max-width:90px}.studio-stage-viewport{padding:var(--sp-2)}.topbar-save-indicator{display:none}.sprop-opts-grid{grid-template-columns:1fr}}@media (height<=500px) and (orientation:landscape){:root{--topbar-h:44px;--left-w:240px;--right-w:240px}.studio-mobile-nav,.mobile-dock{display:none!important}.studio-workspace{flex-direction:row;position:relative}.panel-wrap{z-index:150;background:var(--bg);height:100%;position:absolute;top:0;bottom:0;display:block!important}.panel-wrap:not(.collapsed){box-shadow:var(--shadow-xl)}.panel-wrap--left{left:0}.panel-wrap--right{right:0}.panel-scrim{display:block}.studio-canvas-area{padding:var(--sp-2);flex:1;align-items:center}.studio-stage-viewport{aspect-ratio:auto;height:100%;padding:var(--sp-2)}.topbar-back span{display:none}.topbar-back{padding:var(--sp-1) var(--sp-2)}.topbar-project-name{max-width:110px;font-size:var(--text-sm)}.topbar-mode-switch,.btn-topbar-fullplay,.btn-topbar-play span,.btn-topbar-stop span{display:none}.btn-topbar-play,.btn-topbar-stop{padding:6px 10px}.topbar-save-indicator{display:none}}@media (width>=1600px){:root{--left-w:300px;--right-w:280px}}.studio-skeleton{background:var(--bg);flex-direction:column;height:100vh;display:flex}.skeleton-topbar{height:var(--topbar-h);background:var(--panel);border-bottom:1px solid var(--hairline);align-items:center;gap:var(--sp-3);padding:0 var(--sp-4);display:flex}.skeleton-block{border-radius:var(--r-md);background:var(--panel2);animation:1.4s ease-in-out infinite skelPulse}@keyframes skelPulse{0%,to{opacity:.6}50%{opacity:.3}}.kbd{background:var(--panel2);border:1px solid var(--border);color:var(--muted);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:1px 5px;font-family:SF Mono,Fira Code,monospace;font-size:10px;font-weight:700;line-height:1.4;display:inline-flex}#playOverlay{background:color-mix(in srgb, var(--stage-bg) 88%, transparent);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);justify-content:center;align-items:center;gap:var(--sp-4);z-index:100;border-radius:inherit;flex-direction:column;display:none;position:absolute;inset:0}.play-label{color:var(--muted);font-size:var(--text-sm);letter-spacing:.12em;text-transform:uppercase;font-weight:600}.play-count{color:var(--accent);text-shadow:0 0 40px var(--accent-30);font-size:5rem;font-weight:900;line-height:1;font-family:var(--font-ui);animation:.7s ease-in-out infinite count-pulse}@keyframes count-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.card-hover-actions{z-index:20;opacity:0;transition:opacity var(--t-fast);gap:5px;display:flex;position:absolute;bottom:8px;right:8px}.stage-card:hover .card-hover-actions,.stage-card.actions-revealed .card-hover-actions{opacity:1}.card-action-btn{color:#ffffffe6;cursor:pointer;transition:all var(--t-fast);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);font-size:11px;font-weight:600;font-family:var(--font-ui);background:#000000bf;border:1px solid #ffffff26;border-radius:6px;align-items:center;gap:4px;padding:5px 9px;display:inline-flex}.card-action-btn svg{width:11px;height:11px}.card-action-btn:hover{border-color:var(--accent);color:#fff;background:#0a0a1ee6}.layout-edit-toolbar{z-index:30;align-items:center;gap:5px;display:flex;position:absolute;top:8px;right:8px}.layout-toolbar-btn{cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:all var(--t-fast);font-size:11px;font-weight:600;font-family:var(--font-ui);border:1px solid #fff3;border-radius:6px;align-items:center;gap:4px;padding:5px 9px;display:inline-flex}.layout-toolbar-btn svg{width:11px;height:11px}.layout-toolbar-reset{color:#fffc;background:#000000a6;padding:5px 8px}.layout-toolbar-reset:hover{color:#fff;background:#000000e6}.layout-toolbar-done{color:#fff;background:#10b981e6;border-color:#10b98180}.layout-toolbar-done:hover{background:#10b981}.stage-card.layout-editing{outline-offset:3px;border-radius:14px;outline:2px dashed #ffffff4d;overflow:visible}.ceo-select-box{cursor:grab;box-sizing:border-box;pointer-events:auto;transform-origin:50%;border:1.5px dashed #18a0fb73;position:absolute}.ceo-select-box.selected{border:2px solid #18a0fb;box-shadow:0 0 8px #18a0fb4d}.ceo-select-tag{color:#fff;text-transform:uppercase;pointer-events:none;background:#18a0fb;border-radius:3px 3px 3px 0;padding:2px 6px;font-size:9px;font-weight:700;transition:opacity .2s;position:absolute;top:-20px;left:0}.ceo-resize-handle{z-index:10;background:#fff;border:2px solid #18a0fb;border-radius:50%;width:10px;height:10px;position:absolute}.ceo-rh-nw{cursor:nwse-resize;top:-5px;left:-5px}.ceo-rh-ne{cursor:nesw-resize;top:-5px;right:-5px}.ceo-rh-sw{cursor:nesw-resize;bottom:-5px;left:-5px}.ceo-rh-se{cursor:nwse-resize;bottom:-5px;right:-5px}.ceo-toolbar{z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);color:#fff;white-space:nowrap;pointer-events:auto;background:#0f172af2;border:1px solid #ffffff26;border-radius:12px;align-items:center;gap:8px;max-width:calc(100% - 16px);max-height:calc(100% - 16px);padding:6px 12px;display:flex;position:absolute;overflow:auto;transform:translate(-50%);box-shadow:0 10px 30px #00000080,0 4px 12px #0000004d}.ceo-color-swatch{cursor:pointer;border-radius:50%;width:14px;height:14px;padding:0}.ceo-color-input{cursor:pointer;background:0 0;border:none;border-radius:3px;width:16px;height:16px;padding:0}@media (pointer:coarse){.ceo-resize-handle{width:20px;height:20px}.ceo-rh-nw{top:-10px;left:-10px}.ceo-rh-ne{top:-10px;right:-10px}.ceo-rh-sw{bottom:-10px;left:-10px}.ceo-rh-se{bottom:-10px;right:-10px}.ceo-toolbar-btn{width:34px!important;height:34px!important}.ceo-color-swatch{width:22px;height:22px}.ceo-color-input{width:24px;height:24px}.ceo-toolbar{flex-wrap:wrap;gap:10px;padding:8px 14px}}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);color:#eaeaf2;font-size:11px;font-weight:500;font-family:var(--font-ui);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--t-fast);z-index:1000;box-shadow:var(--shadow-md);background:#1a1a2e;border:1px solid #ffffff1a;border-radius:5px;padding:4px 8px;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}[data-tooltip]:hover:after{opacity:1}.stage-viewport{background:var(--viewport-bg);flex:1;justify-content:center;align-items:center;padding:20px;transition:background .35s;display:flex;overflow:hidden}:-webkit-any(.stage-viewport:fullscreen,.stage-viewport:-webkit-full-screen){background:#000!important;padding:0!important}:is(.stage-viewport:fullscreen,.stage-viewport:fullscreen){background:#000!important;padding:0!important}#stage{box-shadow:var(--card-shadow);background:var(--stage-bg);border-radius:16px;transition:background .35s;position:relative;overflow:auto hidden}#stage.playing{overflow:hidden!important}#stage::-webkit-scrollbar{height:8px}#stage::-webkit-scrollbar-track{background:#0000001f;border-bottom-right-radius:16px;border-bottom-left-radius:16px}#stage::-webkit-scrollbar-thumb{background:var(--accent);border:2px solid var(--stage-bg);border-radius:99px}#stage::-webkit-scrollbar-thumb:hover{background:var(--accent2)}.stage-card{will-change:left;-webkit-user-select:none;user-select:none;display:block;position:absolute;top:0;overflow:hidden}.stage-card img{-webkit-user-drag:none;user-drag:none;pointer-events:none}.cardroot{flex-direction:column;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.cimg{object-fit:cover;width:100%;height:100%;display:block}.ph{opacity:.5;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.badge{text-align:center;clip-path:polygon(0 0,100% 0,100% 80%,50% 100%,0 80%);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:100%;display:flex}.badge-rank{opacity:.85;margin-bottom:2px;font-weight:800;line-height:1}.badge-value{text-shadow:0 2px 10px #00000059;font-weight:900;line-height:1}.badge-unit{opacity:.9;margin-top:3px;font-weight:600}.name-strip{text-align:center;flex-shrink:0;justify-content:center;align-items:center;width:100%;padding:0 6px;font-weight:700;display:flex}.card-image-area{flex:1;width:100%;min-height:0;overflow:hidden}.corp-accent{flex-shrink:0}.corp-img{flex:1;min-height:0;position:relative;overflow:hidden}.corp-body{background:var(--card-surface);flex-direction:column;flex-shrink:0;display:flex}.edi-img{flex-shrink:0;position:relative;overflow:hidden}.edi-body{background:var(--card-surface);flex-direction:column;flex:1;justify-content:center;min-height:0;display:flex}.edi-serif{font-family:Georgia,Times New Roman,serif}.bar-track{background:var(--card-hairline);overflow:hidden}.bar-fill{border-radius:inherit;height:100%;transition:width .5s cubic-bezier(.2,.7,.2,1)}@keyframes podium-rank-pop{0%,80%,to{transform:scale(1)}88%{transform:scale(1.06)}}.podium-rank-num{animation:5s ease-in-out infinite podium-rank-pop;display:inline-block}@keyframes podium-stripe-pulse{0%,to{opacity:.85}50%{opacity:1}}.podium-stripe{animation:3s ease-in-out infinite podium-stripe-pulse}@keyframes glow-pulse{0%,to{opacity:.8}50%{opacity:1}}.glow-ring{animation:2.6s ease-in-out infinite glow-pulse}@keyframes crystal-shimmer{0%{opacity:0;left:-55%}12%{opacity:1}48%{opacity:0;left:130%}to{opacity:0;left:130%}}.crystal-shine{pointer-events:none;z-index:4;background:linear-gradient(90deg,#0000,#ffffff38,#0000);width:40%;animation:6s ease-in-out infinite crystal-shimmer;position:absolute;top:0;bottom:0;transform:skew(-18deg)}@keyframes nature-float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.nature-inner{animation:6s ease-in-out infinite nature-float}@keyframes entry-fade-scale{0%{opacity:0;transform:scale(.7)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.entry-fade-scale{animation:.55s cubic-bezier(.34,1.56,.64,1) forwards entry-fade-scale}@keyframes entry-slide-up{0%{opacity:0;transform:translateY(120px)}to{opacity:1;transform:translateY(0)}}.entry-slide-up{animation:.55s cubic-bezier(.16,1,.3,1) forwards entry-slide-up}@keyframes entry-flip-in{0%{opacity:0;transform:perspective(600px)rotateY(-75deg)scale(.95)}to{opacity:1;transform:perspective(600px)rotateY(0)scale(1)}}.entry-flip-in{transform-origin:0;animation:.65s cubic-bezier(.16,1,.3,1) forwards entry-flip-in}@keyframes entry-rotate-in{0%{opacity:0;transform:rotate(-180deg)scale(.3)}to{opacity:1;transform:rotate(0)scale(1)}}.entry-rotate-in{animation:.65s cubic-bezier(.34,1.56,.64,1) forwards entry-rotate-in}@keyframes entry-zoom-in{0%{opacity:0;transform:scale(.1)}to{opacity:1;transform:scale(1)}}.entry-zoom-in{animation:.55s cubic-bezier(.34,1.56,.64,1) forwards entry-zoom-in}@keyframes entry-blur-in{0%{opacity:0;filter:blur(15px);transform:scale(.95)}to{opacity:1;filter:blur();transform:scale(1)}}.entry-blur-in{animation:.65s cubic-bezier(.16,1,.3,1) forwards entry-blur-in}@keyframes entry-slide-right{0%{opacity:0;transform:translate(-150px)}to{opacity:1;transform:translate(0)}}.entry-slide-right{animation:.55s cubic-bezier(.16,1,.3,1) forwards entry-slide-right}@keyframes entry-hinge-drop{0%{opacity:0;transform-origin:0 0;transform:translateY(-150px)rotate(-10deg)}50%{transform-origin:0 0;transform:rotate(4deg)}to{opacity:1;transform-origin:0 0;transform:translateY(0)rotate(0)}}.entry-hinge-drop{animation:.75s cubic-bezier(.175,.885,.32,1.275) forwards entry-hinge-drop}#playOverlay{background:color-mix(in srgb, var(--stage-bg) 88%, transparent);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;flex-direction:column;justify-content:center;align-items:center;gap:14px;display:none;position:absolute;inset:0}#playOverlay.active{display:flex}.play-label{color:var(--muted);letter-spacing:.12em;text-transform:uppercase;font-size:.85rem}.play-count{color:var(--accent);text-shadow:0 0 40px color-mix(in srgb, var(--accent) 70%, transparent);font-size:5rem;font-weight:900;line-height:1;animation:.7s ease-in-out infinite count-pulse}.empty-stage{color:var(--muted);pointer-events:none;flex-direction:column;justify-content:center;align-items:center;gap:10px;font-size:.88rem;display:flex;position:absolute;inset:0}.empty-stage .icon{opacity:.25;font-size:3rem}@media (width<=768px){.stage-controls{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:7px;padding:6px 10px;overflow-x:auto}.stage-controls::-webkit-scrollbar{display:none}.stage-controls label{white-space:nowrap;font-size:.68rem}.stage-controls select,.stage-controls input[type=number]{padding:3px 5px;font-size:.72rem}.stage-viewport{padding:8px}}@media (width<=480px){.stage-controls{gap:6px;padding:5px 8px}.stage-viewport{padding:4px}#stage{border-radius:10px}}.admin-shell{background:var(--bg);width:100%;height:100dvh;color:var(--text);--admin-display:"Space Grotesk", "Segoe UI", system-ui, sans-serif;grid-template-columns:248px 1fr;transition:grid-template-columns .28s cubic-bezier(.4,0,.2,1);display:grid;overflow:hidden}.admin-shell .admin-stat-value,.admin-shell .admin-adoption-count,.admin-shell .admin-count-chip,.admin-shell .admin-mini-date,.admin-shell .admin-ucell-date{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}.admin-shell .admin-title,.admin-shell .admin-brand-text,.admin-shell .admin-panel-card-head h3,.admin-shell .admin-stat-value,.admin-shell .admin-empty h3{font-family:var(--admin-display)}.admin-shell.collapsed{grid-template-columns:76px 1fr}.admin-sidebar{background:var(--panel);border-right:1px solid var(--hairline);flex-direction:column;padding:18px 14px;display:flex;overflow:hidden}.admin-brand{border-bottom:1px solid var(--hairline);align-items:center;gap:11px;margin-bottom:8px;padding:6px 6px 18px;display:flex}.admin-brand-icon{background:color-mix(in srgb, var(--accent) 15%, transparent);width:36px;height:36px;color:var(--accent);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--accent) 30%, transparent);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.admin-brand-text{white-space:nowrap;letter-spacing:-.01em;font-size:1.05rem;font-weight:700}.admin-brand-text span{color:var(--accent)}.admin-nav{flex-direction:column;flex:1;gap:4px;margin-top:10px;display:flex}.admin-nav-item{width:100%;color:var(--muted);text-align:left;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:10px;justify-content:flex-start;align-items:center;gap:12px;padding:11px 14px;font-family:inherit;font-size:.88rem;font-weight:600;transition:background .2s,color .2s,transform .15s;display:flex;position:relative;overflow:hidden}.admin-nav-item:hover{background:var(--panel2);color:var(--text);transform:translate(3px)}.admin-nav-item:active{transform:translate(3px)scale(.98)}.admin-nav-item.active{background:color-mix(in srgb, var(--accent) 14%, transparent);color:var(--accent)}.admin-nav-item.active:before{content:"";background:var(--accent);border-radius:0 3px 3px 0;width:3px;height:58%;animation:.28s cubic-bezier(.4,0,.2,1) adminNavBar;position:absolute;top:50%;left:0;transform:translateY(-50%)}@keyframes adminNavBar{0%{opacity:0;height:0}to{opacity:1;height:58%}}.admin-nav-icon{flex-shrink:0;transition:transform .2s}.admin-nav-item:hover .admin-nav-icon{transform:scale(1.14)}.admin-nav-item.active .admin-nav-icon{transform:scale(1.08)}.admin-shell.collapsed .admin-nav-item:hover,.admin-shell.collapsed .admin-nav-item:active{transform:none}.admin-nav-item svg,.admin-collapse-btn svg{flex-shrink:0;width:18px;height:18px}.admin-back-btn svg{flex-shrink:0;width:16px;height:16px}.admin-sidebar-footer{border-top:1px solid var(--hairline);margin-top:auto;padding-top:12px}.admin-back-btn{border:1px solid var(--border);background:var(--panel2);width:100%;color:var(--text);cursor:pointer;white-space:nowrap;border-radius:10px;align-items:center;gap:12px;padding:11px 12px;font-family:inherit;font-size:.85rem;font-weight:600;transition:background .18s,border-color .18s;display:flex}.admin-back-btn:hover{background:var(--panel);border-color:var(--accent);color:var(--accent)}.admin-shell.collapsed .admin-nav-label,.admin-shell.collapsed .admin-brand-text{display:none}.admin-shell.collapsed .admin-nav-item,.admin-shell.collapsed .admin-back-btn,.admin-shell.collapsed .admin-brand{justify-content:center}.admin-main{flex-direction:column;min-width:0;display:flex;overflow:hidden}.admin-topbar{background:color-mix(in srgb, var(--panel) 70%, transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--hairline);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;height:66px;padding:0 24px;display:flex}.admin-topbar-left{align-items:center;gap:14px;min-width:0;display:flex}.admin-collapse-btn{border:1px solid var(--border);background:var(--panel2);width:34px;height:34px;color:var(--muted);cursor:pointer;border-radius:9px;justify-content:center;align-items:center;transition:color .18s,transform .28s,background .18s;display:flex}.admin-collapse-btn:hover{color:var(--text);background:var(--panel)}.admin-shell.collapsed .admin-collapse-btn{transform:rotate(180deg)}.admin-title{letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;font-size:1.15rem;font-weight:700;overflow:hidden}.admin-topbar-right{align-items:center;gap:14px;display:flex}.admin-search{border:1px solid var(--border);background:var(--input-bg);color:var(--muted);border-radius:9px;align-items:center;gap:8px;padding:8px 12px;display:flex}.admin-search input{color:var(--text);background:0 0;border:none;outline:none;width:150px;font-family:inherit;font-size:.85rem}.admin-search input::placeholder{color:var(--muted)}.admin-mode-switch{border:1px solid var(--border);background:var(--panel2);border-radius:10px;flex-shrink:0;gap:3px;padding:4px;display:flex}.admin-mode-btn{width:34px;height:30px;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;transition:background .18s,color .18s,transform .12s;display:flex}.admin-mode-btn svg{flex-shrink:0;width:17px;height:17px}.admin-mode-btn:hover{color:var(--text);background:var(--panel)}.admin-mode-btn:active{transform:scale(.9)}.admin-mode-btn.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px color-mix(in srgb, var(--accent) 40%, transparent)}.admin-user{align-items:center;gap:10px;padding-left:6px;display:flex}.admin-user-avatar{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff;width:34px;height:34px;box-shadow:0 2px 8px color-mix(in srgb, var(--accent) 30%, transparent);border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex}.admin-user-name{white-space:nowrap;text-overflow:ellipsis;max-width:140px;font-size:.85rem;font-weight:600;overflow:hidden}.admin-content{flex:1;padding:26px 24px 40px;overflow-y:auto}.admin-content::-webkit-scrollbar{width:8px}.admin-content::-webkit-scrollbar-thumb{background:var(--panel2);border-radius:8px}.admin-stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:22px;display:grid}.admin-stat-card{border:1px solid var(--hairline);background:var(--panel);border-radius:12px;flex-direction:column;gap:10px;padding:18px 18px 16px 20px;transition:border-color .2s;display:flex;position:relative}.admin-stat-card:before{content:"";background:var(--accent);border-radius:3px;width:3px;position:absolute;top:14px;bottom:14px;left:0}.admin-stat-card:hover{border-color:color-mix(in srgb, var(--accent) 35%, var(--hairline))}.admin-stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:6px;font-size:.7rem;font-weight:600;display:flex}.admin-stat-label svg{width:13px;height:13px;color:var(--accent);flex-shrink:0}.admin-stat-value{letter-spacing:-.02em;font-size:1.9rem;font-weight:600;line-height:1}.admin-stat-sub{color:var(--muted);font-size:.75rem;font-weight:500}.admin-stat-bar{flex-direction:column;gap:6px;display:flex}.admin-stat-bar-track{background:color-mix(in srgb, var(--muted) 22%, transparent);border-radius:3px;height:5px;overflow:hidden}.admin-stat-bar-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.admin-stat-bar-cap{color:var(--muted);font-variant-numeric:tabular-nums;font-size:.72rem;font-weight:500}.admin-overview-split{grid-template-columns:1.15fr .85fr;align-items:start;gap:18px;display:grid}.admin-overview-split .admin-panel-card{margin-bottom:0}@media (width<=1040px){.admin-overview-split{grid-template-columns:1fr}}.admin-adoption{flex-direction:column;gap:12px;display:flex}.admin-adoption-row{grid-template-columns:minmax(84px,.6fr) 1fr auto;align-items:center;gap:14px;display:grid}.admin-adoption-name{white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;overflow:hidden}.admin-adoption-track{background:color-mix(in srgb, var(--muted) 16%, transparent);border-radius:5px;height:10px;overflow:hidden}.admin-adoption-fill{background:linear-gradient(90deg, var(--accent), color-mix(in srgb, var(--accent) 60%, var(--accent2)));transform-origin:0;border-radius:5px;min-width:4px;height:100%;animation:.6s cubic-bezier(.4,0,.2,1) both adminBarGrow}@keyframes adminBarGrow{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.admin-adoption-count{font-variant-numeric:tabular-nums;white-space:nowrap;font-size:.9rem;font-weight:600}.admin-adoption-of{color:var(--muted);font-size:.78rem;font-weight:500}@media (prefers-reduced-motion:reduce){.admin-adoption-fill{animation:none}.admin-stat-bar-fill{transition:none}}.admin-panel-card{border:1px solid var(--hairline);background:var(--panel);border-radius:16px;margin-bottom:18px;padding:22px;box-shadow:0 2px 12px #0000000a}.admin-panel-card-head{align-items:center;gap:10px;margin-bottom:16px;display:flex}.admin-panel-card-head h3{font-size:1rem;font-weight:700}.admin-soon-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--accent2);background:color-mix(in srgb, var(--accent2) 16%, transparent);border-radius:20px;padding:3px 8px;font-size:.65rem;font-weight:700}.admin-settings-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px;display:grid}.admin-settings-grid .admin-panel-card{margin-bottom:0}.admin-table-head{background:var(--panel2);text-transform:uppercase;letter-spacing:.05em;color:var(--muted);border-radius:9px;grid-template-columns:1.5fr 2fr 1fr 1fr;gap:12px;padding:10px 14px;font-size:.72rem;font-weight:700;display:grid}.admin-empty{text-align:center;flex-direction:column;align-items:center;gap:6px;padding:44px 20px;display:flex}.admin-empty-icon{background:var(--panel2);width:60px;height:60px;color:var(--muted);border-radius:16px;justify-content:center;align-items:center;margin-bottom:8px;display:flex}.admin-empty h3{font-size:.98rem;font-weight:700}.admin-empty p{color:var(--muted);max-width:360px;font-size:.85rem}@media (width<=860px){.admin-shell{grid-template-columns:76px 1fr}.admin-shell .admin-nav-label,.admin-shell .admin-brand-text{display:none}.admin-shell .admin-nav-item,.admin-shell .admin-back-btn,.admin-shell .admin-brand{justify-content:center}.admin-collapse-btn,.admin-search,.admin-user-name{display:none}.admin-content{padding:18px 14px 32px}.admin-topbar{padding:0 14px}}.admin-card-head-actions{justify-content:space-between}.admin-count-chip{color:var(--muted);background:var(--panel2);white-space:nowrap;border-radius:20px;padding:2px 9px;font-size:.72rem;font-weight:700}.admin-primary-btn{background:linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 70%, var(--accent2)));color:#fff;cursor:pointer;box-shadow:0 4px 14px color-mix(in srgb, var(--accent) 35%, transparent);border:none;border-radius:9px;align-items:center;gap:7px;padding:8px 15px;font-family:inherit;font-size:.83rem;font-weight:600;transition:transform .14s,box-shadow .18s,opacity .18s;display:inline-flex}.admin-primary-btn:hover{box-shadow:0 6px 18px color-mix(in srgb, var(--accent) 45%, transparent);transform:translateY(-1px)}.admin-primary-btn:active{transform:translateY(0)scale(.98)}.admin-primary-btn svg{width:15px;height:15px}.admin-avatar{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff;width:40px;height:40px;box-shadow:0 2px 8px color-mix(in srgb, var(--accent) 28%, transparent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.admin-avatar.sm{width:34px;height:34px;font-size:.72rem}.admin-user-table{flex-direction:column;gap:8px;display:flex}.admin-controls-bar{background:var(--panel);border:1px solid var(--border);border-radius:16px;justify-content:space-between;align-items:center;gap:20px;margin-bottom:24px;padding:20px;display:flex;box-shadow:0 4px 20px #0000000a}.admin-search-wrapper{background:var(--panel2);border:1.5px solid var(--border);border-radius:12px;align-items:center;gap:12px;width:100%;max-width:380px;padding:10px 16px;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.admin-search-wrapper svg{color:var(--muted);transition:color .2s}.admin-search-wrapper:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 15%, transparent);background:var(--panel)}.admin-search-wrapper:focus-within svg{color:var(--accent)}.admin-search-wrapper input{color:var(--text);background:0 0;border:none;outline:none;width:100%;font-size:.9rem;font-weight:500}.admin-search-wrapper input::placeholder{color:var(--muted);opacity:.7}.clear-search-btn{background:var(--border);color:var(--muted);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;padding:0;transition:all .2s;display:flex}.clear-search-btn:hover{background:var(--accent);color:#fff}.admin-filters-group{align-items:center;gap:16px;display:flex}.filter-select-wrapper{align-items:center;gap:8px;display:flex}.filter-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;font-size:.75rem;font-weight:700}.custom-select-container{width:100%;position:relative}.custom-select-trigger{background:var(--panel2);border:1.5px solid var(--border);color:var(--text);cursor:pointer;text-align:left;border-radius:12px;outline:none;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:10px 16px;font-size:.85rem;font-weight:600;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex}.custom-select-trigger:hover{border-color:var(--accent);background:var(--panel)}.custom-select-container.open .custom-select-trigger{border-color:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 15%, transparent);background:var(--panel)}.select-chevron{color:var(--accent);transition:transform .2s}.custom-select-container.open .select-chevron{transform:rotate(180deg)}.custom-select-options{background:var(--panel);border:1px solid var(--border);box-shadow:var(--elev);z-index:150;border-radius:12px;animation:.2s ease-out selectOptionsIn;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:hidden}@keyframes selectOptionsIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.custom-select-option{color:var(--muted);cursor:pointer;padding:10px 16px;font-size:.84rem;font-weight:550;transition:all .15s}.custom-select-option:hover{background:var(--panel2);color:var(--text)}.custom-select-option.selected{background:color-mix(in srgb, var(--accent) 12%, transparent);color:var(--accent);font-weight:700}.admin-utable-head,.admin-utable-row{grid-template-columns:2.4fr 1fr 2fr 1.1fr .9fr;align-items:center;gap:12px;display:grid}.admin-utable-head{background:var(--panel2);text-transform:uppercase;letter-spacing:.05em;color:var(--muted);border:1px solid #0000;border-radius:8px;padding:12px 16px;font-size:.72rem;font-weight:700}.admin-utable-actions-col{text-align:right}.admin-utable-row{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:14px 16px;transition:transform .2s,border-color .2s,box-shadow .2s,background .2s}.admin-utable-row:hover{border-color:color-mix(in srgb, var(--accent) 50%, var(--border));background:color-mix(in srgb, var(--accent) 5%, var(--panel))}.admin-ucell-user{align-items:center;gap:12px;min-width:0;display:flex}.admin-ucell-info{flex-direction:column;gap:2px;min-width:0;display:flex}.admin-ucell-name{white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:7px;font-size:.88rem;font-weight:600;display:flex;overflow:hidden}.admin-ucell-email{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:5px;font-size:.76rem;display:flex;overflow:hidden}.admin-ucell-email svg{flex-shrink:0}.admin-you-tag{text-transform:uppercase;color:var(--accent2);background:color-mix(in srgb, var(--accent2) 18%, transparent);border-radius:5px;padding:2px 6px;font-size:.6rem;font-weight:700}.admin-ucell-rules{flex-wrap:wrap;gap:5px;display:flex}.admin-ucell-date{color:var(--muted);font-size:.8rem}.admin-ucell-actions{justify-content:flex-end;gap:6px;display:flex}.admin-badge{white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:3px 9px;font-size:.72rem;font-weight:600;display:inline-flex}.admin-badge svg{width:11px;height:11px}.admin-badge-admin{color:var(--accent);background:color-mix(in srgb, var(--accent) 16%, transparent)}.admin-badge-user{color:var(--muted);background:var(--panel2)}.admin-badge-rule{color:var(--accent2);background:color-mix(in srgb, var(--accent2) 14%, transparent)}.admin-badge-muted{color:var(--muted);background:var(--panel2);opacity:.8}.admin-icon-btn{border:1px solid var(--border);background:var(--panel2);width:38px;height:38px;color:var(--text);cursor:pointer;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;transition:color .16s,border-color .16s,background .16s,transform .12s;display:flex}.admin-icon-btn svg{flex-shrink:0;width:18px;height:18px}.admin-icon-btn:hover{color:#fff;border-color:var(--accent);background:var(--accent)}.admin-icon-btn:active{transform:scale(.9)}.admin-icon-btn.danger:hover{color:#fff;background:#ef4444;border-color:#ef4444}.admin-icon-btn:disabled{opacity:.3;cursor:not-allowed}.admin-icon-btn:disabled:hover{color:var(--text);border-color:var(--border);background:var(--panel2)}.admin-mini-list{flex-direction:column;display:flex}.admin-mini-row{border-bottom:1px solid var(--hairline);align-items:center;gap:12px;padding:10px 4px;display:flex}.admin-mini-row:last-child{border-bottom:none}.admin-mini-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.admin-mini-name{font-size:.85rem;font-weight:600}.admin-mini-email{color:var(--muted);font-size:.75rem}.admin-mini-date{color:var(--muted);white-space:nowrap;font-size:.76rem}.admin-rules-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;display:grid}.admin-rule-card{border:1px solid var(--hairline);background:var(--panel2);border-radius:12px;align-items:flex-start;gap:12px;padding:16px;display:flex}.admin-rule-card-icon{background:color-mix(in srgb, var(--accent) 16%, transparent);width:38px;height:38px;color:var(--accent);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.admin-rule-card-body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.admin-rule-card-name{font-size:.9rem;font-weight:700}.admin-rule-card-key{color:var(--muted);font-family:ui-monospace,monospace;font-size:.72rem}.admin-rule-card-desc{color:var(--muted);margin-top:4px;font-size:.78rem}.admin-hint{color:var(--muted);background:var(--panel2);border-radius:9px;margin-top:16px;padding:10px 14px;font-size:.8rem}.user-form-modal{max-width:520px!important}.admin-toggle-row{border:1px solid var(--border);background:var(--input-bg);cursor:pointer;border-radius:10px;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:12px 14px;font-family:inherit;transition:border-color .18s,background .18s;display:flex}.admin-toggle-row:hover{border-color:var(--muted)}.admin-toggle-row.on{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, transparent)}.admin-toggle-info{color:var(--text);align-items:center;gap:11px;display:flex}.admin-toggle-info svg{color:var(--accent);flex-shrink:0}.admin-toggle-info>div{text-align:left;flex-direction:column;display:flex}.admin-toggle-title{font-size:.86rem;font-weight:600}.admin-toggle-sub{color:var(--muted);font-size:.74rem}.admin-switch{background:var(--panel2);border:1px solid var(--border);border-radius:20px;flex-shrink:0;width:42px;height:24px;transition:background .2s;position:relative}.admin-switch.on{background:var(--accent);border-color:var(--accent)}.admin-switch-knob{background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s cubic-bezier(.4,0,.2,1);position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0000004d}.admin-switch.on .admin-switch-knob{transform:translate(18px)}.admin-field-group{flex-direction:column;gap:8px;display:flex}.admin-group-label{color:var(--muted);font-size:.78rem;font-weight:600}.admin-rule-list{flex-direction:column;gap:8px;display:flex}.admin-rule-option{border:1px solid var(--border);background:var(--input-bg);cursor:pointer;text-align:left;border-radius:10px;align-items:flex-start;gap:11px;padding:11px 13px;font-family:inherit;transition:border-color .16s,background .16s;display:flex}.admin-rule-option:hover{border-color:var(--muted)}.admin-rule-option.checked{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, transparent)}.admin-checkbox{border:1.5px solid var(--border);background:var(--panel);color:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-top:1px;transition:background .16s,border-color .16s;display:flex}.admin-checkbox.checked{background:var(--accent);border-color:var(--accent)}.admin-checkbox svg{width:12px;height:12px}.admin-rule-option-text{flex-direction:column;gap:1px;display:flex}.admin-rule-option-name{color:var(--text);font-size:.85rem;font-weight:600}.admin-rule-option-desc{color:var(--muted);font-size:.74rem}@media (width<=900px){.admin-utable-head{display:none}.admin-utable-row{border:1px solid var(--hairline);background:var(--panel2);border-radius:12px;grid-template-columns:1fr;gap:10px;margin-bottom:10px;padding:14px}.admin-ucell-actions{justify-content:flex-start}}.admin-tabs{justify-content:center;margin-bottom:22px;display:flex}.admin-tabs-inner{border:1px solid var(--border);background:var(--panel2);border-radius:13px;gap:4px;padding:5px;display:inline-flex}.admin-tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:9px;padding:9px 26px;font-family:inherit;font-size:.85rem;font-weight:600;transition:background .2s,color .2s,box-shadow .2s}.admin-tab:hover{color:var(--text)}.admin-tab.active{background:var(--accent);color:#fff;box-shadow:0 3px 10px color-mix(in srgb, var(--accent) 38%, transparent)}.admin-userrule-list{flex-direction:column;gap:10px;display:flex}.admin-userrule-row{border:1px solid var(--hairline);background:var(--panel2);border-radius:13px;align-items:center;gap:16px;padding:14px 16px;transition:border-color .16s,transform .16s;display:flex}.admin-userrule-row:hover{border-color:color-mix(in srgb, var(--accent) 35%, var(--hairline))}.admin-userrule-row .admin-ucell-user{flex:none;min-width:200px}.admin-userrule-rules{flex-wrap:wrap;flex:1;align-items:center;gap:7px;display:flex}.admin-rule-chip{color:var(--accent2);background:color-mix(in srgb, var(--accent2) 14%, transparent);border:1px solid color-mix(in srgb, var(--accent2) 30%, transparent);border-radius:20px;align-items:center;gap:6px;padding:5px 6px 5px 11px;font-size:.76rem;font-weight:600;display:inline-flex}.admin-rule-chip svg{flex-shrink:0;width:11px;height:11px}.admin-rule-chip-x{background:color-mix(in srgb, var(--accent2) 18%, transparent);width:18px;height:18px;color:var(--accent2);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s,color .15s,transform .12s;display:flex}.admin-rule-chip-x svg{width:11px;height:11px}.admin-rule-chip-x:hover{color:#fff;background:#ef4444}.admin-rule-chip-x:active{transform:scale(.85)}.admin-secondary-btn{border:1px solid var(--border);background:var(--panel);color:var(--text);cursor:pointer;border-radius:9px;flex-shrink:0;align-items:center;gap:6px;padding:8px 14px;font-family:inherit;font-size:.8rem;font-weight:600;transition:border-color .16s,color .16s,background .16s,transform .12s;display:inline-flex}.admin-secondary-btn svg{width:14px;height:14px}.admin-secondary-btn:hover{border-color:var(--accent);color:var(--accent)}.admin-secondary-btn:active{transform:scale(.97)}.admin-select-wrap{position:relative}.admin-select{width:100%;color:var(--text);background:var(--input-bg);border:1px solid var(--border);cursor:pointer;appearance:none;border-radius:11px;outline:none;padding:11px 38px 11px 13px;font-family:inherit;font-size:14px;transition:border-color .18s,box-shadow .18s}.admin-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 16%, transparent)}.admin-select:disabled{opacity:.7;cursor:not-allowed}.admin-select-chevron{color:var(--muted);pointer-events:none;position:absolute;top:50%;right:13px;transform:translateY(-50%)}@media (width<=760px){.admin-userrule-row{flex-direction:column;align-items:stretch}.admin-userrule-row .admin-ucell-user{min-width:0}.admin-secondary-btn{justify-content:center}.admin-tab{padding:9px 18px}}.admin-ur-split{grid-template-columns:300px 1fr;gap:16px;min-height:440px;display:grid}.admin-ur-users{border:1px solid var(--hairline);background:var(--panel2);border-radius:13px;flex-direction:column;gap:10px;min-width:0;padding:12px;display:flex}.admin-ur-search{border:1px solid var(--border);background:var(--input-bg);color:var(--muted);border-radius:10px;flex-shrink:0;align-items:center;gap:8px;padding:9px 12px;display:flex}.admin-ur-search input{color:var(--text);background:0 0;border:none;outline:none;width:100%;font-family:inherit;font-size:.84rem}.admin-ur-search input::placeholder{color:var(--muted)}.admin-ur-userlist{flex-direction:column;gap:4px;max-height:460px;display:flex;overflow-y:auto}.admin-ur-userlist::-webkit-scrollbar{width:6px}.admin-ur-userlist::-webkit-scrollbar-thumb{background:var(--panel);border-radius:6px}.admin-ur-noresult{color:var(--muted);text-align:center;padding:24px 8px;font-size:.82rem}.admin-ur-user{cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:10px;align-items:center;gap:11px;width:100%;padding:9px 10px;font-family:inherit;transition:background .15s,border-color .15s;display:flex}.admin-ur-user:hover{background:var(--panel)}.admin-ur-user.active{background:color-mix(in srgb, var(--accent) 12%, transparent);border-color:color-mix(in srgb, var(--accent) 40%, transparent)}.admin-ur-user-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.admin-ur-user-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.84rem;font-weight:600;overflow:hidden}.admin-ur-user-email{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.admin-ur-detail{border:1px solid var(--hairline);background:var(--panel2);border-radius:13px;min-width:0;padding:18px}.admin-ur-detail-head{border-bottom:1px solid var(--hairline);justify-content:space-between;align-items:center;gap:14px;margin-bottom:16px;padding-bottom:16px;display:flex}.admin-ur-rules{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;display:grid}.admin-ur-rule-card{border:1px solid var(--hairline);background:var(--panel);border-radius:12px;align-items:flex-start;gap:12px;padding:16px 44px 16px 16px;transition:border-color .16s;display:flex;position:relative}.admin-ur-rule-card:hover{border-color:color-mix(in srgb, var(--accent) 35%, var(--hairline))}.admin-ur-rule-del{border:1px solid var(--border);background:var(--panel2);width:30px;height:30px;color:var(--muted);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;transition:color .15s,border-color .15s,background .15s,transform .12s;display:flex;position:absolute;top:10px;right:10px}.admin-ur-rule-del svg{width:15px;height:15px}.admin-ur-rule-del:hover{color:#fff;background:#ef4444;border-color:#ef4444}.admin-ur-rule-del:active{transform:scale(.9)}.rule-assign-modal{width:min(740px,95vw)!important;max-width:740px!important}.rule-assign-body{grid-template-columns:1fr 1fr;gap:16px;padding:18px 22px 4px;display:grid}.rule-assign-col{flex-direction:column;gap:9px;min-width:0;display:flex}.rule-assign-list{flex-direction:column;gap:6px;max-height:320px;padding-right:2px;display:flex;overflow-y:auto}.rule-assign-list::-webkit-scrollbar{width:6px}.rule-assign-list::-webkit-scrollbar-thumb{background:var(--panel2);border-radius:6px}.rule-assign-user{border:1px solid var(--border);background:var(--input-bg);cursor:pointer;text-align:left;border-radius:10px;align-items:center;gap:11px;padding:10px 12px;font-family:inherit;transition:border-color .15s,background .15s;display:flex}.rule-assign-user:hover{border-color:var(--muted)}.rule-assign-user.active{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 9%, transparent)}.rule-assign-user-info{flex-direction:column;gap:1px;min-width:0;display:flex}.admin-radio{border:2px solid var(--border);border-radius:50%;flex-shrink:0;width:18px;height:18px;transition:border-color .15s;position:relative}.admin-radio.on{border-color:var(--accent)}.admin-radio.on:after{content:"";background:var(--accent);border-radius:50%;position:absolute;inset:3px}.rule-assign-actions{padding:14px 22px 20px}.admin-topbar-mobile-back{display:none}.filter-select-wrapper select{appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%237c5cff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-position:right 12px center;background-repeat:no-repeat;background-size:12px;padding-right:32px!important}@media (width<=900px){.admin-ur-split{min-height:unset;grid-template-columns:1fr!important}.admin-ur-userlist{max-height:250px}.rule-assign-body{grid-template-columns:1fr}}@media (width<=768px){.admin-shell{height:100dvh;grid-template-columns:1fr!important}.admin-sidebar{background:var(--panel);border-top:1px solid var(--border);z-index:1000;border-right:none;flex-direction:row;justify-content:space-around;align-items:center;height:64px;padding:0 10px;position:fixed;bottom:0;left:0;right:0}.admin-brand{display:none!important}.admin-nav{flex-direction:row;justify-content:space-around;gap:0;width:100%;margin-top:0}.admin-nav-item{text-align:center;height:100%;color:var(--muted);border-radius:0;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;padding:8px 0;font-size:.68rem}.admin-nav-item:hover{background:0 0;transform:none}.admin-nav-item.active{color:var(--accent);background:0 0}.admin-nav-item.active:before{border-radius:0 0 3px 3px;width:34px;height:3px;top:0;left:50%;transform:translate(-50%)}.admin-sidebar-footer{display:none!important}.admin-main{padding-bottom:64px}.admin-collapse-btn{display:none!important}.admin-topbar-mobile-back{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:6px;transition:background .2s,color .2s;display:flex!important}.admin-topbar-mobile-back:hover{background:var(--panel2);color:var(--text)}.admin-topbar{padding:12px 16px}.admin-topbar-left{gap:12px}.admin-user .admin-user-name,.admin-utable-head{display:none!important}.admin-utable-row{border-radius:12px;align-items:flex-start;gap:12px;padding:16px;position:relative;grid-template-columns:1fr!important}.admin-ucell-actions{border-top:1px solid var(--border);justify-content:flex-end;width:100%;margin-top:4px;padding-top:12px}.admin-controls-bar{flex-direction:column;align-items:stretch;gap:16px;padding:16px}.admin-search-wrapper{width:100%;max-width:none}.admin-filters-group{grid-template-columns:repeat(3,1fr);gap:12px;width:100%;display:grid}.filter-select-wrapper{flex-direction:column;align-items:stretch;gap:6px}.custom-select-trigger{width:100%;padding:10px 12px;font-size:.8rem}.filter-label{text-align:left;margin-left:2px;font-size:.68rem}}@media (width<=580px){.admin-filters-group{grid-template-columns:1fr;gap:12px}}@media (width<=480px){.admin-stats-grid{grid-template-columns:1fr 1fr;gap:12px}.admin-stat-card{gap:10px;padding:14px 12px}.admin-stat-icon{width:32px;height:32px}.admin-stat-value{font-size:1.2rem}.admin-stat-label{font-size:.68rem}}
