:root{--bg:#f6f7fb;--bg-elev:#fff;--bg-soft:#f1f3f9;--text:#0f172a;--text-muted:#64748b;--border:#e5e7eb;--border-soft:#eef0f4;--accent:#6366f1;--accent-strong:#4f46e5;--accent-soft:#eef2ff;--success:#10b981;--warn:#f59e0b;--danger:#ef4444;--pink:#ec4899;--shadow-sm:0 1px 2px #0f172a0a;--shadow:0 6px 18px #0f172a0f;--shadow-lg:0 24px 48px -16px #0f172a2e;--radius:14px;--radius-lg:22px;--transition:.2s cubic-bezier(.4,.2,.2,1)}[data-theme=dark]{--bg:#0b1020;--bg-elev:#131a2c;--bg-soft:#1a2238;--text:#e6e8ee;--text-muted:#8b95ad;--border:#232c43;--border-soft:#1d263c;--accent:#818cf8;--accent-strong:#6366f1;--accent-soft:#1e1f3a;--shadow-sm:0 1px 2px #0000004d;--shadow:0 10px 30px #00000059;--shadow-lg:0 30px 60px -16px #00000080}*{box-sizing:border-box}html,body{height:100%;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.55}#app{grid-template-columns:260px 1fr;min-height:100vh;display:grid}.sidebar{background:var(--bg-elev);border-right:1px solid var(--border);flex-direction:column;gap:18px;height:100vh;padding:22px 18px;display:flex;position:sticky;top:0}.brand{border-bottom:1px solid var(--border-soft);align-items:center;gap:12px;padding:4px 6px 18px;display:flex}.brand-logo{background:linear-gradient(135deg, var(--accent), var(--pink));width:42px;height:42px;box-shadow:var(--shadow);border-radius:12px;place-items:center;font-size:22px;display:grid}.brand-title{font-size:15px;font-weight:700}.brand-sub{color:var(--text-muted);font-size:12px}.nav{flex-direction:column;gap:4px;display:flex}.nav-item{color:var(--text-muted);cursor:pointer;text-align:left;width:100%;transition:background var(--transition), color var(--transition);background:0 0;border:0;border-radius:10px;align-items:center;gap:12px;padding:10px 12px;font-family:inherit;font-size:14px;font-weight:500;display:flex}.nav-item span{font-size:16px}.nav-item:hover{background:var(--bg-soft);color:var(--text)}.nav-item.active{background:var(--accent-soft);color:var(--accent-strong);font-weight:600}.streak-box{border:1px solid var(--border-soft);background:linear-gradient(135deg,#6366f11a,#ec489914);border-radius:14px;margin-top:auto;padding:16px}.streak-label{color:var(--text-muted);font-size:12px}.streak-value{font-size:28px;font-weight:700}.streak-sub{color:var(--text-muted);margin-top:4px;font-size:12px}.theme-toggle button{background:var(--bg-soft);border:1px solid var(--border-soft);cursor:pointer;width:100%;color:var(--text);border-radius:10px;padding:10px;font-size:16px}.main{width:100%;max-width:1280px;margin:0 auto;padding:32px 40px 60px}.view{animation:.22s fadeIn;display:none}.view.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.page-head{justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:28px;display:flex}.page-head h1{letter-spacing:-.01em;margin:0;font-size:28px;font-weight:700}.muted{color:var(--text-muted);margin:4px 0 0;font-size:14px}.head-actions{align-items:center;gap:10px;display:flex}.btn{cursor:pointer;transition:transform var(--transition), background var(--transition), box-shadow var(--transition);border:1px solid #0000;border-radius:10px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:600}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg, var(--accent), var(--accent-strong));color:#fff;box-shadow:0 6px 16px -4px #6366f173}.btn-primary:hover{box-shadow:0 10px 22px -6px #6366f18c}.btn-secondary{background:var(--bg-soft);color:var(--text);border-color:var(--border)}.btn-secondary:hover{background:var(--border-soft)}.btn-danger{background:var(--danger);color:#fff}.btn-ghost{color:var(--text-muted);cursor:pointer;background:0 0;border:0;border-radius:8px;padding:6px 8px;font-size:16px}.btn-ghost:hover{background:var(--bg-soft)}.select,.input{background:var(--bg-elev);color:var(--text);border:1px solid var(--border);transition:border var(--transition);border-radius:10px;outline:none;padding:9px 12px;font-family:inherit;font-size:14px}.select:focus,.input:focus{border-color:var(--accent)}.input.small{max-width:120px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:transform var(--transition), box-shadow var(--transition);padding:18px}.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.stat-icon{margin-bottom:6px;font-size:20px}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:12px}.stat-value{letter-spacing:-.02em;margin:4px 0;font-size:30px;font-weight:700}.stat-sub{color:var(--text-muted);font-size:12px}.grid-2{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}@media (width<=980px){.grid-2{grid-template-columns:1fr}}.panel{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:16px;padding:22px}.panel.danger{border-color:#ef444440}.panel-head{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.panel-head h2{margin:0;font-size:16px;font-weight:700}.deck-list{flex-direction:column;gap:10px;display:flex}.deck-card{background:var(--bg-soft);cursor:pointer;transition:border var(--transition), background var(--transition);border:1px solid #0000;border-radius:12px;align-items:center;gap:14px;padding:14px;display:flex}.deck-card:hover{border-color:var(--accent)}.deck-icon{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:12px;place-items:center;width:44px;height:44px;font-size:22px;display:grid}.deck-meta{flex:1;min-width:0}.deck-sub{color:var(--text-muted);margin-top:2px;font-size:12px}.deck-progress{background:var(--border-soft);border-radius:99px;width:100%;height:6px;margin-top:8px;overflow:hidden}.deck-progress-fill{background:linear-gradient(90deg, var(--accent), var(--pink));height:100%;transition:width var(--transition)}.deck-action{background:var(--bg-elev);border:1px solid var(--border);color:var(--text-muted);border-radius:8px;padding:6px 10px;font-size:12px;font-weight:600}.deck-action.has-due{background:var(--accent);color:#fff;border-color:#0000}.deck-tabs{flex-wrap:wrap;gap:8px;margin-bottom:18px;display:flex}.deck-tab{background:var(--bg-elev);border:1px solid var(--border);cursor:pointer;color:var(--text);font:inherit;transition:background var(--transition), border-color var(--transition), color var(--transition), transform var(--transition);border-radius:999px;align-items:center;gap:8px;padding:9px 14px;font-size:13px;font-weight:600;line-height:1;display:inline-flex}.deck-tab:hover{border-color:var(--accent);transform:translateY(-1px)}.deck-tab.active{background:var(--accent);color:#fff;border-color:#0000}.deck-tab-icon{font-size:15px;line-height:1}.deck-tab-name{white-space:nowrap}.deck-tab-count{background:var(--bg-soft);min-width:22px;color:var(--text-muted);border-radius:999px;justify-content:center;align-items:center;padding:2px 7px;font-size:11px;font-weight:700;display:inline-flex}.deck-tab.active .deck-tab-count{color:#fff;background:#ffffff38}.analytics-overview{flex-direction:column;gap:18px;display:flex}.overview-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.overview-card{background:var(--bg-soft);border:1px solid var(--border-soft);transition:border-color var(--transition), transform var(--transition);border-radius:14px;flex-direction:column;gap:12px;padding:16px;display:flex}.overview-card:hover{border-color:var(--accent)}.overview-head{align-items:center;gap:12px;display:flex}.overview-icon{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:10px;place-items:center;width:40px;height:40px;font-size:20px;display:grid}.overview-title{flex:1;min-width:0}.overview-name{font-size:14px;font-weight:700;line-height:1.2}.overview-sub{margin-top:2px;font-size:12px}.overview-progress{flex-direction:column;gap:4px;display:flex}.overview-progress-bar{background:var(--border-soft);border-radius:99px;height:6px;overflow:hidden}.overview-progress-fill{background:linear-gradient(90deg, var(--accent), var(--pink));height:100%;transition:width var(--transition)}.overview-progress-label{font-size:11px}.overview-metrics{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.overview-metric{background:var(--bg-elev);border:1px solid var(--border-soft);text-align:center;border-radius:8px;padding:8px 10px}.overview-metric-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:10.5px}.overview-metric-value{color:var(--text);margin-top:2px;font-size:15px;font-weight:700}.overview-maturity{background:var(--border-soft);border-radius:99px;height:8px;display:flex;overflow:hidden}.overview-mat-seg{height:100%;display:block}.overview-cta{align-self:flex-start}@media (width<=560px){.overview-metrics{grid-template-columns:repeat(2,1fr)}}.schedule-panel{margin-top:18px}.schedule-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:14px;display:flex}.schedule-head h2{margin:0 0 4px;font-size:16px;font-weight:700}.schedule-head .muted{margin:0;font-size:12px}.schedule-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;display:grid}.schedule-card{background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:14px;flex-direction:column;gap:10px;padding:14px;display:flex}.schedule-card-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.schedule-card-head h3{margin:0;font-size:14px;font-weight:700}.schedule-status{background:var(--bg-elev);border:1px solid var(--border-soft);color:var(--text-muted);border-radius:99px;padding:3px 8px;font-size:11px;font-weight:600}.schedule-status.good{color:var(--success);background:#10b98114;border-color:#10b98159}.schedule-status.bad{color:var(--danger);background:#ef444414;border-color:#ef444459}.schedule-chart{width:100%;height:auto;display:block}.schedule-chart .schedule-axis{stroke:var(--border);stroke-width:1px}.schedule-chart .schedule-ideal{fill:none;stroke:var(--text-muted);stroke-width:1.25px;stroke-dasharray:4 4;opacity:.7}.schedule-chart .schedule-actual{fill:none;stroke:var(--accent);stroke-width:2px;stroke-linejoin:round;stroke-linecap:round}.schedule-chart .schedule-area{fill:var(--accent);opacity:.12}.schedule-chart .schedule-today{stroke:var(--pink);stroke-width:1px;stroke-dasharray:2 3;opacity:.8}.schedule-meta{color:var(--text-muted);flex-wrap:wrap;justify-content:space-between;gap:8px;font-size:11px;display:flex}.heatmap{grid-template-columns:repeat(13,1fr);gap:4px;margin-bottom:12px;display:grid}.hm-cell{aspect-ratio:1;background:var(--border-soft);border-radius:4px;width:100%;display:inline-block}.hm-cell[data-l="1"]{background:#6366f140}.hm-cell[data-l="2"]{background:#6366f180}.hm-cell[data-l="3"]{background:#6366f1bf}.hm-cell[data-l="4"]{background:var(--accent-strong)}.heatmap-legend{align-items:center;gap:6px;font-size:12px;display:flex}.heatmap-legend .hm-cell{aspect-ratio:auto;width:12px;height:12px}.review-progress{margin-bottom:18px}.rp-fill{background:linear-gradient(90deg, var(--accent), var(--pink));width:0;height:100%;transition:width .4s}.rp-labels{color:var(--text-muted);align-items:center;gap:16px;margin-top:8px;font-size:13px;display:flex}.dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.card-stage{place-items:start center;min-height:560px;margin-bottom:22px;display:grid}.empty{text-align:center;color:var(--text-muted)}.empty-icon{margin-bottom:12px;font-size:64px}.empty h2{color:var(--text)}.flashcard{perspective:1500px;width:100%;max-width:960px}.hidden{display:none!important}.card-meta{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.chip{background:var(--bg-soft);color:var(--text-muted);border:1px solid var(--border-soft);border-radius:99px;padding:4px 10px;font-size:12px;font-weight:500}.chip-state{background:var(--accent-soft);color:var(--accent-strong)}.chip-id{font-family:JetBrains Mono,monospace}.card-inner{min-height:480px;transform-style:preserve-3d;grid-template-rows:auto;grid-template-columns:1fr;transition:transform .6s cubic-bezier(.34,1.4,.64,1);display:grid;position:relative}.card-inner>.card-face{grid-area:1/1/2/2}.card-inner.flipped{transform:rotateY(180deg)}.card-face{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);backface-visibility:hidden;flex-direction:column;padding:36px 44px;display:flex}.card-face.card-back{background:linear-gradient(135deg, var(--bg-elev) 0%, var(--accent-soft) 100%);transform:rotateY(180deg)}.face-label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:14px;font-size:11px;font-weight:700}.face-content{white-space:pre-wrap;flex:1;font-size:19px;line-height:1.65;overflow:visible}.face-content code{background:var(--bg-soft);border-radius:4px;padding:2px 6px;font-family:JetBrains Mono,monospace;font-size:.9em}.face-content strong{color:var(--accent-strong);font-weight:700}.card-fig-hint{background:var(--accent-soft);color:var(--accent-strong);border-radius:99px;align-items:center;gap:6px;margin-top:14px;padding:6px 12px;font-size:12px;font-weight:600;display:inline-flex}.card-figure{text-align:center;margin:16px 0 0}.card-figure img{border:1px solid var(--border-soft);cursor:zoom-in;max-width:100%;max-height:60vh;transition:transform var(--transition);background:#fff;border-radius:12px;box-shadow:0 6px 18px -10px #0f172a59}.card-figure img:hover{transform:scale(1.01)}.card-source{text-align:center;margin-top:12px;font-size:13px}.card-source a{background:var(--bg-soft);color:var(--accent-strong);border:1px solid var(--border-soft);transition:background var(--transition), border var(--transition);border-radius:99px;align-items:center;gap:6px;padding:8px 14px;font-weight:600;text-decoration:none;display:inline-flex}.card-source a:hover{background:var(--accent-soft);border-color:var(--accent)}.lightbox{z-index:1000;cursor:zoom-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#080a19d9;justify-content:center;align-items:center;padding:24px;display:none;position:fixed;inset:0}.lightbox.show{animation:.2s fadeIn;display:flex}.lightbox img{border-radius:12px;max-width:95vw;max-height:95vh;box-shadow:0 30px 80px #0009}.btn-flip{background:var(--accent);color:#fff;cursor:pointer;border:0;border-radius:12px;align-self:center;align-items:center;gap:8px;margin-top:18px;padding:12px 22px;font-family:inherit;font-size:14px;font-weight:600;display:inline-flex;box-shadow:0 8px 18px -6px #6366f180}.btn-flip kbd{background:#ffffff2e;border-radius:4px;padding:2px 6px;font-family:JetBrains Mono,monospace;font-size:11px}.rating{grid-template-columns:repeat(4,1fr);gap:10px;max-width:960px;margin:0 auto;display:grid}.rate-btn{border:1px solid var(--border);background:var(--bg-elev);cursor:pointer;text-align:left;transition:transform var(--transition), border var(--transition), box-shadow var(--transition);color:var(--text);border-radius:12px;align-items:center;gap:12px;padding:14px 16px;font-family:inherit;display:flex}.rate-btn:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.rate-btn .rk{background:var(--bg-soft);width:26px;height:26px;color:var(--text-muted);border-radius:8px;place-items:center;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700;display:grid}.rate-btn .rl{font-size:14px;font-weight:700}.rate-btn .ri{color:var(--text-muted);margin-top:2px;font-size:12px}.rate-again{border-color:#ef44444d}.rate-again:hover{border-color:var(--danger)}.rate-hard{border-color:#f59e0b4d}.rate-hard:hover{border-color:var(--warn)}.rate-good{border-color:#10b9814d}.rate-good:hover{border-color:var(--success)}.rate-easy{border-color:#6366f14d}.rate-easy:hover{border-color:var(--accent)}.browse-list{gap:10px;display:grid}.browse-row{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:12px;grid-template-columns:60px 1fr auto;align-items:center;gap:14px;padding:14px 18px;display:grid}.browse-id{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:13px}.browse-q{font-weight:600}.browse-a{color:var(--text-muted);margin-top:4px;font-size:13px}.browse-meta{color:var(--text-muted);text-align:right;min-width:110px;font-size:11px}.chap-list{flex-direction:column;gap:10px;max-height:360px;display:flex;overflow-y:auto}.chap-row{background:var(--bg-soft);border-radius:10px;grid-template-columns:1fr 60px 60px;align-items:center;gap:12px;padding:10px 12px;display:grid}.chap-name{font-size:13px;font-weight:500}.chap-bar{background:var(--border-soft);border-radius:99px;height:6px;margin-top:6px;overflow:hidden}.chap-bar-fill{background:var(--success);height:100%}.chap-pct{text-align:right;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:600}.chap-cnt{text-align:right;color:var(--text-muted);font-size:12px}.legend{color:var(--text-muted);flex-wrap:wrap;gap:14px;margin-top:12px;font-size:12px;display:flex}.legend i{vertical-align:middle;border-radius:3px;width:10px;height:10px;margin-right:4px;display:inline-block}.hardest-list{flex-direction:column;gap:10px;display:flex}.hardest-row{background:var(--bg-soft);border-radius:10px;grid-template-columns:1fr auto auto;align-items:center;gap:14px;padding:12px 16px;display:grid}.hardest-q{font-size:14px;font-weight:500}.hardest-meta{color:var(--text-muted);font-size:12px}.exam-grid{gap:12px;display:grid}.exam-row{background:var(--bg-soft);border-radius:10px;grid-template-columns:200px 1fr 140px 200px;align-items:center;gap:12px;padding:14px;display:grid}.exam-name{font-weight:600}.exam-sub{color:var(--text-muted);font-size:12px}.exam-target{text-align:right;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:600}.setting-row{border-bottom:1px solid var(--border-soft);justify-content:space-between;align-items:center;gap:16px;padding:14px 0;display:flex}.setting-row:last-child{border-bottom:0}.set-title{font-size:14px;font-weight:600}.set-sub{font-size:12px}input[type=checkbox]{appearance:none;background:var(--border);cursor:pointer;width:36px;height:20px;transition:background var(--transition);border-radius:99px;position:relative}input[type=checkbox]:checked{background:var(--accent)}input[type=checkbox]:before{content:"";width:16px;height:16px;transition:transform var(--transition);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px}input[type=checkbox]:checked:before{transform:translate(16px)}input[type=date],input[type=number],input[type=file]{background:var(--bg-elev);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-family:inherit}.toast{background:var(--text);color:var(--bg-elev);box-shadow:var(--shadow-lg);opacity:0;z-index:100;pointer-events:none;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:500;transition:all .28s cubic-bezier(.34,1.4,.64,1);position:fixed;bottom:24px;left:50%;transform:translate(-50%)translateY(100px)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.chat-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;pointer-events:none;z-index:75;background:#080a1973;transition:opacity .2s;position:fixed;inset:0}.chat-backdrop.open{opacity:1;pointer-events:auto}.chat-panel{background:var(--bg-elev);border-left:1px solid var(--border-soft);z-index:260;flex-direction:column;width:440px;max-width:92vw;height:100vh;transition:transform .32s cubic-bezier(.4,.2,.2,1);display:flex;position:fixed;top:0;right:0;transform:translate(100%);box-shadow:-10px 0 30px -15px #0f172a40}.chat-panel.open{transform:translate(0)}body.chat-open .main{padding-right:472px}@media (width<=1100px){body.chat-open .main{padding-right:32px}}.chat-head{border-bottom:1px solid var(--border-soft);justify-content:space-between;align-items:center;gap:12px;padding:18px 20px;display:flex}.chat-head-title{align-items:center;gap:12px;min-width:0;display:flex}.chat-ico{background:linear-gradient(135deg, var(--accent), var(--accent-strong));color:#fff;border-radius:12px;flex-shrink:0;place-items:center;width:38px;height:38px;font-size:18px;display:grid}.chat-h{font-size:15px;font-weight:700}.chat-sub{color:var(--text-muted,#64748b);font-size:12px}.chat-close{cursor:pointer;width:32px;height:32px;color:var(--text-muted,#64748b);background:0 0;border:none;border-radius:8px;font-size:16px}.chat-close:hover{background:var(--accent-soft);color:var(--accent-strong)}.chat-keyhint{color:#92400e;background:#fef3c7;border:1px solid #fde68a;border-radius:10px;margin:12px 16px 0;padding:10px 14px;font-size:13px;line-height:1.5}.chat-keyhint code{background:#00000014;border-radius:4px;padding:1px 6px;font-size:12px}.chat-controls{border-bottom:1px solid var(--border-soft);flex-wrap:wrap;align-items:center;gap:10px;padding:12px 18px;font-size:12px;display:flex}.chat-check{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;display:inline-flex}.chat-check input{accent-color:var(--accent)}.chat-controls .select.small{height:30px;padding:4px 8px;font-size:12px}.chat-controls .btn-ghost.small{padding:4px 8px;font-size:14px;line-height:1}.chat-body{background:var(--bg,#f8fafc);flex-direction:column;flex:1;gap:12px;padding:18px;display:flex;overflow-y:auto}.chat-empty{text-align:center;color:var(--text-muted,#64748b);padding:24px 12px}.chat-empty-ico{font-size:42px}.chat-empty h3{color:var(--text);margin:6px 0 8px}.chat-empty p{font-size:13px;line-height:1.55}.chat-suggests{flex-wrap:wrap;justify-content:center;gap:6px;margin-top:16px;display:flex}.chat-suggest{background:var(--bg-elev);border:1px solid var(--border-soft);color:var(--text);cursor:pointer;border-radius:999px;padding:6px 12px;font-size:12px;transition:all .15s}.chat-suggest:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-strong)}.chat-msg{display:flex}.chat-user{justify-content:flex-end}.chat-bot{justify-content:flex-start}.chat-bubble{word-wrap:break-word;white-space:normal;border-radius:14px;max-width:85%;padding:10px 14px;font-size:14px;line-height:1.55}.chat-user .chat-bubble{background:linear-gradient(135deg, var(--accent), var(--accent-strong));color:#fff;border-bottom-right-radius:4px}.chat-bot .chat-bubble{background:var(--bg-elev);color:var(--text);border:1px solid var(--border-soft);border-bottom-left-radius:4px}.chat-bubble p{margin:0 0 8px}.chat-bubble p:last-child{margin:0}.chat-bubble ul{margin:6px 0 8px;padding-left:18px}.chat-bubble li{margin:2px 0}.chat-bubble code{background:#6366f11f;border-radius:4px;padding:1px 5px;font-family:JetBrains Mono,monospace;font-size:12.5px}.chat-bubble pre{color:#f1f5f9;background:#0f172a;border-radius:8px;margin:8px 0;padding:10px 12px;overflow-x:auto}.chat-bubble pre code{color:inherit;background:0 0;padding:0}.chat-bubble h3,.chat-bubble h4{margin:8px 0 4px}.chat-typing{align-items:center;gap:4px;padding:4px 0;display:inline-flex}.chat-typing span{background:var(--text-muted,#94a3b8);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite chatBlink}@keyframes chatBlink{0%,80%,to{opacity:.25;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.chat-input-row{border-top:1px solid var(--border-soft);background:var(--bg-elev);gap:8px;padding:12px 14px;display:flex}.chat-input-row textarea{resize:none;border:1px solid var(--border-soft);background:var(--bg,#fff);color:var(--text);border-radius:10px;outline:none;flex:1;padding:10px 12px;font-family:inherit;font-size:14px;line-height:1.5;transition:border-color .15s}.chat-input-row textarea:focus{border-color:var(--accent)}.chat-input-row .btn{height:auto;padding:0 18px}#chatToggle{background:linear-gradient(135deg, var(--accent), var(--accent-strong));color:#fff;border:none}#chatToggle.active{box-shadow:0 0 0 3px var(--accent-soft)}.chat-fab{background:linear-gradient(135deg, var(--accent), var(--accent-strong));color:#fff;cursor:pointer;z-index:70;border:none;border-radius:999px;align-items:center;gap:10px;padding:14px 20px;font-size:15px;font-weight:600;transition:transform .15s,box-shadow .15s;display:inline-flex;position:fixed;bottom:24px;right:24px;box-shadow:0 12px 30px -6px #6366f18c,0 4px 8px -2px #0f172a40}.chat-fab:hover{transform:translateY(-2px);box-shadow:0 16px 36px -6px #6366f1a6,0 6px 12px -2px #0f172a4d}.chat-fab.active{background:var(--bg-elev);color:var(--accent-strong);border:1px solid var(--border-soft)}.chat-fab-ico{font-size:22px;line-height:1}@media (width<=600px){.chat-fab-label{display:none}.chat-fab{padding:14px}}body.auth-locked{overflow:hidden}body.auth-locked #app{filter:blur(6px)saturate(.8);pointer-events:none;-webkit-user-select:none;user-select:none}.auth-overlay{z-index:9999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172a8c;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.auth-overlay.show{display:flex}.auth-card{background:var(--bg-elev);border:1px solid var(--border);width:min(420px,100vw - 32px);color:var(--text);border-radius:18px;padding:28px;box-shadow:0 30px 80px #00000059}.auth-brand{align-items:center;gap:12px;margin-bottom:18px;display:flex}.auth-brand-logo{background:linear-gradient(135deg, var(--accent), var(--accent-strong));border-radius:12px;place-items:center;width:44px;height:44px;font-size:24px;display:grid}.auth-brand-title{font-size:18px;font-weight:700}.auth-brand-sub{color:var(--text-muted);font-size:12px}.auth-tabs{gap:8px;margin-bottom:18px;display:flex}.auth-tab{background:var(--bg-soft);color:var(--text-muted);cursor:pointer;border:1px solid #0000;border-radius:10px;flex:1;padding:8px 10px;font-weight:600}.auth-tab.active{background:var(--accent-soft);color:var(--accent-strong);border-color:var(--accent)}.auth-title{margin:0 0 14px;font-size:20px}.auth-label{color:var(--text-muted);margin-bottom:12px;font-size:13px;display:block}.auth-label input{box-sizing:border-box;border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);font:inherit;border-radius:10px;margin-top:6px;padding:10px 12px;font-size:14px;display:block}.auth-label input:focus{outline:2px solid var(--accent);outline-offset:1px}.auth-hint{color:var(--text-muted);margin-top:4px;font-size:11px;display:block}.auth-error{color:#b91c1c;min-height:1.2em;margin:4px 0 12px;font-size:13px}:root[data-theme=dark] .auth-error{color:#fca5a5}.auth-submit{width:100%;padding:12px;font-size:15px}.auth-note{color:var(--text-muted);text-align:center;margin:14px 0 0;font-size:11px}.account-chip{border:1px solid var(--border);background:var(--bg-soft);border-radius:12px;align-items:center;gap:8px;margin:12px 16px 16px;padding:10px 12px;display:flex}.account-info{flex:1;min-width:0}.account-email{white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.account-sync{font-size:10px}.mobile-topbar,.sidebar-backdrop{display:none}@supports (padding:max(0px)){body{padding-bottom:env(safe-area-inset-bottom)}}@media (width<=1024px){.main{padding:24px 24px 60px}.exam-row{grid-template-columns:1fr 100px 160px}}@media (width<=768px){.mobile-topbar{z-index:100;padding:10px 14px;padding-top:max(10px, env(safe-area-inset-top));background:var(--bg-elev);border-bottom:1px solid var(--border-soft);-webkit-backdrop-filter:saturate(160%)blur(8px);backdrop-filter:saturate(160%)blur(8px);align-items:center;gap:10px;display:flex;position:sticky;top:0}.mobile-menu-btn{border:1px solid var(--border);background:var(--bg-elev);cursor:pointer;border-radius:10px;place-items:center;width:42px;height:42px;padding:0;display:grid}.mm-bar{background:var(--text);border-radius:2px;width:18px;height:2px;margin:2px 0;transition:transform .2s,opacity .2s;display:block}body.sidebar-open .mm-bar:first-child{transform:translateY(6px)rotate(45deg)}body.sidebar-open .mm-bar:nth-child(2){opacity:0}body.sidebar-open .mm-bar:nth-child(3){transform:translateY(-6px)rotate(-45deg)}.mobile-brand{flex:1;align-items:center;gap:8px;font-size:15px;font-weight:700;display:flex}.mobile-brand-logo{font-size:20px}.mobile-theme-toggle{border:1px solid var(--border);background:var(--bg-elev);cursor:pointer;border-radius:10px;width:42px;height:42px;padding:0;font-size:18px}#app{grid-template-columns:1fr}.sidebar{z-index:200;width:280px;max-width:86vw;height:100dvh;padding:20px 16px;padding-top:max(20px, env(safe-area-inset-top));padding-bottom:max(20px, env(safe-area-inset-bottom));transition:transform .25s cubic-bezier(.4,.2,.2,1);position:fixed;top:0;left:0;overflow-y:auto;transform:translate(-100%);box-shadow:8px 0 30px -10px #00000059}body.sidebar-open .sidebar{transform:translate(0)}.nav{flex-direction:column}.nav-item{min-height:44px;padding:12px 14px;font-size:15px}.streak-box{display:block}.theme-toggle{display:none}.sidebar-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;pointer-events:none;z-index:150;background:#080a198c;transition:opacity .2s;display:block;position:fixed;inset:0}body.sidebar-open .sidebar-backdrop{opacity:1;pointer-events:auto}body.sidebar-open{overflow:hidden}.main{max-width:100%;padding:16px 14px 100px}.page-head{flex-direction:column;align-items:stretch;gap:12px;margin-bottom:20px}.page-head h1{font-size:22px}.head-actions{flex-wrap:wrap;width:100%}.head-actions .select,.head-actions .input,.head-actions .btn{flex:auto;min-height:44px}.view-dashboard .stats-grid{grid-template-columns:1fr}.view-dashboard .deck-card{flex-wrap:wrap;align-items:flex-start;gap:10px}.view-dashboard .deck-meta,.view-dashboard .deck-action{width:100%}.view-dashboard .deck-action{text-align:center;padding:8px 10px}.stats-grid{grid-template-columns:1fr 1fr;gap:10px}.stat-card{padding:14px}.stat-value{font-size:24px}.panel{padding:16px}.panel h2{font-size:16px}.heatmap{-webkit-overflow-scrolling:touch;grid-template-columns:none;grid-auto-columns:14px;grid-auto-flow:column;padding-bottom:4px;overflow-x:auto}.hm-cell{aspect-ratio:auto;width:14px;height:14px}.rp-labels{flex-wrap:wrap;gap:8px 12px}.card-stage{min-height:auto;margin-bottom:16px}.card-inner{min-height:360px}.card-face{border-radius:16px;padding:22px 18px}.face-content{font-size:16px;line-height:1.55}.card-figure img{max-height:45vh}.btn-flip{width:100%;max-width:320px;min-height:48px;padding:14px 22px;font-size:15px}.rating{grid-template-columns:1fr 1fr;gap:8px}.rate-btn{min-height:56px;padding:14px 12px}.rate-btn .rl{font-size:14px}.rate-btn .ri{display:none}.browse-row{grid-template-columns:1fr;gap:6px;padding:14px}.browse-meta{text-align:left;min-width:0}.chap-row{grid-template-columns:1fr 50px 50px;gap:8px;padding:10px;font-size:12px}.hardest-row{grid-template-columns:1fr;gap:6px;padding:12px}.exam-row{grid-template-columns:1fr;gap:10px;padding:14px}.exam-target{text-align:left}.setting-row{flex-wrap:wrap;gap:10px;padding:14px 0}.select,.input,input[type=date],input[type=number]{min-height:44px;padding:11px 12px;font-size:16px}.btn{min-height:44px;padding:12px 16px}canvas{max-width:100%;height:auto}.chat-backdrop{z-index:240}.chat-panel{border-left:none;width:100vw;max-width:100vw}.chat-head{padding-top:max(18px, env(safe-area-inset-top))}.chat-close{width:40px;height:40px;font-size:20px}.chat-controls{gap:8px;padding:10px 14px}.chat-controls .chat-check,.chat-controls .select.small,.chat-controls .btn-ghost.small{width:100%}.chat-controls .select.small{height:36px}body.chat-open .main{padding-right:14px}.chat-input-row{padding-bottom:max(12px, env(safe-area-inset-bottom))}.chat-fab{bottom:calc(16px + env(safe-area-inset-bottom));justify-content:center;width:56px;height:56px;padding:14px;right:16px}.chat-fab-label{display:none}.auth-card{border-radius:14px;width:calc(100vw - 24px);max-height:calc(100dvh - 24px);padding:22px 20px;overflow-y:auto}.auth-label input{min-height:44px;font-size:16px}.auth-submit{min-height:48px}.account-chip{margin:12px 0 8px}.toast{bottom:max(16px, env(safe-area-inset-bottom));left:16px;right:16px;transform:translateY(100px)}.toast.show{transform:translateY(0)}}@media (width<=380px){.stats-grid,.rating{grid-template-columns:1fr}.card-face{padding:18px 14px}.face-content{font-size:15px}.page-head h1{font-size:20px}}input,textarea,select{-webkit-user-select:text;user-select:text}*{-webkit-tap-highlight-color:#6366f126}.games-grid{flex-direction:column;gap:16px;display:flex}.game-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;color:var(--text);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);align-items:flex-start;gap:14px;padding:18px;font-family:inherit;display:flex}.game-card:hover{box-shadow:var(--shadow);border-color:var(--accent);transform:translateY(-2px)}.game-card-ico{flex:none;font-size:32px;line-height:1}.game-card-body{flex-direction:column;gap:4px;display:flex}.game-card-title{font-size:15px;font-weight:700}.game-card-sub{color:var(--text-muted);font-size:13px}.game-card-tag{color:var(--accent-strong);margin-top:4px;font-size:12px;font-weight:600}.game-stage{background:0 0}.game-header{align-items:center;gap:14px;margin-bottom:18px;display:flex}.game-header-ico{font-size:36px}.game-header-title{margin:0;font-size:22px;font-weight:700}.game-header-sub{color:var(--text-muted);font-size:13px}.game-body{flex-direction:column;gap:16px;display:flex}.game-controls{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;align-items:flex-end;gap:12px;padding:14px;display:flex}.game-controls label{color:var(--text-muted);flex-direction:column;gap:4px;font-size:12px;display:flex}.game-controls .input,.game-controls select{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:8px;padding:8px 10px;font-family:inherit;font-size:14px}.game-controls input[type=number]{border:1px solid var(--border);background:var(--bg);width:90px;color:var(--text);border-radius:8px;padding:8px 10px}.game-info{flex-wrap:wrap;gap:8px;display:flex}.game-info .chip{background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:99px;align-items:center;gap:6px;padding:6px 10px;font-size:13px;display:inline-flex}.game-actions{flex-wrap:wrap;gap:10px;display:flex}.game-help summary{cursor:pointer;color:var(--accent-strong);padding:6px 0;font-weight:600}.game-help{background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:var(--radius);padding:10px 14px}.game-help ul,.game-help ol{margin:6px 0;padding-left:22px}.pr-table-wrap{overflow-x:auto}.pr-table{border-collapse:collapse;background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;min-width:100%;overflow:hidden}.pr-table th,.pr-table td{border:1px solid var(--border-soft);text-align:center;font-variant-numeric:tabular-nums;padding:8px 10px}.pr-table thead th{background:var(--bg-soft);font-weight:600}.pr-cur,.pr-cur-cell{color:var(--accent-strong);font-weight:700;background:#6366f12e!important}.pr-clickable{cursor:pointer;transition:background var(--transition)}.pr-clickable:hover{background:var(--accent-soft)}.pr-log{flex-direction:column;gap:4px;font-family:JetBrains Mono,monospace;font-size:13px;display:flex}.pr-final{color:var(--success);margin-top:8px;font-weight:700}.mmu-decompose{flex-wrap:wrap;align-items:flex-end;gap:10px;display:flex}.mmu-deco-step{flex-direction:column;gap:4px;display:flex}.mmu-deco-label{color:var(--text-muted);font-size:12px}.mmu-input{text-transform:uppercase;width:90px;font-family:JetBrains Mono,monospace}.mmu-tables{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (width<=720px){.mmu-tables{grid-template-columns:1fr}}.mmu-table{border-collapse:collapse;width:100%;font-family:JetBrains Mono,monospace;font-size:12px}.mmu-table th,.mmu-table td{border:1px solid var(--border-soft);text-align:center;padding:4px 8px}.mmu-table thead{background:var(--bg-soft)}.mmu-hl{background:#f59e0b2e;font-weight:700}.mmu-nil{color:var(--danger);font-weight:700}.mmu-sub{margin-bottom:4px;font-size:13px;font-weight:600}.mmu-result{flex-wrap:wrap;align-items:flex-end;gap:10px;display:flex}.mmu-result label{flex-direction:column;flex:1;gap:4px;min-width:240px;font-size:13px;display:flex}.mmu-feedback:empty{display:none}.mmu-ok{color:var(--success);background:#10b9811f;border:1px solid #10b98166;border-radius:8px;padding:10px 14px}.mmu-bad{color:var(--danger);background:#ef44441a;border:1px solid #ef444459;border-radius:8px;padding:10px 14px}.sem-stage{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=720px){.sem-stage{grid-template-columns:1fr}}.sem-proc{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:12px}.sem-proc-h{color:var(--accent-strong);margin-bottom:8px;font-weight:700}.sem-code{flex-direction:column;gap:6px;font-family:JetBrains Mono,monospace;font-size:13px;display:flex}.sem-line{background:var(--bg-soft);border-radius:6px;padding:8px 10px}.sem-slot{border:2px dashed var(--border);cursor:pointer;transition:background var(--transition);background:0 0}.sem-slot:hover{background:var(--bg-soft)}.sem-filled{border-style:solid;border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong);font-weight:600}.sem-bank{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.sem-chip{cursor:pointer;background:var(--accent);color:#fff;border:0;border-radius:6px;padding:6px 10px;font-family:JetBrains Mono,monospace;font-size:12px}.sem-chip:disabled,.sem-chip-used{opacity:.35;cursor:not-allowed}.sem-explain{color:var(--text-muted);font-size:13px}.sem-graph pre{background:var(--bg-soft);border-radius:8px;padding:10px;font-family:JetBrains Mono,monospace}.raid-result{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.raid-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:14px}.raid-label{color:var(--text-muted);font-size:13px}.raid-val{margin-top:4px;font-size:26px;font-weight:700}.raid-formula{color:var(--text-muted);margin-top:6px;font-family:JetBrains Mono,monospace;font-size:12px}.raid-explain{color:var(--text-muted);font-size:13px}.raid-quiz-row{gap:10px;margin:10px 0;display:flex}.raid-quiz h3{margin:0 0 8px}.buddy-bar{background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:8px;gap:2px;min-height:60px;padding:4px;display:flex}.buddy-split{flex:1;gap:2px;display:flex}.buddy-leaf{border-radius:6px;justify-content:center;align-items:center;min-width:30px;padding:8px;font-size:12px;display:flex}.buddy-leaf.buddy-free{color:var(--success);background:#10b98126;border:1px dashed #10b98180}.buddy-leaf.buddy-alloc{color:var(--accent-strong);border:1px solid var(--accent);background:#6366f12e;font-weight:600}.bk-question{background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;padding:12px}.bk-question .input{margin-top:6px}.gantt-bar{border:1px solid var(--border);border-radius:6px;height:44px;display:flex;overflow:hidden}.gantt-seg{color:#fff;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.gantt-axis{height:18px;margin-top:4px;position:relative}.gantt-axis span{color:var(--text-muted);font-size:11px;position:absolute;transform:translate(-50%)}.ds-svg text{fill:var(--text)}.fit-table .select.small{padding:4px 6px;font-size:12px}@media (width<=720px){.game-controls{gap:8px;padding:10px}}.summary-toc{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--radius);max-height:calc(100vh - 64px);box-shadow:var(--shadow-sm);flex-direction:column;gap:2px;padding:16px 12px;display:flex;position:sticky;top:24px;overflow-y:auto}.summary-toc .toc-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-bottom:1px solid var(--border-soft);margin-bottom:6px;padding:4px 8px 8px;font-size:11px;font-weight:700}.summary-toc a{color:var(--text);white-space:normal;overflow-wrap:anywhere;transition:background var(--transition), color var(--transition), border-color var(--transition);border-left:2px solid #0000;border-radius:7px;padding:5px 10px;font-size:13px;line-height:1.35;text-decoration:none;display:block}.summary-toc a:hover{background:var(--bg-soft);color:var(--accent);border-left-color:var(--accent)}.summary-toc a.toc-l1{color:var(--text);margin-top:4px;padding-left:10px;font-weight:700}.summary-toc a.toc-l2{color:var(--text);margin-top:4px;padding-left:10px;font-weight:600}.summary-toc a.toc-l3{color:var(--text-muted);padding-left:22px;font-size:12.5px}.summary-toc a.toc-l4{color:var(--text-muted);padding-left:34px;font-size:12px}.summary-content{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--radius);box-shadow:var(--shadow-sm);min-height:400px;padding:36px 44px}.summary-empty{text-align:center;padding:80px 20px;font-size:14px}.summary-doc{color:var(--text);max-width:78ch;margin:0 auto;font-size:15px;line-height:1.7}.summary-doc h1{letter-spacing:-.02em;border-bottom:2px solid var(--border-soft);margin:0 0 28px;padding-bottom:14px;font-size:30px;font-weight:800}.summary-doc h2{letter-spacing:-.01em;border-left:4px solid var(--accent);margin:36px 0 14px;padding-left:12px;scroll-margin-top:24px;font-size:22px;font-weight:700}.summary-doc h3{color:var(--text);margin:24px 0 8px;scroll-margin-top:24px;font-size:17px;font-weight:700}.summary-doc h4{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:18px 0 6px;scroll-margin-top:24px;font-size:15px;font-weight:700}.summary-doc p{margin:10px 0}.summary-doc strong{color:var(--text);font-weight:700}.summary-doc em{color:var(--text)}.summary-doc ul,.summary-doc ol{margin:10px 0 14px;padding-left:24px}.summary-doc li{margin:4px 0}.summary-doc li::marker{color:var(--accent)}.summary-doc code{background:var(--bg-soft);border:1px solid var(--border-soft);color:var(--accent-strong);border-radius:6px;padding:1px 6px;font-family:JetBrains Mono,ui-monospace,Consolas,monospace;font-size:.88em}.summary-doc pre{background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:10px;margin:14px 0;padding:14px 16px;overflow-x:auto}.summary-doc pre code{color:var(--text);background:0 0;border:0;padding:0;font-size:13px}.summary-doc blockquote{border-left:4px solid var(--accent);background:var(--accent-soft);color:var(--text);border-radius:0 8px 8px 0;margin:14px 0;padding:10px 16px}.summary-doc hr{border:0;border-top:1px solid var(--border-soft);margin:28px 0}.summary-doc a{color:var(--accent-strong);text-underline-offset:2px;text-decoration:underline}@media (width<=980px){.summary-layout{grid-template-columns:1fr}.summary-toc{max-height:220px;position:static}.summary-content{padding:24px 20px}}@media print{.sidebar,.mobile-topbar,.chat-fab,.chat-panel,.summary-toc,.head-actions,#toast{display:none!important}#app{display:block}.main{max-width:none;padding:0}.view{display:none}.view-summaries.active{display:block}.summary-layout{grid-template-columns:1fr}.summary-content{box-shadow:none;color:#000;background:#fff;border:0;padding:0}.summary-doc{color:#000;max-width:none}.summary-doc h2{border-left-color:#000}}.games-filter{flex-wrap:wrap;gap:8px;margin-bottom:18px;display:flex}.games-filter-chip{border:1px solid var(--border);background:var(--bg-elev);color:var(--text-muted);cursor:pointer;transition:all var(--transition);border-radius:99px;align-items:center;gap:8px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex}.games-filter-chip:hover{border-color:var(--accent);color:var(--text)}.games-filter-chip.active{background:linear-gradient(135deg, var(--accent), var(--accent-strong));color:#fff;border-color:#0000;box-shadow:0 4px 12px -3px #6366f173}.games-filter-count{background:var(--bg-soft);min-width:22px;height:22px;color:var(--text-muted);border-radius:99px;place-items:center;padding:0 6px;font-size:11px;font-weight:700;display:inline-grid}.games-filter-chip.active .games-filter-count{color:#fff;background:#ffffff40}.games-cards{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.ph-status{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:10px;padding:12px 14px;display:flex}.ph-stat{background:var(--bg-soft);border-radius:99px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;display:inline-flex}.ph-stat b{font-weight:800}.ph-score b{color:var(--accent-strong)}.ph-combo b{color:var(--warn)}.ph-lives{letter-spacing:2px}.ph-end{text-align:center;background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--radius);padding:36px 20px}.ph-end-grade{margin-bottom:8px;font-size:26px;font-weight:800}.ph-end-score{color:var(--text-muted);margin-bottom:14px;font-size:18px}.ph-mail{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.ph-mail-head{background:var(--bg-soft);border-bottom:1px solid var(--border-soft);flex-direction:column;gap:6px;padding:14px 18px;font-size:13px;display:flex}.ph-mail-head .ph-l{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-right:6px;font-size:11px}.ph-mail-head code{color:var(--text);word-break:break-all;background:0 0;font-family:JetBrains Mono,monospace;font-size:13px}.ph-mail-body{white-space:pre-wrap;padding:18px;font-size:14px;line-height:1.55}.ph-actions{flex-wrap:wrap;gap:12px;display:flex}.ph-btn{border-radius:12px;flex:180px;padding:16px;font-size:16px;font-weight:700}.ph-btn-phish{background:var(--danger);color:#fff;border:0}.ph-btn-phish:hover{background:#dc2626}.ph-btn-legit{background:var(--success);color:#fff;border:0}.ph-btn-legit:hover{background:#059669}.ph-reveal{border-radius:var(--radius);background:var(--bg-elev);border:1px solid var(--border-soft);border-left-width:6px;padding:18px 20px}.ph-reveal.ok{border-left-color:var(--success)}.ph-reveal.bad{border-left-color:var(--danger)}.ph-reveal-head{margin-bottom:10px;font-size:16px;font-weight:700}.ph-reveal-flags ul{margin:6px 0 14px;padding-left:22px}.ca-cipher{letter-spacing:3px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);text-align:center;word-break:break-word;color:var(--accent-strong);padding:18px;font-family:JetBrains Mono,monospace;font-size:18px;font-weight:600}.ca-wheel{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--radius);grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:14px 18px;display:grid}.ca-wheel .btn{padding:8px 18px;font-size:22px}.ca-shift{text-align:center}.ca-shift-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:11px}.ca-shift-val{color:var(--accent-strong);font-size:32px;font-weight:800;line-height:1}.ca-slider{width:100%;accent-color:var(--accent);grid-column:1/-1}.ca-plain{letter-spacing:2px;background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:var(--radius);text-align:center;word-break:break-word;transition:all var(--transition);padding:16px;font-family:JetBrains Mono,monospace;font-size:16px}.ca-plain.ok{border-color:var(--success);color:var(--success);background:#10b9811f;font-weight:700}.ca-hintbox{background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:var(--radius);padding:12px 14px;font-size:13px}.ca-hintbox .chip{margin:0 4px;font-family:monospace}.phh-q{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:26px}.phh-svc{letter-spacing:-.02em;color:var(--accent-strong);font-size:38px;font-weight:800}.phh-hint{margin-top:6px;font-size:14px}.phh-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.phh-opt{border:2px solid var(--border);background:var(--bg-elev);color:var(--text);cursor:pointer;border-radius:14px;padding:22px;font-family:JetBrains Mono,monospace;font-size:22px;font-weight:700;transition:all .15s}.phh-opt:hover{border-color:var(--accent);transform:translateY(-2px)}.phh-opt.ok{background:var(--success);color:#fff;border-color:#0000;transform:scale(1.05)}.phh-opt.bad{background:var(--danger);color:#fff;border-color:#0000;animation:.3s shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.mm-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.mm-card{cursor:pointer;perspective:600px;background:0 0;border:0;border-radius:12px;height:110px;padding:0;font-family:inherit;position:relative}.mm-front,.mm-back{text-align:center;backface-visibility:hidden;border-radius:12px;place-items:center;padding:10px;font-size:13px;transition:transform .4s cubic-bezier(.4,0,.2,1);display:grid;position:absolute;inset:0}.mm-front{background:linear-gradient(135deg, var(--accent), var(--pink));color:#fff;font-size:32px;font-weight:800}.mm-back{background:var(--bg-elev);border:1px solid var(--border);color:var(--text);font-weight:600;line-height:1.3;transform:rotateY(180deg)}.mm-card.flip .mm-front{transform:rotateY(180deg)}.mm-card.flip .mm-back{transform:rotateY(360deg)}.mm-card.matched .mm-back{border-color:var(--success);color:var(--success);background:#10b98126}.mm-k .mm-back{font-size:15px;font-weight:800}@media (width<=720px){.mm-grid{grid-template-columns:repeat(2,1fr)}}.rsa-grid{gap:14px;display:grid}.rsa-step{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px 20px 18px 64px;position:relative}.rsa-num{background:linear-gradient(135deg, var(--accent), var(--accent-strong));color:#fff;width:36px;height:36px;box-shadow:var(--shadow-sm);border-radius:50%;place-items:center;font-size:16px;font-weight:800;display:grid;position:absolute;top:16px;left:16px}.rsa-title{margin-bottom:8px;font-weight:700}.rsa-eq{background:var(--bg-soft);border-radius:8px;margin:4px 0;padding:8px 12px;font-family:JetBrains Mono,monospace;font-size:14px}.rsa-eq b{color:var(--accent-strong)}.rsa-eq b.ok{color:var(--success)}.rsa-row{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.rsa-row label{color:var(--text-muted);flex-direction:column;gap:4px;font-size:12px;display:flex}.rsa-row select,.rsa-row input{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:8px;padding:8px 10px;font-family:inherit}.rsa-keys{grid-template-columns:1fr 1fr;gap:10px;margin-top:10px;display:grid}.rsa-key{border-radius:10px;padding:10px 14px;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:600}.rsa-pub{color:var(--success);background:#10b9811f;border:1px solid #10b9814d}.rsa-priv{color:var(--danger);background:#ef44441a;border:1px solid #ef44444d}.bad{color:var(--danger);font-weight:600}@media (width<=720px){.rsa-keys{grid-template-columns:1fr}}.dh-public{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--radius);padding:14px 18px}.dh-pub-title{margin-bottom:8px;font-size:14px;font-weight:700}.dh-row{flex-wrap:wrap;gap:14px;display:flex}.dh-row label{color:var(--text-muted);flex-direction:column;gap:4px;font-size:12px;display:flex}.dh-row select,.dh-row input{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:8px;padding:8px 10px;font-family:inherit}.dh-grid{grid-template-columns:1fr auto 1fr;align-items:stretch;gap:14px;display:grid}.dh-party{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--radius);padding:16px}.dh-party-title{margin-bottom:10px;font-size:16px;font-weight:700}.dh-alice .dh-party-title{color:var(--pink)}.dh-bob .dh-party-title{color:var(--accent-strong)}.dh-party label{color:var(--text-muted);flex-direction:column;gap:4px;margin-bottom:8px;font-size:12px;display:flex}.dh-party input{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:8px;padding:8px 10px;font-family:inherit}.dh-eq{background:var(--bg-soft);word-break:break-all;border-radius:6px;margin:4px 0;padding:6px 10px;font-family:JetBrains Mono,monospace;font-size:12.5px}.dh-eq b.ok{color:var(--success);font-weight:800}.dh-arrows{flex-direction:column;justify-content:center;align-items:center;gap:12px;min-width:160px;display:flex}.dh-arrow{background:var(--bg-soft);color:var(--text-muted);border-radius:99px;padding:6px 12px;font-family:JetBrains Mono,monospace;font-size:12px}.dh-shared{text-align:center;border-radius:10px;padding:10px 14px;font-size:13px;font-weight:700}.dh-shared.ok{color:var(--success);background:#10b98126;border:1px solid #10b98166}.dh-shared.bad{color:var(--danger);background:#ef44441f;border:1px solid #ef444466}@media (width<=980px){.dh-grid{grid-template-columns:1fr}.dh-arrows{flex-flow:wrap}}.sqm-table{border-collapse:collapse;background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;width:100%;font-size:14px;overflow:hidden}.sqm-table th,.sqm-table td{border-bottom:1px solid var(--border-soft);text-align:left;padding:8px 12px}.sqm-table th{background:var(--bg-soft);text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-size:12px;font-weight:700}.sqm-table tr.square td{color:var(--accent-strong)}.sqm-table tr.multiply{background:#6366f10d}.sqm-table tr.multiply td{color:var(--pink);font-weight:600}.sqm-table code{background:var(--bg-soft);border-radius:4px;padding:2px 6px;font-family:JetBrains Mono,monospace}.ecb-side{grid-template-columns:1fr 1fr;align-items:start;gap:18px;display:grid}.ecb-h{margin-bottom:8px;font-size:14px;font-weight:700}.ecb-svg{border:1px solid var(--border-soft);background:var(--bg-elev);border-radius:8px;width:100%;max-width:260px;height:auto}.ecb-explain{border-radius:var(--radius);border-left:4px solid var(--border-soft);padding:14px 18px;font-size:14px;line-height:1.5}.ecb-explain.ok{border-left-color:var(--success);background:#10b9811a}.ecb-explain.bad{border-left-color:var(--danger);background:#ef444414}@media (width<=720px){.ecb-side{grid-template-columns:1fr}}@media (width<=768px){.games-filter{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;padding-bottom:6px;overflow-x:auto}.games-filter::-webkit-scrollbar{display:none}.games-filter-chip{flex-shrink:0;padding:7px 12px;font-size:12px}.games-filter-count{min-width:18px;height:18px;font-size:10px}.games-cards{grid-template-columns:1fr}.game-card{gap:12px;padding:14px}.game-card-ico{font-size:26px}.game-header{flex-wrap:wrap;gap:8px;margin-bottom:14px}.game-header-ico{font-size:28px}.game-header-title{font-size:18px}.game-controls{flex-direction:column;gap:10px;padding:12px}.game-controls label{width:100%}.game-controls .input,.game-controls select,.game-controls input[type=number]{width:100%;min-height:44px;font-size:16px}.game-actions{flex-direction:column}.game-actions .btn{width:100%;min-height:44px}.mmu-result label{flex:100%;min-width:0}.mmu-input{width:100%}.raid-result{grid-template-columns:1fr}.raid-quiz-row{flex-direction:column;gap:8px}.rsa-step{padding:14px 12px 14px 48px}.rsa-num{width:28px;height:28px;font-size:12px;top:14px;left:10px}.rsa-keys{grid-template-columns:1fr}.phh-grid{grid-template-columns:1fr 1fr;gap:8px}.phh-opt{padding:16px 8px;font-size:18px}.phh-svc{font-size:28px}.phh-q{padding:18px 14px}.ca-cipher,.ca-plain{letter-spacing:1px;padding:14px;font-size:15px}.buddy-bar{-webkit-overflow-scrolling:touch;overflow-x:auto}.gantt-bar{height:36px}.gantt-seg{font-size:11px}.pr-table th,.pr-table td{padding:5px 6px;font-size:12px}}@media (width<=380px){.games-filter-chip{padding:6px 10px;font-size:11px}.phh-grid{grid-template-columns:1fr}.phh-opt{padding:14px 8px;font-size:16px}.game-header-title{font-size:16px}}.sync-toolbar{background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 8%, var(--bg-elev)), var(--bg-elev));border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;padding:14px 16px;display:flex}.sync-toolbar-label{color:var(--text-muted);align-items:center;gap:10px;font-size:13px;font-weight:600;display:flex}.sync-toolbar-sel{background:var(--bg);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:8px;padding:7px 10px;font-size:13px;font-weight:500}.sync-toolbar-info{flex-wrap:wrap;gap:8px;display:flex}.sync-pill{background:var(--bg);border:1px solid var(--border);color:var(--text-muted);border-radius:999px;padding:5px 11px;font-size:12px}.sync-pill b{color:var(--text);margin-right:2px}.sync-rules{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:14px}.sync-rules>summary{cursor:pointer;-webkit-user-select:none;user-select:none;padding:12px 16px;font-size:14px;font-weight:600;list-style:none}.sync-rules>summary::-webkit-details-marker{display:none}.sync-rules>summary:before{content:"▸";color:var(--accent);margin-right:8px;transition:transform .18s;display:inline-block}.sync-rules[open]>summary:before{transform:rotate(90deg)}.sync-rules-body{color:var(--text-muted);padding:0 16px 14px;font-size:13px;line-height:1.55}.sync-rules-body p{margin:6px 0}.sync-rules-body ol{margin:8px 0 0 20px;padding:0}.sync-rules-body li{margin:3px 0}.sync-bank-wrap{grid-template-columns:1fr auto;gap:12px;margin-bottom:18px;display:grid}.sync-bank{background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 5%, var(--bg-elev)), var(--bg-elev));border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:0 1px 2px #00000008,0 4px 12px #0000000a}.sync-bank-head{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:12px;display:flex}.sync-bank-title{color:var(--text);font-size:14px;font-weight:700}.sync-bank-hint{color:var(--text-muted);font-size:12px;font-style:italic}.sync-bank-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;display:grid}.sync-bank-pair{background:var(--bg);border:1px solid var(--border);border-left:3px solid var(--sem-color);border-radius:8px;align-items:center;gap:8px;padding:8px 10px;transition:transform .15s,box-shadow .15s;display:flex}.sync-bank-pair:hover{box-shadow:0 4px 10px color-mix(in srgb, var(--sem-color) 25%, transparent);transform:translateY(-1px)}.sync-bank-label{color:var(--sem-color);min-width:22px;font-size:13px;font-weight:700}.sync-trash{background:var(--bg-elev);border:2px dashed var(--border);border-radius:var(--radius);min-width:88px;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:12px 14px;font-size:11px;transition:all .18s;display:flex}.sync-trash-icon{font-size:24px;line-height:1}.sync-trash-hover{background:color-mix(in srgb, var(--danger) 15%, var(--bg-elev));border-color:var(--danger);color:var(--danger);box-shadow:0 0 0 4px color-mix(in srgb, var(--danger) 18%, transparent);transform:scale(1.05)}.sync-op{cursor:grab;-webkit-user-select:none;user-select:none;background:linear-gradient(135deg, color-mix(in srgb, var(--sem-color) 20%, var(--bg)), color-mix(in srgb, var(--sem-color) 8%, var(--bg)));color:var(--sem-color);border:1.5px solid color-mix(in srgb, var(--sem-color) 50%, transparent);white-space:nowrap;border-radius:7px;align-items:center;gap:1px;padding:5px 10px;font-family:JetBrains Mono,Consolas,ui-monospace,monospace;font-size:12.5px;font-weight:700;transition:transform .12s,box-shadow .12s,opacity .12s;display:inline-flex}.sync-op:hover{box-shadow:0 6px 14px color-mix(in srgb, var(--sem-color) 35%, transparent);transform:translateY(-2px)scale(1.03)}.sync-op:active{cursor:grabbing}.sync-op-letter{letter-spacing:.3px;font-weight:800}.sync-op-paren{opacity:.6;font-weight:600}.sync-op sub{opacity:.85;font-size:.75em}.sync-op-V{background:linear-gradient(135deg, color-mix(in srgb, var(--sem-color) 30%, var(--bg)), color-mix(in srgb, var(--sem-color) 14%, var(--bg)))}.sync-op-dragging{opacity:.45;cursor:grabbing;transform:scale(.94)}.sync-op-tapselected{outline:2px solid var(--sem-color);outline-offset:2px;box-shadow:0 0 0 4px color-mix(in srgb, var(--sem-color) 20%, transparent)}@keyframes syncOpPop{0%{opacity:0;transform:scale(.4)rotate(-6deg)}60%{opacity:1;transform:scale(1.18)rotate(2deg)}to{opacity:1;transform:scale(1)rotate(0)}}.sync-op-pop{animation:.38s cubic-bezier(.34,1.56,.64,1) syncOpPop}@keyframes syncOpRemove{to{opacity:0;transform:scale(.3)rotate(8deg)}}.sync-op-removing{animation:.18s ease-in forwards syncOpRemove}.sync-board{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:14px;display:grid}.sync-proc{background:linear-gradient(180deg, color-mix(in srgb, var(--proc-color) 5%, var(--bg-elev)), var(--bg-elev));border:1px solid var(--border);border-top:3px solid var(--proc-color);border-radius:var(--radius);flex-direction:column;gap:6px;padding:12px;display:flex}.sync-proc-head{color:var(--text);border-bottom:1px dashed var(--border);align-items:center;gap:8px;margin-bottom:4px;padding-bottom:8px;font-size:13px;font-weight:700;display:flex}.sync-proc-dot{background:var(--proc-color);width:8px;height:8px;box-shadow:0 0 0 3px color-mix(in srgb, var(--proc-color) 22%, transparent);border-radius:50%}.sync-proc-body{flex-direction:column;gap:4px;display:flex}.sync-block{border-radius:8px;justify-content:space-between;align-items:center;padding:10px 12px;font-family:JetBrains Mono,Consolas,ui-monospace,monospace;font-size:15px;font-weight:700;display:flex}.sync-block-letter{font-size:18px}.sync-block-tag{letter-spacing:.5px;text-transform:uppercase;background:color-mix(in srgb, var(--accent) 22%, transparent);color:var(--accent);font-size:9.5px;font-weight:700;font-family:var(--font-sans,system-ui);border-radius:999px;padding:2px 6px}.sync-block-tag-free{background:color-mix(in srgb, var(--text-muted) 18%, transparent);color:var(--text-muted)}.sync-block-crit{background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 18%, var(--bg)), color-mix(in srgb, var(--accent) 6%, var(--bg)));border:1px solid color-mix(in srgb, var(--accent) 40%, transparent);color:var(--accent)}.sync-block-free{background:var(--bg);border:1px dashed var(--border);color:var(--text-muted)}.sync-slot{background:color-mix(in srgb, var(--text-muted) 4%, transparent);border:1.5px dashed color-mix(in srgb, var(--text-muted) 25%, transparent);border-radius:6px;flex-wrap:wrap;align-items:center;gap:4px;min-height:36px;padding:4px 8px;transition:all .15s;display:flex}.sync-slot-empty{justify-content:center}.sync-slot-hint{color:color-mix(in srgb, var(--text-muted) 60%, transparent);font-size:16px;font-weight:300}.sync-slot-full{background:color-mix(in srgb, var(--accent) 6%, transparent)}.sync-slot-hover{background:color-mix(in srgb, var(--accent) 15%, transparent);border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 18%, transparent);border-style:solid;transform:scale(1.02)}@keyframes syncSlotSuccess{0%,to{background:color-mix(in srgb, var(--accent) 6%, transparent)}50%{background:color-mix(in srgb, var(--success,#22c55e) 35%, transparent);box-shadow:0 0 0 4px color-mix(in srgb, var(--success,#22c55e) 25%, transparent)}}.sync-slot-success{border-color:var(--success,#22c55e);animation:.7s syncSlotSuccess}.sync-actions{flex-wrap:wrap;gap:8px;margin:14px 0 10px;display:flex}.sync-feedback{margin-top:8px}.sync-result{border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-elev);align-items:flex-start;gap:12px;padding:14px 16px;animation:.32s cubic-bezier(.34,1.56,.64,1) syncOpPop;display:flex}.sync-result-icon{font-size:26px;line-height:1}.sync-result-title{margin-bottom:4px;font-size:14px;font-weight:700}.sync-result-sub{color:var(--text-muted);font-size:13px}.sync-result-list{margin:4px 0 0 18px;padding:0;font-size:13px;line-height:1.55}.sync-result-list li{margin:2px 0}.sync-result-ok{background:linear-gradient(135deg, color-mix(in srgb, var(--success,#22c55e) 18%, var(--bg-elev)), var(--bg-elev));border-color:color-mix(in srgb, var(--success,#22c55e) 50%, transparent)}.sync-result-bad{background:linear-gradient(135deg, color-mix(in srgb, var(--danger,#ef4444) 14%, var(--bg-elev)), var(--bg-elev));border-color:color-mix(in srgb, var(--danger,#ef4444) 45%, transparent)}.sync-result-info{background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 12%, var(--bg-elev)), var(--bg-elev));border-color:color-mix(in srgb, var(--accent) 45%, transparent)}@media (width<=768px){.sync-toolbar{gap:8px;padding:10px 12px}.sync-bank-wrap{grid-template-columns:1fr}.sync-trash{flex-direction:row;min-width:0}.sync-trash-icon{font-size:20px}.sync-bank-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}.sync-bank-pair{padding:6px 8px}.sync-board{grid-template-columns:1fr;gap:10px}.sync-proc{padding:10px}.sync-block{padding:8px 10px;font-size:14px}.sync-block-letter{font-size:16px}.sync-op{padding:4px 8px;font-size:11.5px}.sync-slot{min-height:32px;padding:3px 6px}}@media (width<=380px){.sync-pill{padding:4px 8px;font-size:11px}.sync-op{padding:3px 7px;font-size:11px}.sync-block-letter{font-size:15px}}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}.boot-screen{background:var(--bg,#f6f7fb);min-height:100vh;color:var(--text,#0f172a);place-items:center;gap:1rem;font-weight:700;display:grid}.spinner{border:3px solid #6366f133;border-top-color:#6366f1;border-radius:999px;width:2rem;height:2rem;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.deck-card,.flashcard{text-align:left;width:100%;color:inherit;font:inherit;border:0}.deck-card{cursor:pointer;gap:1rem;display:flex}.deck-icon{font-size:2rem}.deck-body{flex:1}.progress{background:#94a3b82e;border-radius:999px;height:.55rem;overflow:hidden}.progress>span{background:linear-gradient(90deg,#6366f1,#22c55e);height:100%;display:block}.heatmap{grid-template-columns:repeat(13,minmax(10px,1fr));gap:.35rem;display:grid}.heat-cell{aspect-ratio:1;background:#94a3b82e;border-radius:.25rem}.heat-cell.level-1{background:#bfdbfe}.heat-cell.level-2{background:#60a5fa}.heat-cell.level-3{background:#2563eb}.heat-cell.level-4{background:#1d4ed8}.review-panel{max-width:980px;margin:0 auto}.session-stats,.review-actions,.browse-tools,.chat-options,.chat-input{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.flashcard{cursor:pointer;perspective:1200px;background:0 0;min-height:360px;margin:1rem 0;display:grid}.card-face{background:var(--panel,#fff);box-shadow:var(--shadow,0 20px 60px #0f172a1a);backface-visibility:hidden;border:1px solid #94a3b833;border-radius:1.5rem;grid-area:1/1;padding:2rem;transition:transform .35s}.card-back,.flashcard.flipped .card-front{transform:rotateY(180deg)}.flashcard.flipped .card-back{transform:rotateY(360deg)}.card-figure,.browse-figure{border:1px solid #94a3b840;border-radius:1rem;max-width:100%;margin-top:1rem}.rate-btn{gap:.2rem;min-width:8rem;display:grid}.browse-columns{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;display:grid}.card-list{gap:1rem;display:grid}.summary-grid{grid-template-columns:minmax(220px,320px) 1fr}.summary-content{max-width:920px}.markdown :is(h1,h2,h3){margin-top:1.3em}.bar-row,.chapter-row,.settings-panel label{gap:.45rem;margin:.75rem 0;display:grid}.import-label input{display:none}.danger{color:#dc2626}.chat-toggle{z-index:40;color:#fff;background:#6366f1;border:0;border-radius:999px;width:3.25rem;height:3.25rem;font-size:1.3rem;position:fixed;bottom:1.25rem;right:1.25rem;box-shadow:0 14px 40px #0f172a40}.chat-panel{z-index:39;background:var(--panel,#fff);border:1px solid #94a3b840;border-radius:1.25rem;flex-direction:column;width:min(440px,100vw - 2rem);max-height:min(760px,100vh - 7rem);display:none;position:fixed;inset:auto 1rem 5rem auto;overflow:hidden;box-shadow:0 24px 80px #0f172a40}.chat-panel.open{display:flex}.chat-head,.chat-options,.chat-input{border-bottom:1px solid #94a3b82e;padding:1rem}.chat-head{justify-content:space-between;gap:1rem;display:flex}.chat-body{flex:1;padding:1rem;overflow:auto}.chat-input{border-top:1px solid #94a3b82e;border-bottom:0}.chat-input textarea{flex:1;min-height:4rem}.chat-bubble .markdown p{margin:0}@media (width<=900px){.summary-grid,.grid-2{grid-template-columns:1fr}}.review-progress{gap:.6rem;margin-bottom:1rem;display:grid}.rp-labels{color:var(--muted,#64748b);flex-wrap:wrap;align-items:center;gap:.75rem;font-size:.9rem;display:flex}.rp-labels strong{color:var(--text,#0f172a);margin-left:auto}.rp-bar{background:#94a3b82e;border-radius:999px;height:.65rem;overflow:hidden}.rp-fill{border-radius:inherit;background:linear-gradient(90deg,#6366f1,#22c55e);height:100%;transition:width .25s;display:block}.dot-new,.dot-learn,.dot-due{border-radius:999px;width:.55rem;height:.55rem;margin-right:.25rem;display:inline-block}.dot-new{background:#38bdf8}.dot-learn{background:#a78bfa}.dot-due{background:#f97316}.card-inner{width:100%;min-height:clamp(360px,48vh,620px);color:inherit;font:inherit;text-align:left;cursor:pointer;background:0 0;border:0;padding:0;display:grid}.card-stage .card-face{min-height:inherit;flex-direction:column;grid-area:1/1;gap:1rem;padding:clamp(1.3rem,3vw,2.3rem);display:flex}.face-label{color:#4f46e5;background:#6366f117;border-radius:999px;align-self:flex-start;padding:.35rem .7rem;font-size:.8rem;font-weight:700}.face-content{font-size:clamp(1rem,1.7vw,1.25rem);line-height:1.65}.card-fig-hint{color:#4f46e5;cursor:zoom-in;gap:.4rem;font-weight:700;display:grid}.card-source{color:var(--muted,#64748b);margin-top:auto;font-size:.9rem}.btn-flip kbd,.rate-btn kbd,.review-hints kbd{font:inherit;background:#0f172a14;border-radius:.35rem;padding:.1rem .35rem;font-size:.75rem}.review-actions{margin-top:.75rem}.rate-btn{background:var(--panel,#fff);cursor:pointer;border:1px solid #94a3b840;border-radius:1rem;padding:.85rem 1rem;box-shadow:0 10px 28px #0f172a14}.rate-again{color:#dc2626;border-color:#ef444459}.rate-hard{color:#d97706;border-color:#f59e0b66}.rate-good{color:#16a34a;border-color:#22c55e59}.rate-easy{color:#2563eb;border-color:#3b82f659}.lightbox{z-index:80;cursor:zoom-out;background:#020617d1;border:0;place-items:center;display:none;position:fixed;inset:0}.lightbox.show{display:grid}.lightbox img{background:#fff;border-radius:1rem;max-width:min(94vw,1200px);max-height:90vh}.deck-tabs{flex-wrap:wrap;gap:.75rem;margin:0 0 1rem;display:flex}.deck-tab{background:var(--panel,#fff);color:inherit;cursor:pointer;border:1px solid #94a3b838;border-radius:1rem;align-items:center;gap:.55rem;padding:.75rem .95rem;display:flex;box-shadow:0 8px 24px #0f172a0d}.deck-tab.active{color:#4f46e5;background:#6366f11a;border-color:#6366f18c}.deck-tab-icon{font-size:1.1rem}.deck-tab-name{font-weight:750}.deck-tab-count{background:#94a3b829;border-radius:999px;padding:.1rem .45rem;font-size:.8rem}.deck-card{background:var(--panel,#fff);border:1px solid #94a3b82e;border-radius:1.25rem;align-items:center;padding:1rem;box-shadow:0 12px 32px #0f172a0f}.deck-meta{flex:1;gap:.35rem;display:grid}.deck-name{font-size:1.05rem;font-weight:850}.deck-sub,.overview-metrics{color:var(--muted,#64748b);font-size:.88rem}.deck-progress,.overview-maturity{background:#94a3b82e;border-radius:999px;height:.5rem;overflow:hidden}.deck-progress span,.overview-maturity span{border-radius:inherit;background:linear-gradient(90deg,#6366f1,#22c55e);height:100%;display:block}.deck-action{background:#94a3b81f;border-radius:.8rem;padding:.55rem .8rem;font-weight:800}.deck-action.has-due{color:#fff;background:#4f46e5}.overview-metrics{flex-wrap:wrap;gap:.55rem;display:flex}.analytics-overview{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-bottom:1rem;display:grid}.overview-card{background:var(--panel,#fff);border:1px solid #94a3b82e;border-radius:1.25rem;gap:.75rem;padding:1rem;display:grid;box-shadow:0 12px 32px #0f172a0f}.overview-card h3{margin:0}.overview-cta{color:#4f46e5;margin:0;font-weight:750}.analytics-detail-grid{align-items:start}.chap-list,.hardest-list{gap:.75rem;display:grid}.chap-row{grid-template-columns:minmax(0,1fr) 35% auto;align-items:center;gap:.75rem;display:grid}.chap-row span,.hardest-meta{color:var(--muted,#64748b);font-size:.85rem;display:block}.chap-bar{background:#94a3b82e;border-radius:999px;height:.55rem;overflow:hidden}.chap-bar-fill{background:#22c55e;height:100%;display:block}.chap-bar-fill.warn{background:#f59e0b}.chap-bar-fill.bad{background:#ef4444}.hardest-row{background:#94a3b80f;border:1px solid #94a3b82e;border-radius:1rem;padding:.8rem}.hardest-q{-webkit-line-clamp:2;-webkit-box-orient:vertical;font-weight:750;display:-webkit-box;overflow:hidden}.filter-chips{flex-wrap:wrap;gap:.45rem;display:flex}.chip.active{color:#fff;background:#4f46e5}.browse-row{padding:0;overflow:hidden}.browse-summary{width:100%;color:inherit;text-align:left;cursor:pointer;background:0 0;border:0;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:1rem;padding:1rem;display:grid}.browse-id{color:#4f46e5;font-weight:850}.browse-q{text-overflow:ellipsis;white-space:nowrap;font-weight:700;overflow:hidden}.browse-meta{color:var(--muted,#64748b);font-size:.85rem}.browse-details{padding:0 1rem 1rem}.browse-actions,.settings-actions{flex-wrap:wrap;align-items:center;gap:.75rem;margin-top:1rem;display:flex}.summary-layout{grid-template-columns:minmax(220px,320px) minmax(0,1fr);align-items:start;gap:1rem;display:grid}.summary-toc{background:var(--panel,#fff);border:1px solid #94a3b82e;border-radius:1.25rem;max-height:calc(100vh - 2rem);padding:1rem;position:sticky;top:1rem;overflow:auto;box-shadow:0 12px 32px #0f172a0f}.toc-title{margin-bottom:.75rem;font-weight:850}.summary-toc a{color:var(--muted,#64748b);border-radius:.6rem;padding:.35rem .5rem;text-decoration:none;display:block}.summary-toc a.active,.summary-toc a:hover{color:#4f46e5;background:#6366f11a}.toc-l2{padding-left:1rem!important}.toc-l3{font-size:.92rem;padding-left:1.6rem!important}.toc-l4{font-size:.86rem;padding-left:2.2rem!important}.summary-content{background:var(--panel,#fff);border:1px solid #94a3b82e;border-radius:1.25rem;padding:clamp(1rem,3vw,2rem);box-shadow:0 12px 32px #0f172a0f}.summary-doc{line-height:1.75}.summary-doc :is(h1,h2,h3,h4){scroll-margin-top:1.5rem}.heading-anchor{opacity:0;color:#4f46e5;margin-right:.45rem;text-decoration:none}.summary-doc :is(h1,h2,h3,h4):hover .heading-anchor{opacity:1}.setting-row,.exam-row{border-bottom:1px solid #94a3b829;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:1rem;padding:.9rem 0;display:grid}.set-title,.exam-name{font-weight:800;display:block}.set-sub,.exam-sub{color:var(--muted,#64748b);font-size:.86rem;display:block}.exam-row{grid-template-columns:minmax(0,1fr) auto auto}.exam-target{color:#4f46e5;font-weight:800}.chat-backdrop{z-index:38;background:#0f172a38;border:0;position:fixed;inset:0}.chat-panel{border-radius:1.25rem 0 0 1.25rem;width:min(520px,100vw);max-height:none;inset:0 0 0 auto}.chat-head-title{align-items:center;gap:.75rem;display:flex}.chat-ico{background:#6366f11f;border-radius:.8rem;place-items:center;width:2.3rem;height:2.3rem;display:grid}.chat-fab{justify-content:center;align-items:center;gap:.45rem;width:auto;min-width:3.25rem;padding:0 1rem;display:flex}.chat-fab-label{font-size:.85rem;font-weight:800}.chat-keyhint{color:#dc2626;background:#ef44441a;padding:.75rem 1rem}.chat-suggests{flex-wrap:wrap;gap:.5rem;margin-top:.75rem;display:flex}.chat-suggest{color:#4f46e5;cursor:pointer;background:#6366f114;border:1px solid #6366f140;border-radius:999px;padding:.45rem .7rem}.chat-typing span{background:currentColor;border-radius:999px;width:.35rem;height:.35rem;margin-right:.15rem;animation:1s ease-in-out infinite typingPulse;display:inline-block}.chat-typing span:nth-child(2){animation-delay:.15s}.chat-typing span:nth-child(3){animation-delay:.3s}@keyframes typingPulse{0%,80%,to{opacity:.25;transform:translateY(0)}40%{opacity:1;transform:translateY(-2px)}}.game-toast{z-index:90;color:#fff;background:#111827;border-radius:999px;padding:.75rem 1rem;position:fixed;bottom:2rem;left:50%;transform:translate(-50%);box-shadow:0 16px 44px #0f172a47}@media (width<=900px){.summary-layout,.browse-summary,.chap-row,.exam-row{grid-template-columns:1fr}.summary-toc{max-height:35vh;position:static}.chat-panel{border-radius:0;width:100vw}.chat-fab-label{display:none}}.sr-only{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.select-wrap{align-items:center;display:inline-flex;position:relative}.select-wrap:after{content:"";border-right:2px solid var(--text-muted,#64748b);border-bottom:2px solid var(--text-muted,#64748b);pointer-events:none;width:.55rem;height:.55rem;transition:border-color var(--transition,.2s);position:absolute;top:50%;right:.85rem;transform:translateY(-65%)rotate(45deg)}.select-wrap:focus-within:after{border-color:var(--accent,#6366f1)}select.select,.head-actions>select,.browse-tools>select{appearance:none;font:inherit;background:var(--bg-elev,#fff);color:var(--text,#0f172a);border:1px solid var(--border,#e5e7eb);cursor:pointer;transition:border-color var(--transition,.2s), box-shadow var(--transition,.2s);border-radius:.7rem;outline:none;min-width:12rem;padding:.6rem 2.4rem .6rem .9rem;font-weight:600;box-shadow:0 1px 2px #0f172a0a}select.select:hover,.head-actions>select:hover,.browse-tools>select:hover{border-color:var(--accent,#6366f1)}select.select:focus,.head-actions>select:focus,.browse-tools>select:focus{border-color:var(--accent,#6366f1);box-shadow:0 0 0 3px #6366f12e}select.select option{background:var(--bg-elev,#fff);color:var(--text,#0f172a);padding:.5rem}.head-actions>select{min-width:11rem}.card-stage{perspective:1600px;margin:1rem 0}.card-stage .card-inner{width:100%;min-height:clamp(360px,48vh,620px);color:inherit;font:inherit;text-align:left;cursor:pointer;transform-style:preserve-3d;background:0 0;border:0;padding:0;transition:transform .55s cubic-bezier(.34,1.4,.64,1);display:block;position:relative}.card-stage.flipped .card-inner{transform:rotateY(180deg)}.card-stage .card-face{background:var(--bg-elev,#fff);border:1px solid var(--border-soft,#eef0f4);backface-visibility:hidden;border-radius:1.4rem;flex-direction:column;gap:1rem;padding:clamp(1.4rem,3vw,2.4rem);display:flex;position:absolute;inset:0;overflow:auto;box-shadow:0 24px 48px -16px #0f172a2e}.card-stage .card-back{background:linear-gradient(135deg, var(--bg-elev,#fff) 0%, var(--accent-soft,#eef2ff) 100%);transform:rotateY(180deg)}.face-foot{text-align:center;opacity:.8;margin-top:auto;font-size:.82rem}.review-actions{grid-template-columns:repeat(4,1fr);gap:.65rem;margin-top:1.1rem;display:grid}.review-actions:has(.btn-flip){grid-template-columns:1fr;justify-items:center}.btn-flip{background:linear-gradient(135deg, var(--accent,#6366f1), var(--accent-strong,#4f46e5));color:#fff;cursor:pointer;border:0;border-radius:.9rem;align-items:center;gap:.5rem;width:auto;padding:.9rem 1.6rem;font-size:.95rem;font-weight:700;display:inline-flex;box-shadow:0 10px 24px -8px #6366f18c}.btn-flip kbd{color:#fff;background:#fff3;border:0;padding:.15rem .4rem}.rate-btn{border:1.5px solid var(--border,#e5e7eb);background:var(--bg-elev,#fff);color:var(--text,#0f172a);cursor:pointer;text-align:center;transition:transform var(--transition,.2s), border-color var(--transition,.2s), box-shadow var(--transition,.2s), background var(--transition,.2s);border-radius:.9rem;grid-template-rows:auto auto auto;place-items:center;gap:.25rem;padding:.9rem .6rem;font-family:inherit;display:grid;box-shadow:0 4px 12px #0f172a0a}.rate-btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px -10px #0f172a2e}.rate-btn:active{transform:translateY(0)}.rate-btn .rate-key kbd{width:1.4rem;height:1.4rem;color:var(--text-muted,#64748b);background:#0f172a14;border-radius:.4rem;place-items:center;font:700 .75rem JetBrains Mono,ui-monospace,monospace;display:inline-grid}.rate-btn .rate-label{letter-spacing:.01em;font-size:1rem;font-weight:800}.rate-btn .rate-due{color:var(--text-muted,#64748b);font-size:.78rem;font-weight:600}.rate-btn.rate-again{border-color:#ef444459}.rate-btn.rate-again:hover{background:#ef444414;border-color:#ef4444}.rate-btn.rate-again .rate-label{color:#dc2626}.rate-btn.rate-hard{border-color:#f59e0b66}.rate-btn.rate-hard:hover{background:#f59e0b1a;border-color:#f59e0b}.rate-btn.rate-hard .rate-label{color:#b45309}.rate-btn.rate-good{border-color:#22c55e66}.rate-btn.rate-good:hover{background:#22c55e14;border-color:#22c55e}.rate-btn.rate-good .rate-label{color:#15803d}.rate-btn.rate-easy{border-color:#3b82f666}.rate-btn.rate-easy:hover{background:#3b82f614;border-color:#3b82f6}.rate-btn.rate-easy .rate-label{color:#1d4ed8}.review-tools{border-top:1px dashed var(--border-soft,#eef0f4);flex-wrap:wrap;justify-content:center;align-items:center;gap:.35rem 1rem;margin-top:.9rem;padding:.6rem 0 0;display:flex}.btn-link{color:var(--text-muted,#64748b);font:inherit;cursor:pointer;transition:background var(--transition,.2s), color var(--transition,.2s);background:0 0;border:0;border-radius:.5rem;padding:.35rem .55rem;font-size:.88rem;font-weight:600}.btn-link:hover{background:var(--bg-soft,#f1f3f9);color:var(--text,#0f172a)}.btn-link.danger{color:#dc2626}.btn-link.danger:hover{color:#b91c1c;background:#ef44441a}@media (width<=720px){.review-actions{grid-template-columns:repeat(2,1fr)}}.browse-tools{grid-template-columns:minmax(220px,1fr) auto 1fr auto;align-items:center;gap:.8rem;padding:1rem 1.1rem;display:grid}.browse-search{align-items:center;display:flex;position:relative}.browse-search-icon{pointer-events:none;opacity:.6;font-size:.9rem;position:absolute;left:.8rem}.browse-tools .browse-search .input{border:1px solid var(--border,#e5e7eb);background:var(--bg-elev,#fff);width:100%;color:var(--text,#0f172a);font:inherit;transition:border-color var(--transition,.2s), box-shadow var(--transition,.2s);border-radius:.7rem;outline:none;padding:.6rem .9rem .6rem 2.2rem}.browse-tools .browse-search .input:focus{border-color:var(--accent,#6366f1);box-shadow:0 0 0 3px #6366f12e}.browse-count{color:var(--text-muted,#64748b);white-space:nowrap;font-size:.85rem;font-weight:600}.browse-tools .filter-chips{grid-column:1/-1}.filter-chips .chip{border:1px solid var(--border,#e5e7eb);background:var(--bg-elev,#fff);color:var(--text-muted,#64748b);font:inherit;cursor:pointer;transition:all var(--transition,.2s);border-radius:999px;padding:.4rem .8rem;font-size:.82rem;font-weight:600}.filter-chips .chip:hover{border-color:var(--accent,#6366f1);color:var(--text,#0f172a)}.filter-chips .chip.active{background:linear-gradient(135deg, var(--accent,#6366f1), var(--accent-strong,#4f46e5));color:#fff;border-color:#0000;box-shadow:0 6px 14px -6px #6366f18c}.browse-list{gap:.55rem;margin-top:1rem;display:grid}.browse-empty{text-align:center;padding:2rem}.browse-row{background:var(--bg-elev,#fff);border:1px solid var(--border-soft,#eef0f4);transition:border-color var(--transition,.2s), box-shadow var(--transition,.2s);border-radius:.9rem;padding:0;display:block;overflow:hidden}.browse-row:hover{border-color:var(--accent,#6366f1);box-shadow:0 8px 20px -10px #0f172a26}.browse-row.expanded{border-color:var(--accent,#6366f1);box-shadow:0 14px 30px -14px #6366f159}.browse-row.suspended{opacity:.65;background:repeating-linear-gradient(45deg, var(--bg-elev,#fff), var(--bg-elev,#fff) 12px, var(--bg-soft,#f1f3f9) 12px, var(--bg-soft,#f1f3f9) 24px)}.browse-summary{width:100%;color:inherit;text-align:left;cursor:pointer;font:inherit;background:0 0;border:0;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:1rem;padding:.85rem 1.1rem;display:grid}.browse-main{flex-direction:column;gap:.35rem;min-width:0;display:flex}.browse-id{color:var(--accent-strong,#4f46e5);background:var(--accent-soft,#eef2ff);white-space:nowrap;border-radius:.4rem;padding:.2rem .55rem;font-family:JetBrains Mono,ui-monospace,monospace;font-size:.82rem;font-weight:700}.browse-q{color:var(--text,#0f172a);text-overflow:ellipsis;white-space:nowrap;font-size:.94rem;font-weight:600;overflow:hidden}.browse-meta{color:var(--text-muted,#64748b);flex-wrap:wrap;align-items:center;gap:.4rem;font-size:.82rem;display:flex}.browse-chevron{color:var(--text-muted,#64748b);font-size:.8rem}.status-pill{letter-spacing:.02em;text-transform:uppercase;border-radius:999px;padding:.15rem .55rem;font-size:.72rem;font-weight:700;display:inline-block}.status-pill.status-new{color:#0369a1;background:#38bdf826}.status-pill.status-learning{color:#6d28d9;background:#a78bfa2e}.status-pill.status-review{color:#15803d;background:#22c55e26}.status-pill.status-suspended{color:#475569;background:#94a3b840}.badge-mini{opacity:.8;font-size:.82rem}.browse-details{border-top:1px solid var(--border-soft,#eef0f4);background:var(--bg-soft,#f1f3f9);padding:0 1.1rem 1.1rem}.browse-columns h4{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted,#64748b);margin:.9rem 0 .3rem;font-size:.78rem}.btn.danger-outline{color:#dc2626;background:0 0;border:1px solid #ef444459}.btn.danger-outline:hover{background:#ef444414;border-color:#ef4444}@media (width<=720px){.browse-summary{grid-template-columns:auto minmax(0,1fr) auto}.browse-tools{grid-template-columns:1fr}}[data-theme=dark] .face-label{color:#c7d2fe;background:#818cf82e}[data-theme=dark] .rate-btn{background:var(--bg-elev,#131a2c)}[data-theme=dark] .rate-btn .rate-key kbd{color:#cbd5e1;background:#ffffff14}[data-theme=dark] .browse-id{color:#c7d2fe;background:#818cf82e}[data-theme=dark] .status-pill.status-new{color:#7dd3fc;background:#38bdf833}[data-theme=dark] .status-pill.status-learning{color:#ddd6fe;background:#a78bfa40}[data-theme=dark] .status-pill.status-review{color:#86efac;background:#22c55e33}[data-theme=dark] .status-pill.status-suspended{color:#cbd5e1;background:#94a3b833}[data-theme=dark] .browse-details{background:#ffffff08}[data-theme=dark] .filter-chips .chip{background:var(--bg-elev,#131a2c);border-color:var(--border,#232c43)}[data-theme=dark] .btn-link:hover{background:#ffffff0f}[data-theme=dark] .heading-anchor{color:#a5b4fc}[data-theme=dark] .summary-toc a.active,[data-theme=dark] .summary-toc a:hover{color:#c7d2fe;background:#818cf826}[data-theme=dark] .deck-tab.active{color:#c7d2fe;background:#818cf82e;border-color:#818cf88c}[data-theme=dark] .card-stage .card-back{background:linear-gradient(135deg, var(--bg-elev,#131a2c) 0%, #6366f133 100%)}[data-theme=dark] select.select option{color:#e6e8ee;background:#1a2238}.games-view-react{gap:1.25rem;display:grid}.games-hero{background:radial-gradient(circle at 100% 0,#6366f138,#0000 34rem),linear-gradient(135deg,#6366f11c,#22c55e14);border:1px solid #94a3b838;border-radius:1.5rem;padding:1.5rem;position:relative;overflow:hidden}.eyebrow{color:#6366f1;letter-spacing:.08em;text-transform:uppercase;margin:0 0 .35rem;font-size:.78rem;font-weight:800}.games-filter.modern{background:#94a3b81f;border:1px solid #94a3b833;border-radius:999px;flex-wrap:wrap;gap:.7rem;width:fit-content;max-width:100%;padding:.35rem;display:flex}.games-filter.modern .games-filter-chip{color:inherit;cursor:pointer;background:0 0;border:0;border-radius:999px;align-items:center;gap:.45rem;padding:.72rem 1rem;font-weight:750;transition:transform .18s,background .18s,box-shadow .18s;display:inline-flex}.games-filter.modern .games-filter-chip:hover{background:#ffffffa6;transform:translateY(-1px)}.games-filter.modern .games-filter-chip.active{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 12px 30px #6366f140}.games-filter-count{background:#0f172a1a;border-radius:999px;place-items:center;min-width:1.45rem;height:1.45rem;font-size:.75rem;display:inline-grid}.games-filter-chip.active .games-filter-count{background:#ffffff38}.modern-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;display:grid}.game-card.modern-card{min-height:9.5rem;color:inherit;text-align:left;cursor:pointer;background:linear-gradient(#ffffffd6,#ffffffad),radial-gradient(circle at 0 0,#6366f11f,#0000 16rem);border:1px solid #94a3b838;border-radius:1.35rem;align-items:flex-start;gap:1rem;padding:1.15rem;transition:transform .18s,box-shadow .18s,border-color .18s;display:flex;position:relative;box-shadow:0 14px 35px #0f172a14}[data-theme=dark] .game-card.modern-card{background:linear-gradient(#0f172adb,#0f172ab8),radial-gradient(circle at 0 0,#6366f129,#0000 16rem)}.game-card.modern-card:hover{border-color:#6366f173;transform:translateY(-3px);box-shadow:0 22px 55px #0f172a24}.game-card.modern-card .game-card-ico{background:linear-gradient(135deg,#6366f12e,#22c55e24);border-radius:1rem;flex:none;place-items:center;width:3.4rem;height:3.4rem;font-size:1.65rem;display:grid}.game-card-kicker{color:#6366f1;letter-spacing:.05em;text-transform:uppercase;margin-bottom:.25rem;font-size:.72rem;font-weight:800}.game-card.modern-card .game-card-title{font-size:1.08rem;font-weight:850}.game-card.modern-card .game-card-sub{color:var(--muted,#64748b);margin-top:.25rem;line-height:1.35}.game-card.modern-card .game-card-tag{color:#4f46e5;background:#6366f11f;border-radius:999px;margin-top:.7rem;padding:.28rem .62rem;font-size:.78rem;font-weight:750;display:inline-flex}.game-card-arrow{color:#6366f1;opacity:.65;margin-left:auto;font-weight:900}.react-stage{background:#94a3b814;border:1px solid #94a3b82e;border-radius:1.5rem;gap:1rem;padding:1rem;display:grid}.react-game-header{background:var(--panel,#fff);border:1px solid #94a3b82e;border-radius:1.15rem;margin:0;padding:1rem}.react-game-host{gap:1rem;display:grid}.react-game-host .game-body,.react-game-host>*{max-width:100%}.react-game-host button,.react-game-host input,.react-game-host select{font:inherit}.game-error{color:#dc2626;background:#ef44441f;border-radius:1rem;padding:1rem;font-weight:700}.db-card{border:1px solid var(--border,#94a3b840);background:var(--bg-soft,#fff9);border-radius:14px;gap:.55rem;margin-top:.75rem;padding:14px 16px;display:grid}.db-card-title{font-size:1.02rem}.db-kicker{letter-spacing:.08em;text-transform:uppercase;color:#6366f1;font-size:.72rem;font-weight:800}.db-mono{white-space:pre-wrap;background:#6366f112;border-radius:8px;padding:.55rem .7rem;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.92rem}.db-list{margin:.25rem 0 0 .25rem;padding-left:1.1rem}.db-list li{margin:.15rem 0}.db-choices{gap:.55rem;margin-top:.35rem;display:grid}.db-choices.row{grid-auto-columns:minmax(80px,1fr);grid-auto-flow:column}.db-choice{text-align:left;border:1px solid var(--border,#94a3b84d);background:var(--bg,#fff);color:inherit;cursor:pointer;border-radius:12px;padding:.7rem .85rem;transition:transform .12s,border-color .12s,background .12s}.db-choice:hover:not(:disabled){border-color:#6366f1;transform:translateY(-1px)}.db-choice.pill{text-align:center;border-radius:999px;font-weight:800}.db-choice pre{white-space:pre-wrap;margin:0;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.82rem}.db-choice:disabled{cursor:default;opacity:.9}.db-choice.ok{background:#22c55e2e;border-color:#22c55e}.db-choice.bad{background:#ef44442e;border-color:#ef4444}.db-feedback{background:#6366f114;border-radius:10px;min-height:1.6rem;padding:.55rem .7rem;font-size:.92rem}.db-feedback.ok{color:#15803d;background:#22c55e26}.db-feedback.bad{color:#b91c1c;background:#ef444426}.db-badge{color:#4338ca;background:#6366f124;border-radius:999px;align-items:center;padding:.25rem .65rem;font-size:.82rem;font-weight:700;display:inline-flex}.db-badge.good{color:#15803d;background:#22c55e2e}.db-table{border-collapse:collapse;width:100%;font-size:.9rem}.db-table th,.db-table td{text-align:left;border-bottom:1px solid var(--border-soft,#94a3b82e);padding:.45rem .55rem}.db-table tr.best td{background:#22c55e1f;font-weight:700}.db-2pc-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem;margin-top:.75rem;display:grid}.sw-grid{margin:1rem 0 0 2.5rem;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.82rem;position:relative;overflow-x:auto}.sw-cell{border-radius:6px;justify-content:center;align-items:center;font-size:.85rem;transition:transform .12s;display:flex;position:absolute}.sw-cell:hover{transform:scale(1.08)}.sw-cell.sw-send{color:#0369a1;background:#0ea5e933;border:1px solid #0ea5e980}.sw-cell.sw-send.sw-lost{color:#b91c1c;background:#ef44442e;border-color:#ef4444}.sw-cell.sw-ack{color:#15803d;background:#22c55e33;border:1px solid #22c55e80;font-weight:700}.sw-cell.sw-timeout{color:#b45309;background:#f59e0b38;border:1px solid #f59e0b}.sw-row-label,.sw-col-label{color:var(--text-muted,#64748b);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.78rem;position:absolute}
