.auth-page{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b);display:flex;align-items:center;justify-content:center;padding:20px}.auth-container{width:100%;max-width:400px}.auth-brand{text-align:center;margin-bottom:40px}.brand-text{display:block;font-size:2.5rem;font-weight:900;background:linear-gradient(to right,#fbbf24,#f59e0b);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:8px}.brand-slogan{display:block;font-size:1rem;color:#64748b;font-weight:500}.auth-card{background:#1e293bcc;border-radius:24px;padding:35px;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 20px 60px #0006}.auth-tabs{display:flex;gap:10px;margin-bottom:30px}.auth-tab{flex:1;padding:12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.05);color:#64748b;border-radius:12px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s}.auth-tab.active{background:#fbbf2426;border-color:#fbbf244d;color:#fbbf24}.auth-form{display:flex;flex-direction:column;gap:20px}.input-group{display:flex;flex-direction:column;gap:8px}.input-group label{font-size:.9rem;color:#94a3b8;font-weight:500}.input-group input{padding:14px 16px;background:#0f172a99;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#f8fafc;font-size:1rem;transition:all .2s}.input-group input::placeholder{color:#475569}.input-group input:focus{outline:none;border-color:#fbbf24;box-shadow:0 0 0 3px #fbbf241a}.auth-error{color:#f87171;font-size:.9rem;padding:12px;background:#ef44441a;border-radius:10px;border:1px solid rgba(239,68,68,.2)}.auth-submit{padding:16px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border:none;border-radius:14px;color:#78350f;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s;margin-top:10px}.auth-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #fbbf244d}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-footer{text-align:center;margin-top:25px;color:#64748b;font-size:.9rem}.auth-footer button{background:none;border:none;color:#fbbf24;cursor:pointer;font-size:.9rem;font-weight:600;margin-left:5px}.auth-footer button:hover{text-decoration:underline}.profile-page{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b);padding:20px;color:#f8fafc}.profile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.profile-header span{font-size:1.2rem;font-weight:700}.logout-btn{background:#ef444433;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:8px 16px;border-radius:10px;cursor:pointer;font-size:.9rem;transition:all .2s}.logout-btn:hover{background:#ef44444d}.profile-page .user-card{display:flex;flex-direction:column;gap:14px;background:linear-gradient(135deg,#1e293bbf,#0f172ad9);padding:22px;border-radius:22px;border:1px solid rgba(255,255,255,.1);margin-bottom:25px;box-shadow:0 18px 50px #00000059;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.streak-card{display:flex;align-items:center;justify-content:space-between;gap:14px;background:#1e293b73;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:14px 16px;margin-bottom:16px;position:relative;overflow:hidden;isolation:isolate}.streak-card:before{content:"";position:absolute;inset:-2px;border-radius:20px;background:radial-gradient(circle at 20% 15%,rgba(59,130,246,.25),transparent 45%),radial-gradient(circle at 85% 70%,rgba(99,102,241,.18),transparent 55%);opacity:.55;filter:blur(10px);z-index:-2}.streak-card:after{content:"";position:absolute;inset:0;border-radius:18px;background:linear-gradient(120deg,rgba(255,255,255,.06),transparent 35%,rgba(255,255,255,.03));opacity:.6;z-index:-1}.streak-left{min-width:0}.streak-title{font-size:.8rem;font-weight:900;color:#94a3b8f2}.streak-value{margin-top:6px;font-weight:1000;font-size:1.35rem;color:#f8fafcfa;letter-spacing:.2px}.streak-sub{margin-top:6px;font-size:.8rem;color:#e2e8f0b8}.streak-btn{flex:0 0 auto;padding:10px 14px;border-radius:14px;border:1px solid rgba(96,165,250,.26);background:#3b82f629;color:#e2e8f0eb;font-weight:1000;cursor:pointer;transition:transform .18s ease,background .18s ease,border-color .18s ease}.streak-btn:hover{transform:translateY(-1px);background:#3b82f638;border-color:#60a5fa5c}.streak-btn:active{transform:translateY(0)}.streak-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.streak-btn.done{border-color:#22c55e47;background:#22c55e24}.streak-tier-badge{flex:0 0 auto;padding:8px 10px;border-radius:999px;border:1px solid rgba(148,163,184,.22);background:#02061759;color:#e2e8f0db;font-weight:950;font-size:.75rem;letter-spacing:.02em;white-space:nowrap;text-shadow:0 1px 0 rgba(0,0,0,.35)}@keyframes streakPulseBlue{0%,to{transform:translateZ(0) scale(1);filter:blur(10px);opacity:.45}50%{transform:translateZ(0) scale(1.015);filter:blur(12px);opacity:.75}}@keyframes streakShimmerViolet{0%{transform:translate(-25%);opacity:0}20%{opacity:.7}to{transform:translate(140%);opacity:0}}@keyframes streakSparkleGold{0%{transform:translateY(0) translate(0) scale(.9);opacity:0}15%{opacity:.8}to{transform:translateY(-18px) translate(12px) scale(1.15);opacity:0}}@keyframes streakAurora{0%{transform:rotate(0) scale(1);opacity:.45}50%{transform:rotate(12deg) scale(1.05);opacity:.75}to{transform:rotate(0) scale(1);opacity:.45}}.streak-card.tier-0{border-color:#94a3b824}.streak-card.tier-1:before{background:radial-gradient(circle at 15% 20%,rgba(56,189,248,.28),transparent 48%),radial-gradient(circle at 85% 70%,rgba(59,130,246,.2),transparent 58%);animation:streakPulseBlue 2.8s ease-in-out infinite}.streak-tier-badge.tier-1{border-color:#38bdf847;background:#38bdf81a;color:#bae6fdf2}.streak-card.tier-2{border-color:#818cf838}.streak-card.tier-2:before{background:radial-gradient(circle at 22% 20%,rgba(129,140,248,.26),transparent 48%),radial-gradient(circle at 88% 70%,rgba(244,114,182,.16),transparent 58%);animation:streakPulseBlue 2.6s ease-in-out infinite}.streak-card.tier-2:after{background:linear-gradient(110deg,transparent 0%,rgba(129,140,248,.14) 35%,transparent 70%);width:55%;left:-55%;right:auto;animation:streakShimmerViolet 2.9s ease-in-out infinite}.streak-tier-badge.tier-2{border-color:#818cf847;background:#6366f11f;color:#e0e7fff2}.streak-card.tier-3{border-color:#fbbf2442}.streak-card.tier-3:before{background:radial-gradient(circle at 18% 18%,rgba(251,191,36,.22),transparent 50%),radial-gradient(circle at 86% 72%,rgba(34,197,94,.12),transparent 58%),radial-gradient(circle at 60% 40%,rgba(59,130,246,.12),transparent 58%);animation:streakPulseBlue 2.4s ease-in-out infinite}.streak-card.tier-3.unchecked .streak-btn:not(.done){border-color:#fbbf244d;background:#fbbf2424}.streak-card.tier-3:after{background:radial-gradient(circle at 20% 70%,rgba(251,191,36,.22),transparent 48%),radial-gradient(circle at 65% 25%,rgba(251,191,36,.16),transparent 52%),radial-gradient(circle at 85% 60%,rgba(251,191,36,.18),transparent 52%);opacity:.35}.streak-card.tier-3 .streak-left:after,.streak-card.tier-4 .streak-left:after{content:"";position:absolute;width:6px;height:6px;border-radius:50%;background:#fbbf24d9;box-shadow:0 0 0 6px #fbbf241f,0 0 18px #fbbf248c;top:18px;right:26%;pointer-events:none;animation:streakSparkleGold 2.2s ease-in-out infinite}.streak-tier-badge.tier-3{border-color:#fbbf2452;background:#fbbf241f;color:#fef3c7f2}.streak-card.tier-4{border-color:#facc154d}.streak-card.tier-4:before{background:radial-gradient(circle at 18% 18%,rgba(34,211,238,.18),transparent 54%),radial-gradient(circle at 86% 72%,rgba(244,114,182,.16),transparent 56%),radial-gradient(circle at 55% 40%,rgba(250,204,21,.18),transparent 60%);animation:streakAurora 3.2s ease-in-out infinite}.streak-card.tier-4:after{background:linear-gradient(90deg,#facc152e,#22d3ee29,#f472b624,#facc152e);opacity:.22;filter:blur(1px)}.streak-tier-badge.tier-4{border-color:#facc155c;background:linear-gradient(135deg,#facc1529,#22d3ee1a);color:#fef3c7fa}.streak-card.tier-4 .streak-value{background:linear-gradient(180deg,#fffffffa,#fef3c7eb 35%,#a5f3fcd1);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}@media(prefers-reduced-motion:reduce){.streak-card:before,.streak-card:after,.streak-card .streak-left:after{animation:none!important}}.profile-page .user-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;width:100%}.profile-page .user-card-main{min-width:0;display:flex;flex-direction:column;gap:10px}.profile-page .user-card-actions{display:flex;flex-direction:column;align-items:flex-end;gap:10px;flex:0 0 auto}.profile-page .user-card-actions-top{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.user-card-leaderboards-btn{padding:10px 12px;border-radius:14px;background:#3b82f61f;border:1px solid rgba(96,165,250,.22);color:#e2e8f0;display:flex;align-items:center;justify-content:flex-end;gap:8px;cursor:pointer;transition:transform .18s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease;font-weight:900}.user-card-leaderboards-btn:hover{transform:translateY(-2px);background:#3b82f629;border-color:#60a5fa57;box-shadow:0 10px 24px #00000059}.user-card-leaderboards-btn:active{transform:translateY(0)}.user-card-leaderboards-icon{font-size:1.05rem;line-height:1}.user-card-leaderboards-label{font-size:.9rem}.user-card-portrait-btn{padding:10px 12px;border-radius:14px;background:#fbbf241a;border:1px solid rgba(251,191,36,.22);color:#e2e8f0;display:flex;align-items:center;justify-content:flex-end;gap:8px;cursor:pointer;transition:transform .18s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease;font-weight:900}.user-card-portrait-btn:hover{transform:translateY(-2px);background:#fbbf2424;border-color:#fbbf2457;box-shadow:0 10px 24px #00000059}.user-card-portrait-btn:active{transform:translateY(0)}.user-card-portrait-icon{font-size:1.05rem;line-height:1}.user-card-portrait-label{font-size:.9rem}.user-card-subscribe{padding:10px 12px;border-radius:14px;border:1px solid rgba(251,191,36,.25);background:#fbbf241a;color:#fbbf24;font-weight:900;cursor:pointer;display:inline-flex;align-items:center;gap:10px;transition:transform .18s ease,background .18s ease,border-color .18s ease}.user-card-subscribe-label{color:#f8fafceb;font-weight:1000;font-size:.9rem}.user-card-subscribe-price{font-family:Courier New,monospace;font-weight:1000;font-size:.95rem;color:#fbbf24;padding:4px 8px;border-radius:999px;border:1px solid rgba(251,191,36,.26);background:#0f172a38;line-height:1}.user-card-subscribe-price.promo{border-color:#22c55e38;color:#4ade80f2;background:#22c55e1a}.user-card-subscribe:hover{transform:translateY(-2px);background:#fbbf2424;border-color:#fbbf2459}.user-card-subscribe:active{transform:translateY(0)}.system-notice-modal .notice-content .subscribe-price-card,.system-notice-modal .notice-content .subscribe-tip-card,.system-notice-modal .notice-content .subscribe-wechat-card{border-radius:14px;padding:14px;border:1px solid rgba(255,255,255,.06);background:#02061738}.system-notice-modal .notice-content .subscribe-price-card{margin-bottom:12px}.system-notice-modal .notice-content .subscribe-tip-card{margin-bottom:12px;border-color:#818cf82e;background:#818cf814}.subscribe-tip-line{margin:0!important;font-size:.86rem;color:#e2e8f0eb!important;font-weight:900;line-height:1.45}.subscribe-price-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.subscribe-price-label{font-size:.85rem;font-weight:900;color:#e2e8f0cc}.subscribe-price-value{font-family:Courier New,monospace;font-size:1.35rem;font-weight:1000;color:#fbbf24;display:inline-flex;align-items:center;gap:8px}.subscribe-price-badge{font-size:.72rem;font-weight:1000;padding:4px 8px;border-radius:999px;border:1px solid rgba(34,197,94,.25);background:#22c55e1f;color:#4ade80f2}.subscribe-price-sub{margin-top:10px;font-size:.82rem;color:#cbd5e1d6;line-height:1.4}.subscribe-wechat-line{margin:0 0 10px!important;font-size:.9rem;color:#e2e8f0eb!important;font-weight:900}.subscribe-wechat-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.subscribe-wechat-id{flex:1 1 auto;min-width:0;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#0f172a59;color:#f8fafcf0;font-family:Courier New,monospace;font-weight:1000;cursor:pointer;transition:transform .15s ease,border-color .15s ease,background .15s ease}.subscribe-wechat-id:hover{background:#0f172a73;border-color:#fbbf2438;transform:translateY(-1px)}.subscribe-wechat-copy{flex:0 0 auto;padding:10px 12px;border-radius:12px;border:1px solid rgba(96,165,250,.26);background:#3b82f624;color:#e2e8f0eb;font-weight:1000;cursor:pointer;transition:transform .15s ease,border-color .15s ease,background .15s ease}.subscribe-wechat-copy:hover{transform:translateY(-1px);background:#3b82f62e;border-color:#60a5fa61}.user-nickname{font-size:1.5rem;font-weight:700;margin:0}.user-level{display:flex;align-items:center;gap:12px;margin-top:5px}.user-membership{display:flex;align-items:center;gap:10px;margin-top:10px;flex-wrap:wrap}.membership-badge{padding:2px 10px;border-radius:999px;background:#3b82f626;border:1px solid rgba(59,130,246,.35);color:#bfdbfe;font-size:.8rem;font-weight:800}.membership-expire{font-size:.8rem;color:#cbd5f5;background:#0f172a59;border:1px solid rgba(255,255,255,.08);padding:2px 8px;border-radius:8px}.membership-expire.expired{color:#fca5a5;background:#ef444426;border-color:#ef444440}.level-badge{padding:2px 10px;border:1px solid currentColor;background:#ffffff0d;border-radius:6px;font-size:.85rem;font-weight:800;text-shadow:0 0 10px currentColor}.level-exp{font-size:.8rem;color:#94a3b8;background:#0f172a66;padding:2px 8px;border-radius:4px;letter-spacing:1px;font-family:Courier New,monospace}.stats-board{background:#1e293b73;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:16px;margin-bottom:25px}.stats-board-head{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.stats-board-sub{font-size:.85rem;color:#e2e8f0c7}.stats-panel{display:grid;gap:12px}.stats-grade-pill{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:16px;background:#0f172a66;border:1px solid rgba(255,255,255,.08)}.stats-grade-badge{width:32px;height:32px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;font-weight:1000;color:#0b1220;background:#fbbf24f2}.stats-grade-text{font-weight:900;color:#e2e8f0eb;font-size:.9rem}.stats-kpis{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.stats-kpi{background:#0f172a73;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:10px 12px;min-height:74px}.stats-kpi-label{font-size:.8rem;color:#94a3b8}.stats-kpi-value{margin-top:6px;font-size:1.35rem;font-weight:900;color:#f8fafc}.stats-kpi-sub{margin-top:4px;font-size:.78rem;color:#e2e8f0bf}.stats-modules-compact{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.stats-module-compact{background:#0f172a73;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:12px}.stats-module-compact.locked{opacity:.55}.stats-module-compact.last{grid-column:1 / -1}.stats-module-compact-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.stats-module-compact-name{display:flex;align-items:center;gap:8px;min-width:0;font-weight:900;color:#f8fafcf2}.stats-module-compact-name span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stats-module-compact-icon{width:30px;height:30px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:#1e293ba6;border:1px solid rgba(255,255,255,.06);flex:0 0 auto}.stats-module-compact-score{font-family:Courier New,monospace;font-weight:1000;font-size:.95rem;flex:0 0 auto}.stats-module-compact-sub{margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:10px;font-weight:900;font-size:.8rem;color:#e2e8f0cc;font-family:Courier New,monospace}.stats-advice-compact{background:linear-gradient(135deg,#60a5fa1f,#0f172a59);border:1px solid rgba(96,165,250,.18);border-radius:16px;padding:12px}.stats-advice-compact-title{font-weight:1000;color:#bfdbfe;margin-bottom:10px}.stats-advice-compact-body{display:grid;gap:8px}.stats-advice-compact-focus{background:#0f172a59;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:10px 12px;color:#e2e8f0eb;font-weight:900;line-height:1.35}.stats-portrait-cta{margin-top:12px;width:100%;background:#3b82f62e;border:1px solid rgba(96,165,250,.24);color:#e2e8f0;padding:10px 12px;border-radius:14px;font-weight:900;cursor:pointer;transition:transform .18s ease,background .18s ease,border-color .18s ease}.stats-portrait-cta:hover{transform:translateY(-1px);background:#3b82f638;border-color:#60a5fa57}.stats-portrait-cta:active{transform:translateY(0)}.stats-modules{margin-top:14px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.stats-module{background:#0f172a73;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:14px}.stats-module.locked{opacity:.6}.stats-module-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.stats-module-name{display:flex;align-items:center;gap:8px;font-weight:900;color:#f8fafc;min-width:0}.stats-module-name span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stats-module-icon{width:32px;height:32px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:#1e293ba6;border:1px solid rgba(255,255,255,.06)}.stats-module-badge{flex:0 0 auto;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#1e293b8c;font-weight:900;font-family:Courier New,monospace}.stats-module-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 0;border-top:1px solid rgba(255,255,255,.04)}.stats-module-row:first-of-type{border-top:none}.stats-module-k{color:#94a3b8f2;font-size:.8rem}.stats-module-v{font-weight:800;color:#e2e8f0eb;font-size:.85rem}.stats-guidance{margin-top:14px;background:linear-gradient(135deg,#60a5fa1f,#0f172a73);border:1px solid rgba(96,165,250,.18);border-radius:16px;padding:14px}.stats-guidance-title{font-weight:900;color:#bfdbfe;margin-bottom:10px}.stats-guidance-body{display:grid;gap:8px}.stats-guidance-item{background:#0f172a59;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:10px 12px;color:#e2e8f0eb;font-weight:700;line-height:1.35}.stats-guidance-btn{margin-top:12px;width:100%;background:#3b82f62e;border:1px solid rgba(96,165,250,.24);color:#e2e8f0;padding:10px 12px;border-radius:14px;font-weight:900;cursor:pointer;transition:transform .18s ease,background .18s ease,border-color .18s ease}.stats-guidance-btn:hover{transform:translateY(-1px);background:#3b82f638;border-color:#60a5fa57}.stats-guidance-btn:active{transform:translateY(0)}.portrait-summary-card{display:flex;gap:14px;align-items:center;background:linear-gradient(135deg,#1e293b99,#0f172ac7);border:1px solid rgba(255,255,255,.08);border-radius:22px;padding:16px;margin-bottom:16px}.portrait-summary-left{flex:0 0 auto}.portrait-summary-right{min-width:0;display:flex;flex-direction:column;gap:10px}.portrait-summary-title{font-weight:1000;letter-spacing:.2px;font-size:1.05rem;color:#f8fafcfa}.portrait-summary-sub{font-size:.82rem;color:#e2e8f0bd}.portrait-summary-tags{display:flex;flex-wrap:wrap;gap:8px}.portrait-tag{background:#0f172a6b;border:1px solid rgba(255,255,255,.08);color:#e2e8f0eb;padding:6px 10px;border-radius:999px;font-weight:900;font-size:.78rem}.portrait-ring{width:74px;height:74px;border-radius:999px;display:grid;place-items:center;background:conic-gradient(from 210deg,#3b82f6f2 calc(var(--p) * 1%),#94a3b829 0);border:1px solid rgba(255,255,255,.1);box-shadow:0 18px 44px #00000059}.portrait-ring.grade-A{background:conic-gradient(from 210deg,#22c55ef2 calc(var(--p) * 1%),#94a3b829 0)}.portrait-ring.grade-B{background:conic-gradient(from 210deg,#3b82f6f2 calc(var(--p) * 1%),#94a3b829 0)}.portrait-ring.grade-C{background:conic-gradient(from 210deg,#f59e0bf2 calc(var(--p) * 1%),#94a3b829 0)}.portrait-ring.grade-D{background:conic-gradient(from 210deg,#ef4444f2 calc(var(--p) * 1%),#94a3b829 0)}.portrait-ring-core{width:58px;height:58px;border-radius:999px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:#0f172ad1;border:1px solid rgba(255,255,255,.1)}.portrait-ring-score{font-weight:1000;color:#f8fafcfa;font-size:1.15rem;line-height:1}.portrait-ring-grade{font-weight:1000;color:#e2e8f0b8;font-size:.78rem;line-height:1}.portrait-dims{display:grid;gap:12px}.portrait-dim{background:#0f172a61;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:12px}.portrait-dim-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.portrait-dim-label{font-weight:1000;color:#f8fafcf2}.portrait-dim-value{font-family:Courier New,monospace;font-weight:1000;color:#e2e8f0d1}.portrait-dim-bar{margin-top:10px;height:10px;border-radius:999px;overflow:hidden;background:#94a3b81f;border:1px solid rgba(255,255,255,.05)}.portrait-dim-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#3b82f6eb,#3b82f62e)}.portrait-dim-sub{margin-top:8px;font-size:.8rem;color:#e2e8f0b3;line-height:1.35}.portrait-radar{display:flex;flex-direction:column;gap:14px}.portrait-radar-visual{display:flex;justify-content:center;align-items:center}.portrait-radar-svg{width:clamp(190px,52vw,260px);height:clamp(190px,52vw,260px);background:#0f172a59;border:1px solid rgba(255,255,255,.06);border-radius:20px;padding:10px;box-shadow:0 18px 44px #00000047}.portrait-radar-ring{fill:none;stroke:#94a3b829;stroke-width:1}.portrait-radar-axis{stroke:#94a3b82e;stroke-width:1}.portrait-radar-area{fill:#3b82f62e;stroke:#60a5faa6;stroke-width:1.5}.portrait-radar-legend{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 12px;min-width:0}.portrait-radar-item{display:flex;align-items:center;gap:10px;min-width:0;padding:10px 12px;border-radius:14px;background:#0f172a57;border:1px solid rgba(255,255,255,.06)}.portrait-radar-dot{width:10px;height:10px;border-radius:999px;flex:0 0 auto}.portrait-radar-name{font-weight:900;font-size:.86rem;color:#e2e8f0e6;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(min-width:720px){.portrait-radar-legend{grid-template-columns:repeat(3,minmax(0,1fr))}}.portrait-module-table{display:grid;gap:10px}.portrait-module-row{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#0f172a61;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:12px}.portrait-module-row.locked{opacity:.6}.portrait-module-left{display:flex;align-items:center;gap:10px;min-width:0}.portrait-module-text{min-width:0}.portrait-module-name{font-weight:1000;color:#f8fafcf2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portrait-module-sub{margin-top:4px;font-size:.78rem;color:#e2e8f0b3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portrait-module-right{display:flex;align-items:center;gap:10px;flex:0 0 auto}.portrait-mini-bar{width:92px;height:10px;border-radius:999px;overflow:hidden;background:#94a3b81f;border:1px solid rgba(255,255,255,.05)}.portrait-mini-fill{height:100%;border-radius:999px}.portrait-mini-score{font-family:Courier New,monospace;font-weight:1000;width:36px;text-align:right}.portrait-trend{display:grid;gap:10px}.portrait-trend-svg{width:100%;background:#0f172a59;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:8px 10px}.portrait-trend-line{fill:none;stroke:#60a5fae6;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.portrait-trend-meta{display:grid;gap:4px}.portrait-trend-main{font-weight:1000;color:#e2e8f0eb}.portrait-trend-sub{font-size:.8rem;color:#e2e8f0b3}.portrait-empty{background:#0f172a59;border:1px dashed rgba(255,255,255,.14);border-radius:16px;padding:12px;color:#e2e8f0c7;font-weight:800}.portrait-mistakes{display:grid;gap:10px}.portrait-mistake{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#0f172a61;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:12px}.portrait-mistake-left{display:flex;align-items:center;gap:10px;min-width:0}.portrait-mistake-no{width:28px;height:28px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:#1e293ba6;border:1px solid rgba(255,255,255,.06);color:#e2e8f0e6;font-weight:1000;font-family:Courier New,monospace;flex:0 0 auto}.portrait-mistake-text{min-width:0}.portrait-mistake-title{font-weight:1000;color:#f8fafcf2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portrait-mistake-sub{margin-top:4px;font-size:.78rem;color:#e2e8f0b3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portrait-mistake-right{font-family:Courier New,monospace;font-weight:1000;color:#e2e8f0bf;flex:0 0 auto}.portrait-insights{display:grid;gap:10px}.portrait-insight{background:#0f172a61;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:12px}.portrait-insight-k{font-size:.78rem;color:#94a3b8f2;font-weight:900}.portrait-insight-v{margin-top:6px;font-size:1.05rem;font-weight:1000;color:#f8fafcf5}.portrait-insight-sub{margin-top:6px;font-size:.8rem;color:#e2e8f0b8}.portrait-plan{display:grid;gap:10px}.portrait-plan-item{background:#0f172a61;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:12px;font-weight:900;color:#e2e8f0eb;line-height:1.45}.portrait-hero{background:linear-gradient(135deg,#1e293b8c,#0f172ab8);border:1px solid rgba(255,255,255,.08);border-radius:22px;padding:18px;margin-bottom:16px}.portrait-grade{display:flex;align-items:center;gap:14px}.portrait-grade-letter{width:62px;height:62px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:2.2rem;font-weight:1000;color:#0b1220;background:#fbbf24;box-shadow:0 14px 36px #00000059}.portrait-grade-letter.grade-A{background:linear-gradient(135deg,#34d399,#22c55e)}.portrait-grade-letter.grade-B{background:linear-gradient(135deg,#60a5fa,#3b82f6)}.portrait-grade-letter.grade-C{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.portrait-grade-letter.grade-D{background:linear-gradient(135deg,#fb7185,#ef4444)}.portrait-grade-meta{min-width:0}.portrait-grade-title{font-size:.85rem;color:#e2e8f0c7;font-weight:800}.portrait-grade-score{margin-top:4px;font-size:1.6rem;font-weight:1000;letter-spacing:.2px}.portrait-grade-sub{margin-top:6px;font-size:.78rem;color:#94a3b8eb;line-height:1.35}.portrait-badges{margin-top:14px;display:flex;flex-wrap:wrap;gap:8px}.portrait-badge{background:#0f172a66;border:1px solid rgba(255,255,255,.08);color:#e2e8f0eb;padding:6px 10px;border-radius:999px;font-weight:800;font-size:.8rem}.portrait-kpis{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:16px}.portrait-kpi{background:#1e293b73;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:14px}.portrait-kpi-label{font-size:.78rem;color:#94a3b8f2;font-weight:800}.portrait-kpi-value{margin-top:6px;font-size:1.35rem;font-weight:1000;color:#f8fafc}.portrait-kpi-sub{margin-top:6px;font-size:.8rem;color:#e2e8f0c7;line-height:1.35}.portrait-panel{background:#1e293b73;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:16px;margin-bottom:16px}.portrait-panel-title{font-weight:1000;color:#e2e8f0;margin-bottom:12px}.portrait-modules{display:grid;gap:12px}.portrait-module{background:#0f172a61;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:12px}.portrait-module-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.portrait-module-name{display:flex;align-items:center;gap:8px;font-weight:900;color:#f8fafc;min-width:0}.portrait-module-icon{width:30px;height:30px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:#1e293ba6;border:1px solid rgba(255,255,255,.06)}.portrait-module-score{font-weight:1000;font-family:Courier New,monospace}.portrait-bar{margin-top:10px;height:10px;border-radius:999px;background:#94a3b824;border:1px solid rgba(255,255,255,.05);overflow:hidden}.portrait-bar-fill{height:100%;border-radius:999px}.portrait-module-meta{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px;color:#e2e8f0c7;font-size:.8rem;font-weight:700}.portrait-findings{display:grid;gap:12px}.portrait-finding{background:#0f172a61;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:12px}.portrait-finding-title{font-size:.8rem;color:#94a3b8f2;font-weight:900}.portrait-finding-value{margin-top:6px;font-size:1.05rem;font-weight:1000;color:#f8fafc}.portrait-finding-sub{margin-top:6px;font-size:.8rem;color:#e2e8f0bf}.portrait-tips{display:grid;gap:10px}.portrait-tip{background:#0f172a61;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:12px;font-weight:800;color:#e2e8f0eb;line-height:1.45}.mode-progress-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:25px}.profile-metrics{background:#1e293b73;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:20px;margin-bottom:25px}.metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.metric-card{background:#0f172a73;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:12px;min-height:76px}.metric-label{font-size:.8rem;color:#94a3b8}.metric-value{margin-top:6px;font-size:1.35rem;font-weight:900;color:#f8fafc;letter-spacing:.2px}.metric-sub{margin-top:4px;font-size:.78rem;color:#e2e8f0bf}.teacher-compact{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#1e293b73;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:16px 18px;margin-bottom:25px}.teacher-compact-title{font-size:1rem;font-weight:800;color:#fbbf24}.teacher-compact-sub{margin-top:6px;font-size:.85rem;color:#e2e8f0d9}.teacher-compact-btn{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1f2937;border:none;border-radius:12px;padding:10px 14px;font-weight:800;cursor:pointer;white-space:nowrap}.teacher-compact-btn:hover{transform:translateY(-1px)}.teacher-compact-btn:active{transform:translateY(0)}@media(min-width:720px){.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.stats-board{padding:20px}.stats-kpis{grid-template-columns:repeat(4,minmax(0,1fr))}.stats-modules-compact{grid-template-columns:repeat(3,minmax(0,1fr))}.stats-module-compact.last{grid-column:auto}.stats-modules{grid-template-columns:repeat(3,minmax(0,1fr))}.portrait-kpis{grid-template-columns:repeat(4,minmax(0,1fr))}.portrait-modules{grid-template-columns:repeat(2,minmax(0,1fr))}.portrait-findings{grid-template-columns:repeat(3,minmax(0,1fr))}}.teacher-panel{background:#1e293b80;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:20px;margin-bottom:25px}.teacher-header{display:flex;flex-direction:column;gap:16px;margin-bottom:18px}.teacher-header h3{font-size:1.1rem;font-weight:700;margin:0}.teacher-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.teacher-stat-card{background:#0f172a80;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px;text-align:center}.teacher-stat-label{font-size:.8rem;color:#94a3b8}.teacher-stat-value{font-size:1.4rem;font-weight:800;color:#fbbf24;margin-top:6px}.teacher-form{background:#0f172a66;border-radius:14px;padding:16px;border:1px solid rgba(255,255,255,.06);margin-bottom:16px}.teacher-tip{font-size:.85rem;color:#e2e8f0e6;margin-bottom:10px;line-height:1.35}.teacher-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.teacher-form-item label{display:block;font-size:.8rem;color:#cbd5f5;margin-bottom:6px}.teacher-input{width:100%;background:#1e293bcc;border:1px solid rgba(148,163,184,.4);color:#f8fafc;padding:8px 10px;border-radius:8px;outline:none}.teacher-create-btn{grid-column:span 2;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1f2937;border:none;border-radius:10px;padding:10px 16px;font-weight:700;cursor:pointer;transition:transform .2s}.teacher-create-btn:disabled{opacity:.6;cursor:not-allowed}.teacher-create-btn:hover{transform:translateY(-1px)}.teacher-table{border-radius:12px;border:1px solid rgba(255,255,255,.06);overflow:hidden;background:#0f172a59}.teacher-table-header,.teacher-table-row{display:grid;grid-template-columns:1.2fr .8fr .7fr 1fr 1fr;gap:8px;padding:10px 12px;font-size:.85rem}.teacher-request-header,.teacher-request-row{grid-template-columns:repeat(6,minmax(0,1fr))}.teacher-table-header{background:#1e293bcc;font-weight:700;color:#e2e8f0}.teacher-table-row{border-top:1px solid rgba(255,255,255,.04);color:#cbd5f5}.teacher-code{font-family:Courier New,monospace;font-weight:700;color:#f8fafc}.teacher-empty{padding:16px;text-align:center;color:#94a3b8}.teacher-pagination{display:flex;align-items:center;justify-content:space-between;margin-top:12px}.teacher-page-info{font-size:.85rem;color:#94a3b8}.teacher-page-btns{display:flex;gap:8px}.teacher-page-btn{background:#1e293bb3;border:1px solid rgba(255,255,255,.1);color:#e2e8f0;padding:6px 12px;border-radius:8px;cursor:pointer}.teacher-page-btn:disabled{opacity:.5;cursor:not-allowed}.teacher-segment{display:flex;gap:8px;padding:6px;background:#0f172a59;border:1px solid rgba(255,255,255,.06);border-radius:14px;margin-bottom:14px}.teacher-seg-btn{flex:1;background:transparent;border:1px solid transparent;color:#e2e8f0d9;padding:10px 12px;border-radius:12px;font-weight:700;cursor:pointer}.teacher-seg-btn.active{background:#1e293bbf;border-color:#ffffff1a;color:#f8fafc}.teacher-section{margin-top:4px}.teacher-section-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin:14px 0 10px}.teacher-section-title{font-size:.95rem;font-weight:800;color:#e2e8f0}.teacher-section-sub{font-size:.82rem;color:#94a3b8;white-space:nowrap}.teacher-filter{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:6px 0}.teacher-pill{background:#1e293b8c;border:1px solid rgba(255,255,255,.1);color:#e2e8f0e6;padding:8px 10px;border-radius:999px;cursor:pointer;font-weight:700;font-size:.85rem}.teacher-pill.active{background:#fbbf2429;border-color:#fbbf2459;color:#fde68a}.teacher-invite-list,.teacher-request-list{display:grid;gap:10px}.teacher-invite-item,.teacher-request-item{background:#0f172a59;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:12px}.teacher-invite-top,.teacher-request-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.teacher-code-block{display:flex;align-items:center;gap:8px;min-width:0}.teacher-code-mono{font-family:Courier New,monospace;font-weight:800;color:#f8fafc;letter-spacing:.3px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.teacher-badge{display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.1);border-radius:999px;padding:4px 10px;font-size:.82rem;font-weight:800;white-space:nowrap}.teacher-invite-meta,.teacher-request-meta{margin-top:10px;display:grid;gap:6px;font-size:.84rem;color:#cbd5f5eb;line-height:1.35}.teacher-request-count{font-weight:800;color:#e2e8f0}.mode-card{background:#1e293b99;padding:16px;border-radius:16px;text-align:center;border:1px solid rgba(255,255,255,.05);position:relative;overflow:hidden}.mode-card.locked{opacity:.5;background:#1e293b4d}.mode-number{position:absolute;top:8px;left:12px;width:24px;height:24px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:800;color:#78350f}.mode-card.locked .mode-number{background:#64748b4d;color:#64748b}.mode-name{font-size:1rem;font-weight:700;color:#f8fafc;margin-bottom:8px;margin-top:10px}.mode-clears{font-size:.85rem;color:#94a3b8;margin-bottom:4px}.mode-time{font-size:1.2rem;font-weight:800;color:#fbbf24;font-family:Courier New,monospace}.mode-locked{font-size:.9rem;color:#64748b;margin-top:10px}.leaderboard-tabs{display:flex;justify-content:center;gap:6px;margin-bottom:20px;overflow-x:auto;padding:4px}.leaderboard-tab{flex:0 0 auto;min-width:70px;padding:8px 10px;background:#1e293b99;border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .3s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.leaderboard-tab:hover{background:#2d3748cc}.leaderboard-tab.active{background:#1e293be6;box-shadow:0 4px 15px #0000004d}.leaderboard-tab .tab-icon{font-size:1.1rem}.leaderboard-tab .tab-label{font-size:.7rem;font-weight:700}.leaderboard-section{background:#1e293b66;padding:25px;border-radius:20px;border:1px solid rgba(255,255,255,.05)}.section-title{font-size:1.1rem;font-weight:700;margin-bottom:20px;text-align:center}.personal-record{background:linear-gradient(135deg,#1e293bcc,#0f172acc);border:1px solid;border-radius:16px;padding:20px;text-align:center;margin-bottom:20px}.record-label{font-size:.85rem;color:#94a3b8;margin-bottom:8px}.record-time{font-size:2rem;font-weight:900;font-family:Courier New,monospace}.record-info{font-size:.85rem;color:#64748b;margin-top:8px}.leaderboard-list{display:flex;flex-direction:column;gap:10px}.leaderboard-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#1e293b99;border-radius:12px;border:1px solid rgba(255,255,255,.05);transition:all .2s}.leaderboard-item:hover{background:#2d3748b3}.rank-badge{width:36px;font-size:1.1rem;font-weight:700;text-align:center}.player-name{flex:1;font-size:.95rem;color:#f8fafc;font-weight:600}.player-time{font-size:1rem;font-weight:700;font-family:Courier New,monospace}.empty-state{text-align:center;padding:40px;color:#64748b}.empty-state .empty-icon{font-size:3rem;display:block;margin-bottom:15px;opacity:.5}.empty-state p{font-size:1rem}.loading-spinner{display:flex;align-items:center;justify-content:center;height:50vh;color:#94a3b8;font-size:1.1rem}@media(max-width:600px){.mode-progress-cards{grid-template-columns:repeat(2,1fr)}.portrait-summary-card{align-items:flex-start}.portrait-radar-legend{grid-template-columns:repeat(2,minmax(0,1fr))}.portrait-module-right{gap:8px}.portrait-mini-bar{width:74px}.user-card{padding:20px}.leaderboard-tabs{gap:6px}.leaderboard-tab{min-width:60px;padding:10px 6px}.leaderboard-tab .tab-icon{font-size:1.1rem}.leaderboard-tab .tab-label{font-size:.7rem}.record-time{font-size:1.6rem}.teacher-stats,.teacher-form-grid{grid-template-columns:1fr}.teacher-create-btn{grid-column:span 1}.teacher-table-header,.teacher-table-row,.teacher-request-header,.teacher-request-row{grid-template-columns:1fr}.teacher-panel{padding:14px}.teacher-stat-card{padding:10px}.teacher-stat-value{font-size:1.25rem}.teacher-seg-btn{padding:9px 10px}}.nickname-display-group{display:flex;align-items:center;gap:10px}.edit-nickname-btn{background:#ffffff1a;border:none;color:#94a3b8;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.8rem;transition:all .2s}.edit-nickname-btn:hover{background:#fbbf2433;color:#fbbf24}.nickname-edit-group{display:flex;flex-direction:column;gap:8px}.nickname-input{background:#0f172acc;border:1px solid #fbbf24;color:#fff;padding:6px 12px;border-radius:8px;font-size:1.1rem;font-weight:700;width:100%;outline:none}.edit-actions{display:flex;gap:8px}.save-btn,.cancel-btn{padding:4px 12px;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}.save-btn{background:#fbbf24;border:1px solid #fbbf24;color:#78350f}.cancel-btn{background:transparent;border:1px solid rgba(255,255,255,.2);color:#94a3b8}.save-btn:hover{background:#f59e0b}.cancel-btn:hover{background:#ffffff0d}.player-perfect-badge{font-size:.75rem;color:#10b981;background:#10b9811a;padding:2px 6px;border-radius:4px;border:1px solid rgba(16,185,129,.2);font-weight:700}.record-perfect{color:#10b981;font-weight:700}:root{--bg: #020617;--card: #1e293b;--card-hover: #334155;--accent: #818cf8;--success: #34d399;--danger: #f87171;--text-main: #f1f5f9;--text-muted: #cbd5e1}.app{background:var(--bg);min-height:100vh;color:var(--text-main);font-family:Inter,-apple-system,sans-serif;padding:20px 20px 100px}.menu-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.brand-header{margin-bottom:40px;display:flex;justify-content:space-between;align-items:center;width:100%;max-width:600px;padding:0 10px}.logo-wrapper{background:#ffffff08;padding:12px 24px;border-radius:16px;border:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.user-entry{display:flex;align-items:center}.login-btn{background:linear-gradient(135deg,#fbbf2426,#f59e0b1a);border:1px solid rgba(251,191,36,.3);color:#fbbf24;padding:12px 24px;border-radius:16px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .3s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-btn:hover{background:linear-gradient(135deg,#fbbf2440,#f59e0b33);border-color:#fbbf2480;transform:translateY(-2px);box-shadow:0 8px 20px #fbbf2426}.user-btn{display:flex;align-items:center;gap:10px;background:#1e293b99;border:1px solid rgba(255,255,255,.1);padding:8px 16px;border-radius:16px;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.user-btn:hover{background:#334155cc;border-color:#fbbf244d}.user-avatar-small{width:36px;height:36px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:800;color:#78350f}.user-name{color:#f8fafc;font-size:.9rem;font-weight:600;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logo-text{font-size:1.2rem;font-weight:900;letter-spacing:6px;color:#fff;opacity:.95;margin-right:-6px}.logo-line{width:100%;height:1px;background:linear-gradient(to right,transparent,rgba(255,255,255,.2),transparent);margin:6px 0}.logo-en{font-size:.5rem;font-weight:600;letter-spacing:2.5px;color:#64748b;text-transform:uppercase}.title-section{text-align:center;margin-bottom:40px}.hero-title{font-size:2.4rem;font-weight:950;line-height:1.1;margin-bottom:16px;background:linear-gradient(180deg,#fff,#a5b4fc);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-1.5px}.hero-title .accent{background:linear-gradient(135deg,#818cf8,#6366f1);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-style:italic;margin-right:4px}.badge-row{display:flex;justify-content:center;gap:10px;margin-bottom:24px}.premium-badge{background:linear-gradient(90deg,#f59e0b33,#fbbf241a);color:#fbbf24;padding:4px 14px;border-radius:100px;font-size:.7rem;font-weight:800;border:1px solid rgba(245,158,11,.2);letter-spacing:1px}.version-badge{background:#ffffff0d;color:#64748b;padding:4px 10px;border-radius:100px;font-size:.7rem;font-weight:700;border:1px solid rgba(255,255,255,.08)}.hero-subtitle{font-size:.85rem;color:#475569;font-weight:500;letter-spacing:2px;text-transform:uppercase}.mode-buttons{display:flex;flex-direction:column;gap:24px;width:100%;max-width:340px}.mode-btn{background:#1e293bb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:24px;text-align:left;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;display:flex;align-items:center;gap:20px}.mode-btn:hover{background:#2d3748cc;border-color:#818cf8;transform:translateY(-4px) scale(1.01);box-shadow:0 20px 40px -15px #0009}.btn-content{display:flex;flex-direction:column;gap:4px}.mode-btn .label{font-size:1.25rem;font-weight:800;background:linear-gradient(to right,#fff,#cbd5e1);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.mode-btn .desc{font-size:.85rem;color:#94a3b8;line-height:1.4}.step-badge{position:absolute;top:0;right:0;font-size:.65rem;font-weight:800;padding:6px 12px;background:#818cf833;border-bottom-left-radius:16px;color:#a5b4fc;border-left:1px solid rgba(129,140,248,.3);border-bottom:1px solid rgba(129,140,248,.3);letter-spacing:1px}.mode-btn:active{transform:scale(.98)}.mode-btn .icon{font-size:2.5rem;display:block;margin-bottom:15px;filter:drop-shadow(0 0 10px rgba(255,255,255,.2))}.mode-btn .label{font-size:1.4rem;font-weight:800;display:block;margin-bottom:8px;color:#fff;letter-spacing:.5px}.mode-btn .desc{font-size:.95rem;color:#94a3b8;font-weight:500}.mode-btn.locked{opacity:.45;cursor:not-allowed;filter:grayscale(50%)}.mode-btn.locked:hover{transform:none;box-shadow:none}.mode-btn.locked:after{content:"";position:absolute;inset:0;background:#0f172a80;border-radius:inherit}.mode-btn.def{border-left:4px solid #818cf8}.mode-btn.formula{border-left:4px solid #34d399}.mode-btn.module{border-left:4px solid #f59e0b}.mode-btn.law{border-left:4px solid #a78bfa}.mode-btn.def .icon{filter:drop-shadow(0 0 15px rgba(129,140,248,.4))}.mode-btn.formula .icon{filter:drop-shadow(0 0 15px rgba(52,211,153,.4))}.mode-btn.module .icon{filter:drop-shadow(0 0 15px rgba(245,158,11,.4))}.mode-btn.law .icon{filter:drop-shadow(0 0 15px rgba(167,139,250,.4))}.mode-btn.law .step-badge{background:#a78bfa33;color:#c4b5fd;border-color:#a78bfa4d}.mode-card-wrapper{display:flex;align-items:stretch;gap:8px;width:100%}.mode-card-wrapper .mode-btn{flex:1}.answer-peek-btn{width:44px;min-width:44px;background:#1e293bb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(251,191,36,.3);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;transition:all .3s;color:#fbbf24}.answer-peek-btn:hover{background:#fbbf2426;border-color:#fbbf2480;transform:translateY(-2px);box-shadow:0 8px 20px #fbbf2426}.answer-peek-btn:active{transform:scale(.95)}.answer-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .3s ease}.answer-modal{background:linear-gradient(135deg,#1e293bfa,#0f172afa);border:1px solid rgba(251,191,36,.3);border-radius:28px;width:100%;max-width:500px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 30px 60px #00000080;animation:slideUp .4s cubic-bezier(.22,1,.36,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.answer-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:#ffffff1a;border:none;color:#94a3b8;font-size:1rem;cursor:pointer;transition:all .2s;z-index:10}.answer-close:hover{background:#ef444433;color:#f87171}.answer-header{position:relative;padding:24px 24px 16px;text-align:center;border-bottom:1px solid rgba(255,255,255,.08)}.answer-icon{font-size:2.5rem;display:block;margin-bottom:12px}.answer-header h2{font-size:1.3rem;font-weight:800;background:linear-gradient(to right,#fbbf24,#f59e0b);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin:0 0 8px}.answer-tip{font-size:.85rem;color:#64748b;margin:0}.answer-list{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}.answer-group{background:#0003;border-radius:16px;padding:12px}.answer-group-title{font-size:1.1rem;font-weight:800;color:#818cf8;margin-bottom:8px;padding-left:4px}.answer-item{background:#1e293b99;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px 14px;transition:all .2s}.answer-item:hover{background:#2d3748cc;border-color:#818cf84d}.answer-item.mode1{display:flex;align-items:flex-start;gap:12px;margin-bottom:6px}.answer-word{font-size:1rem;font-weight:700;color:#fbbf24;white-space:nowrap;min-width:70px}.answer-def{font-size:.85rem;color:#94a3b8;line-height:1.4}.answer-item.mode2,.answer-item.mode3,.answer-item.mode4{display:flex;flex-direction:column;gap:8px}.answer-formula{font-family:"Latin Modern Math","STIX Two Math","Cambria Math",Times New Roman,serif;font-size:1.25rem;font-weight:700;color:#22d3ee}.answer-law-name{font-size:1rem;font-weight:700;color:#a78bfa}.answer-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.answer-hint{font-size:.8rem;color:#94a3b8}.answer-module,.answer-module-tag{font-size:.7rem;font-weight:700;padding:3px 10px;background:#818cf826;color:#a5b4fc;border-radius:20px;border:1px solid rgba(129,140,248,.2)}.answer-category{font-size:.7rem;font-weight:700;padding:3px 10px;background:#a88bfa26;color:#c4b5fd;border-radius:20px;border:1px solid rgba(168,139,250,.2)}.answer-start-btn{margin:16px;padding:16px 24px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border:none;border-radius:16px;font-size:1rem;font-weight:800;color:#78350f;cursor:pointer;transition:all .3s}.answer-start-btn:hover{transform:translateY(-2px);box-shadow:0 10px 25px #fbbf244d}.answer-start-btn:active{transform:scale(.98)}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;font-size:1rem;color:var(--text-muted);font-weight:500;gap:10px}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.05);gap:10px}.header-left{display:flex;align-items:center;gap:12px;flex:1}.speedrun-timer{background:#0f172a99;border:1px solid rgba(251,191,36,.2);color:#fbbf24;padding:4px 10px;border-radius:12px;font-size:.85rem;font-weight:800;font-family:Courier New,monospace;display:flex;align-items:center;gap:4px}.shadow-indicator{display:flex;align-items:center;background:#7c3aed1a;border:1px solid rgba(124,58,237,.3);padding:4px 10px;border-radius:12px;font-size:.75rem;color:#a78bfa;animation:pulse-border 2s infinite}@keyframes pulse-border{0%{border-color:#7c3aed4d}50%{border-color:#7c3aedcc}to{border-color:#7c3aed4d}}.shadow-tag{font-weight:900;font-size:.6rem;margin-right:6px;background:#7c3aed;color:#fff;padding:1px 4px;border-radius:3px}.shadow-ghost-action{max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.canvas-wrapper,.formula-canvas-wrapper{position:relative;width:100%}.ghost-canvas{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:inherit;font-size:1.5rem;font-weight:700;color:#a78bfa66;pointer-events:none;z-index:1;text-shadow:0 0 10px rgba(167,139,250,.2)}.race-track-container{margin-top:20px;padding:8px 15px;background:#0f172a4d;border-radius:12px}.race-track{height:3px;background:#ffffff0d;position:relative}.race-marker{position:absolute;top:50%;transform:translate(-50%,-50%);transition:left .5s ease}.race-marker .marker-label{position:absolute;top:-18px;left:50%;transform:translate(-50%);font-size:.6rem;font-weight:800}.race-marker:after{content:"";width:8px;height:8px;background:currentColor;border-radius:50%;display:block}.player{color:#fbbf24}.ghost{color:#a78bfa}.back-btn{background:#ffffff1a;color:var(--text-main);padding:8px 16px;border-radius:12px;font-weight:600;border:1px solid rgba(255,255,255,.1)}.back-btn:hover{background:#fff3}.letter-display{font-size:5rem;font-weight:900;text-align:center;background:linear-gradient(135deg,#818cf8,#c084fc);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:15px;filter:drop-shadow(0 4px 20px rgba(129,140,248,.4))}.hint{text-align:center;color:var(--text-muted);font-size:1rem;margin-bottom:30px;line-height:1.5;background:#ffffff0d;padding:10px 20px;border-radius:16px;display:inline-block;margin-left:auto;margin-right:auto;width:100%}.hint-revealed{background:linear-gradient(135deg,#6366f126,#c084fc26);border:1px solid rgba(129,140,248,.3);color:#a5b4fc;animation:fadeInHint .5s ease}@keyframes fadeInHint{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.formula-question{text-align:center;color:var(--text-muted);font-size:.95rem;margin-top:8px}.word-definition{background:linear-gradient(135deg,#34d3991a,#10b9811a);border:1px solid rgba(52,211,153,.3);border-radius:16px;padding:16px 20px;margin-bottom:20px;animation:fadeInDefinition .4s ease}.definition-text{color:#a7f3d0;font-size:.95rem;line-height:1.6;margin:0}@keyframes fadeInDefinition{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.found-words{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:30px}.word-slot{padding:12px 20px;border-radius:14px;font-weight:700;background:#1e293b99;color:#64748b;border:2px dashed rgba(255,255,255,.15);font-size:1.1rem;transition:all .3s ease}.word-slot.found{background:#34d39933;color:#34d399;border:2px solid #34d399;text-shadow:0 0 10px rgba(52,211,153,.3)}.toast{position:fixed;top:100px;left:50%;transform:translate(-50%);z-index:1000;min-width:300px;max-width:90%;text-align:center;padding:16px 24px;border-radius:16px;background:#1e293bf2;border:1px solid rgba(255,255,255,.1);font-weight:700;font-size:1.1rem;color:#fff;box-shadow:0 10px 40px #00000080;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:slideDownToast .3s ease}@keyframes slideDownToast{0%{opacity:0;transform:translate(-50%,-20px)}to{opacity:1;transform:translate(-50%)}}.toast.success{border-color:#34d39966;background:#064e3be6;color:#6ee7b7;box-shadow:0 10px 30px #10b98133}.toast.error{border-color:#f8717166;background:#7f1d1de6;color:#fca5a5;box-shadow:0 10px 30px #ef444433}.toast.warning{border-color:#fbbf2466;background:#78350fe6;color:#fcd34d;box-shadow:0 10px 30px #f59e0b33}.build-zone{background:#1e293b80;border-radius:24px;padding:24px;margin-bottom:24px;border:1px solid rgba(255,255,255,.05)}.canvas,.formula-canvas{min-height:70px;background:#0f172a99;border-radius:16px;display:flex;align-items:center;justify-content:center;padding:20px;margin-bottom:20px;font-family:"Latin Modern Math","STIX Two Math","Cambria Math",Times New Roman,serif;font-style:normal!important;text-rendering:optimizeLegibility;font-size:min(1.5rem,5vw);font-weight:700;color:#fbbf24;border:2px solid rgba(255,255,255,.1);box-shadow:inset 0 2px 10px #0000004d;word-wrap:break-word;overflow-wrap:break-word;text-align:center}.actions,.formula-actions{display:flex;flex-direction:column;gap:12px}.secondary-actions{display:flex;gap:12px;width:100%}.actions button,.formula-actions button{padding:12px;border-radius:16px;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid rgba(255,255,255,.1);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}.btn-undo,.btn-clear{flex:1;font-size:.85rem;padding:10px!important;background:#1e293b80;color:var(--text-muted)}.btn-undo:hover{background:#ffffff1a;color:#fff}.btn-clear{background:#ef44440d;color:#f87171b3;border-color:#ef44441a!important}.btn-clear:hover{background:#ef444426;color:#f87171}.submit{width:100%;padding:18px!important;font-size:1.1rem!important;background:linear-gradient(135deg,#6366f1,#818cf8);color:#fff!important;border:none!important;border-radius:20px!important;box-shadow:0 10px 25px -5px #6366f180;text-transform:uppercase;letter-spacing:1px}.submit:hover{transform:translateY(-2px);filter:brightness(1.1);box-shadow:0 15px 30px -5px #6366f199}.submit:active{transform:scale(.98)}.char-pool,.symbol-bank{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.char-btn,.sym-btn{min-width:56px;height:56px;padding:0 12px;background:#1e293bcc;border:1px solid rgba(255,255,255,.15);border-radius:16px;color:#fff;font-size:1.2rem;font-weight:700;box-shadow:0 4px 6px -1px #0003;transition:all .2s}.char-btn:active,.sym-btn:active{background:var(--accent);transform:scale(.95)}.formula-hint{text-align:center;margin-bottom:30px}.module-tag{display:inline-block;background:#818cf833;color:#a5b4fc;padding:6px 18px;border-radius:20px;font-size:.9rem;font-weight:700;margin-bottom:12px;border:1px solid rgba(129,140,248,.3)}.formula-hint p{color:var(--text-muted);font-size:1rem}.symbol-bank{margin-bottom:30px}.formula-display{font-family:"Latin Modern Math","STIX Two Math","Cambria Math",Times New Roman,serif;font-style:normal!important;text-rendering:optimizeLegibility;font-size:min(3.5rem,12vw);font-weight:950;text-align:center;background:linear-gradient(to right,#fbbf24,#f59e0b);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin:40px 0;filter:drop-shadow(0 0 15px rgba(245,158,11,.3));word-break:break-all;padding:0 10px;line-height:1.2}.module-question{text-align:center;color:var(--text-muted);margin-bottom:30px;font-size:1.1rem}.module-options{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-height:400px;overflow-y:auto;padding:5px}@media(max-width:520px){.module-options{grid-template-columns:1fr;gap:12px;max-height:none;padding:0}}.module-btn{padding:16px;background:#1e293b99;border:1px solid rgba(255,255,255,.1);border-radius:18px;color:#f1f5f9;text-align:left;display:flex;flex-direction:column;gap:6px;transition:all .2s;box-shadow:0 10px 24px #00000047}.module-btn:hover{background:#1e293be6;border-color:#818cf866;transform:translateY(-1px);box-shadow:0 14px 30px #00000061}.module-btn:active{background:var(--accent)}.module-btn:disabled{opacity:1;cursor:default}.m-name{font-weight:700;font-size:1rem;color:#fff}.m-desc{font-size:.75rem;color:#94a3b8}.strategy-map{margin-top:60px;padding:32px 24px;background:#1e293b4d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:32px;border:1px solid rgba(255,255,255,.05);width:100%;max-width:800px;animation:fadeIn 1s cubic-bezier(.22,1,.36,1);box-shadow:0 40px 100px -20px #00000080}.strategy-header{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:40px}.strategy-line{height:1px;flex:1;background:linear-gradient(to right,transparent,rgba(129,140,248,.3),transparent)}.strategy-title{font-size:1rem;color:#a5b4fc;text-align:center;font-weight:800;letter-spacing:4px;text-transform:uppercase;margin-bottom:0;white-space:nowrap}.map-steps{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:25px}.map-item{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center}.map-circle{width:40px;height:40px;background:#818cf81a;border:1px solid rgba(129,140,248,.3);color:#818cf8;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;margin-bottom:12px;font-size:1rem;box-shadow:0 0 20px #818cf81a}.map-item p{font-size:1rem;color:#f8fafc;font-weight:700;line-height:1.4}.map-item span{font-size:.75rem;color:#64748b;font-weight:400;display:block;margin-top:4px}.map-arrow{color:#818cf833;font-size:1.25rem;font-weight:900;margin-top:8px}.map-arrow.highlighted{color:#818cf8;text-shadow:0 0 10px rgba(129,140,248,.5)}.map-item.goal .map-circle{background:linear-gradient(135deg,#fbbf24,#f59e0b);border:none;color:#78350f;box-shadow:0 0 30px #fbbf2466}.map-goal{margin-top:15px;padding-top:20px;border-top:1px dashed rgba(255,255,255,.1)}.map-item.goal{flex-direction:row;justify-content:center;gap:25px;background:#fbbf240d;padding:24px;border-radius:20px;border:1px solid rgba(251,191,36,.1)}.goal-text{text-align:left}.map-item.goal p{color:#fbbf24;font-size:1.4rem;margin-bottom:4px}.map-item.goal span{font-size:1rem;color:#fbbf2499}.law-display{background:linear-gradient(135deg,#1e293bcc,#0f172ae6);padding:40px;border-radius:24px;border:1px solid rgba(255,255,255,.1);text-align:center;margin:30px 0;box-shadow:0 20px 50px #0006;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.law-content{font-family:"Latin Modern Math","STIX Two Math",serif;font-size:2.8rem;font-weight:800;background:linear-gradient(to right,#fbbf24,#f59e0b);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:25px;line-height:1.3}.law-meta{display:flex;justify-content:center;gap:15px}.category-badge{background:#3b82f626;color:#93c5fd;padding:6px 16px;border-radius:10px;font-size:1rem;border:1px solid rgba(59,130,246,.3);letter-spacing:1px}.level-b-badge{background:#f59e0b26;color:#fcd34d;padding:6px 16px;border-radius:10px;font-size:1rem;border:1px solid rgba(245,158,11,.4);font-weight:800;box-shadow:0 0 15px #f59e0b1a}.law-options{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:25px;padding:15px;background:#ffffff05;border-radius:20px;max-height:55vh;overflow-y:auto}@media(min-width:720px){.law-options{grid-template-columns:repeat(3,minmax(0,1fr))}}.law-btn{background:linear-gradient(145deg,#2d3748e6,#1e293bf2);border:1px solid rgba(255,255,255,.1);color:#f1f5f9;border-radius:16px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:.9rem;font-weight:700;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;line-height:1.2;padding:12px;height:84px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;box-shadow:0 4px 15px #0000004d}.law-btn:hover:not(:disabled){background:linear-gradient(145deg,#6366f166,#818cf84d);border-color:#818cf8;color:#fff;transform:translateY(-2px);box-shadow:0 8px 25px #818cf840;z-index:10}.law-btn:active:not(:disabled){transform:translateY(0)}.law-btn.correct{background:linear-gradient(145deg,#10b981e6,#064e3bf2);border-color:#34d399;color:#fff;box-shadow:0 0 25px #10b98166;transform:none}.law-btn:disabled{opacity:.5;cursor:not-allowed}.law-options::-webkit-scrollbar{width:6px}.law-options::-webkit-scrollbar-track{background:#ffffff08;border-radius:10px}.law-options::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:10px}.law-options::-webkit-scrollbar-thumb:hover{background:#fff3}@media(max-width:600px){.strategy-map{border-radius:24px;padding:24px 20px;margin-top:40px}.strategy-header{margin-bottom:25px}.map-steps{flex-direction:row;flex-wrap:nowrap;gap:10px}.map-item{padding:0;font-size:.8rem}.map-item p{font-size:.85rem}.map-item span{font-size:.65rem}.map-circle{width:32px;height:32px;margin-bottom:8px}.map-arrow{font-size:1rem}.map-item.goal{gap:15px;padding:16px}.map-item.goal p{font-size:1.1rem}}.completion-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;z-index:9999;padding:40px 20px;overflow-y:auto;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.completion-modal{background:linear-gradient(135deg,#1e293bf2,#0f172afa);border:1px solid rgba(251,191,36,.3);border-radius:24px;padding:40px 50px;text-align:center;max-width:340px;width:90%;box-shadow:0 25px 80px #00000080,0 0 60px #fbbf2426;animation:scaleIn .4s cubic-bezier(.175,.885,.32,1.275);margin:auto}@keyframes scaleIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.completion-icon{font-size:4rem;margin-bottom:15px;animation:bounce .6s ease infinite alternate}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-8px)}}.completion-title{font-size:1.8rem;font-weight:900;color:#fbbf24;margin-bottom:8px;letter-spacing:1px}.completion-mode{font-size:1.1rem;color:#94a3b8;margin-bottom:25px}.completion-stats{display:flex;justify-content:center;gap:30px;margin-bottom:25px}.completion-stats .stat-item{display:flex;flex-direction:column;align-items:center;gap:5px}.completion-stats .stat-label{font-size:.85rem;color:#64748b}.completion-stats .stat-value{font-size:1.6rem;font-weight:800;font-family:Courier New,monospace}.completion-stats .stat-value.time{color:#fbbf24}.completion-stats .stat-value.rank{color:#a5b4fc}.unlock-notice{background:linear-gradient(135deg,#4ade8026,#22c55e1a);border:1px solid rgba(74,222,128,.3);color:#4ade80;padding:12px 20px;border-radius:12px;margin-bottom:25px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px}.unlock-icon{font-size:1.2rem}.completion-btn{background:linear-gradient(135deg,#fbbf24,#f59e0b);border:none;color:#78350f;font-size:1.1rem;font-weight:800;padding:14px 40px;border-radius:14px;cursor:pointer;transition:all .2s;box-shadow:0 4px 20px #fbbf244d}.completion-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px #fbbf2466}.completion-btn:active{transform:translateY(0)}.completion-overlay.new-record{background:radial-gradient(ellipse at center,#fbbf2426,#000000e6 70%)}.confetti-container{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:9998}.confetti{position:absolute;top:-20px;width:10px;height:20px;opacity:.8;animation:confetti-fall 4s linear infinite;border-radius:2px}@keyframes confetti-fall{0%{transform:translateY(-20px) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.completion-modal.record-modal{border-color:#fbbf2499;box-shadow:0 25px 80px #00000080,0 0 80px #fbbf244d,0 0 120px #fbbf2426;animation:recordPulse 2s ease-in-out infinite,scaleIn .4s cubic-bezier(.175,.885,.32,1.275)}@keyframes recordPulse{0%,to{box-shadow:0 25px 80px #00000080,0 0 60px #fbbf2440,0 0 100px #fbbf241a}50%{box-shadow:0 25px 80px #00000080,0 0 100px #fbbf2466,0 0 150px #fbbf2433}}.record-glow{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at center,rgba(251,191,36,.15) 0%,transparent 50%);animation:glowRotate 8s linear infinite;pointer-events:none}@keyframes glowRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.completion-title.record-title{background:linear-gradient(90deg,#fbbf24,#f59e0b,#fcd34d,#f59e0b,#fbbf24);background-size:200% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer 2s linear infinite}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}.stat-value.record-time{animation:recordTimePulse 1s ease-in-out infinite;text-shadow:0 0 20px rgba(251,191,36,.5)}@keyframes recordTimePulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.stat-value.previous{color:#64748b;font-size:1.2rem;text-decoration:line-through;opacity:.7}.record-notice{background:linear-gradient(135deg,#fbbf2426,#f59e0b1a);border:1px solid rgba(251,191,36,.4);color:#fbbf24;padding:12px 20px;border-radius:12px;margin-bottom:20px;font-weight:700;font-size:.95rem;display:flex;align-items:center;justify-content:center;gap:10px;animation:noticeGlow 2s ease-in-out infinite}@keyframes noticeGlow{0%,to{box-shadow:0 0 10px #fbbf2433}50%{box-shadow:0 0 25px #fbbf2466}}.record-star{font-size:1.1rem;animation:starSpin 3s ease-in-out infinite}@keyframes starSpin{0%,to{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.2)}}.completion-btn.record-btn{background:linear-gradient(135deg,#f59e0b,#fbbf24,#f59e0b);background-size:200% auto;animation:btnShimmer 2s linear infinite;box-shadow:0 6px 30px #fbbf2480}@keyframes btnShimmer{0%{background-position:-200% center}to{background-position:200% center}}.completion-btn.record-btn:hover{box-shadow:0 8px 40px #fbbf2499;transform:translateY(-3px)}@media(max-width:480px){.completion-overlay{padding:20px 15px}.completion-modal{padding:30px 25px;border-radius:20px;max-width:100%;width:92%}.completion-icon{font-size:3rem;margin-bottom:10px}.completion-title{font-size:1.5rem;margin-bottom:6px}.completion-mode{font-size:1rem;margin-bottom:20px}.completion-stats{flex-direction:column;gap:15px;margin-bottom:20px}.completion-stats .stat-value{font-size:1.4rem}.completion-stats .stat-value.previous{font-size:1rem}.record-notice{padding:10px 15px;font-size:.85rem;gap:8px;flex-wrap:wrap;text-align:center}.unlock-notice{padding:10px 15px;font-size:.9rem}.completion-btn{font-size:1rem;padding:12px 30px;width:100%}.confetti{width:8px;height:16px}}.wechat-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;align-items:center;z-index:9999;padding:40px 20px;overflow-y:auto;animation:fadeIn .3s ease}.wechat-modal{background:linear-gradient(135deg,#1e293b,#0f172a);border:1px solid rgba(74,222,128,.3);border-radius:24px;padding:30px;max-width:360px;width:90%;position:relative;box-shadow:0 25px 80px #00000080,0 0 60px #4ade801a;animation:scaleIn .4s cubic-bezier(.175,.885,.32,1.275);margin:auto}.wechat-close{position:absolute;top:15px;right:15px;background:#ffffff1a;border:none;color:#94a3b8;font-size:1.2rem;width:32px;height:32px;border-radius:50%;cursor:pointer;transition:all .2s}.wechat-close:hover{background:#fff3;color:#fff}.wechat-header{text-align:center;margin-bottom:25px}.wechat-icon{font-size:3rem;display:block;margin-bottom:10px}.wechat-header h2{font-size:1.5rem;font-weight:800;color:#4ade80;margin:0}.wechat-id{background:#4ade801a;border:2px dashed rgba(74,222,128,.4);border-radius:16px;padding:15px 20px;display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.wechat-id .label{font-size:.85rem;color:#64748b}.wechat-id .id-text{font-size:1.4rem;font-weight:800;color:#4ade80;letter-spacing:1px;font-family:Courier New,monospace}.wechat-id .copy-btn{background:linear-gradient(135deg,#4ade80,#22c55e);border:none;color:#052e16;font-size:.85rem;font-weight:700;padding:8px 16px;border-radius:10px;cursor:pointer;transition:all .2s}.wechat-id .copy-btn:hover{transform:scale(1.05)}.wechat-benefits{margin-bottom:20px}.benefit-item{background:#ffffff08;border-radius:10px;padding:12px 15px;margin-bottom:8px;font-size:.95rem;color:#e2e8f0}.wechat-slogan{text-align:center;margin-bottom:15px;padding:15px;background:linear-gradient(135deg,#fbbf241a,#f59e0b0d);border-radius:12px;border:1px solid rgba(251,191,36,.2)}.wechat-slogan p{margin:0;font-size:1.1rem;color:#fbbf24}.wechat-slogan .sub{font-size:.85rem;color:#94a3b8;margin-top:8px}.wechat-cta{text-align:center}.wechat-cta p{margin:0;font-size:.9rem;color:#64748b}@media(max-width:480px){.wechat-overlay{padding:20px 15px}.wechat-modal{padding:25px 20px;border-radius:20px;max-width:100%;width:92%}.wechat-icon{font-size:2.5rem}.wechat-header h2{font-size:1.3rem}.wechat-id{padding:12px 15px;flex-wrap:wrap;gap:8px}.wechat-id .id-text{font-size:1.2rem}.wechat-id .copy-btn{padding:6px 12px;font-size:.8rem}.benefit-item{font-size:.85rem;padding:10px 12px}.wechat-slogan p{font-size:1rem}.wechat-slogan .sub{font-size:.8rem}.wechat-cta p{font-size:.85rem}}.global-toast{position:fixed;top:80px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#1e293bf2,#0f172afa);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:14px 28px;font-size:1rem;font-weight:600;color:#f8fafc;z-index:10000;box-shadow:0 10px 40px #0006;animation:toastSlideIn .3s ease}@keyframes toastSlideIn{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.global-toast.success{border-color:#4ade8066;color:#4ade80}.global-toast.warning{border-color:#fbbf2466;color:#fbbf24}.global-toast.error{border-color:#f8717166;color:#f87171}.intro-overlay{position:fixed;inset:0;background:#04070cf2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:flex;flex-direction:column;align-items:center;z-index:10000;padding:40px 20px;overflow:hidden;overscroll-behavior:contain;animation:introFadeIn .5s ease}@keyframes introFadeIn{0%{opacity:0}to{opacity:1}}.intro-modal{background:#0f172a;border:1px solid rgba(255,255,255,.1);border-radius:32px;padding:40px 30px;max-width:420px;width:100%;max-height:calc(100dvh - 80px);position:relative;display:flex;flex-direction:column;box-shadow:0 40px 100px #000c;margin:auto}.tutorial-close{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:14px;border:1px solid rgba(148,163,184,.22);background:#02061773;color:#e2e8f0eb;font-size:22px;line-height:1;font-weight:900;cursor:pointer;transition:transform .15s ease,border-color .15s ease,background .15s ease}.tutorial-close:hover{transform:translateY(-1px);border-color:#fbbf2459;background:#0206179e}@media(max-width:480px){.intro-overlay{padding:20px 15px}.intro-modal{padding:25px 20px;border-radius:24px;max-height:92vh}.intro-header h2{font-size:1.5rem!important;white-space:normal!important}.intro-badge{white-space:normal!important;text-align:center}.flow-label,.flow-target,.step-box,.mantra-box p,.mantra-note{white-space:normal!important}.step-point{flex-direction:column;gap:8px}.intro-action-btn{padding:16px!important;margin-top:15px!important;font-size:1rem!important}.method-section{margin-bottom:16px}}@media(max-height:740px){.intro-overlay{padding:16px 12px}.intro-modal{padding:22px 18px;max-height:calc(100dvh - 32px)}.intro-header{margin-bottom:18px}.intro-body{margin-bottom:10px}.method-section{margin-bottom:14px}}.intro-modal:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at center,rgba(30,64,175,.1) 0%,transparent 70%);pointer-events:none}.intro-header{text-align:center;margin-bottom:35px}.intro-badge{display:inline-block;background:#fbbf241a;color:#fbbf24;font-size:.75rem;font-weight:700;padding:4px 12px;border-radius:100px;margin-bottom:12px;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap}.intro-header h2{font-size:1.8rem;font-weight:800;color:#fff;margin:0;letter-spacing:-.02em;white-space:nowrap}.intro-line{width:40px;height:4px;background:#fbbf24;margin:15px auto 0;border-radius:2px}.intro-body{flex:1;overflow-y:auto;min-height:0;padding-right:0;margin-bottom:14px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y}.intro-body::-webkit-scrollbar{width:4px}.intro-body::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.method-section{margin-bottom:22px}.section-head{display:flex;align-items:center;gap:10px;margin-bottom:15px}.section-head .dot{width:6px;height:6px;background:#60a5fa;border-radius:50%;box-shadow:0 0 10px #60a5fa}.section-head .dot.yellow{background:#fbbf24;box-shadow:0 0 10px #fbbf24}.section-head h3{font-size:1rem;font-weight:700;color:#94a3b8;margin:0}.section-desc{font-size:.85rem;color:#64748b;margin:-5px 0 20px 16px;line-height:1.6}.analogy-flow{display:flex;flex-direction:column;gap:10px}.flow-card{background:#1e293b80;border:1px solid rgba(255,255,255,.05);padding:12px 20px;border-radius:16px;display:flex;align-items:center;gap:15px;transition:transform .2s ease}.flow-card:hover{transform:translate(5px);border-color:#fbbf244d}.flow-label{font-size:.9rem;font-weight:700;color:#60a5fa;width:45px;white-space:nowrap}.flow-arrow{color:#334155;font-weight:300}.flow-target{font-size:.95rem;font-weight:600;color:#f1f5f9;white-space:nowrap}.step-track{display:flex;flex-direction:column;align-items:center}.step-point{display:flex;gap:10px;width:100%}.step-box{flex:1;background:#1e293b80;border:1px solid rgba(255,255,255,.05);padding:12px;border-radius:12px;text-align:center;font-size:.85rem;font-weight:600;color:#cbd5e1;white-space:nowrap}.step-box.highlight{background:#fbbf241a;border-color:#fbbf244d;color:#fbbf24}.step-divider{display:flex;flex-direction:column;align-items:center;margin:5px 0}.step-divider .line{width:1px;height:15px;background:#fbbf244d}.step-divider .arrow-down{width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid rgba(251,191,36,.3)}.mantra-box{background:linear-gradient(to right,rgba(251,191,36,.05),transparent);border-left:3px solid #fbbf24;padding:15px 20px;border-radius:0 16px 16px 0;margin-top:10px}.mantra-box p{margin:0;font-size:.9rem;line-height:1.6;color:#94a3b8;white-space:nowrap}.mantra-box .emph{font-weight:700;color:#f1f5f9;margin-top:4px}.mantra-note{font-size:.75rem;color:#64748b;margin-top:8px;font-style:italic;white-space:nowrap}.intro-action-btn{width:100%;margin-top:30px;background:#fbbf24;color:#000;border:none;padding:18px;border-radius:20px;font-size:1.05rem;font-weight:900;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 10px 30px #fbbf244d}.intro-action-btn:hover{transform:translateY(-4px);box-shadow:0 20px 40px #fbbf2466;background:#fcd34d}.intro-action-btn:active{transform:translateY(0)}.today-mission-section{display:flex;flex-direction:column;align-items:center;gap:10px;margin:10px 0 20px;width:100%}.today-mission-bar{display:flex;align-items:center;justify-content:center;gap:12px;background:#1e293b99;border:1px solid rgba(251,191,36,.2);border-radius:14px;padding:12px 16px;width:100%}.mission-day{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#78350f;font-weight:900;font-size:.85rem;padding:6px 10px;border-radius:8px}.mission-content{display:flex;flex-direction:column;gap:2px}.mission-title{color:#fff;font-weight:800;font-size:.9rem}.mission-mode{color:#818cf8;font-size:.75rem;font-weight:700}.mission-view-btn{background:none;border:1px solid rgba(255,255,255,.1);color:#94a3b8;font-size:.8rem;font-weight:600;cursor:pointer;padding:8px 16px;border-radius:20px;transition:all .2s;align-self:center}.mission-view-btn:hover{color:#fbbf24;border-color:#fbbf244d;background:#fbbf240d}.plan-modal-overlay,.ui-popup-overlay{position:fixed;inset:0;background:#020617e6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .3s ease-out}.ui-popup-modal{background:#0f172a;background-image:radial-gradient(at 0% 0%,rgba(30,64,175,.1) 0,transparent 50%),radial-gradient(at 100% 100%,rgba(245,158,11,.05) 0,transparent 50%);border:1px solid rgba(255,255,255,.1);border-radius:22px;max-width:420px;width:100%;max-height:80vh;position:relative;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 50px 100px -20px #000000bf;animation:slideUp .4s cubic-bezier(.16,1,.3,1)}.ui-popup-close{position:absolute;top:14px;right:14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#94a3b8;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:10;font-size:1.25rem}.ui-popup-close:hover{background:#ef444433;color:#f87171;border-color:#ef44444d}.ui-popup-header{padding:22px 22px 16px;border-bottom:1px solid rgba(255,255,255,.06)}.ui-popup-body{flex:1;min-height:0;overflow-y:auto;padding:18px 22px 20px;display:flex;flex-direction:column;gap:14px}.ui-popup-footer{padding:14px 22px 20px;border-top:1px solid rgba(255,255,255,.06);background:linear-gradient(to bottom,#0f172a00,#0f172aa6)}.ui-popup-body::-webkit-scrollbar{width:6px}.ui-popup-body::-webkit-scrollbar-track{background:#ffffff08;border-radius:10px}.ui-popup-body::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:10px}.ui-popup-body::-webkit-scrollbar-thumb:hover{background:#ffffff2e}.ui-popup-title{font-size:1.1rem;font-weight:900;color:#fff;letter-spacing:-.02em}.ui-popup-sub{margin-top:6px;font-size:.8rem;color:#94a3b8;font-weight:600}.ui-popup-list{padding:14px;display:grid;gap:10px;overflow-y:auto}.ui-popup-list::-webkit-scrollbar{width:6px}.ui-popup-list::-webkit-scrollbar-track{background:#ffffff08;border-radius:10px}.ui-popup-list::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:10px}.ui-popup-list::-webkit-scrollbar-thumb:hover{background:#ffffff2e}.ui-popup-item{width:100%;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:16px;color:#e2e8f0;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;transition:all .2s;text-align:left}.ui-popup-item:hover{transform:translateY(-1px);border-color:#fbbf2440;background:#fbbf240f;box-shadow:0 14px 30px #00000059}.ui-popup-item.selected{border-color:#fbbf2459;background:#fbbf241a}.ui-popup-item-text{font-weight:800;line-height:1.3}.ui-popup-item-mark{color:#fbbf24;font-weight:900}@media(max-width:480px){.ui-popup-overlay{padding:16px}.ui-popup-modal{max-width:100%;width:92%;max-height:90vh;border-radius:20px}.ui-popup-header{padding:18px 18px 14px}.ui-popup-body{padding:16px 18px 18px;gap:12px}.ui-popup-footer{padding:12px 18px 18px}}.qb-explain-meta{color:var(--text-muted);font-weight:800;line-height:1.35}.qb-explain-question{font-weight:900;line-height:1.65;color:#f8fafc}.qb-explain-box{display:grid;gap:8px;padding:14px;border-radius:16px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a}.qb-explain-row{font-weight:850;line-height:1.45}.qb-explain-row.good{color:#34d399f2}.qb-explain-row.bad{color:#f87171f2}.qb-explain-tip{padding:14px;border-radius:16px;border:1px solid rgba(255,255,255,.1);background:#ffffff08;line-height:1.75;color:var(--text-main);font-weight:700}.qb-explain-nudge{padding:12px 14px;border-radius:16px;border:1px solid rgba(251,191,36,.22);background:#fbbf2414;color:#f8fafc;line-height:1.7;font-weight:750}.qb-select{width:100%;padding:12px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:#ffffff0a;color:var(--text-main);display:flex;align-items:center;justify-content:space-between;gap:12px}.qb-select:hover{border-color:#fbbf2440;background:#fbbf240f}.qb-select-value{font-weight:800}.qb-select-caret{color:#94a3b8;font-weight:900}.practice-btn{width:100%;padding:14px 16px;border-radius:18px;background:#1e293ba6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.12);color:#e2e8f0;font-weight:900;letter-spacing:.02em;display:flex;align-items:center;justify-content:center;gap:12px;box-shadow:0 12px 28px #00000059;transition:all .25s cubic-bezier(.16,1,.3,1)}.practice-btn:hover{transform:translateY(-2px);border-color:#818cf859;background:#2d3748b8;box-shadow:0 18px 36px #00000073}.practice-btn:active{transform:translateY(0) scale(.99)}.practice-btn:focus-visible{outline:none;box-shadow:0 0 0 3px #818cf859,0 16px 34px #00000073}.practice-btn>span:last-child{padding:6px 10px;border-radius:999px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);font-weight:900;letter-spacing:.08em;color:#a5b4fc}.challenge-btn{width:100%;padding:15px 18px;border-radius:20px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border:1px solid rgba(251,191,36,.35);color:#1f2937;font-size:1rem;font-weight:950;letter-spacing:.04em;box-shadow:0 18px 40px #f59e0b40;transition:all .25s cubic-bezier(.16,1,.3,1)}.challenge-btn:hover:not(:disabled){transform:translateY(-3px);filter:brightness(1.03) saturate(1.05);box-shadow:0 22px 54px #f59e0b52}.challenge-btn:active:not(:disabled){transform:translateY(-1px) scale(.99)}.challenge-btn:focus-visible{outline:none;box-shadow:0 0 0 3px #fbbf2459,0 22px 54px #f59e0b52}.challenge-btn:disabled{cursor:not-allowed;opacity:.55;filter:grayscale(15%);box-shadow:none}.plan-modal{background:#0f172a;background-image:radial-gradient(at 0% 0%,rgba(30,64,175,.1) 0,transparent 50%),radial-gradient(at 100% 100%,rgba(245,158,11,.05) 0,transparent 50%);border:1px solid rgba(255,255,255,.1);border-radius:28px;max-width:440px;width:100%;max-height:85vh;position:relative;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 50px 100px -20px #000000b3;animation:slideUp .4s cubic-bezier(.16,1,.3,1)}.plan-modal-header{padding:24px 28px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;position:relative}.plan-modal-close{position:absolute;top:15px;right:15px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#94a3b8;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:100;font-size:1.2rem}.plan-modal-close:hover{background:#ef444433;color:#f87171;border-color:#ef44444d}.plan-header-left{display:flex;align-items:center;gap:12px}.plan-modal-icon{font-size:1.6rem;background:#ffffff0d;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:12px}.plan-modal-header h2{font-size:1.25rem;font-weight:800;color:#fff;margin:0}.plan-modal-tag{font-size:.7rem;font-weight:800;color:#fbbf24;padding:4px 12px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);border-radius:100px;text-transform:uppercase;letter-spacing:.5px}.plan-modal-list{flex:1;overflow-y:auto;padding:24px 28px;position:relative;scrollbar-width:none}.plan-modal-list::-webkit-scrollbar{display:none}.plan-modal-list:before{content:"";position:absolute;top:30px;left:44px;bottom:30px;width:2px;background:linear-gradient(to bottom,#fbbf24,#fbbf2433);opacity:.3;z-index:1}.plan-modal-item{position:relative;display:flex;gap:20px;margin-bottom:24px;z-index:2}.plan-item-indicator{position:relative;flex-shrink:0;width:34px;height:34px;border-radius:50%;background:#1e293b;border:2px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;color:#64748b;transition:all .3s}.plan-modal-item.completed .plan-item-indicator{background:#fbbf24;border-color:#fbbf24;color:#78350f;box-shadow:0 0 15px #fbbf2466}.plan-modal-item.active .plan-item-indicator{border-color:#fbbf24;color:#fbbf24;box-shadow:0 0 15px #fbbf2433}.plan-item-content{flex:1;background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:18px;padding:16px 20px;transition:all .3s}.plan-modal-item.active .plan-item-content{background:#fbbf240d;border-color:#fbbf2433;transform:translate(4px)}.plan-item-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.plan-item-title{font-size:1rem;font-weight:800;color:#fff}.plan-item-mode{font-size:.7rem;font-weight:700;color:#818cf8;background:#818cf81a;padding:2px 10px;border-radius:6px}.plan-item-task{font-size:.85rem;color:#94a3b8;line-height:1.6;margin-bottom:12px}.plan-item-footer{display:flex;align-items:center;gap:8px}.plan-item-tip{font-size:.75rem;font-weight:700;color:#34d399;display:flex;align-items:center;gap:4px}.plan-item-tip:before{content:"💡";font-size:.8rem}.plan-modal-footer{padding:20px 28px 28px;background:linear-gradient(to top,#0f172a,transparent)}.plan-modal-start{width:100%;padding:18px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border:none;border-radius:18px;color:#78350f;font-size:1.1rem;font-weight:950;cursor:pointer;transition:all .3s;box-shadow:0 15px 30px #f59e0b33}.plan-modal-start:hover{transform:translateY(-2px);box-shadow:0 20px 40px #f59e0b4d}@media(max-width:480px){.plan-modal{max-height:90vh;border-radius:24px}.plan-modal-header,.plan-modal-list{padding:20px}.plan-modal-list:before{left:36px}.plan-item-indicator{width:30px;height:30px;font-size:.7rem}}.plan-section .section-title{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding:0 5px}.plan-section .section-title h3{font-size:1.1rem;font-weight:800;color:#fff;margin:0;flex:1}.plan-section .days-left{font-size:.75rem;color:#64748b;background:#ffffff0d;padding:4px 10px;border-radius:100px}.roadmap-container{display:flex;justify-content:flex-start;align-items:center;gap:12px;overflow-x:auto;padding:10px 10px 20px;margin:0 -10px;scrollbar-width:none;-ms-overflow-style:none}.roadmap-container::-webkit-scrollbar{display:none}.roadmap-container:before{content:"";position:absolute;top:30px;left:20px;right:20px;height:2px;background:#ffffff0d;z-index:1}.roadmap-day{display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;z-index:2;cursor:default;flex:0 0 60px}.day-node{width:40px;height:40px;background:#1e293b;border:2px solid #334155;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#64748b;font-weight:800;font-size:.9rem;transition:all .3s ease;position:relative}.day-label{font-size:.7rem;font-weight:700;color:#475569;letter-spacing:.05em}.roadmap-day.completed .day-node{background:#fbbf24;border-color:#fbbf24;color:#78350f;box-shadow:0 0 15px #fbbf244d}.roadmap-day.completed .day-label{color:#fbbf24}.roadmap-day.active{cursor:pointer}.roadmap-day.active .day-node{background:#fbbf241a;border-color:#fbbf24;color:#fbbf24;box-shadow:0 0 20px #fbbf2433}.roadmap-day.active .day-label{color:#fff}.pulse-ring{position:absolute;width:100%;height:100%;border:2px solid #fbbf24;border-radius:50%;animation:node-pulse 2s infinite}@keyframes node-pulse{0%{transform:scale(1);opacity:.8}70%{transform:scale(1.5);opacity:0}to{transform:scale(1);opacity:0}}.today-task-box{margin-top:20px;background:#0f172ab3;border:1px solid rgba(251,191,36,.2);border-radius:12px;padding:20px;position:relative;overflow:hidden}.task-layout{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.task-day-tag{color:#fbbf24;font-weight:900;font-size:1.1rem;letter-spacing:1px;margin-bottom:12px;display:block}.task-main{color:#fff;font-size:.95rem;margin:0 0 10px;line-height:1.5;width:100%}.task-logic-text{color:#94a3b8;font-size:.85rem;margin:0;line-height:1.6;padding:12px;background:#ffffff08;border-radius:8px;border-left:3px solid #60a5fa;width:100%}.task-footer-hint{width:100%;margin-top:15px;font-size:.75rem;color:#475569;text-align:center;font-style:italic}.task-tip{text-align:center;padding:10px;font-weight:700;font-size:.9rem;width:100%}.task-tip.done{color:#4ade80}.task-tip.wait{color:#60a5fa}.plan-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:15px}.plan-day-card{background:#1e293b99;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:16px;transition:all .3s}.plan-day-card:hover{border-color:#fbbf244d;transform:translateY(-2px)}.plan-day-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.plan-day-num{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#78350f;font-weight:900;font-size:.8rem;padding:4px 10px;border-radius:8px}.plan-day-title{color:#fff;font-weight:800;font-size:1rem}.plan-day-mode{color:#818cf8;font-size:.8rem;font-weight:700;margin-bottom:8px}.plan-day-task{color:#e2e8f0;font-size:.9rem;line-height:1.5;margin-bottom:10px}.plan-day-tip{color:#94a3b8;font-size:.8rem;padding:8px 12px;background:#ffffff08;border-radius:8px;border-left:3px solid #4ade80}@media(max-width:600px){.plan-grid{grid-template-columns:1fr}}.menu-screen{flex:1;display:flex;flex-direction:column;justify-content:flex-start!important;padding-top:40px!important;overflow-x:hidden}.grade-circle{width:100px;height:100px;border:4px solid #fbbf24;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 15px;background:#fbbf240d}.grade-letter{font-size:3rem;font-weight:900;color:#fbbf24}.grade-score{font-size:1.5rem;font-weight:800;color:#fff}.report-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:20px 0}.report-stat{background:#1e293b99;padding:12px;border-radius:12px;border:1px solid rgba(255,255,255,.05)}.report-stat .stat-label{display:block;font-size:.75rem;color:#94a3b8;margin-bottom:4px}.report-stat .stat-value{display:block;font-size:1.1rem;font-weight:800;color:#fff}.report-stat.highlight{background:#fbbf241a;border-color:#fbbf244d}.report-stat.highlight .stat-value{color:#fbbf24}.report-record-notice{background:linear-gradient(135deg,#fbbf2433,#f59e0b33);padding:12px 20px;border-radius:12px;color:#fbbf24;font-weight:700;font-size:.95rem;margin:15px 0;border:1px solid rgba(251,191,36,.3)}.report-btn{width:100%;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#78350f;border:none;padding:14px;border-radius:14px;font-size:1rem;font-weight:900;cursor:pointer;transition:all .2s;margin-top:10px}.report-btn:hover{transform:scale(1.02);box-shadow:0 8px 25px #fbbf2466}.system-notice-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;animation:fadeIn .3s ease}.system-notice-modal{background:linear-gradient(135deg,#1e293bfa,#0f172afa);border:1px solid rgba(251,191,36,.3);border-radius:24px;width:100%;max-width:380px;padding:28px 24px;text-align:center;box-shadow:0 30px 60px #00000080;animation:slideUp .4s cubic-bezier(.22,1,.36,1)}.system-notice-modal .notice-icon{font-size:3rem;margin-bottom:16px;filter:drop-shadow(0 0 20px rgba(251,191,36,.4))}.system-notice-modal h3{font-size:1.4rem;font-weight:800;background:linear-gradient(to right,#fbbf24,#f59e0b);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin:0 0 20px}.notice-content{text-align:left;background:#0003;border-radius:16px;padding:16px;margin-bottom:20px}.notice-content p{font-size:.9rem;color:#cbd5e1;margin:0 0 12px;line-height:1.5}.notice-content ul{list-style:none;padding:0;margin:0 0 16px}.notice-content li{font-size:.85rem;color:#94a3b8;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.05)}.notice-content li:last-child{border-bottom:none}.notice-solution{background:linear-gradient(135deg,#34d3991a,#22c55e0d);border:1px solid rgba(52,211,153,.2);border-radius:12px;padding:12px;margin:12px 0 0!important}.notice-solution strong{color:#34d399;font-weight:700}.notice-tip{background:#818cf81a;border:1px solid rgba(129,140,248,.2);border-radius:10px;padding:10px 12px;margin-top:12px;font-size:.8rem;color:#a5b4fc}.notice-tip span{font-weight:700;color:#818cf8}.notice-btn{width:100%;padding:14px 24px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border:none;border-radius:14px;font-size:1rem;font-weight:800;color:#78350f;cursor:pointer;transition:all .3s}.notice-btn:hover{transform:translateY(-2px);box-shadow:0 10px 25px #fbbf244d}.notice-btn:active{transform:scale(.98)}@media(max-width:480px){.system-notice-modal{max-width:340px;padding:24px 20px}.system-notice-modal .notice-icon{font-size:2.5rem}.system-notice-modal h3{font-size:1.2rem}}.initial-menu{min-height:100vh;background:radial-gradient(circle at 15% 10%,rgba(59,130,246,.18),transparent 45%),radial-gradient(circle at 90% 20%,rgba(236,72,153,.14),transparent 45%),linear-gradient(180deg,#050812,#070b17 55%,#050812);color:#e2e8f0;padding:16px 16px 28px}.initial-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;max-width:980px;margin:0 auto;padding:10px 6px}.initial-brand-title{font-size:1.35rem;font-weight:900;letter-spacing:.02em}.initial-brand-sub{font-size:.78rem;color:#e2e8f0a6;letter-spacing:.22em;margin-top:2px}.initial-user{display:inline-flex;align-items:center;gap:10px;border:1px solid rgba(148,163,184,.25);background:#02061759;color:#e2e8f0;padding:8px 10px;border-radius:14px;cursor:pointer;transition:transform .15s ease,border-color .15s ease,background .15s ease}.initial-user:hover{transform:translateY(-1px);border-color:#94a3b873;background:#0206178c}.initial-user-avatar{width:30px;height:30px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-weight:900;background:linear-gradient(135deg,#38bdf840,#818cf82e);border:1px solid rgba(125,211,252,.25)}.initial-user-name{font-weight:800;font-size:.92rem}.initial-hero{max-width:980px;margin:10px auto 14px;border:1px solid rgba(148,163,184,.18);background:#02061759;border-radius:18px;padding:18px 18px 16px;box-shadow:0 30px 80px #0000008c}.initial-hero-kicker{display:inline-flex;align-items:center;gap:8px;font-weight:900;font-size:.9rem;color:#fde68a;background:#fbbf2414;border:1px solid rgba(251,191,36,.18);padding:8px 10px;border-radius:999px}.initial-hero-title{margin-top:12px;font-size:1.4rem;font-weight:950;letter-spacing:.01em}.initial-hero-desc{margin-top:8px;font-size:.95rem;color:#e2e8f0bf;line-height:1.5}.initial-hero-actions{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}.initial-btn{border:1px solid rgba(148,163,184,.22);background:#0206174d;color:#e2e8f0;padding:10px 12px;border-radius:14px;font-weight:900;cursor:pointer;transition:transform .15s ease,border-color .15s ease,background .15s ease}.initial-btn:hover{transform:translateY(-1px);border-color:#94a3b866;background:#02061780}.initial-btn.primary{border-color:#60a5fa4d;background:linear-gradient(135deg,#3b82f652,#6366f138)}.initial-btn.tutorial{border-color:#fbbf2442;background:linear-gradient(135deg,#fbbf242e,#f472b61f);color:#fef3c7eb}.initial-cards{max-width:980px;margin:0 auto;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.initial-card{text-align:left;border:1px solid rgba(148,163,184,.18);background:#02061747;color:#e2e8f0;border-radius:18px;padding:14px 14px 12px;cursor:pointer;transition:transform .15s ease,border-color .15s ease,background .15s ease}.initial-card:hover{transform:translateY(-2px);border-color:#94a3b861;background:#02061775}.initial-card-phase{font-size:.82rem;font-weight:900;color:#e2e8f0b3;letter-spacing:.02em}.initial-card-row{display:flex;align-items:flex-start;gap:12px;margin-top:10px}.initial-card-icon{font-size:1.5rem;line-height:1;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:#0f172a99;border:1px solid rgba(148,163,184,.16)}.initial-card-title{font-size:1.05rem;font-weight:950}.initial-card-desc{margin-top:6px;font-size:.9rem;color:#e2e8f0b8;line-height:1.45}.initial-card-main{flex:1;min-width:0}.initial-card-cta{font-size:1rem;opacity:.85;margin-left:4px}.initial-card-cta-btn{font-size:1rem;opacity:.85;margin-left:4px;background:transparent;border:none;color:inherit;padding:6px 8px;border-radius:12px;cursor:pointer}.initial-card-cta-btn:hover{background:#fbbf241f}.initial-card-cta-btn:active{background:#fbbf242e}@media(max-width:700px){.initial-cards{grid-template-columns:1fr}}
