@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Titan+One&family=Sora:wght@400;700;800&display=swap");:root{--primary:#ea580c;--primary-light:#fb923c;--bg:#f8f9fb;--card:#fff;--text:#1e293b;--muted:#94a3b8;--success:#10b981;--error:#f43f5e;--radius:16px;--tab-h:52px;--safe-bottom:env(safe-area-inset-bottom,0px);--tab-total-h:calc(var(--tab-h) + var(--safe-bottom));--topnav-h:60px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;overscroll-behavior-y:none;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;top:0;left:0;right:0;height:env(safe-area-inset-top);background:#131f22;z-index:9999;pointer-events:none}.streakpop-overlay{position:fixed;inset:0;z-index:10050;background:#000000;justify-content:center}.streakpop-overlay,.streakpop-screen{display:flex;flex-direction:column;align-items:center;overflow:hidden}.streakpop-screen{width:100%;max-width:390px;height:100%;max-height:844px;padding:calc(18px + env(safe-area-inset-top)) 32px calc(32px + env(safe-area-inset-bottom));box-sizing:border-box;position:relative;background:#000}.streakpop-main{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:0;width:100%;gap:40px}.streakpop-topbar{width:100%;display:flex;justify-content:flex-end;margin-bottom:10px}.streakpop-x{width:38px;height:38px;border:none;border-radius:12px;background:transparent;color:#e5e2e1;font-size:18px;cursor:pointer;opacity:.95}.streakpop-hero{display:flex;flex-direction:column;align-items:center;animation:streakpop-hero-in .52s cubic-bezier(.34,1.56,.64,1) both}@keyframes streakpop-hero-in{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.streakpop-iconrow{display:flex;align-items:center;gap:16px;margin-bottom:28px}.streakpop-firewrap{width:128px;height:128px;animation:streakpop-fire-pop .8s cubic-bezier(.34,1.56,.64,1) both}@keyframes streakpop-fire-pop{0%{transform:scale(0) rotate(-180deg)}40%{transform:scale(1.3) rotate(20deg)}60%{transform:scale(.9) rotate(-10deg)}80%{transform:scale(1.1) rotate(5deg)}to{transform:scale(1) rotate(0)}}.streakpop-fire{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 0 20px rgba(234,88,12,.6))}.streakpop-num{font-family:Inter,system-ui,-apple-system,sans-serif;font-weight:900;font-size:72px;line-height:72px;color:#ea580c;width:56px;text-align:left;animation:streakpop-num-in .4s ease-out both;animation-delay:.46s}@keyframes streakpop-num-in{0%{transform:translateX(20px);opacity:0}to{transform:translateX(0);opacity:1}}.streakpop-title{font-weight:900;font-size:28px;line-height:42px;letter-spacing:.7px;color:#e5e2e1;text-align:center;margin-bottom:6px}.streakpop-desc{font-weight:500;font-size:16px;line-height:24px;color:#e2bfb2;text-align:center;max-width:320px}.streakpop-week{width:100%;max-width:320px;background:#1c1b1b;border-radius:32px;padding:22px 18px;border:1px solid rgba(58,57,57,.2);box-shadow:inset 0 2px 10px rgba(0,0,0,.5);display:flex;justify-content:space-between;align-items:center;animation:streakpop-week-in .52s ease-out both;animation-delay:.42s}@keyframes streakpop-week-in{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.streakpop-day{flex-direction:column;gap:8px}.streakpop-day,.streakpop-dot{display:flex;align-items:center}.streakpop-dot{width:40px;height:40px;border-radius:999px;background:#2a2929;opacity:.3;justify-content:center;box-shadow:inset 1px 1px 2px rgba(0,0,0,.5)}.streakpop-dot.is-today{width:48px;height:48px;opacity:1;box-shadow:inset 2px 2px 4px rgba(255,255,255,.3),inset -2px -2px 4px rgba(0,0,0,.3),0 0 8px rgba(234,88,12,.4)}.streakpop-dot.is-done{background:#ea580c;opacity:.8;box-shadow:inset 2px 2px 4px rgba(255,255,255,.2),inset -2px -2px 4px rgba(0,0,0,.3)}.streakpop-dot.is-done.is-today{opacity:1}.streakpop-check{color:#ffffff;font-weight:900;font-size:16px;transform:translateY(-1px)}.streakpop-label{font-size:12px;line-height:14.4px;font-weight:600;color:#5a5959}.streakpop-label.is-done{color:#e2bfb2}.streakpop-label.is-today{color:#ea580c;font-weight:800;font-size:14px;letter-spacing:.7px;line-height:16.8px}.streakpop-cta{width:100%;padding:48px 0 24px;flex-shrink:0}.streakpop-btn{width:100%;background:#ea580c;border:none;border-radius:999px;padding:12px 18px;color:#ffffff;font-weight:800;font-size:16px;line-height:24px;cursor:pointer;box-shadow:inset 2px 2px 4px rgba(255,255,255,.2),inset -2px -2px 4px rgba(0,0,0,.3),0 4px 6px rgba(234,88,12,.4)}.streakpop-confetti{position:absolute;inset:0;pointer-events:none;overflow:hidden}.streakpop-confetti-piece{position:absolute;top:0;border-radius:2px;opacity:0;animation-name:streakpop-confetti-fall;animation-timing-function:ease-out;animation-fill-mode:both}.streakpop-confetti-piece.is-pill{border-radius:999px}@keyframes streakpop-confetti-fall{0%{opacity:0;transform:translate3d(0,-12px,0) rotate(0deg)}10%{opacity:1}to{opacity:0;transform:translate3d(var(--drift),520px,0) rotate(420deg)}}@media (prefers-reduced-motion:reduce){.streakpop-confetti-piece,.streakpop-firewrap,.streakpop-hero,.streakpop-num,.streakpop-week{animation:none!important}}.app-shell{display:flex;flex-direction:column;min-height:100vh;max-width:480px;margin:0 auto;position:relative}.app-content{flex:1 1;padding:calc(20px + env(safe-area-inset-top, 0px)) 16px calc(var(--tab-total-h) + 16px);overflow-y:auto;-webkit-overflow-scrolling:touch}.top-nav{display:none}.bottom-tab-bar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;height:var(--tab-total-h);background:#131F22;border-radius:0;border-top:1px solid rgba(255,255,255,.15);box-shadow:0 -4px 12px rgba(0,0,0,.2);display:flex;justify-content:space-around;align-items:flex-start;z-index:1000;padding-bottom:var(--safe-bottom);box-sizing:border-box}.bottom-tab-bar .tab-item{height:var(--tab-h);min-height:unset;padding:2px 4px;justify-content:center}.bottom-tab-bar .tab-label{display:none}.tab-item{display:flex;flex-direction:column;align-items:center;gap:0;text-decoration:none;color:#636363;transition:.2s;position:relative;padding:6px 4px;-webkit-tap-highlight-color:transparent}.tab-item.tab-active{color:#ffffff}.tab-label{font-size:.5rem;font-weight:700;letter-spacing:.03em;margin-top:-7px}@media (max-height:500px){.bottom-tab-bar{display:none!important}}@media(min-width:768px){.app-shell{max-width:900px}.app-content{padding:calc(var(--topnav-h) + 20px) 32px 32px}.bottom-tab-bar{display:none!important}.top-nav{display:flex;align-items:center;justify-content:space-between;position:fixed;top:0;left:0;right:0;margin:0 auto;width:100%;max-width:900px;height:var(--topnav-h);padding:0 32px;z-index:1000;transition:transform .3s cubic-bezier(.4,0,.2,1)}.top-nav.top-nav-hidden{transform:translateY(-100%)}.top-nav:before{content:"";position:fixed;top:0;left:0;right:0;height:var(--topnav-h);background:rgba(19,31,34,.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.08);z-index:-1;pointer-events:none;transition:transform .3s cubic-bezier(.4,0,.2,1)}.top-nav.top-nav-hidden:before{transform:translateY(-100%)}.top-nav-logo{display:flex;align-items:center;gap:8px;text-decoration:none;color:#ffffff}.top-nav-brand{font-size:1.2rem;font-weight:900;letter-spacing:-.02em}.top-nav-brand em{font-style:normal;color:var(--primary)}.top-nav-links{display:flex;gap:4px}.top-nav-link{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:10px;text-decoration:none;font-size:.82rem;font-weight:700;color:#94a3b8;transition:.15s}.top-nav-link:hover{background:rgba(255,255,255,.08);color:#ffffff}.top-nav-active{color:#ffffff;background:rgba(99,102,241,.25)}.pg-map{padding:20px 32px 32px!important;max-width:480px;margin:-20px auto!important}.page-title{font-size:1.5rem;margin-bottom:20px}.subtopic-header h1{font-size:1.3rem}.back-btn{width:36px;height:36px;font-size:1rem}.library-card{padding:16px;gap:14px;border-radius:16px;margin-bottom:12px}.library-icon{width:48px;height:48px;font-size:1.4rem}.library-info h3{font-size:1rem}.library-info p{font-size:.82rem}.group-bar{border-radius:18px;margin-bottom:12px}.group-bar-header{padding:18px 20px;gap:14px}.group-icon,.group-icon-img{width:48px;height:48px}.group-icon{font-size:1.8rem}.group-icon,.group-icon-img{border-radius:12px}.group-title{font-size:1.02rem}.group-count{font-size:.82rem}.group-chevron{font-size:1.3rem}.group-dropdown{padding:0 16px 16px}.subtopic-row{padding:16px;border-radius:14px;margin-bottom:10px}.subtopic-row-title{font-size:.95rem}.subtopic-row-count{font-size:.78rem;padding:3px 10px}.action-chip{padding:8px 16px;font-size:.82rem;border-radius:10px}.action-btn{padding:10px 20px;font-size:.85rem}.solutions-tabs{gap:12px;margin-bottom:20px}.sol-tab{padding:12px;font-size:.95rem;border-radius:12px}.solution-card{padding:20px;gap:16px;border-radius:16px}.solution-qnum{width:40px;height:40px;font-size:.85rem;border-radius:10px}.solution-body>div:first-child{font-size:.95rem;margin-bottom:14px}.solution-opt{font-size:.88rem;padding:8px 14px;border-radius:10px}.solution-opt-letter{width:24px;height:24px;font-size:.78rem}.solution-answer{font-size:.88rem}.solution-explanation{font-size:.82rem;padding:12px 14px}.quiz-question{font-size:1rem;line-height:1.7}.quiz-option{padding:14px 18px;font-size:.92rem;border-radius:12px}.quiz-counter{font-size:.82rem}.qnav-btn{padding:13px;font-size:.92rem}.pg-profile{margin:calc(-1 * (var(--topnav-h) + 20px)) -32px -32px!important;padding:0 32px 32px!important;min-height:100vh!important}.pg-profile:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--bg);z-index:-1;pointer-events:none}.page-library{margin:calc(-1 * (var(--topnav-h) + 20px)) -32px -32px!important;padding:calc(var(--topnav-h) + 20px) 32px 32px!important;min-height:100vh!important}.page-library:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--bg);z-index:-1;pointer-events:none}.page-polity-notes{margin:calc(-1 * (var(--topnav-h) + 20px)) -32px -32px!important;padding:calc(var(--topnav-h) + 20px) 32px 32px!important;min-height:100vh!important}.page-polity-notes:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--pn-bg,#131f22);z-index:-1;pointer-events:none}.page-geography-notes{margin:calc(-1 * (var(--topnav-h) + 20px)) -32px -32px!important;padding:calc(var(--topnav-h) + 20px) 32px 32px!important;min-height:100vh!important}.page-geography-notes:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--pn-bg,#12201c);z-index:-1;pointer-events:none}.page-quiz{margin:calc(-1 * (var(--topnav-h) + 20px)) -32px -32px!important;padding:20px 32px 32px!important;min-height:100vh!important}.page-quiz:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--bg);z-index:-1;pointer-events:none}.library-search{padding:12px 18px;border-radius:14px}.search-input{font-size:.95rem}.page-home{margin:calc(-1 * (var(--topnav-h) + 20px)) -32px -32px!important;padding:calc(var(--topnav-h) + 20px) 32px 32px!important;min-height:100vh!important}.page-home:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--bg);z-index:-1;pointer-events:none}.home-greeting{font-size:1.5rem}.home-sub{font-size:.88rem}.continue-info h4{font-size:.9rem}.continue-info p{font-size:.78rem}.chip-label{display:inline}.chip-icon{width:20px;height:20px}.action-chip{padding:8px 14px;font-size:.78rem;gap:6px}.subtopic-row{padding:14px}.subtopic-row-title{font-size:.92rem}.subtopic-row-actions{gap:8px}}.landing{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0c0c0e;position:relative;overflow:hidden}.landing-glow{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none;will-change:transform}.landing-glow-1{width:340px;height:340px;background:radial-gradient(circle,rgba(234,88,12,.16) 0,transparent 70%);top:-60px;right:-80px;animation:glow-drift-1 8s ease-in-out infinite alternate}.landing-glow-2{width:280px;height:280px;background:radial-gradient(circle,rgba(251,146,60,.1) 0,transparent 70%);bottom:10%;left:-80px;animation:glow-drift-2 10s ease-in-out infinite alternate}@keyframes glow-drift-1{0%{transform:translate(0) scale(1)}to{transform:translate(-20px,30px) scale(1.1)}}@keyframes glow-drift-2{0%{transform:translate(0) scale(1)}to{transform:translate(25px,-20px) scale(1.05)}}.landing-content{text-align:center;padding:40px 28px;z-index:2;max-width:400px;width:100%;display:flex;flex-direction:column;align-items:center}.landing-mascot{width:72px;height:72px;margin-bottom:16px;border-radius:20px;background:linear-gradient(145deg,#1a1a1e,#141416);border:1px solid rgba(234,88,12,.12);display:flex;align-items:center;justify-content:center;font-size:2.4rem;box-shadow:0 8px 32px rgba(234,88,12,.06);animation:mascot-float 3s ease-in-out infinite}@keyframes mascot-float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.landing-title{font-size:2.6rem;font-weight:900;color:#fafafa;letter-spacing:-.04em;margin:0;line-height:1}.landing-title span{color:#ea580c}.landing-tagline{color:#52525b;font-size:.88rem;margin:4px 0 36px;font-weight:500;letter-spacing:-.01em}.landing-timeline{position:relative;padding-left:28px;margin-bottom:40px;width:100%}.landing-timeline:before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:1px;background:linear-gradient(180deg,#ea580c 0,#27272a 40%,#27272a 60%,#ea580c)}.tl-feat{position:relative;padding:10px 0;text-align:left}.tl-feat:before{content:"";position:absolute;left:-24px;top:16px;width:9px;height:9px;border-radius:50%;background:#ea580c;box-shadow:0 0 8px rgba(234,88,12,.3)}.tl-top{display:flex;align-items:baseline;gap:8px}.tl-num{font-size:1.1rem;font-weight:900;color:#ea580c;letter-spacing:-.03em}.tl-title{font-size:.88rem;font-weight:700;color:#e4e4e7}.tl-sub{font-size:.74rem;color:#52525b;margin-top:3px;line-height:1.4}.landing-actions{display:flex;flex-direction:column;gap:12px}.landing-btn{display:block;padding:14px;border-radius:12px;font-weight:700;font-size:.92rem;text-decoration:none;text-align:center;transition:all .2s ease;cursor:pointer;letter-spacing:-.01em}.landing-btn-primary{background:#ea580c;color:#fff;box-shadow:0 4px 16px rgba(234,88,12,.25)}.landing-btn-primary:hover{transform:translateY(-1px);background:#dc5209;box-shadow:0 6px 24px rgba(234,88,12,.35)}.landing-btn-primary:active{transform:translateY(1px);box-shadow:0 2px 8px rgba(234,88,12,.2)}.landing-btn-outline{background:transparent;border:1.5px solid rgba(255,255,255,.08);color:rgba(255,255,255,.6)}.landing-btn-outline:hover{transform:translateY(-1px);border-color:rgba(255,255,255,.16);color:rgba(255,255,255,.85);background:rgba(255,255,255,.03)}.landing-btn-outline:active{transform:translateY(1px)}.landing-guest{margin-top:24px}.landing-guest a{color:#3f3f46;font-size:.78rem;text-decoration:none;font-weight:500;transition:.2s}.landing-guest a:hover{color:#ea580c}.landing-trust{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:16px}.landing-trust-dot{width:5px;height:5px;border-radius:50%;background:#10b981;box-shadow:0 0 6px rgba(16,185,129,.4)}.landing-trust span{font-size:.68rem;color:#3f3f46;font-weight:600}@media (display-mode:standalone){.hide-in-app{display:none!important}}.splash-container{position:fixed;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(170deg,#060814,#10122b 50%,#17113a);overflow:hidden;z-index:9999}@media (display-mode:standalone){.splash-container{display:flex!important}}.ambient-orb{position:absolute;border-radius:50%;filter:blur(120px);opacity:.35;pointer-events:none;animation:ambient-drift 10s ease-in-out infinite alternate}.splash-orb-1{width:500px;height:500px;background:#ea580c;top:-100px;left:-100px}.splash-orb-2{width:400px;height:400px;background:#fb923c;bottom:-100px;right:-50px;animation-delay:-5s;opacity:.25}@keyframes ambient-drift{0%{transform:translate(0) scale(1)}to{transform:translate(30px,40px) scale(1.1)}}.splash-content{z-index:10;gap:32px}.fox-wrapper,.splash-content{position:relative;display:flex;flex-direction:column;align-items:center}.fox-sprite{width:160px;height:160px;background-image:url(/mascot/Fox_run.png);background-size:300% 300%;filter:drop-shadow(0 15px 25px rgba(0,0,0,.6));z-index:2;animation:fox-run-sprite .833s step-end infinite,fox-bounce .33s cubic-bezier(.4,0,.2,1) infinite alternate}@keyframes fox-run-sprite{0%{background-position:50% 0}20%{background-position:100% 0}40%{background-position:0 50%}60%{background-position:50% 50%}80%{background-position:0 100%}to{background-position:50% 0}}@keyframes fox-bounce{0%{transform:translateY(0)}to{transform:translateY(-4px)}}.fox-shadow{position:absolute;bottom:10px;width:80px;height:12px;background:rgba(255,123,53,.4);border-radius:50%;filter:blur(6px);z-index:1;animation:shadow-pulse .33s cubic-bezier(.4,0,.2,1) infinite alternate}@keyframes shadow-pulse{0%{transform:scale(1);opacity:.5}to{transform:scale(.8);opacity:.2}}.loading-pill{display:flex;align-items:center;gap:16px;background:rgba(30,32,66,.4);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);box-shadow:0 10px 30px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.05);padding:12px 24px;border-radius:100px;position:relative;overflow:hidden}.loading-pill:after{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);transform:skewX(-20deg);animation:shimmer 2.5s infinite}.loading-text{font-size:.95rem;font-weight:700;letter-spacing:.5px;color:rgba(255,255,255,.85);margin:0}.wave-spinner{display:flex;gap:4px}.wave-bar{width:4px;height:16px;background:#ff7b35;border-radius:4px;animation:wave 1s ease-in-out infinite}.wave-bar:first-child{animation-delay:-.4s;background:#f59e0b}.wave-bar:nth-child(2){animation-delay:-.2s;background:#ff7b35}.wave-bar:nth-child(3){animation-delay:0s;background:#ef4444}@keyframes wave{0%,to{transform:scaleY(.4);opacity:.5}50%{transform:scaleY(1);opacity:1}}.speed-particle{position:absolute;background:rgba(255,255,255,.4);border-radius:50%;animation:dash linear infinite}@keyframes dash{0%{transform:translateX(100vw);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateX(-100vw);opacity:0}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0c0c0e;padding:24px;position:relative;overflow:hidden}.auth-page:after{content:"";position:absolute;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(251,146,60,.1) 0,transparent 70%);bottom:10%;left:-40px;pointer-events:none}.auth-card{background:#18181bd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.06);border-radius:24px;padding:24px 20px;width:100%;max-width:400px;box-shadow:0 24px 80px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.04);position:relative;z-index:1}.auth-back{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.05);color:rgba(255,255,255,.5);text-decoration:none;transition:all .2s;border:1px solid rgba(255,255,255,.06)}.auth-back:hover{background:rgba(255,255,255,.1);color:rgba(255,255,255,.8)}.auth-top{display:flex;align-items:center;gap:14px;margin-bottom:24px}.auth-header{flex:1 1}.auth-title{font-size:1.5rem;font-weight:800;color:#fff;margin:0;letter-spacing:-.02em}.auth-subtitle{color:rgba(255,255,255,.4);font-size:.88rem;margin:6px 0 0;font-weight:500}.auth-form{gap:16px}.auth-field,.auth-form{display:flex;flex-direction:column}.auth-field{gap:5px}.auth-label{font-size:.75rem;font-weight:700;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:.06em;padding-left:2px}.auth-input-wrap{position:relative;display:flex;align-items:center}.auth-input-icon{position:absolute;left:14px;color:rgba(255,255,255,.25);pointer-events:none;transition:color .2s;flex-shrink:0}.auth-input-wrap:focus-within .auth-input-icon{color:rgba(234,88,12,.7)}.auth-input{width:100%;padding:13px 42px;background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.08);border-radius:12px;font-size:.9rem;font-family:inherit;color:#fff;outline:none;transition:all .25s}.auth-input::placeholder{color:rgba(255,255,255,.2)}.auth-input:focus{border-color:rgba(234,88,12,.5);background:rgba(234,88,12,.06);box-shadow:0 0 0 3px rgba(234,88,12,.1)}.auth-input:-webkit-autofill,.auth-input:-webkit-autofill:focus,.auth-input:-webkit-autofill:hover{-webkit-text-fill-color:#fff;-webkit-box-shadow:inset 0 0 0 1000px rgba(24,24,27,.95);border-color:rgba(234,88,12,.3);-webkit-transition:background-color 5000s ease-in-out 0s;transition:background-color 5000s ease-in-out 0s}.auth-eye{position:absolute;right:12px;background:none;border:none;color:rgba(255,255,255,.25);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.auth-eye:hover{color:rgba(255,255,255,.5)}.auth-error{color:#f87171;font-size:.8rem;margin:-8px 0 0;padding-left:2px}.auth-submit{width:100%;padding:14px;background:#ea580c;color:#fff;border:none;border-radius:12px;font-weight:800;font-size:.92rem;font-family:inherit;cursor:pointer;transition:all .2s;box-shadow:0 3px 0 #9a3412,0 5px 16px rgba(234,88,12,.3);position:relative;margin-top:2px;display:flex;align-items:center;justify-content:center;min-height:48px}.auth-submit:hover{transform:translateY(-1px);box-shadow:0 5px 0 #9a3412,0 8px 28px rgba(234,88,12,.4)}.auth-submit:active{transform:translateY(2px);box-shadow:0 2px 0 #9a3412,0 4px 12px rgba(234,88,12,.25)}.auth-submit:disabled{opacity:.7;cursor:not-allowed;transform:none}.auth-spinner{width:20px;height:20px;border:2.5px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:authSpin .6s linear infinite}@keyframes authSpin{to{transform:rotate(1turn)}}.auth-switch{text-align:center;font-size:.8rem;color:rgba(255,255,255,.35);margin-top:20px}.auth-switch a{color:#ea580c;font-weight:700;text-decoration:none;transition:color .2s}.auth-switch a:hover{color:#fb923c}.auth-google{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:13px;background:#fff;color:#3c4043;border:none;border-radius:12px;font-weight:700;font-size:.9rem;font-family:inherit;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);box-shadow:inset 1px 1px 2px rgba(255,255,255,.9),inset -1px -1px 2px rgba(0,0,0,.08),0 3px 0 #d1d5db,0 4px 12px rgba(0,0,0,.15);min-height:48px}.auth-google:hover{transform:translateY(-1px);box-shadow:inset 1px 1px 2px rgba(255,255,255,.9),inset -1px -1px 2px rgba(0,0,0,.08),0 4px 0 #d1d5db,0 6px 18px rgba(0,0,0,.2)}.auth-google:active{transform:translateY(2px);box-shadow:inset 1px 1px 2px rgba(255,255,255,.9),inset -1px -1px 2px rgba(0,0,0,.08),0 1px 0 #d1d5db,0 2px 6px rgba(0,0,0,.1)}.auth-google:disabled{opacity:.7;cursor:not-allowed;transform:none}.auth-divider{display:flex;align-items:center;gap:12px;margin:18px 0}.auth-divider:after,.auth-divider:before{content:"";flex:1 1;height:1px;background:rgba(255,255,255,.08)}.auth-divider span{color:rgba(255,255,255,.25);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.page-home{--bg:#131F22;--card:#1e2e32;--text:#f0fdf4;--muted:#8aa3a8;background-color:var(--bg);color:var(--text);margin:-20px -16px calc(-1 * (var(--tab-h) + 16px));padding:20px 16px calc(var(--tab-h) + 24px);min-height:100vh;position:relative;overflow-x:hidden}.home-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:16px 4px 20px;border-bottom:1.5px solid rgba(255,255,255,.06);position:relative}.home-header>*{position:relative;z-index:1}.home-greeting{font-size:1.6rem;font-weight:900;letter-spacing:-.03em;color:#f0fdf4}.home-sub{color:#8aa3a8;font-size:.82rem;margin-top:3px;font-weight:600}.home-streak-badge{display:flex;align-items:center;gap:5px;background:rgba(255,255,255,.06);padding:6px 14px;border-radius:10px;font-weight:800;font-size:.95rem;color:#f59e0b}.home-section{margin-bottom:12px}.map-banner-section{margin-top:24px}.exam-guide-section{margin-top:8px;padding-bottom:8px}.eg-intro-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.eg-intro-label{font-size:.88rem;font-weight:800;color:#f0fdf4;margin:0;letter-spacing:-.01em}.eg-paper-tabs{display:flex;gap:4px;background:rgba(255,255,255,.04);border-radius:8px;padding:3px}.eg-paper-tab{padding:5px 14px;border:none;border-radius:6px;background:transparent;color:#8aa3a8;font-size:.68rem;font-weight:700;font-family:inherit;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.eg-paper-tab.active{background:rgba(255,255,255,.1);color:#f0fdf4}.eg-treemap{width:100%;aspect-ratio:5/4;border-radius:16px;overflow:hidden;position:relative;margin-bottom:16px}.eg-tm-cell{position:absolute;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;padding:10px;overflow:hidden;cursor:default;border:1.5px solid rgba(19,31,34,.9)}.eg-tm-name{font-size:.76rem;font-weight:700;color:rgba(255,255,255,.92);z-index:1;line-height:1.2}.eg-tm-qs{font-size:.55rem;font-weight:600;color:rgba(255,255,255,.5);z-index:1;margin-top:2px}.eg-tm-cell.small .eg-tm-name{font-size:.62rem}.eg-tm-cell.small .eg-tm-qs{font-size:.48rem}.eg-tm-cell.small{padding:5px 6px}.eg-guidance-card{padding:18px 16px;border-radius:18px;background:linear-gradient(145deg,#1a2a2e,#162225);box-shadow:inset 1px 1px 2px rgba(255,255,255,.05),inset -1px -1px 2px rgba(0,0,0,.3),0 3px 0 #0f1c1f,0 6px 14px rgba(0,0,0,.3);margin-bottom:16px}.eg-guidance-title{display:flex;align-items:center;gap:8px;font-size:.88rem;font-weight:800;color:#fde68a;margin:0 0 14px;text-shadow:0 1px 3px rgba(0,0,0,.4)}.eg-guidance-icon{font-size:1.15rem}.eg-tips{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.eg-tips li{font-size:.78rem;color:#a3bfc5;line-height:1.6;padding-left:18px;position:relative}.eg-tips li:before{content:"";position:absolute;left:0;top:7px;width:7px;height:7px;border-radius:50%;background:linear-gradient(135deg,#ea580c,#fb923c);box-shadow:0 0 6px rgba(234,88,12,.4),inset 0 1px 1px rgba(255,255,255,.4)}.eg-tips li strong{color:#f0fdf4;font-weight:700}.eg-app-help-card{padding:18px 16px;border-radius:18px;background:linear-gradient(145deg,#182830,#14222a);border:1px solid rgba(99,102,241,.12);box-shadow:inset 1px 1px 2px rgba(255,255,255,.04),inset -1px -1px 2px rgba(0,0,0,.3),0 3px 0 #0d1a1e,0 6px 14px rgba(0,0,0,.3);margin-bottom:16px}.eg-app-help-title{display:flex;align-items:center;gap:8px;font-size:.88rem;font-weight:800;color:#f0fdf4;margin:0 0 16px}.eg-app-help-icon{font-size:1.15rem}.eg-features{display:flex;flex-direction:column;gap:14px}.eg-feature{display:flex;align-items:flex-start;gap:12px}.eg-feature-badge{flex-shrink:0;width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:linear-gradient(145deg,#ea580c,#c2410c);font-size:1.05rem;box-shadow:inset 1px 1px 2px rgba(255,255,255,.35),inset -1px -1px 2px rgba(0,0,0,.15),0 2px 0 #9a3412,0 4px 8px rgba(154,52,18,.3)}.eg-feature strong{display:block;font-size:.82rem;font-weight:800;color:#f0fdf4;margin-bottom:3px;letter-spacing:-.01em}.eg-feature p{font-size:.74rem;color:#8aa3a8;line-height:1.5;margin:0}.eg-footer-note{text-align:center;padding:16px 20px;border-radius:16px;background:linear-gradient(145deg,rgba(99,102,241,.08),rgba(99,102,241,.03));border:1px solid rgba(99,102,241,.1)}.eg-footer-note p{font-size:.78rem;color:#a3bfc5;line-height:1.6;margin:0;font-style:italic}.section-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:16px;padding-bottom:8px;border-bottom:1.5px solid rgba(0,0,0,.3);box-shadow:0 1px 0 rgba(255,255,255,.05)}.section-header h3{font-size:.9rem!important;font-weight:700!important;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.35);text-shadow:0 1px 1px rgba(0,0,0,.4)}.see-all{color:var(--primary);font-size:.6rem!important;font-weight:800;text-transform:uppercase;letter-spacing:.04em;text-decoration:none;opacity:.8}.quick-start-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:8px}.quick-start-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px 8px;border-radius:16px;text-decoration:none;transition:.15s;position:relative;border:none}.quick-start-card:active{transform:scale(.96)}.qs-icon-img{width:80px;height:80px;object-fit:contain;margin-bottom:10px;filter:drop-shadow(0 4px 6px rgba(0,0,0,.25))}.qs-label{font-size:.85rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.qs-polity{background:linear-gradient(145deg,#8b5cf6,#7c3aed);box-shadow:inset 1px 1px 3px rgba(255,255,255,.4),inset -1px -1px 3px rgba(0,0,0,.2),0 4px 0 #6d28d9,0 6px 12px rgba(109,40,217,.3)}.qs-polity:active{box-shadow:inset 1px 1px 3px rgba(255,255,255,.4),inset -1px -1px 3px rgba(0,0,0,.2),0 2px 0 #6d28d9,0 4px 6px rgba(109,40,217,.3)}.qs-polity .qs-icon-img{transform:scale(1.3)}.qs-geo{background:linear-gradient(145deg,#22c55e,#16a34a);box-shadow:inset 1px 1px 3px rgba(255,255,255,.4),inset -1px -1px 3px rgba(0,0,0,.2),0 4px 0 #15803d,0 6px 12px rgba(21,128,61,.3)}.qs-geo:active{box-shadow:inset 1px 1px 3px rgba(255,255,255,.4),inset -1px -1px 3px rgba(0,0,0,.2),0 2px 0 #15803d,0 4px 6px rgba(21,128,61,.3)}.qs-geo .qs-icon-img{transform:scale(1.6)}.qs-hist{background:linear-gradient(145deg,#ea580c,#c2410c);box-shadow:inset 1px 1px 3px rgba(255,255,255,.4),inset -1px -1px 3px rgba(0,0,0,.2),0 4px 0 #9a3412,0 6px 12px rgba(154,52,18,.3)}.qs-hist:active{box-shadow:inset 1px 1px 3px rgba(255,255,255,.4),inset -1px -1px 3px rgba(0,0,0,.2),0 2px 0 #9a3412,0 4px 6px rgba(154,52,18,.3)}.qs-hist .qs-icon-img{transform:scale(1.65)}.continue-card{display:flex;align-items:center;background:linear-gradient(145deg,#0ea5e9,#0284c7);border-radius:20px;padding:18px 16px;box-shadow:inset 1px 1px 3px rgba(255,255,255,.4),inset -1px -1px 3px rgba(0,0,0,.2),0 4px 0 #075985,0 8px 16px rgba(3,105,161,.4);gap:14px;transition:.15s cubic-bezier(.34,1.56,.64,1);border:none;color:#fff}.continue-card:active{transform:translateY(2px) scale(.98);box-shadow:inset 1px 1px 3px rgba(255,255,255,.4),inset -1px -1px 3px rgba(0,0,0,.2),0 2px 0 #075985,0 4px 8px rgba(3,105,161,.4)}.continue-progress{position:relative;width:52px;height:52px;flex-shrink:0}.progress-ring{width:100%;height:100%;transform:rotate(-90deg)}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.7rem;font-weight:800;color:#fff!important}.continue-card path:first-child{stroke:rgba(255,255,255,.25)!important}.continue-card path:last-child{stroke:#fff!important}.continue-info h4{font-size:.9rem;font-weight:700;margin:0 0 3px;color:#fff}.continue-info p{font-size:.75rem;color:rgba(255,255,255,.85)}.continue-arrow{color:rgba(255,255,255,.85);font-size:1.2rem;margin-left:auto}.continue-pause-icon{width:52px;height:52px;flex-shrink:0;border-radius:14px;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center}.pg-map{padding-bottom:8px}.mp-hud-bar{position:fixed;top:0;left:0;right:0;z-index:100;max-width:480px;margin:0 auto;padding:calc(10px + env(safe-area-inset-top)) 12px 8px;pointer-events:auto}.mp-pills{display:flex;gap:6px;overflow-x:auto;margin-bottom:6px;padding:8px 4px 16px;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}.mp-pills::-webkit-scrollbar{display:none}.mp-pill{flex-shrink:0;padding:8px 16px;border-radius:20px;border:none;background:linear-gradient(145deg,#fde8c8,#f5d5a0);font-size:.72rem;font-weight:800;font-family:inherit;color:#6b3a1a;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);-webkit-tap-highlight-color:transparent;box-shadow:0 3px 0 #d0b078,2px 2px 5px rgba(0,0,0,.25),inset 1px 1px 2px rgba(255,255,255,.6),inset -1px -1px 2px rgba(0,0,0,.08)}.mp-pill:hover{transform:translateY(-2px);background:linear-gradient(145deg,#fff0d8,#fce0b5)}.mp-pill:active{transform:translateY(3px);box-shadow:0 0 0 #d0b078,inset 2px 2px 4px rgba(0,0,0,.15)}.mp-pill.mp-on,.mp-pill.mp-on:hover{background:linear-gradient(145deg,#f97316,#ea580c);color:#fff;transform:translateY(-2px);box-shadow:0 3px 0 #b34508,3px 3px 6px rgba(234,88,12,.4),0 0 14px rgba(234,88,12,.3),inset 2px 2px 4px rgba(253,186,116,.45),inset -2px -2px 4px rgba(0,0,0,.2)}.mp-stats-row{display:flex;align-items:center;gap:10px}.mp-prog{flex:1 1;min-width:0}.mp-track{height:10px;background:linear-gradient(145deg,#3a1a0a,#2a1005);border-radius:6px;overflow:hidden;box-shadow:inset 0 2px 4px rgba(0,0,0,.6),inset 0 -1px 0 rgba(249,115,22,.06)}.mp-fill{height:100%;background:linear-gradient(90deg,#dc2626,#ef4444,#f97316);border-radius:6px;transition:.4s;position:relative}.mp-fill:after{content:"";position:absolute;top:1px;left:3px;right:3px;height:2.5px;background:rgba(255,255,255,.35);border-radius:4px}.mp-info{display:flex;justify-content:space-between;margin-top:4px}.mp-pct{font-size:.85rem;font-weight:800;color:#fb923c;text-shadow:0 0 8px rgba(251,146,60,.5),0 1px 3px rgba(0,0,0,.8)}.mp-lbl{font-size:.68rem;color:#fde8c8;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.8)}.mp-star-badge{display:flex;align-items:center;gap:2px;flex-shrink:0;padding:3px 10px 3px 4px;border-radius:20px;background:linear-gradient(160deg,#f97316,#ea580c);border:none;box-shadow:0 3px 0 #b34508,inset 0 2px 3px rgba(253,200,140,.45),inset 0 -1px 2px rgba(0,0,0,.1)}.mp-star-val{font-size:1.35rem;font-weight:900;color:#fde047;text-shadow:0 0 10px rgba(253,224,71,.5),0 1px 2px rgba(0,0,0,.6);letter-spacing:.02em;line-height:1}.mp-star-sep{color:rgba(255,230,180,.4)}.mp-star-sep,.mp-star-total{font-size:.68rem;font-weight:700}.mp-star-total{color:rgba(255,230,180,.65);text-shadow:0 1px 2px rgba(0,0,0,.5)}.mp-floating-btns{position:fixed;top:calc(112px + env(safe-area-inset-top));right:14px;z-index:100;flex-direction:column;gap:10px;pointer-events:auto}.mp-floating-btns,.mp-hint-btn{display:flex;align-items:center}.mp-hint-btn{justify-content:center;width:44px;height:44px;padding:0;border:none;border-radius:50%;background:linear-gradient(160deg,#f97316,#ea580c);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .1s;box-shadow:0 3px 0 #b34508,inset 0 2px 3px rgba(253,200,140,.45),inset 0 -1px 2px rgba(0,0,0,.1)}.mp-hint-btn:active{transform:translateY(3px);box-shadow:0 0 0 #702808,inset 0 2px 4px rgba(0,0,0,.15)}.mp-music-btn{position:relative;overflow:hidden}.mp-music-off:after{content:"";position:absolute;top:50%;left:50%;width:120%;height:3px;background:#ef4444;border-radius:2px;transform:translate(-50%,-50%) rotate(-45deg);box-shadow:0 1px 2px rgba(0,0,0,.4)}.mp-trail{position:relative;overflow:visible}.mp-svg{top:0;left:0;width:100%;height:100%;pointer-events:none}.mp-node,.mp-svg{position:absolute}.mp-node{display:flex;flex-direction:column;align-items:center;gap:4px;z-index:10}.mp-name{font-weight:700;font-size:.72rem;color:#fde68a;text-align:center;max-width:80px;line-height:1.25;text-shadow:0 1px 3px rgba(127,29,29,1),0 1px 6px rgba(127,29,29,.8)}.mp-ancient .mp-name{color:#1e6fa0;text-shadow:0 1px 2px rgba(255,255,255,.8)}.mp-ancient .mp-name.mp-dim{color:#95a5b5}.mp-ancient .map-node-img{filter:drop-shadow(0 3px 4px rgba(0,0,0,.2)) saturate(1.1) contrast(1.02)}.mp-ancient.map-node--progress:after{background:#93c5fd;box-shadow:0 0 12px 6px rgba(96,165,250,.5),0 0 24px 10px rgba(59,130,246,.3)}.mp-dim{color:#cbd5e1;font-weight:600}.map-node-icon{position:relative;width:65px;height:65px}.map-node-img{width:65px;height:65px;object-fit:contain;border-radius:14px;filter:drop-shadow(0 12px 12px rgba(0,0,0,.6)) drop-shadow(0 4px 4px rgba(0,0,0,.5)) saturate(1.15) contrast(1.05);transition:transform .25s cubic-bezier(.34,1.56,.64,1),filter .25s}.map-node--locked .map-node-img{filter:grayscale(100%) brightness(.8) contrast(1.1) drop-shadow(0 8px 8px rgba(0,0,0,.4));opacity:1}.mp-shake{animation:clayShake .5s ease-in-out}@keyframes clayShake{0%,to{transform:translateX(-50%)}15%{transform:translateX(calc(-50% + 6px))}30%{transform:translateX(calc(-50% - 5px))}45%{transform:translateX(calc(-50% + 4px))}60%{transform:translateX(calc(-50% - 3px))}75%{transform:translateX(calc(-50% + 2px))}}.mp-locked-tap{cursor:not-allowed;-webkit-tap-highlight-color:transparent}.map-node--progress .map-node-img{filter:saturate(1.2) brightness(1.1);animation:clayBreathe 2s ease-in-out infinite;z-index:1;position:relative}.map-node--progress:after{content:"";position:absolute;bottom:2px;left:50%;transform:translateX(-50%);width:40px;height:12px;border-radius:50%;background:#fde047;box-shadow:0 0 16px 8px #f97316,0 0 30px 12px #ea580c;filter:blur(4px);z-index:0;pointer-events:none;animation:lavaPulse 2s ease-in-out infinite}@keyframes lavaPulse{0%,to{opacity:.5;transform:translateX(-50%) scale(1)}50%{opacity:.9;transform:translateX(-50%) scale(1.2)}}@keyframes clayBreathe{0%,to{transform:scale(1) translateY(0);filter:drop-shadow(0 12px 12px rgba(0,0,0,.6)) drop-shadow(0 4px 4px rgba(0,0,0,.5)) saturate(1.15) contrast(1.05)}50%{transform:scale(1.02) translateY(-2px);filter:drop-shadow(0 14px 12px rgba(0,0,0,.55)) drop-shadow(0 5px 5px rgba(0,0,0,.4)) saturate(1.18) contrast(1.08)}}.map-node-sheen{position:absolute;top:2px;left:2px;width:30px;height:20px;border-radius:12px 12px 50% 4px;background:linear-gradient(135deg,rgba(255,255,255,.55),rgba(255,255,255,0));z-index:3;pointer-events:none;animation:sheenPulse 2.8s ease-in-out infinite}@keyframes sheenPulse{0%,to{opacity:.7}50%{opacity:1}}.map-node--complete .map-node-img{filter:sepia(.8) saturate(3.5) hue-rotate(-15deg) brightness(1.2) contrast(1.15) drop-shadow(0 10px 10px rgba(139,69,19,.5));border-radius:14px}.map-node--complete .map-node-icon:before{content:"";position:absolute;inset:0;border-radius:14px;background:linear-gradient(135deg,rgba(255,215,0,.25),rgba(255,235,130,.15) 30%,transparent 50%,rgba(255,215,0,.1) 70%,rgba(218,165,32,.2));z-index:3;pointer-events:none;animation:goldenShimmer 3s ease-in-out infinite}@keyframes goldenShimmer{0%,to{opacity:.6}50%{opacity:1}}.map-node-seal{position:absolute;bottom:-6px;right:-6px;width:28px;height:28px;z-index:4;filter:drop-shadow(0 1px 2px rgba(0,0,0,.2));animation:sealPop .4s cubic-bezier(.34,1.56,.64,1)}@keyframes sealPop{0%{transform:scale(0) rotate(-30deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.mp-node--complete.mp-clickable:active .map-node-img{animation:clayJiggle .5s ease-in-out}@keyframes clayJiggle{0%,to{transform:rotate(0) scale(1)}15%{transform:rotate(-6deg) scale(1.08)}30%{transform:rotate(5deg) scale(1.06)}45%{transform:rotate(-4deg) scale(1.04)}60%{transform:rotate(3deg) scale(1.02)}75%{transform:rotate(-1deg) scale(1.01)}}.mp-node-ribbon-wrap{position:relative;display:flex;align-items:center;justify-content:center;z-index:5;margin-bottom:-6px;width:72px}.mp-node-ribbon-img{width:100%;height:auto;display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,.35))}.mp-node-ribbon-stars{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;gap:2px;pointer-events:none}.mp-node--complete.mp-clickable:active:after,.mp-node--complete.mp-clickable:active:before{content:"✦";position:absolute;font-size:.6rem;color:#eab308;z-index:5;animation:sparkleFloat .6s ease-out forwards}.mp-node--complete.mp-clickable:active:before{top:0;left:0}.mp-node--complete.mp-clickable:active:after{top:-4px;right:0;animation-delay:.1s}@keyframes sparkleFloat{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(-8px,-16px) scale(1.5)}}.polity-node--complete .map-node-img{filter:sepia(.7) saturate(3) hue-rotate(-10deg) brightness(1.15) contrast(1.1) drop-shadow(0 4px 6px rgba(139,69,19,.4));border-radius:14px}.polity-node--complete:before{content:"";position:absolute;inset:0;border-radius:14px;background:linear-gradient(135deg,rgba(255,215,0,.25),rgba(255,235,130,.15) 30%,transparent 50%,rgba(255,215,0,.1) 70%,rgba(218,165,32,.2));z-index:3;pointer-events:none;animation:goldenShimmer 3s ease-in-out infinite}.mp-clickable{cursor:pointer;-webkit-tap-highlight-color:transparent}.mp-clickable:active{transform:translateX(-50%) scale(.95)!important}.node-pulse{animation:iconPulse 2s ease-in-out infinite}@keyframes iconPulse{0%,to{filter:drop-shadow(0 0 0 rgba(13,148,136,.1))}50%{filter:drop-shadow(0 0 12px rgba(13,148,136,.5))}}.map-node--skipped .map-node-img{filter:drop-shadow(0 12px 12px rgba(0,0,0,.6)) drop-shadow(0 4px 4px rgba(0,0,0,.5)) saturate(1.15) contrast(1.05);opacity:1;z-index:1;position:relative}.map-node--skipped:after{display:none}.mp-node--skipped{cursor:pointer;-webkit-tap-highlight-color:transparent}.mo-skip{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px;margin-top:8px;border-radius:12px;border:1.5px dashed rgba(251,191,36,.2);background:rgba(251,191,36,.05);font-size:.75rem;font-weight:600;color:#fde68a;cursor:pointer;font-family:inherit;transition:.2s}.mo-skip:active{transform:scale(.97);background:rgba(251,191,36,.1)}.mo-skip-badge{text-align:center;padding:8px;margin-top:8px;border-radius:10px;background:rgba(251,191,36,.06);font-size:.72rem;font-weight:600;color:#fde68a}@keyframes candySwirl{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.mo-card.mo-hint{position:relative;background:linear-gradient(135deg,#ea580c,#fcd34d,#f43f5e,#fb923c,#ea580c);background-size:400% 400%;animation:candySwirl 10s ease infinite;box-shadow:inset 4px 4px 10px rgba(255,255,255,.3),inset -4px -4px 12px rgba(154,52,18,.6),0 6px 0 #9a3412,0 16px 30px rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.1);border-radius:28px}.mo-card.mo-hint .mo-title{color:#fff;text-shadow:0 1px 2px rgba(154,52,18,.8);font-size:1.15rem;font-weight:800;text-align:left;margin-bottom:0}.mo-card.mo-hint .mo-close{position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;cursor:pointer;background:rgba(255,255,255,.2);box-shadow:inset 1px 1px 2px rgba(255,255,255,.4),inset -1px -1px 2px rgba(154,52,18,.4),0 2px 4px rgba(154,52,18,.3);color:#fff;padding:0;transition:.1s}.mo-card.mo-hint .mo-close:active{transform:scale(.9);background:rgba(255,255,255,.3)}.mo-hint-content{display:flex;flex-direction:column;gap:12px;margin-top:18px}.mo-hint-item{display:flex;align-items:flex-start;gap:12px;background:#fffbeb;padding:12px 14px;border-radius:16px;box-shadow:inset 2px 2px 4px #ffffff,inset -2px -2px 6px rgba(217,119,6,.3),0 4px 8px rgba(0,0,0,.15);border:none}.mo-hint-item img{flex-shrink:0;margin-top:2px;filter:drop-shadow(0 2px 4px rgba(217,119,6,.3))}.mo-hint-item strong{display:block;font-size:.9rem;font-weight:800;color:#9a3412;margin-bottom:3px;letter-spacing:.02em;text-shadow:none}.mo-hint-item p{font-size:.75rem;color:#c2410c;line-height:1.4;margin:0;font-weight:600}.mo-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mo-scene{perspective:1000px;width:calc(100% - 32px);max-width:420px;max-height:55vh;margin:0 auto;animation:popIn .35s cubic-bezier(.175,.885,.32,1.275)}.mo-card-inner{position:relative;width:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.mo-flipped{transform:rotateY(180deg)}.mo-card{backface-visibility:hidden;width:100%;background:linear-gradient(170deg,#374151,#1f2937,#111827);border-radius:28px;padding:24px 16px;box-shadow:0 -3px 0 #4b5563,0 -6px 0 #374151,0 -20px 40px rgba(0,0,0,.3),inset 0 2px 0 rgba(255,255,255,.05);border-top:1px solid rgba(255,255,255,.08)}.mo-card-front{position:relative}.mo-card-back{position:absolute;top:0;left:0;height:100%;transform:rotateY(180deg);display:flex;flex-direction:column}@keyframes popIn{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.mo-close-punch{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;border:none;background:transparent;font-size:1rem;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:inherit;color:#6b7280;padding:0;transition:.1s;z-index:20}.mo-close-punch:active{transform:scale(.9);color:#ef4444}.mo-close-back{width:auto;padding:0 12px;border-radius:12px;font-weight:700;font-size:.75rem;color:#d1d5db;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1)}.mo-header-compact{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-right:20px}.mo-header-icon-small{width:50px;height:50px;flex-shrink:0;position:relative}.mo-header-icon-small .map-node-icon,.mo-header-icon-small .map-node-img{width:50px!important;height:50px!important;margin-top:0!important;box-shadow:none!important;filter:none!important;background:transparent!important;border:none!important}.mo-header-icon-small .map-node-icon:after,.mo-header-icon-small .map-node-icon:before,.mo-header-icon-small .map-node-sheen{display:none!important}.mo-trophy-wrap-small{position:relative;width:50px;height:50px;flex-shrink:0}.mo-header-text-col{flex:1 1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:4px}.mo-header-actions-col{display:flex;flex-direction:column;gap:8px;flex-shrink:0}.mo-info-btn{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:12px;border:none;background:linear-gradient(145deg,#65a30d,#4d7c0f);color:#fff;font-size:1.1rem;cursor:pointer;box-shadow:0 2px 0 #3f6212,0 4px 6px rgba(0,0,0,.15),inset 1px 1px 2px rgba(255,255,255,.3);text-shadow:0 1px 1px rgba(0,0,0,.3);transition:.1s}.mo-info-btn:active{transform:translateY(2px);box-shadow:0 0 0 #3f6212}.mo-notes-content{background:rgba(255,255,255,.05);box-shadow:inset 0 1px 0 rgba(255,255,255,.04),inset 0 -1px 0 rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.06);padding:20px;border-radius:18px;font-size:clamp(.72rem,2vw,.9rem);color:#d1d5db;line-height:1.6;font-weight:600;flex-grow:1;overflow-y:auto;max-height:45vh;scrollbar-width:none;-ms-overflow-style:none}.mo-notes-content::-webkit-scrollbar{display:none}.mo-header-icon{margin-top:-75px;z-index:10;filter:drop-shadow(0 6px 12px rgba(0,0,0,.2));flex-shrink:0;width:95px;height:95px;position:relative}.mo-header-icon .map-node-img{width:95px!important;height:95px!important}.mo-header-icon .map-node-icon{width:95px;height:95px}.mo-header-icon .map-node-img{animation:none!important}.mo-header-icon .map-node-icon:after,.mo-header-icon .map-node-icon:before,.mo-header-icon .map-node-sheen{display:none!important;animation:none!important}.mo-header-icon .map-node-seal{animation:none!important}.mo-trophy-wrap{position:relative;margin-top:-65px;z-index:10;flex-shrink:0;width:95px;height:95px}.mo-trophy-icon{animation:trophyPulse 1.5s ease-in-out infinite;filter:drop-shadow(0 4px 12px rgba(234,179,8,.4))}@keyframes trophyPulse{0%,to{transform:scale(1);filter:drop-shadow(0 4px 12px rgba(234,179,8,.3))}50%{transform:scale(1.08);filter:drop-shadow(0 6px 20px rgba(234,179,8,.6))}}.mo-confetti{position:absolute;width:6px;height:6px;border-radius:1px;background:hsl(var(--hue,0),80%,60%);top:50%;left:50%;animation:confettiBurst 2s ease-out infinite;opacity:0}@keyframes confettiBurst{0%{transform:translate(-50%,-50%) rotate(0deg);opacity:1}30%{opacity:1}to{transform:translate(calc(-50% + cos(calc(var(--ci) * 30deg)) * 60px),calc(-50% + sin(calc(var(--ci) * 30deg)) * 60px - 30px)) rotate(calc(var(--ci) * 90deg));opacity:0}}.mo-title{font-size:1.1rem;font-weight:800;color:#e5e7eb;margin:0;text-shadow:0 1px 2px rgba(0,0,0,.4);line-height:1.2;word-wrap:break-word;white-space:normal}.mo-sub{font-size:.75rem;margin:2px 0 0}.mo-hint-desc,.mo-sub{color:#9ca3af;font-weight:600}.mo-hint-desc{margin:0 0 4px;padding:10px 14px;font-size:.72rem;line-height:1.5;background:rgba(255,255,255,.04);border-radius:12px;border:1px solid rgba(255,255,255,.06);box-shadow:inset 0 1px 0 rgba(255,255,255,.03)}.mo-sets{display:flex;flex-direction:column;gap:8px}.mo-set{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-radius:16px;border:none;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);box-shadow:inset 0 1px 0 rgba(255,255,255,.04),inset 0 -1px 0 rgba(0,0,0,.2)}.mo-set-done{border-color:rgba(255,255,255,.08)}.mo-set-cur{background:rgba(13,148,136,.1);border-color:rgba(13,148,136,.2);box-shadow:inset 0 1px 0 rgba(13,148,136,.06),0 0 0 1px rgba(13,148,136,.15)}.mo-set-lock{opacity:.45}.mo-star-ribbon{display:inline-flex;padding:1px 6px;border-radius:6px;font-size:.45rem;font-weight:800;color:#fff;letter-spacing:.3px;text-transform:uppercase;margin-left:4px;box-shadow:inset 0 1px 0 rgba(255,255,255,.35),0 1px 3px rgba(0,0,0,.2);text-shadow:0 1px 1px rgba(0,0,0,.4);vertical-align:middle}.mo-set-done-gold{background:rgba(251,191,36,.08);box-shadow:inset 0 1px 0 rgba(251,191,36,.06),inset 0 -1px 0 rgba(0,0,0,.15)}.mo-set-done-silver{background:rgba(148,163,184,.08);box-shadow:inset 0 1px 0 rgba(148,163,184,.06),inset 0 -1px 0 rgba(0,0,0,.15)}.mo-set-done-bronze{background:rgba(180,120,40,.08);box-shadow:inset 0 1px 0 rgba(180,120,40,.06),inset 0 -1px 0 rgba(0,0,0,.15)}.mo-set-info{gap:10px}.mo-set-icon,.mo-set-info{display:flex;align-items:center}.mo-set-icon{font-size:1rem;width:30px;height:30px;justify-content:center;border-radius:10px;background:rgba(255,255,255,.06);box-shadow:inset 1px 1px 2px rgba(0,0,0,.15);font-weight:800;flex-shrink:0}.mo-set-done .mo-set-icon{background:rgba(22,163,74,.15);color:#4ade80}.mo-set-cur .mo-set-icon{background:rgba(13,148,136,.1);color:#2dd4bf}.mo-tier-name{font-size:.82rem;font-weight:700;color:#f3f4f6;margin:0;line-height:1.2;text-shadow:0 1px 2px rgba(0,0,0,.3)}.mo-set-desc{font-size:.68rem;color:#9ca3af;margin:2px 0 0}.mo-play{padding:8px 18px;border-radius:12px;border:none;background:linear-gradient(145deg,#65a30d,#4d7c0f);color:#fff;font-weight:800;font-size:.78rem;font-family:inherit;cursor:pointer;box-shadow:0 3px 0 #3f6212,0 4px 8px rgba(0,0,0,.25),inset 1px 1px 2px rgba(255,255,255,.25);text-shadow:0 1px 1px rgba(0,0,0,.3);transition:.1s}.mo-play:active{transform:translateY(3px);box-shadow:0 0 0 #3f6212}.mo-overlay--force{background:rgba(0,0,0,.62)}@keyframes moPlayPulse{0%{transform:translateY(0) scale(1);box-shadow:0 3px 0 #3f6212,0 4px 8px rgba(0,0,0,.25),inset 1px 1px 2px rgba(255,255,255,.25),0 0 0 0 rgba(101,163,13,0)}55%{transform:translateY(-1px) scale(1.03);box-shadow:0 3px 0 #3f6212,0 10px 22px rgba(0,0,0,.35),inset 1px 1px 2px rgba(255,255,255,.3),0 0 0 10px rgba(101,163,13,.18)}to{transform:translateY(0) scale(1);box-shadow:0 3px 0 #3f6212,0 4px 8px rgba(0,0,0,.25),inset 1px 1px 2px rgba(255,255,255,.25),0 0 0 0 rgba(101,163,13,0)}}.mo-play--onboard{animation:moPlayPulse 1.1s ease-in-out infinite;position:relative;z-index:50}.mo-replay{padding:8px 18px;border-radius:12px;border:none;background:linear-gradient(145deg,#6b7280,#4b5563);box-shadow:0 3px 0 #374151,0 4px 8px rgba(0,0,0,.25),inset 1px 1px 2px rgba(255,255,255,.15);color:#fff;font-weight:800;font-size:.72rem;font-family:inherit;cursor:pointer;text-shadow:0 1px 1px rgba(0,0,0,.3);letter-spacing:.3px;transition:.1s}.mo-replay:active{transform:translateY(3px);box-shadow:0 0 0 #374151}.mo-complete-badge{text-align:center;margin-top:16px;padding:14px;background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.2);border-radius:14px;font-weight:800;font-size:.88rem;color:#fde68a;box-shadow:inset 0 1px 0 rgba(251,191,36,.08),0 0 15px rgba(251,191,36,.05);text-shadow:0 1px 2px rgba(0,0,0,.3)}.mq-quiz{display:flex;flex-direction:column;min-height:100vh}.mq-topbar{gap:10px;margin-bottom:16px}.mq-close,.mq-topbar{display:flex;align-items:center}.mq-close{width:32px;height:32px;border-radius:10px;border:none;background:rgba(0,0,0,.06);font-size:.85rem;cursor:pointer;flex-shrink:0;font-family:inherit;justify-content:center}.mq-pbar{flex:1 1;height:6px;background:rgba(0,0,0,.08);border-radius:3px;overflow:hidden}.mq-pfill{height:100%;background:#0d9488;border-radius:3px;transition:.3s}.mq-count{font-size:.72rem;font-weight:700;color:#78716c;white-space:nowrap}.mq-setlabel{font-size:.68rem;font-weight:800;color:#0d9488;letter-spacing:.06em;margin-bottom:16px;text-transform:uppercase}.mq-question{font-size:.95rem;font-weight:600;line-height:1.65;margin-bottom:20px;color:#1e293b}.mq-opts{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.mq-opt{display:flex;align-items:flex-start;gap:10px;width:100%;text-align:left;background:#fff;border:2px solid #e8eaed;padding:13px 14px;border-radius:12px;font-size:.84rem;font-weight:500;font-family:inherit;cursor:pointer;transition:.15s;color:#1e293b;-webkit-tap-highlight-color:transparent}.mq-opt:active{transform:scale(.98)}.mq-sel{border-color:#0d9488;background:#f0fdfa;box-shadow:0 0 0 2px rgba(13,148,136,.12)}.mq-optletter{width:24px;height:24px;border-radius:7px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.72rem;color:#64748b;flex-shrink:0}.mq-sel .mq-optletter{background:#0d9488;color:#fff}.mq-nav{display:flex;gap:8px;margin-top:auto;padding-bottom:16px}.mq-btn{flex:1 1;padding:14px;border-radius:12px;font-weight:700;font-size:.85rem;font-family:inherit;border:1.5px solid #e2e8f0;background:#fff;color:#1e293b;cursor:pointer;transition:.15s}.mq-btn:disabled{opacity:.35}.mq-next{background:#0d9488;color:#fff;border-color:#0d9488}.mq-submit{background:#eab308;color:#fff;border-color:#eab308}.mr-exit-btn{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:10px;border:none;background:linear-gradient(145deg,#ef4444,#dc2626);color:#fff;font-size:.85rem;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:20;box-shadow:0 2px 0 #b91c1c,0 3px 6px rgba(0,0,0,.15),inset 1px 1px 2px rgba(255,255,255,.3);transition:.1s}.mr-exit-btn:active{transform:translateY(2px);box-shadow:0 0 0 #b91c1c}.mo-result{border-radius:24px;max-height:90vh;overflow:visible!important;position:relative;padding-bottom:16px}.mr-banner{text-align:center;padding:24px 16px;margin:-24px -16px 16px;border-radius:24px 24px 16px 16px}.mr-pass{background:linear-gradient(135deg,rgba(22,163,74,.12),rgba(13,148,136,.1))}.mr-fail{background:linear-gradient(135deg,rgba(239,68,68,.12),rgba(220,38,38,.08))}.mr-emoji{font-size:2rem;display:block;margin-bottom:8px}.mr-banner h3{font-size:1.1rem;font-weight:800;margin:0;color:#e5e7eb}.mr-banner p{font-size:.78rem;color:#9ca3af;margin:4px 0 0}.mr-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}.mr-stat{text-align:center;padding:12px 6px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:12px}.mr-val{display:block;font-size:1.1rem;font-weight:800;color:#e5e7eb}.mr-label{font-size:.62rem;color:#9ca3af;font-weight:600}.mr-actions{display:flex;gap:8px;margin-bottom:0}.mr-btn{flex:1 1;padding:12px;border-radius:12px;font-weight:800;font-size:.82rem;font-family:inherit;border:none;cursor:pointer;transition:.1s}.mr-btn:active{transform:translateY(3px)}.mr-btn-pri{background:linear-gradient(145deg,#65a30d,#4d7c0f);color:#fff;box-shadow:0 3px 0 #3f6212,0 4px 8px rgba(0,0,0,.25),inset 1px 1px 2px rgba(255,255,255,.25);text-shadow:0 1px 1px rgba(0,0,0,.3)}.mr-btn-pri:active{box-shadow:0 0 0 #3f6212}.mr-btn-sec{background:rgba(255,255,255,.05);color:#d1d5db;border:1px solid rgba(255,255,255,.08)}.mr-btn-replay{background:linear-gradient(145deg,#6b7280,#4b5563);color:#fff;text-shadow:0 1px 1px rgba(0,0,0,.3);box-shadow:0 3px 0 #374151,0 4px 8px rgba(0,0,0,.25),inset 1px 1px 2px rgba(255,255,255,.15)}.mr-btn-replay:active{box-shadow:0 0 0 #374151}.mr-close{width:100%;padding:10px;border:none;background:transparent;color:#94a3b8;font-weight:600;font-size:.78rem;font-family:inherit;cursor:pointer;margin-top:4px}.mr-details{max-height:300px;overflow-y:auto;margin-bottom:8px}.mr-q{padding:12px;border-radius:10px;margin-bottom:6px;font-size:.78rem;line-height:1.5}.mr-q-ok{background:rgba(22,163,74,.08);border-left:3px solid #22c55e}.mr-q-wrong{background:rgba(239,68,68,.08);border-left:3px solid #ef4444}.mr-q-text{margin:0 0 4px;font-weight:600;color:#e5e7eb}.mr-q-ans{margin:0;color:#9ca3af}.mr-q-correct{margin:0;color:#4ade80}.mr-q-exp{margin:6px 0 0;padding:8px;background:rgba(255,255,255,.04);border-radius:6px;color:#9ca3af;font-size:.72rem}.page-quiz{--bg:#131F22;--card:#1a2d31;--card-border:rgba(255,255,255,0.06);--text:#f0fdf4;--muted:#8aa3a8;background-color:var(--bg);color:var(--text);margin:-20px -16px calc(-1 * (var(--tab-h) + 16px));padding:20px 16px calc(var(--tab-h) + 24px);min-height:100vh}.page-title{font-size:1.5rem;font-weight:800;margin-bottom:16px}.filter-scroll{display:flex;gap:8px;margin-bottom:20px;overflow-x:auto}.filter-scroll::-webkit-scrollbar{display:none}.filter-chip{flex-shrink:0;padding:8px 18px;border-radius:20px;border:1.5px solid var(--card-border);background:var(--card);font-size:.8rem;font-weight:700;font-family:inherit;color:var(--muted);cursor:pointer;transition:.2s}.filter-active{background:var(--primary);color:#fff;border-color:var(--primary)}.featured-quiz{background:linear-gradient(135deg,#f97316,#ef4444);padding:24px;border-radius:20px;color:#fff;margin-bottom:24px;box-shadow:0 8px 28px rgba(239,68,68,.2)}.featured-badge{font-size:.65rem;font-weight:800;letter-spacing:.1em;background:rgba(255,255,255,.2);display:inline-block;padding:4px 10px;border-radius:6px;margin-bottom:10px}.featured-title{font-size:1.2rem;font-weight:800;margin:0}.featured-meta{font-size:.82rem;opacity:.8;margin:4px 0 16px}.featured-bottom{display:flex;justify-content:space-between;align-items:center}.featured-start{background:rgba(255,255,255,.2);padding:10px 20px;border-radius:10px;font-weight:800;font-size:.88rem;text-decoration:none;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.featured-timer{font-size:.75rem;opacity:.7}.quiz-section{margin-bottom:24px}.quiz-section h3{font-size:1rem;font-weight:800;margin-bottom:12px}.practice-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px}.practice-scroll::-webkit-scrollbar{display:none}.practice-card{flex-shrink:0;width:150px;background:var(--card);border-radius:14px;padding:16px;box-shadow:0 2px 8px rgba(0,0,0,.15);border:1px solid var(--card-border)}.practice-card h4{font-size:.85rem;font-weight:700;margin:0 0 4px}.practice-card p{font-size:.72rem;color:var(--muted);margin:0 0 8px}.difficulty-badge{font-size:.65rem;font-weight:800;padding:3px 8px;border-radius:6px}.past-quiz-row{display:flex;justify-content:space-between;align-items:center;background:var(--card);padding:14px 16px;border-radius:14px;margin-bottom:8px;box-shadow:0 1px 4px rgba(0,0,0,.15);border:1px solid var(--card-border)}.past-info h4{font-size:.88rem;font-weight:700;margin:0 0 2px}.past-info p{font-size:.72rem;color:var(--muted)}.past-score{text-align:right}.score-val{font-size:1rem;font-weight:800;color:var(--primary);display:block}.score-acc{font-size:.7rem;color:var(--muted)}.empty-state{font-size:.82rem;color:var(--muted,#8aa3a8);text-align:center;padding:24px 16px;background:var(--card,#1a2d31);border-radius:14px;border:1px dashed var(--card-border,rgba(255,255,255,.08))}.pyp-sets{display:flex;flex-direction:column;gap:8px}.pyp-set-row{display:flex;align-items:center;justify-content:space-between;background:var(--card);border:1px solid var(--card-border);border-radius:14px;padding:14px 16px;text-decoration:none;color:var(--text);transition:transform .15s;-webkit-tap-highlight-color:transparent}.pyp-set-row:active{transform:scale(.98)}.pyp-set-info{display:flex;flex-direction:column;gap:2px}.pyp-set-label{font-size:.88rem;font-weight:700}.pyp-set-count{font-size:.72rem;color:var(--muted)}.pyp-set-arrow{font-size:1rem;color:var(--muted);font-weight:700}.pyp-empty{text-align:center;padding:40px 20px;color:var(--muted);font-size:.88rem}.pyp-set-actions{display:flex;gap:6px;flex-shrink:0}.pyp-btn{padding:6px 14px;border-radius:8px;font-size:.72rem;font-weight:700;font-family:inherit;text-decoration:none;white-space:nowrap;transition:transform .15s;-webkit-tap-highlight-color:transparent}.pyp-btn:active{transform:scale(.95)}.pyp-btn-attempt{background:rgba(99,102,241,.2);color:#a5b4fc}.pyp-btn-reattempt{background:rgba(245,158,11,.2);color:#fcd34d}.pyp-btn-reattempt-outline{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.15);color:#cbd5e1;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.pyp-btn-solutions{background:rgba(20,184,166,.2);color:#5eead4}.pyp-btn-solutions-clay{background:#58cc02;color:#ffffff;box-shadow:0 3px 0 #58a700;text-transform:uppercase;font-weight:800}.pyp-btn-solutions-clay:active{transform:translateY(3px) scale(.98);box-shadow:0 0 0 transparent!important}.page-library{--bg:#131F22;--card:#1a2d31;--card-border:rgba(255,255,255,0.06);--text:#f0fdf4;--muted:#8aa3a8;background-color:var(--bg);color:var(--text);margin:-20px -16px calc(-1 * (var(--tab-h) + 16px));padding:20px 16px calc(var(--tab-h) + 24px);min-height:100vh;padding-bottom:calc(var(--tab-h) + 24px)}.library-search{display:flex;align-items:center;background:var(--card);border-radius:14px;padding:12px 16px;margin-bottom:16px;box-shadow:0 1px 6px rgba(0,0,0,.15);border:1px solid var(--card-border);gap:10px}.search-icon{font-size:1rem;opacity:.5}.search-input{border:none;outline:none;flex:1 1;font-size:.9rem;font-family:inherit;background:transparent;color:var(--text)}.library-card{display:flex;align-items:center;background:var(--card);border-radius:16px;padding:16px;margin-bottom:10px;text-decoration:none;color:inherit;box-shadow:0 2px 10px rgba(0,0,0,.15);border:1px solid var(--card-border);gap:14px;transition:.15s;-webkit-tap-highlight-color:transparent}.library-card:active{transform:scale(.98)}.library-card-wrap.library-card:active{transform:none}.library-card-main{flex:1 1;min-width:0;display:flex;align-items:center;gap:14px;text-decoration:none;color:inherit;-webkit-tap-highlight-color:transparent}.library-card-main:active{transform:scale(.98)}.library-card-notes-btn{flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 10px;min-height:44px;min-width:76px;border-radius:12px;border:1px solid var(--card-border);background:rgba(148,163,184,.08);font-family:inherit;font-size:.72rem;font-weight:600;color:var(--text);cursor:default;-webkit-tap-highlight-color:transparent}.library-card-notes-placeholder{font-size:.62rem;font-weight:500;color:var(--muted);line-height:1.2;text-align:center}a.library-card-notes-btn{text-decoration:none;color:inherit;cursor:pointer}.library-card-notes-btn--link:active{transform:scale(.97)}.library-card-notes-placeholder--open{color:rgba(234,88,12,.85)}.library-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.library-icon-img{width:32px;height:32px;object-fit:contain}.library-info{flex:1 1}.library-info h3{font-size:.95rem;font-weight:700;margin:0 0 2px}.library-info p{font-size:.75rem;color:var(--muted)}.library-q-badge{font-size:.7rem;font-weight:800;padding:4px 10px;border-radius:8px;flex-shrink:0}.library-progress-ring{width:40px;height:40px;position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0}.progress-ring-small{width:100%;height:100%;transform:rotate(-90deg);position:absolute}.subtopic-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.subtopic-header h1{font-size:1.2rem;font-weight:800}.back-btn{width:36px;height:36px;border-radius:10px;background:var(--card);display:flex;align-items:center;justify-content:center;text-decoration:none;color:var(--text);font-weight:700;box-shadow:0 1px 4px rgba(0,0,0,.06);font-size:1rem;flex-shrink:0;border:none;cursor:pointer}.subtopic-card{background:var(--card);border-radius:16px;padding:16px;margin-bottom:10px;box-shadow:0 2px 8px rgba(0,0,0,.04)}.subtopic-card h3{font-size:.92rem;font-weight:700;margin:0 0 4px}.subtopic-meta{font-size:.75rem;color:var(--muted);margin:0 0 12px}.subtopic-actions{display:flex;gap:8px;flex-wrap:wrap}.action-btn{padding:10px 18px;border-radius:10px;font-weight:700;font-size:.82rem;text-decoration:none;transition:.2s;display:inline-block;-webkit-tap-highlight-color:transparent}.action-pre{background:#1e293b;color:#fff}.action-mains{background:var(--primary);color:#fff}.group-bar{background:var(--card);border-radius:16px;margin-bottom:10px;box-shadow:0 2px 8px rgba(0,0,0,.15);border:1px solid var(--card-border);overflow:hidden;transition:box-shadow .25s}.group-bar--open{box-shadow:0 4px 16px rgba(99,102,241,.1)}.group-bar-header{gap:12px;width:100%;padding:14px 16px;background:none;border:none;cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent}.group-bar-header,.group-icon{display:flex;align-items:center}.group-icon{font-size:1.5rem;flex-shrink:0;width:38px;height:38px;justify-content:center;border-radius:10px;background:#3a484c}.group-info{flex:1 1;min-width:0}.group-title{display:block;font-size:.88rem;font-weight:700;color:var(--text)}.group-count{display:block;font-size:.72rem;color:var(--muted);margin-top:2px}.group-chevron{font-size:1.1rem;color:var(--muted);transition:transform .25s;flex-shrink:0}.group-chevron--open{transform:rotate(180deg)}.group-dropdown{padding:0 12px 12px;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.subtopic-row{background:rgba(255,255,255,.06);border-radius:12px;padding:10px;margin-bottom:6px}.subtopic-row:last-child{margin-bottom:0}.subtopic-row-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.subtopic-row-title{font-size:.78rem;font-weight:700;color:var(--text)}.subtopic-row-count{font-size:.65rem;color:#f0fdf4;background:rgba(255,255,255,.08);padding:2px 6px;border-radius:6px}.subtopic-row-actions{display:flex;gap:5px;flex-wrap:nowrap}.action-chip{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:4px 8px;border-radius:10px;font-weight:800;font-size:.7rem;text-decoration:none;background:rgba(255,255,255,.08);color:#ffffff;transition:transform .18s cubic-bezier(.34,1.56,.64,1),filter .18s;-webkit-tap-highlight-color:transparent;position:relative}.action-chip:hover{transform:scale(1.18);filter:drop-shadow(0 2px 6px rgba(0,0,0,.18))}.action-chip:active{transform:scale(.88)}.chip-icon{width:28px;height:28px;object-fit:contain;flex-shrink:0;transition:transform .15s}.chip-label{display:none;color:#ffffff!important}.action-chip.action-pre{box-shadow:inset 0 0 0 1px #38bdf8}.action-chip.action-mains,.action-chip.action-pre{background:rgba(255,255,255,.03);color:#ffffff!important}.action-chip.action-mains{box-shadow:inset 0 0 0 1px #fb923c}.action-chip.action-attempted{background:#58cc02!important;color:#ffffff!important;box-shadow:0 4px 0 #58a700!important;border-color:#58cc02!important}.action-chip.action-paused{background:#10b981!important;color:#ffffff!important;box-shadow:0 4px 0 #059669!important;border-color:#10b981!important}.action-chip.action-solutions{background:rgba(255,255,255,.03);color:#ffffff!important;box-shadow:inset 0 0 0 1px #34d399}.action-chip.action-history{background:rgba(255,255,255,.03);color:#ffffff!important;box-shadow:inset 0 0 0 1px #a1a1aa}.quiz-action-stack{flex-direction:row;width:100%;margin-top:auto;gap:4px}.quiz-action-stack,.quiz-clay-btn{display:flex;box-sizing:border-box}.quiz-clay-btn{flex:1 1;min-width:0;height:20px;line-height:1;align-items:center;justify-content:center;font-size:.45rem;font-weight:800;padding:0;border-radius:6px;border:none;text-transform:uppercase;text-decoration:none;text-align:center;transition:transform .1s,box-shadow .1s,background .1s;white-space:nowrap;overflow:hidden}.quiz-clay-btn:active{transform:translateY(3px);box-shadow:0 0 0 transparent!important}.clay-duo-green{background:#58cc02;color:#ffffff;box-shadow:0 3px 0 #58a700}.clay-duo-grey{background:#64748b;color:#ffffff;box-shadow:0 3px 0 #334155}.group-icon-img{width:38px;height:38px;border-radius:10px;object-fit:cover;flex-shrink:0;transition:transform .2s}.group-bar-header:hover .group-icon-img{transform:scale(1.12)}.group-bar-header:active .group-icon-img{transform:scale(.95)}.ungrouped-subtopics{background:var(--card);border-radius:16px;padding:12px;margin-bottom:10px;box-shadow:0 2px 8px rgba(0,0,0,.04)}.solutions-tabs{display:flex;gap:8px;margin-bottom:16px}.sol-tab{flex:1 1;padding:10px;border-radius:10px;font-weight:700;font-size:.85rem;border:2px solid var(--border);background:var(--card);color:var(--muted);cursor:pointer;transition:.2s}.sol-tab--active{background:var(--primary);color:#fff;border-color:var(--primary)}.sol-tab:disabled{opacity:.4;cursor:not-allowed}.solutions-list{display:flex;flex-direction:column;gap:12px}.solution-card{background:var(--card);border-radius:14px;padding:16px;box-shadow:0 2px 8px rgba(0,0,0,.04);display:flex;gap:12px}.solution-qnum{font-weight:800;font-size:.75rem;color:var(--primary);background:rgba(99,102,241,.08);width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.solution-body{flex:1 1;min-width:0}.solution-body>div:first-child{font-size:.85rem;font-weight:600;line-height:1.5;margin-bottom:10px}.solution-options{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.solution-opt{font-size:.78rem;padding:6px 10px;border-radius:8px;background:var(--bg);display:flex;align-items:center;gap:8px}.solution-opt--correct{background:rgba(16,185,129,.12);color:#059669;font-weight:700}.solution-opt-letter{font-weight:800;font-size:.7rem;width:20px;height:20px;border-radius:5px;display:flex;align-items:center;justify-content:center;background:var(--card);flex-shrink:0}.solution-opt--correct .solution-opt-letter{background:#059669;color:#fff}.solution-answer{font-size:.78rem;font-weight:700;color:#059669;margin-bottom:6px}.solution-answer-label{font-weight:800}.solution-explanation{font-size:.75rem;color:var(--muted);line-height:1.5;padding:8px 10px;background:var(--bg);border-radius:8px}.solution-exp-label{font-weight:700;color:var(--text)}.quiz-active{display:flex;flex-direction:column;min-height:100vh;padding-bottom:80px}.quiz-active~.bottom-tab-bar,body.quiz-mode .bottom-tab-bar{display:none!important}.quiz-topbar{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.quiz-topbar-row{display:flex;align-items:center;gap:10px}.quiz-topbar-row .qpill-submit,.quiz-topbar-row .quiz-timer{margin-left:auto}.quiz-topbar-row .quiz-timer~.qpill-submit{margin-left:0}.quiz-progress-bar{flex:1 1;height:6px;background:rgba(255,255,255,.1);border-radius:3px;overflow:hidden}.quiz-progress-fill{height:100%;background:var(--primary);border-radius:3px;transition:.3s}.quiz-counter{font-size:.78rem;font-weight:700;color:var(--muted);white-space:nowrap}.qpill-scroll{flex:1 1;display:flex;gap:6px;overflow-x:auto;padding:2px 0;-webkit-overflow-scrolling:touch}.qpill-scroll::-webkit-scrollbar{display:none}.qpill{flex-shrink:0;width:30px;height:30px;border-radius:8px;border:none;font-size:.72rem;font-weight:700;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent}.qpill:active{transform:scale(.9)}.qpill-current{outline:2px solid #fff;outline-offset:1px}.qpill-unseen{background:rgba(255,255,255,.08);color:var(--muted,#8aa3a8)}.qpill-skipped{background:rgba(239,68,68,.25);color:#fca5a5}.qpill-answered{background:rgba(16,185,129,.25);color:#6ee7b7}.qpill-submit{flex-shrink:0;padding:6px 14px;border-radius:8px;background:#10b981;color:#fff;font-size:.72rem;font-weight:800;font-family:inherit;border:none;cursor:pointer;white-space:nowrap;transition:transform .15s;-webkit-tap-highlight-color:transparent}.qpill-submit:active{transform:scale(.95)}.quiz-layout,.quiz-main{flex:1 1;display:flex;flex-direction:column}.quiz-sidebar{display:none}.quiz-body{flex:1 1}.quiz-question{font-size:1.02rem;font-weight:600;line-height:1.65;margin-bottom:20px}.quiz-options{display:flex;flex-direction:column;gap:10px}.quiz-option{display:block;width:100%;text-align:left;background:var(--card);border:2px solid var(--card-border);padding:14px 16px;border-radius:12px;font-size:.88rem;font-weight:500;font-family:inherit;cursor:pointer;transition:.15s;color:var(--text);-webkit-tap-highlight-color:transparent}.quiz-option:active{transform:scale(.98)}.quiz-option-selected{border-color:var(--primary);background:rgba(99,102,241,.15);box-shadow:0 0 0 2px rgba(99,102,241,.12)}.quiz-nav{display:flex;gap:10px;position:fixed;bottom:0;left:0;right:0;padding:12px 16px max(12px,env(safe-area-inset-bottom));background:var(--bg,#131F22);border-top:1px solid var(--card-border,rgba(255,255,255,.06));z-index:100}.qnav-btn{flex:1 1;padding:14px;border-radius:12px;font-weight:700;font-size:.9rem;font-family:inherit;border:1.5px solid var(--card-border);background:var(--card);color:var(--text);cursor:pointer;transition:.2s}.qnav-btn:disabled{opacity:.4}.qnav-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.qnav-submit{background:var(--success);color:#fff;border-color:var(--success)}.quiz-timer{font-size:.78rem;font-weight:800;font-family:Courier New,monospace;color:#6ee7b7;background:rgba(16,185,129,.12);padding:4px 10px;border-radius:6px;white-space:nowrap;flex-shrink:0}.quiz-timer-warn{color:#fca5a5!important;background:rgba(239,68,68,.15)!important;animation:timer-pulse 1s ease-in-out infinite}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.5}}.quiz-popup-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;display:flex;justify-content:center;align-items:flex-start;padding-top:0;animation:popup-fade .2s ease}.quiz-popup{background:var(--card,#1a2d31);border:1px solid var(--card-border,rgba(255,255,255,.1));border-radius:0 0 18px 18px;padding:calc(20px + env(safe-area-inset-top, 0px)) 20px 16px;width:100%;max-width:400px;animation:popup-slide .25s ease;box-shadow:0 8px 32px rgba(0,0,0,.4)}.quiz-popup-msg{font-size:.88rem;font-weight:600;color:var(--text,#f0fdf4);margin:0 0 16px;line-height:1.5;text-align:center}.quiz-popup-btns{display:flex;gap:10px}.quiz-popup-cancel,.quiz-popup-confirm{flex:1 1;padding:12px;border-radius:10px;font-size:.82rem;font-weight:700;font-family:inherit;border:none;cursor:pointer;transition:transform .15s;-webkit-tap-highlight-color:transparent}.quiz-popup-cancel{background:rgba(255,255,255,.08);color:var(--muted,#8aa3a8)}.quiz-popup-confirm{background:#10b981;color:#fff}.quiz-popup-cancel:active,.quiz-popup-confirm:active{transform:scale(.96)}@keyframes popup-fade{0%{opacity:0}to{opacity:1}}@keyframes popup-slide{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.qs-timer-box{display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.03);padding:10px 12px;border-radius:10px;margin-bottom:14px}.qs-timer-label{font-size:.7rem;font-weight:600;color:var(--muted,#8aa3a8)}.qs-timer-val{font-size:.95rem;font-weight:900;font-family:Courier New,monospace;color:#6ee7b7}.results-page{padding-bottom:24px}.res-hero{flex-direction:column;padding:28px 0 20px;gap:10px}.res-hero,.res-ring{display:flex;align-items:center}.res-ring{width:110px;height:110px;border-radius:50%;background:conic-gradient(var(--ring-color) calc(var(--pct) * 1%),rgba(255,255,255,.08) calc(var(--pct) * 1%));justify-content:center;position:relative}.res-ring:before{content:"";position:absolute;inset:10px;border-radius:50%;background:var(--bg,#131F22)}.res-pct{position:relative;z-index:1;font-size:1.6rem;font-weight:900;color:var(--text,#f0fdf4)}.res-grade{font-size:1.2rem;font-weight:900;margin:0}.res-subtitle{font-size:.82rem;color:var(--muted,#8aa3a8);margin:0}.res-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:24px}.res-stat{background:var(--card,#1a2d31);padding:14px 6px;border-radius:12px;text-align:center;border:1px solid var(--card-border,rgba(255,255,255,.06))}.res-stat-val{display:block;font-size:1.35rem;font-weight:900}.res-stat-label{display:block;font-size:.62rem;color:var(--muted,#8aa3a8);margin-top:2px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.res-review-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--card-border,rgba(255,255,255,.06))}.res-review-title{font-size:.88rem;font-weight:800;color:var(--text,#f0fdf4);margin:0}.res-time-badge{font-size:.72rem;font-weight:700;color:var(--muted,#8aa3a8);background:rgba(255,255,255,.06);padding:4px 10px;border-radius:6px}.res-pill-strip{display:flex;gap:6px;overflow-x:auto;padding:2px 0;margin-bottom:16px;-webkit-overflow-scrolling:touch}.res-pill-strip::-webkit-scrollbar{display:none}.res-pill-strip .qpill{text-decoration:none}.res-q-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted,#8aa3a8);margin:0 0 4px}.res-q-text{font-size:.92rem;font-weight:600;line-height:1.55;margin:0 0 12px;color:var(--text,#f0fdf4)}.res-options{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.res-opt{gap:10px;padding:10px 12px;border-radius:10px;font-size:.82rem;font-weight:500;background:rgba(255,255,255,.04);color:var(--text,#f0fdf4);border:1px solid rgba(255,255,255,.06);transition:.15s}.res-opt,.res-opt-label{display:flex;align-items:center}.res-opt-label{width:22px;height:22px;border-radius:6px;background:rgba(255,255,255,.08);justify-content:center;font-size:.68rem;color:var(--muted,#8aa3a8)}.res-opt-label,.res-opt-tag{font-weight:800;flex-shrink:0}.res-opt-tag{margin-left:auto;font-size:.82rem}.res-opt-correct{background:rgba(16,185,129,.12);border-color:rgba(16,185,129,.3);color:#6ee7b7}.res-opt-correct .res-opt-label{background:rgba(16,185,129,.25);color:#6ee7b7}.res-opt-correct .res-opt-tag{color:#10b981}.res-opt-wrong{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.3);color:#fca5a5}.res-opt-wrong .res-opt-label{background:rgba(239,68,68,.25);color:#fca5a5}.res-opt-tag-wrong{color:#ef4444!important}.res-skipped-label{font-size:.75rem;font-weight:600;color:#94a3b8;font-style:italic;margin:4px 0 8px}.res-solutions-btn{display:block;width:100%;text-align:center;padding:14px;border-radius:12px;background:rgba(16,185,129,.1);border:1.5px solid rgba(16,185,129,.35);color:#6ee7b7;font-weight:800;font-size:.9rem;font-family:inherit;cursor:pointer;transition:transform .15s;-webkit-tap-highlight-color:transparent;margin-bottom:0}.res-solutions-btn:active{transform:scale(.97)}.res-back-btn{display:block;width:100%;text-align:center;padding:14px;border-radius:12px;background:var(--card,#1a2d31);border:1px solid var(--card-border,rgba(255,255,255,.06));color:var(--text,#f0fdf4);font-weight:700;font-size:.88rem;font-family:inherit;text-decoration:none;margin-top:8px;margin-bottom:100px;transition:transform .15s;-webkit-tap-highlight-color:transparent}.res-back-btn:active{transform:scale(.98)}.review-opt{cursor:default!important;display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:12px;font-size:.85rem;font-weight:500;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);color:var(--text,#f0fdf4)}.review-opt-correct{background:rgba(16,185,129,.12)!important;border-color:rgba(16,185,129,.35)!important;color:#6ee7b7!important}.review-opt-correct .res-opt-label{background:rgba(16,185,129,.3);color:#6ee7b7}.review-opt-wrong{background:rgba(239,68,68,.12)!important;border-color:rgba(239,68,68,.35)!important;color:#fca5a5!important}.review-opt-wrong .res-opt-label{background:rgba(239,68,68,.3);color:#fca5a5}.res-ai-bulk{background:var(--card,#1a2d31);border:1px solid var(--card-border,rgba(255,255,255,.06));border-radius:14px;padding:16px;margin-bottom:20px;text-align:center}.res-ai-label{font-size:.78rem;font-weight:700;color:var(--muted,#8aa3a8);margin:0 0 10px}.res-ai-btns{display:flex;gap:8px;justify-content:center}.res-ai-btn{padding:10px 20px;border-radius:10px;font-size:.82rem;font-weight:700;font-family:inherit;border:none;cursor:pointer;transition:transform .15s;-webkit-tap-highlight-color:transparent}.res-ai-btn:active{transform:scale(.95)}.res-ai-gemini{background:rgba(139,92,246,.2);color:#c4b5fd}.res-ai-gpt{background:rgba(20,184,166,.2);color:#5eead4}.res-ai-inline{display:flex;gap:6px;margin-top:8px;justify-content:flex-end}.res-ai-sm{width:30px;height:30px;border-radius:8px;border:none;font-size:.82rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s;-webkit-tap-highlight-color:transparent}.res-ai-sm:active{transform:scale(.9)}.res-ai-sm.res-ai-gemini{background:rgba(139,92,246,.2);color:#c4b5fd}.res-ai-sm.res-ai-gpt{background:rgba(20,184,166,.2);color:#5eead4}.results-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:20px}.rstat{background:var(--card);padding:14px 8px;border-radius:12px;text-align:center;box-shadow:0 1px 4px rgba(0,0,0,.15)}.rstat-val{display:block;font-size:1.4rem;font-weight:900}.rstat-label{font-size:.65rem;color:var(--muted);margin-top:2px}.result-card{background:var(--card);border-radius:14px;padding:16px;margin-bottom:10px;box-shadow:0 1px 4px rgba(0,0,0,.15)}.explanation{background:rgba(245,158,11,.1);padding:12px;border-radius:10px;border-left:4px solid rgba(245,158,11,.5);margin-top:10px;font-size:.82rem;line-height:1.55}.question-statements{font-weight:500;font-size:.88rem;margin:10px 0;padding-left:12px;border-left:3px solid var(--primary);opacity:.9}.statement-line{margin-bottom:5px}.question-table-wrap{overflow-x:auto;margin:12px 0}.question-table{width:100%;border-collapse:collapse;font-size:.8rem;font-weight:500}.question-table td,.question-table th{padding:8px;border:1px solid rgba(128,128,128,.2)}.question-table thead tr{background:rgba(128,128,128,.08)}.pg-profile{--bg:#131F22;--card:#1a2d31;--card-border:rgba(255,255,255,0.06);--text:#f0fdf4;--muted:#8aa3a8;--accent:#ea580c;--accent-glow:rgba(234,88,12,0.25);background-color:var(--bg);color:var(--text);margin:-20px -16px calc(-1 * (var(--tab-h) + 16px));padding:0 16px calc(var(--tab-h) + 32px);min-height:100vh}.pg-profile .section-header{border-bottom-color:rgba(255,255,255,.12);box-shadow:none}.pg-profile .section-header h3,.pg-profile .see-all{color:rgba(255,255,255,.5)}.prof-hero{display:flex;flex-direction:column;align-items:center;padding:24px 20px 16px}.prof-avatar-ring{width:68px;height:68px;border-radius:50%;background:rgba(255,255,255,.15);padding:2.5px;margin-bottom:12px}@keyframes ringRotate{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(1turn)}}.prof-avatar{width:100%;height:100%;border-radius:50%;background:linear-gradient(145deg,#1e2e32,#131F22);display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:800;color:#f0fdf4}.prof-name{font-size:1.2rem;font-weight:800;margin:0;letter-spacing:-.02em}.prof-email{font-size:.78rem;color:var(--muted);margin:3px 0 0}.prof-joined{display:inline-block;margin-top:8px;font-size:.65rem;font-weight:600;color:var(--accent);background:var(--accent-glow);padding:2px 10px;border-radius:8px}.prof-stats{display:flex;align-items:flex-start;justify-content:space-around;padding:4px 0 20px}.prof-stat{display:flex;flex-direction:column;align-items:center;gap:3px}.prof-stat-val{font-size:1.1rem;font-weight:800;line-height:1}.prof-stat-label{font-size:.6rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.03em}.ach-carousel-wrap{padding:12px 0 20px}.ach-carousel{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:0}.ach-carousel::-webkit-scrollbar{display:none}.ach-page{flex-shrink:0;width:100%;display:flex;flex-direction:column;gap:10px;scroll-snap-align:start}.ach-dots{display:flex;justify-content:center;gap:8px;padding-top:16px}.ach-dot{width:8px;height:8px;border-radius:50%;border:none;background:rgba(255,255,255,.15);padding:0;cursor:pointer;transition:background .3s ease,transform .2s ease}.ach-dot:active{transform:scale(1.3)}.ach-dot--active{background:#ea580c;box-shadow:0 0 8px rgba(234,88,12,.5)}.ach-row{display:flex;align-items:center;gap:14px;padding:14px 16px;background:#0e1a1d;border:1.5px solid rgba(255,255,255,.05);border-radius:16px;transition:transform .15s ease,box-shadow .3s ease}.ach-row:active{transform:scale(.98)}.ach-row-badge{position:relative;flex-shrink:0;width:48px;height:48px}.ach-row-badge-img{width:48px;height:48px;object-fit:contain;filter:grayscale(1) opacity(.35);transition:filter .4s ease}.ach-row-check{display:none}.ach-row-body{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:6px}.ach-row-header{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.ach-row-title{font-size:.85rem;font-weight:700;color:rgba(255,255,255,.35);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ach-row-pct{font-size:.72rem;font-weight:700;color:rgba(255,255,255,.2);flex-shrink:0}.ach-row-bar-wrap{width:100%;height:8px;background:rgba(255,255,255,.06);border-radius:99px;overflow:hidden}.ach-row-bar{height:100%;background:#8aa3a8;border-radius:99px;transition:width .5s cubic-bezier(.4,0,.2,1)}.ach-row-hint{font-size:.68rem;font-weight:500;color:rgba(255,255,255,.2);line-height:1.3}.ach-row--done{background:linear-gradient(160deg,#162b23,#0f201a);border-color:rgba(234,88,12,.25);box-shadow:0 2px 16px rgba(234,88,12,.08)}.ach-row--done .ach-row-badge-img{filter:none}.ach-row--done .ach-row-check{display:flex;align-items:center;justify-content:center;position:absolute;bottom:-2px;right:-2px;width:18px;height:18px;border-radius:50%;background:#ea580c;color:#fff;font-size:.55rem;font-weight:800;line-height:1;box-shadow:0 2px 6px rgba(234,88,12,.4)}.ach-row--done .ach-row-title{color:#f0fdf4}.ach-row--done .ach-row-pct{color:#ea580c;font-weight:800}.ach-row--done .ach-row-bar{background:linear-gradient(90deg,#ea580c,#fb923c)}.ach-row--done .ach-row-hint{color:#ea580c;font-weight:600}.achpop-overlay{position:fixed;inset:0;z-index:10000;background:#131313;flex-direction:column;overflow:hidden}.achpop-close,.achpop-overlay{display:flex;align-items:center;justify-content:center}.achpop-close{position:absolute;top:16px;right:24px;background:none;border:none;cursor:pointer;padding:8px;z-index:12}.achpop-screen{display:flex;flex-direction:column;width:100%;max-width:390px;height:100%;max-height:844px;padding:80px 32px 32px;box-sizing:border-box}.achpop-hero{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:0;width:100%}.achpop-badge-block{width:256px;padding-bottom:24px;flex-shrink:0}.achpop-badge-stage{position:relative;width:256px;height:256px;display:flex;align-items:center;justify-content:center;overflow:visible}.achpop-particles,.achpop-rays{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:visible}.achpop-ray{width:3px;height:80px;background:linear-gradient(180deg,rgba(251,146,60,.6) 0,transparent);transform-origin:bottom center}.achpop-particle,.achpop-ray{position:absolute;left:50%;top:50%}.achpop-particle{width:8px;height:8px;margin-left:-4px;margin-top:-4px;border-radius:50%;z-index:1}.achpop-glow{position:absolute;left:50%;top:50%;width:200px;height:200px;margin-left:-100px;margin-top:-100px;border-radius:50%;background:radial-gradient(circle,rgba(234,88,12,.6) 0,rgba(234,88,12,0) 70%);z-index:1;pointer-events:none}.achpop-badge-wrap{position:relative;z-index:3;width:224px;height:224px;display:flex;align-items:center;justify-content:center}.achpop-badge-float,.achpop-badge-img,.achpop-badge-shadow{width:100%;height:100%}.achpop-badge-img{object-fit:contain;display:block;filter:drop-shadow(0 25px 25px rgba(0,0,0,.3))}.achpop-text{display:flex;flex-direction:column;align-items:center;gap:16px;padding-top:32px;width:100%}.achpop-subtitle{font-weight:700;font-size:13px;color:#ffb599;letter-spacing:1.3px;text-transform:uppercase;text-shadow:0 2px 2px rgba(234,88,12,.3)}.achpop-subtitle,.achpop-title{font-family:Sora,Inter,sans-serif;text-align:center;margin:0}.achpop-title{font-weight:800;font-size:44px;color:#e5e2e1;letter-spacing:-.88px;line-height:1.1}.achpop-desc{font-family:Sora,Inter,sans-serif;font-weight:400;font-size:16px;color:#e2bfb2;text-align:center;line-height:1.6;max-width:300px;margin:0}.achpop-cta{width:100%;padding:48px 0 24px;flex-shrink:0}.achpop-btn{position:relative;width:100%;background:#ea580c;color:#fff;border:none;border-radius:9999px;padding:16px 32px;font-family:Sora,Inter,sans-serif;font-weight:700;font-size:14px;letter-spacing:.7px;text-transform:uppercase;cursor:pointer;box-shadow:0 8px 24px -4px rgba(234,88,12,.3),inset 4px 4px 8px 0 rgba(255,255,255,.2),inset -4px -4px 8px 0 rgba(0,0,0,.3)}.achpop-btn-shine{position:absolute;inset:0;border-radius:inherit;pointer-events:none;box-shadow:inset -4px -4px 8px rgba(0,0,0,.3),inset 4px 4px 8px rgba(255,255,255,.2)}@media (prefers-reduced-motion:reduce){.achpop-badge-float,.achpop-badge-shadow,.achpop-glow,.achpop-particle,.achpop-ray{animation:none!important}}@media (min-width:1024px){.achpop-overlay{display:none}}.prof-sub-banner{display:flex;align-items:center;gap:16px;padding:22px 20px;margin:8px 0 24px;border-radius:18px;background:linear-gradient(135deg,rgba(99,102,241,.2),rgba(168,85,247,.15) 50%,rgba(236,72,153,.1));border:1.5px solid rgba(99,102,241,.3);box-shadow:0 4px 20px rgba(99,102,241,.15),inset 0 1px 0 rgba(255,255,255,.06)}.prof-sub-info{flex:1 1;display:flex;flex-direction:column;gap:4px}.prof-sub-plan{font-size:.95rem;font-weight:800;color:var(--text)}.prof-sub-desc{font-size:.7rem;color:var(--muted);font-weight:500;line-height:1.4}.prof-sub-btn{flex-shrink:0;padding:10px 22px;border:none;border-radius:12px;background:linear-gradient(135deg,#ea580c,#fb923c);color:#fff;font-size:.82rem;font-weight:800;font-family:inherit;cursor:pointer;transition:transform .15s;box-shadow:0 3px 12px rgba(234,88,12,.4);position:relative;overflow:hidden}.prof-sub-btn:after{content:"";position:absolute;top:-50%;left:-60%;width:40%;height:200%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);transform:skewX(-20deg);animation:shimmer 3s ease-in-out infinite}@keyframes shimmer{0%,to{left:-60%}50%{left:120%}}.prof-sub-btn:active{transform:scale(.95)}.prof-action-arrow{color:var(--muted);font-size:.85rem}.prof-setting-row{display:flex;align-items:center;gap:12px;padding:13px 4px;border-bottom:1px solid rgba(255,255,255,.04);font-size:.85rem;font-weight:500}.prof-setting-label{flex:1 1}.prof-setting-value{color:var(--muted);font-size:.75rem;font-weight:600}.prof-logout-btn{width:100%;padding:16px 4px;border:none;background:transparent;color:#f43f5e;font-weight:700;font-size:.85rem;font-family:inherit;cursor:pointer;text-align:left;transition:opacity .15s}.prof-logout-btn:active{opacity:.7}.prof-version{text-align:center;font-size:.6rem;color:rgba(138,163,168,.4);font-weight:500;padding:16px 0 0}.ai-btn-group,.ai-btn-group-small{display:flex;gap:6px}.btn{padding:10px 18px;border:none;border-radius:12px;cursor:pointer;font-weight:700;transition:.2s;display:inline-flex;align-items:center;gap:6px;font-size:.82rem;font-family:inherit}.mp-bike-mascot{position:absolute;top:50%;transform:translateY(-55%);display:flex;flex-direction:column;align-items:center;gap:2px;pointer-events:none;z-index:3}.mp-bike--right{left:calc(100% + 4px);align-items:flex-start}.mp-bike--right .mp-bike-bubble:after{left:52px;transform:translateX(-50%)}.mp-bike--left{right:calc(100% + 4px);align-items:flex-end}.mp-bike--left .mp-bike-bubble:after{left:auto;right:52px;transform:translateX(50%)}.mp-bike--left .mp-bike-images{transform:scaleX(-1)}.mp-bike-bubble{background:#fff;border-radius:10px;padding:4px 8px;font-size:.58rem;font-weight:700;color:#44403c;white-space:nowrap;box-shadow:0 2px 8px rgba(0,0,0,.1),0 0 0 1px rgba(0,0,0,.04);position:relative;animation:bikeBubblePop .4s cubic-bezier(.34,1.56,.64,1) both;animation-delay:.5s}.mp-bike-bubble:after{content:"";position:absolute;bottom:-5px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid #fff}.mp-bike-images{display:flex;align-items:flex-end;gap:-8px;position:relative}.mp-bike-img{width:104px;filter:drop-shadow(0 0 2px rgba(255,255,255,.6)) drop-shadow(0 6px 6px rgba(0,0,0,.5)) saturate(1.25) contrast(1.1);z-index:1}.mp-bike-dirt,.mp-bike-img{height:auto;object-fit:contain;position:relative}.mp-bike-dirt{width:60px;opacity:.7;margin-left:-24px;bottom:8px;z-index:0;animation:dirtPuff 2s ease-in-out infinite}@keyframes bikeFloat{0%,to{transform:translateY(-55%)}50%{transform:translateY(calc(-55% - 4px))}}@keyframes bikeBubblePop{0%{opacity:0;transform:scale(.5) translateY(4px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes dirtPuff{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.mascot-overlay{position:fixed;inset:0;z-index:2000;display:flex;align-items:flex-end;justify-content:flex-end;cursor:pointer;-webkit-tap-highlight-color:transparent;animation:mascotFadeIn .4s ease both;padding:0 0 calc(var(--tab-h)) 0}.mascot-overlay-bg{position:absolute;inset:0;background:rgba(0,0,0,.3);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.mascot-greet-container{position:relative;z-index:1;display:flex;flex-direction:column;align-items:flex-end;gap:0;animation:mascotSlideUp .5s cubic-bezier(.34,1.56,.64,1) both;animation-delay:.15s}.mascot-greet-bubble{background:#fff;border-radius:16px;padding:10px 14px 8px;max-width:200px;text-align:center;box-shadow:0 4px 24px rgba(0,0,0,.12),0 0 0 1.5px rgba(0,0,0,.04);margin-bottom:-4px;margin-right:20px;position:relative;z-index:2;animation:bubblePopIn .4s cubic-bezier(.34,1.56,.64,1) both;animation-delay:.3s}.mascot-greet-bubble:after{content:"";position:absolute;bottom:-10px;right:24px;left:auto;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-top:12px solid #fff;filter:drop-shadow(0 2px 2px rgba(0,0,0,.05))}.mascot-greet-name{display:inline-block;background:linear-gradient(135deg,#E8752A,#d4621e);color:#fff;font-size:.65rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:2px 8px;border-radius:6px;margin-bottom:6px}.mascot-greet-text{font-size:.78rem;font-weight:600;color:#1e293b;line-height:1.4;margin:0 0 10px}.mascot-greet-tap{font-size:.65rem;color:#94a3b8;font-weight:600}.mascot-greet-img-wrap{display:flex;justify-content:center;align-items:flex-end;margin-top:4px}.mascot-greet-img{width:150px;height:auto;object-fit:contain;filter:drop-shadow(0 4px 14px rgba(0,0,0,.18));animation:mascotImgIn .5s cubic-bezier(.34,1.56,.64,1) both;animation-delay:.2s}@keyframes mascotFadeIn{0%{opacity:0}to{opacity:1}}@keyframes mascotSlideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes bubblePopIn{0%{opacity:0;transform:scale(.6) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes mascotImgIn{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}.mascot-overlay--animating .mascot-greet-bubble{animation:bubbleFadeOut .3s ease both}.mascot-overlay--animating .mascot-greet-img{animation:none}@keyframes bubbleFadeOut{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.8) translateY(-10px)}}.mascot-overlay--animating{animation:mascotDismiss .4s ease 2.7s both}.mascot-overlay--animating .mascot-greet-container{animation:mascotContainerOut .35s ease 2.65s both}@keyframes mascotDismiss{0%{opacity:1}to{opacity:0;pointer-events:none}}@keyframes mascotContainerOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(30px) scale(.9)}}.map-banner-section{margin-bottom:24px}.map-banner{display:block;position:relative;width:100%;aspect-ratio:2/1;min-height:140px;border-radius:20px;overflow:hidden;text-decoration:none;background:var(--card);box-shadow:0 4px 12px rgba(0,0,0,.15);transition:transform .15s}.map-banner:after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:inset 2px 3px 6px rgba(255,255,255,.5),inset -2px -5px 8px rgba(0,0,0,.25);z-index:5;pointer-events:none}.map-banner:active{transform:scale(.98)}.map-banner-bg{position:absolute;top:0;left:0;width:400%;height:100%;background-image:url(/sky_strip.png);background-size:auto 100%;background-position:0;background-repeat:repeat-x;animation:panClouds 60s linear infinite;z-index:1}@keyframes panClouds{0%{transform:translateX(0)}to{transform:translateX(-50%)}}.map-banner-content{position:absolute;top:50%;left:20px;transform:translateY(calc(-50% - 12px));z-index:2;width:50%;font-family:Fredoka,Nunito,Varela Round,SF Pro Rounded,ui-rounded,sans-serif}.map-banner-content h3{font-family:Titan One,Fredoka,Nunito,Varela Round,sans-serif;font-size:1.6rem;font-weight:400;color:transparent;background-image:linear-gradient(180deg,#e74c3c,#d63031 50%,#a51d1d);-webkit-background-clip:text;background-clip:text;letter-spacing:.04em;margin:0 0 7px;line-height:1.1;transform:rotate(-3deg)}.map-banner-content p{font-size:.82rem;font-weight:800;color:#334155;margin:0}.map-banner-fg{position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:3;object-fit:cover;object-position:bottom center;pointer-events:none;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}@keyframes twinkle{0%,to{opacity:.3}50%{opacity:1}}.lightning-boss{position:absolute;bottom:25px;left:50%;transform:translateX(-50%);width:50px;height:132px;background-image:url(/sprite/lightening.png);background-size:250px 132px;background-repeat:no-repeat;mix-blend-mode:screen;animation:play-lightning .6s steps(5) infinite;pointer-events:none;z-index:10;filter:contrast(3) brightness(.7) saturate(1.5)}@keyframes play-lightning{0%{background-position:0 0}to{background-position:-250px 0}}.sprite-blue-explosion{position:absolute;width:150px;height:150px;background-image:url(/sprite/blue_explosion.png);background-size:300% 200%;mix-blend-mode:screen;pointer-events:none;animation:animExpX .3s steps(3) infinite,animExpY .6s steps(2) infinite;filter:contrast(1.5) brightness(1.2)}@keyframes animExpX{to{background-position-x:-300%}}@keyframes animExpY{to{background-position-y:-200%}}.sprite-fire-tornado{position:absolute;width:100px;height:100px;background-image:url(/sprite/firetornado.png);background-size:500% 500%;mix-blend-mode:screen;pointer-events:none;animation:animTornadoX .4s steps(5) infinite,animTornadoY 2s steps(5) infinite;filter:contrast(1.5)}@keyframes animTornadoX{to{background-position-x:-500%}}@keyframes animTornadoY{to{background-position-y:-500%}}.sprite-fire-orb{position:absolute;width:130px;height:130px;background-image:url(/sprite/fireorb.png);background-size:300% 300%;mix-blend-mode:screen;pointer-events:none;animation:animFireOrbX .3s steps(3) infinite,animFireOrbY .9s steps(3) infinite,fireOrbPop .9s ease both;filter:contrast(1.4) brightness(2)}@keyframes animFireOrbX{to{background-position-x:-300%}}@keyframes animFireOrbY{to{background-position-y:-300%}}@keyframes fireOrbPop{0%{transform:translate(-50%,-50%) scale(.3);opacity:0}15%{transform:translate(-50%,-50%) scale(1.3);opacity:1}30%{transform:translate(-50%,-50%) scale(1)}85%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(.5);opacity:0}}@media (min-width:900px){.quiz-active .quiz-topbar .qpill-scroll,.quiz-active .quiz-topbar-row .qpill-submit,.quiz-active .quiz-topbar-row .quiz-timer{display:none}.quiz-active .quiz-topbar{margin-bottom:16px}.quiz-layout{flex-direction:row;gap:24px;align-items:flex-start}.quiz-main{flex:1 1;min-width:0}.quiz-active .quiz-nav{position:static;padding:16px 0;border-top:none;background:transparent}.quiz-sidebar{display:flex!important;flex-direction:column;width:240px;flex-shrink:0;background:var(--card,#1a2d31);border:1px solid var(--card-border,rgba(255,255,255,.06));border-radius:16px;padding:16px;position:sticky;top:80px;max-height:calc(100vh - 100px);overflow-y:auto}.qs-header{font-size:.82rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--muted,#8aa3a8);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--card-border,rgba(255,255,255,.06))}.qs-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:16px}.qs-num{width:100%;aspect-ratio:1;border-radius:8px;border:none;font-size:.78rem;font-weight:700;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s;-webkit-tap-highlight-color:transparent}.qs-num:hover{transform:scale(1.1)}.qs-num-current{outline:2px solid #fff;outline-offset:1px}.qs-legend{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;padding:12px;background:rgba(255,255,255,.03);border-radius:10px}.qs-legend-item{display:flex;align-items:center;gap:8px;font-size:.72rem;font-weight:600;color:var(--muted,#8aa3a8)}.qs-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}.qs-dot-answered{background:rgba(16,185,129,.5);border:1px solid #10b981}.qs-dot-skipped{background:rgba(239,68,68,.5);border:1px solid #ef4444}.qs-dot-unseen{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15)}.qs-submit{width:100%;padding:12px;border-radius:10px;background:#10b981;color:#fff;font-size:.88rem;font-weight:800;font-family:inherit;border:none;cursor:pointer;transition:transform .15s,filter .15s;-webkit-tap-highlight-color:transparent}.qs-submit:hover{filter:brightness(1.1);transform:scale(1.02)}.qs-submit:active{transform:scale(.98)}}.authgate-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:authgateFadeIn .25s ease-out}@keyframes authgateFadeIn{0%{opacity:0}to{opacity:1}}.authgate-card{background:linear-gradient(145deg,rgba(255,255,255,.95),rgba(248,250,252,.98));border-radius:24px;padding:32px 28px;max-width:340px;width:90%;text-align:center;box-shadow:0 24px 80px rgba(0,0,0,.3),inset 1px 1px 3px rgba(255,255,255,.8),inset -1px -1px 3px rgba(0,0,0,.05);animation:authgateSlideUp .3s cubic-bezier(.34,1.56,.64,1)}@keyframes authgateSlideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.authgate-emoji{font-size:2.8rem;margin-bottom:8px}.authgate-title{font-size:1.2rem;font-weight:800;color:#1e293b;margin:0 0 8px}.authgate-desc{font-size:.85rem;color:#64748b;line-height:1.5;margin:0 0 20px}.authgate-btns{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.authgate-btn{padding:14px;border:none;border-radius:14px;font-size:.95rem;font-weight:800;font-family:inherit;cursor:pointer;transition:all .15s cubic-bezier(.34,1.56,.64,1);-webkit-tap-highlight-color:transparent}.authgate-signup{background:#ea580c;color:#fff;box-shadow:0 4px 0 #9a3412,0 6px 16px rgba(234,88,12,.35),inset 1px 1px 2px rgba(255,255,255,.3)}.authgate-signup:active{transform:translateY(2px);box-shadow:0 2px 0 #9a3412,0 4px 8px rgba(234,88,12,.3),inset 1px 1px 2px rgba(255,255,255,.3)}.authgate-login{background:#f1f5f9;color:#334155;box-shadow:0 2px 0 #e2e8f0,inset 1px 1px 2px rgba(255,255,255,.8),inset -1px -1px 2px rgba(0,0,0,.05)}.authgate-login:active{transform:translateY(1px);box-shadow:inset 2px 2px 4px rgba(0,0,0,.08)}.authgate-dismiss{background:none;border:none;color:#94a3b8;font-size:.82rem;font-weight:600;font-family:inherit;cursor:pointer;padding:6px 12px;-webkit-tap-highlight-color:transparent}.authgate-dismiss:hover{color:#64748b}body.locale-hi{font-family:var(--font-devanagari),system-ui,sans-serif}.lang-setting{display:inline-flex;gap:6px;padding:4px;border-radius:12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1)}.lang-setting-btn{border:0;cursor:pointer;padding:8px 14px;border-radius:10px;font-size:.85rem;font-weight:600;font-family:inherit;color:#a1a1aa;background:transparent}.lang-setting-btn--on{background:#ea580c;color:#fff}.prof-setting-row--lang{flex-wrap:wrap;gap:12px;align-items:center}.coming-soon-wrap{min-height:60vh;display:flex;align-items:center;justify-content:center;padding:24px 16px}.coming-soon-card{max-width:360px;text-align:center;padding:28px 20px;border-radius:20px;background:var(--card,#1a1a1a);border:1px solid var(--card-border,#333)}.coming-soon-mascot{margin:0 auto 16px;display:block}.coming-soon-title{margin:0 0 12px;font-size:1.35rem;font-weight:800;color:#fafafa}.coming-soon-body,.coming-soon-hint{margin:0 0 12px;font-size:.9rem;line-height:1.5;color:#a1a1aa}.coming-soon-back{display:inline-block;margin-top:8px;color:#ea580c;font-weight:600;text-decoration:none}.mo-play--disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.6)}