:root,[data-theme=dark]{--bg:#0a0a0c;--bg-2:#111114;--panel:#16161a;--panel-2:#1d1d22;--panel-3:#25252b;--border:#2a2a32;--border-bright:#3a3a45;--ink:#e8e6e0;--ink-dim:#8a877e;--ink-faint:#4a4842;--ink-ghost:#2a2826;--accent:#ff5a1f;--accent-2:#ffb347;--accent-soft:rgba(255,90,31,0.15);--green:#6bd968;--red:#ff4d4d;--blue:#6db6ff;--purple:#b388ff;--yellow:#ffd84d;--shadow-win:0 20px 60px rgba(0,0,0,0.6),0 4px 12px rgba(0,0,0,0.4);--shadow-win-focus:0 24px 80px rgba(255,90,31,0.18),0 4px 12px rgba(0,0,0,0.5);--wallpaper:radial-gradient(ellipse at 18% 22%,rgba(255,90,31,0.10) 0%,transparent 35%),radial-gradient(ellipse at 82% 78%,rgba(109,182,255,0.06) 0%,transparent 40%),radial-gradient(ellipse at 50% 50%,transparent 40%,rgba(0,0,0,0.55) 100%);--stars-pattern:radial-gradient(circle at 7% 14%,rgba(255,255,255,0.55) 1px,transparent 1.5px),radial-gradient(circle at 22% 8%,rgba(255,255,255,0.35) 0.9px,transparent 1.4px),radial-gradient(circle at 37% 22%,rgba(255,255,255,0.65) 1.2px,transparent 1.8px),radial-gradient(circle at 53% 11%,rgba(255,255,255,0.45) 1px,transparent 1.5px),radial-gradient(circle at 68% 18%,rgba(255,255,255,0.4) 1px,transparent 1.5px),radial-gradient(circle at 84% 9%,rgba(255,255,255,0.55) 1.2px,transparent 1.7px),radial-gradient(circle at 95% 23%,rgba(255,255,255,0.35) 1px,transparent 1.5px),radial-gradient(circle at 14% 38%,rgba(255,255,255,0.45) 1px,transparent 1.5px),radial-gradient(circle at 33% 47%,rgba(255,255,255,0.3) 0.8px,transparent 1.3px),radial-gradient(circle at 47% 35%,rgba(255,255,255,0.55) 1.3px,transparent 1.8px),radial-gradient(circle at 62% 42%,rgba(255,255,255,0.4) 1px,transparent 1.5px),radial-gradient(circle at 78% 55%,rgba(255,255,255,0.45) 1px,transparent 1.5px),radial-gradient(circle at 90% 65%,rgba(255,255,255,0.3) 0.8px,transparent 1.3px),radial-gradient(circle at 8% 72%,rgba(255,255,255,0.5) 1.2px,transparent 1.7px),radial-gradient(circle at 24% 85%,rgba(255,255,255,0.35) 1px,transparent 1.5px),radial-gradient(circle at 42% 92%,rgba(255,255,255,0.45) 1.1px,transparent 1.6px),radial-gradient(circle at 59% 78%,rgba(255,255,255,0.55) 1.3px,transparent 1.8px),radial-gradient(circle at 73% 88%,rgba(255,255,255,0.4) 1px,transparent 1.5px),radial-gradient(circle at 88% 95%,rgba(255,255,255,0.45) 1px,transparent 1.5px);--grid-color:rgba(255,255,255,0.02)}[data-theme=light]{--bg:#f0e8d4;--bg-2:#ebe2ca;--panel:#f5efe0;--panel-2:#ede4cd;--panel-3:#d8cdb0;--border:#c4b89a;--border-bright:#9c8e6f;--ink:#1a1614;--ink-dim:#5a4f40;--ink-faint:#8a7e6a;--ink-ghost:#c8bca0;--accent:#d94815;--accent-2:#b8390e;--accent-soft:rgba(217,72,21,0.12);--green:#2d8a3a;--red:#c43030;--blue:#2a6fb8;--purple:#7a4ac4;--yellow:#c4a000;--shadow-win:0 20px 40px rgba(74,58,32,0.18),0 4px 12px rgba(74,58,32,0.12);--shadow-win-focus:0 24px 60px rgba(217,72,21,0.20),0 4px 12px rgba(74,58,32,0.18);--wallpaper:radial-gradient(ellipse at 18% 22%,rgba(217,72,21,0.10) 0%,transparent 40%),radial-gradient(ellipse at 82% 78%,rgba(196,160,0,0.08) 0%,transparent 45%);--stars-pattern:radial-gradient(circle at 7% 14%,rgba(26,22,20,0.20) 1px,transparent 1.5px),radial-gradient(circle at 22% 8%,rgba(26,22,20,0.12) 0.9px,transparent 1.4px),radial-gradient(circle at 37% 22%,rgba(26,22,20,0.25) 1.2px,transparent 1.8px),radial-gradient(circle at 53% 11%,rgba(26,22,20,0.15) 1px,transparent 1.5px),radial-gradient(circle at 68% 18%,rgba(26,22,20,0.14) 1px,transparent 1.5px),radial-gradient(circle at 84% 9%,rgba(26,22,20,0.22) 1.2px,transparent 1.7px),radial-gradient(circle at 95% 23%,rgba(26,22,20,0.12) 1px,transparent 1.5px),radial-gradient(circle at 14% 38%,rgba(26,22,20,0.15) 1px,transparent 1.5px),radial-gradient(circle at 33% 47%,rgba(26,22,20,0.10) 0.8px,transparent 1.3px),radial-gradient(circle at 47% 35%,rgba(26,22,20,0.22) 1.3px,transparent 1.8px),radial-gradient(circle at 62% 42%,rgba(26,22,20,0.14) 1px,transparent 1.5px),radial-gradient(circle at 78% 55%,rgba(26,22,20,0.15) 1px,transparent 1.5px),radial-gradient(circle at 90% 65%,rgba(26,22,20,0.10) 0.8px,transparent 1.3px),radial-gradient(circle at 8% 72%,rgba(26,22,20,0.20) 1.2px,transparent 1.7px),radial-gradient(circle at 24% 85%,rgba(26,22,20,0.12) 1px,transparent 1.5px),radial-gradient(circle at 42% 92%,rgba(26,22,20,0.18) 1.1px,transparent 1.6px),radial-gradient(circle at 59% 78%,rgba(26,22,20,0.22) 1.3px,transparent 1.8px),radial-gradient(circle at 73% 88%,rgba(26,22,20,0.14) 1px,transparent 1.5px),radial-gradient(circle at 88% 95%,rgba(26,22,20,0.18) 1px,transparent 1.5px);--grid-color:rgba(26,22,20,0.03);--chrome-bg-1:#c4ad84;--chrome-bg-2:#a89368;--chrome-ink:#1a1614;--chrome-border:#8a7656}[data-accent=amber]{--accent:#ffaa00;--accent-2:#ffd84d;--accent-soft:rgba(255,170,0,0.15)}[data-accent=green]{--accent:#00d96b;--accent-2:#6bd968;--accent-soft:rgba(0,217,107,0.12)}[data-accent=cyan]{--accent:#00d4ff;--accent-2:#6db6ff;--accent-soft:rgba(0,212,255,0.12)}[data-accent=magenta]{--accent:#ff4dc4;--accent-2:#ff8adb;--accent-soft:rgba(255,77,196,0.12)}[data-theme=light][data-accent=amber]{--accent:#b8810a;--accent-2:#d09a14}[data-theme=light][data-accent=green]{--accent:#1a7a3a;--accent-2:#2d8a3a}[data-theme=light][data-accent=cyan]{--accent:#146fa0;--accent-2:#2090c4}[data-theme=light][data-accent=magenta]{--accent:#b53480;--accent-2:#c44a98}*{box-sizing:border-box}body,html{margin:0;padding:0;overflow:hidden;height:100%}body{color:var(--ink);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased}.os-root,body{background:var(--bg);font-family:var(--font-mono)}.os-root{position:fixed;inset:0;background-image:var(--wallpaper);overflow:hidden;-webkit-user-select:none;-moz-user-select:none;user-select:none;height:100dvh}input,textarea{-moz-user-select:text;user-select:text;-webkit-user-select:text;touch-action:manipulation}.os-root[data-scanlines=on]:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.018) 0 1px,transparent 1px 3px);pointer-events:none;z-index:9999;mix-blend-mode:overlay}[data-theme=light] .os-root[data-scanlines=on]:before{background-image:repeating-linear-gradient(0deg,rgba(26,22,20,.03) 0 1px,transparent 1px 3px)}.os-root[data-wallpaper=grid]{background-image:linear-gradient(var(--grid-color) 1px,transparent 1px),linear-gradient(90deg,var(--grid-color) 1px,transparent 1px),var(--stars-pattern),var(--wallpaper);background-size:32px 32px,32px 32px,100% 100%,100% 100%}.os-root[data-wallpaper=stars]{background-image:var(--stars-pattern),var(--wallpaper)}[data-theme=light] .menubar{background:linear-gradient(180deg,var(--chrome-bg-1) 0,var(--chrome-bg-2) 100%);border-bottom-color:var(--chrome-border);color:var(--chrome-ink)}[data-theme=light] .menubar .item{color:var(--chrome-ink)}[data-theme=light] .menubar .item.active,[data-theme=light] .menubar .item:hover{background:rgba(255,255,255,.25);color:var(--ink)}[data-theme=light] .menubar .clock,[data-theme=light] .menubar .tick .sym{color:var(--chrome-ink)}[data-theme=light] .menubar .tick .px{color:rgba(26,22,20,.65)}[data-theme=light] .taskbar{background:linear-gradient(180deg,var(--chrome-bg-1) 0,var(--chrome-bg-2) 100%);border-top-color:var(--chrome-border)}[data-theme=light] .tb-app{background:rgba(255,255,255,.25);border-color:var(--chrome-border);color:rgba(26,22,20,.7)}[data-theme=light] .tb-app.on{background:var(--panel);color:var(--ink);border-color:var(--accent)}[data-theme=light] .tb-tray{color:var(--chrome-ink)}[data-theme=light] .tb-tray .theme-toggle{border-color:var(--chrome-border);color:var(--chrome-ink)}.os-desk{position:absolute;top:28px;left:0;right:0;bottom:38px}.menubar{height:28px;background:linear-gradient(180deg,var(--panel-2) 0,var(--bg-2) 100%);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 14px;gap:18px;font-family:var(--font-pixel);font-size:9px;letter-spacing:.08em;color:var(--ink-dim);position:relative;z-index:100}.menubar .logo{color:var(--accent);font-weight:700;cursor:default}.menubar .item{cursor:pointer;padding:4px 6px}.menubar .item.active,.menubar .item:hover{color:var(--ink);background:var(--panel-3)}.menubar .spacer{flex:1}.ticker{gap:14px;font-family:var(--font-mono);font-size:11px;letter-spacing:0;overflow:hidden;max-width:50%}.tick,.ticker{display:flex;align-items:center}.tick{gap:4px;white-space:nowrap}.tick .sym{color:var(--ink);font-weight:600}.tick .px{color:var(--ink-dim);font-variant-numeric:tabular-nums}.tick.up .delta{color:var(--green)}.tick.down .delta{color:var(--red)}.tick.up .sym:after{content:" ▲";color:var(--green);font-size:8px}.tick.down .sym:after{content:" ▼";color:var(--red);font-size:8px}.menubar .clock{color:var(--ink);font-variant-numeric:tabular-nums;font-family:var(--font-mono);letter-spacing:0;font-size:11px}.menubar .tweaks-btn{font-family:var(--font-pixel);font-size:8px;letter-spacing:.15em;padding:4px 8px;background:var(--accent);color:var(--bg);cursor:pointer;margin-left:8px}.menubar .tweaks-btn:hover{filter:brightness(1.1)}.boot{position:fixed;inset:0;background:#000;color:#ff5a1f;font-family:var(--font-mono);z-index:99999;font-size:13px;line-height:1.4;white-space:pre-wrap;overflow:hidden;padding:40px}@media (max-width:640px){.boot{font-size:8px;padding:10px;line-height:1.25}.boot pre.logo{font-size:4.5px;line-height:1.05;margin:4px 0}.boot .cta-line{margin-top:4px;font-size:9px}}@media (max-width:1023px) and (min-width:641px){.boot{font-size:11px;padding:20px;line-height:1.3}.boot pre.logo{font-size:8px}}.boot .cta-line{margin-top:14px;color:#ff5a1f;font-weight:700;animation:cta-blink .7s steps(2) infinite;text-shadow:0 0 6px rgba(255,90,31,.6)}.boot .cta-line .prompt{color:#ff5a1f;opacity:.8}@keyframes cta-blink{50%{opacity:.45}}@media (max-width:640px){.boot{font-size:11px}.boot-log{padding:20px 16px 12px}.boot-foot{padding:10px 16px 18px}.boot pre.logo{font-size:7px}}.boot pre.logo{color:#ff5a1f;font-size:11px;line-height:1.15;text-shadow:0 0 8px rgba(255,90,31,.6);margin-bottom:20px}.boot .line.dim{color:#888}.boot .line.ok:before{content:"[ ";color:#6bd968}.boot .line.ok:after{content:" ] ";color:#6bd968}.boot .cursor{display:inline-block;width:9px;height:14px;background:#ff5a1f;vertical-align:-2px;animation:blink-bk .8s steps(2) infinite}@keyframes blink-bk{50%{opacity:0}}.win{position:absolute;background:var(--panel);border:1px solid var(--border-bright);box-shadow:0 0 0 1px rgba(0,0,0,.4),var(--shadow-win);display:flex;flex-direction:column;min-width:240px;min-height:120px;transition:transform .18s cubic-bezier(.2,.7,.3,1),opacity .18s}.win.focused{box-shadow:0 0 0 1px var(--accent),var(--shadow-win-focus);z-index:50}.win.minimized{transform:scale(.5);opacity:0;pointer-events:none}.win.maximized{transition:top .2s,left .2s,width .2s,height .2s}.win .tb{height:26px;background:repeating-linear-gradient(180deg,rgba(255,255,255,.04) 0 1px,transparent 1px 2px),var(--bg-2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 8px;gap:8px;font-family:var(--font-pixel);font-size:8px;letter-spacing:.1em;color:var(--ink-dim);text-transform:uppercase;cursor:grab;flex-shrink:0}[data-theme=light] .win .tb{background:repeating-linear-gradient(180deg,rgba(0,0,0,.04) 0 1px,transparent 1px 2px),var(--bg-2)}.win .tb:active{cursor:grabbing}.win.focused .tb{color:var(--ink)}.win .dots{display:flex;gap:4px;flex-shrink:0}.win .dot{width:12px;height:12px;background:var(--border-bright);border:1px solid rgba(0,0,0,.4);cursor:pointer;position:relative}.win.focused .dot.close{background:var(--accent)}.win.focused .dot.min{background:var(--accent-2)}.win.focused .dot.max{background:var(--green)}.win .dot:hover:after{content:attr(data-glyph);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:monospace;font-size:8px;color:rgba(0,0,0,.7)}.win .tb .title{flex:1;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none}.win .tb .meta{color:var(--ink-faint);font-family:var(--font-mono);text-transform:none;letter-spacing:0;font-size:10px;flex-shrink:0}.win .body{flex:1;overflow:auto;position:relative}.app-projects,.app-stocks .symbol-tabs,.app-terminal .log,.pj-grid,.pj-side,.start-menu,.tb-apps,.win .body{scrollbar-width:thin;scrollbar-color:var(--accent) var(--bg-2)}.app-terminal .log::-webkit-scrollbar,.pj-grid::-webkit-scrollbar,.pj-side::-webkit-scrollbar,.start-menu::-webkit-scrollbar,.win .body::-webkit-scrollbar{width:12px;height:12px}.app-terminal .log::-webkit-scrollbar-track,.pj-grid::-webkit-scrollbar-track,.pj-side::-webkit-scrollbar-track,.start-menu::-webkit-scrollbar-track,.win .body::-webkit-scrollbar-track{background:var(--bg-2);border-left:1px solid var(--border);background-image:repeating-linear-gradient(45deg,transparent 0 4px,rgba(255,255,255,.025) 4px 5px)}[data-theme=light] .app-terminal .log::-webkit-scrollbar-track,[data-theme=light] .pj-grid::-webkit-scrollbar-track,[data-theme=light] .pj-side::-webkit-scrollbar-track,[data-theme=light] .start-menu::-webkit-scrollbar-track,[data-theme=light] .win .body::-webkit-scrollbar-track{background-image:repeating-linear-gradient(45deg,transparent 0 4px,rgba(0,0,0,.04) 4px 5px)}.app-terminal .log::-webkit-scrollbar-thumb,.pj-grid::-webkit-scrollbar-thumb,.pj-side::-webkit-scrollbar-thumb,.start-menu::-webkit-scrollbar-thumb,.win .body::-webkit-scrollbar-thumb{background:var(--accent);box-shadow:inset 1px 1px 0 rgba(255,255,255,.35),inset -1px -1px 0 rgba(0,0,0,.35);background-image:repeating-linear-gradient(0deg,transparent 0 3px,rgba(0,0,0,.18) 3px 4px);min-height:32px}.app-terminal .log::-webkit-scrollbar-thumb:hover,.pj-grid::-webkit-scrollbar-thumb:hover,.pj-side::-webkit-scrollbar-thumb:hover,.start-menu::-webkit-scrollbar-thumb:hover,.win .body::-webkit-scrollbar-thumb:hover{background-color:var(--accent-2)}.app-terminal .log::-webkit-scrollbar-corner,.win .body::-webkit-scrollbar-corner{background:var(--bg-2);border-left:1px solid var(--border);border-top:1px solid var(--border)}.app-terminal .log::-webkit-scrollbar-button:vertical:decrement,.win .body::-webkit-scrollbar-button:vertical:decrement{height:12px;background:var(--panel-2);border:1px solid var(--border);background-image:linear-gradient(45deg,transparent 45%,var(--accent) 45%,var(--accent) 55%,transparent 55%),linear-gradient(-45deg,transparent 45%,var(--accent) 45%,var(--accent) 55%,transparent 55%);background-size:7px 4px;background-repeat:no-repeat;background-position:3px 4px,3px 4px}.app-terminal .log::-webkit-scrollbar-button:vertical:increment,.win .body::-webkit-scrollbar-button:vertical:increment{height:12px;background:var(--panel-2);border:1px solid var(--border);background-image:linear-gradient(-45deg,transparent 45%,var(--accent) 45%,var(--accent) 55%,transparent 55%),linear-gradient(45deg,transparent 45%,var(--accent) 45%,var(--accent) 55%,transparent 55%);background-size:7px 4px;background-repeat:no-repeat;background-position:3px 4px,3px 4px}.app-stocks .symbol-tabs::-webkit-scrollbar,.tb-apps::-webkit-scrollbar{height:0;width:0}.app-about{padding:16px 20px;font-size:13px}.app-about,.ascii-logo{font-family:var(--font-mono)}.ascii-logo{font-size:10px;line-height:1.15;color:var(--accent);white-space:pre;margin:0 0 14px;text-shadow:0 0 6px var(--accent-soft)}.term-line{display:flex;gap:8px;flex-wrap:wrap;margin:3px 0}.term-line .prompt{color:var(--accent);flex-shrink:0}.term-line .cmd{color:var(--ink)}.term-line.out{padding-left:0;color:var(--ink-dim)}.term-line.out .ok{color:var(--green)}.term-line.out .em{color:var(--accent-2)}.term-line.out .lk{color:var(--blue);text-decoration:underline;cursor:pointer}.kv{display:grid;grid-template-columns:110px 1fr;gap:2px 16px;margin:6px 0;font-size:12px}.kv .k{color:var(--ink-faint)}.kv .v{color:var(--ink)}.kv .v.acc{color:var(--accent)}.cursor-block{display:inline-block;width:8px;height:14px;background:var(--accent);vertical-align:-2px;animation:blink-bk .8s steps(2) infinite}.app-hero{padding:32px 36px;background:linear-gradient(135deg,var(--panel) 0,var(--bg) 100%);position:relative;height:100%;display:flex;flex-direction:column;justify-content:center}.hero-eyebrow{font-family:var(--font-pixel);font-size:9px;letter-spacing:.3em;color:var(--ink-dim);margin-bottom:12px}.hero-eyebrow .led{display:inline-block;width:8px;height:8px;background:var(--green);margin-right:8px;vertical-align:1px;animation:blink-bk 1.2s steps(2) infinite}.hero-name{font-family:var(--font-serif);font-size:64px;line-height:.95;color:var(--ink);margin:0 0 4px;letter-spacing:-.02em;font-weight:400}.hero-name em{font-style:italic;color:var(--accent)}.hero-name .px-name{display:inline-block;font-family:var(--font-pixel);font-weight:700;font-size:.6em;line-height:1.25;letter-spacing:.01em;margin-bottom:6px}.hero-name .px-name em{font-style:normal}.hero-tag{font-family:var(--font-pixel-soft);font-size:20px;color:var(--ink-dim);letter-spacing:.02em;margin:10px 0 22px}.hero-meta{display:flex;gap:22px;flex-wrap:wrap;font-family:var(--font-mono);font-size:11px;color:var(--ink-dim)}.hero-meta b{color:var(--ink);font-weight:500}.hero-meta .dot{color:var(--accent)}.hero-cta{display:flex;gap:8px;margin-top:24px}.hero-cta button{background:var(--accent);color:var(--bg);border:0;padding:10px 16px;font-family:var(--font-pixel);font-size:9px;letter-spacing:.15em;cursor:pointer}.hero-cta button.ghost{background:transparent;color:var(--ink);border:1px solid var(--border-bright)}.hero-cta button:hover{filter:brightness(1.1);transform:translateY(-1px)}.mascot{position:absolute;right:24px;bottom:24px;width:88px;height:110px;image-rendering:pixelated}.mascot.bob{animation:bob-up-down 2.4s ease-in-out infinite}@keyframes bob-up-down{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.app-projects{display:grid;grid-template-columns:160px 1fr;height:100%}.pj-side{border-right:1px solid var(--border);padding:12px 6px;background:rgba(0,0,0,.18);font-family:var(--font-mono);font-size:11px;overflow:auto}[data-theme=light] .pj-side{background:rgba(0,0,0,.04)}.pj-side .h{font-family:var(--font-pixel);font-size:8px;letter-spacing:.15em;color:var(--ink-faint);text-transform:uppercase;padding:6px 8px;margin-top:6px}.pj-side .it{display:flex;align-items:center;gap:8px;padding:5px 8px;color:var(--ink-dim);cursor:pointer;border-radius:2px}.pj-side .it:hover{background:var(--accent-soft);color:var(--ink)}.pj-side .it.on{background:var(--accent-soft);color:var(--accent)}.pj-side .it:before{content:"";width:12px;height:10px;background:currentColor;clip-path:polygon(0 0,40% 0,50% 20%,100% 20%,100% 100%,0 100%);opacity:.7;flex-shrink:0}.pj-grid{padding:12px;display:grid;grid-template-columns:1fr 1fr;gap:10px;align-content:start;overflow:auto}.pj-row{display:grid;grid-template-columns:44px 1fr auto;gap:12px;align-items:center;padding:10px 12px;background:rgba(255,255,255,.02);border:1px solid var(--border);cursor:pointer;transition:.12s}[data-theme=light] .pj-row{background:rgba(0,0,0,.03)}.pj-row:hover{background:var(--accent-soft);border-color:var(--accent);transform:translateY(-1px)}.pj-icon{width:44px;height:44px;image-rendering:pixelated}.pj-name{font-family:var(--font-pixel-soft);font-size:15px;color:var(--ink);line-height:1.1;margin-bottom:2px}.pj-desc{font-size:10.5px;color:var(--ink-dim)}.pj-stack{font-family:var(--font-mono);font-size:9px;color:var(--ink-faint);margin-top:3px;letter-spacing:.04em}.pj-tag{font-family:var(--font-pixel);font-size:7px;letter-spacing:.1em;padding:3px 6px;border:1px solid;color:var(--green);align-self:start}.pj-tag.wip{color:var(--accent-2)}.pj-tag.exp,.pj-tag.game{color:var(--purple)}.pj-tag.arch{color:var(--ink-faint)}.app-detail{padding:22px 28px;font-family:var(--font-mono);font-size:13px;color:var(--ink-dim);line-height:1.55}.app-detail h2{font-family:var(--font-serif);font-size:44px;line-height:1;color:var(--ink);margin:8px 0 6px;letter-spacing:-.02em;font-weight:400}.app-detail h2 em{color:var(--accent);font-style:italic}.app-detail .crumb{font-family:var(--font-pixel);font-size:9px;letter-spacing:.2em;color:var(--ink-faint);text-transform:uppercase}.app-detail .crumb .acc{color:var(--accent)}.app-detail .desc{color:var(--ink-dim);font-size:14px;margin:14px 0 22px;max-width:60ch}.app-detail .desc b{color:var(--ink)}.app-detail .preview{width:100%;height:240px;background:var(--bg-2);border:1px solid var(--border);image-rendering:pixelated;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;margin-bottom:22px}.app-detail .preview svg{width:100%;height:100%}.app-detail h3{font-family:var(--font-pixel);font-size:10px;letter-spacing:.2em;color:var(--accent);text-transform:uppercase;margin:20px 0 10px}.app-detail h3:before{content:"▮ "}.app-detail ul{list-style:none;padding:0;margin:0}.app-detail ul li{padding:6px 0 6px 18px;position:relative;font-size:13px;color:var(--ink-dim);border-bottom:1px dashed var(--border)}.app-detail ul li:last-child{border-bottom:0}.app-detail ul li:before{content:"→";position:absolute;left:0;color:var(--accent)}.app-detail ul li b{color:var(--ink)}.app-detail .chips{display:flex;gap:4px;flex-wrap:wrap}.app-detail .chip{font-family:var(--font-pixel-soft);font-size:12px;padding:3px 9px;background:rgba(255,255,255,.03);border:1px solid var(--border);color:var(--ink)}[data-theme=light] .app-detail .chip{background:rgba(0,0,0,.04)}.app-detail .chip.hot{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}.app-detail .links{display:flex;gap:14px;margin-top:12px;flex-wrap:wrap}.app-detail .links a{font-family:var(--font-pixel);font-size:9px;letter-spacing:.15em;color:var(--accent);text-decoration:none;border:1px solid var(--accent);padding:8px 12px;cursor:pointer}.app-detail .links a:hover{background:var(--accent);color:var(--bg)}.app-stocks{display:flex;flex-direction:column;height:100%}.app-stocks .head{padding:12px 14px;display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--border)}.app-stocks .head .sym{font-family:var(--font-pixel-soft);font-size:22px;color:var(--ink);letter-spacing:.05em}.app-stocks .head .sym small{font-family:var(--font-mono);font-size:10px;color:var(--ink-faint);letter-spacing:0}.app-stocks .head .px{font-family:var(--font-mono);font-size:26px;color:var(--green);font-weight:700;font-variant-numeric:tabular-nums}.app-stocks .head .px.down{color:var(--red)}.app-stocks .head .ch{font-size:11px;margin-left:8px}.app-stocks .symbol-tabs{display:flex;border-bottom:1px solid var(--border);overflow-x:auto}.app-stocks .symbol-tabs::-webkit-scrollbar{height:0}.app-stocks .symbol-tabs .tab{padding:6px 10px;font-family:var(--font-pixel);font-size:8px;letter-spacing:.12em;color:var(--ink-dim);cursor:pointer;background:var(--panel-2);border-right:1px solid var(--border);display:flex;align-items:center;gap:5px;white-space:nowrap}.app-stocks .symbol-tabs .tab:hover{color:var(--ink)}.app-stocks .symbol-tabs .tab.on{background:var(--panel);color:var(--accent);border-bottom:2px solid var(--accent)}.app-stocks .symbol-tabs .tab .arrow{font-size:6px}.app-stocks .symbol-tabs .tab .arrow.up{color:var(--green)}.app-stocks .symbol-tabs .tab .arrow.down{color:var(--red)}.app-stocks .chart{flex:1;min-height:120px;position:relative;background:rgba(0,0,0,.15)}[data-theme=light] .app-stocks .chart{background:rgba(0,0,0,.03)}.app-stocks .chart svg{width:100%;height:100%;display:block}.app-stocks .foot{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:8px 14px 12px;font-size:10px;border-top:1px solid var(--border)}.app-stocks .foot .l{color:var(--ink-faint);font-family:var(--font-pixel);font-size:7px;letter-spacing:.1em}.app-stocks .foot .v{color:var(--ink);font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:12px}.app-now{padding:14px 16px;flex-direction:column}.app-now,.now-row{display:flex;gap:12px}.now-row{align-items:center}.now-icon{width:32px;height:32px;image-rendering:pixelated;flex-shrink:0}.now-text{flex:1;min-width:0}.now-label{font-family:var(--font-pixel);font-size:7px;letter-spacing:.15em;color:var(--ink-faint);text-transform:uppercase;margin-bottom:2px}.now-val{font-family:var(--font-mono);font-size:12px;color:var(--ink)}.now-val .dim{color:var(--ink-dim)}.app-skills{padding:16px 20px}.skills-h{font-family:var(--font-pixel);font-size:9px;letter-spacing:.2em;color:var(--ink-faint);margin:12px 0 8px;text-transform:uppercase}.skills-h:first-child{margin-top:0}.skills-h .count{color:var(--accent);margin-left:6px}.skill-grid{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:4px}.chip{font-family:var(--font-pixel-soft);font-size:13px;padding:4px 10px;background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--ink);letter-spacing:.02em}[data-theme=light] .chip{background:rgba(0,0,0,.04)}.chip.exp{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}.skill-bar{display:grid;grid-template-columns:110px 1fr 40px;align-items:center;gap:12px;margin:6px 0;font-size:12px}.skill-bar .n{color:var(--ink)}.skill-bar .b{height:8px;background:var(--bg-2);border:1px solid var(--border);position:relative;overflow:hidden}.skill-bar .b:before{background:linear-gradient(90deg,var(--accent),var(--accent-2))}.skill-bar .b:after,.skill-bar .b:before{content:"";position:absolute;left:0;top:0;bottom:0;width:var(--p,80%)}.skill-bar .b:after{background-image:repeating-linear-gradient(90deg,transparent 0 6px,rgba(0,0,0,.4) 6px 7px)}.skill-bar .y{color:var(--ink-faint);font-family:var(--font-mono);font-size:10px;text-align:right;font-variant-numeric:tabular-nums}.app-timeline{padding:18px 22px}.tl-row{display:grid;grid-template-columns:90px 18px 1fr;gap:8px;padding:8px 0;border-bottom:1px dashed var(--border)}.tl-row:last-child{border-bottom:0}.tl-when{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-faint);padding-top:2px}.tl-when b{color:var(--accent);font-weight:500;display:block}.tl-dot{position:relative}.tl-dot:before{top:6px;width:8px;height:8px;background:var(--accent)}.tl-dot:after,.tl-dot:before{content:"";position:absolute;left:50%;transform:translateX(-50%)}.tl-dot:after{top:14px;bottom:-16px;width:1px;background:var(--border)}.tl-row:last-child .tl-dot:after{display:none}.tl-content .role{font-family:var(--font-pixel-soft);font-size:14px;color:var(--ink);margin-bottom:1px}.tl-content .co{font-family:var(--font-mono);font-size:11px;color:var(--ink-dim);margin-bottom:4px}.tl-content .li{font-size:11.5px;color:var(--ink-dim);margin:1px 0;padding-left:10px;position:relative}.tl-content .li:before{content:"›";position:absolute;left:0;color:var(--accent)}.app-terminal{background:var(--bg);font-family:var(--font-mono);font-size:13px;height:100%;display:flex;flex-direction:column}.app-terminal .log{flex:1;overflow:auto;padding:14px 18px 6px;color:var(--ink-dim)}.app-terminal .log .l{margin:2px 0;white-space:pre-wrap;word-break:break-word}.app-terminal .log .l .p{color:var(--accent)}.app-terminal .log .l .u{color:var(--ink)}.app-terminal .log .l.out{color:var(--ink-dim);padding-left:0}.app-terminal .log .l.out .em{color:var(--accent-2)}.app-terminal .log .l.out .ok{color:var(--green)}.app-terminal .log .l.out .er{color:var(--red)}.app-terminal .log .l.out .lk{color:var(--blue);text-decoration:underline;cursor:pointer}.app-terminal .log .l.out b{color:var(--ink);font-weight:500}.app-terminal .input-row{display:flex;align-items:center;padding:6px 18px 14px;gap:8px}.app-terminal .input-row .p{color:var(--accent);font-family:var(--font-mono)}.app-terminal .input-row input{flex:1;background:transparent;border:0;outline:0;color:var(--ink);font-family:var(--font-mono);font-size:13px;caret-color:var(--accent)}.taskbar{position:absolute;left:0;right:0;bottom:0;height:38px;background:linear-gradient(180deg,var(--panel-2) 0,var(--bg-2) 100%);border-top:1px solid var(--border-bright);padding:0 8px;gap:6px;z-index:100}.start,.taskbar{display:flex;align-items:center}.start{gap:8px;padding:6px 12px;background:var(--accent);color:var(--bg);font-family:var(--font-pixel);font-size:9px;letter-spacing:.15em;cursor:pointer;flex-shrink:0}.start:before{content:"";width:12px;height:12px;background:var(--bg);clip-path:polygon(0 0,50% 0,50% 50%,100% 50%,100% 100%,50% 100%,50% 50%,0 50%)}.start:hover{filter:brightness(1.1)}.start.open{box-shadow:inset 0 0 0 2px var(--bg)}.tb-apps{display:flex;gap:4px;overflow-x:auto;flex:1;padding:0 4px}.tb-apps::-webkit-scrollbar{height:0}.tb-app{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--panel-2);border:1px solid var(--border);font-family:var(--font-pixel);font-size:8px;letter-spacing:.1em;color:var(--ink-dim);text-transform:uppercase;cursor:pointer;white-space:nowrap;flex-shrink:0;max-width:160px}.tb-app .lbl{overflow:hidden;text-overflow:ellipsis}.tb-app.on,.tb-app:hover{color:var(--ink)}.tb-app.on{background:var(--panel);border-color:var(--accent)}.tb-app .led{width:6px;height:6px;background:var(--green);box-shadow:0 0 4px var(--green);flex-shrink:0}.tb-app.minimized .led{background:var(--ink-faint);box-shadow:none}.tb-tray{display:flex;gap:12px;color:var(--ink-dim);font-family:var(--font-mono);font-size:11px;align-items:center;flex-shrink:0;padding:0 8px}.tb-tray .theme-toggle{font-family:var(--font-pixel);font-size:8px;letter-spacing:.12em;padding:4px 8px;border:1px solid var(--border-bright);cursor:pointer}.tb-tray .theme-toggle:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.start-menu{position:absolute;left:8px;bottom:44px;width:320px;background:var(--panel);border:1px solid var(--border-bright);box-shadow:var(--shadow-win);z-index:200;padding:14px}.start-menu h3{font-family:var(--font-pixel);font-size:9px;letter-spacing:.2em;color:var(--accent);margin:0 0 8px;text-transform:uppercase}.start-menu .user-card{background:var(--bg-2);border:1px solid var(--border);padding:12px;display:flex;align-items:center;gap:12px;margin-bottom:14px}.start-menu .user-card .avatar{width:40px;height:40px;image-rendering:pixelated}.start-menu .user-card .who{font-family:var(--font-pixel-soft);font-size:14px;color:var(--ink)}.start-menu .user-card .status{font-family:var(--font-mono);font-size:10px;color:var(--green)}.start-menu .grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}.start-menu .grid .it{padding:8px 10px;border:1px solid var(--border);font-family:var(--font-mono);font-size:11px;color:var(--ink);cursor:pointer;display:flex;align-items:center;gap:8px}.start-menu .grid .it:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.start-menu .grid .it:before{content:"";width:12px;height:10px;background:currentColor;clip-path:polygon(0 0,40% 0,50% 20%,100% 20%,100% 100%,0 100%)}.start-menu .foot{margin-top:14px;display:flex;justify-content:space-between;font-family:var(--font-pixel);font-size:8px;letter-spacing:.15em;color:var(--ink-faint)}.start-menu .foot .lk{color:var(--accent);cursor:pointer}.ctx-menu{position:absolute;background:var(--panel);border:1px solid var(--border-bright);box-shadow:var(--shadow-win);z-index:500;min-width:180px;font-family:var(--font-mono);font-size:11px}.ctx-menu .it{padding:7px 12px;cursor:pointer;color:var(--ink);display:flex;justify-content:space-between}.ctx-menu .it:hover{background:var(--accent);color:var(--bg)}.ctx-menu .it .sub{font-size:9px;color:var(--ink-faint);font-family:var(--font-pixel);letter-spacing:.1em}.ctx-menu .it:hover .sub{color:var(--bg);opacity:.7}.ctx-menu hr{border:0;border-top:1px solid var(--border);margin:4px 0}.desk-icons{position:absolute;right:12px;top:8px;display:grid;grid-template-columns:80px;gap:16px;z-index:0}.desk-icon{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 4px;cursor:pointer;border-radius:2px}.desk-icon:hover{background:var(--accent-soft)}.desk-icon .ic{width:36px;height:36px;image-rendering:pixelated}.desk-icon .lbl{font-family:var(--font-pixel);font-size:8px;letter-spacing:.1em;color:var(--ink);text-align:center;text-shadow:1px 1px 0 var(--bg)}.os-home,.os-root[data-device=mobile] .desk-icons{display:none}.os-root[data-device=mobile] .os-desk{bottom:58px}.os-root[data-device=mobile] .win.minimized{display:none}.os-root[data-device=mobile] .os-home{position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;padding:22px 16px 24px;overflow-y:auto}.os-home-h{font-family:var(--font-pixel);font-size:11px;letter-spacing:.3em;color:var(--accent);text-align:center;margin:6px 0 22px}.os-home-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px 10px;align-content:start}.os-home-app{flex-direction:column;gap:7px;background:transparent;border:0;padding:0;cursor:pointer;-webkit-tap-highlight-color:transparent}.os-home-app,.os-home-ico{display:flex;align-items:center}.os-home-ico{width:60px;height:60px;justify-content:center;border-radius:15px;background:linear-gradient(160deg,var(--panel-2),var(--bg-2));border:1px solid var(--border-bright);box-shadow:0 2px 8px rgba(0,0,0,.4),0 0 0 1px rgba(0,0,0,.3);transition:transform .1s ease}.os-home-ico svg{width:36px;height:36px;image-rendering:pixelated}.os-home-app:active .os-home-ico{transform:scale(.92);border-color:var(--accent)}.os-home-lbl{font-family:var(--font-pixel-soft);font-size:12px;letter-spacing:.02em;color:var(--ink);text-align:center;max-width:72px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:1px 1px 0 var(--bg)}.hint{position:absolute;left:50%;bottom:56px;transform:translateX(-50%);background:var(--panel);border:1px solid var(--accent);padding:8px 14px;font-family:var(--font-pixel);font-size:9px;letter-spacing:.15em;color:var(--ink);box-shadow:var(--shadow-win);z-index:90;display:flex;align-items:center;gap:8px;animation:hint-pop .4s ease-out}.hint:before{content:"▮";color:var(--accent)}.hint .k{display:inline-block;padding:2px 6px;background:var(--accent);color:var(--bg);font-size:8px;letter-spacing:.1em}.hint .close{cursor:pointer;opacity:.5;padding:0 4px}.hint .close:hover{opacity:1}@keyframes hint-pop{0%{transform:translateX(-50%) translateY(8px);opacity:0}}.spark{display:inline-block;vertical-align:middle}.app-settings{padding:18px 22px;font-family:var(--font-mono);font-size:12px;color:var(--ink-dim)}.settings-section{margin-bottom:22px}.settings-h{font-family:var(--font-pixel);font-size:10px;letter-spacing:.2em;color:var(--accent);text-transform:uppercase;padding-bottom:8px;border-bottom:1px dashed var(--border);margin-bottom:12px;display:flex;justify-content:space-between;align-items:baseline}.settings-h .meta{color:var(--ink-faint);font-family:var(--font-mono);font-size:10px;letter-spacing:0;text-transform:none}.settings-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:10px;padding:6px 0}.settings-label{font-family:var(--font-pixel-soft);font-size:14px;color:var(--ink)}.settings-seg{display:inline-flex;border:1px solid var(--border-bright);background:var(--bg-2)}.settings-seg button{background:transparent;border:0;border-right:1px solid var(--border);padding:6px 12px;font-family:var(--font-pixel);font-size:9px;letter-spacing:.12em;color:var(--ink-dim);cursor:pointer}.settings-seg button:last-child{border-right:0}.settings-seg button:hover{color:var(--ink);background:rgba(255,255,255,.05)}[data-theme=light] .settings-seg button:hover{background:rgba(0,0,0,.04)}.settings-seg button.on{background:var(--accent);color:var(--bg)}.settings-swatches{display:flex;gap:10px;padding:6px 0}.settings-swatches .swatch{position:relative;width:56px;height:56px;border:2px solid var(--border-bright);cursor:pointer;padding:0;box-shadow:inset 1px 1px 0 rgba(255,255,255,.25),inset -1px -1px 0 rgba(0,0,0,.3);transition:transform .12s}.settings-swatches .swatch:hover{transform:translateY(-2px)}.settings-swatches .swatch.on{border-color:var(--ink);box-shadow:inset 1px 1px 0 rgba(255,255,255,.4),inset -1px -1px 0 rgba(0,0,0,.35),0 0 0 3px var(--bg),0 0 0 5px var(--ink)}.settings-swatches .check{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-pixel);font-size:22px;color:rgba(255,255,255,.95);text-shadow:1px 1px 0 rgba(0,0,0,.5);font-weight:900}.settings-help{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-faint);margin-top:10px;letter-spacing:.02em}.settings-buttons{display:flex;gap:8px;flex-wrap:wrap}.settings-buttons button{flex:1;min-width:120px;padding:10px 14px;background:var(--panel-2);border:1px solid var(--border-bright);font-family:var(--font-pixel);font-size:9px;letter-spacing:.15em;color:var(--ink);cursor:pointer}.settings-buttons button:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}@media (max-width:640px){.app-settings{padding:14px 16px;font-size:11px}.settings-row{grid-template-columns:1fr;gap:6px}.settings-buttons button{min-width:0}}.menubar .gear{cursor:pointer;padding:2px 8px;font-size:14px;color:var(--ink-dim);display:inline-flex;align-items:center;transition:transform .4s}.menubar .gear:hover{color:var(--accent);transform:rotate(60deg)}[data-theme=light] .menubar .gear{color:rgba(26,22,20,.7)}[data-theme=light] .menubar .gear:hover{color:var(--accent)}@media (max-width:1023px){.menubar{font-size:8px;padding:0 8px;gap:10px}.menubar .item{display:none}.menubar .item:nth-child(2),.menubar .item:nth-child(3){display:inline}.ticker{max-width:40%}.ticker .tick:nth-child(n+4){display:none}.menubar .clock{font-size:10px}.desk-icons{right:8px;top:6px;grid-template-columns:64px;gap:10px}.desk-icon .ic{width:28px;height:28px}.desk-icon .lbl{font-size:7px}.start-menu{width:280px}.hero-name{font-size:48px}.app-detail h2{font-size:32px}}@media (max-width:640px){.os-root[data-scanlines=on]:before{background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.008) 0 1px,transparent 1px 3px)}.menubar{height:30px;font-size:8px;gap:0;padding:0 10px;justify-content:space-between}.menubar .item,.menubar .ticker{display:none!important}.menubar .clock,.menubar .logo{font-size:10px}.desk-icons{display:none}.os-root[data-device=mobile] .win{left:0!important;top:0!important;width:100%!important;height:100%!important;border:0;box-shadow:none;z-index:10;transform:none!important}.os-root[data-device=mobile] .win.focused{box-shadow:none}.os-root[data-device=mobile] .win:not(.focused){display:none}.os-root[data-device=mobile] .win .tb{height:38px;padding:0 12px;font-size:9px;cursor:default;background:var(--bg-2)}.os-root[data-device=mobile] .win .tb .dot{width:18px;height:18px}.os-root[data-device=mobile] .win .tb .dot.max,.os-root[data-device=mobile] .win .tb .dot.min,.os-root[data-device=mobile] .win .tb .meta{display:none}.taskbar{height:58px;padding:0 6px;gap:4px;background:var(--bg-2);border-top:2px solid var(--accent)}.start{width:50px;padding:0;height:44px;justify-content:center;font-size:0;flex-shrink:0}.start:before{width:16px;height:16px}.tb-apps{gap:4px}.tb-app{padding:4px 0;width:48px;height:44px;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:0;overflow:hidden;background:var(--panel-2)}.tb-app.on{border-color:var(--accent)}.tb-app .led{width:4px;height:4px}.tb-app .lbl{font-size:6px!important;letter-spacing:.05em;line-height:1;max-width:44px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tb-tray{flex-direction:column;gap:2px;font-size:7px;padding:0 4px}.tb-tray>span:not(.theme-toggle){display:none}.tb-tray .theme-toggle{width:44px;height:44px;padding:0;display:flex;align-items:center;justify-content:center;font-size:9px}.start-menu{left:0;right:0;bottom:60px;width:100%;border-left:0;border-right:0;border-radius:0;max-height:70vh;overflow-y:auto}.hint{display:none}.app-hero{padding:20px 18px;text-align:left}.hero-name{font-size:38px;line-height:1}.hero-tag{font-size:14px}.hero-meta{font-size:10px;gap:12px}.hero-cta{flex-direction:column;align-items:stretch}.hero-cta button{padding:12px 14px;font-size:9px}.mascot{right:12px;bottom:12px;width:60px;height:76px}.app-projects{grid-template-columns:1fr;grid-template-rows:auto 1fr}.pj-side{border-right:0;border-bottom:1px solid var(--border);display:flex;overflow-x:auto;overflow-y:hidden;flex-wrap:nowrap;padding:6px;gap:4px;height:auto;align-items:center}.pj-side .h{display:none}.pj-side .it{padding:6px 10px;white-space:nowrap;border:1px solid var(--border);flex-shrink:0;background:var(--panel-2);font-size:10px}.pj-side .it:before{display:none}.pj-grid{grid-template-columns:1fr;gap:8px;padding:10px}.pj-row{grid-template-columns:36px 1fr;gap:10px}.pj-icon{width:36px;height:36px}.pj-row .pj-tag{grid-column:1/-1;justify-self:end;margin-top:-22px}.app-detail{padding:16px 18px;font-size:12px}.app-detail h2{font-size:28px}.app-detail .preview{height:160px}.app-timeline{padding:14px 16px}.tl-row{grid-template-columns:70px 12px 1fr;gap:6px}.tl-when{font-size:9.5px}.tl-content .role{font-size:12px}.tl-content .li{font-size:10.5px}.app-stocks .head{padding:10px 12px;flex-direction:column;align-items:flex-start;gap:4px}.app-stocks .head .sym{font-size:18px}.app-stocks .head .px{font-size:22px}.app-stocks .symbol-tabs .tab{padding:5px 8px;font-size:7px}.app-stocks .foot{padding:6px 10px 10px;gap:4px}.app-stocks .foot .v{font-size:11px}.app-skills{padding:14px 16px}.chip{font-size:11px;padding:3px 7px}.skill-bar{grid-template-columns:80px 1fr 34px;gap:8px;font-size:11px}.app-terminal .log{padding:12px 14px 4px;font-size:12px}.app-terminal .input-row{padding:8px 14px 14px;font-size:16px}.app-terminal .input-row input{font-size:16px;touch-action:manipulation}.app-terminal,.app-terminal .input-row input{-moz-user-select:text;user-select:text;-webkit-user-select:text}.app-about{padding:14px 16px;font-size:12px}.ascii-logo{font-size:8px}.kv{grid-template-columns:80px 1fr;gap:1px 12px;font-size:11px}}@media (max-width:380px){.hero-name{font-size:30px}.app-detail h2{font-size:22px}.tb-app{width:44px}.tb-app .lbl{font-size:5.5px!important;max-width:40px}}.app-mail{display:grid;grid-template-columns:180px 320px 1fr;height:100%;font-family:var(--font-mono);font-size:12px;color:var(--ink);background:var(--bg);position:relative}.mail-side{border-right:1px solid var(--border);padding:10px 8px;background:rgba(0,0,0,.18);overflow-y:auto}[data-theme=light] .mail-side{background:rgba(0,0,0,.04)}.mail-compose{display:flex;align-items:center;gap:8px;width:100%;padding:9px 10px;background:var(--accent);color:var(--bg);border:0;font-family:var(--font-pixel);font-size:9px;letter-spacing:.15em;cursor:pointer;margin-bottom:12px}.mail-compose:hover{filter:brightness(1.1)}.mail-compose .px{font-family:var(--font-mono);font-size:12px}.mail-side-h{font-family:var(--font-pixel);font-size:8px;letter-spacing:.2em;color:var(--ink-faint);padding:8px 8px 6px;text-transform:uppercase}.mail-side-it{display:flex;align-items:center;gap:8px;padding:6px 8px;cursor:pointer;color:var(--ink-dim);font-size:11px}.mail-side-it .g{width:14px;color:var(--ink-faint);text-align:center;font-size:11px}.mail-side-it .l{flex:1}.mail-side-it .c{font-family:var(--font-pixel);font-size:8px;background:var(--panel-2);color:var(--ink);padding:2px 5px;border:1px solid var(--border)}.mail-side-it:hover{background:var(--accent-soft);color:var(--ink)}.mail-side-it.on{background:var(--accent-soft);color:var(--accent);border-left:2px solid var(--accent);padding-left:6px}.mail-side-it.on .c{background:var(--accent);color:var(--bg);border-color:var(--accent)}.mail-side-it .dot{width:8px;height:8px;display:inline-block}.mail-list{border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.mail-search{display:flex;align-items:center;padding:6px 10px;border-bottom:1px solid var(--border);gap:6px;background:var(--bg-2)}.mail-burger{display:none;background:var(--panel-2);border:1px solid var(--border-bright);color:var(--ink);width:28px;height:26px;font-size:14px;cursor:pointer}.mail-burger:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.mail-nav-backdrop{display:none}.mail-reader-back{display:none;background:var(--panel-2);border:1px solid var(--border-bright);color:var(--ink);font-family:var(--font-pixel);font-size:8px;letter-spacing:.15em;padding:6px 10px;margin-right:8px;cursor:pointer}.mail-reader-back:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.mail-search .ic{color:var(--ink-faint);font-size:13px}.mail-search input{flex:1;background:transparent;border:0;outline:0;color:var(--ink);font-family:var(--font-mono);font-size:12px}.mail-search .x{cursor:pointer;color:var(--ink-faint);padding:0 4px}.mail-search .x:hover{color:var(--accent)}.mail-list-h{display:flex;justify-content:space-between;padding:8px 12px;font-family:var(--font-pixel);font-size:8px;letter-spacing:.18em;color:var(--ink-faint);border-bottom:1px solid var(--border)}.mail-list-h .c{color:var(--accent)}.mail-list-body{flex:1;overflow-y:auto}.mail-row{display:grid;grid-template-columns:36px 1fr;gap:10px;padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--border)}.mail-row.on,.mail-row:hover{background:var(--accent-soft)}.mail-row.on{border-left:3px solid var(--accent);padding-left:9px}.mail-row.unread{background:rgba(255,255,255,.02)}[data-theme=light] .mail-row.unread{background:rgba(0,0,0,.025)}.mail-row.unread .from,.mail-row.unread .subj{font-weight:700;color:var(--ink)}.mail-row-avatar{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-family:var(--font-pixel);font-size:13px;color:#fff;text-transform:uppercase;letter-spacing:0}.mail-row-main{min-width:0;overflow:hidden}.mail-row-top{display:flex;justify-content:space-between;font-size:11px}.mail-row-top .from{color:var(--ink);font-weight:500}.mail-row-top .date{color:var(--ink-faint);font-family:var(--font-mono);font-size:10px}.mail-row-subj{font-size:11.5px;color:var(--ink);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mail-row-subj .star{color:var(--accent)}.mail-row-snip{font-size:10.5px;color:var(--ink-dim);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mail-tag{display:inline-block;margin-top:6px;padding:2px 6px;font-family:var(--font-pixel);font-size:7px;letter-spacing:.12em;text-transform:uppercase;border:1px solid}.mail-tag.tag-work{color:var(--accent)}.mail-tag.tag-personal{color:var(--blue)}.mail-tag.tag-finance{color:var(--green)}.mail-tag.tag-newsletters{color:var(--purple)}.mail-empty,.mail-reader-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--ink-faint)}.mail-empty .g,.mail-reader-empty .g{font-size:36px;color:var(--ink-faint);margin-bottom:8px}.mail-empty .t,.mail-reader-empty .t{font-family:var(--font-pixel);font-size:11px;letter-spacing:.15em;color:var(--ink-dim);text-transform:uppercase;margin-bottom:4px}.mail-empty .d,.mail-reader-empty .d{font-size:11px;color:var(--ink-faint)}.mail-reader{display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.mail-reader-h{display:flex;align-items:center;padding:6px 12px;border-bottom:1px solid var(--border);background:var(--bg-2)}.mail-reader-actions{display:flex;gap:4px}.mail-reader-actions button{background:transparent;border:1px solid var(--border);width:28px;height:26px;color:var(--ink-dim);cursor:pointer;font-size:13px}.mail-reader-actions button:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.mail-reader-body{flex:1;overflow-y:auto;padding:16px 22px 20px}.mail-reader-subj{font-family:var(--font-serif);font-size:24px;line-height:1.2;color:var(--ink);margin-bottom:14px}.mail-reader-meta{display:flex;align-items:center;gap:12px;padding-bottom:14px;border-bottom:1px solid var(--border)}.mail-reader-avatar{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-family:var(--font-pixel);font-size:13px;color:#fff;text-transform:uppercase;flex-shrink:0}.mail-reader-from{font-size:12px;color:var(--ink)}.mail-reader-from .em{color:var(--ink-faint);font-style:italic}.mail-reader-to{font-size:10.5px;color:var(--ink-faint);margin-top:1px}.mail-reader-text{font-family:var(--font-mono);font-size:12.5px;line-height:1.6;color:var(--ink-dim);margin:18px 0;white-space:pre-wrap;word-break:break-word}.mail-reader-text b,.mail-reader-text strong{color:var(--ink)}.mail-reply-box{margin-top:18px;border:1px solid var(--border);background:var(--panel)}.mail-reply-h{padding:6px 10px;font-family:var(--font-pixel);font-size:8px;letter-spacing:.2em;color:var(--accent);border-bottom:1px solid var(--border)}.mail-reply-box textarea{width:100%;border:0;background:transparent;outline:0;color:var(--ink);font-family:var(--font-mono);font-size:12px;padding:10px 12px;resize:vertical;min-height:70px;box-sizing:border-box}.mail-reply-foot{display:flex;gap:6px;padding:8px 10px;border-top:1px solid var(--border)}.mail-reply-foot button,.mc-foot button{background:var(--panel-2);border:1px solid var(--border-bright);font-family:var(--font-pixel);font-size:8px;letter-spacing:.15em;color:var(--ink);padding:6px 12px;cursor:pointer}.mail-reply-foot button.primary,.mail-reply-foot button:hover,.mc-foot button.primary,.mc-foot button:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.mail-reply-foot button.primary:hover,.mc-foot button.primary:hover{filter:brightness(1.1)}.mail-compose-modal{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:50}.mail-compose-win{width:90%;max-width:560px;background:var(--panel);border:1px solid var(--border-bright);box-shadow:var(--shadow-win);display:flex;flex-direction:column}.mc-h{display:flex;justify-content:space-between;padding:8px 12px;font-family:var(--font-pixel);font-size:9px;letter-spacing:.18em;color:var(--accent);background:var(--bg-2);border-bottom:1px solid var(--border)}.mc-h .x{cursor:pointer;color:var(--ink-faint);font-size:14px;line-height:1}.mc-h .x:hover{color:var(--accent)}.mc-row{display:grid;grid-template-columns:70px 1fr;gap:8px;padding:6px 12px;border-bottom:1px solid var(--border);align-items:center}.mc-row .k{font-family:var(--font-pixel);font-size:8px;letter-spacing:.15em;color:var(--ink-faint)}.mail-compose-win textarea,.mc-row input{background:transparent;border:0;outline:0;color:var(--ink);font-family:var(--font-mono);font-size:12px;padding:4px 0;width:100%;box-sizing:border-box}.mail-compose-win textarea{padding:12px;min-height:180px;resize:vertical;border-bottom:1px solid var(--border)}.mc-foot{display:flex;gap:6px;align-items:center;padding:10px 12px}.mc-foot .m{margin-left:auto;font-size:10px;color:var(--ink-faint)}.app-inv,.mc-foot .m{font-family:var(--font-mono)}.app-inv{padding:16px 18px;font-size:12px;color:var(--ink)}.inv-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}.kpi{border:1px solid var(--border);background:var(--panel-2);padding:10px 12px}.kpi .l{font-family:var(--font-pixel);font-size:8px;letter-spacing:.18em;color:var(--ink-faint);margin-bottom:4px}.kpi .v{font-family:var(--font-mono);font-size:18px;color:var(--ink);font-variant-numeric:tabular-nums}.kpi .d{font-size:10px;color:var(--ink-faint);margin-top:3px}.inv-new{width:100%;margin-top:4px;background:var(--accent);color:var(--bg);border:0;padding:10px;font-family:var(--font-pixel);font-size:9px;letter-spacing:.15em;cursor:pointer}.inv-new:hover{filter:brightness(1.1)}.inv-filters{display:flex;gap:4px;margin-bottom:10px}.inv-filter{background:var(--panel-2);border:1px solid var(--border);font-family:var(--font-pixel);font-size:8px;letter-spacing:.15em;color:var(--ink-dim);padding:6px 10px;cursor:pointer}.inv-filter:hover{color:var(--ink)}.inv-filter.on{background:var(--accent);color:var(--bg);border-color:var(--accent)}.inv-table{border:1px solid var(--border);background:var(--panel)}.inv-row,.inv-table-h{display:grid;grid-template-columns:110px 1.4fr 110px 110px 110px 120px;gap:10px;padding:8px 12px;align-items:center}.inv-table-h{background:var(--bg-2);font-family:var(--font-pixel);font-size:8px;letter-spacing:.18em;color:var(--ink-faint);border-bottom:1px solid var(--border)}.inv-row .r,.inv-table-h .r{text-align:right}.inv-row{border-bottom:1px solid var(--border);cursor:pointer;font-size:12px}.inv-row:hover{background:var(--accent-soft)}.inv-row .id{color:var(--accent);font-family:var(--font-mono)}.inv-row .cl{color:var(--ink);font-family:var(--font-pixel-soft);font-size:14px}.inv-row .dt{color:var(--ink-dim);font-size:11px}.inv-row .r{color:var(--ink);font-variant-numeric:tabular-nums;font-weight:600}.inv-row .st{font-family:var(--font-pixel);font-size:8px;letter-spacing:.15em;text-transform:uppercase}.inv-row .st-paid{color:var(--green)}.inv-row .st-overdue{color:var(--red)}.inv-row .st-sent{color:var(--accent)}.inv-empty,.inv-row .st-draft{color:var(--ink-faint)}.inv-empty{padding:30px;text-align:center;font-style:italic}.app-inv-edit{padding:14px 18px 22px;font-family:var(--font-mono);font-size:12px;color:var(--ink)}.inv-edit-h{display:flex;align-items:center;gap:10px;padding-bottom:12px;margin-bottom:14px;border-bottom:1px dashed var(--border);font-size:9px}.inv-edit-h,.inv-edit-h .back,.inv-edit-h button{font-family:var(--font-pixel);letter-spacing:.15em}.inv-edit-h .back,.inv-edit-h button{background:var(--panel-2);border:1px solid var(--border-bright);color:var(--ink);font-size:8px;padding:7px 12px;cursor:pointer}.inv-edit-h .back:hover,.inv-edit-h button:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.inv-edit-h .id{color:var(--ink-dim)}.inv-edit-h .id b{color:var(--accent)}.inv-edit-h .spacer{flex:1}.inv-edit-h button.primary{background:var(--accent);color:var(--bg);border-color:var(--accent)}.st-pill{font-family:var(--font-pixel);font-size:8px;letter-spacing:.15em;padding:4px 8px;border:1px solid}.st-pill.st-paid{color:var(--green)}.st-pill.st-overdue{color:var(--red)}.st-pill.st-sent{color:var(--accent)}.st-pill.st-draft{color:var(--ink-faint)}.inv-edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.inv-edit-field{display:flex;flex-direction:column;gap:4px}.inv-edit-field.span-2{grid-column:1/-1}.inv-edit-field label{font-family:var(--font-pixel);font-size:8px;letter-spacing:.18em;color:var(--ink-faint)}.inv-edit-field input,.inv-edit-field textarea{background:var(--bg-2);border:1px solid var(--border);color:var(--ink);font-family:var(--font-mono);font-size:12px;padding:8px 10px;outline:0;resize:vertical}.inv-edit-field input:focus,.inv-edit-field textarea:focus,.inv-edit-line input:focus,.inv-edit-notes textarea:focus{border-color:var(--accent)}.inv-edit-lines{border:1px solid var(--border);background:var(--panel);margin-bottom:14px}.inv-edit-line,.inv-edit-lines-h{display:grid;grid-template-columns:1fr 56px 72px 96px 110px 32px;gap:8px;padding:8px 10px;align-items:center}.inv-edit-lines-h{background:var(--bg-2);font-family:var(--font-pixel);font-size:8px;letter-spacing:.18em;color:var(--ink-faint)}.inv-edit-line,.inv-edit-lines-h{border-bottom:1px solid var(--border)}.inv-edit-line input{background:transparent;font-size:12px;padding:6px 8px}.inv-edit-line input,.inv-edit-line select{border:1px solid var(--border);color:var(--ink);font-family:var(--font-mono);outline:0}.inv-edit-line select{background:var(--bg-2);font-size:11px;padding:6px 4px;cursor:pointer}.inv-edit-line select:focus{border-color:var(--accent)}.inv-edit-line .lt{text-align:right;font-variant-numeric:tabular-nums;font-weight:600;color:var(--ink);padding-right:6px}.inv-edit-line .rm{background:transparent;border:1px solid var(--border);color:var(--ink-faint);cursor:pointer;width:28px;height:28px;font-size:14px}.inv-edit-line .rm:hover{background:var(--red);color:#fff;border-color:var(--red)}.inv-add-line{width:100%;background:transparent;border:1px dashed var(--border-bright);color:var(--ink-dim);font-family:var(--font-pixel);font-size:9px;letter-spacing:.15em;padding:10px;cursor:pointer}.inv-add-line:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}.inv-edit-totals{margin-left:auto;width:280px;border:1px solid var(--border);background:var(--panel-2);padding:8px 12px;margin-bottom:14px}.inv-edit-totals>div{display:flex;justify-content:space-between;padding:4px 0;font-variant-numeric:tabular-nums;font-size:12px;color:var(--ink-dim)}.inv-edit-totals>div.grand{border-top:1px solid var(--border);margin-top:4px;padding-top:8px;font-family:var(--font-pixel-soft);font-size:16px;color:var(--ink);font-weight:700}.inv-edit-totals>div.grand span:last-child{color:var(--accent)}.inv-edit-notes label{display:block;font-family:var(--font-pixel);font-size:8px;letter-spacing:.18em;color:var(--ink-faint);margin-bottom:4px}.inv-edit-notes textarea{width:100%;background:var(--bg-2);border:1px solid var(--border);color:var(--ink);font-family:var(--font-mono);font-size:12px;padding:8px 10px;outline:0;box-sizing:border-box}.app-inv-print{background:#6a6a6a;min-height:100%}.inv-print-toolbar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg-2);border-bottom:1px solid var(--border)}.inv-print-toolbar button{background:var(--panel-2);border:1px solid var(--border-bright);color:var(--ink);font-family:var(--font-pixel);font-size:8px;letter-spacing:.15em;padding:7px 12px;cursor:pointer}.inv-print-toolbar button.primary,.inv-print-toolbar button:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.inv-print-toolbar .spacer{flex:1}.inv-print-page{background:#fff;color:#111;margin:22px auto;width:720px;max-width:92%;padding:44px 44px 32px;font-family:var(--font-mono);font-size:12px;box-shadow:0 6px 24px rgba(0,0,0,.4);border:1px solid #ddd}.ip-head{display:flex;justify-content:space-between;border-bottom:2px solid #111;padding-bottom:18px;margin-bottom:22px}.ip-brand{font-family:var(--font-pixel);font-size:16px;letter-spacing:.18em;color:#ff5a1f;margin-bottom:6px}.ip-meta{font-family:var(--font-mono);font-size:11px;color:#444;line-height:1.5;white-space:pre-wrap}.ip-title-block{text-align:right}.ip-big{font-family:var(--font-pixel);font-size:24px;letter-spacing:.18em;color:#111}.ip-id{font-family:var(--font-mono);font-size:14px;color:#ff5a1f;margin:4px 0 8px}.ip-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-bottom:22px}.ip-h{font-family:var(--font-pixel);font-size:8px;letter-spacing:.18em;color:#888;margin-bottom:6px}.ip-strong{font-family:var(--font-pixel-soft);font-size:16px;color:#111;margin-bottom:2px}.ip-kv{display:flex;justify-content:space-between;font-size:12px;padding:2px 0}.ip-kv span:first-child{color:#888}.ip-table{width:100%;border-collapse:collapse;margin-bottom:18px}.ip-table th{font-family:var(--font-pixel);font-size:8px;letter-spacing:.18em;text-align:left;color:#fff;background:#111;padding:8px 10px}.ip-table td.r,.ip-table th.r{text-align:right}.ip-table td{padding:8px 10px;border-bottom:1px solid #eee;font-size:12px;font-variant-numeric:tabular-nums;color:#222}.ip-table tr:nth-child(2n) td{background:#fafafa}.ip-totals{margin-left:auto;width:280px;border-top:2px solid #111;padding-top:10px;margin-bottom:24px}.ip-totals>div{display:flex;justify-content:space-between;padding:4px 0;font-variant-numeric:tabular-nums;font-size:12px;color:#444}.ip-totals>div.grand{border-top:1px solid #111;margin-top:4px;padding-top:10px;font-family:var(--font-pixel-soft);font-size:18px;color:#111;font-weight:700}.ip-notes{border:1px solid #ddd;background:#fafafa;padding:12px 14px;margin-bottom:20px;font-size:11px;color:#333}.ip-foot{text-align:center;font-family:var(--font-pixel);font-size:8px;letter-spacing:.15em;color:#aaa;padding-top:14px;border-top:1px dashed #ccc}@media print{body *{visibility:hidden!important}#invoice-print-target,#invoice-print-target *{visibility:visible!important}#invoice-print-target{position:fixed;left:0;top:0;width:100%!important;margin:0!important;padding:30mm 22mm!important;box-shadow:none!important;border:0!important}}.game-rou{padding:12px 14px 14px;font-family:var(--font-mono);font-size:12px;color:var(--ink);background:radial-gradient(ellipse at 50% 30%,rgba(255,90,31,.05) 0,transparent 60%),var(--bg);height:100%;overflow:hidden;display:flex;flex-direction:column}.game-rou .rou-stage{flex:1;min-height:0}.rou-head{display:flex;gap:14px;align-items:center;margin-bottom:8px;padding-bottom:8px;border-bottom:1px dashed var(--border)}.rou-bal,.rou-bet{border:1px solid var(--border);padding:6px 12px;background:var(--panel-2)}.rou-bal .l,.rou-bet .l{font-family:var(--font-pixel);font-size:7px;letter-spacing:.2em;color:var(--ink-faint)}.rou-bal .v{color:var(--green)}.rou-bal .v,.rou-bet .v{font-family:var(--font-mono);font-size:18px;font-variant-numeric:tabular-nums}.rou-bet .v{color:var(--accent)}.rou-win{font-family:var(--font-pixel);font-size:11px;letter-spacing:.15em;color:var(--bg);background:var(--green);padding:8px 14px;margin-left:auto;animation:rou-pulse .6s ease-out}@keyframes rou-pulse{0%{transform:scale(.8);opacity:0}}.rou-lose{font-family:var(--font-pixel);font-size:9px;letter-spacing:.15em;color:var(--ink-faint);margin-left:auto}.rou-stage{display:grid;grid-template-columns:1fr 220px;gap:14px;align-items:center;margin-bottom:12px}.rou-wheel-wrap{display:flex;justify-content:center}.rou-wheel{width:100%;max-width:280px}.rou-history{border:1px solid var(--border);background:var(--panel-2);padding:10px 12px;height:100%}.rou-history .h{font-family:var(--font-pixel);font-size:8px;letter-spacing:.2em;color:var(--ink-faint);margin-bottom:8px}.rou-history .g{display:flex;flex-wrap:wrap;gap:4px}.rou-history .b{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-pixel);font-size:9px;color:#fff}.rou-history .b.red{background:#c43030}.rou-history .b.black{background:#1a1614;border:1px solid #444}.rou-history .b.green{background:#2d8a3a}.rou-history .dim{color:var(--ink-faint)}.rou-board{display:grid;grid-template-columns:repeat(9,1fr);grid-template-rows:auto auto auto;gap:3px;margin-bottom:12px;background:var(--bg-2);border:1px solid var(--border);padding:6px}.rou-area{display:flex}.rou-bet-cell{flex:1;position:relative;background:var(--panel-2);border:1px solid var(--border);color:var(--ink);font-family:var(--font-pixel);font-size:8px;letter-spacing:.12em;padding:10px 6px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;min-height:44px}.rou-bet-cell.on,.rou-bet-cell:hover{background:var(--accent-soft);border-color:var(--accent)}.rou-bet-cell.on{color:var(--accent)}.rou-bet-cell .lbl{font-size:9px}.rou-bet-cell .po{font-size:7px;color:var(--ink-faint)}.rou-area.red .rou-bet-cell{color:#ff5a5a}.rou-area.black .rou-bet-cell{color:var(--ink)}.rou-area.green .rou-bet-cell{color:var(--green)}.rou-numbers{display:grid;grid-template-columns:repeat(12,1fr);gap:2px}.rou-n{position:relative;border:1px solid #0a0a0c;color:#fff;font-family:var(--font-pixel);font-size:9px;padding:8px 0;cursor:pointer;min-height:34px}.rou-n.red{background:#c43030}.rou-n.black{background:#1a1614}.rou-n.green{background:#2d8a3a}.rou-n.on,.rou-n:hover{outline:2px solid var(--accent);z-index:2}.rou-n:disabled{opacity:.6;cursor:not-allowed}.chip-sm{position:absolute;bottom:2px;right:2px;background:var(--accent);color:var(--bg);font-family:var(--font-pixel);font-size:7px;padding:1px 4px;border:1px solid #000}.rou-controls{justify-content:space-between;gap:10px;padding-top:8px;border-top:1px dashed var(--border)}.rou-chips,.rou-controls{display:flex;align-items:center}.rou-chips{gap:6px;flex-wrap:wrap}.rou-chips .l{font-size:8px;letter-spacing:.18em;color:var(--ink-faint);margin-right:4px}.rou-chip,.rou-chips .l{font-family:var(--font-pixel)}.rou-chip{background:var(--panel-2);border:2px solid var(--border-bright);color:var(--ink);font-size:9px;width:40px;height:40px;border-radius:50%;cursor:pointer}.rou-chip:hover{transform:translateY(-2px)}.rou-chip.val-1{background:#e8e6e0;color:#1a1614}.rou-chip.val-5{background:#c43030;color:#fff}.rou-chip.val-10{background:#6db6ff;color:#1a1614}.rou-chip.val-25{background:#2d8a3a;color:#fff}.rou-chip.val-100{background:#1a1614;color:var(--accent);border-color:var(--accent)}.rou-chip.on{outline:3px solid var(--accent);outline-offset:2px}.rou-actions{display:flex;gap:6px}.rou-actions button{background:var(--panel-2);border:1px solid var(--border-bright);color:var(--ink);font-family:var(--font-pixel);font-size:9px;letter-spacing:.15em;padding:10px 16px;cursor:pointer}.rou-actions button:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.rou-actions button:disabled{opacity:.4;cursor:not-allowed}.rou-actions button.primary{background:var(--accent);color:var(--bg);border-color:var(--accent);font-size:10px;padding:10px 22px}.game-spin{display:grid;grid-template-columns:1.4fr 1fr;gap:0;min-height:100%;font-family:var(--font-mono);font-size:12px;color:var(--ink)}.spin-left{padding:20px;flex-direction:column;align-items:center;gap:16px;background:radial-gradient(circle at 50% 40%,rgba(255,90,31,.06) 0,transparent 60%),var(--bg);border-right:1px solid var(--border)}.spin-left,.spin-wheel-wrap{display:flex;justify-content:center}.spin-wheel,.spin-wheel-wrap{max-width:360px;width:100%}.spin-actions{display:flex;gap:8px}.spin-actions button{background:var(--accent);color:var(--bg);border:0;font-family:var(--font-pixel);font-size:11px;letter-spacing:.15em;padding:14px 26px;cursor:pointer}.spin-actions button:hover{filter:brightness(1.1)}.spin-actions button:disabled{opacity:.4;cursor:not-allowed}.spin-result{text-align:center;border:1px solid var(--accent);background:var(--accent-soft);padding:10px 18px;animation:rou-pulse .6s ease-out}.spin-result .l{font-family:var(--font-pixel);font-size:8px;letter-spacing:.2em;color:var(--accent)}.spin-result .v{font-family:var(--font-pixel-soft);font-size:22px;color:var(--ink);margin-top:2px}.spin-right{padding:18px;background:rgba(0,0,0,.15);overflow-y:auto}[data-theme=light] .spin-right{background:rgba(0,0,0,.04)}.spin-h{font-family:var(--font-pixel);font-size:9px;letter-spacing:.2em;color:var(--accent);margin-bottom:8px;text-transform:uppercase}.spin-h .c{color:var(--ink-faint);margin-left:6px}.spin-input{display:flex;gap:4px;margin-bottom:12px}.spin-input input{flex:1;background:var(--bg-2);border:1px solid var(--border);color:var(--ink);font-family:var(--font-mono);font-size:12px;padding:8px 10px;outline:0}.spin-input input:focus{border-color:var(--accent)}.spin-input button{background:var(--accent);color:var(--bg);border:0;font-family:var(--font-pixel);font-size:8px;letter-spacing:.15em;padding:8px 12px;cursor:pointer}.spin-input button:disabled{opacity:.3}.spin-opts{display:flex;flex-direction:column;gap:3px;margin-bottom:8px}.spin-opt{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--panel-2);border:1px solid var(--border);font-size:12px}.spin-opt .sw{width:14px;height:14px;display:inline-block;flex-shrink:0}.spin-opt .t{flex:1;color:var(--ink)}.spin-opt .x{background:transparent;border:0;color:var(--ink-faint);cursor:pointer;font-size:16px;line-height:1;width:22px;height:22px}.spin-opt .x:hover{color:var(--red)}.spin-opt .x:disabled{opacity:.3;cursor:not-allowed}.spin-empty{padding:14px;text-align:center;color:var(--ink-faint);font-style:italic}.spin-hist{display:flex;flex-wrap:wrap;gap:4px}.spin-hist .hi{font-family:var(--font-pixel-soft);font-size:12px;padding:3px 8px;background:rgba(255,90,31,.08);border:1px solid var(--accent);color:var(--accent)}.spin-hist .dim{color:var(--ink-faint);font-style:italic}.spin-presets{display:flex;gap:4px;flex-wrap:wrap}.spin-presets button{background:var(--panel-2);border:1px solid var(--border);color:var(--ink-dim);font-family:var(--font-pixel);font-size:8px;letter-spacing:.12em;padding:6px 10px;cursor:pointer}.spin-presets button:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.app-wx{padding:16px 18px 18px;font-family:var(--font-mono);font-size:12px;color:var(--ink)}.wx-tabs{display:flex;gap:2px;margin-bottom:14px;border-bottom:1px solid var(--border)}.wx-tab{background:var(--panel-2);border:1px solid var(--border);border-bottom:0;color:var(--ink-dim);font-family:var(--font-pixel);font-size:8px;letter-spacing:.15em;padding:7px 10px;cursor:pointer}.wx-tab:hover{color:var(--ink)}.wx-tab.on{background:var(--accent);color:var(--bg);border-color:var(--accent)}.wx-hero{display:grid;grid-template-columns:1fr auto;align-items:center;background:var(--panel-2);border:1px solid var(--border);padding:18px 20px;margin-bottom:14px}.wx-loc{font-family:var(--font-pixel);font-size:9px;letter-spacing:.18em;color:var(--accent);margin-bottom:4px}.wx-temp{font-family:var(--font-serif);font-size:72px;line-height:.9;color:var(--ink);letter-spacing:-.04em;margin-bottom:6px}.wx-cond{font-family:var(--font-pixel-soft);font-size:18px;color:var(--ink)}.wx-feels{font-family:var(--font-mono);font-size:11px;color:var(--ink-dim);margin-top:2px}.wx-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:14px}.wx-stats .s{border:1px solid var(--border);background:var(--panel-2);padding:8px 10px}.wx-stats .l{font-family:var(--font-pixel);font-size:7px;letter-spacing:.18em;color:var(--ink-faint)}.wx-stats .v{font-family:var(--font-mono);font-size:13px;color:var(--ink);margin-top:2px}.wx-stats .v .dim{color:var(--ink-faint);font-size:10px}.wx-section-h{font-family:var(--font-pixel);font-size:9px;letter-spacing:.2em;color:var(--accent);margin:14px 0 8px;text-transform:uppercase}.wx-hourly{display:grid;grid-template-columns:repeat(10,1fr);gap:4px;background:var(--bg-2);border:1px solid var(--border);padding:10px 8px;margin-bottom:6px}.wx-h{display:flex;flex-direction:column;align-items:center;gap:4px;padding:4px 0}.wx-h .t{font-family:var(--font-pixel);font-size:8px;color:var(--ink-faint);letter-spacing:.1em}.wx-h .v{font-family:var(--font-mono);font-size:13px;color:var(--ink);font-variant-numeric:tabular-nums}.wx-daily{background:var(--bg-2);border:1px solid var(--border);padding:4px 12px}.wx-d{display:grid;grid-template-columns:60px 32px 36px 1fr 36px;align-items:center;gap:10px;padding:6px 0;border-bottom:1px dashed var(--border)}.wx-d:last-child{border-bottom:0}.wx-d .day{font-family:var(--font-pixel);font-size:9px;letter-spacing:.15em;color:var(--ink)}.wx-d .lo{color:var(--blue)}.wx-d .hi,.wx-d .lo{font-family:var(--font-mono);font-size:11px;text-align:right;font-variant-numeric:tabular-nums}.wx-d .hi{color:var(--accent)}.wx-d .bar{position:relative;height:6px;background:rgba(255,255,255,.05);border:1px solid var(--border)}[data-theme=light] .wx-d .bar{background:rgba(0,0,0,.06)}.wx-d .bar .fill{position:absolute;top:0;bottom:0;background:linear-gradient(90deg,var(--blue),var(--accent))}.wx-foot{margin-top:14px;font-family:var(--font-pixel);font-size:8px;letter-spacing:.15em;color:var(--ink-faint);text-align:center}.app-lib{display:grid;grid-template-columns:200px 1fr;height:100%;font-family:var(--font-mono);font-size:12px;color:var(--ink);background:var(--bg)}.lib-side{border-right:1px solid var(--border);background:rgba(0,0,0,.18);padding:12px 8px;overflow-y:auto;display:flex;flex-direction:column}[data-theme=light] .lib-side{background:rgba(0,0,0,.04)}.lib-side-h{font-family:var(--font-pixel);font-size:8px;letter-spacing:.2em;color:var(--ink-faint);padding:6px 8px;text-transform:uppercase}.lib-side-it{display:flex;align-items:center;gap:8px;padding:6px 8px;cursor:pointer;color:var(--ink-dim);font-size:11px}.lib-side-it:hover{background:var(--accent-soft);color:var(--ink)}.lib-side-it.on{background:var(--accent-soft);color:var(--accent);border-left:2px solid var(--accent);padding-left:6px}.lib-side-it .g{width:14px;text-align:center;color:var(--ink-faint)}.lib-side-it.on .g{color:var(--accent)}.lib-side-it .l{flex:1}.lib-side-it .c{font-family:var(--font-pixel);font-size:8px;background:var(--panel-2);color:var(--ink);padding:2px 5px;border:1px solid var(--border)}.lib-side-it.on .c{background:var(--accent);color:var(--bg);border-color:var(--accent)}.lib-side-foot{margin-top:auto;padding:12px 10px;font-family:var(--font-mono);font-size:10px;line-height:1.6;color:var(--ink-faint);border-top:1px dashed var(--border)}.lib-side-foot .g{font-family:var(--font-pixel);font-size:10px;letter-spacing:.18em;color:var(--accent);margin-bottom:4px}.lib-main{display:flex;flex-direction:column;overflow:hidden}.lib-toolbar{display:flex;align-items:center;padding:8px 14px;background:var(--bg-2);border-bottom:1px solid var(--border);gap:14px}.lib-title{display:flex;flex-direction:column}.lib-title .t{font-family:var(--font-pixel);font-size:10px;letter-spacing:.18em;color:var(--accent)}.lib-title .d{font-family:var(--font-mono);font-size:10px;color:var(--ink-faint);margin-top:1px}.lib-search{display:flex;align-items:center;gap:6px;background:var(--panel);border:1px solid var(--border);padding:5px 10px;margin-left:auto;flex:0 1 320px}.lib-search .ic{color:var(--ink-faint);font-size:13px}.lib-search input{flex:1;background:transparent;border:0;outline:0;color:var(--ink);font-family:var(--font-mono);font-size:12px}.lib-search .x{cursor:pointer;color:var(--ink-faint);padding:0 4px}.lib-search .x:hover{color:var(--accent)}.lib-shelf{flex:1;overflow-y:auto;padding:18px 16px 22px;display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:18px;align-content:start;background:repeating-linear-gradient(0deg,transparent,transparent 219px,rgba(0,0,0,.25) 0,rgba(0,0,0,.25) 226px);background-attachment:local}[data-theme=light] .lib-shelf{background:repeating-linear-gradient(0deg,transparent,transparent 219px,rgba(0,0,0,.08) 0,rgba(0,0,0,.08) 226px)}.lib-empty{grid-column:1/-1;text-align:center;padding:60px 20px;color:var(--ink-faint)}.lib-empty .g{font-size:36px;margin-bottom:8px}.lib-empty .t{font-family:var(--font-pixel);font-size:11px;letter-spacing:.18em;color:var(--ink-dim);margin-bottom:4px}.lib-empty .d{font-size:11px;color:var(--ink-faint)}.lib-book{display:flex;flex-direction:column;cursor:pointer;transition:transform .12s ease}.lib-book:hover{transform:translateY(-3px)}.lib-book:hover .lib-cover{box-shadow:0 6px 12px rgba(0,0,0,.45),4px 0 0 rgba(0,0,0,.4)}.lib-cover{width:100%;aspect-ratio:100/140;box-shadow:0 3px 6px rgba(0,0,0,.4),3px 0 0 rgba(0,0,0,.35);margin-bottom:8px;transition:box-shadow .15s ease}.lib-book-meta{display:flex;flex-direction:column;gap:2px}.lib-book-meta .t{font-family:var(--font-pixel-soft);font-size:13px;color:var(--ink);line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.lib-book-meta .a{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-dim)}.lib-book-meta .row{display:flex;gap:6px;align-items:center;margin-top:3px}.lib-book-meta .st{letter-spacing:.15em}.lib-book-meta .pdf,.lib-book-meta .st{font-family:var(--font-pixel);font-size:7px}.lib-book-meta .pdf{letter-spacing:.1em;color:var(--bg);background:var(--accent);padding:2px 5px}.lib-book-meta .rt{font-size:10px;color:var(--accent);letter-spacing:1px;margin-top:1px}.lib-book-meta .rt .dim{color:var(--ink-faint)}.app-lib-read{display:flex;flex-direction:column;height:100%;background:var(--bg);font-family:var(--font-mono);font-size:12px;color:var(--ink)}.lr-h{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--bg-2);border-bottom:1px solid var(--border)}.lr-h .back,.lr-h .lr-btn{background:var(--panel-2);border:1px solid var(--border-bright);color:var(--ink);font-family:var(--font-pixel);font-size:8px;letter-spacing:.15em;padding:7px 12px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center}.lr-h .back:hover,.lr-h .lr-btn:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.lr-h .hl{display:flex;align-items:baseline;gap:8px;margin-left:4px;min-width:0}.lr-h .hl .t{font-family:var(--font-pixel-soft);font-size:14px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:360px}.lr-h .hl .a{font-family:var(--font-mono);font-size:11px;color:var(--ink-faint);white-space:nowrap}.lr-h .spacer{flex:1}.lr-body{flex:1;display:grid;grid-template-columns:240px 1fr;min-height:0}.lr-side{border-right:1px solid var(--border);background:rgba(0,0,0,.18);padding:14px;overflow-y:auto}[data-theme=light] .lr-side{background:rgba(0,0,0,.04)}.lr-cover-wrap{width:100%;margin-bottom:12px;display:flex;justify-content:center}.lr-cover-wrap .lib-cover{width:100%;max-width:180px;box-shadow:0 5px 10px rgba(0,0,0,.45),4px 0 0 rgba(0,0,0,.4)}.lr-status{text-align:center;font-family:var(--font-pixel);font-size:9px;letter-spacing:.18em;margin-bottom:12px;padding-bottom:10px;border-bottom:1px dashed var(--border)}.lr-kv{display:flex;justify-content:space-between;padding:4px 0;font-size:11px}.lr-kv span:first-child{font-family:var(--font-pixel);font-size:8px;letter-spacing:.18em;color:var(--ink-faint)}.lr-kv span:last-child{color:var(--ink)}.lr-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:10px;padding-top:8px;border-top:1px dashed var(--border)}.lr-tags .tg{font-family:var(--font-mono);font-size:10px;color:var(--ink-dim);background:var(--panel-2);border:1px solid var(--border);padding:2px 6px}.lr-notes{margin-top:14px;padding-top:12px;border-top:1px dashed var(--border)}.lr-notes .h{font-family:var(--font-pixel);font-size:8px;letter-spacing:.2em;color:var(--accent);margin-bottom:6px}.lr-notes pre{font-family:var(--font-mono);font-size:11px;line-height:1.6;color:var(--ink-dim);white-space:pre-wrap;word-break:break-word;margin:0}.lr-reader{display:flex;background:#6a6a6a;min-width:0;min-height:0}.lr-pdf{flex:1;width:100%;height:100%;border:0;background:#6a6a6a}.lr-no-pdf{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--ink-faint);text-align:center;background:var(--bg-2);padding:40px}.lr-no-pdf .g{font-size:48px;margin-bottom:12px;color:var(--ink-faint)}.lr-no-pdf .t{font-family:var(--font-pixel);font-size:11px;letter-spacing:.2em;color:var(--ink-dim);margin-bottom:8px}.lr-no-pdf .d{font-size:12px;line-height:1.6}.user-card.auth-card{display:grid;grid-template-columns:40px 1fr auto;gap:10px;align-items:center}.user-card.auth-card .auth-meta{min-width:0}.user-card.auth-card .auth-meta .who{font-family:var(--font-pixel-soft);font-size:14px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-card.auth-card .auth-meta .status{font-family:var(--font-mono);font-size:10px;color:var(--green);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-card.auth-card .auth-meta .status.status-dim{color:var(--ink-faint)}.auth-avatar{font-family:var(--font-pixel);font-weight:700;color:#fff;letter-spacing:.04em;border:1px solid rgba(0,0,0,.4);text-shadow:1px 1px 0 rgba(0,0,0,.3)}.auth-avatar,.auth-avatar-empty{display:flex;align-items:center;justify-content:center}.auth-avatar-empty{width:40px;height:40px;background:var(--panel-2);border:1px solid var(--border);color:var(--ink-faint)}.auth-cta{display:flex;flex-direction:column;gap:3px}.auth-mini{background:var(--panel-2);border:1px solid var(--border-bright);color:var(--ink);font-family:var(--font-pixel);font-size:7px;letter-spacing:.15em;padding:4px 8px;cursor:pointer;white-space:nowrap}.auth-mini.primary,.auth-mini:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.auth-mini.primary:hover{filter:brightness(1.1)}.auth-modal{position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.55);-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);display:flex;align-items:center;justify-content:center;padding:14px}.auth-modal-win{width:100%;max-width:420px;background:var(--panel);border:1px solid var(--border-bright);box-shadow:var(--shadow-win),0 14px 40px rgba(0,0,0,.5);font-family:var(--font-mono);color:var(--ink);max-height:calc(100vh - 28px);overflow-y:auto}.auth-h{display:flex;align-items:center;justify-content:space-between;background:var(--bg-2);border-bottom:1px solid var(--border);padding:9px 14px}.auth-h .t{font-family:var(--font-pixel);font-size:10px;letter-spacing:.18em;color:var(--accent)}.auth-h .x{cursor:pointer;color:var(--ink-faint);font-size:18px;line-height:1;padding:0 4px}.auth-h .x:hover{color:var(--accent)}.auth-body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:14px}.auth-subtitle{font-size:12px;color:var(--ink-dim);line-height:1.5;text-align:center;margin-top:-2px}.auth-social{display:flex;flex-direction:column;gap:6px}.auth-social-btn{display:flex;align-items:center;gap:10px;justify-content:center;background:var(--panel-2);border:1px solid var(--border-bright);color:var(--ink);font-family:var(--font-mono);font-size:12px;padding:10px 14px;cursor:pointer;width:100%}.auth-social-btn:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--ink)}.auth-social-btn:disabled{opacity:.5;cursor:not-allowed}.auth-social-btn svg{flex-shrink:0}.auth-or{display:flex;align-items:center;gap:8px;color:var(--ink-faint);font-family:var(--font-pixel);font-size:8px;letter-spacing:.2em;text-transform:uppercase}.auth-or:after,.auth-or:before{content:"";flex:1;height:1px;background:var(--border)}.auth-form{gap:10px}.auth-field,.auth-form{display:flex;flex-direction:column}.auth-field{gap:3px}.auth-field span{font-family:var(--font-pixel);font-size:8px;letter-spacing:.18em;color:var(--ink-faint)}.auth-field input{background:var(--bg-2);border:1px solid var(--border);color:var(--ink);font-family:var(--font-mono);font-size:12px;padding:9px 11px;outline:0}.auth-field input:focus{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}.auth-err{font-family:var(--font-mono);font-size:11px;color:var(--red);background:rgba(255,77,77,.08);border:1px solid var(--red);padding:6px 10px}.auth-submit{background:var(--accent);color:var(--bg);border:0;font-family:var(--font-pixel);font-size:10px;letter-spacing:.18em;padding:12px 14px;cursor:pointer;margin-top:4px}.auth-submit:hover{filter:brightness(1.1)}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-toggle{text-align:center;font-family:var(--font-mono);font-size:11px;color:var(--ink-dim);padding-top:8px;border-top:1px dashed var(--border)}.auth-toggle .lk{color:var(--accent);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.auth-toggle .lk:hover{color:var(--accent-2)}.auth-foot{font-family:var(--font-mono);font-size:10px;color:var(--ink-faint);line-height:1.5;text-align:center}.auth-foot .lk{color:var(--accent);cursor:pointer}.rou-landed{display:inline-flex;align-items:center;gap:10px;margin-bottom:8px;padding:6px 12px 6px 6px;background:var(--panel-2);border:1px solid var(--border-bright);font-family:var(--font-pixel)}.rou-landed .l{font-size:8px;letter-spacing:.2em;color:var(--ink-faint);margin-left:6px}.rou-landed .n{display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:30px;padding:0 6px;font-family:var(--font-pixel);font-size:14px;color:#fff;border:1px solid #000}.rou-landed .n.red{background:#c43030}.rou-landed .n.black{background:#1a1614}.rou-landed .n.green{background:#2d8a3a}.rou-landed .c{font-size:9px;letter-spacing:.15em}.rou-landed.landed-red .c{color:#ff5a5a}.rou-landed.landed-black .c{color:var(--ink)}.rou-landed.landed-green .c{color:var(--green)}.pj-launch{display:inline-block;margin-left:8px;font-family:var(--font-pixel);font-size:7px;letter-spacing:.15em;background:var(--accent);color:var(--bg);padding:2px 6px;vertical-align:middle}.pj-row:hover .pj-launch{filter:brightness(1.15)}.pj-open-app{display:block;margin:18px 0 4px;background:var(--accent);color:var(--bg);border:0;font-family:var(--font-pixel);font-size:11px;letter-spacing:.18em;padding:14px 22px;cursor:pointer;width:100%;text-align:left;box-shadow:4px 4px 0 rgba(0,0,0,.35);transition:transform .08s,box-shadow .08s,filter .08s}.pj-open-app:hover{filter:brightness(1.1)}.pj-open-app:active{transform:translate(2px,2px);box-shadow:2px 2px 0 rgba(0,0,0,.35)}@media (max-width:1023px){.app-mail{grid-template-columns:60px 280px 1fr}.mail-side{padding:8px 4px}.mail-compose{font-size:0;padding:12px}.mail-compose .px{font-size:16px}.mail-side-h,.mail-side-it .c,.mail-side-it .l{display:none}.mail-side-it{justify-content:center;padding:10px 6px}.mail-side-it .g{font-size:14px}.inv-kpis{grid-template-columns:repeat(2,1fr)}.inv-row,.inv-table-h{grid-template-columns:90px 1fr 90px 100px}.inv-row .dt:first-of-type,.inv-table-h span:nth-child(3){display:none}.inv-row .st,.inv-table-h span:nth-child(5){font-size:7px}.game-spin{grid-template-columns:1fr}.spin-left{border-right:0;border-bottom:1px solid var(--border)}.rou-stage{grid-template-columns:1fr}.rou-history{max-height:120px;overflow-y:auto}.wx-stats{grid-template-columns:repeat(3,1fr)}.wx-hourly{grid-template-columns:repeat(5,1fr)}.wx-hourly .wx-h:nth-child(n+6){display:none}}@media (max-width:640px){.game-rou{overflow-y:auto}.game-rou .rou-stage{flex:none}.rou-wheel{max-width:230px}.app-mail{grid-template-columns:1fr;grid-template-rows:1fr}.app-mail .mail-list{border-right:0}.app-mail .mail-burger{display:inline-flex;align-items:center;justify-content:center}.app-mail .mail-side{display:block;position:absolute;inset:0 auto 0 0;width:240px;transform:translateX(-100%);transition:transform .18s ease;z-index:7;background:var(--panel);box-shadow:4px 0 12px rgba(0,0,0,.4)}.app-mail.nav-open .mail-side{transform:translateX(0)}.app-mail .mail-side .mail-side-h,.app-mail .mail-side .mail-side-it .c,.app-mail .mail-side .mail-side-it .l{display:inline}.app-mail .mail-side .mail-side-h{display:block}.app-mail .mail-side .mail-side-it{justify-content:flex-start;padding:8px 10px}.app-mail .mail-side .mail-compose{font-size:9px;padding:9px 10px}.app-mail .mail-side .mail-compose .px{font-size:12px}.app-mail.nav-open .mail-nav-backdrop{display:block;position:absolute;inset:0;background:rgba(0,0,0,.5);z-index:6}.app-mail .mail-reader{position:absolute;inset:0;z-index:5;background:var(--bg);display:none}.app-mail.has-reader .mail-reader{display:flex;flex-direction:column}.app-mail .mail-reader-back{display:inline-flex;align-items:center}.app-mail .mail-reader-empty{display:none}.app-lib{grid-template-columns:1fr}.app-lib .lib-side{display:none}.lib-shelf{padding:14px 10px;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:14px}.lr-body{grid-template-columns:1fr;grid-template-rows:auto 1fr}.lr-side{border-right:0;border-bottom:1px solid var(--border);max-height:220px;display:grid;grid-template-columns:100px 1fr;gap:12px;align-items:start}.lr-cover-wrap{margin-bottom:0}.lr-cover-wrap .lib-cover{max-width:100px}.lr-side>:not(.lr-cover-wrap){grid-column:2}.lr-notes{display:none}.inv-kpis{grid-template-columns:repeat(2,1fr)}.inv-edit-grid{grid-template-columns:1fr}.inv-edit-line,.inv-edit-lines-h{grid-template-columns:1fr 60px 32px;font-size:10px}.inv-edit-line .lt,.inv-edit-line input:nth-child(4),.inv-edit-line select,.inv-edit-lines-h span:nth-child(3),.inv-edit-lines-h span:nth-child(4),.inv-edit-lines-h span:nth-child(5){display:none}.inv-print-page{padding:22px 18px}.rou-numbers{grid-template-columns:repeat(6,1fr)}.rou-board{gap:2px;padding:4px}.rou-bet-cell{padding:8px 2px;font-size:7px}.rou-bet-cell .lbl{font-size:7px}.rou-chips{gap:4px}.rou-chip{width:34px;height:34px;font-size:8px}.wx-temp{font-size:56px}.wx-stats{grid-template-columns:repeat(2,1fr)}.wx-hourly{grid-template-columns:repeat(5,1fr)}.wx-d{grid-template-columns:50px 26px 30px 1fr 30px;gap:6px}}