:root{--bg:#1a1a2e;--surface:#ffffff0d;--surface-2:#ffffff0a;--surface-3:#ffffff08;--surface-hover:#ffffff14;--overlay-scrim:#1a1a2ef2;--border:#ffffff14;--border-soft:#ffffff0f;--border-hard:#ffffff4d;--fg-1:#fff;--fg-2:#e0e0e0;--fg-3:#9ca3af;--fg-4:#6b7280;--fg-5:#475569;--accent-blue:#3b82f6;--accent-blue-2:#38bdf8;--accent-green:#4ade80;--accent-red:#f87171;--accent-orange:#f97316;--accent-purple:#a855f7;--accent-yellow:#eab308;--tint-blue:#3b82f62e;--tint-red:#ef44442e;--tint-amber:#fbbf242e;--tint-purple:#a855f72e;--status-ok-bg:#22c55e21;--status-ok-fg:#22c55e;--status-warn-bg:#eab30821;--status-warn-fg:#eab308;--status-err-bg:#ef444421;--status-err-fg:#ef4444;--grad-avatar:linear-gradient(135deg,#667eea 0%,#764ba2 100%);--grad-music:linear-gradient(135deg,#6366f1,#a855f7);--grad-hot:linear-gradient(135deg,#f97316,#ef4444);--grad-progress:linear-gradient(90deg,#a855f7,#ec4899);--r-xs:4px;--r-sm:8px;--r-md:10px;--r-lg:12px;--r-xl:14px;--r-card:18px;--r-pill:9999px;--s-1:4px;--s-2:8px;--s-3:12px;--s-4:14px;--s-5:16px;--s-6:20px;--s-8:32px;--blur-card:10px;--font-sans:-apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono:ui-monospace, "SF Mono", Menlo, Consolas, monospace;--fs-10:10px;--fs-11:11px;--fs-12:12px;--fs-13:13px;--fs-14:14px;--fs-15:15px;--fs-16:16px;--fs-17:17px;--fs-20:20px;--fs-22:22px;--fs-28:28px;--fs-48:48px;--type-page-title-size:24px;--type-page-title-weight:700;--type-card-title-size:16px;--type-card-title-weight:700;--type-eyebrow-size:10px;--type-eyebrow-weight:600;--type-label-size:12px;--type-label-weight:500;--type-body-size:15px;--type-body-weight:400;--type-body-sm-size:14px;--type-body-sm-weight:400;--type-meta-size:12px;--type-meta-weight:400;--type-numeric-hero-size:48px;--type-numeric-hero-weight:800;--type-numeric-size:22px;--type-numeric-weight:700;--tracking-wide:.08em;--tracking-widest:.15em;--lh-tight:1.1;--lh-body:1.5}html,body{background:var(--bg);color:var(--fg-2);font-family:var(--font-sans);font-size:var(--fs-15);line-height:var(--lh-body)}.hd-page-title{font-size:var(--type-page-title-size);font-weight:var(--type-page-title-weight);color:var(--fg-1)}.hd-card-title{font-size:var(--type-card-title-size);font-weight:var(--type-card-title-weight);color:var(--fg-1)}.hd-eyebrow{font-size:var(--type-eyebrow-size);font-weight:var(--type-eyebrow-weight);letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--fg-3)}.hd-label{font-size:var(--type-label-size);font-weight:var(--type-label-weight);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--fg-4)}.hd-body{font-size:var(--fs-15);color:var(--fg-2)}.hd-body-sm{font-size:var(--fs-14);color:var(--fg-3)}.hd-meta{font-size:var(--fs-12);color:var(--fg-5)}.hd-numeric-hero{font-size:var(--type-numeric-hero-size);font-weight:var(--type-numeric-hero-weight);color:var(--fg-1);line-height:var(--lh-tight)}.hd-numeric{font-size:var(--type-numeric-size);font-weight:var(--type-numeric-weight);color:var(--fg-1)}.hd-tabular{font-variant-numeric:tabular-nums}.hd-card{background:var(--surface);-webkit-backdrop-filter:blur(var(--blur-card));border:1px solid var(--border);border-radius:var(--r-card);padding:var(--s-5)}.hd-chip{font-size:var(--fs-13);border-radius:var(--r-pill);border:1px solid;align-items:center;gap:6px;padding:2px 10px;font-weight:700;display:inline-flex}.hd-chip--ok{background:var(--status-ok-bg);color:var(--status-ok-fg);border-color:#22c55e54}.hd-chip--warn{background:var(--status-warn-bg);color:var(--status-warn-fg);border-color:#eab30854}.hd-chip--err{background:var(--status-err-bg);color:var(--status-err-fg);border-color:#ef444454}body{background:var(--bg);color:var(--fg-2);font-family:var(--font-sans);font-size:var(--fs-15);-webkit-font-smoothing:antialiased;overflow:hidden}button{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:9999px}::-webkit-scrollbar-track{background:0 0}[data-theme=light]{--bg:#f4f5f7;--surface:#ffffffd9;--surface-2:#ffffffa6;--surface-3:#ffffff73;--surface-hover:#0000000d;--overlay-scrim:#fffffff2;--border:#00000014;--border-soft:#0000000d;--border-hard:#00000040;--fg-1:#0f172a;--fg-2:#1e293b;--fg-3:#475569;--fg-4:#64748b;--fg-5:#94a3b8}.app{width:100vw;height:100vh;display:flex}.rail{background:var(--surface);border-right:1px solid var(--border);z-index:5;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;width:64px;padding:16px 0 12px;transition:width .2s;display:flex;position:relative}.rail.is-expanded{align-items:stretch;width:232px;padding:16px 12px 12px}.rail-brand{border-bottom:1px solid var(--border-soft);flex-shrink:0;align-items:center;gap:10px;height:56px;margin-bottom:8px;padding:0 6px 14px;display:flex}.rail-logo{background:var(--grad-music);color:#fff;border-radius:10px;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:17px;font-weight:800;display:grid;box-shadow:inset 0 0 0 1px #ffffff14}.rail-wordmark{color:var(--fg-1);letter-spacing:-.01em;white-space:nowrap;opacity:0;pointer-events:none;font-size:15px;font-weight:700;transition:opacity .15s}.rail.is-expanded .rail-wordmark{opacity:1;pointer-events:auto}.rail-section-label{letter-spacing:.15em;text-transform:uppercase;color:var(--fg-5);white-space:nowrap;opacity:0;height:0;padding:14px 8px 6px;font-size:10px;font-weight:700;transition:opacity .15s;overflow:hidden}.rail.is-expanded .rail-section-label{opacity:1;height:auto}.rail-btn{border-radius:var(--r-xl);width:44px;height:44px;color:var(--fg-3);cursor:pointer;text-align:left;background:0 0;border:0;flex-shrink:0;align-items:center;gap:12px;padding:0 10px;font-size:14px;transition:background .2s,color .2s,width .2s;display:flex;position:relative}.rail.is-expanded .rail-btn{width:100%}.rail-btn:hover{background:var(--surface-hover);color:var(--fg-1)}.rail-btn.is-active{color:var(--accent-blue);background:#3b82f626}.rail-btn .ico{text-align:center;flex-shrink:0;width:24px;font-size:18px}.rail-btn .label{white-space:nowrap;opacity:0;pointer-events:none;font-size:14px;font-weight:500;transition:opacity .15s}.rail.is-expanded .rail-btn .label{opacity:1;pointer-events:auto}.rail-btn .badge{background:var(--accent-blue);color:#fff;opacity:0;border-radius:9999px;margin-left:auto;padding:2px 6px;font-size:10px;font-weight:700;transition:opacity .15s}.rail.is-expanded .rail-btn .badge{opacity:1}.rail-spacer{flex:1}.rail-divider{background:var(--border-soft);flex-shrink:0;height:1px;margin:8px 0}.rail-toggle{background:var(--bg);border:1px solid var(--border);width:24px;height:24px;color:var(--fg-3);cursor:pointer;z-index:10;border-radius:50%;place-items:center;font-size:11px;transition:transform .2s,color .2s;display:grid;position:absolute;top:22px;right:-12px}.rail-toggle:hover{color:var(--fg-1)}.main{background:var(--bg);flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.topbar{border-bottom:1px solid var(--border-soft);background:var(--bg);flex-shrink:0;align-items:center;gap:16px;padding:16px 24px;display:flex}.topbar-title{flex:1;align-items:baseline;gap:12px;min-width:0;display:flex}.topbar h1{color:var(--fg-1);letter-spacing:-.01em;margin:0;font-size:20px;font-weight:700}.topbar .meta{color:var(--fg-4);white-space:nowrap;font-size:12px}.topbar-actions{align-items:center;gap:8px;display:flex}.iconbtn{border-radius:var(--r-md);width:36px;height:36px;color:var(--fg-3);cursor:pointer;background:0 0;border:1px solid #0000;place-items:center;font-size:15px;transition:background .2s,color .2s,border-color .2s;display:grid}.iconbtn:hover{background:var(--surface-hover);color:var(--fg-1)}.iconbtn.is-bordered{border-color:var(--border)}.btn{border-radius:var(--r-md);cursor:pointer;border:1px solid #0000;align-items:center;gap:8px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--accent-blue);color:#fff}.btn-primary:hover{filter:brightness(1.1)}.btn-ghost{background:var(--surface-2);color:var(--fg-1);border-color:var(--border)}.btn-ghost:hover{background:var(--surface-hover)}.btn-lg{border-radius:var(--r-lg);padding:12px 18px;font-size:14px}.scroll{flex:1;min-height:0;overflow-y:auto}.dash-grid{grid-template-columns:repeat(12,1fr);grid-auto-rows:88px;grid-auto-flow:dense;gap:12px;padding:16px 24px 80px;display:grid}@media (width<=1100px){.dash-grid{grid-template-columns:repeat(8,1fr)}}@media (width<=720px){.dash-grid{grid-template-columns:repeat(4,1fr);padding:12px}}.s2x2{grid-area:span 2/span 2}.s3x2{grid-area:span 2/span 3}.s3x3{grid-area:span 3/span 3}.s3x4{grid-area:span 4/span 3}.s4x2{grid-area:span 2/span 4}.s4x3{grid-area:span 3/span 4}.s4x4{grid-area:span 4/span 4}.s6x2{grid-area:span 2/span 6}.s6x3{grid-area:span 3/span 6}.s12x2{grid-area:span 2/span 12}@media (width<=1100px){.s4x3,.s4x4{grid-column:span 4}.s6x2,.s6x3,.s12x2{grid-column:span 8}}@media (width<=720px){.s2x2,.s3x2,.s3x3,.s4x2,.s4x3,.s4x4,.s6x2,.s6x3,.s12x2{grid-column:span 4}}.w{background:var(--surface);-webkit-backdrop-filter:blur(var(--blur-card));border:1px solid var(--border);border-radius:var(--r-card);flex-direction:column;min-height:0;padding:16px;transition:border-color .2s,transform .2s;display:flex;position:relative;overflow:hidden}.w:hover{border-color:#ffffff24}[data-theme=light] .w:hover{border-color:#00000024}.w-head{flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.w-title{align-items:center;gap:8px;display:flex}.w-title h3{color:var(--fg-1);margin:0;font-size:14px;font-weight:700}.w-title .ico{font-size:14px}.w-tools{opacity:0;align-items:center;gap:4px;transition:opacity .2s;display:flex}.w:hover .w-tools{opacity:1}.w-tool{width:22px;height:22px;color:var(--fg-4);cursor:pointer;background:0 0;border:0;border-radius:6px;place-items:center;font-size:12px;display:grid}.w-tool:hover{background:var(--surface-hover);color:var(--fg-1)}.w-body{flex-direction:column;flex:1;min-height:0;display:flex}.eyebrow{letter-spacing:.15em;text-transform:uppercase;color:var(--fg-4);font-size:10px;font-weight:700}.label{letter-spacing:.08em;text-transform:uppercase;color:var(--fg-4);font-size:12px;font-weight:500}.num-hero{color:var(--fg-1);letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:38px;font-weight:800;line-height:1}.num{color:var(--fg-1);font-variant-numeric:tabular-nums;font-size:22px;font-weight:700}.muted{color:var(--fg-3)}.meta{color:var(--fg-5);font-size:12px}.divider{background:var(--border-soft);height:1px;margin:10px 0}.row{align-items:center;gap:8px;display:flex}.row-between{justify-content:space-between;align-items:center;display:flex}.login{grid-template-columns:1.1fr 1fr;width:100vw;height:100vh;display:grid}@media (width<=880px){.login{grid-template-columns:1fr;height:auto;min-height:100vh}.login-marketing{gap:24px;padding:32px 24px 24px}.login-slogan{max-width:none}.login-slogan h1{margin-bottom:12px;font-size:28px}.login-slogan p{max-width:none;font-size:14px}.login-preview{width:100%;height:auto;margin-top:16px;position:static;transform:none}.login-marketing-foot{display:none}.login-form-wrap{padding:32px 20px 48px}}@media (width<=480px){.login-preview{display:none}}.login-marketing{background:linear-gradient(135deg,#1e3a5f 0%,#2d1b4e 60%,#1a1a2e 100%);flex-direction:column;justify-content:space-between;padding:48px;display:flex;position:relative;overflow:hidden}.login-brand{color:#fff;align-items:center;gap:12px;font-size:16px;font-weight:700;display:flex}.login-brand .rail-logo{border-radius:10px;width:36px;height:36px}.login-slogan{color:#fff;max-width:480px}.login-slogan h1{letter-spacing:-.02em;margin:0 0 16px;font-size:44px;font-weight:800;line-height:1.05}.login-slogan p{color:#ffffffb3;max-width:420px;margin:0;font-size:15px;line-height:1.55}.login-preview{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:none;background:#ffffff0f;border:1px solid #ffffff14;border-radius:18px;grid-template-columns:1fr 1fr;gap:10px;width:380px;height:240px;padding:16px;display:grid;position:absolute;bottom:80px;right:-60px;transform:rotate(-2deg)}.login-preview-card{background:#ffffff0f;border:1px solid #ffffff14;border-radius:12px;flex-direction:column;justify-content:space-between;padding:12px;display:flex}.login-marketing-foot{color:#ffffff73;font-size:12px}.login-form-wrap{background:var(--bg);justify-content:center;align-items:center;padding:48px 32px;display:flex}.login-form{width:100%;max-width:380px}.login-form h2{color:var(--fg-1);margin:0 0 6px;font-size:24px;font-weight:700}.login-form .sub{color:var(--fg-3);margin-bottom:28px;font-size:14px}.field{margin-bottom:14px}.field label{color:var(--fg-3);letter-spacing:.02em;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.input{border-radius:var(--r-md);background:var(--surface-2);border:1px solid var(--border);width:100%;color:var(--fg-1);padding:11px 14px;font-family:inherit;font-size:14px;transition:border-color .2s,background .2s}.input:focus{border-color:var(--accent-blue);background:var(--surface);outline:none}.input::placeholder{color:var(--fg-5)}.login-row{justify-content:space-between;align-items:center;margin:4px 0 16px;font-size:12px;display:flex}.login-row a{color:var(--accent-blue);text-decoration:none}.cb{color:var(--fg-3);cursor:pointer;align-items:center;gap:6px;display:inline-flex}.cb input{accent-color:var(--accent-blue)}.btn-block{justify-content:center;width:100%;padding:12px;font-size:14px}.divider-or{color:var(--fg-5);text-transform:uppercase;letter-spacing:.15em;align-items:center;gap:10px;margin:18px 0;font-size:11px;display:flex}.divider-or:before,.divider-or:after{content:"";background:var(--border-soft);flex:1;height:1px}.oauth-row{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px;display:grid}.oauth-btn{border:1px solid var(--border);background:var(--surface-2);color:var(--fg-1);border-radius:var(--r-md);cursor:pointer;justify-content:center;align-items:center;gap:8px;padding:10px;font-size:13px;font-weight:500;transition:background .2s,border-color .2s;display:inline-flex}.oauth-btn:hover{background:var(--surface-hover)}.oauth-ico{place-items:center;width:16px;height:16px;display:grid}.foot-row{color:var(--fg-3);text-align:center;font-size:13px}.foot-row a{color:var(--accent-blue);font-weight:600;text-decoration:none}.foot-row .guest{color:var(--fg-4);margin-top:14px;display:block}.anon-banner{border-radius:var(--r-card);background:linear-gradient(135deg,#3b82f62e 0%,#a855f72e 100%);border:1px solid #3b82f640;align-items:center;gap:16px;margin:16px 24px 0;padding:14px 18px;display:flex}.anon-banner .copy{flex:1}.anon-banner .copy h3{color:var(--fg-1);margin:0 0 2px;font-size:14px;font-weight:700}.anon-banner .copy p{color:var(--fg-3);margin:0;font-size:12px}.anon-banner .lock-ico{width:36px;height:36px;color:var(--accent-blue);background:#3b82f633;border-radius:10px;flex-shrink:0;place-items:center;font-size:16px;display:grid}.overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:50;background:#0a0a14b3;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}[data-theme=light] .overlay{background:#00001466}.lib{background:var(--bg);border:1px solid var(--border);border-radius:18px;grid-template-columns:220px 1fr;width:min(1120px,100%);height:min(720px,92vh);display:grid;overflow:hidden}.lib-side{border-right:1px solid var(--border-soft);padding:20px 16px;overflow-y:auto}.lib-side h4{color:var(--fg-1);margin:0 0 14px;font-size:16px;font-weight:700}.lib-cat{cursor:pointer;color:var(--fg-3);border-radius:8px;align-items:center;gap:10px;padding:8px 10px;font-size:13px;transition:background .2s,color .2s;display:flex}.lib-cat:hover{background:var(--surface-hover);color:var(--fg-1)}.lib-cat.is-active{color:var(--accent-blue);background:#3b82f626}.lib-cat .count{color:var(--fg-5);margin-left:auto;font-size:11px}.lib-cat.is-active .count{color:var(--accent-blue)}.lib-main{flex-direction:column;min-height:0;display:flex}.lib-head{border-bottom:1px solid var(--border-soft);align-items:center;gap:12px;padding:18px 24px;display:flex}.lib-head .input{flex:1}.lib-head h3{color:var(--fg-1);margin:0;font-size:18px;font-weight:700}.lib-grid{flex:1;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));align-content:start;gap:14px;min-height:0;padding:20px 24px;display:grid;overflow-y:auto}.lib-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;flex-direction:column;gap:8px;padding:14px;transition:border-color .2s,transform .2s;display:flex}.lib-card:hover{border-color:var(--accent-blue)}.lib-card .preview{background:var(--surface-2);border:1px solid var(--border-soft);border-radius:10px;place-items:center;height:80px;font-size:28px;display:grid;position:relative;overflow:hidden}.lib-card .preview .pro{letter-spacing:.1em;color:#fbbf24;background:#fbbf2426;border:1px solid #fbbf244d;border-radius:9999px;padding:2px 6px;font-size:9px;font-weight:700;position:absolute;top:6px;right:6px}.lib-card h5{color:var(--fg-1);margin:0;font-size:13px;font-weight:600}.lib-card .desc{color:var(--fg-4);font-size:11px;line-height:1.4}.lib-card .add{color:var(--accent-blue);align-items:center;gap:4px;margin-top:auto;font-size:11px;font-weight:600;display:flex}.settings-pop{background:var(--bg);border-left:1px solid var(--border);z-index:60;flex-direction:column;width:min(420px,100%);height:100vh;animation:.22s slidein;display:flex;position:fixed;top:0;right:0;box-shadow:-20px 0 60px #0006}@keyframes slidein{0%{transform:translate(100%)}to{transform:translate(0)}}.settings-pop .head{border-bottom:1px solid var(--border-soft);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.settings-pop h2{color:var(--fg-1);margin:0;font-size:18px;font-weight:700}.settings-pop .body{flex:1;padding:24px;overflow-y:auto}.settings-section h4{letter-spacing:.15em;text-transform:uppercase;color:var(--fg-4);margin:0 0 12px;font-size:11px;font-weight:700}.settings-row{border-bottom:1px solid var(--border-soft);justify-content:space-between;align-items:center;padding:12px 0;display:flex}.settings-row:last-child{border-bottom:0}.settings-row .lbl{color:var(--fg-1);font-size:14px}.settings-row .sub{color:var(--fg-4);font-size:12px}.swatch-row{gap:8px;display:flex}.sw{cursor:pointer;border:2px solid #0000;border-radius:50%;width:28px;height:28px;transition:transform .15s;position:relative}.sw:hover{transform:scale(1.1)}.sw.is-active{border-color:var(--fg-1)}.sw.is-active:after{content:"✓";color:#fff;place-items:center;font-size:12px;display:grid;position:absolute;inset:0}.theme-toggle{background:var(--surface-2);border:1px solid var(--border-soft);border-radius:9999px;gap:6px;padding:4px;display:flex}.theme-toggle button{color:var(--fg-3);cursor:pointer;background:0 0;border:0;border-radius:9999px;padding:6px 14px;font-size:12px;font-weight:600;transition:all .15s}.theme-toggle button.is-active{background:var(--accent-blue);color:#fff}.toggle{background:var(--accent-blue);cursor:pointer;border:0;border-radius:9999px;flex-shrink:0;width:36px;height:20px;padding:0;transition:background .2s;position:relative}.toggle:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:left .2s;position:absolute;top:2px;left:18px}.toggle.off{background:#fff3}[data-theme=light] .toggle.off{background:#00000026}.toggle.off:after{left:2px}.chip{letter-spacing:.04em;border:1px solid;border-radius:9999px;align-items:center;gap:5px;padding:2px 9px;font-size:11px;font-weight:700;display:inline-flex}.chip-ok{background:var(--status-ok-bg);color:var(--status-ok-fg);border-color:#22c55e54}.chip-warn{background:var(--status-warn-bg);color:var(--status-warn-fg);border-color:#eab30854}.chip-err{background:var(--status-err-bg);color:var(--status-err-fg);border-color:#ef444454}.chip-info{color:var(--accent-blue);background:#3b82f621;border-color:#3b82f654}.chip-purple{color:var(--accent-purple);background:#a855f721;border-color:#a855f754}.chip-orange{color:var(--accent-orange);background:#f9731621;border-color:#f9731654}.mini-bars{align-items:flex-end;gap:4px;height:60px;display:flex}.mini-bars .bar{background:var(--accent-blue);opacity:.7;border-radius:3px 3px 0 0;flex:1;min-width:0;position:relative}.mini-bars .bar.peak{opacity:1}.mini-bars .lbl-row{gap:4px;margin-top:4px;display:flex}.mini-bars-wrap .x-row{gap:4px;margin-top:6px;display:flex}.mini-bars-wrap .x-row span{text-align:center;color:var(--fg-5);flex:1;font-size:9px}.spark{width:100%;height:36px}.pbar{background:#ffffff12;border-radius:3px;height:6px;overflow:hidden}[data-theme=light] .pbar{background:#00000014}.pbar-fill{border-radius:3px;height:100%;transition:width .3s}.add-slot{border:1.5px dashed var(--border);border-radius:var(--r-card);color:var(--fg-4);cursor:pointer;background:0 0;place-items:center;font-size:13px;transition:border-color .2s,color .2s,background .2s;display:grid}.add-slot:hover{border-color:var(--accent-blue);color:var(--accent-blue);background:#3b82f60d}.add-slot .ico{margin-bottom:4px;font-size:22px}.bills-modal{background:var(--bg);border:1px solid var(--border);border-radius:18px;flex-direction:column;width:min(640px,100%);max-height:88vh;display:flex;overflow:hidden}.bills-modal .head{border-bottom:1px solid var(--border-soft);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.bills-modal .body{padding:22px;overflow-y:auto}.bills-row{cursor:pointer;border-radius:10px;grid-template-columns:36px 1fr auto auto;align-items:center;gap:14px;padding:12px;transition:background .2s;display:grid}.bills-row:hover,.bills-row.is-active{background:var(--surface-2)}.bills-row .util-ico{border-radius:10px;place-items:center;width:36px;height:36px;font-size:17px;display:grid}.spin{animation:1.2s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:.25s both fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.link{color:var(--accent-blue);cursor:pointer}.link:hover{text-decoration:underline}.kbd{background:var(--surface-2);border:1px solid var(--border);min-width:18px;height:18px;color:var(--fg-3);font-size:10px;font-weight:600;font-family:var(--font-mono);border-radius:4px;justify-content:center;align-items:center;padding:0 5px;display:inline-flex}.confirm-dialog{background:var(--bg);border:1px solid var(--border);text-align:center;border-radius:16px;width:min(420px,100%);padding:28px 24px 18px;box-shadow:0 20px 60px #00000080}.confirm-icon{border-radius:50%;place-items:center;width:56px;height:56px;margin:0 auto 16px;font-size:26px;font-weight:700;display:grid}.confirm-icon.tone-danger{color:var(--accent-red);background:#ef444421;border:1px solid #ef44444d}.confirm-icon.tone-info{color:var(--accent-blue);background:#3b82f621;border:1px solid #3b82f64d}.confirm-dialog h3{color:var(--fg-1);letter-spacing:-.01em;margin:0 0 8px;font-size:17px;font-weight:700}.confirm-dialog p{color:var(--fg-3);text-wrap:pretty;margin:0 0 22px;font-size:13px;line-height:1.5}.confirm-actions{justify-content:center;gap:10px;margin-bottom:14px;display:flex}.confirm-actions .btn{justify-content:center;min-width:130px;padding:10px 16px;font-size:13px}.btn-danger{background:var(--accent-red);color:#fff}.btn-danger:hover{filter:brightness(1.08)}.confirm-foot{color:var(--fg-5);border-top:1px solid var(--border-soft);justify-content:center;gap:16px;padding-top:12px;font-size:11px;display:flex}.confirm-foot span{align-items:center;gap:5px;display:inline-flex}.donut-svg{width:100%;height:100%}html,body,#root{height:100%;margin:0}body{overflow:hidden}*{box-sizing:border-box}.hd-app{background:var(--bg);height:100vh;color:var(--fg-2);display:flex}.hd-sidebar{background:#ffffff0d;border-right:1px solid #ffffff0f;flex-direction:column;flex-shrink:0;align-items:center;gap:8px;width:72px;padding:20px 0;display:flex}.hd-avatar{background:var(--grad-avatar);color:#fff;-webkit-user-select:none;user-select:none;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;margin-bottom:12px;font-size:13px;font-weight:700;display:flex}.hd-nav-btn{width:44px;height:44px;color:var(--fg-3);cursor:pointer;background:0 0;border:0;border-radius:14px;justify-content:center;align-items:center;font-size:20px;transition:background .2s,color .2s;display:flex;position:relative}.hd-nav-btn:hover{color:#e5e7eb;background:#ffffff14}.hd-nav-btn.is-active{color:var(--accent-blue);background:#3b82f640}.hd-nav-rail{background:var(--accent-blue);border-radius:0 4px 4px 0;width:4px;height:24px;position:absolute;top:50%;left:-10px;transform:translateY(-50%)}.hd-main{flex:1;min-height:0;overflow-y:auto}.hd-main::-webkit-scrollbar{width:4px}.hd-main::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:999px}.hd-grid{grid-template-columns:1fr;align-items:start;gap:14px;padding:16px;display:grid}@media (width>=768px){.hd-grid{grid-template-columns:1fr 1fr}}@media (width>=1024px){.hd-grid{grid-template-columns:1fr 1fr 1fr}}.hd-col{flex-direction:column;gap:14px;display:flex}.hd-widget{-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);color:var(--fg-2);background:#ffffff0d;border-radius:18px;padding:16px}.hd-widget-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.hd-widget-title{color:#fff;margin:0;font-size:16px;font-weight:700}.hd-drag{color:var(--fg-4);cursor:grab;-webkit-user-select:none;user-select:none;border-radius:6px;padding:4px;font-size:16px}.hd-drag:hover{color:#e5e7eb;background:#ffffff0d}.hd-menu{color:var(--fg-4);cursor:pointer;letter-spacing:.1em;background:0 0;border:0;padding:2px 4px;font-size:16px}.hd-menu:hover{color:#e5e7eb}.hd-toggle{background:var(--accent-blue);border-radius:9999px;width:36px;height:20px;transition:background .2s;display:inline-block;position:relative}.hd-toggle:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:left .2s;position:absolute;top:2px;left:18px}.hd-toggle.is-off{background:#fff3}.hd-toggle.is-off:after{left:2px}.hd-empty{flex-direction:column;justify-content:center;align-items:center;gap:14px;height:100%;display:flex}.hd-empty-ico{opacity:.3;font-size:56px}.hd-empty-label{color:var(--fg-4);text-transform:capitalize;font-size:20px}.hd-settings{max-width:440px;margin:0 auto;padding:32px}.hd-settings h1{color:#fff;margin:0 0 22px;font-size:24px;font-weight:700}.hd-lang-buttons{gap:10px;display:flex}.hd-lang-btn{border:1px solid var(--border);color:var(--fg-3);cursor:pointer;background:#ffffff0a;border-radius:12px;flex:1;padding:12px;font-size:13px;font-weight:600;transition:all .2s}.hd-lang-btn.is-active{border-color:var(--accent-blue);color:var(--accent-blue);background:#3b82f640}.hd-lang-btn:hover:not(.is-active){background:#ffffff14}.hd-bottom-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1a2ecc;border-top:1px solid #ffffff14;display:flex;position:fixed;bottom:0;left:0;right:0}.hd-bn-btn{min-height:56px;color:var(--fg-3);cursor:pointer;background:0 0;border:0;flex-direction:column;flex:1;align-items:center;gap:4px;padding:10px 2px;font-size:11px;transition:color .2s;display:flex}.hd-bn-btn.is-active{color:var(--accent-blue)}.hd-bn-ico{font-size:20px;line-height:1}@media (width>=768px){.hd-bottom-nav{display:none}}@media (width<=767px){.hd-sidebar{display:none}}.centered-fill{width:100vw;height:100vh;color:var(--fg-3);place-items:center;font-size:14px;display:grid}.widget-state{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:80px;padding:8px;display:flex}.widget-state-error{color:var(--accent-red)}.widget-spinner{flex-direction:column;align-items:center;display:flex}.spinner-ring{border:2px solid var(--surface-2);border-top-color:var(--accent-blue);border-radius:50%;width:22px;height:22px;animation:.9s linear infinite spin}.gh-grid-wrap{width:100%;min-height:100%;display:block}.react-grid-item.react-grid-placeholder{background:var(--accent-blue)!important;opacity:.2!important;border-radius:var(--r-card)!important}.react-grid-item>.react-resizable-handle{background-image:none!important}.react-grid-item.react-draggable-dragging,.react-grid-item.resizing{z-index:5}.gh-grid-wrap.is-edit .react-grid-item{outline:1px dashed var(--accent-blue);outline-offset:-2px;border-radius:var(--r-card)}.react-grid-item>div,.react-grid-item>.w{width:100%;height:100%}.bottom-nav{background:var(--bg);border-top:1px solid var(--border);z-index:40;padding:6px 0 max(env(safe-area-inset-bottom), 6px);display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav button{color:var(--fg-3);cursor:pointer;background:0 0;border:0;flex-direction:column;flex:1;align-items:center;gap:2px;padding:4px;font-size:10px;display:flex}.bottom-nav button.is-active{color:var(--accent-blue)}.locale-switch{border:1px solid var(--border);border-radius:var(--r-pill);gap:2px;padding:2px;display:inline-flex}.locale-switch button{color:var(--fg-3);border-radius:var(--r-pill);cursor:pointer;background:0 0;border:0;padding:2px 8px;font-size:11px}.locale-switch button.is-active{background:var(--accent-blue);color:#fff}.settings-pop{background:var(--bg);border-left:1px solid var(--border);z-index:60;width:420px;max-width:100vw;padding:20px;position:fixed;top:0;bottom:0;right:0;overflow-y:auto;box-shadow:-20px 0 60px #0006}.settings-section{margin-bottom:24px}.settings-section h4{text-transform:uppercase;letter-spacing:.08em;color:var(--fg-4);margin:0 0 8px;font-size:12px;font-weight:600}.settings-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.settings-row .input{flex:1;max-width:200px}.accent-swatches{gap:8px;display:flex}.accent-swatches button{cursor:pointer;border:2px solid #0000;border-radius:50%;width:24px;height:24px}.accent-swatches button.is-active{border-color:var(--fg-1)}.skel{background:linear-gradient(90deg, var(--surface-2) 0%, var(--surface-hover) 50%, var(--surface-2) 100%);background-size:200% 100%;border-radius:6px;animation:1.4s ease-in-out infinite skel-shimmer}@keyframes skel-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.react-grid-layout{transition:height .2s;position:relative}.react-grid-item{transition:left .2s,top .2s,width .2s,height .2s}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{z-index:1;will-change:width, height;transition:none}.react-grid-item.react-draggable-dragging{z-index:3;will-change:transform;transition:none}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{opacity:.2;z-index:2;-webkit-user-select:none;user-select:none;-o-user-select:none;background:red;transition-duration:.1s}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{width:20px;height:20px;position:absolute}.react-grid-item>.react-resizable-handle:after{content:"";border-bottom:2px solid #0006;border-right:2px solid #0006;width:5px;height:5px;position:absolute;bottom:3px;right:3px}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{cursor:sw-resize;bottom:0;left:0;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{cursor:se-resize;bottom:0;right:0}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{cursor:nw-resize;top:0;left:0;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{cursor:ne-resize;top:0;right:0;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{cursor:ew-resize;margin-top:-10px;top:50%}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{cursor:ns-resize;margin-left:-10px;left:50%}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-resizable{position:relative}.react-resizable-handle{box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:100% 100%;background-repeat:no-repeat;background-origin:content-box;width:20px;height:20px;padding:0 3px 3px 0;position:absolute}.react-resizable-handle-sw{cursor:sw-resize;bottom:0;left:0;transform:rotate(90deg)}.react-resizable-handle-se{cursor:se-resize;bottom:0;right:0}.react-resizable-handle-nw{cursor:nw-resize;top:0;left:0;transform:rotate(180deg)}.react-resizable-handle-ne{cursor:ne-resize;top:0;right:0;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{cursor:ew-resize;margin-top:-10px;top:50%}.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-resizable-handle-n,.react-resizable-handle-s{cursor:ns-resize;margin-left:-10px;left:50%}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}
