@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap";:root{--blue:#0071E3;--blue-hover:#0077ED;--blue-light:#5AC8FA;--green:#30D158;--red:#FF453A;--orange:#FF9F0A;--yellow:#FFD60A;--purple:#BF5AF2;--teal:#64D2FF;--g-bg:rgba(255,255,255,.72);--g-border:rgba(0,0,0,.06);--g-shine:inset 0 .5px 0 rgba(255,255,255,.95);--g-shadow:0 1px 3px rgba(0,0,0,.04), 0 4px 24px rgba(0,0,0,.06);--g-blur:blur(40px) saturate(180%);--g-depth-1:0 1px 3px rgba(0,0,0,.03), 0 4px 16px rgba(0,0,0,.04);--g-depth-2:0 2px 8px rgba(0,0,0,.04), 0 8px 32px rgba(0,0,0,.08);--g-depth-3:0 4px 16px rgba(0,0,0,.06), 0 16px 48px rgba(0,0,0,.12);--sidebar-g:rgba(255,255,255,.68);--tab-g:rgba(255,255,255,.82);--label:#1d1d1f;--label2:rgba(60,60,67,.72);--label3:rgba(60,60,67,.48);--sep:rgba(60,60,67,.12);--fill:rgba(120,120,128,.12);--fill2:rgba(120,120,128,.06);--fill3:rgba(120,120,128,.03);--bg:transparent;--bg2:var(--g-bg);--bg3:rgba(255,255,255,.5);--shadow:var(--g-shadow);--sidebar-w:260px;--page-bg:#F2F2F7;--radius-sm:10px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--t-fast:.12s;--t-normal:.22s;--t-slow:.38s;--ease-spring:cubic-bezier(.34,1.56,.64,1);--ease-smooth:cubic-bezier(.25,.46,.45,.94);--ease-out:cubic-bezier(.16,1,.3,1);--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"SF Pro Display","Segoe UI",Roboto,sans-serif;--fs-xs:11px;--fs-sm:13px;--fs-base:15px;--fs-md:17px;--fs-lg:20px;--fs-xl:28px;--fs-2xl:34px;--fs-display:clamp(32px,5vw,42px);--mod-home:#0071E3;--mod-lessons:#0071E3;--mod-vocab:#FF9F0A;--mod-grammar:#BF5AF2;--mod-practice:#30D158;--mod-pronunciation:#FF453A;--mod-listening:#64D2FF;--mod-writing:#FF9F0A;--mod-dialogues:#5AC8FA;--mod-error:#FF453A;--mod-build:#30D158;--mod-pictures:#BF5AF2;--mod-stories:#64D2FF;--mod-news:#8E8E93;--mod-culture:#0071E3;--mod-context:#AF52DE;--mod-videos:#FF453A;--mod-games:#FFD60A;--mod-yki:#FF453A;--mod-analytics:#0071E3;--mod-progress:#0071E3;--mod-leaderboard:#FF9F0A;--mod-friends:#30D158;--mod-achievements:#FF9F0A;--mod-settings:#8E8E93;--mod-account:#8E8E93;--current-mod:var(--mod-home)}html[data-theme=dark]{--g-bg:rgba(28,28,30,.72);--g-border:rgba(255,255,255,.08);--g-shine:inset 0 .5px 0 rgba(255,255,255,.12);--g-shadow:0 1px 3px rgba(0,0,0,.1), 0 4px 24px rgba(0,0,0,.16);--g-blur:blur(40px) saturate(200%);--g-depth-1:0 1px 3px rgba(0,0,0,.08), 0 4px 16px rgba(0,0,0,.1);--g-depth-2:0 2px 8px rgba(0,0,0,.12), 0 8px 32px rgba(0,0,0,.2);--g-depth-3:0 4px 16px rgba(0,0,0,.16), 0 16px 48px rgba(0,0,0,.28);--sidebar-g:rgba(28,28,30,.82);--tab-g:rgba(28,28,30,.88);--label:#f5f5f7;--label2:rgba(235,235,245,.68);--label3:rgba(235,235,245,.42);--sep:rgba(84,84,88,.36);--fill:rgba(120,120,128,.24);--fill2:rgba(120,120,128,.12);--fill3:rgba(120,120,128,.06);--bg:transparent;--bg2:var(--g-bg);--bg3:rgba(255,255,255,.1);--page-bg:#000000}@keyframes springFadeUp{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes popIn{0%{transform:scale(.6) rotate(-8deg);opacity:0}70%{transform:scale(1.06) rotate(2deg)}to{transform:scale(1) rotate(0);opacity:1}}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes cardIn{0%{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:translateZ(0)}}@keyframes animPopIn{0%{transform:scale(0);opacity:0}70%{transform:scale(1.08)}to{transform:scale(1);opacity:1}}@keyframes animBounce{0%,to{transform:translateY(0)}40%{transform:translateY(-8px)}60%{transform:translateY(-4px)}}@keyframes staggerFadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes scale-in{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}@keyframes slide-in{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.anim-fade{animation:springFadeUp .38s var(--ease-out) both}.anim-slide{animation:slideIn .3s var(--ease-smooth) both}.anim-pop{animation:popIn .45s var(--ease-spring) both}.anim-pop-in{animation:animPopIn .35s var(--ease-spring) both}.anim-bounce{animation:animBounce .6s cubic-bezier(.34,1.4,.64,1)}.anim-stagger{animation:staggerFadeUp .35s cubic-bezier(.34,1.18,.64,1) both;animation-delay:calc(var(--i,0) * 50ms)}.card-enter{animation:cardIn .38s var(--ease-out) both}@keyframes tabSlideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes tabSlideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes screenFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.anim-slide-in-left{animation:tabSlideInLeft .25s var(--ease-smooth) both}.anim-slide-in-right{animation:tabSlideInRight .25s var(--ease-smooth) both}.screen-content{animation:screenFadeIn .25s ease-out}@keyframes correctFlash{0%{box-shadow:0 0 #2db84d80}50%{box-shadow:0 0 0 10px #2db84d2e}to{box-shadow:0 0 #2db84d00}}@keyframes correctGlow{0%{box-shadow:0 0 #2db84d80}50%{box-shadow:0 0 0 10px #2db84d2e}to{box-shadow:0 0 #2db84d00}}@keyframes wrongShakeH{0%,to{transform:translate(0)}15%,45%,75%{transform:translate(-5px)}30%,60%,90%{transform:translate(5px)}}@keyframes shakeX{0%,to{transform:translate(0)}18%{transform:translate(-8px)}36%{transform:translate(8px)}54%{transform:translate(-5px)}72%{transform:translate(5px)}90%{transform:translate(-2px)}}@keyframes checkPop{0%{transform:scale(0) rotate(-20deg);opacity:0}60%{transform:scale(1.2) rotate(5deg);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}@keyframes correctNudge{0%,to{transform:translateY(0)}50%{transform:translateY(-1.5px)}}@keyframes incorrectShake{0%,to{transform:translate(0)}20%,60%{transform:translate(-4px)}40%,80%{transform:translate(4px)}}.anim-correct{animation:correctFlash .5s ease both;border-color:var(--green)!important;background:#2db84d14!important}.anim-wrong{animation:wrongShakeH .45s ease both;border-color:var(--red)!important;background:#e5342b0f!important}.anim-check-pop{animation:checkPop .35s var(--ease-spring) both}.anim-correct-nudge{animation:correctNudge .25s ease}.flash-correct{animation:correctFlash .75s ease-out}.shake{animation:shakeX .48s cubic-bezier(.36,.07,.19,.97) both}.anim-press{transition:transform .12s cubic-bezier(.34,1.4,.64,1)}.anim-press:active{transform:scale(.95)!important}.anim-card-press{transition:transform .15s ease,box-shadow .15s ease}.anim-card-press:active{transform:translateY(1px) scale(.98)!important;box-shadow:0 2px 8px #0000000f!important}.anim-ripple{position:relative;overflow:hidden}.anim-ripple:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at var(--ripple-x,50%) var(--ripple-y,50%),rgba(0,82,165,.15) 0%,transparent 60%);transform:scale(0);opacity:0;border-radius:inherit;transition:none;pointer-events:none}.anim-ripple:active:after{transform:scale(2.5);opacity:1;transition:transform .4s ease-out,opacity .4s ease-out}.anim-flip-container{perspective:1000px}.anim-flip-inner{position:relative;transition:transform .5s cubic-bezier(.4,.2,.2,1);transform-style:preserve-3d}.anim-flip-inner.flipped{transform:rotateY(180deg)}.anim-flip-front,.anim-flip-back{backface-visibility:hidden;-webkit-backface-visibility:hidden}.anim-flip-back{transform:rotateY(180deg);position:absolute;top:0;right:0;bottom:0;left:0}.lesson-card{transform-style:preserve-3d;perspective:800px;transition:transform .5s cubic-bezier(.4,.2,.2,1),box-shadow .3s,border-color .3s}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes skelShimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulseLoad{0%,to{opacity:.5}50%{opacity:.85}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.skeleton{position:relative;overflow:hidden;background:var(--fill);border-radius:8px}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,var(--fill2) 50%,transparent 100%);animation:shimmer 1.6s ease infinite;will-change:transform}.skel{background:linear-gradient(90deg,var(--fill) 25%,var(--fill2) 50%,var(--fill) 75%);background-size:200% 100%;animation:skelShimmer 1.6s ease-in-out infinite;border-radius:8px}.shimmer{position:relative;overflow:hidden;background:var(--fill);border-radius:8px}.shimmer:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,var(--fill2) 50%,transparent 100%);animation:shimmer 1.6s ease infinite;will-change:transform}.pulse-load{animation:pulseLoad 1.5s ease-in-out infinite}@keyframes xpFloat{0%{opacity:1;transform:translateY(0) scale(1)}65%{opacity:1;transform:translateY(-58px) scale(1.14)}to{opacity:0;transform:translateY(-86px) scale(.8)}}@keyframes xpFlyUp{0%{opacity:0;transform:translateY(0) scale(.7)}20%{opacity:1;transform:translateY(-12px) scale(1.15)}to{opacity:0;transform:translateY(-70px) scale(.95)}}@keyframes pillPulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes countGlow{0%{text-shadow:0 0 0 transparent}50%{text-shadow:0 0 12px rgba(0,82,165,.3)}to{text-shadow:0 0 0 transparent}}@keyframes flyup{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-40px)}}.xp-toast{position:fixed;z-index:9999;font-size:var(--fs-md);font-weight:800;color:#fff;background:var(--blue);padding:7px 18px;border-radius:999px;pointer-events:none;box-shadow:0 4px 16px #0071e359;animation:xpFloat 1.8s cubic-bezier(.22,.68,0,1.1) forwards}.anim-fly-up{position:fixed;pointer-events:none;z-index:9999;font-size:18px;font-weight:800;color:#f5a623;text-shadow:0 1px 6px rgba(245,166,35,.4),0 0 2px rgba(0,0,0,.3);animation:xpFlyUp 1.5s cubic-bezier(.22,.68,.35,1) forwards;white-space:nowrap}.pulse{animation:pillPulse .55s var(--ease-spring)}.anim-count-up{animation:countGlow .8s ease}@keyframes animGlowPulse{0%,to{box-shadow:0 0 8px #0052a533}50%{box-shadow:0 0 20px #0052a573}}@keyframes glowPulse{0%,to{opacity:.6;transform:translate(-50%,-60%) scale(1)}50%{opacity:1;transform:translate(-50%,-60%) scale(1.15)}}@keyframes badgeGlow{0%,to{filter:drop-shadow(0 0 0px rgba(255,204,0,0))}50%{filter:drop-shadow(0 0 8px rgba(255,204,0,.75))}}.anim-glow-pulse{animation:animGlowPulse 2s ease-in-out infinite}.badge-earned-icon{animation:badgeGlow 2.5s ease-in-out infinite;display:inline-block}@keyframes confettiFall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(90px) rotate(450deg);opacity:0}}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}@keyframes sparkleFloat{0%{opacity:0;transform:translate(0) scale(0) rotate(0)}20%{opacity:1;transform:scale(1.2)}to{opacity:0;transform:translate(var(--dx,30px),var(--dy,-60px)) scale(.3) rotate(var(--dr,180deg))}}@keyframes starBurst{0%{opacity:0;transform:scale(0) rotate(0)}30%{opacity:1;transform:scale(1.3) rotate(90deg)}to{opacity:0;transform:scale(.5) rotate(360deg);filter:blur(1px)}}.confetti-piece{position:absolute;border-radius:3px;animation:confettiFall 1s ease-out both}.anim-sparkle{animation:sparkleFloat 1s ease-out forwards;pointer-events:none;position:absolute}.anim-star{animation:starBurst 1.2s ease-out forwards;pointer-events:none;position:absolute}@keyframes auroraA{0%,to{transform:scale(1) translate(0);opacity:.28}40%{transform:scale(1.22) translate(14px,-12px);opacity:.4}70%{transform:scale(.88) translate(-9px,9px);opacity:.2}}@keyframes auroraB{0%,to{transform:scale(1) translate(0);opacity:.18}35%{transform:scale(1.28) translate(-14px,13px);opacity:.26}65%{transform:scale(.84) translate(11px,-9px);opacity:.13}}@keyframes heroShimmer{0%{transform:translate(-110%)}to{transform:translate(240%)}}.hero-blob-a{position:absolute;width:230px;height:200px;border-radius:50%;background:#78c4ff61;filter:blur(46px);top:-45px;right:-35px;animation:auroraA 7s ease-in-out infinite;pointer-events:none;z-index:0}.hero-blob-b{position:absolute;width:180px;height:155px;border-radius:50%;background:#c8e8ff38;filter:blur(54px);bottom:-28px;left:-5px;animation:auroraB 9.5s ease-in-out infinite;pointer-events:none;z-index:0}.hero-shimmer{position:absolute;top:0;left:0;width:38%;height:100%;z-index:1;background:linear-gradient(108deg,transparent 0%,rgba(255,255,255,.11) 50%,transparent 100%);animation:heroShimmer 3.6s ease-in-out infinite;pointer-events:none}.card-lg{transition:transform var(--t-normal) var(--ease-spring),box-shadow var(--t-normal),border-color var(--t-normal)}.card-lg:hover{transform:translateY(-2px) scale(1.005);box-shadow:var(--g-depth-2);border-color:#0071e31a}.stat{transition:transform var(--t-normal) var(--ease-spring),box-shadow var(--t-normal),border-color var(--t-normal)}.stat:hover{transform:translateY(-2px) scale(1.01);border-color:#0071e31a;box-shadow:var(--g-depth-2)}.vc-card:hover{transform:none!important;border-color:var(--g-border)!important}.sb-item{transition:all var(--t-fast) var(--ease-smooth);position:relative}.sb-item:not(.on):hover{transform:translate(2px)}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes typewriter{0%{width:0}to{width:100%}}@keyframes progressGlow{0%{box-shadow:0 0 4px #3498db66}50%{box-shadow:0 0 12px #3498db99}to{box-shadow:0 0 4px #3498db66}}button:focus-visible,.choice:focus-visible,.sb-item:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,[role=tab]:focus-visible{outline:3px solid var(--blue);outline-offset:2px;border-radius:inherit;box-shadow:0 0 0 6px #0071e31a}input:focus-visible,textarea:focus-visible,select:focus-visible{outline-offset:0;border-color:var(--blue)!important}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{z-index:99999;background:var(--blue);color:#fff;padding:12px 24px;border-radius:0 0 8px;font-size:14px;font-weight:600;text-decoration:none}.skip-link:focus{position:fixed;top:0;left:0;width:auto;height:auto;clip:auto;margin:0;overflow:visible;white-space:normal}.u-center{text-align:center}.u-flex1{flex:1}.u-ml-auto{margin-left:auto}.u-mb-4{margin-bottom:4px}.u-mb-8{margin-bottom:8px}.u-mb-12{margin-bottom:12px}.u-mb-16{margin-bottom:16px}.u-mb-20{margin-bottom:20px}.u-mb-24{margin-bottom:24px}.u-mt-4{margin-top:4px}.u-mt-8{margin-top:8px}.u-mt-12{margin-top:12px}.u-mt-16{margin-top:16px}.u-mx-auto{margin-left:auto;margin-right:auto}.u-center-mb16{text-align:center;margin-bottom:16px}.u-section-label{font-size:12px;font-weight:600;color:var(--label2);margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.u-section-label-sm{font-size:12px;font-weight:700;color:var(--label3);margin-bottom:8px}.u-heading-lg{font-size:22px;font-weight:700;color:var(--label)}.u-heading-md{font-size:16px;font-weight:700;color:var(--label)}.u-heading-sm{font-size:14px;font-weight:600;color:var(--label)}.u-heading-sm-mb12{font-size:14px;font-weight:600;color:var(--label);margin-bottom:12px}.u-meta{font-size:11px;color:var(--label2)}.u-meta-dim{font-size:11px;color:var(--label3)}.u-meta-dim-mb4{font-size:11px;color:var(--label3);margin-bottom:4px}.u-hint{font-size:13px;color:var(--label2)}.u-glass-pad{padding:14px 16px}.u-w100{width:100%}.u-col{display:flex;flex-direction:column}.u-col-4{display:flex;flex-direction:column;gap:4px}.u-col-6{display:flex;flex-direction:column;gap:6px}.u-col-8{display:flex;flex-direction:column;gap:8px}.u-col-10{display:flex;flex-direction:column;gap:10px}.u-col-12{display:flex;flex-direction:column;gap:12px}.u-col-14{display:flex;flex-direction:column;gap:14px}.u-row{display:flex;align-items:center}.u-row-4{display:flex;align-items:center;gap:4px}.u-row-8{display:flex;align-items:center;gap:8px}.u-row-10{display:flex;align-items:center;gap:10px}.u-row-12{display:flex;align-items:center;gap:12px}.u-gap-4{gap:4px}.u-gap-6{gap:6px}.u-gap-8{gap:8px}.u-gap-10{gap:10px}.u-gap-12{gap:12px}.u-flex-wrap{flex-wrap:wrap}.u-flex-min0{flex:1;min-width:0}.u-justify-between{display:flex;justify-content:space-between;align-items:center}.u-justify-center{display:flex;justify-content:center}.u-cursor{cursor:pointer}.u-mb-0{margin-bottom:0}.u-mb-6{margin-bottom:6px}.u-mb-10{margin-bottom:10px}.u-mb-14{margin-bottom:14px}.u-mt-0{margin-top:0}.u-mt-10{margin-top:10px}.u-p-6{padding:6px}.u-p-18{padding:18px}.u-label2-13{font-size:13px;color:var(--label2)}.u-label2-14{font-size:14px;color:var(--label2)}.u-label2-12{font-size:12px;color:var(--label2)}.u-label3-11{font-size:11px;color:var(--label3)}.u-label3-12{font-size:12px;color:var(--label3)}.card-lg{will-change:transform}.mob-scroll,.desk-area{contain:layout style}img{content-visibility:auto}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth}body{font-family:var(--font-sans);color:var(--label);min-height:100vh;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;letter-spacing:-.011em;font-feature-settings:"cv01","cv02","cv03","cv11";background:radial-gradient(ellipse 80% 70% at 8% 4%,rgba(0,113,227,.1) 0%,transparent 58%),radial-gradient(ellipse 65% 65% at 93% 88%,rgba(0,56,128,.06) 0%,transparent 60%),radial-gradient(ellipse 55% 50% at 56% 1%,rgba(90,200,250,.12) 0%,transparent 55%),radial-gradient(ellipse 42% 46% at 10% 90%,rgba(175,210,255,.14) 0%,transparent 54%),var(--page-bg)}html[data-theme=dark] body{background:radial-gradient(ellipse 72% 62% at 10% 10%,rgba(0,50,120,.5) 0%,transparent 60%),radial-gradient(ellipse 65% 62% at 92% 84%,rgba(0,20,80,.4) 0%,transparent 60%),radial-gradient(ellipse 44% 40% at 53% 48%,rgba(0,60,140,.15) 0%,transparent 55%),radial-gradient(ellipse 38% 36% at 20% 94%,rgba(20,70,160,.1) 0%,transparent 50%),var(--page-bg)}button{font-family:inherit;cursor:pointer;border:none;background:none;min-height:36px}@media(max-width:768px){::-webkit-scrollbar{display:none}}#root{display:flex;justify-content:center;min-height:100vh}.shell{width:100%;min-height:100vh;display:flex;flex-direction:column;position:relative}[dir=rtl] .mob-nav-inner,[dir=rtl] .nav-pills{flex-direction:row-reverse}[dir=rtl] .sb-item{text-align:right;flex-direction:row-reverse}[dir=rtl] .mob-tab,[dir=rtl] .mob-tab-label{direction:rtl}[dir=rtl] input,[dir=rtl] textarea{text-align:right}[dir=rtl] .card{direction:rtl}.dlg-screen{display:flex;flex-direction:column;gap:14px;padding:20px;max-width:720px;margin:0 auto;padding-bottom:calc(80px + env(safe-area-inset-bottom,8px))}.dlg-header{text-align:center;margin-bottom:4px}.dlg-title{font-size:22px;font-weight:800;color:var(--label);margin:0}.dlg-subtitle{font-size:13px;color:var(--label3);margin:4px 0 0}.dlg-card{background:var(--g-bg);border:.5px solid var(--g-border);border-radius:var(--radius-lg);padding:16px 18px;backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);box-shadow:var(--g-depth-1),var(--g-shine)}.dlg-main-card{padding:20px}.dlg-level-pills{display:flex;flex-wrap:wrap;gap:6px}.dlg-pill{display:inline-flex;align-items:center;gap:2px;padding:6px 14px;border-radius:20px;border:1.5px solid var(--sep);background:var(--fill2);font-size:13px;font-weight:600;color:var(--label2);cursor:pointer;transition:all .15s;font-family:inherit}.dlg-pill:hover{background:var(--fill)}.dlg-pill.active{font-weight:700}.dlg-start-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border-radius:var(--radius-md);background:var(--blue);color:#fff;border:none;font-size:var(--fs-base);font-weight:700;cursor:pointer;font-family:var(--font-sans);transition:all var(--t-normal);box-shadow:0 2px 8px #0071e32e}.dlg-start-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px #0071e340;filter:brightness(1.06)}.dlg-list-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:14px;background:var(--g-bg);border:.5px solid var(--g-border);cursor:pointer;transition:all .15s;text-align:left;font-family:inherit;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.dlg-list-item:hover{background:var(--fill2);transform:translateY(-1px)}.dlg-list-item.correct{border-left:3px solid var(--green)}.dlg-list-item.wrong{border-left:3px solid var(--red)}.dlg-list-num{width:28px;height:28px;border-radius:50%;background:var(--fill);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--label2);flex-shrink:0}.dlg-list-info{flex:1;min-width:0}.dlg-list-ctx{font-size:14px;font-weight:600;color:var(--label)}.dlg-list-preview{font-size:12px;color:var(--label3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dlg-list-status{font-size:18px}.dlg-list-arrow{font-size:22px;color:var(--label3);font-weight:300}.dlg-exercise-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.dlg-back-btn{background:none;border:none;color:var(--blue);font-size:14px;font-weight:600;cursor:pointer;padding:4px 0;font-family:inherit}.dlg-exercise-counter{font-size:13px;color:var(--label3);font-weight:600}.dlg-progress-bar{height:4px;background:var(--fill);border-radius:2px;overflow:hidden;margin-bottom:16px}.dlg-progress-fill{height:100%;background:var(--blue);border-radius:2px;transition:width .3s}.dlg-context-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;background:var(--fill2);border:.5px solid var(--g-border);font-size:13px;font-weight:600;color:var(--label2);margin-bottom:16px}.dlg-conversation{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;padding:8px 0}.dlg-bubble-row{display:flex;align-items:flex-start;gap:8px;animation:dlgFadeIn .3s ease both}.dlg-bubble-row.left{flex-direction:row}.dlg-bubble-row.right{flex-direction:row-reverse}@keyframes dlgFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dlg-speaker-badge{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0;color:#fff}.dlg-speaker-badge.a{background:var(--blue)}.dlg-speaker-badge.b{background:var(--teal)}.dlg-bubble{max-width:75%;padding:12px 16px;border-radius:18px;position:relative;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:all .3s}.dlg-bubble.a{background:#0052a514;border:.5px solid rgba(0,82,165,.15);border-bottom-left-radius:6px}.dlg-bubble.b{background:#4a96c814;border:.5px solid rgba(74,150,200,.15);border-bottom-right-radius:6px}.dlg-bubble.blank{animation:dlgPulse 2s ease-in-out infinite}@keyframes dlgPulse{0%,to{box-shadow:0 0 #0052a51a}50%{box-shadow:0 0 0 6px #0052a50d}}.dlg-bubble-text{font-size:15px;line-height:1.5;color:var(--label)}.dlg-bubble.blank .dlg-bubble-text{font-size:18px;font-weight:700;color:var(--blue);text-align:center;letter-spacing:4px}.dlg-bubble-correct-label{font-size:11px;font-weight:700;margin-top:6px;color:var(--green)}.dlg-options{display:flex;flex-direction:column;gap:8px}.dlg-options-label{font-size:12px;font-weight:700;color:var(--label3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}.dlg-option{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:14px;background:var(--g-bg);border:1.5px solid var(--g-border);cursor:pointer;transition:all .15s;text-align:left;font-family:inherit;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);min-height:60px}.dlg-option:hover{border-color:var(--blue);background:#0052a50f;transform:translateY(-1px)}.dlg-opt-letter{width:26px;height:26px;border-radius:50%;background:var(--fill);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--label2);flex-shrink:0}.dlg-opt-text{font-size:14px;color:var(--label);flex:1}.dlg-feedback-area{display:flex;flex-direction:column;gap:12px}.dlg-feedback{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:14px}.dlg-feedback.correct{background:#2db84d1a;border:1px solid rgba(45,184,77,.2)}.dlg-feedback.wrong{background:#e5342b14;border:1px solid rgba(229,52,43,.15)}.dlg-feedback-icon{font-size:24px;flex-shrink:0}.dlg-feedback-title{font-size:15px;font-weight:700;color:var(--label)}.dlg-feedback-explain{font-size:13px;color:var(--label2);margin-top:4px;line-height:1.5}.dlg-answered-options{display:flex;flex-direction:column;gap:6px}.dlg-option-result{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:12px;font-size:14px}.dlg-option-result.correct{background:#2db84d14;border:1px solid rgba(45,184,77,.2)}.dlg-option-result.wrong{background:#e5342b0f;border:1px solid rgba(229,52,43,.15)}.dlg-option-result.dimmed{background:var(--fill2);border:.5px solid var(--g-border);opacity:.5}.dlg-opt-check{color:var(--green);font-weight:700;margin-left:auto}.dlg-opt-cross{color:var(--red);font-weight:700;margin-left:auto}.dlg-translation-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:20px;background:var(--fill2);border:.5px solid var(--g-border);font-size:13px;font-weight:600;color:var(--label2);cursor:pointer;font-family:inherit;transition:all .15s;align-self:center;margin:0 auto}.dlg-translation-btn:hover{background:var(--fill)}.dlg-translation{font-size:13px;color:var(--label3);line-height:1.6;padding:12px 16px;background:var(--fill2);border-radius:12px;font-style:italic;text-align:center}.dlg-btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:12px 28px;border-radius:12px;background:var(--blue);color:#fff;border:none;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s}.dlg-btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0052a540}.dlg-btn-secondary{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border-radius:12px;background:var(--fill2);color:var(--label);border:.5px solid var(--g-border);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.dlg-btn-secondary:hover{background:var(--fill)}.dlg-results-header{text-align:center;padding:24px 0}.dlg-results-score{font-size:36px;font-weight:800;color:var(--label);margin-top:8px}.dlg-results-pct{font-size:18px;font-weight:700;color:var(--blue)}.dlg-results-msg{font-size:16px;color:var(--label2);margin-top:6px}.dlg-results-actions{display:flex;gap:10px;justify-content:center;margin-top:20px;flex-wrap:wrap}.dlg-review-list{display:flex;flex-direction:column;gap:8px}.dlg-review-item{padding:10px 14px;border-radius:12px;font-size:13px}.dlg-review-item.correct{background:#2db84d0f;border-left:3px solid var(--green)}.dlg-review-item.wrong{background:#e5342b0d;border-left:3px solid var(--red)}.dlg-review-q{font-weight:600;color:var(--label);margin-bottom:2px}.dlg-review-a{color:var(--label2)}.mob-nav{position:sticky;top:0;z-index:100;flex-shrink:0;backdrop-filter:blur(50px) saturate(180%);-webkit-backdrop-filter:blur(50px) saturate(180%);background:var(--tab-g);border-bottom:.5px solid var(--g-border);box-shadow:0 .5px 0 var(--g-border);padding:14px 20px 12px}.mob-nav-inner{display:flex;align-items:center;justify-content:space-between}.mob-title{font-size:var(--fs-lg);font-weight:700;letter-spacing:-.02em;color:var(--label);line-height:1}.mob-sub{font-size:var(--fs-xs);color:var(--label2);margin-top:2px;font-weight:500}.nav-pills{display:flex;gap:6px;align-items:center}.nav-pill{display:flex;align-items:center;justify-content:center;background:var(--fill2);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:.5px solid var(--g-border);border-radius:var(--radius-sm);font-size:var(--fs-sm);font-weight:600;color:var(--label);box-shadow:none;width:36px;height:36px;padding:0;transition:background var(--t-fast)}.nav-pill:hover{background:var(--fill)}.nav-pill--text{width:auto;padding:0 14px;border-radius:999px;gap:4px;font-weight:700}.mob-tabs{position:fixed;bottom:calc(env(safe-area-inset-bottom,0px) + 12px);left:50%;transform:translate(-50%);width:calc(100% - 32px);max-width:400px;backdrop-filter:blur(60px) saturate(180%);-webkit-backdrop-filter:blur(60px) saturate(180%);background:var(--tab-g);border:.5px solid var(--g-border);border-radius:var(--radius-xl);display:flex;box-shadow:var(--g-depth-3);z-index:300;overflow:hidden}.mob-tab{flex:1;display:flex;flex-direction:column;align-items:center;padding:12px 0 10px;gap:3px;font-size:0;font-weight:500;letter-spacing:.2px;min-height:44px;min-width:44px;color:var(--label2);transition:color .18s,transform .18s;position:relative}.mob-tab:active{transform:scale(.92)}.mob-tab.on{color:var(--blue)}.mob-tab.on:after{content:"";position:absolute;bottom:4px;width:5px;height:5px;border-radius:50%;background:var(--blue);box-shadow:0 0 6px #0071e359}.mob-tab.on .tab-icon{filter:drop-shadow(0 0 6px rgba(0,113,227,.3));transform:scale(1.06)}.tab-icon{font-size:22px;line-height:1;transition:filter var(--t-normal),transform var(--t-normal)}*{-webkit-tap-highlight-color:transparent}button,a,.card-lg{-webkit-touch-callout:none}.vocab-fullpage{-webkit-user-select:none;user-select:none}input,textarea,select{font-size:16px!important;font-family:var(--font-sans);outline:none;transition:border-color var(--t-fast),box-shadow var(--t-fast)}input:focus-visible,textarea:focus-visible,select:focus-visible{border-color:var(--blue)!important;box-shadow:0 0 0 4px #0071e31f}.mob-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;background:transparent}.mob-scroll::-webkit-scrollbar{width:4px}.mob-scroll::-webkit-scrollbar-track{background:transparent}.mob-scroll::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}html[data-theme=dark] .mob-scroll::-webkit-scrollbar-thumb{background:#ffffff14}.sidebar,.desk-header{display:none}.desk-area{display:contents}.dash-grid{display:flex;flex-direction:column;gap:12px}.stat-row{display:flex;gap:10px}.stat-row>.stat{animation:staggerFadeUp .35s cubic-bezier(.34,1.18,.64,1) both}.stat-row>.stat:nth-child(1){animation-delay:0ms}.stat-row>.stat:nth-child(2){animation-delay:60ms}.stat-row>.stat:nth-child(3){animation-delay:.12s}.stat-row>.stat:nth-child(4){animation-delay:.18s}.pad{padding:20px 20px calc(120px + env(safe-area-inset-bottom,8px))}.lesson-grid{display:flex;flex-direction:column;gap:12px}@media(min-width:480px){.pad{padding:24px 32px calc(120px + env(safe-area-inset-bottom,8px))}.dash-grid{gap:14px}.lesson-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.stat-row{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}}@media(min-width:768px){#root{align-items:stretch;justify-content:stretch}.shell{flex-direction:row;width:100%;min-height:100vh}.mob-nav,.mob-tabs{display:none}.mob-scroll{padding-bottom:0;overflow-y:visible;background:transparent}.sidebar{display:flex}.desk-area{flex:1;min-width:0;display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch;background:transparent}.desk-header{display:flex;padding:20px 40px;align-items:center;justify-content:space-between;margin-bottom:0;position:sticky;top:0;z-index:50;flex-shrink:0;background:var(--sidebar-g);backdrop-filter:blur(64px) saturate(180%);-webkit-backdrop-filter:blur(64px) saturate(180%);border-bottom:.5px solid var(--g-border)}.desk-title{font-size:var(--fs-2xl);font-weight:700;letter-spacing:-.025em;color:var(--label)}.pad{padding:32px 40px 52px}.lesson-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.fc-constrain{max-width:960px;margin:0 auto;width:100%}.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.dash-span{grid-column:1/-1}.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}}@media(min-width:900px){.pad{padding:32px 44px 52px}.lesson-grid{grid-template-columns:repeat(3,1fr);gap:14px}.dash-grid{grid-template-columns:repeat(2,1fr);gap:16px}}@media(min-width:1100px){.pad{padding:36px 52px 56px}.lesson-grid{grid-template-columns:repeat(4,1fr);gap:16px}}.sidebar{flex-direction:column;width:var(--sidebar-w);flex-shrink:0;background:var(--sidebar-g);backdrop-filter:blur(64px) saturate(180%);-webkit-backdrop-filter:blur(64px) saturate(180%);border-right:.5px solid var(--g-border);box-shadow:var(--g-depth-1);position:sticky;top:0;height:100vh;overflow-y:auto;overflow-x:hidden;padding:24px 14px;scrollbar-width:none;-ms-overflow-style:none}.sidebar::-webkit-scrollbar{display:none}.sb-brand{display:flex;align-items:center;gap:10px;padding:8px 8px 16px;justify-content:center;flex-direction:column;text-align:center}.sb-flag{font-size:32px;line-height:1}.sb-name{font-size:var(--fs-md);font-weight:700;color:var(--label);line-height:1.2;letter-spacing:-.02em}.sb-tagline{font-size:var(--fs-xs);color:var(--label2);font-weight:500}.sb-section{font-size:var(--fs-xs);font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--label3);padding:0 10px;margin:14px 0 6px}.sb-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);font-size:var(--fs-base);font-weight:500;color:var(--label);transition:all var(--t-fast) var(--ease-smooth);width:100%;text-align:left;border:.5px solid transparent}.sb-item:hover{background:var(--fill2);border-color:var(--g-border)}.sb-item.on{background:#0071e31a;color:var(--blue);font-weight:600;border-color:transparent;border-radius:var(--radius-sm);box-shadow:none}.sb-item-icon{width:22px;text-align:center;font-size:18px;flex-shrink:0}.nav-group{margin:0}.nav-group-header{cursor:pointer;justify-content:space-between}.nav-group-arrow{font-size:12px;color:var(--label2);transition:transform .25s cubic-bezier(.4,0,.2,1);display:inline-block}.nav-group-arrow.expanded{transform:rotate(90deg)}.nav-group-children{overflow:hidden;max-height:0;transition:max-height .3s cubic-bezier(.4,0,.2,1);padding-left:16px}.nav-group-children.expanded{max-height:500px}.sb-child-item{font-size:14px!important;padding:9px 14px!important}.sb-footer{border-top:.5px solid var(--sep);padding-top:20px;display:flex;flex-direction:column;gap:4px}.sb-stat{display:flex;align-items:center;gap:8px;padding:0 8px;font-size:13px;font-weight:500;color:var(--label2)}.sb-stat-val{font-size:15px;font-weight:700;color:var(--label);margin-left:auto}button,.nav-pill,.choice-btn,[role=button]{transition:transform var(--t-fast) ease,box-shadow var(--t-normal) ease}button:active,.nav-pill:active,.choice-btn:active{transform:scale(.97)}.glass-card,.g-card,.lesson-card,.stat-card,.dlg-card{transition:transform var(--t-normal) var(--ease-smooth),box-shadow var(--t-normal)}@media(hover:hover){.glass-card:hover,.g-card:hover,.lesson-card:hover{transform:translateY(-2px);box-shadow:var(--g-depth-2)}}.count-up{display:inline-block}.btn-primary-gradient{background:var(--blue)!important;border:none!important;color:#fff!important;font-weight:600;padding:14px 28px;border-radius:var(--radius-md);font-size:var(--fs-base);cursor:pointer;transition:transform var(--t-fast),box-shadow var(--t-normal),filter var(--t-normal);box-shadow:0 2px 8px #0071e333}.btn-primary-gradient:hover{box-shadow:0 4px 16px #0071e34d;filter:brightness(1.06)}.btn-primary-gradient:active{transform:scale(.97)}.card-elevated{box-shadow:var(--g-depth-1)}.card-floating{box-shadow:var(--g-depth-3)}.sb-separator{height:.5px;background:var(--sep);margin:8px 16px}.sidebar .sb-item.on{border-left:3px solid var(--current-mod, var(--blue));background:#0071e314;padding-left:11px}html[data-theme=dark] .sidebar .sb-item.on{background:#0071e31f}@media(min-width:768px){.sidebar{border-radius:0}}@media(max-width:768px){.mob-scroll{padding-bottom:100px}}.progress-bar-animated{transition:width .8s cubic-bezier(.4,0,.2,1)}.progress-bar-animated.active{animation:progressGlow 2s infinite}.dlg-progress-bar>div,.challenge-progress-bar>div,.av-level-bar>div,.fc-challenge-progress-bar>div,.pic-progress-bar>div,.listen-progress-bar>div{transition:width .8s cubic-bezier(.4,0,.2,1)}.heading-xl{font-size:var(--fs-display);font-weight:800;letter-spacing:-.025em;line-height:1.08}.heading-lg{font-size:var(--fs-xl);font-weight:700;letter-spacing:-.02em;line-height:1.14}.heading-md{font-size:var(--fs-md);font-weight:600;line-height:1.3;letter-spacing:-.01em}.body-lg{font-size:var(--fs-base);line-height:1.53}.body-sm{font-size:var(--fs-sm);line-height:1.5;color:var(--label2)}.caption{font-size:var(--fs-xs);line-height:1.4;color:var(--label3)}.section-gap{margin-bottom:var(--space-xl)}.section-title{font-size:var(--fs-sm);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--label3);margin-bottom:12px}.t-display{font-size:var(--fs-display);font-weight:700;letter-spacing:-.025em;color:var(--label)}.t-title{font-size:clamp(20px,3vw+4px,28px);font-weight:700;letter-spacing:-.02em;color:var(--label)}.t-head{font-size:clamp(15px,2vw+2px,18px);font-weight:600;color:var(--label);letter-spacing:-.01em}.t-sub{font-size:clamp(14px,1.5vw+2px,16px);color:var(--label)}.t-foot{font-size:clamp(12px,1vw+2px,14px);color:var(--label2)}.t-cap{font-size:clamp(11px,.8vw+2px,13px);font-weight:500;color:var(--label2)}.t-cap2{font-size:var(--fs-xs);font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--label3)}.scene-lbl{color:#ffffffd1!important;text-shadow:0 1px 6px rgba(0,0,0,.7),0 2px 20px rgba(0,0,0,.4)}.card{background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border-radius:var(--radius-lg);overflow:hidden;border:.5px solid var(--g-border);box-shadow:var(--g-depth-1),var(--g-shine);will-change:transform;transform:translateZ(0);-webkit-transform:translateZ(0)}.card-lg{background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border-radius:var(--radius-xl);overflow:hidden;border:.5px solid var(--g-border);box-shadow:var(--g-depth-1),var(--g-shine);will-change:transform;transform:translateZ(0);-webkit-transform:translateZ(0)}.build-screen{max-width:900px;margin:0 auto;padding:20px;display:flex;flex-direction:column;gap:16px;font-family:var(--font-sans)}.build-card{background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border-radius:var(--radius-lg);overflow:hidden;border:.5px solid var(--g-border);box-shadow:var(--g-depth-1),var(--g-shine);padding:20px;transition:transform var(--t-fast) var(--ease-spring),box-shadow var(--t-normal);animation:slideUp .35s var(--ease-out) both}.build-card:hover{box-shadow:var(--g-depth-2),var(--g-shine);transform:translateY(-1px)}.scene-bg .build-card,.scene-bg .card,.scene-bg .card-lg{background:#ffffff24!important;border:1px solid rgba(255,255,255,.22)!important;border-radius:var(--radius-lg)!important;backdrop-filter:blur(40px) saturate(180%)!important;-webkit-backdrop-filter:blur(40px) saturate(180%)!important;box-shadow:inset 0 1px #ffffff47,inset 0 -.5px #ffffff0f,0 2px 16px #00000052,0 0 1px #ffffff26!important;--label:#f5f2ec;--label2:rgba(255,255,255,.75);--label3:rgba(255,255,255,.5);--sep:rgba(255,255,255,.12);--fill:rgba(255,255,255,.1);--fill2:rgba(255,255,255,.05);color:var(--label)!important}.scene-bg .build-card:hover,.scene-bg .card:hover,.scene-bg .card-lg:hover{background:#fff3!important;border-color:#ffffff4d!important;box-shadow:inset 0 1px #ffffff59,inset 0 -.5px #ffffff14,0 4px 24px #00000061,0 0 1px #fff3!important;transform:translateY(-2px)}.scene-bg button.build-card,.scene-bg button.card-lg{background:#ffffff24!important;border:1px solid rgba(255,255,255,.22)!important;backdrop-filter:blur(40px) saturate(180%)!important;-webkit-backdrop-filter:blur(40px) saturate(180%)!important;box-shadow:inset 0 1px #ffffff47,inset 0 -.5px #ffffff0f,0 2px 16px #00000052,0 0 1px #ffffff26!important}.scene-bg button.build-card:hover,.scene-bg button.card-lg:hover{background:#fff3!important;border-color:#ffffff4d!important;box-shadow:inset 0 1px #ffffff59,0 4px 24px #00000061,0 0 1px #fff3!important}.btn{display:block;width:100%;font-family:var(--font-sans);font-weight:600;font-size:var(--fs-md);border-radius:var(--radius-md);padding:16px;transition:transform var(--t-fast) var(--ease-spring),box-shadow var(--t-normal),opacity .15s}.btn:active{transform:scale(.97)!important}.btn-blue{background:var(--blue);color:#fff;border:none;box-shadow:0 1px 2px #0000000f,0 4px 16px #0071e347;transition:transform var(--t-fast) var(--ease-spring),box-shadow var(--t-normal),filter var(--t-normal)}.btn-blue:hover{filter:brightness(1.06);box-shadow:0 2px 4px #00000014,0 8px 24px #0071e35c}.btn-green{background:var(--green);color:#fff;border:none;box-shadow:0 1px 2px #0000000f,0 4px 16px #30d15847;transition:transform var(--t-fast) var(--ease-spring),box-shadow var(--t-normal),filter var(--t-normal)}.btn-green:hover{filter:brightness(1.06);box-shadow:0 2px 4px #00000014,0 8px 24px #30d1585c}.btn-fill{background:var(--g-bg);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);color:var(--label);border:.5px solid var(--g-border);box-shadow:var(--g-depth-1)}.btn-sm{font-size:var(--fs-base);font-weight:600;border-radius:var(--radius-sm);padding:10px 18px;display:inline-block;width:auto}.row{display:flex;align-items:center;gap:14px;padding:13px 16px;border-bottom:.5px solid var(--sep);transition:background .12s}.row:last-child{border-bottom:none}.row:active,.row:hover{background:var(--fill)}.row-icon{width:44px;height:44px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:22px}.track{background:var(--fill);border-radius:999px;overflow:hidden}.fill-bar{border-radius:999px;position:relative;transition:width .65s cubic-bezier(.25,.46,.45,.94)}.fill-bar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.28) 50%,transparent 100%);pointer-events:none}.pill{display:inline-flex;align-items:center;background:var(--fill);border-radius:999px;padding:4px 12px;font-size:13px;font-weight:500;color:var(--label)}.lv-Beginner{color:#1a9e3c;background:#2aaa4b26}.lv-Intermediate{color:#c47600;background:#d2820024}.lv-Advanced{color:#d42a1f;background:#dc32281f}html[data-theme=dark] .lv-Beginner{color:#34c759;background:#34c75926}html[data-theme=dark] .lv-Intermediate{color:#ff9500;background:#ff950026}html[data-theme=dark] .lv-Advanced{color:#ff3b30;background:#ff3b301f}.choice{width:100%;text-align:left;padding:14px 16px;border-radius:var(--radius-md);font-size:var(--fs-base);font-weight:500;background:var(--g-bg);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border:1.5px solid var(--g-border);color:var(--label);box-shadow:var(--g-depth-1);transition:all var(--t-fast) var(--ease-smooth);display:flex;align-items:center;gap:10px}.choice:active:not(:disabled){transform:scale(.98)}.choice.sel{border-color:var(--blue);background:#0071e314;color:var(--blue);box-shadow:0 0 0 3px #0071e31f,var(--g-depth-1)}.choice.ok{border-color:var(--green);background:#30d15814;color:var(--green);box-shadow:0 0 0 3px #30d1581f;animation:correctGlow .5s ease both}.choice.no{border-color:var(--red);background:#ff453a0f;color:var(--red);box-shadow:0 0 0 3px #ff453a1a;animation:wrongShakeH .45s ease both}.choice.dim{border-color:var(--sep);color:var(--label3);opacity:.42}.choice-lbl{width:28px;height:28px;border-radius:999px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:var(--fs-sm);font-weight:700;background:var(--fill);color:var(--label2);transition:background var(--t-fast),color var(--t-fast)}.choice.sel .choice-lbl{background:var(--blue);color:#fff}.choice.ok .choice-lbl{background:var(--green);color:#fff}.choice.no .choice-lbl{background:var(--red);color:#fff}.vocab-fullpage{display:flex;flex-direction:column;height:100vh;height:100dvh;padding:8px 16px 0;padding-bottom:calc(70px + env(safe-area-inset-bottom,8px));overflow:hidden;box-sizing:border-box}.mob-scroll:has(.vocab-fullpage){overflow:hidden!important;height:100vh;height:100dvh}.vocab-fullpage .vc-card-area{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}@media(min-width:768px){.vocab-fullpage{padding:16px 32px 20px;height:100vh}.desk-area:has(.vocab-fullpage){overflow:hidden!important}}.vc-card{background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border-radius:var(--radius-xl);border:.5px solid var(--g-border);box-shadow:var(--g-depth-2),var(--g-shine);padding:24px 20px;text-align:center;width:100%;max-width:560px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12;position:relative;user-select:none;-webkit-user-select:none;transition:box-shadow var(--t-normal);min-height:0;touch-action:none;-webkit-tap-highlight-color:transparent}@media(min-width:768px){.vc-card{padding:56px 48px;min-height:420px;max-width:720px;border-radius:28px;gap:22}}@media(min-width:1100px){.vc-card{min-height:480px;max-width:800px}}.vc-card:active{box-shadow:0 1px 8px #0000000f}.vc-fi{font-size:clamp(38px,11vw,72px);font-weight:700;color:var(--blue);letter-spacing:-.03em;line-height:1.1;text-shadow:0 0 40px rgba(0,113,227,.12)}.vc-en{font-size:clamp(32px,9vw,64px);font-weight:700;color:var(--label);letter-spacing:-.4px;line-height:1.1}@media(min-width:768px){.vc-fi{font-size:clamp(56px,5.5vw,96px)}.vc-en{font-size:clamp(48px,4.5vw,84px)}}@media(min-width:1100px){.vc-fi{font-size:clamp(64px,6vw,108px)}.vc-en{font-size:clamp(52px,5vw,92px)}}.vc-cat{background:#0052a51a;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:.5px solid rgba(0,82,165,.22);border-radius:999px;padding:5px 16px;font-size:13px;font-weight:600;color:var(--blue)}.vc-hint{font-size:12px;color:var(--label3);margin-top:4px}.vc-example{background:#0052a50f;border:.5px solid rgba(0,82,165,.14);border-radius:14px;padding:14px 16px;text-align:left;width:100%;max-width:400px}.vc-actions{display:flex;gap:8px;width:100%;max-width:800px;margin:0 auto;padding:0}.vc-actions button{flex:1;min-height:44px;border-radius:14px;font-weight:700;font-size:15px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6;transition:transform .12s,opacity .12s;font-family:inherit;-webkit-tap-highlight-color:transparent;touch-action:manipulation}@media(min-width:768px){.vc-actions button{min-height:58px;font-size:17px;border-radius:18px}}.vc-actions button:active{transform:scale(.97)}.vc-btn-again{background:#ff453a14;color:var(--red);border:1.5px solid rgba(255,69,58,.2)!important}.vc-btn-good{background:#0071e314;color:var(--blue);border:1.5px solid rgba(0,113,227,.18)!important}.vc-btn-known{background:#30d15814;color:var(--green);border:1.5px solid rgba(48,209,88,.2)!important}.vc-btn-reveal{background:var(--blue);color:#fff;font-size:var(--fs-md);min-height:56px;-webkit-tap-highlight-color:transparent;box-shadow:0 2px 8px #0071e333}@media(min-width:768px){.vc-btn-reveal{min-height:62px;font-size:18px}}.vc-stats{display:flex;justify-content:center;gap:28px;padding:6px 0 2px}.vc-stats>div{text-align:center}.vc-stats .vc-stat-num{font-size:20px;font-weight:700;letter-spacing:-.3px}.vc-stats .vc-stat-lbl{font-size:10px;font-weight:500;color:var(--label2);margin-top:1px}.hero{border-radius:var(--radius-xl);padding:28px 24px 24px;color:#fff;background:linear-gradient(140deg,#001d3d,#0071e3 55%,#5ac8fa);position:relative;overflow:hidden;border:.5px solid rgba(255,255,255,.18);box-shadow:0 2px 4px #0000000a,0 8px 32px #0071e333}.hero-chips{display:flex;gap:8px;margin:12px 0 16px;flex-wrap:wrap}.hero-chip{background:#ffffff2e;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:.5px solid rgba(255,255,255,.3);border-radius:999px;padding:5px 14px;font-size:var(--fs-sm);font-weight:600;color:#fff}.stat{flex:1;background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border-radius:var(--radius-lg);padding:18px 16px;display:flex;flex-direction:column;gap:6px;border:.5px solid var(--g-border);box-shadow:var(--g-depth-1),var(--g-shine);min-height:108px;justify-content:center;will-change:transform,backdrop-filter;transform:translateZ(0);-webkit-transform:translateZ(0)}.lesson-banner{border-radius:20px;overflow:hidden;position:relative;border:.5px solid var(--g-border);box-shadow:0 2px 16px #0000000f;background:var(--fill);aspect-ratio:16/7;margin-bottom:16px}.lesson-banner img{width:100%;height:100%;object-fit:cover;display:block;transition:opacity .35s}.lesson-banner-overlay{position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(transparent,#0000004d);pointer-events:none}.lesson-thumb{width:44px;height:44px;border-radius:12px;overflow:hidden;flex-shrink:0;border:.5px solid var(--g-border);object-fit:cover;display:block}.video-embed-wrap{border-radius:18px;overflow:hidden;position:relative;aspect-ratio:16/9;border:.5px solid var(--g-border);box-shadow:0 2px 16px #0000000f;background:#000}.video-embed-wrap iframe{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:none}.video-link-card{display:flex;align-items:center;gap:13;background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);border-radius:18px;padding:14px 16px;box-shadow:0 2px 16px #0000000f;text-decoration:none;transition:transform .15s,box-shadow .15s}.video-link-card:hover{transform:translateY(-1px);box-shadow:0 8px 32px #0000001a,0 2px 8px #0000000d}.video-source-badge{display:inline-flex;align-items:center;gap:4px;border-radius:999px;padding:3px 10px;font-size:11px;font-weight:700;letter-spacing:.2px}.badge-youtube{background:#ff00001f;color:#e00}.badge-yle{background:#0064c81f;color:var(--blue)}.badge-vimeo{background:#1ab7ea1f;color:#1ab7ea}.badge-ext{background:var(--fill);color:var(--label2)}.video-play-btn{width:48px;height:48px;border-radius:14px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--fill);border:.5px solid var(--g-border)}.sec-hdr{display:flex;align-items:center;gap:8px;margin-bottom:10px}.ctx-doc-area{background:#fffcf5f2;border:1px solid rgba(0,0,0,.08);border-radius:8px;padding:24px 20px;font-family:monospace;font-size:14px;line-height:1.7;white-space:pre-line;color:#1a1a1a;margin-bottom:14px;box-shadow:0 2px 8px #0000000f,inset 0 0 0 1px #00000005}html[data-theme=dark] .ctx-doc-area{background:#1e1c18eb!important;color:#e0ddd8!important;border-color:#ffffff14!important}.badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px;padding:4px 0}.badge-grid>*{animation:staggerFadeUp .35s cubic-bezier(.34,1.18,.64,1) both}.badge-grid>*:nth-child(1){animation-delay:0ms}.badge-grid>*:nth-child(2){animation-delay:50ms}.badge-grid>*:nth-child(3){animation-delay:.1s}.badge-grid>*:nth-child(4){animation-delay:.15s}.badge-grid>*:nth-child(5){animation-delay:.2s}.badge-grid>*:nth-child(6){animation-delay:.25s}.badge-grid>*:nth-child(7){animation-delay:.3s}.badge-grid>*:nth-child(8){animation-delay:.35s}.badge-grid>*:nth-child(n+9){animation-delay:.4s}@media(min-width:600px){.badge-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.badge-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:14px 8px;border-radius:18px;text-align:center;background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);box-shadow:0 2px 16px #0000000f;transition:transform var(--t-fast),box-shadow var(--t-fast);min-height:120px;position:relative;overflow:hidden}.badge-card:active{transform:scale(.97)}.badge-card.earned{cursor:pointer}.badge-card.locked{opacity:.45;filter:grayscale(.6)}.badge-card .badge-icon{font-size:36px;margin-bottom:6px;line-height:1.2;display:block}.badge-card.earned .badge-icon{animation:badgeGlow 2.5s ease-in-out infinite}.badge-card .badge-name{font-size:11px;font-weight:700;color:var(--label);line-height:1.3;margin-bottom:2px}.badge-card .badge-tier{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;border-radius:99px;padding:1px 7px}.badge-tier.bronze{background:#cd7f322e;color:#cd7f32}.badge-tier.silver{background:#c0c0c02e;color:#a0a0a0}.badge-tier.gold{background:#ffcc002e;color:#d4a800}html[data-theme=dark] .badge-tier.bronze{background:#cd7f3240;color:#e0a060}html[data-theme=dark] .badge-tier.silver{background:#c0c0c038;color:silver}html[data-theme=dark] .badge-tier.gold{background:#ffcc0038;color:gold}.badge-card .badge-hint{font-size:9px;color:var(--label3);margin-top:4px;line-height:1.3}.badge-card .badge-date{font-size:9px;color:var(--label3);margin-top:3px}.badge-card.earned .badge-shine{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(from 0deg,transparent 0%,rgba(255,255,255,.06) 10%,transparent 20%);animation:badgeSpin 6s linear infinite;pointer-events:none}@keyframes badgeSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.badge-card.recent{box-shadow:0 0 20px #ffcc004d,0 2px 16px #0000000f}@keyframes recentPulse{0%,to{box-shadow:0 0 12px #fc03,0 2px 16px #0000000f}50%{box-shadow:0 0 24px #ffcc0073,0 2px 16px #0000000f}}.badge-card.recent{animation:recentPulse 2s ease-in-out infinite}.badge-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:#000000a6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:fadeIn var(--t-normal) ease-out}.badge-modal{background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);box-shadow:0 12px 48px #0003;border-radius:28px;padding:32px 28px 24px;text-align:center;max-width:320px;width:90%;position:relative;overflow:hidden;animation:badgeModalIn .5s cubic-bezier(.34,1.56,.64,1)}@keyframes badgeModalIn{0%{opacity:0;transform:scale(.5) translateY(30px)}to{opacity:1;transform:scale(1) translateY(0)}}.badge-modal .badge-modal-icon{font-size:72px;display:block;margin:0 auto 12px;animation:badgeIconPop .7s cubic-bezier(.34,1.56,.64,1) .2s both}@keyframes badgeIconPop{0%{transform:scale(0) rotate(-20deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.badge-modal .badge-modal-glow{position:absolute;top:50%;left:50%;width:200px;height:200px;transform:translate(-50%,-60%);border-radius:50%;background:radial-gradient(circle,rgba(255,204,0,.25) 0%,transparent 70%);animation:glowPulse 2s ease-in-out infinite;pointer-events:none}.badge-modal-title{font-size:22px;font-weight:800;color:var(--label);margin-bottom:4px;position:relative}.badge-modal-desc{font-size:14px;color:var(--label2);margin-bottom:16px;position:relative;line-height:1.4}.badge-modal-btn{padding:10px 28px;border-radius:999px;font-size:var(--fs-sm);font-weight:700;background:var(--blue);color:#fff;border:none;cursor:pointer;min-height:44px;box-shadow:0 2px 8px #0071e340;transition:transform var(--t-fast),filter var(--t-fast)}.badge-modal-btn:hover{filter:brightness(1.06)}.badge-modal-btn:active{transform:scale(.96)}.badge-cat-header{font-size:13px;font-weight:700;color:var(--label);margin:16px 0 8px;display:flex;align-items:center;gap:6px}.badge-cat-header span{font-size:16px}.badge-progress-pill{font-size:10px;font-weight:600;color:var(--label3);margin-left:auto}.challenge-panel{margin-top:36px}.challenge-card{position:relative;overflow:hidden;background:var(--g-bg);border-radius:20px;backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);box-shadow:0 2px 16px #0000000f;border:1.5px solid var(--g-border);padding:16px 18px;margin-bottom:10px;transition:transform var(--t-fast),box-shadow var(--t-fast)}.challenge-card:active{transform:scale(.985)}.challenge-card-easy{border-left:3px solid #2DB84D}.challenge-card-medium{border-left:3px solid #E68600}.challenge-card-hard{border-left:3px solid #E5342B}.challenge-card-complete{opacity:.75}.challenge-card-complete .challenge-title{text-decoration:line-through;opacity:.7}.challenge-card-complete:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,rgba(45,184,77,.06) 0%,transparent 70%);pointer-events:none}.challenge-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.challenge-icon{font-size:24px;width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--fill2);flex-shrink:0}.challenge-title{font-size:14px;font-weight:700;color:var(--label);line-height:1.3}.challenge-desc{font-size:12px;color:var(--label2);line-height:1.4}.challenge-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px}.challenge-xp{font-size:12px;font-weight:700;color:var(--blue);display:flex;align-items:center;gap:4px}.challenge-check{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;background:#2db84d;color:#fff;animation:challenge-pop .4s cubic-bezier(.34,1.56,.64,1)}.challenge-progress-bar{height:6px;background:var(--fill);border-radius:3px;overflow:hidden;margin-top:8px}.challenge-progress-fill{height:100%;border-radius:3px;transition:width .6s cubic-bezier(.25,1,.5,1)}.challenge-progress-fill-easy{background:linear-gradient(90deg,#2db84d,#4ade80)}.challenge-progress-fill-medium{background:linear-gradient(90deg,#e68600,#fbbf24)}.challenge-progress-fill-hard{background:linear-gradient(90deg,#e5342b,#fb7185)}.challenge-progress-text{font-size:11px;color:var(--label3);margin-top:4px;text-align:right;font-weight:600}.weekly-quest-card{background:var(--g-bg);border-radius:20px;backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);box-shadow:0 2px 16px #0000000f;border:1.5px solid var(--g-border);padding:18px 20px;margin-bottom:10px;position:relative;overflow:hidden}.weekly-quest-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--purple),var(--teal))}.weekly-quest-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.weekly-quest-icon{font-size:28px}.weekly-quest-title{font-size:15px;font-weight:700;color:var(--label)}.weekly-quest-desc{font-size:12px;color:var(--label2)}.weekly-quest-reward{font-size:13px;font-weight:700;color:var(--blue);margin-top:8px}.challenge-bonus-card{background:linear-gradient(135deg,#0052a51f,#2db84d1f);border:1.5px solid rgba(45,184,77,.3);border-radius:20px;padding:16px 18px;text-align:center;margin-top:10px;animation:challenge-glow 2s ease-in-out infinite alternate}.challenge-bonus-text{font-size:14px;font-weight:700;color:var(--label)}.challenge-bonus-xp{font-size:12px;font-weight:600;color:#2db84d;margin-top:4px}.challenge-toast{position:fixed;top:-80px;left:50%;transform:translate(-50%);z-index:10000;background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:1.5px solid var(--g-border);box-shadow:0 12px 48px #0000002e;border-radius:16px;padding:14px 20px;display:flex;align-items:center;gap:12px;min-width:280px;max-width:380px;transition:top .5s cubic-bezier(.34,1.56,.64,1)}.challenge-toast.show{top:calc(env(safe-area-inset-top,16px) + 16px)}.challenge-toast-icon{font-size:28px}.challenge-toast-text{flex:1}.challenge-toast-title{font-size:14px;font-weight:700;color:var(--label)}.challenge-toast-sub{font-size:12px;color:var(--label2)}.xp-flyup{position:fixed;pointer-events:none;z-index:10001;font-size:20px;font-weight:800;color:var(--blue);text-shadow:0 2px 8px rgba(0,82,165,.3);animation:flyup 1.2s ease-out forwards}@keyframes challenge-pop{0%{transform:scale(0)}60%{transform:scale(1.3)}to{transform:scale(1)}}@keyframes challenge-glow{0%{box-shadow:0 0 8px #2db84d1a}to{box-shadow:0 0 20px #2db84d33}}.landing-page{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;background:linear-gradient(160deg,#000,#0a1628 40%,#0d2040,#000);overflow-y:auto;overflow-x:hidden;font-family:var(--font-sans);color:#fff}.landing-inner{max-width:1100px;margin:0 auto;padding:0 24px}.landing-nav{display:flex;align-items:center;justify-content:space-between;padding:20px 0}.landing-logo{font-size:22px;font-weight:800;letter-spacing:-.5px;display:flex;align-items:center;gap:10px}.landing-logo-flag{font-size:28px}.landing-nav-btns{display:flex;gap:12px;align-items:center}.landing-nav-btn{padding:10px 22px;border-radius:12px;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .2s;font-family:inherit}.landing-nav-signin{background:transparent;color:#fffc;border:1px solid rgba(255,255,255,.15)}.landing-nav-signin:hover{background:#ffffff14;color:#fff}.landing-nav-start{background:var(--blue,#0052A5);color:#fff}.landing-nav-start:hover{background:#06c;transform:translateY(-1px);box-shadow:0 4px 20px #0052a566}.landing-hero{text-align:center;padding:80px 0 60px;position:relative}.landing-hero h1{font-size:clamp(36px,6vw,64px);font-weight:800;letter-spacing:-1.5px;line-height:1.1;margin:0 0 20px;background:linear-gradient(135deg,#fff,#ffffffd9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-hero-sub{font-size:clamp(16px,2.5vw,20px);color:#ffffffb3;max-width:640px;margin:0 auto 36px;line-height:1.6;font-weight:400}.landing-cta-group{display:flex;flex-direction:column;align-items:center;gap:12px}.landing-cta-btn{padding:16px 44px;border-radius:var(--radius-md);font-size:var(--fs-md);font-weight:700;border:none;cursor:pointer;background:var(--blue);color:#fff;transition:all var(--t-normal);box-shadow:0 2px 12px #0071e347;font-family:var(--font-sans)}.landing-cta-btn:hover{transform:translateY(-1px);box-shadow:0 4px 20px #0071e366;filter:brightness(1.06)}.landing-cta-note{font-size:13px;color:#ffffff80;font-weight:500}.landing-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;padding:40px 0 60px}.landing-feature-card{background:#ffffff0a;border:.5px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);padding:28px 24px;transition:all var(--t-normal) var(--ease-smooth);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.landing-feature-card:hover{background:#ffffff0f;border-color:#ffffff1f;transform:translateY(-2px);box-shadow:0 8px 32px #00000029}.landing-feature-icon{font-size:36px;margin-bottom:14px;display:block}.landing-feature-title{font-size:17px;font-weight:700;margin-bottom:6px;color:#fff}.landing-feature-desc{font-size:14px;color:#fff9;line-height:1.5}.landing-stats{display:flex;justify-content:center;flex-wrap:wrap;gap:12px;padding:0 0 60px}.landing-stat{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:18px 28px;text-align:center;min-width:150px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.landing-stat-val{font-size:22px;font-weight:800;color:#fff;letter-spacing:-.5px}.landing-stat-label{font-size:12px;color:#ffffff80;margin-top:4px;font-weight:500}.landing-social-proof{text-align:center;padding:0 0 60px}.landing-section-heading{font-size:22px;font-weight:700;color:#ffffffe6;margin:0 0 28px;letter-spacing:-.3px}.landing-testimonials{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-bottom:28px;text-align:left}.landing-testimonial-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:20px;transition:border-color .2s}.landing-testimonial-card:hover{border-color:#ffffff26}.landing-testimonial-stars{font-size:14px;margin-bottom:10px;letter-spacing:2px}.landing-testimonial-text{font-size:14px;line-height:1.6;color:#ffffffb3;margin:0 0 14px;font-style:italic}.landing-testimonial-author{display:flex;align-items:baseline;gap:8px}.landing-testimonial-name{font-size:13px;font-weight:700;color:#ffffffd9}.landing-testimonial-detail{font-size:12px;color:#fff6;font-weight:500}.landing-trust-badges{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}.landing-trust-badge{font-size:12px;font-weight:600;color:#fff9;background:#0052a526;border:1px solid rgba(0,82,165,.25);border-radius:20px;padding:6px 14px;letter-spacing:.2px}.landing-final-cta{text-align:center;padding:48px 20px 60px;border-top:1px solid rgba(255,255,255,.06)}.landing-final-cta h2{font-size:24px;font-weight:700;color:#ffffffe6;margin:0 0 10px}.landing-final-cta p{font-size:15px;color:#ffffff80;margin:0 0 24px}.landing-footer{border-top:1px solid rgba(255,255,255,.06);padding:28px 0;display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap}.landing-footer a,.landing-footer-link{color:#fff6;font-size:13px;line-height:1;text-decoration:none;transition:color .2s;font-weight:500;background:none;border:none;cursor:pointer;font-family:inherit;padding:0;display:inline-flex;align-items:center}.landing-footer a:hover,.landing-footer-link:hover{color:#ffffffb3}.landing-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px}.landing-modal{background:var(--card,#1a1a2e);border:1px solid rgba(255,255,255,.1);border-radius:20px;max-width:600px;width:100%;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.landing-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.08)}.landing-modal-header h2{margin:0;font-size:18px;font-weight:700;color:#ffffffe6}.landing-modal-close{background:none;border:none;color:#ffffff80;font-size:20px;cursor:pointer;padding:4px 8px;border-radius:8px;transition:background .15s}.landing-modal-close:hover{background:#ffffff14;color:#fffc}.landing-modal-body{padding:24px;overflow-y:auto;-webkit-overflow-scrolling:touch}.landing-modal-body p{font-size:14px;line-height:1.7;color:#ffffffa6;margin:0 0 16px}.landing-modal-body p:first-child{font-size:16px;font-weight:700;color:#ffffffd9;margin-bottom:4px}.landing-modal-body p:nth-child(2){font-size:12px;color:#fff6;margin-bottom:20px}.landing-glow{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(0,82,165,.15) 0%,transparent 70%);pointer-events:none;top:-200px;left:50%;transform:translate(-50%)}@media(max-width:600px){.landing-hero{padding:50px 0 40px}.landing-features{grid-template-columns:1fr}.landing-stats{gap:8px}.landing-stat{min-width:120px;padding:14px 18px}.landing-nav-signin{display:none}.landing-testimonials{grid-template-columns:1fr}.landing-final-cta{padding:36px 16px 48px}.landing-modal{margin:10px;max-height:90vh}}.prelogin-onboard-container{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--page-bg);overflow:hidden;z-index:9999;display:flex;flex-direction:column;touch-action:pan-y}.onboard-lang-selector{position:absolute;top:16px;right:16px;z-index:10;display:flex;gap:8px}.onboard-lang-btn{background:#ffffff1a;border:1px solid var(--g-border);color:var(--label);padding:8px 12px;border-radius:8px;cursor:pointer;font-size:13px;transition:all .2s;min-width:50px}.onboard-lang-btn:hover{background:#ffffff26}.onboard-lang-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}.onboard-screens{flex:1;position:relative;overflow:hidden}.onboard-slide{position:absolute;top:0;left:0;right:0;bottom:0;padding:60px 24px 120px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;opacity:0;transform:translate(100%);transition:all .4s cubic-bezier(.34,1.56,.64,1);pointer-events:none}.onboard-slide.active{opacity:1;transform:translate(0);pointer-events:auto}.onboard-slide.prev{transform:translate(-100%)}@keyframes cursor-blink{50%{border-color:transparent}}.typewriter-wrap{display:inline-block;overflow:hidden;vertical-align:bottom;margin-bottom:16px;max-width:100%}.typewriter-text{font-size:48px;font-weight:700;color:var(--blue);white-space:nowrap;display:inline-block;border-right:3px solid var(--blue);animation:typewriter 2s steps(20,end) 1,cursor-blink .75s step-end infinite;line-height:1.3;padding:6px 0}.finland-flag{width:120px;height:120px;margin:0 auto 24px;position:relative;animation:flagPulse 2s ease-in-out infinite}@keyframes flagPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.flag-bg{width:100%;height:100%;background:#fff;border-radius:12px;position:relative;overflow:hidden;box-shadow:0 4px 16px #0000001a}.flag-cross-vertical{position:absolute;width:30%;height:100%;background:#003580;left:35%;animation:crossSlide 1.2s ease-out infinite}.flag-cross-horizontal{position:absolute;width:100%;height:30%;background:#003580;top:35%;animation:crossSlide 1.2s ease-out .3s infinite}@keyframes crossSlide{0%{opacity:0}50%{opacity:1}to{opacity:1}}.onboard-heading{font-size:32px;font-weight:700;color:var(--label);margin:16px 0 12px}.onboard-subheading{font-size:18px;font-weight:500;color:var(--label2);margin-bottom:24px}.onboard-tagline{font-size:16px;color:var(--label2);margin-bottom:32px;max-width:500px}.onboard-value-props{display:flex;flex-direction:column;gap:16px;margin:32px 0;width:100%;max-width:500px}.onboard-value-prop{background:var(--g-bg);border:1px solid var(--g-border);border-radius:12px;padding:16px;display:flex;gap:12px;align-items:flex-start;-webkit-backdrop-filter:var(--g-blur);backdrop-filter:var(--g-blur)}.onboard-value-prop-icon{font-size:24px;flex-shrink:0}.onboard-value-prop-text{text-align:left;font-size:14px;color:var(--label);font-weight:500}.onboard-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;margin:32px 0;width:100%;max-width:600px}@media(max-width:500px){.onboard-cards{grid-template-columns:repeat(2,1fr)}}.onboard-card{background:var(--g-bg);border:2px solid var(--g-border);border-radius:16px;padding:20px 16px;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column;gap:8px;align-items:center;text-align:center;min-height:140px;justify-content:center;-webkit-backdrop-filter:var(--g-blur);backdrop-filter:var(--g-blur)}.onboard-card:hover{transform:translateY(-4px);border-color:var(--blue)}.onboard-card.selected{border-color:var(--green);background:#2db84d14;box-shadow:0 0 20px #2db84d33}.onboard-card-icon{font-size:32px}.onboard-card-title{font-size:14px;font-weight:600;color:var(--label)}.onboard-card-subtitle{font-size:12px;color:var(--label2)}.onboard-micro-lesson{display:flex;flex-direction:column;gap:24px;width:100%;max-width:400px}.lesson-card{background:var(--g-bg);border:1px solid var(--g-border);border-radius:20px;padding:40px 24px;min-height:200px;display:flex;flex-direction:column;justify-content:center;align-items:center;cursor:pointer;transition:all .3s;-webkit-backdrop-filter:var(--g-blur);backdrop-filter:var(--g-blur)}.lesson-card:hover{border-color:var(--blue);box-shadow:0 8px 32px #0052a526}.lesson-card.flipped{transform:rotateY(180deg)}.lesson-word{font-size:36px;font-weight:700;color:var(--blue);margin-bottom:12px}.lesson-translation{font-size:24px;font-weight:600;color:var(--label)}.lesson-progress{font-size:12px;color:var(--label2);margin-top:16px}.lesson-audio-btn{background:var(--blue);color:#fff;border:none;border-radius:12px;padding:12px 16px;font-size:13px;font-weight:600;cursor:pointer;min-height:44px;transition:all .2s;display:flex;gap:6px;align-items:center;justify-content:center}.lesson-audio-btn:hover{background:#0043a0;transform:translateY(-2px)}.lesson-audio-btn:active{transform:translateY(0)}.onboard-progress-dots{position:fixed;bottom:32px;left:50%;transform:translate(-50%);display:flex;gap:8px}.progress-dot{width:8px;height:8px;border-radius:50%;background:#ffffff4d;cursor:pointer;transition:all .3s}.progress-dot.active{background:var(--blue);width:24px;border-radius:4px}.onboard-button-group{position:fixed;bottom:16px;left:16px;right:16px;display:flex;gap:12px;max-width:600px;margin:0 auto;width:calc(100% - 32px)}.onboard-btn{flex:1;background:var(--blue);color:#fff;border:none;border-radius:12px;padding:12px 24px;font-size:16px;font-weight:600;cursor:pointer;min-height:44px;transition:all .2s;white-space:nowrap}.onboard-btn:hover{background:#0043a0;transform:translateY(-2px)}.onboard-btn:active{transform:translateY(0)}.onboard-btn-secondary{background:#ffffff1a;color:var(--label);border:1px solid var(--g-border)}.onboard-btn-secondary:hover{background:#ffffff26}.onboard-btn-text{background:none;border:none;color:var(--blue);font-size:13px;cursor:pointer;padding:8px;text-decoration:underline}.onboard-btn-text:hover{color:#0043a0}.onboard-back-btn{position:fixed;top:16px;left:16px;background:#ffffff1a;border:1px solid var(--g-border);color:var(--label);padding:8px 12px;border-radius:8px;cursor:pointer;font-size:14px;min-height:44px;display:flex;align-items:center;gap:6px;z-index:11}.onboard-back-btn:hover{background:#ffffff26}.onboard-celebration{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:100}.celebration-particle{position:absolute;pointer-events:none;animation:onboard-confetti-fall 3s linear forwards}@keyframes onboard-confetti-fall{0%{opacity:1;transform:translateY(0) rotate(0)}to{opacity:0;transform:translateY(100vh) rotate(360deg)}}@media(max-width:600px){.onboard-slide{padding:40px 16px 100px}.typewriter-text{font-size:36px}.onboard-heading{font-size:24px}.onboard-subheading{font-size:16px}.onboard-lang-selector{top:12px;right:12px}.onboard-lang-btn{min-width:40px;font-size:12px;padding:6px 10px}.onboard-cards{grid-template-columns:repeat(2,1fr);gap:12px}.onboard-card{min-height:110px;padding:12px}.onboard-card-icon{font-size:28px}.onboard-button-group{flex-direction:column}.onboard-btn{width:100%}}@media(max-width:360px){.onboard-cards{grid-template-columns:1fr}}html[data-theme=dark] .onboard-flag-bg{background:#1a1a2e}.pv-section-header{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--label2);margin-bottom:14px;display:flex;align-items:center;gap:8px}.pv-section-header:before{content:"";display:inline-block;width:3px;height:14px;border-radius:2px;background:var(--blue)}.pv-rings-wrap{display:flex;align-items:center;justify-content:center;gap:28px;padding:24px 16px}@media(max-width:600px){.pv-rings-wrap{flex-direction:column;gap:20px}}.pv-ring-labels{display:flex;flex-direction:column;gap:10px;min-width:140px}.pv-ring-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--label)}.pv-ring-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.pv-ring-pct{margin-left:auto;font-weight:700;font-size:14px;font-variant-numeric:tabular-nums}.pv-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(min-width:768px){.pv-stat-grid{grid-template-columns:repeat(3,1fr);gap:14px}}.pv-stat-card{background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--g-depth-1),var(--g-shine);display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden;animation:fadeSlideUp .38s var(--ease-out) both}.pv-stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:16px 16px 0 0}.pv-stat-card[data-cat=xp]:before{background:linear-gradient(90deg,#0052a5,#2e8adb)}.pv-stat-card[data-cat=streak]:before{background:linear-gradient(90deg,#ff6b00,#fbbf24)}.pv-stat-card[data-cat=lessons]:before{background:linear-gradient(90deg,#34c759,#4ade80)}.pv-stat-card[data-cat=words]:before{background:linear-gradient(90deg,#af52de,#da8fff)}.pv-stat-card[data-cat=time]:before{background:linear-gradient(90deg,#ff2d55,#ff6b8a)}.pv-stat-card[data-cat=badges]:before{background:linear-gradient(90deg,gold,orange)}.pv-stat-icon{font-size:24px}.pv-stat-val{font-size:24px;font-weight:800;letter-spacing:-.5px;color:var(--label);font-variant-numeric:tabular-nums;line-height:1.1}.pv-stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--label3)}.pv-stat-sub{font-size:11px;color:var(--label3);font-weight:500;margin-top:2px}.pv-heatmap-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.pv-heatmap-scroll::-webkit-scrollbar{height:4px}.pv-heatmap-scroll::-webkit-scrollbar-thumb{background:var(--fill);border-radius:2px}.pv-heatmap-grid{display:flex;gap:3px}.pv-heatmap-col{display:flex;flex-direction:column;gap:3px}.pv-heatmap-cell{width:14px;height:14px;border-radius:3px;cursor:pointer;transition:transform .15s,box-shadow .15s}.pv-heatmap-cell:hover{transform:scale(1.35);box-shadow:0 2px 8px #0000002e;z-index:2;position:relative}.pv-heatmap-day-labels{display:flex;flex-direction:column;gap:3px;margin-right:6px;flex-shrink:0}.pv-heatmap-day-label{height:14px;font-size:9px;color:var(--label3);display:flex;align-items:center;font-weight:500}.pv-heatmap-tooltip{position:fixed;z-index:9999;padding:8px 12px;border-radius:10px;font-size:12px;background:var(--g-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:.5px solid var(--g-border);box-shadow:0 8px 32px #00000038;pointer-events:none;white-space:nowrap;color:var(--label);font-weight:500;animation:fadeSlideUp .2s ease both}.pv-heatmap-legend{display:flex;align-items:center;gap:4px;margin-top:10px;font-size:10px;color:var(--label3);font-weight:500;justify-content:flex-end}.pv-heatmap-legend-cell{width:12px;height:12px;border-radius:2px}.pv-level-track{display:flex;align-items:center;gap:0;position:relative;height:32px;margin:16px 0}.pv-level-seg{flex:1;height:8px;position:relative;transition:background .3s}.pv-level-seg:first-child{border-radius:4px 0 0 4px}.pv-level-seg:last-child{border-radius:0 4px 4px 0}.pv-level-marker{position:absolute;bottom:-20px;font-size:9px;font-weight:700;color:var(--label3);transform:translate(-50%);white-space:nowrap}.pv-level-here{position:absolute;top:-8px;width:18px;height:18px;border-radius:50%;background:var(--blue);border:2.5px solid #fff;box-shadow:0 2px 8px #0052a566;transform:translate(-50%);z-index:2;animation:pvPulse 2s ease-in-out infinite}@keyframes pvPulse{0%,to{box-shadow:0 2px 8px #0052a566}50%{box-shadow:0 2px 16px #0052a5b3,0 0 0 6px #0052a526}}.pv-trend-bars{display:flex;align-items:flex-end;gap:6px;height:100px;padding:0 4px}.pv-trend-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.pv-trend-bar{width:100%;border-radius:4px 4px 2px 2px;min-height:2px;transition:height .6s cubic-bezier(.34,1.18,.64,1);position:relative}.pv-trend-prev{position:absolute;top:0;left:50%;width:2px;border-radius:1px;background:#ffffff59;transform:translate(-50%);transition:height .4s ease}.pv-trend-label{font-size:10px;color:var(--label3);font-weight:600}.pv-trend-val{font-size:10px;color:var(--label2);font-weight:700;font-variant-numeric:tabular-nums}.pv-trend-summary{display:flex;align-items:center;justify-content:space-between;margin-top:14px;font-size:12px;font-weight:600;color:var(--label2)}.pv-trend-arrow{font-size:18px;font-weight:800}.pv-trend-arrow.up{color:#34c759}.pv-trend-arrow.down{color:#ff3b30}.pv-trend-arrow.stable{color:var(--label3)}.pv-mastery-bars{display:flex;flex-direction:column;gap:14px}.pv-mastery-row{cursor:pointer;transition:transform .15s}.pv-mastery-row:hover{transform:translate(4px)}.pv-mastery-row:active{transform:scale(.98)}.pv-mastery-info{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px}.pv-mastery-label{font-size:13px;font-weight:600;color:var(--label)}.pv-mastery-count{font-size:12px;font-weight:700;color:var(--label2);font-variant-numeric:tabular-nums}.pv-mastery-track{height:10px;background:var(--fill);border-radius:5px;overflow:hidden}.pv-mastery-fill{height:100%;border-radius:5px;transition:width .8s cubic-bezier(.34,1.18,.64,1)}@keyframes pvRingFill{0%{stroke-dashoffset:var(--pv-ring-circ)}to{stroke-dashoffset:var(--pv-ring-offset)}}.pv-ring-animated{animation:pvRingFill 1.2s cubic-bezier(.34,1,.64,1) forwards;stroke-dashoffset:var(--pv-ring-circ)}@keyframes pvCountUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.pv-count-anim{animation:pvCountUp .5s cubic-bezier(.34,1.18,.64,1) both}@keyframes pvBarGrow{0%{width:0}to{width:var(--pv-bar-w)}}.pv-bar-anim{animation:pvBarGrow .8s cubic-bezier(.34,1.18,.64,1) both}@media(max-width:480px){.pv-heatmap-cell{width:12px;height:12px}.pv-stat-grid{gap:10px}.pv-stat-card{padding:14px}.pv-stat-val{font-size:20px}}.analytics-tabs{display:flex;gap:4px;padding:4px;background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);border-radius:14px;margin-bottom:20px;width:fit-content}.analytics-tab{padding:10px 20px;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;border:none;background:transparent;color:var(--label3);transition:all .2s ease}.analytics-tab.active{background:var(--blue);color:#fff;box-shadow:0 2px 8px #0052a54d}.analytics-tab:hover:not(.active){background:var(--fill);color:var(--label)}.axp-chart{display:flex;align-items:flex-end;gap:8px;height:140px;padding:12px 4px 0}.axp-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}.axp-bar{width:100%;border-radius:6px 6px 2px 2px;min-height:3px;transition:height .6s cubic-bezier(.34,1.18,.64,1);position:relative}.axp-bar-val{font-size:10px;font-weight:700;color:var(--label2);font-variant-numeric:tabular-nums}.axp-bar-day{font-size:11px;font-weight:700;color:var(--label3)}.axp-bar-today{color:var(--blue)!important;font-weight:800}.ag-grid{display:grid;grid-template-columns:1fr;gap:16px}.ag-level-group{display:flex;flex-direction:column;gap:8px}.ag-level-title{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--label3);padding-bottom:4px;border-bottom:1px solid var(--g-border)}.ag-modules{display:flex;flex-wrap:wrap;gap:8px}.ag-module{padding:8px 14px;border-radius:10px;font-size:12px;font-weight:600;border:.5px solid var(--g-border);background:var(--g-bg);-webkit-backdrop-filter:var(--g-blur);backdrop-filter:var(--g-blur);display:flex;align-items:center;gap:6px;transition:transform .15s}.ag-module:hover{transform:scale(1.03)}.ag-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ag-dot.strong{background:#34c759}.ag-dot.medium{background:#ff9500}.ag-dot.weak{background:#ff3b30}.ag-dot.none{background:var(--fill)}.ag-pct{font-size:10px;font-weight:700;color:var(--label3);margin-left:4px}.av-levels{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.av-level-card{background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);border-radius:14px;padding:14px;text-align:center}.av-level-name{font-size:13px;font-weight:800;color:var(--label);margin-bottom:6px}.av-level-bar{height:6px;background:var(--fill);border-radius:3px;overflow:hidden;margin-bottom:6px}.av-level-fill{height:100%;border-radius:3px;transition:width .6s cubic-bezier(.34,1.18,.64,1)}.av-level-count{font-size:11px;color:var(--label3);font-weight:600}.alt-timeline{display:flex;align-items:center;gap:0;padding:8px 0;overflow-x:auto}.alt-node{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:60px;position:relative}.alt-dot{width:28px;height:28px;border-radius:50%;border:3px solid var(--g-border);background:var(--card);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;transition:all .3s}.alt-dot.done{background:#34c759;border-color:#34c759;color:#fff}.alt-dot.current{background:var(--blue);border-color:var(--blue);color:#fff;box-shadow:0 0 0 4px #0052a533;animation:pvPulse 2s ease-in-out infinite}.alt-dot.locked{opacity:.4}.alt-line{flex:1;height:3px;background:var(--fill);min-width:12px;border-radius:2px}.alt-line.done{background:#34c759}.alt-label{font-size:9px;font-weight:700;color:var(--label3)}.alt-pct{font-size:8px;font-weight:600;color:var(--label3)}.asc-grid{display:flex;gap:3px;overflow-x:auto;padding-bottom:4px}.asc-col{display:flex;flex-direction:column;gap:3px}.asc-cell{width:12px;height:12px;border-radius:2px;transition:transform .15s}.asc-cell:hover{transform:scale(1.4);z-index:2;position:relative}.asc-month-labels{display:flex;gap:3px;margin-bottom:4px;padding-left:20px}.asc-month-label{font-size:9px;color:var(--label3);font-weight:600}.ai-insight{padding:12px 16px;border-radius:12px;background:var(--fill);margin-bottom:8px;display:flex;align-items:flex-start;gap:10px;font-size:13px;font-weight:500;color:var(--label);line-height:1.5}.ai-insight-icon{font-size:18px;flex-shrink:0;margin-top:1px}.ai-insight.positive{border-left:3px solid #34C759}.ai-insight.warning{border-left:3px solid #FF9500}.ai-insight.info{border-left:3px solid var(--blue)}.admin-stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media(min-width:768px){.admin-stat-grid{grid-template-columns:repeat(3,1fr)}}.admin-stat-card{background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);border-radius:16px;padding:16px;text-align:center}.admin-stat-val{font-size:28px;font-weight:800;color:var(--label);font-variant-numeric:tabular-nums}.admin-stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--label3);margin-top:4px}.admin-stat-sub{font-size:11px;color:var(--label3);margin-top:2px}.admin-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.admin-table th{text-align:left;padding:10px 12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--label3);border-bottom:1px solid var(--g-border)}.admin-table td{padding:10px 12px;border-bottom:.5px solid var(--g-border);color:var(--label);font-weight:500}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--fill)}.admin-placeholder{padding:32px;text-align:center;border:1.5px dashed var(--g-border);border-radius:16px;color:var(--label3);font-size:13px;font-weight:500}.admin-placeholder-icon{font-size:32px;margin-bottom:8px}@media(max-width:480px){.analytics-tabs{width:100%}.analytics-tab{flex:1;text-align:center;padding:8px 12px}.axp-chart{height:110px}.av-levels{grid-template-columns:repeat(2,1fr)}.admin-stat-grid{gap:10px}}.st-tierup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:600;background:#00000080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;animation:stFadeIn .2s ease}.st-tierup-modal{width:calc(100% - 48px);max-width:320px;background:var(--g-bg);border:.5px solid var(--g-border);border-radius:24px;padding:32px 24px;text-align:center;backdrop-filter:blur(48px) saturate(180%);-webkit-backdrop-filter:blur(48px) saturate(180%);box-shadow:0 8px 32px #00000029;animation:stSlideUp .4s cubic-bezier(.22,1,.36,1);position:relative;overflow:hidden}.st-tierup-glow{position:absolute;top:-50%;left:-50%;width:200%;height:200%;border-radius:50%;opacity:.15;pointer-events:none}@keyframes stTierGlow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.streak-flame{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.flame-svg{width:100%;height:100%;filter:drop-shadow(0 0 6px rgba(230,134,0,.4))}.flame-tier-0 .flame-path{display:none}.flame-tier-1 .flame-path,.flame-tier-2 .flame-path,.flame-tier-3 .flame-path{fill:url(#flame-orange-gradient);opacity:1;animation:flame-flicker 1.8s ease-in-out infinite}.flame-tier-4 .flame-path,.flame-tier-5 .flame-path,.flame-tier-6 .flame-path{fill:url(#flame-bright-gradient);opacity:1;animation:flame-glow 2s ease-in-out infinite;filter:drop-shadow(0 0 8px rgba(255,200,0,.6))}.flame-tier-7 .flame-path,.flame-tier-8 .flame-path{fill:url(#flame-intense-gradient);opacity:1;animation:flame-intense 2.2s ease-in-out infinite;filter:drop-shadow(0 0 12px rgba(255,150,0,.8))}.flame-tier-9 .flame-path{fill:url(#flame-blue-gradient);opacity:1;animation:flame-blue 2.4s ease-in-out infinite;filter:drop-shadow(0 0 14px rgba(100,150,255,.6)) drop-shadow(0 0 8px rgba(230,134,0,.5))}.flame-tier-10 .flame-path{fill:url(#flame-purple-gradient);opacity:1;animation:flame-purple 2.6s ease-in-out infinite;filter:drop-shadow(0 0 16px rgba(200,100,255,.7))}.flame-tier-11 .flame-path{fill:url(#flame-golden-gradient);opacity:1;animation:flame-golden 2.8s ease-in-out infinite;filter:drop-shadow(0 0 18px rgba(255,215,0,.8))}.flame-tier-12 .flame-path{fill:url(#flame-rainbow-gradient);opacity:1;animation:flame-rainbow 3s ease-in-out infinite;filter:drop-shadow(0 0 20px rgba(255,100,200,.7)) drop-shadow(0 0 10px rgba(100,200,255,.5))}@keyframes flame-flicker{0%,to{transform:scaleY(1) scaleX(.95)}50%{transform:scaleY(1.1) scaleX(1)}}@keyframes flame-glow{0%,to{transform:scaleY(1.05) scaleX(.98)}50%{transform:scaleY(1.15) scaleX(1.05)}}@keyframes flame-intense{0%,to{transform:scaleY(1.1) scaleX(1)}50%{transform:scaleY(1.25) scaleX(1.1)}}@keyframes flame-blue{0%,to{transform:scaleY(1.15) scaleX(1.05)}50%{transform:scaleY(1.3) scaleX(1.15)}}@keyframes flame-purple{0%,to{transform:scaleY(1.2) scaleX(1.1)}25%{transform:scaleY(1.35) scaleX(1.2)}50%{transform:scaleY(1.25) scaleX(1.15)}75%{transform:scaleY(1.3) scaleX(1.1)}}@keyframes flame-golden{0%,to{transform:scaleY(1.25) scaleX(1.15)}25%{transform:scaleY(1.4) scaleX(1.25)}50%{transform:scaleY(1.3) scaleX(1.2)}75%{transform:scaleY(1.35) scaleX(1.18)}}@keyframes flame-rainbow{0%,to{transform:scaleY(1.3) scaleX(1.2)}15%{transform:scaleY(1.45) scaleX(1.3)}30%{transform:scaleY(1.35) scaleX(1.25)}45%{transform:scaleY(1.4) scaleX(1.28)}60%{transform:scaleY(1.38) scaleX(1.22)}75%{transform:scaleY(1.42) scaleX(1.26)}}.streak-widget{background:var(--g-bg);border:1px solid var(--g-border);border-radius:20px;padding:24px;margin-bottom:24px;-webkit-backdrop-filter:var(--g-blur);backdrop-filter:var(--g-blur);box-shadow:var(--g-shadow);position:relative;overflow:hidden}.streak-widget:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--g-shine);pointer-events:none;border-radius:20px}.streak-widget-content{position:relative;z-index:1}.streak-flame-container{width:100%;height:120px;margin-bottom:20px;display:flex;align-items:center;justify-content:center}.streak-stats{display:flex;flex-direction:column;gap:12px}.streak-stat-row{display:flex;align-items:center;gap:12px;padding:12px;background:#ffffff0a;border-radius:12px;border:1px solid var(--g-border)}.streak-stat-icon{font-size:24px;flex-shrink:0}.streak-stat-value{font-size:20px;font-weight:700;color:var(--label)}.streak-stat-label{font-size:12px;color:var(--label3);margin-left:auto;text-align:right}.streak-milestone-indicator{font-size:12px;color:var(--orange);font-weight:600;margin-top:8px;padding-top:8px;border-top:1px solid var(--g-border)}.streak-calendar{background:#ffffff05;border-radius:12px;padding:16px;border:1px solid var(--g-border);margin-top:16px}.streak-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:12px}.streak-calendar-day{aspect-ratio:1 / 1;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;background:var(--fill);border:1px solid var(--g-border);color:var(--label3);position:relative}.streak-calendar-day.active{background:linear-gradient(135deg,#e6860099,#ffc80066);color:#fff;border-color:#e68600cc}.streak-calendar-day.today{background:linear-gradient(135deg,#e68600e6,#ffc800b3);color:#fff;border-color:#e68600;animation:streak-pulse 1.5s ease-in-out infinite}.streak-calendar-day.freeze{background:linear-gradient(135deg,#64c8ff80,#96dcff4d);color:#fff;border-color:#64c8ffcc}@keyframes streak-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.85}}.streak-calendar-header{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px;text-align:center}.streak-calendar-header-day{font-size:11px;font-weight:600;color:var(--label3);padding:4px 0}.streak-freeze-badge{display:inline-flex;align-items:center;gap:4px;background:linear-gradient(135deg,#64c8ff33,#96dcff1a);border:1px solid rgba(100,200,255,.4);border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600;color:var(--blue);margin-top:12px}.streak-freeze-count{font-size:16px;font-weight:700}.streak-milestone-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fade-in .2s ease-out}.streak-milestone-content{background:var(--g-bg);border:1px solid var(--g-border);border-radius:24px;padding:32px 24px;max-width:400px;width:90vw;text-align:center;-webkit-backdrop-filter:var(--g-blur);backdrop-filter:var(--g-blur);box-shadow:var(--g-shadow);animation:streak-scale-in .3s cubic-bezier(.34,1.56,.64,1)}@keyframes streak-scale-in{0%{transform:scale(.9) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.streak-milestone-flame{width:120px;height:120px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center}.streak-milestone-title{font-size:24px;font-weight:700;color:var(--label);margin-bottom:8px}.streak-milestone-description{font-size:14px;color:var(--label2);margin-bottom:16px}.streak-milestone-xp{background:linear-gradient(135deg,#0052a533,#0096ff1a);border:1px solid rgba(0,82,165,.3);border-radius:12px;padding:12px 16px;margin-bottom:20px;font-size:13px;color:var(--label);font-weight:600}.streak-milestone-button{background:var(--blue);color:#fff;border:none;border-radius:12px;padding:12px 32px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.streak-milestone-button:hover{background:#0052a5e6;transform:translateY(-2px)}.streak-milestone-button:active{transform:translateY(0)}.streak-repair-banner{background:linear-gradient(135deg,#e6860033,#ffc8001a);border:1px solid rgba(230,134,0,.4);border-radius:12px;padding:16px;margin-bottom:20px;display:flex;align-items:center;gap:12px;animation:streak-slide-in .4s ease-out}@keyframes streak-slide-in{0%{transform:translate(-20px);opacity:0}to{transform:translate(0);opacity:1}}.streak-repair-icon{font-size:24px;flex-shrink:0}.streak-repair-text{font-size:13px;color:var(--label);font-weight:600;flex:1}.streak-repair-progress{display:flex;gap:4px;flex-shrink:0}.streak-repair-dot{width:8px;height:8px;border-radius:50%;background:#ffc8004d;border:1px solid rgba(255,200,0,.6)}.streak-repair-dot.filled{background:#ffc800e6}.streak-activity-dots{display:flex;gap:6px;margin-top:16px;padding:12px 0;border-top:1px solid var(--g-border)}.streak-activity-dot{width:24px;height:24px;border-radius:50%;background:#ffffff0f;border:1px solid var(--g-border);display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0}.streak-activity-dot.active{background:linear-gradient(135deg,#e6860099,#ffc80066);border-color:#e68600cc;color:#fff}html[data-theme=dark] .streak-widget{--g-bg: rgba(20, 28, 50, .6);--g-border: rgba(255, 255, 255, .08)}html[data-theme=dark] .streak-stat-row{background:#0003}html[data-theme=dark] .streak-milestone-modal{background:#000000b3}html[data-theme=dark] .streak-milestone-content{--g-bg: rgba(20, 28, 50, .8)}@media(max-width:480px){.streak-widget{padding:18px;margin-bottom:18px}.streak-flame-container{height:100px;margin-bottom:16px}.streak-stat-row{padding:10px;gap:10px}.streak-stat-value{font-size:18px}.streak-calendar{padding:12px}.streak-calendar-grid{gap:3px}}.ceremony-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:#000000b3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);animation:ceremonyFadeIn .4s ease both;overflow-y:auto;padding:20px}@keyframes ceremonyFadeIn{0%{opacity:0}to{opacity:1}}.ceremony-card{width:100%;max-width:420px;background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);box-shadow:0 8px 32px #00000029;border-radius:24px;padding:32px 24px;text-align:center;position:relative;animation:ceremonySlideUp .5s cubic-bezier(.34,1.18,.64,1) both}@keyframes ceremonySlideUp{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.ceremony-score-ring{position:relative;width:160px;height:160px;margin:0 auto 20px}.ceremony-score-ring svg{width:160px;height:160px;transform:rotate(-90deg)}.ceremony-score-ring circle{fill:none;stroke-width:10;stroke-linecap:round}.ceremony-score-bg{stroke:var(--fill2)}.ceremony-score-fg{transition:stroke-dashoffset 1.5s cubic-bezier(.34,1.18,.64,1)}.ceremony-score-num{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.ceremony-score-pct{font-size:42px;font-weight:800;letter-spacing:-1px;line-height:1}.ceremony-score-label{font-size:13px;color:var(--label2);margin-top:4px;font-weight:600}.ceremony-stars{display:flex;gap:8px;justify-content:center;margin-bottom:20px}.ceremony-star{font-size:36px;opacity:0;transform:scale(0);animation:ceremonyStarPop .4s cubic-bezier(.34,1.56,.64,1) both}.ceremony-star:nth-child(1){animation-delay:1s}.ceremony-star:nth-child(2){animation-delay:1.2s}.ceremony-star:nth-child(3){animation-delay:1.4s}@keyframes ceremonyStarPop{0%{opacity:0;transform:scale(0) rotate(-30deg)}to{opacity:1;transform:scale(1) rotate(0)}}.ceremony-star.empty{filter:grayscale(1) opacity(.3)}.ceremony-xp-line{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;border-radius:10px;background:var(--fill2);margin-bottom:6px;opacity:0;transform:translate(40px);animation:ceremonySlideIn .4s ease both;font-size:14px;font-weight:600}.ceremony-xp-line .xp-val{color:var(--green);font-weight:700}@keyframes ceremonySlideIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.ceremony-xp-total{display:flex;justify-content:center;align-items:center;gap:8px;padding:12px 18px;border-radius:14px;background:linear-gradient(135deg,#34c75926,#34c7590d);border:1px solid rgba(52,199,89,.25);margin-top:10px;font-size:20px;font-weight:800;color:var(--green);animation:ceremonyPulseGlow 2s ease infinite}@keyframes ceremonyPulseGlow{0%,to{box-shadow:0 0 #34c75933}50%{box-shadow:0 0 20px 4px #34c75926}}.ceremony-mastery{padding:14px;border-radius:14px;background:var(--fill2);margin-top:16px;text-align:center}.ceremony-mastery-tier{font-size:15px;font-weight:700;margin-bottom:8px}.ceremony-mastery-next{font-size:12px;color:var(--label2);margin-top:6px}.ceremony-rank{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:999px;background:#0052a51a;border:.5px solid rgba(0,82,165,.2);color:var(--blue);font-size:13px;font-weight:700;margin-bottom:16px}.ceremony-actions{display:flex;flex-direction:column;gap:8px;margin-top:20px}.ceremony-actions .btn{width:100%;padding:14px;font-size:15px;border-radius:14px}.ceremony-section{margin-top:16px;opacity:0;animation:ceremonyFadeIn .3s ease both}.ceremony-perfect-text{font-size:28px;font-weight:900;background:linear-gradient(135deg,gold,orange);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-fill-color:transparent;animation:ceremonyPerfectGlow 1.5s ease infinite;margin-bottom:8px;letter-spacing:1px}@keyframes ceremonyPerfectGlow{0%,to{filter:brightness(1)}50%{filter:brightness(1.3)}}.ceremony-level-up{padding:16px;border-radius:14px;background:linear-gradient(135deg,#ffcc001f,#ff950014);border:1px solid rgba(255,204,0,.3);margin-top:12px;animation:ceremonyFadeIn .4s ease 3.2s both}.ceremony-level-up-title{font-size:18px;font-weight:800;color:var(--orange);margin-bottom:4px}.ceremony-level-up-sub{font-size:13px;color:var(--label2);line-height:1.5}.ceremony-skip{position:absolute;top:12px;right:12px;background:var(--fill2);border:none;border-radius:999px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;color:var(--label2);z-index:2}.ceremony-skip:hover{background:var(--fill3)}@media(max-width:480px){.ceremony-card{padding:24px 16px;border-radius:20px;max-width:100%}.ceremony-score-ring{width:130px;height:130px}.ceremony-score-ring svg{width:130px;height:130px}.ceremony-score-pct{font-size:34px}.ceremony-star{font-size:28px}}.ceremony-anim-skip .ceremony-star,.ceremony-anim-skip .ceremony-xp-line,.ceremony-anim-skip .ceremony-section,.ceremony-anim-skip .ceremony-level-up{animation-duration:0s!important;animation-delay:0s!important;opacity:1!important;transform:none!important}.ceremony-anim-skip .ceremony-score-fg{transition-duration:0s!important}.lb-container{max-width:600px;margin:0 auto;padding:0 16px 100px}.lb-tier-badge{display:flex;align-items:center;gap:12px;padding:18px 20px;border-radius:20px;margin-bottom:16px;position:relative;overflow:hidden}.lb-tier-badge:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:.15;background:inherit;filter:blur(30px)}.lb-tier-icon{font-size:36px;position:relative;z-index:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,.3))}.lb-tier-info{position:relative;z-index:1}.lb-tier-name{font-size:18px;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.2)}.lb-tier-sub{font-size:12px;color:#ffffffc7;margin-top:2px}.lb-tier-bronze{background:linear-gradient(135deg,#cd7f32,#8b5e23)}.lb-tier-silver{background:linear-gradient(135deg,silver,#6b6b6b)}.lb-tier-gold{background:linear-gradient(135deg,gold,#b8960c)}.lb-tier-platinum{background:linear-gradient(135deg,#e5e4e2,#7a7a7a)}.lb-tier-diamond{background:linear-gradient(135deg,#b9f2ff,#0077b6)}.lb-stats-card{display:flex;gap:4px;padding:6px;border-radius:16px;background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);box-shadow:0 2px 8px #0000000a;margin-bottom:16px}.lb-stat-item{flex:1;text-align:center;padding:10px 4px;border-radius:12px}.lb-stat-item:hover{background:var(--fill2)}.lb-stat-val{font-size:20px;font-weight:700;color:var(--label);letter-spacing:-.3px}.lb-stat-lbl{font-size:10px;color:var(--label3);margin-top:2px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.lb-tabs{display:flex;gap:4px;padding:4px;border-radius:14px;background:var(--fill2);margin-bottom:16px}.lb-tab{flex:1;padding:10px 8px;border-radius:11px;border:none;background:transparent;font-size:13px;font-weight:600;color:var(--label2);cursor:pointer;transition:all .2s}.lb-tab.active{background:var(--g-bg);color:var(--label);box-shadow:0 2px 8px #00000014}.lb-countdown{text-align:center;font-size:12px;color:var(--label3);margin-bottom:14px;font-weight:500}.lb-countdown span{color:var(--blue);font-weight:700}.lb-list{border-radius:16px;background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);box-shadow:0 2px 8px #0000000a;overflow:hidden}.lb-row{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:.5px solid var(--sep);transition:background .2s,transform .15s}.lb-row:last-child{border-bottom:none}.lb-row.lb-promo{background:#2db84d0f}.lb-row.lb-demote{background:#e686000f}.lb-row.lb-me{background:#0052a51a;border-left:3px solid var(--blue)}html[data-theme=dark] .lb-row.lb-promo{background:#2db84d1f}html[data-theme=dark] .lb-row.lb-demote{background:#e686001f}html[data-theme=dark] .lb-row.lb-me{background:#0052a52e}.lb-rank{width:28px;text-align:center;font-size:14px;font-weight:700;color:var(--label2);flex-shrink:0}.lb-rank.gold{color:gold}.lb-rank.silver{color:silver}.lb-rank.bronze-r{color:#cd7f32}.lb-medal{font-size:18px}.lb-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;color:#fff;flex-shrink:0}.lb-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.lb-name{font-size:14px;font-weight:600;color:var(--label);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lb-name.lb-me-name{color:var(--blue);font-weight:700}.lb-streak{font-size:11px;color:var(--label3)}.lb-value{text-align:right;flex-shrink:0}.lb-value-num{font-size:15px;font-weight:700;color:var(--label);display:block}.lb-value-sub{font-size:11px;color:var(--label2);font-weight:500}.lb-zone-label{padding:4px 14px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.lb-zone-label.promo{color:var(--green);background:#2db84d14}.lb-zone-label.demote{color:var(--orange);background:#e6860014}.lb-friends-shell{padding:24px;text-align:center;border-radius:16px;background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);box-shadow:0 2px 8px #0000000a;margin-top:20px}.lb-coming-badge{display:inline-block;padding:4px 12px;border-radius:999px;background:#0052a51f;color:var(--blue);font-size:11px;font-weight:700;margin-bottom:12px;letter-spacing:.3px}.lb-friends-placeholder{display:flex;flex-direction:column;gap:10px;margin-top:16px}.lb-friend-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;background:var(--fill2);opacity:.5}.lb-friend-avatar{width:36px;height:36px;border-radius:50%;background:var(--fill);display:flex;align-items:center;justify-content:center;font-size:16px}.lb-friend-bar{height:8px;border-radius:4px;background:var(--fill)}.lb-friend-bar-s{width:60%}.lb-friend-bar-m{width:40%;margin-top:4px}.home-lb-card{padding:18px;border-radius:16px;background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);box-shadow:0 2px 8px #0000000a;cursor:pointer;transition:transform .15s,box-shadow .15s;position:relative;overflow:hidden}.home-lb-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000014}.home-lb-card:active{transform:scale(.98)}.home-lb-mini-row{display:flex;align-items:center;gap:8px;padding:6px 0}.home-lb-mini-row:not(:last-child){border-bottom:.5px solid var(--sep)}@keyframes lbMeGlow{0%,to{box-shadow:0 0 8px #0052a526}50%{box-shadow:0 0 18px #0052a559}}@keyframes lbRankUp{0%{transform:translateY(8px);opacity:0}60%{transform:translateY(-2px)}to{transform:translateY(0);opacity:1}}.lb-row.lb-me{animation:lbMeGlow 2.5s ease-in-out infinite}.lb-row:active{transform:scale(.99)}.lb-rank-up-anim{animation:lbRankUp .5s ease-out}.lb-toast{position:fixed;top:80px;left:50%;transform:translate(-50%);z-index:9999;padding:12px 22px;border-radius:16px;font-size:14px;font-weight:600;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 8px 32px #0000002e;animation:springFadeUp .4s ease-out;pointer-events:none;max-width:90vw;text-align:center}.lb-toast-promo{background:#2db84de6;color:#fff}.lb-toast-demote{background:#e68600d9;color:#fff}.lb-toast-rankup{background:#0052a5e6;color:#fff}.lb-stats-card .lb-stat-item.lb-stat-danger .lb-stat-val{color:var(--orange)}.lb-stats-card .lb-stat-item.lb-stat-safe .lb-stat-val{color:var(--green)}.lb-friend-add{display:flex;gap:8px;max-width:320px;margin:16px auto}.lb-friend-input{flex:1;padding:10px 14px;border-radius:12px;border:.5px solid var(--g-border);background:var(--fill2);font-size:14px;color:var(--label);outline:none;font-family:monospace;letter-spacing:1px}.lb-friend-input::placeholder{color:var(--label3);font-family:-apple-system,sans-serif;letter-spacing:0}.lb-friend-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #0052a51f}.lb-friend-add-btn{padding:10px 16px;border-radius:12px;background:var(--blue);color:#fff;font-size:13px;font-weight:700;border:none;cursor:pointer;white-space:nowrap;opacity:.5;pointer-events:none}.lb-friend-code-box{display:flex;align-items:center;gap:10px;padding:12px 18px;border-radius:14px;background:var(--fill2);border:.5px solid var(--g-border);max-width:320px;margin:12px auto 16px}.lb-friend-code{font-size:16px;font-weight:700;color:var(--label);letter-spacing:2px;font-family:monospace;flex:1;text-align:center}.lb-friend-copy{padding:6px 14px;border-radius:8px;background:var(--blue);color:#fff;font-size:12px;font-weight:600;border:none;cursor:pointer;transition:transform .1s}.lb-friend-copy:active{transform:scale(.95)}.lb-friend-preview{display:flex;flex-direction:column;gap:8px;margin-top:16px}.lb-friend-preview-row{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:14px;background:var(--fill2);border:.5px solid var(--g-border);opacity:.4}.lb-friend-preview-avatar{width:40px;height:40px;border-radius:50%;background:var(--fill);display:flex;align-items:center;justify-content:center;font-size:18px}.lb-friend-preview-info{flex:1;text-align:left}.lb-friend-preview-name{height:10px;border-radius:5px;background:var(--fill);width:60%;margin-bottom:6px}.lb-friend-preview-stat{height:8px;border-radius:4px;background:var(--fill);width:40%}.lb-friend-compare-btn{padding:6px 14px;border-radius:8px;border:.5px solid var(--sep);background:transparent;color:var(--label3);font-size:11px;font-weight:600;cursor:default;opacity:.4}.lb-friends-tabs{display:flex;gap:4px;padding:4px;border-radius:12px;background:var(--fill2);margin-bottom:16px;max-width:320px;margin-left:auto;margin-right:auto}.lb-friends-tab{flex:1;padding:8px;border-radius:9px;border:none;background:transparent;font-size:12px;font-weight:600;color:var(--label3);cursor:pointer;transition:all .2s}.lb-friends-tab.active{background:var(--g-bg);color:var(--label);box-shadow:0 2px 6px #0000000f}@media(max-width:768px){.lb-container{padding:0 12px 100px}.lb-stats-card{flex-wrap:wrap}.lb-stat-item{min-width:70px}.lb-toast{top:auto;bottom:100px;font-size:13px}}.friends-screen{max-width:600px;margin:0 auto;padding:0 16px 100px}.friends-tabs-bar{display:flex;gap:4px;padding:4px;border-radius:14px;background:var(--fill2);margin-bottom:20px}.friends-tab-btn{flex:1;padding:10px 8px;border-radius:11px;border:none;background:transparent;font-size:13px;font-weight:600;color:var(--label3);cursor:pointer;transition:all .2s}.friends-tab-btn.active{background:var(--g-bg);color:var(--label);box-shadow:0 2px 8px #0000000f}.friends-card{padding:16px;border-radius:16px;background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);box-shadow:0 2px 8px #0000000a;margin-bottom:12px}.friends-card-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.friends-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:700;color:#fff;flex-shrink:0}.friends-info{flex:1;min-width:0}.friends-name{font-size:15px;font-weight:700;color:var(--label);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.friends-meta{font-size:12px;color:var(--label3);margin-top:2px}.friends-stats{display:flex;gap:16px;flex-wrap:wrap}.friends-stat{text-align:center}.friends-stat-val{font-size:15px;font-weight:700;color:var(--label)}.friends-stat-lbl{font-size:11px;color:var(--label3)}.friends-remove{padding:4px 10px;border-radius:8px;border:.5px solid var(--sep);background:transparent;color:var(--label3);font-size:11px;cursor:pointer;transition:all .2s}.friends-remove:hover{background:#e5342b14;color:var(--red);border-color:var(--red)}.friends-empty{text-align:center;padding:40px 20px}.friends-empty-icon{font-size:48px;margin-bottom:12px}.friends-empty-title{font-size:16px;font-weight:700;color:var(--label);margin-bottom:6px}.friends-empty-sub{font-size:13px;color:var(--label3);max-width:280px;margin:0 auto}.friends-code-display{display:flex;align-items:center;gap:12px;padding:14px 20px;border-radius:14px;background:var(--fill2);border:.5px solid var(--g-border);margin:16px auto;max-width:360px}.friends-code-text{font-size:18px;font-weight:700;color:var(--label);letter-spacing:2px;font-family:monospace;flex:1;text-align:center}.friends-code-copy{padding:8px 16px;border-radius:10px;background:var(--blue);color:#fff;font-size:13px;font-weight:600;border:none;cursor:pointer;transition:transform .1s}.friends-code-copy:active{transform:scale(.95)}.friends-add-row{display:flex;gap:8px;margin:16px auto;max-width:360px}.friends-add-input{flex:1;padding:12px 16px;border-radius:12px;border:.5px solid var(--g-border);background:var(--fill2);font-size:14px;color:var(--label);outline:none;font-family:monospace;letter-spacing:1px}.friends-add-input::placeholder{color:var(--label3);font-family:-apple-system,sans-serif;letter-spacing:0}.friends-add-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #0052a51f}.friends-add-btn{padding:12px 20px;border-radius:12px;background:var(--blue);color:#fff;font-size:14px;font-weight:700;border:none;cursor:pointer;transition:all .15s}.friends-add-btn:hover{background:#0047a0}.friends-add-btn:active{transform:scale(.96)}.friends-add-btn:disabled{opacity:.5;cursor:default}.friends-toast{position:fixed;top:80px;left:50%;transform:translate(-50%);z-index:9999;padding:12px 22px;border-radius:16px;font-size:14px;font-weight:600;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 8px 32px #0000002e;animation:springFadeUp .4s ease-out;pointer-events:none;max-width:90vw;text-align:center}.friends-toast-success{background:#2db84de6;color:#fff}.friends-toast-error{background:#e5342be6;color:#fff}.activity-item{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:14px;background:var(--fill2);border:.5px solid var(--g-border);margin-bottom:8px;transition:transform .1s}.activity-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.activity-icon-lesson{background:#0052a51a}.activity-icon-badge{background:#e686001a}.activity-icon-streak{background:#e5342b1a}.activity-icon-level{background:#2db84d1a}.activity-icon-pronunciation{background:#9b59b61a}.activity-content{flex:1;min-width:0}.activity-text{font-size:13px;color:var(--label);line-height:1.4}.activity-text strong{font-weight:700}.activity-time{font-size:11px;color:var(--label3);margin-top:3px}.activity-xp{font-size:12px;font-weight:700;color:var(--blue);white-space:nowrap}.fc-challenge-card{padding:18px;border-radius:16px;background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);box-shadow:0 2px 8px #0000000a;margin-bottom:12px}.fc-challenge-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.fc-challenge-icon{font-size:24px}.fc-challenge-title{font-size:15px;font-weight:700;color:var(--label)}.fc-challenge-desc{font-size:13px;color:var(--label2);margin-bottom:12px}.fc-challenge-progress-bar{height:8px;border-radius:4px;background:var(--fill2);overflow:hidden;margin-bottom:8px}.fc-challenge-progress-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--blue),var(--teal));transition:width .3s}.fc-challenge-standings{display:flex;flex-direction:column;gap:6px;margin-top:12px}.fc-challenge-standing-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:10px;background:var(--fill2)}.fc-challenge-standing-row.me{background:#0052a514;border:.5px solid rgba(0,82,165,.15)}.fc-challenge-standing-rank{width:24px;font-size:13px;font-weight:700;color:var(--label2);text-align:center}.fc-challenge-standing-name{flex:1;font-size:13px;font-weight:600;color:var(--label)}.fc-challenge-standing-val{font-size:13px;font-weight:700;color:var(--blue)}.fc-challenge-timer{font-size:12px;color:var(--label3);text-align:center;margin-top:8px}.friends-section-title{font-size:14px;font-weight:700;color:var(--label);margin-bottom:12px;display:flex;align-items:center;gap:8px}.friends-lb-toggle{display:flex;gap:4px;padding:3px;border-radius:10px;background:var(--fill2);margin-bottom:16px}.friends-lb-toggle-btn{padding:7px 14px;border-radius:8px;border:none;background:transparent;font-size:12px;font-weight:600;color:var(--label3);cursor:pointer;transition:all .2s}.friends-lb-toggle-btn.active{background:var(--g-bg);color:var(--label);box-shadow:0 1px 4px #0000000f}.account-friend-code{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:12px;background:var(--fill2);border:.5px solid var(--g-border);margin-top:8px}.account-friend-code-text{font-size:15px;font-weight:700;color:var(--label);letter-spacing:1.5px;font-family:monospace;flex:1}.account-friend-code-btn{padding:6px 12px;border-radius:8px;background:var(--blue);color:#fff;font-size:12px;font-weight:600;border:none;cursor:pointer}@media(max-width:768px){.friends-screen{padding:0 12px 100px}.friends-stats{gap:10px}.friends-add-row{flex-direction:column}}.state-empty,.state-error,.state-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;text-align:center;min-height:200px}.state-empty .state-icon,.state-error .state-icon{font-size:3rem;margin-bottom:1rem}.state-empty .state-title,.state-error .state-title{font-size:1.2rem;font-weight:600;margin-bottom:.5rem;color:var(--text,#fff)}.state-empty .state-desc,.state-error .state-desc{font-size:.9rem;color:var(--text-sec,#aab);max-width:280px;line-height:1.5}.state-error .state-title{color:#ff6b6b}.state-error .state-retry{margin-top:1rem;padding:.6rem 1.5rem;border-radius:12px;background:var(--accent,#4a9eff);color:#fff;border:none;cursor:pointer;font-size:.9rem;font-weight:500}.state-error .state-retry:active{transform:scale(.95)}.skel{border-radius:8px;background:linear-gradient(90deg,#ffffff0f 25%,#ffffff1f,#ffffff0f 75%);background-size:200% 100%;animation:skelShimmerAlt 1.5s infinite}@keyframes skelShimmerAlt{0%{background-position:200% 0}to{background-position:-200% 0}}.skel-card{height:80px;margin-bottom:12px}.skel-line{height:16px;margin-bottom:8px;width:80%}.skel-line.short{width:50%}.skel-circle{width:48px;height:48px;border-radius:50%}.offline-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:#ff6b6b;color:#fff;text-align:center;padding:8px;font-size:.85rem;font-weight:500;transform:translateY(-100%);transition:transform .3s}.offline-banner.show{transform:translateY(0)}.account-section{background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);border-radius:20px;padding:20px;margin-bottom:16px;display:flex;flex-direction:column;gap:12px}.account-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue-light));display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:700;color:#fff;margin:0 auto 16px;box-shadow:0 8px 24px #4a9eff4d}.account-field{display:flex;flex-direction:column;gap:6px}.account-field-label{font-size:12px;font-weight:600;color:var(--label3);text-transform:uppercase;letter-spacing:.5px}.account-field-value{font-size:14px;color:var(--label);font-weight:500}.account-field-editable{display:flex;gap:8px}.account-field-input{flex:1;background:#ffffff14;border:.5px solid var(--g-border);border-radius:12px;padding:10px 14px;font-size:14px;color:var(--label);font-family:inherit;transition:all .2s}.account-field-input:focus{outline:none;background:#ffffff1f;border-color:var(--blue);box-shadow:0 0 0 3px #4a9eff1a}.account-btn{padding:10px 16px;border-radius:12px;border:.5px solid var(--g-border);background:#ffffff14;color:var(--label);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.account-btn:active{transform:scale(.95);background:#ffffff1f}.account-btn-primary{background:var(--blue);color:#fff;border:none}.account-btn-primary:active{background:#4a9effd9;transform:scale(.95)}.account-btn-danger{background:#ff6b6b26;color:#ff6b6b;border:.5px solid rgba(255,107,107,.3)}.account-btn-danger:active{background:#ff6b6b40;transform:scale(.95)}.account-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.account-stat-card{background:#ffffff0f;border:.5px solid var(--g-border);border-radius:12px;padding:12px;text-align:center}.account-stat-value{font-size:18px;font-weight:700;color:var(--blue);display:block}.account-stat-label{font-size:11px;color:var(--label3);margin-top:4px;font-weight:500}.account-pill-group{display:flex;gap:8px;flex-wrap:wrap}.account-pill{padding:8px 14px;border-radius:20px;border:.5px solid var(--g-border);background:transparent;color:var(--label3);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.account-pill.active{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 4px 12px #4a9eff4d}.account-pill:active{transform:scale(.95)}.account-plan-badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.account-plan-free{background:#64748b33;color:#64748b}.account-plan-premium{background:#3b82f633;color:#3b82f6}.account-plan-pro{background:#a855f733;color:#a855f7}.account-plan-admin{background:#ef444433;color:#ef4444}.account-section-title{font-size:14px;font-weight:700;color:var(--label);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.account-link{color:var(--blue);text-decoration:none;font-weight:600;cursor:pointer;border-bottom:1px solid var(--blue);transition:opacity .2s}.account-link:active{opacity:.7}.account-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9998;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.account-modal{background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);border-radius:24px;padding:28px;max-width:90%;width:340px;text-align:center;animation:modalSlideUp .3s ease-out}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.account-modal-title{font-size:18px;font-weight:700;color:var(--label);margin-bottom:8px}.account-modal-subtitle{font-size:13px;color:var(--label3);margin-bottom:20px;line-height:1.5}.account-modal-input{width:100%;background:#ffffff14;border:.5px solid var(--g-border);border-radius:12px;padding:12px;font-size:14px;color:var(--label);font-family:inherit;margin-bottom:16px;box-sizing:border-box;transition:all .2s}.account-modal-input:focus{outline:none;background:#ffffff1f;border-color:var(--blue);box-shadow:0 0 0 3px #4a9eff1a}.account-modal-buttons{display:flex;gap:12px}.account-modal-btn{flex:1;padding:12px;border-radius:12px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.account-modal-btn-cancel{background:transparent;border:.5px solid var(--g-border);color:var(--label3)}.account-modal-btn-cancel:active{background:#ffffff14}.account-modal-btn-confirm{background:var(--blue);color:#fff}.account-modal-btn-confirm:active{background:#4a9effd9}.account-modal-btn-danger{background:#ff6b6b33;color:#ff6b6b;border:.5px solid rgba(255,107,107,.3)}.account-modal-btn-danger:active{background:#ff6b6b4d}.account-section-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.account-section-icon{font-size:20px}.home-stat-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.home-bottom-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media(max-width:480px){.home-stat-grid{grid-template-columns:1fr 1fr}.home-bottom-grid{grid-template-columns:1fr}.mob-nav .nav-pill{width:32px;height:32px}}@media(max-width:768px){.account-section{padding:16px}.account-stat-grid{grid-template-columns:1fr}.account-modal{width:95%;padding:20px}}.pron-screen{max-width:720px;margin:0 auto;padding:24px 16px;padding-bottom:calc(80px + env(safe-area-inset-bottom,20px))}.pron-header{text-align:center;margin-bottom:24px}.pron-header h2{font-size:28px;font-weight:800;color:var(--label);margin:0 0 4px}.pron-header p{font-size:14px;color:var(--label2);margin:0}.pron-card{background:var(--g-bg);border:.5px solid var(--g-border);border-radius:20px;backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);padding:24px;margin-bottom:16px;box-shadow:var(--g-shadow)}.pron-mode-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}@media(max-width:600px){.pron-mode-grid{grid-template-columns:1fr}}.pron-mode-btn{padding:16px 12px;border-radius:16px;border:1.5px solid var(--g-border);background:var(--g-bg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);cursor:pointer;text-align:center;transition:all .2s}.pron-mode-btn:hover{border-color:var(--blue);transform:translateY(-1px)}.pron-mode-btn.active{border-color:var(--blue);background:#0052a51f}.pron-mode-btn .mode-icon{font-size:28px;display:block;margin-bottom:6px}.pron-mode-btn .mode-title{font-size:13px;font-weight:700;color:var(--label);display:block}.pron-mode-btn .mode-sub{font-size:11px;color:var(--label3);display:block;margin-top:2px}.pron-sentence-area{text-align:center;padding:20px 0;min-height:100px;display:flex;flex-direction:column;align-items:center;justify-content:center}.pron-sentence-fi{font-size:26px;font-weight:700;color:var(--blue);line-height:1.35;margin-bottom:8px}.pron-sentence-en{font-size:15px;color:var(--label2);margin-bottom:4px}.mic-btn{width:80px;height:80px;border-radius:50%;background:var(--accent, var(--blue));border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:32px;transition:all .3s;color:#fff;margin:16px auto;box-shadow:0 4px 20px #0052a540}.mic-btn:hover{transform:scale(1.06)}.mic-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.mic-btn.recording{animation:mic-pulse 1.5s infinite;background:#e74c3c;box-shadow:0 4px 20px #e74c3c59}@keyframes mic-pulse{0%{box-shadow:0 0 #e74c3c66}70%{box-shadow:0 0 0 20px #e74c3c00}to{box-shadow:0 0 #e74c3c00}}.pron-word-feedback{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:16px 0}.pron-word{padding:6px 14px;border-radius:10px;font-size:18px;font-weight:600;transition:all .3s}.pron-word.correct{background:#34c75926;color:#34c759;border:1px solid rgba(52,199,89,.3)}.pron-word.close{background:#ff9f0a26;color:#ff9f0a;border:1px solid rgba(255,159,10,.3)}.pron-word.missed{background:#ff453a26;color:#ff453a;border:1px solid rgba(255,69,58,.3)}.pron-score-badge{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:14px;font-size:18px;font-weight:700;margin:12px 0}.pron-score-badge.great{background:#34c75926;color:#34c759}.pron-score-badge.good{background:#ff9f0a26;color:#ff9f0a}.pron-score-badge.try{background:#ff453a26;color:#ff453a}.pron-actions{display:flex;gap:10px;justify-content:center;margin-top:16px;flex-wrap:wrap}.pron-actions button{padding:12px 24px;border-radius:14px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .2s}.pron-actions button:hover{transform:translateY(-1px)}.pron-btn-primary{background:var(--blue);color:#fff}.pron-btn-secondary{background:var(--g-bg);border:.5px solid var(--g-border)!important;color:var(--label)}.pron-btn-listen{background:#0052a51f;color:var(--blue)}.pron-session-stats{display:flex;gap:12px;justify-content:center;margin:12px 0;flex-wrap:wrap}.pron-stat{padding:8px 16px;border-radius:12px;background:var(--fill2);font-size:13px;color:var(--label2);font-weight:600}.pron-stat span{color:var(--label);font-weight:700}.pron-level-pills{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;margin-bottom:14px}.pron-pill{padding:8px 16px;border-radius:12px;border:1px solid var(--g-border);background:var(--g-bg);font-size:13px;font-weight:600;cursor:pointer;color:var(--label);transition:all .2s}.pron-pill:hover{border-color:var(--blue)}.pron-pill.active{border-color:var(--blue);background:#0052a526;color:var(--blue)}.pron-drill-pair{display:flex;gap:12px;justify-content:center;margin:16px 0}.pron-drill-word{padding:14px 28px;border-radius:16px;font-size:22px;font-weight:700;cursor:pointer;border:2px solid var(--g-border);background:var(--g-bg);color:var(--label);transition:all .2s;min-width:120px;text-align:center}.pron-drill-word:hover{border-color:var(--blue);transform:translateY(-2px)}.pron-drill-word.selected{border-color:var(--blue);background:#0052a51f}.pron-drill-word.correct-pick{border-color:#34c759;background:#34c75926}.pron-drill-word.wrong-pick{border-color:#ff453a;background:#ff453a26}.pron-compat-notice{text-align:center;padding:40px 20px}.pron-compat-notice p{font-size:15px;color:var(--label2);margin:8px 0}.pron-compat-notice a{color:var(--blue);text-decoration:underline}.waveform-container{height:80px;display:flex;align-items:center;gap:2px;padding:12px;border-radius:12px;background:var(--g-bg);border:.5px solid var(--g-border);overflow:hidden}.waveform-bar{width:3px;border-radius:2px;transition:height .1s;min-height:4px;flex-shrink:0}.waveform-bar.target{background:#3498db99}.waveform-bar.user{background:#2ecc7199}.waveform-bar.user.poor{background:#f39c1299}.waveform-compare{display:flex;flex-direction:column;gap:8px;margin:12px 0}.waveform-label{font-size:11px;font-weight:700;color:var(--label3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:2px}.waveform-live{border:1.5px solid rgba(231,76,60,.3)}.pron-playback-controls{display:flex;gap:8px;justify-content:center;margin:12px 0;flex-wrap:wrap}.pron-playback-btn{padding:8px 16px;border-radius:12px;border:1px solid var(--g-border);background:var(--g-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);cursor:pointer;font-size:13px;font-weight:600;color:var(--label);transition:all .2s;display:flex;align-items:center;gap:6px}.pron-playback-btn:hover{border-color:var(--blue);transform:translateY(-1px)}.pron-playback-btn.playing{border-color:var(--blue);background:#0052a51f;color:var(--blue)}.pron-playback-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.pron-attempt-row{display:flex;gap:6px;justify-content:center;margin:8px 0;flex-wrap:wrap}.pron-attempt-btn{padding:6px 12px;border-radius:10px;border:1px solid var(--g-border);background:var(--g-bg);cursor:pointer;font-size:12px;font-weight:600;color:var(--label2);transition:all .2s}.pron-attempt-btn:hover{border-color:var(--blue)}.pron-attempt-btn.active{border-color:var(--blue);background:#0052a51f;color:var(--blue)}.pron-attempt-score{font-size:11px;font-weight:700;margin-left:4px}.pron-attempt-score.great{color:#34c759}.pron-attempt-score.good{color:#ff9f0a}.pron-attempt-score.try{color:#ff453a}.puhekieli-toggle{display:flex;align-items:center;gap:8px;padding:6px 14px;border-radius:12px;background:var(--g-bg);border:.5px solid var(--g-border);cursor:pointer;font-size:13px;font-weight:600;color:var(--label);transition:all .2s}.puhekieli-toggle.active{border-color:#8b5cf6;background:#8b5cf61f;color:#8b5cf6}.puhekieli-toggle:hover{border-color:#8b5cf6}.puhekieli-written{font-size:24px;font-weight:700;color:var(--blue);text-align:center;padding:16px 0;line-height:1.4}.puhekieli-spoken{font-size:24px;font-weight:700;color:#8b5cf6;text-align:center;padding:16px 0;line-height:1.4}.puhekieli-category-badge{display:inline-block;padding:3px 10px;border-radius:8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.puhekieli-options{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:12px 0}@media(max-width:400px){.puhekieli-options{grid-template-columns:1fr}}.puhekieli-option{padding:14px;border-radius:14px;border:1.5px solid var(--g-border);background:var(--g-bg);cursor:pointer;text-align:center;font-size:16px;font-weight:600;color:var(--label);transition:all .2s}.puhekieli-option:hover{border-color:#8b5cf6;transform:translateY(-1px)}.puhekieli-option.correct-pick{border-color:#34c759;background:#34c7591f;color:#34c759}.puhekieli-option.wrong-pick{border-color:#ff453a;background:#ff453a1f;color:#ff453a}.puhekieli-option.selected{border-color:#8b5cf6;background:#8b5cf61f}.puhekieli-arrow{font-size:28px;text-align:center;color:var(--label3);margin:8px 0}.pron-diagnostic{max-width:640px;margin:0 auto}.pron-diagnostic-progress{height:6px;border-radius:3px;background:var(--fill2);margin:16px 0;overflow:hidden}.pron-diagnostic-progress-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--blue),#8b5cf6);transition:width .4s ease}.pron-radar-chart{width:260px;height:260px;margin:16px auto;position:relative}.pron-radar-axis{position:absolute;width:2px;background:var(--g-border);transform-origin:bottom center;left:50%;bottom:50%}.pron-radar-label{position:absolute;font-size:11px;font-weight:600;color:var(--label2);white-space:nowrap}.pron-radar-polygon{fill:#0052a526;stroke:var(--blue);stroke-width:2}.pron-diagnostic-category{padding:14px;border-radius:14px;background:var(--g-bg);border:.5px solid var(--g-border);margin-bottom:10px}.pron-diagnostic-category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.pron-diagnostic-category-name{font-size:14px;font-weight:700;color:var(--label)}.pron-diagnostic-category-score{font-size:14px;font-weight:700;padding:3px 10px;border-radius:8px}.pron-diagnostic-bar{height:8px;border-radius:4px;background:var(--fill2);overflow:hidden}.pron-diagnostic-bar-fill{height:100%;border-radius:4px;transition:width .6s ease}.pron-diagnostic-recs{margin-top:16px}.pron-diagnostic-rec{display:flex;gap:10px;align-items:flex-start;padding:10px 14px;border-radius:12px;background:#ff9f0a14;border:.5px solid rgba(255,159,10,.2);margin-bottom:8px}.pron-diagnostic-rec-icon{font-size:18px;flex-shrink:0}.pron-diagnostic-rec-text{font-size:13px;color:var(--label);line-height:1.5}.referral-section{padding:20px;border-radius:16px;background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);box-shadow:var(--g-shine),0 2px 8px #00000014;margin-bottom:16px}.referral-section-title{font-size:15px;font-weight:700;color:var(--label);margin-bottom:12px;display:flex;align-items:center;gap:8px}.referral-link-box{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;background:var(--fill2);border:.5px solid var(--g-border);margin-bottom:12px}.referral-link-text{flex:1;font-size:13px;font-family:monospace;color:var(--label);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.referral-copy-btn{padding:6px 14px;border-radius:8px;background:var(--blue);color:#fff;font-size:12px;font-weight:600;border:none;cursor:pointer;white-space:nowrap;transition:transform .15s}.referral-copy-btn:active{transform:scale(.95)}.referral-share-row{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.referral-share-btn{flex:1;min-width:80px;padding:10px 12px;border-radius:12px;border:none;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:transform .15s,opacity .15s;color:#fff}.referral-share-btn:active{transform:scale(.95);opacity:.85}.referral-share-btn.whatsapp{background:#25d366}.referral-share-btn.telegram{background:#08c}.referral-share-btn.email-share{background:var(--blue)}.referral-share-btn.share-native{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.referral-stats{display:flex;gap:12px;margin-bottom:16px}.referral-stat{flex:1;text-align:center;padding:12px 8px;border-radius:12px;background:var(--fill2);border:.5px solid var(--g-border)}.referral-stat-num{font-size:22px;font-weight:800;color:var(--label)}.referral-stat-label{font-size:11px;color:var(--label3);margin-top:2px}.referral-invited-list{margin-top:12px}.referral-invited-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:.5px solid var(--g-border)}.referral-invited-item:last-child{border-bottom:none}.referral-milestone{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;background:var(--fill2);border:.5px solid var(--g-border);margin-bottom:8px}.referral-milestone.unlocked{background:#34c75914;border-color:#34c7594d}.referral-milestone-icon{font-size:24px}.referral-milestone-info{flex:1}.referral-milestone-title{font-size:13px;font-weight:600;color:var(--label)}.referral-milestone-desc{font-size:11px;color:var(--label3)}.referral-milestone-check{font-size:18px;color:var(--green)}.share-achievement-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:13px;font-weight:600;border:none;cursor:pointer;transition:transform .15s,opacity .15s}.share-achievement-btn:active{transform:scale(.95);opacity:.85}.share-prompt-overlay{position:fixed;bottom:80px;left:50%;transform:translate(-50%);z-index:1500;width:calc(100% - 40px);max-width:360px;animation:sharePromptSlide .4s ease}.share-prompt-card{padding:16px 20px;border-radius:16px;background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:.5px solid var(--g-border);box-shadow:0 8px 32px #0000002e;display:flex;align-items:center;gap:12px}.share-prompt-text{flex:1;font-size:13px;color:var(--label);line-height:1.4}.share-prompt-text strong{display:block;font-size:14px;margin-bottom:2px}.share-prompt-actions{display:flex;gap:6px;flex-shrink:0}.share-prompt-btn{padding:8px 14px;border-radius:10px;font-size:12px;font-weight:600;border:none;cursor:pointer}.share-prompt-btn.share{background:var(--blue);color:#fff}.share-prompt-btn.dismiss{background:var(--fill2);color:var(--label3)}@keyframes sharePromptSlide{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.pic-screen{max-width:720px;margin:0 auto;padding:0 16px 120px}.pic-header{text-align:center;margin-bottom:20px}.pic-title{font-size:26px;font-weight:800;color:var(--label);margin:0 0 4px}.pic-subtitle{font-size:14px;color:var(--label3);margin:0}.pic-card{background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:1px solid var(--g-border);border-radius:20px;padding:16px;margin-bottom:14px;box-shadow:var(--g-shadow)}.pic-main-card{padding:24px}.pic-level-pills{display:flex;flex-wrap:wrap;gap:6px}.pic-pill{padding:6px 14px;border-radius:10px;border:1.5px solid var(--g-border);background:var(--fill2);font-size:13px;font-weight:600;color:var(--label2);cursor:pointer;transition:all var(--t-fast)}.pic-pill:hover{background:var(--fill2)}.pic-pill.active{font-weight:700}.pic-exercise-list{display:flex;flex-direction:column;gap:8px}.pic-exercise-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:14px;background:var(--g-bg);-webkit-backdrop-filter:var(--g-blur);backdrop-filter:var(--g-blur);border:1px solid var(--g-border);cursor:pointer;transition:all var(--t-fast);box-shadow:var(--g-shadow)}.pic-exercise-item:hover{transform:translateY(-1px);box-shadow:0 4px 20px #00000014}.pic-exercise-item.completed{border-left:3px solid var(--green)}.pic-ex-num{width:32px;height:32px;border-radius:10px;background:var(--fill2);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:var(--label2);flex-shrink:0}.pic-exercise-item.completed .pic-ex-num{background:var(--green);color:#fff}.pic-ex-info{flex:1;min-width:0}.pic-ex-title{font-size:15px;font-weight:600;color:var(--label)}.pic-ex-meta{font-size:12px;color:var(--label3);margin-top:2px}.pic-ex-score{font-size:13px;font-weight:600;color:var(--green)}.pic-score-badge{padding:2px 8px;border-radius:8px;background:#2db84d1f}.pic-score-badge.perfect{background:#2db84d33}.pic-ex-arrow{font-size:20px;color:var(--label3)}.pic-exercise-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.pic-back-btn{font-size:14px;color:var(--blue);background:none;border:none;cursor:pointer;font-weight:600;padding:4px 0}.pic-exercise-title{font-size:18px;font-weight:700;color:var(--label)}.pic-scene-area{text-align:center;padding:28px 16px;margin-bottom:16px;background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);border:1px solid var(--g-border);border-radius:20px;box-shadow:var(--g-shadow)}.pic-scene-emojis{font-size:56px;letter-spacing:12px;margin-bottom:12px;line-height:1.4}.pic-scene-hint{font-size:13px;color:var(--label3);font-style:italic;margin-top:8px}.pic-question-label{font-size:16px;font-weight:600;color:var(--label);margin-bottom:14px;text-align:center}.pic-options{display:flex;flex-direction:column;gap:10px}.pic-option{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:14px;border:1.5px solid var(--g-border);background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);box-shadow:var(--g-shadow);cursor:pointer;transition:all var(--t-fast);font-size:15px;color:var(--label);text-align:left}.pic-option:hover:not(:disabled):not(.correct):not(.wrong):not(.dimmed){border-color:var(--blue);background:#0052a50f}.pic-option.correct{border-color:var(--green);background:#2db84d1a;color:var(--green)}.pic-option.wrong{border-color:var(--red);background:#e5342b14;color:var(--red)}.pic-option.dimmed{opacity:.5}.pic-opt-letter{width:28px;height:28px;border-radius:8px;background:var(--fill2);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:var(--label2);flex-shrink:0}.pic-option.correct .pic-opt-letter{background:var(--green);color:#fff}.pic-option.wrong .pic-opt-letter{background:var(--red);color:#fff}.pic-opt-text{flex:1}.pic-feedback{margin-top:12px;padding:12px 16px;border-radius:12px;font-size:14px;line-height:1.5;transition:all var(--t-fast)}.pic-feedback.correct{background:#2db84d1a;color:var(--green)}.pic-feedback.wrong{background:#e5342b14;color:var(--red)}.pic-results-header{text-align:center;padding:20px 0}.pic-results-emoji{font-size:48px;margin-bottom:8px}.pic-results-score{font-size:32px;font-weight:800;color:var(--label)}.pic-results-pct{font-size:20px;font-weight:600;color:var(--blue);margin-top:4px}.pic-results-msg{font-size:16px;color:var(--label2);margin-top:8px}.pic-review{margin-top:16px}.pic-review-item{padding:12px;border-radius:12px;margin-bottom:8px;background:var(--fill2)}.pic-review-item.correct{border-left:3px solid var(--green)}.pic-review-item.wrong{border-left:3px solid var(--red)}.pic-review-scene{font-size:13px;color:var(--label3);margin-bottom:4px}.pic-review-answer{font-size:14px;font-weight:600;color:var(--label);margin-bottom:2px}.pic-review-explain{font-size:13px;color:var(--label2)}.pic-results-actions{display:flex;gap:10px;justify-content:center;margin-top:20px;flex-wrap:wrap}.pic-btn{padding:10px 20px;border-radius:12px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--t-fast)}.pic-btn-primary{background:var(--blue);color:#fff}.pic-btn-primary:hover{filter:brightness(1.08)}.pic-btn-secondary{background:var(--fill2);color:var(--label2)}.pic-btn-secondary:hover{background:var(--fill3)}.pic-progress-bar{height:6px;border-radius:3px;background:var(--fill2);margin-bottom:16px;overflow:hidden}.pic-progress-fill{height:100%;border-radius:3px;background:var(--blue);transition:width var(--t-normal)}.listen-screen{max-width:720px;margin:0 auto;padding:0 16px 120px}.listen-header{text-align:center;margin-bottom:20px}.listen-title{font-size:26px;font-weight:800;color:var(--label);margin:0 0 4px}.listen-subtitle{font-size:14px;color:var(--label3);margin:0}.listen-card{background:var(--g-bg);border:.5px solid var(--g-border);border-radius:18px;padding:20px;margin-bottom:16px;backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);box-shadow:var(--g-shadow),var(--g-shine)}.listen-main-card{padding:24px}.listen-level-pills{display:flex;flex-wrap:wrap;gap:6px}.listen-pill{padding:6px 14px;border-radius:20px;border:1.5px solid var(--sep);background:transparent;font-size:13px;font-weight:600;cursor:pointer;color:var(--label);transition:all var(--t-fast);display:inline-flex;align-items:center}.listen-pill:hover{background:var(--fill2)}.listen-pill.active{font-weight:700}.listen-exercise-list{display:flex;flex-direction:column;gap:8px}.listen-exercise-item{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--g-bg);border:.5px solid var(--g-border);border-radius:14px;cursor:pointer;transition:all var(--t-fast);width:100%;text-align:left;backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);box-shadow:var(--g-shadow),var(--g-shine)}.listen-exercise-item:hover{transform:translateY(-1px);box-shadow:0 4px 20px #00000014}.listen-exercise-item.completed{border-left:3px solid var(--green)}.listen-ex-num{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;background:var(--fill);color:var(--label2);flex-shrink:0}.listen-exercise-item.completed .listen-ex-num{background:var(--green);color:#fff}.listen-ex-info{flex:1;min-width:0}.listen-ex-title{font-size:15px;font-weight:600;color:var(--label)}.listen-ex-meta{font-size:12px;color:var(--label3);margin-top:2px}.listen-ex-score{font-size:13px;font-weight:600;color:var(--green)}.listen-score-badge{padding:2px 8px;border-radius:8px;background:#2db84d1f}.listen-score-badge.perfect{background:#2db84d33}.listen-ex-arrow{font-size:20px;color:var(--label3)}.listen-exercise-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.listen-back-btn{background:none;border:none;cursor:pointer;font-size:14px;font-weight:600;color:var(--blue);padding:4px 0}.listen-exercise-title{font-size:18px;font-weight:700;color:var(--label)}.listen-play-area{text-align:center;padding:16px 0}.listen-speaker-icon{font-size:48px;margin-bottom:12px;transition:transform .3s}.listen-speaker-icon.playing{animation:listen-pulse 1s ease-in-out infinite}@keyframes listen-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.listen-play-buttons{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.listen-btn{padding:10px 22px;border-radius:12px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--t-fast)}.listen-btn:disabled{opacity:.5;cursor:default}.listen-btn-play{background:var(--blue);color:#fff}.listen-btn-play:hover:not(:disabled){background:#0047a0}.listen-btn-slow{background:var(--fill);color:var(--label)}.listen-btn-slow:hover:not(:disabled){background:var(--fill2)}.listen-btn-text{background:none;border:1px solid var(--sep)!important;color:var(--label2);font-size:13px;padding:8px 16px}.listen-btn-primary{background:var(--blue);color:#fff;padding:12px 28px;font-size:15px;border-radius:14px}.listen-btn-primary:hover:not(:disabled){background:#0047a0;transform:translateY(-1px)}.listen-btn-secondary{background:var(--fill);color:var(--label);padding:12px 28px;font-size:15px;border-radius:14px}.listen-btn-sm{font-size:12px;padding:6px 14px;border-radius:10px;background:var(--fill);color:var(--label)}.listen-passage-box{background:var(--fill2);border-radius:14px;padding:16px;margin-top:16px;border:.5px solid var(--g-border)}.listen-passage-fi{font-size:16px;font-weight:500;color:var(--label);line-height:1.6;margin-bottom:10px}.listen-passage-en{font-size:13px;color:var(--label3);font-style:italic;line-height:1.5}.listen-progress-bar{width:100%;height:6px;border-radius:3px;background:var(--fill);margin-bottom:8px;overflow:hidden}.listen-progress-fill{height:100%;border-radius:3px;background:var(--blue);transition:width var(--t-normal)}.listen-question-text{font-size:18px;font-weight:600;color:var(--label);margin-bottom:16px;line-height:1.4}.listen-options{display:flex;flex-direction:column;gap:10px}.listen-option{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--g-bg);border:1.5px solid var(--sep);border-radius:14px;cursor:pointer;transition:all var(--t-fast);width:100%;text-align:left;font-size:15px;color:var(--label)}.listen-option:hover:not(:disabled):not(.correct):not(.wrong):not(.dimmed){border-color:var(--blue);background:#0052a50f}.listen-option.correct{border-color:var(--green);background:#2db84d1a;color:var(--green)}.listen-option.wrong{border-color:var(--red);background:#e5342b14;color:var(--red)}.listen-option.dimmed{opacity:.5}.listen-opt-letter{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;background:var(--fill);flex-shrink:0}.listen-option.correct .listen-opt-letter{background:var(--green);color:#fff}.listen-option.wrong .listen-opt-letter{background:var(--red);color:#fff}.listen-opt-text{flex:1}.listen-feedback{text-align:center;padding:12px;border-radius:12px;margin-top:12px;font-size:14px;font-weight:600}.listen-feedback.correct{background:#2db84d1a;color:var(--green)}.listen-feedback.wrong{background:#e5342b14;color:var(--red)}.listen-results-header{text-align:center;padding:20px 0}.listen-results-emoji{font-size:48px;margin-bottom:8px}.listen-results-score{font-size:32px;font-weight:800;color:var(--label)}.listen-results-pct{font-size:20px;font-weight:600;color:var(--blue);margin-top:4px}.listen-results-msg{font-size:16px;color:var(--label2);margin-top:8px}.listen-review{margin-top:16px}.listen-review-item{padding:12px;border-radius:12px;margin-bottom:8px;background:var(--fill2)}.listen-review-item.correct{border-left:3px solid var(--green)}.listen-review-item.wrong{border-left:3px solid var(--red)}.listen-review-q{font-size:14px;font-weight:600;color:var(--label);margin-bottom:4px}.listen-review-a{font-size:13px;color:var(--label2)}.listen-results-actions{display:flex;gap:10px;justify-content:center;margin-top:20px;flex-wrap:wrap}.review-fab{position:fixed;bottom:90px;right:20px;width:56px;height:56px;border-radius:50%;background:#e74c3c;border:none;color:#fff;font-size:24px;cursor:pointer;z-index:9999;box-shadow:0 4px 16px #e74c3c66;transition:transform .2s;display:flex;align-items:center;justify-content:center}.review-fab:active{transform:scale(.9)}.review-fab:hover{transform:scale(1.05);box-shadow:0 6px 24px #e74c3c80}.review-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:10000;display:flex;align-items:center;justify-content:center;padding:16px}.review-modal{background:var(--g-bg, #1a1f2e);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:24px;max-width:480px;width:100%;max-height:80vh;overflow-y:auto}.review-select,.review-textarea{width:100%;padding:12px;border-radius:8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#fff;font-size:14px;margin-bottom:12px;box-sizing:border-box;font-family:inherit}.review-select option{background:#1a1f2e;color:#fff}.review-textarea{min-height:100px;resize:vertical}.review-submit{width:100%;padding:14px;border-radius:12px;background:linear-gradient(135deg,#e74c3c,#c0392b);border:none;color:#fff;font-weight:600;font-size:16px;cursor:pointer;transition:opacity .2s}.review-submit:hover{opacity:.9}.review-submit:disabled{opacity:.5;cursor:not-allowed}.review-toggle-label{position:relative;display:inline-block;width:48px;height:26px;flex-shrink:0}.review-toggle-input{opacity:0;width:0;height:0;position:absolute}.review-toggle-slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background:#ffffff26;border-radius:26px;transition:.3s}.review-toggle-slider:before{content:"";position:absolute;height:20px;width:20px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s}.review-toggle-input:checked+.review-toggle-slider{background:#e74c3c}.review-toggle-input:checked+.review-toggle-slider:before{transform:translate(22px)}.ctx-vocab-section{margin:16px 0}.ctx-vocab-toggle{background:none;border:1px solid rgba(255,255,255,.1);color:#fff9;padding:10px 16px;border-radius:10px;width:100%;text-align:left;font-size:14px;cursor:pointer;font-family:inherit}.ctx-vocab-list{margin-top:8px;background:var(--g-bg);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px 16px}.ctx-vocab-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04)}.ctx-vocab-row:last-child{border-bottom:none}.ctx-vocab-fi{color:#fff;font-weight:500;font-size:14px}.ctx-vocab-en{color:#ffffff80;font-size:14px}.story-show-translation-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;background:#0052a51a;border:.5px solid rgba(0,82,165,.25);color:var(--blue);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;margin-top:8px;transition:all .15s}.story-show-translation-btn:hover{background:#0052a52e}.mod-screen{padding:0 16px 100px;max-width:680px;margin:0 auto}.mod-back-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:10px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:#fff;font-size:14px;cursor:pointer;margin-bottom:16px;transition:background .2s;font-family:inherit;font-weight:600}.mod-back-btn:hover{background:#ffffff1a}.mod-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.mod-title{font-size:22px;font-weight:700;color:#fff}.mod-subtitle{font-size:14px;color:#ffffff80;margin-top:4px}.mod-level-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.mod-level-pill{padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600;border:1px solid rgba(255,255,255,.12);background:#ffffff0a;color:#fff9;cursor:pointer;transition:all .2s;font-family:inherit;display:inline-flex;align-items:center;gap:4px}.mod-level-pill:hover{background:#ffffff14}.mod-level-pill.active{background:var(--current-mod,var(--accent,#3498db));color:#fff;border-color:transparent}.mod-level-pill.locked{opacity:.4;cursor:default}@keyframes skPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes vkFlashRed{0%{background:#ef44444d}to{background:transparent}}@keyframes vkFlashGreen{0%{background:#10b9814d}to{background:#10b98126}}.mod-card{background:var(--g-bg,rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:20px;margin-bottom:16px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.mod-options{display:flex;flex-direction:column;gap:10px;margin:16px 0}.mod-option{padding:14px 18px;border-radius:12px;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);color:#fff;font-size:15px;cursor:pointer;transition:all .2s;min-height:48px;display:flex;align-items:center;font-family:inherit;text-align:left;width:100%}.mod-option:hover{background:#ffffff14}.mod-option.correct{background:#2ecc7126;border-color:#2ecc71}.mod-option.wrong{background:#e74c3c26;border-color:#e74c3c}.mod-option.selected{border-color:var(--current-mod,var(--accent,#3498db));background:#3498db1a}.mod-option.dimmed{opacity:.5}.mod-btn-primary{width:100%;padding:16px;border-radius:14px;background:linear-gradient(135deg,var(--current-mod,#3498db),var(--current-mod-end,#2ecc71));border:none;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:transform .1s,box-shadow .2s;box-shadow:0 4px 16px #0003;font-family:inherit}.mod-btn-primary:active{transform:scale(.97)}.mod-btn-primary:disabled{opacity:.5;cursor:default;transform:none}.mod-btn-secondary{padding:10px 20px;border-radius:10px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:#fff;font-size:14px;cursor:pointer;font-family:inherit;font-weight:600;transition:background .2s}.mod-btn-secondary:hover{background:#ffffff1a}.mod-progress-bar{height:4px;background:#ffffff14;border-radius:2px;overflow:hidden;margin:12px 0}.mod-progress-fill{height:100%;background:var(--current-mod,var(--accent,#3498db));border-radius:2px;transition:width .5s ease}.mod-results{text-align:center;padding:32px 20px}.mod-results-score{font-size:48px;font-weight:800;margin-bottom:8px}.mod-results-label{color:#ffffff80;font-size:14px}.mod-exercise-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-radius:12px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);margin-bottom:8px;cursor:pointer;transition:background .2s;font-family:inherit;text-align:left;width:100%;color:#fff}.mod-exercise-item:hover{background:#ffffff0f}.mod-counter{font-size:13px;color:#ffffff80;font-weight:600}.mod-section-label{font-size:12px;font-weight:700;color:#fff6;text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px}#sl-loader{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0f1a;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:99999;transition:opacity .5s}#sl-loader.hidden{opacity:0;pointer-events:none}#sl-loader-logo{font-size:48px;margin-bottom:16px}#sl-loader-title{color:#fff;font-size:24px;font-weight:700;margin-bottom:8px;font-family:-apple-system,BlinkMacSystemFont,sans-serif}#sl-loader-sub{color:#ffffff80;font-size:14px;margin-bottom:32px;font-family:-apple-system,BlinkMacSystemFont,sans-serif}#sl-loader-bar-bg{width:200px;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}#sl-loader-bar{height:100%;width:0%;background:linear-gradient(90deg,#3498db,#2ecc71);border-radius:2px;animation:sl-load 3s ease-in-out infinite}@keyframes sl-load{0%{width:0%}50%{width:80%}to{width:100%}}@keyframes sl-sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}#sl-loader-tip{color:#fff6;font-size:12px;margin-top:16px;font-family:-apple-system,BlinkMacSystemFont,sans-serif;transition:opacity .3s}.fc-check-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px #22c55e66}.fc-feedback{margin-top:16px;border:1px solid rgba(34,197,94,.18);background:#22c55e0a}.fc-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:16px;padding:12px;background:#0000002e;border-radius:10px}.fc-stat{display:flex;flex-direction:column;gap:4px}.fc-stat-label{font-size:11px;color:#ffffff8c;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.fc-stat-bar{height:6px;background:#ffffff14;border-radius:3px;overflow:hidden}.fc-stat-fill{height:100%;border-radius:3px;transition:width .5s ease}.fc-stat-val{font-size:13px;color:#fff;font-weight:600}.fc-stat-val-lg{font-size:22px;font-weight:700;color:#fff;line-height:1;margin-top:2px}.fc-task-warning{padding:12px 14px;background:#f59e0b1a;border-left:3px solid #f59e0b;border-radius:8px;color:#fde68a;font-size:13px;margin-bottom:14px;line-height:1.5}.fc-no-errors{padding:16px;text-align:center;background:#22c55e1a;border-radius:10px;color:#86efac;font-size:14px;font-weight:600}.fc-errors-header{font-size:13px;color:#ffffffb3;font-weight:600;margin-bottom:10px}.fc-error-group{margin-bottom:12px}.fc-error-group-title{font-size:12px;color:#fff9;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;padding-bottom:4px;border-bottom:1px dashed rgba(255,255,255,.1)}.fc-error-item{display:flex;gap:10px;padding:8px 12px;margin-bottom:4px;background:#0003;border-left:3px solid #ef4444;border-radius:6px;font-size:13px;line-height:1.5}.fc-error-icon{flex-shrink:0;font-size:14px}.fc-error-body{flex:1;color:#ffffffd9}.fc-error-word{font-family:Georgia,serif;color:#fbbf24;font-weight:600;margin-right:6px}.fc-error-msg{color:#ffffffbf}.fc-suggestions{margin-top:14px;padding:12px 14px;background:#3b82f614;border-left:3px solid #3b82f6;border-radius:8px}.fc-suggestions-title{font-size:13px;color:#93c5fd;font-weight:700;margin-bottom:8px}.fc-suggestion-item{font-size:13px;color:#fffc;line-height:1.5;margin-bottom:4px}.sl-toast-stack{position:fixed;bottom:calc(env(safe-area-inset-bottom,16px) + 80px);left:50%;transform:translate(-50%);z-index:10001;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none;max-width:92vw;width:360px}.sl-toast{display:flex;align-items:center;gap:10px;padding:12px 18px;border-radius:14px;font-size:13px;font-weight:600;line-height:1.3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 8px 32px #00000038;animation:slToastIn .35s cubic-bezier(.34,1.56,.64,1);pointer-events:auto;cursor:pointer}.sl-toast-icon{font-size:18px;flex-shrink:0}.sl-toast-msg{flex:1;color:#fff}.sl-toast-error{background:#dc3228eb}.sl-toast-success{background:#2db84deb}.sl-toast-info{background:#0052a5eb}@keyframes slToastIn{0%{opacity:0;transform:translateY(16px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:600px){.sl-toast-stack{bottom:calc(env(safe-area-inset-bottom,8px) + 70px);width:calc(100vw - 24px)}}.build-screen{max-width:900px;margin:0 auto;padding:20px;display:flex;flex-direction:column;gap:16px;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,SF Pro Display,Inter,Helvetica Neue,sans-serif}.build-header{background:var(--g-bg);border:.5px solid var(--g-border);border-radius:20px;backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);padding:28px 24px;text-align:center;box-shadow:var(--g-shine),var(--g-shadow)}.build-card.build-info{text-align:center;padding:24px}.build-card.build-prompt{padding:20px 24px;text-align:center;margin-bottom:14px}.build-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--label3);margin-bottom:12px}.build-level-bar{display:flex;flex-wrap:wrap;gap:8px}.build-level-pill{padding:8px 16px;border-radius:20px;border:.5px solid var(--g-border);background:var(--g-bg);backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);font-family:inherit;font-size:13px;font-weight:600;color:var(--label);cursor:pointer;transition:all .2s cubic-bezier(.34,1.18,.64,1);text-align:center;box-shadow:var(--g-shine),0 2px 8px #0000000a;white-space:nowrap}.build-level-id{font-weight:700;font-size:14px;color:var(--label);margin-bottom:4px}.build-level-count{font-size:11px;color:var(--label2);margin-top:2px}.build-level-pill:hover:not(.locked){border-color:#0052a54d;background:#0052a514;transform:translateY(-2px);box-shadow:var(--g-shine),0 6px 20px #0052a51f}.build-level-pill.active{border-color:#0052a566;background:#0052a524;color:var(--blue);box-shadow:inset 0 1px #ffffff4d,0 4px 16px #0052a52e}.build-level-pill.locked{opacity:.55;cursor:not-allowed;filter:grayscale(.4);color:var(--label3)}.build-topbar{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--g-bg);border:.5px solid var(--g-border);border-radius:18px;backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);box-shadow:var(--g-shine),var(--g-shadow)}.build-back-btn{background:var(--g-bg);border:.5px solid var(--g-border);border-radius:10px;padding:7px 14px;font-size:15px;color:var(--label2);cursor:pointer;transition:all .18s;font-family:inherit;font-weight:600;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.build-back-btn:hover{background:var(--fill2);color:var(--label);border-color:#0052a533}.build-progress-bar{flex:1;height:6px;background:var(--fill);border-radius:3px;overflow:hidden}.build-progress-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--purple));border-radius:3px;transition:width .3s ease}.build-progress-text{font-size:12px;font-weight:700;color:var(--label2);white-space:nowrap;min-width:32px;text-align:right}.build-score{font-size:13px;font-weight:700;color:var(--green);white-space:nowrap}.build-english{font-size:19px;font-weight:700;color:var(--label);line-height:1.5;margin-bottom:12px}.build-btn-audio{padding:8px 16px;border-radius:8px;border:1px solid var(--sep);background:var(--fill2);color:var(--label);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s}.build-btn-audio:hover{border-color:var(--blue);color:var(--blue);background:#0052a50d}.build-built-area{min-height:64px;padding:16px 18px;border-radius:16px;border:2px dashed var(--sep);background:var(--fill2);margin-bottom:16px;display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:flex-start;transition:all .22s cubic-bezier(.34,1.18,.64,1)}.build-built-area.correct{border-color:var(--green);background:#2db84d14}.build-built-area.incorrect{border-color:var(--red);background:#e5342b14}.build-placeholder{font-size:14px;color:var(--label3);font-style:italic;margin:auto}.build-tile-built{padding:8px 16px;border-radius:10px;border:1px solid var(--blue);background:#0052a51a;color:var(--blue);font-weight:600;font-size:15px;cursor:pointer;font-family:inherit;transition:all .15s}.build-built-area.correct .build-tile-built{border-color:var(--green);background:#2db84d26;color:var(--green)}.build-built-area.incorrect .build-tile-built{border-color:var(--red);background:#e5342b26;color:var(--red)}.build-tile-built:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 2px 8px currentColor}.build-tile-built:disabled{cursor:default}.build-audio-actions{display:flex;gap:8px;justify-content:center;margin-bottom:14px;flex-wrap:wrap}.build-pool{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px;justify-content:center;padding:14px;background:var(--fill2);border-radius:16px;border:.5px solid var(--g-border)}.build-tile-pool{padding:10px 18px;border-radius:12px;border:.5px solid var(--g-border);background:var(--g-bg);color:var(--label);font-weight:600;font-size:14px;cursor:pointer;font-family:inherit;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:var(--g-shine),0 2px 8px #0000000d;transition:all .18s cubic-bezier(.34,1.18,.64,1)}.build-tile-pool:hover:not(:disabled){transform:translateY(-2px);border-color:#0052a54d;box-shadow:var(--g-shine),0 6px 16px #0052a51f}.build-tile-pool:active:not(:disabled){transform:scale(.96)}.build-tile-pool:disabled{opacity:.4;cursor:default;filter:grayscale(.2)}.build-hint-btn{background:none;border:none;color:var(--blue);font-size:13px;cursor:pointer;font-family:inherit;font-weight:600;transition:all .2s;padding:6px 12px}.build-hint-btn:hover{color:var(--purple);text-decoration:underline}.build-feedback{background:#e5342b14;border:.5px solid rgba(229,52,43,.2);border-radius:16px;padding:14px 18px;margin-bottom:14px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.build-feedback-title{font-size:12px;font-weight:700;color:var(--red);text-transform:uppercase;margin-bottom:4px}.build-feedback-answer{font-size:16px;font-weight:700;color:var(--label);margin-bottom:8px;padding:8px 0}.build-feedback-grammar-label{font-size:10px;font-weight:700;color:var(--label3);text-transform:uppercase;margin-top:8px;margin-bottom:4px}.build-feedback-grammar{font-size:12px;color:var(--label2);line-height:1.5;font-style:italic}.build-btn-primary{padding:15px 40px;border-radius:14px;border:.5px solid rgba(255,255,255,.16);background:linear-gradient(180deg,#1a6fc4,#003f88);color:#fff;font-weight:700;font-size:16px;cursor:pointer;font-family:inherit;transition:transform .18s cubic-bezier(.34,1.4,.64,1),box-shadow .18s,filter .18s;box-shadow:inset 0 1px #ffffff4d,0 6px 24px #0052a559,0 2px 8px #0000001a}.build-btn-primary:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-2px);box-shadow:inset 0 1px #ffffff4d,0 10px 32px #0052a566,0 4px 12px #0000001f}.build-btn-primary:active:not(:disabled){transform:scale(.97)}.build-btn-primary:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.2)}.build-btn-primary.success{background:linear-gradient(180deg,#46e36a,#27b844);box-shadow:inset 0 1px #ffffff4d,0 6px 24px #34c75959,0 2px 8px #0000001a}.build-btn-secondary{padding:11px 22px;border-radius:12px;border:.5px solid var(--g-border);background:var(--g-bg);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);color:var(--label);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .18s;box-shadow:var(--g-shine),0 2px 8px #0000000a}.build-btn-secondary:hover{border-color:#0052a54d;color:var(--blue);background:#0052a50f;box-shadow:var(--g-shine),0 4px 16px #0052a51a}.build-results{background:var(--g-bg);border:.5px solid var(--g-border);border-radius:24px;backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);padding:44px 36px;text-align:center;box-shadow:var(--g-shine),var(--g-shadow)}.build-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.build-modal{background:var(--g-bg);border:.5px solid var(--g-border);border-radius:24px;backdrop-filter:var(--g-blur);-webkit-backdrop-filter:var(--g-blur);padding:32px 28px;max-width:400px;box-shadow:var(--g-shine),0 24px 64px #0003,0 8px 24px #0000001a}@keyframes shake{0%{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}to{transform:translate(0)}}@keyframes tilePulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.build-card,.build-results{animation:slideUp .35s cubic-bezier(.34,1.18,.64,1) both;animation-fill-mode:both}@media(max-width:768px){.build-screen{padding:12px;gap:12px}.build-level-bar{grid-template-columns:repeat(auto-fit,minmax(80px,1fr))}.build-pool{padding:8px;gap:6px}.build-tile-pool{padding:8px 12px;font-size:13px}.build-btn-primary{padding:12px 28px;font-size:15px}}@media(max-width:480px){.build-screen{padding:8px}.build-card{padding:16px}.build-level-bar{grid-template-columns:repeat(2,1fr)}.build-topbar{flex-wrap:wrap;padding:8px 12px}.build-progress-bar{width:100%;order:3}.build-english{font-size:16px}.build-tile-built{padding:6px 12px;font-size:13px}.build-tile-pool{padding:8px 12px;font-size:12px}.build-btn-primary{padding:12px 24px;font-size:14px}.build-results{padding:28px 20px}}:root{--v2-surface-canvas: #0A0F1C;--v2-surface-base: #0F1626;--v2-surface-elevated: #161E33;--v2-surface-overlay: #1F2940;--v2-surface-glass: rgba(255, 255, 255, .06);--v2-surface-glass-strong: rgba(255, 255, 255, .1);--v2-text-primary: #F5F7FB;--v2-text-secondary: #B8C0D0;--v2-text-tertiary: #7A8499;--v2-text-quaternary: #4A5468;--v2-text-inverse: #0F1626;--v2-border-subtle: rgba(255, 255, 255, .06);--v2-border-medium: rgba(255, 255, 255, .1);--v2-border-strong: rgba(255, 255, 255, .18);--v2-brand-50: #E6F4FE;--v2-brand-100: #C6E6FC;--v2-brand-200: #9FD3F9;--v2-brand-300: #69B7F4;--v2-brand-400: #3D97E8;--v2-brand-500: #1E7FD4;--v2-brand-600: #1565B0;--v2-brand-700: #0F4D8B;--v2-brand-800: #0B3866;--v2-brand-900: #072545;--v2-level-a11: #4ADE80;--v2-level-a12: #34D8B4;--v2-level-a21: #22D3EE;--v2-level-a22: #3D97E8;--v2-level-b11: #818CF8;--v2-level-b12: #A78BFA;--v2-level-b21: #C084FC;--v2-level-b22: #E879F9;--v2-success: #4ADE80;--v2-success-bg: rgba(74, 222, 128, .16);--v2-success-border: rgba(74, 222, 128, .32);--v2-warning: #FBBF24;--v2-warning-bg: rgba(251, 191, 36, .14);--v2-warning-border: rgba(251, 191, 36, .3);--v2-danger: #F87171;--v2-danger-bg: rgba(248, 113, 113, .14);--v2-danger-border: rgba(248, 113, 113, .3);--v2-info: #60A5FA;--v2-font-display: "SF Pro Display", -apple-system, BlinkMacSystemFont, Inter, system-ui, sans-serif;--v2-font-body: "SF Pro Text", -apple-system, BlinkMacSystemFont, Inter, system-ui, sans-serif;--v2-font-serif: "New York", Bookerly, ui-serif, Georgia, serif;--v2-font-mono: "SF Mono", ui-monospace, "JetBrains Mono", monospace;--v2-radius-xs: 4px;--v2-radius-sm: 8px;--v2-radius-md: 12px;--v2-radius-lg: 16px;--v2-radius-xl: 20px;--v2-radius-2xl: 24px;--v2-radius-3xl: 28px;--v2-radius-4xl: 32px;--v2-radius-full: 9999px;--v2-shadow-edge: inset 0 1px 0 rgba(255, 255, 255, .1);--v2-shadow-sm: 0 2px 8px -2px rgba(0, 0, 0, .2);--v2-shadow-md: 0 8px 24px -8px rgba(0, 0, 0, .35);--v2-shadow-lg: 0 20px 60px -12px rgba(0, 0, 0, .5);--v2-shadow-xl: 0 40px 96px -20px rgba(0, 0, 0, .65);--v2-glow-brand: 0 0 40px -8px rgba(61, 151, 232, .45);--v2-glow-success: 0 0 40px -8px rgba(74, 222, 128, .4);--v2-glow-danger: 0 0 40px -8px rgba(248, 113, 113, .4);--v2-ease-quick: cubic-bezier(.32, .72, 0, 1);--v2-ease-spring: cubic-bezier(.34, 1.56, .64, 1);--v2-ease-soft: cubic-bezier(.4, 0, .2, 1);--v2-ease-enter: cubic-bezier(.16, 1, .3, 1);--v2-dur-quick: .15s;--v2-dur-normal: .22s;--v2-dur-slow: .38s;--v2-dur-enter: .5s}.v2-glass-surface{background:#ffffff0a;backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px #ffffff14}.v2-glass-elevated{background:#ffffff14;backdrop-filter:blur(40px) saturate(180%);-webkit-backdrop-filter:blur(40px) saturate(180%);border:1px solid rgba(255,255,255,.12);box-shadow:inset 0 1px #ffffff26,0 24px 60px -20px #0009}.v2-glass-primary{background:#3d97e82e;backdrop-filter:blur(32px) saturate(180%);-webkit-backdrop-filter:blur(32px) saturate(180%);border:1px solid rgba(105,183,244,.3);box-shadow:inset 0 1px #fff3,0 0 0 1px #3d97e81a,0 8px 32px -8px #3d97e859}.v2-glass-success{background:#4ade8026;backdrop-filter:blur(32px) saturate(180%);-webkit-backdrop-filter:blur(32px) saturate(180%);border:1px solid rgba(74,222,128,.32);box-shadow:inset 0 1px #fff3,0 8px 32px -8px #4ade804d}.v2-glass-danger{background:#f8717124;backdrop-filter:blur(32px) saturate(180%);-webkit-backdrop-filter:blur(32px) saturate(180%);border:1px solid rgba(248,113,113,.3);box-shadow:inset 0 1px #ffffff2e,0 8px 32px -8px #f8717147}.v2-page-canvas{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;overflow:hidden;pointer-events:none;background:var(--v2-surface-canvas)}:where(html):has(.v2-page-canvas),:where(body):has(.v2-page-canvas){background:var(--v2-surface-canvas)}.v2-step-shell{overflow-x:hidden}.v2-step-shell>main>*{min-width:0}.v2-color-blob{position:absolute;border-radius:50%;filter:blur(120px);opacity:.5;pointer-events:none}.v2-noise-layer{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.025;pointer-events:none;background-image:radial-gradient(circle at 25% 25%,rgba(255,255,255,.4) .5px,transparent .5px),radial-gradient(circle at 75% 75%,rgba(255,255,255,.3) .5px,transparent .5px);background-size:4px 4px,6px 6px}@keyframes v2-page-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes v2-stagger-enter{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes v2-press{0%{transform:scale(1)}50%{transform:scale(.97)}to{transform:scale(1)}}@keyframes v2-pulse-ring{0%{transform:scale(1);opacity:.7}to{transform:scale(1.8);opacity:0}}@keyframes v2-correct-glow{0%{box-shadow:0 0 #4ade80b3}to{box-shadow:0 0 0 12px #4ade8000}}@keyframes v2-wrong-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes v2-checkmark-pop{0%{transform:scale(0) rotate(-20deg);opacity:0}50%{transform:scale(1.2) rotate(0);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}@keyframes v2-flame-pulse{0%,to{transform:scale(1);filter:drop-shadow(0 0 6px rgba(251,146,60,.5))}50%{transform:scale(1.1);filter:drop-shadow(0 0 14px rgba(251,146,60,.8))}}@keyframes v2-confetti-rise{0%{opacity:0;transform:translateY(20px) scale(.6)}20%{opacity:1}to{opacity:0;transform:translateY(-80px) scale(1)}}.v2-anim-page-enter{animation:v2-page-enter var(--v2-dur-enter) var(--v2-ease-enter) both}.v2-anim-stagger-enter{animation:v2-stagger-enter var(--v2-dur-slow) var(--v2-ease-enter) both}@keyframes v2-slide-from-right{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes v2-slide-from-left{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}.v2-anim-slide-from-right{animation:v2-slide-from-right .3s var(--v2-ease-enter) both}.v2-anim-slide-from-left{animation:v2-slide-from-left .3s var(--v2-ease-enter) both}@keyframes v2-pulse-ready{0%{box-shadow:inset 0 1px #ffffff40,0 0 #3d97e88c}50%{box-shadow:inset 0 1px #ffffff40,0 0 0 8px #3d97e800}to{box-shadow:inset 0 1px #ffffff40,0 8px 24px -8px #3d97e88c}}.v2-anim-pulse-ready{animation:v2-pulse-ready .9s ease-out 1}.v2-anim-correct{animation:v2-correct-glow .6s ease-out}.v2-anim-wrong{animation:v2-wrong-shake .32s var(--v2-ease-quick)}.v2-anim-checkmark{animation:v2-checkmark-pop .42s var(--v2-ease-spring) both}.v2-anim-flame-pulse{animation:v2-flame-pulse 1.8s ease-in-out infinite}.v2-anim-stagger-enter:nth-child(1){animation-delay:0ms}.v2-anim-stagger-enter:nth-child(2){animation-delay:40ms}.v2-anim-stagger-enter:nth-child(3){animation-delay:80ms}.v2-anim-stagger-enter:nth-child(4){animation-delay:.12s}.v2-anim-stagger-enter:nth-child(5){animation-delay:.16s}.v2-anim-stagger-enter:nth-child(6){animation-delay:.2s}.v2-anim-stagger-enter:nth-child(7){animation-delay:.24s}.v2-anim-stagger-enter:nth-child(8){animation-delay:.28s}.v2-anim-stagger-enter:nth-child(9){animation-delay:.32s}.v2-anim-stagger-enter:nth-child(10){animation-delay:.36s}.v2-pressable{transition:transform var(--v2-dur-quick) var(--v2-ease-quick),box-shadow var(--v2-dur-quick) var(--v2-ease-quick),background var(--v2-dur-quick) var(--v2-ease-quick),border-color var(--v2-dur-quick) var(--v2-ease-quick),opacity var(--v2-dur-quick) var(--v2-ease-quick);-webkit-user-select:none;user-select:none}.v2-pressable:hover{transform:translateY(-1px)}.v2-pressable:active{transform:scale(.97)}.v2-recording-pulse:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:#f871714d;animation:v2-pulse-ring 1.4s ease-out infinite;pointer-events:none}@media(prefers-reduced-motion:reduce){.v2-anim-page-enter,.v2-anim-stagger-enter,.v2-anim-slide-from-right,.v2-anim-slide-from-left,.v2-anim-pulse-ready,.v2-anim-correct,.v2-anim-wrong,.v2-anim-checkmark,.v2-anim-flame-pulse{animation:none!important}.v2-pressable{transition:opacity var(--v2-dur-quick) linear}.v2-pressable:hover,.v2-pressable:active{transform:none}.v2-recording-pulse:after{animation:none;opacity:.4}}@media(prefers-reduced-transparency:reduce){.v2-glass-surface{background:#161e33;backdrop-filter:none;-webkit-backdrop-filter:none}.v2-glass-elevated{background:#1f2940;backdrop-filter:none;-webkit-backdrop-filter:none}.v2-glass-primary{background:#1565b0;backdrop-filter:none;-webkit-backdrop-filter:none}.v2-glass-success{background:#166534;backdrop-filter:none;-webkit-backdrop-filter:none}.v2-glass-danger{background:#7f1d1d;backdrop-filter:none;-webkit-backdrop-filter:none}.v2-color-blob,.v2-noise-layer{display:none}}@supports not (backdrop-filter: blur(1px)){.v2-glass-surface{background:#161e33f2}.v2-glass-elevated{background:#1f2940f2}.v2-glass-primary{background:#1565b0f2}}.adm-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;display:flex;flex-direction:column;background:var(--page-bg, #01071C);color:var(--label, #fff);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px}.adm-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 20px;background:var(--g-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--g-border);flex-shrink:0;min-height:56px;max-height:64px}.adm-topbar-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.adm-topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.adm-topbar-icon{font-size:20px;line-height:1}.adm-topbar-title{font-size:16px;font-weight:700;color:var(--label);margin:0;white-space:nowrap}.adm-unsaved{font-size:12px;color:#f59e0b;background:#f59e0b1f;padding:4px 12px;border-radius:10px;font-weight:600;border:1px solid rgba(245,158,11,.2)}.adm-save-toast{font-size:12px;padding:4px 12px;border-radius:10px;font-weight:600;animation:adm-toast-in .3s ease-out}.adm-save-ok{color:#4ade80;background:#22c55e1f;border:1px solid rgba(34,197,94,.2)}.adm-save-err{color:#f87171;background:#ef44441f;border:1px solid rgba(239,68,68,.2)}@keyframes adm-toast-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.adm-body{display:flex;flex:1;overflow:hidden}.adm-sidebar{width:230px;flex-shrink:0;background:var(--g-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid var(--g-border);overflow-y:auto;padding:12px 8px}.adm-sidebar-group{margin-bottom:14px}.adm-sidebar-group:last-child{margin-bottom:0}.adm-sidebar-group .build-label{padding:4px 12px 6px;margin:0}.adm-mod-btn{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;background:transparent;border:1px solid transparent;border-radius:12px;color:var(--label2);cursor:pointer;text-align:left;font-size:13px;font-weight:500;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.adm-mod-btn:hover{background:var(--fill2);border-color:var(--g-border)}.adm-mod-btn.active{background:#0052a51f;border-color:var(--blue);color:var(--blue);font-weight:600;box-shadow:0 0 0 2px #0052a514}.adm-mod-btn.modified .adm-mod-name{font-weight:700}.adm-mod-btn.adm-mod-dashboard{margin-bottom:2px}.adm-mod-btn.adm-mod-dashboard.active{background:#0052a526;border-color:var(--blue);color:var(--blue)}.adm-mod-btn.adm-mod-suggestions{margin-bottom:4px}.adm-mod-btn.adm-mod-suggestions.active{background:#f59e0b1f;border-color:#f59e0b4d;color:#f59e0b}.adm-mod-icon{font-size:16px;flex-shrink:0}.adm-mod-name{flex:1}.adm-mod-count{font-size:11px;color:var(--label3);background:var(--fill2);padding:2px 7px;border-radius:6px;font-weight:600}.adm-mod-dot{color:#f59e0b;font-size:10px}.adm-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;min-height:0}.adm-toolbar{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--g-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--g-border);flex:0 0 auto;flex-wrap:wrap;min-height:0}.adm-search{flex:1;min-width:200px;padding:10px 14px;border-radius:12px;border:1.5px solid var(--g-border);background:var(--g-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);color:var(--label);font-size:13px;font-weight:500;outline:none;transition:all .2s ease}.adm-search:focus{border-color:var(--blue);box-shadow:0 0 0 3px #0052a51a}.adm-search::placeholder{color:var(--label3)}.adm-toolbar-actions{display:flex;gap:6px;margin-left:auto}.adm-content-area{display:flex;flex:1;overflow:hidden;min-height:0;position:relative}.adm-list{flex:1;overflow-y:auto;padding:10px;min-width:0;min-height:0;transition:flex .2s}.adm-list-narrow{border-right:1px solid var(--g-border)}.adm-list-header{font-size:12px;color:var(--label3);padding:4px 10px 10px;font-weight:600}.adm-list-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:12px;cursor:pointer;transition:all .15s ease;gap:8px;border:1px solid transparent;margin-bottom:2px}.adm-list-item:hover{background:var(--fill2);border-color:var(--g-border)}.adm-list-item.active{background:#0052a514;border-color:#0052a533}.adm-list-item-actions{display:flex;gap:2px;opacity:0;transition:opacity .15s;flex-shrink:0}.adm-list-item:hover .adm-list-item-actions{opacity:1}.adm-item-preview{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.adm-item-idx{font-size:11px;color:var(--label3);width:28px;text-align:right;flex-shrink:0;font-weight:600}.adm-item-info{flex:1;min-width:0}.adm-item-id{font-size:13px;font-weight:600;color:var(--label);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.adm-item-text{font-size:12px;color:var(--label3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.adm-pill{font-size:10px;padding:3px 9px;border-radius:8px;font-weight:600;flex-shrink:0}.adm-pill-level{background:#0052a51f;color:var(--blue);border:1px solid rgba(0,82,165,.2)}.adm-pill-type{background:#8b5cf61f;color:#a78bfa;border:1px solid rgba(139,92,246,.2)}.adm-editor{flex:0 0 40%;min-width:480px;max-width:720px;min-height:0;display:flex;flex-direction:column;overflow:hidden;background:var(--g-bg);border-left:1px solid var(--g-border)}.adm-editor-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--g-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--g-border);font-weight:600;font-size:13px;color:var(--label);flex-shrink:0;gap:8px;flex-wrap:wrap}.adm-editor-header>div{display:flex;gap:6px;flex-wrap:wrap}.adm-editor-body{flex:1;min-height:0;overflow-y:auto;padding:16px}@media(max-width:768px){.adm-editor{position:fixed;top:56px;right:0;bottom:0;left:0;flex:none;min-width:0;max-width:none;width:auto;z-index:100;background:var(--page-bg, #01071C);border-left:none;box-shadow:0 -4px 20px #0006}}.adm-field{margin-bottom:10px}.adm-field-key{display:block;font-size:11px;font-weight:700;color:var(--label3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.adm-input{width:100%;padding:8px 12px;border-radius:10px;border:1.5px solid var(--g-border);background:var(--g-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);color:var(--label);font-size:13px;font-weight:500;outline:none;box-sizing:border-box;transition:all .2s ease}.adm-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #0052a51a}.adm-textarea{width:100%;padding:10px 12px;border-radius:10px;border:1.5px solid var(--g-border);background:var(--g-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);color:var(--label);font-size:13px;font-weight:500;line-height:1.5;resize:vertical;outline:none;font-family:inherit;box-sizing:border-box;transition:all .2s ease}.adm-textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px #0052a51a}.adm-select{padding:8px 12px;border-radius:10px;border:1.5px solid var(--g-border);background:var(--g-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);color:var(--label);font-size:13px;font-weight:500;outline:none;transition:all .2s ease}.adm-select:focus{border-color:var(--blue);box-shadow:0 0 0 3px #0052a51a}.adm-badge{font-size:10px;color:var(--label3);font-weight:400}.adm-field-array{margin-bottom:14px}.adm-field-type{display:inline-block;margin-left:6px;padding:1px 6px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-radius:4px;background:var(--fill2);color:var(--label3);vertical-align:middle}.adm-field[data-fieldtype=string] .adm-input,.adm-field[data-fieldtype=string] .adm-textarea,.adm-field[data-fieldtype=number] .adm-input{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:13px}.adm-field[data-fieldtype=string]>.adm-field-key>.adm-field-type{background:#22c55e24;color:#4ade80}.adm-field[data-fieldtype=number]>.adm-field-key>.adm-field-type{background:#0052a524;color:var(--blue)}.adm-field[data-fieldtype=boolean]>.adm-field-key>.adm-field-type{background:#f59e0b24;color:#f59e0b}.adm-field[data-fieldtype=array]>.adm-field-key>.adm-field-type{background:#a855f724;color:#c084fc}.adm-field[data-fieldtype=object]>.adm-field-key>.adm-field-type{background:#f472b624;color:#f472b6}.adm-array-item{margin:6px 0;padding:12px;background:var(--fill2);border:1px solid var(--g-border);border-radius:12px}.adm-array-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.adm-array-idx{font-size:11px;color:var(--label3);font-weight:600;flex-shrink:0;width:30px}.adm-array-item-inline{display:flex;align-items:center;gap:6px;margin:4px 0}.adm-array-item-inline .adm-input{flex:1}.adm-btn{padding:8px 16px;border-radius:10px;border:1px solid var(--g-border);background:var(--g-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);color:var(--label2);font-size:12px;cursor:pointer;font-weight:600;transition:all .2s ease;white-space:nowrap}.adm-btn:hover{background:var(--fill2);border-color:var(--blue);transform:translateY(-1px)}.adm-btn-save{background:linear-gradient(135deg,#166534,#15803d);border-color:#22c55e;color:#86efac}.adm-btn-save:hover{box-shadow:0 4px 12px #22c55e33}.adm-btn-create{background:linear-gradient(135deg,var(--blue),#2563eb);border-color:transparent;color:#fff}.adm-btn-create:hover{box-shadow:0 4px 12px #3b82f64d}.adm-btn-close{background:#ef44441f;border-color:#ef444440;color:#f87171}.adm-btn-close:hover{background:#ef444433}.adm-btn-sm{padding:4px 8px;border-radius:8px;border:1px solid var(--g-border);background:transparent;color:var(--label3);font-size:11px;cursor:pointer;transition:all .15s ease}.adm-btn-sm:hover{background:var(--fill2);color:var(--label)}.adm-btn-danger{color:#f87171}.adm-btn-danger:hover{background:#ef44441f}.adm-btn-add{color:var(--blue);border-color:#0052a533;margin-top:6px}.adm-btn-add:hover{background:#0052a514}.adm-empty{text-align:center;color:var(--label3);padding:40px 16px;font-size:14px}.adm-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100000;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center}.adm-modal{width:90%;max-width:900px;max-height:85vh;display:flex;flex-direction:column;background:var(--g-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:20px;border:1px solid var(--g-border);overflow:hidden;box-shadow:0 24px 48px #0003}.adm-modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--g-border);font-weight:600;color:var(--label)}.adm-modal-footer{display:flex;gap:8px;justify-content:flex-end;padding:14px 18px;border-top:1px solid var(--g-border)}.adm-json-editor{flex:1;padding:16px;background:var(--fill2);color:var(--blue);border:none;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:12px;line-height:1.5;resize:none;outline:none;min-height:400px}.adm-suggestions{flex:1;overflow-y:auto;padding:16px}.adm-sug-tabs{display:flex;gap:8px;margin-bottom:16px;align-items:center}.adm-sug-tab{padding:8px 16px;border-radius:12px;border:1px solid var(--g-border);background:var(--g-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);color:var(--label2);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.adm-sug-tab:hover{border-color:var(--blue)}.adm-sug-tab.active{box-shadow:0 0 0 2px #0052a514}.adm-sug-count{font-size:11px;background:var(--fill2);padding:2px 7px;border-radius:6px}.adm-sug-refresh{background:none;border:none;font-size:16px;cursor:pointer;padding:6px;border-radius:8px;transition:all .2s ease;margin-left:auto}.adm-sug-refresh:hover{background:var(--fill2);transform:rotate(90deg)}.adm-sug-loading,.adm-sug-empty{text-align:center;color:var(--label3);padding:40px 16px;font-size:14px}.adm-sug-error{color:var(--red);background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:12px;padding:10px 14px;font-size:13px;margin-bottom:12px}.adm-sug-list{display:flex;flex-direction:column;gap:10px}.adm-sug-card{background:var(--g-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--g-border);border-radius:16px;padding:16px;transition:all .2s ease}.adm-sug-card:hover{border-color:var(--blue);box-shadow:0 4px 12px #0052a514}.adm-sug-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;flex-wrap:wrap;gap:8px}.adm-sug-meta{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.adm-sug-module{font-size:11px;font-weight:700;text-transform:uppercase;background:#0052a51f;color:var(--blue);padding:3px 9px;border-radius:8px}.adm-sug-id{font-size:11px;font-weight:600;color:var(--label3);background:var(--fill2);padding:3px 8px;border-radius:6px}.adm-sug-field{font-size:11px;font-weight:600;color:#a78bfa;background:#8b5cf61f;padding:3px 8px;border-radius:6px}.adm-sug-reviewer{font-size:12px;color:var(--label3);display:flex;align-items:center;gap:8px}.adm-sug-date{font-size:11px;color:var(--label3);opacity:.7}.adm-sug-diff{display:flex;gap:12px;align-items:stretch;margin-bottom:10px}.adm-sug-diff-col{flex:1;border-radius:12px;padding:10px 12px}.adm-sug-original{background:#ef44440f;border:1px solid rgba(239,68,68,.15)}.adm-sug-suggested{background:#22c55e0f;border:1px solid rgba(34,197,94,.15)}.adm-sug-diff-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.adm-sug-original .adm-sug-diff-label{color:#f87171}.adm-sug-suggested .adm-sug-diff-label{color:#4ade80}.adm-sug-diff-removed{background:#ef44442e;color:#fca5a5;border-radius:3px;padding:0 2px;text-decoration:line-through;text-decoration-color:#ef444480}.adm-sug-diff-added{background:#22c55e2e;color:#86efac;border-radius:3px;padding:0 2px;font-weight:600}.adm-sug-diff-value{font-size:13px;color:var(--label);word-break:break-word;line-height:1.5}.adm-sug-diff-arrow{display:flex;align-items:center;color:var(--label3);font-size:16px;flex-shrink:0}.adm-sug-reason{font-size:12px;color:var(--label2);background:var(--fill2);padding:8px 12px;border-radius:10px;margin-bottom:8px}.adm-sug-admin-note{font-size:12px;color:var(--blue);background:#0052a514;padding:8px 12px;border-radius:10px;margin-bottom:8px}.adm-sug-actions{display:flex;gap:8px;margin-top:4px}.adm-sug-btn{padding:8px 16px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.adm-sug-btn-approve{background:linear-gradient(135deg,#166534,#15803d);color:#86efac;box-shadow:0 2px 8px #22c55e26}.adm-sug-btn-approve:hover{box-shadow:0 4px 12px #22c55e40;transform:translateY(-1px)}.adm-sug-btn-reject{background:#ef44441f;color:#f87171;border:1px solid rgba(239,68,68,.2)}.adm-sug-btn-reject:hover{background:#ef444433}@media(max-width:768px){.adm-sug-diff{flex-direction:column}.adm-sug-diff-arrow{transform:rotate(90deg);justify-content:center}}.adm-dash{flex:1;overflow-y:auto;padding:20px}.adm-dash-loading,.adm-dash-empty{text-align:center;color:var(--label3);padding:60px 20px;font-size:14px}.adm-dash-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.adm-dash-kpi{background:var(--g-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--g-border);border-radius:16px;padding:18px 16px;text-align:center;transition:all .2s ease;cursor:default;display:flex;flex-direction:column;align-items:center;gap:4px}button.adm-dash-kpi{cursor:pointer;font-family:inherit}button.adm-dash-kpi:hover{border-color:var(--blue);box-shadow:0 4px 12px #0052a51f;transform:translateY(-2px)}.adm-dash-kpi-value{font-size:28px;font-weight:800;color:var(--label);line-height:1.1}.adm-kpi-warn{color:#f59e0b}.adm-kpi-blue{color:var(--blue)}.adm-kpi-green{color:#4ade80}.adm-kpi-danger{color:#f87171}.adm-dash-band{margin-bottom:24px}.adm-dash-band:last-child{margin-bottom:0}.adm-dash-band>.build-label{margin-bottom:12px}.adm-dash-quick{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;margin-bottom:14px}.adm-dash-quick-cta{display:flex;align-items:center;gap:10px;padding:14px 16px;background:var(--g-bg);border:1px solid var(--g-border);border-radius:14px;color:var(--label);font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.adm-dash-quick-cta:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:0 4px 12px #0052a51f}.adm-dash-quick-icon{font-size:20px}.adm-dash-quick-label{flex:1;text-align:left}.adm-dash-quick-arrow{color:var(--label3);font-size:16px}.adm-dash-health-head,.adm-dash-health-row{display:grid;grid-template-columns:1fr 110px 110px;align-items:center;gap:12px;padding:8px 10px}.adm-dash-health-head{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--label3);border-bottom:1px solid var(--sep)}.adm-dash-health-row{background:transparent;border:1px solid transparent;border-radius:8px;font-family:inherit;font-size:13px;color:var(--label);cursor:pointer;transition:all .15s ease}.adm-dash-health-row:hover{background:var(--fill2);border-color:var(--g-border)}.adm-dash-health-num{text-align:center;font-weight:600}.adm-dash-health-warn{color:#f59e0b}.adm-dash-health-icon{margin-right:4px}button.adm-dash-feed-item{background:transparent;border:none;width:100%;text-align:left;font-family:inherit;cursor:pointer}button.adm-dash-feed-item:hover{background:var(--fill2)}.adm-dash-kpi-label{font-size:12px;font-weight:600;color:var(--label2)}.adm-dash-kpi-sub{font-size:11px;color:var(--label3)}.adm-dash-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px}.adm-dash-card{background:var(--g-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--g-border);border-radius:16px;padding:18px}.adm-dash-card-title{font-size:14px;font-weight:700;color:var(--label);margin-bottom:2px}.adm-dash-card-sub{font-size:11px;color:var(--label3);margin-bottom:14px}.adm-dash-empty-small{font-size:12px;color:var(--label3);text-align:center;padding:16px}.adm-dash-bars{display:flex;flex-direction:column;gap:6px}.adm-dash-bar-row{display:flex;align-items:center;gap:10px;background:none;border:none;padding:4px 0;cursor:pointer;width:100%;font-family:inherit;transition:opacity .15s}.adm-dash-bar-row:hover{opacity:.8}.adm-dash-bar-label{font-size:12px;font-weight:600;color:var(--label2);width:90px;text-align:right;flex-shrink:0}.adm-dash-bar-track{flex:1;height:8px;background:var(--fill2);border-radius:4px;overflow:hidden}.adm-dash-bar-fill{height:100%;background:linear-gradient(135deg,var(--blue),#2563eb);border-radius:4px;transition:width .5s ease-out}.adm-dash-bar-count{font-size:12px;font-weight:700;color:var(--label);width:30px;flex-shrink:0}.adm-dash-reviewer-list{display:flex;flex-direction:column;gap:8px}.adm-dash-reviewer{display:flex;align-items:center;gap:8px}.adm-dash-rank{font-size:11px;font-weight:700;color:var(--blue);width:24px}.adm-dash-reviewer-email{flex:1;font-size:12px;color:var(--label2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.adm-dash-reviewer-count{font-size:11px;font-weight:600;color:var(--label3);background:var(--fill2);padding:2px 8px;border-radius:6px}.adm-dash-override-chips{display:flex;flex-wrap:wrap;gap:6px}.adm-dash-chip{padding:6px 12px;border-radius:10px;border:1px solid var(--g-border);background:var(--fill2);color:var(--label2);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px;font-family:inherit}.adm-dash-chip:hover{border-color:var(--blue);background:#0052a514}.adm-dash-chip-count{background:#0052a526;color:var(--blue);padding:1px 6px;border-radius:6px;font-size:11px}.adm-dash-feed{display:flex;flex-direction:column;gap:8px}.adm-dash-feed-item{display:flex;align-items:flex-start;gap:8px;padding:6px 0;border-bottom:1px solid var(--fill2)}.adm-dash-feed-item:last-child{border-bottom:none}.adm-dash-feed-icon{font-size:14px;flex-shrink:0;margin-top:1px}.adm-dash-feed-info{flex:1;min-width:0}.adm-dash-feed-main{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.adm-dash-feed-module{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--blue);background:#0052a51a;padding:2px 7px;border-radius:6px}.adm-dash-feed-field{font-size:11px;color:var(--label3)}.adm-dash-feed-meta{font-size:11px;color:var(--label3);margin-top:2px}@media(max-width:700px){.adm-dash-kpis{grid-template-columns:repeat(2,1fr)}.adm-dash-grid{grid-template-columns:1fr}}.adm-team{padding:20px;max-width:1100px;display:flex;flex-direction:column;gap:16px}.adm-team-hero{padding:20px 24px 14px;text-align:left}.adm-team-hero-title{margin:0}.adm-team-hero-sub{font-size:14px;color:var(--label2);margin:6px 0 0}.adm-team-invite-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.adm-team-invite-form .adm-input{flex:1;min-width:220px}.adm-team-msg{margin-top:10px;padding:8px 12px;border-radius:8px;font-size:13px}.adm-team-msg-ok{background:#22c55e24;color:#4ade80}.adm-team-msg-err{background:#ef444424;color:#fca5a5}.adm-team-filter-row{display:flex;gap:6px}.adm-team-filter-btn{padding:7px 14px;border-radius:8px;border:1px solid var(--g-border);background:transparent;color:var(--label2);font-size:13px;font-family:inherit;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:8px}.adm-team-filter-btn:hover{background:var(--fill2)}.adm-team-filter-btn.active{background:var(--blue);color:#fff;border-color:transparent}.adm-team-filter-count{font-size:11px;padding:1px 7px;border-radius:10px;background:#ffffff1f;font-weight:700}.adm-team-state{padding:48px 24px;text-align:center;color:var(--label3);font-size:14px}.adm-team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:12px}.adm-team-card{display:grid;grid-template-columns:44px 1fr auto;gap:14px;align-items:start}.adm-team-avatar{width:42px;height:42px;border-radius:50%;overflow:hidden;background:var(--blue);color:#fff;font-weight:700;font-size:18px;display:flex;align-items:center;justify-content:center}.adm-team-avatar img{width:100%;height:100%;object-fit:cover}.adm-team-info{min-width:0}.adm-team-name{font-size:14px;font-weight:600;color:var(--label);display:flex;align-items:center;gap:8px}.adm-team-you{font-size:10px;padding:2px 7px;border-radius:6px;background:var(--blue);color:#fff;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.adm-team-email{font-size:12px;color:var(--label2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.adm-team-meta{font-size:11px;color:var(--label3);margin-top:2px}.adm-team-stats{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.adm-team-stat{font-size:11px;padding:2px 8px;border-radius:6px;background:var(--fill2);color:var(--label2)}.adm-team-stat-ok{color:#4ade80;background:#22c55e1f}.adm-team-stat-warn{color:#f59e0b;background:#f59e0b1f}.adm-team-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.adm-team-segmented{display:inline-flex;background:var(--fill2);border:1px solid var(--g-border);border-radius:10px;padding:2px}.adm-team-seg-btn{padding:5px 12px;border:none;background:transparent;color:var(--label2);font-size:12px;font-weight:600;font-family:inherit;border-radius:8px;cursor:pointer;transition:all .15s}.adm-team-seg-btn:hover:not(.active):not(:disabled){background:#ffffff0d}.adm-team-seg-btn.active{background:var(--blue);color:#fff}.adm-team-seg-btn:disabled{opacity:.5;cursor:not-allowed}.adm-team-remove{padding:4px 8px}.cv-panel{padding:24px;max-width:1000px}.cv-header{margin-bottom:20px}.cv-title{font-size:22px;font-weight:700;color:var(--label, #fff);margin:0 0 4px}.cv-subtitle{font-size:13px;color:var(--label3, #8899aa);margin:0}.cv-run-row{display:flex;align-items:center;gap:12px;margin-bottom:20px}.cv-run-btn{padding:10px 24px;border-radius:10px;border:none;background:var(--blue, #4A90D9);color:#fff;font-weight:600;font-size:14px;cursor:pointer;transition:opacity .2s}.cv-run-btn:hover{opacity:.85}.cv-run-btn:disabled{opacity:.5;cursor:not-allowed}.cv-status{font-size:13px;color:var(--label3, #8899aa)}.cv-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-bottom:24px}.cv-summary-card{background:var(--g-bg, rgba(255,255,255,.06));border:1px solid var(--g-border, rgba(255,255,255,.08));border-radius:12px;padding:14px 16px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:pointer;transition:border-color .15s}.cv-summary-card:hover{border-color:#ffffff26}.cv-summary-card.has-issues{border-left:3px solid #f59e0b}.cv-summary-card.clean{border-left:3px solid #22c55e}.cv-summary-module{font-size:13px;font-weight:600;color:var(--label, #fff);margin-bottom:4px}.cv-summary-count{font-size:12px;color:var(--label3, #8899aa)}.cv-summary-count.issues{color:#f59e0b}.cv-summary-count.clean{color:#22c55e}.cv-issues-section{margin-top:16px}.cv-issues-title{font-size:15px;font-weight:600;color:var(--label, #fff);margin:0 0 12px}.cv-issue-list{display:flex;flex-direction:column;gap:6px}.cv-issue{display:flex;align-items:flex-start;gap:12px;padding:10px 14px;background:var(--g-bg, rgba(255,255,255,.04));border:1px solid var(--g-border, rgba(255,255,255,.06));border-radius:10px;cursor:pointer;transition:border-color .15s}.cv-issue:hover{border-color:#ffffff1f}.cv-issue-sev{font-size:11px;padding:3px 8px;border-radius:6px;font-weight:600;flex-shrink:0}.cv-issue-sev.error{background:#ef444426;color:#ef4444}.cv-issue-sev.warning{background:#f59e0b26;color:#f59e0b}.cv-issue-sev.info{background:#3b82f626;color:#3b82f6}.cv-issue-body{flex:1;min-width:0}.cv-issue-msg{font-size:13px;color:var(--label, #fff)}.cv-issue-loc{font-size:11px;color:var(--label3, #8899aa);margin-top:2px}.cv-empty{padding:48px 24px;text-align:center;color:var(--label3, #8899aa);font-size:14px}.adm-diff-toggle{padding:6px 14px;border-radius:8px;border:1px solid var(--g-border, rgba(255,255,255,.1));background:transparent;color:var(--label2, #aab);font-size:12px;cursor:pointer;transition:all .15s;margin-left:8px}.adm-diff-toggle.active{background:var(--blue, #4A90D9);color:#fff;border-color:transparent}.adm-diff-panel{padding:16px;border-bottom:1px solid var(--g-border, rgba(255,255,255,.08));max-height:300px;overflow-y:auto}.adm-diff-row{display:flex;gap:2px;margin-bottom:4px;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:12px;line-height:1.5}.adm-diff-key{color:var(--label2, #aab);min-width:140px;flex-shrink:0;padding:2px 8px;border-radius:4px}.adm-diff-old{flex:1;padding:2px 8px;border-radius:4px;background:#ef44441a;color:#fca5a5;text-decoration:line-through;word-break:break-word}.adm-diff-new{flex:1;padding:2px 8px;border-radius:4px;background:#22c55e1a;color:#86efac;word-break:break-word}.adm-diff-arrow{color:var(--label3, #8899aa);padding:2px 6px;flex-shrink:0}.adm-diff-empty{padding:12px;text-align:center;color:var(--label3, #8899aa);font-size:13px}.adm-bulk-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--blue, #4A90D9);border-radius:10px;margin-bottom:10px;animation:adm-fade-in .2s ease}.adm-bulk-count{font-size:13px;font-weight:600;color:#fff}.adm-bulk-actions{display:flex;gap:6px;margin-left:auto}.adm-bulk-btn{padding:6px 14px;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s}.adm-bulk-btn:hover{background:#fff3}.adm-bulk-btn.danger{border-color:#ef444466;color:#fca5a5}.adm-bulk-btn.danger:hover{background:#ef444433}.adm-bulk-clear{padding:6px 10px;border:none;background:transparent;color:#ffffffb3;cursor:pointer;font-size:12px}.adm-bulk-clear:hover{color:#fff}.adm-bulk-check{width:18px;height:18px;border-radius:5px;border:2px solid var(--g-border, rgba(255,255,255,.15));background:transparent;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s;margin-right:6px;color:transparent;font-size:12px}.adm-bulk-check.checked{background:var(--blue, #4A90D9);border-color:var(--blue, #4A90D9);color:#fff}@keyframes adm-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.admin-shell{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background:var(--page-bg, #01071C);color:var(--label, #fff);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;z-index:1000}.admin-shell-topbar{display:flex;align-items:center;gap:16px;padding:8px 16px;background:var(--g-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--g-border);flex-shrink:0;min-height:52px;max-height:64px}.admin-shell-brand{display:flex;align-items:center;gap:8px;flex-shrink:0}.admin-shell-brand-icon{font-size:20px;line-height:1}.admin-shell-brand-text{font-size:15px;font-weight:700;color:var(--label);white-space:nowrap}.admin-shell-nav{display:flex;align-items:center;gap:4px;flex:1;min-width:0;overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--g-border) transparent;padding:0 8px}.admin-shell-nav::-webkit-scrollbar{height:4px}.admin-shell-nav::-webkit-scrollbar-thumb{background:var(--g-border);border-radius:2px}.admin-shell-nav-pill{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:999px;border:1px solid transparent;background:transparent;color:var(--label2);font-size:12px;font-weight:600;font-family:inherit;text-decoration:none;cursor:pointer;white-space:nowrap;transition:all .15s ease;flex-shrink:0}.admin-shell-nav-pill:hover{background:var(--fill2);color:var(--label)}.admin-shell-nav-pill.is-active{background:#0052a529;border-color:var(--blue);color:var(--blue)}.admin-shell-nav-icon{font-size:13px;line-height:1}.admin-shell-nav-label{font-size:12px}.admin-shell-nav-divider{display:inline-block;width:1px;height:18px;background:var(--g-border);margin:0 6px;flex-shrink:0}.admin-shell-nav-gap{display:inline-block;width:12px;flex-shrink:0}.admin-shell-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.admin-shell-main{flex:1;min-height:0;min-width:0;overflow:hidden;display:flex;flex-direction:column}.adm-root-embedded{flex:1;min-height:0;display:flex;flex-direction:column;background:transparent;color:var(--label)}.adm-root-embedded>.adm-body{flex:1;min-height:0}.adm-embedded-statusbar{display:flex;align-items:center;gap:10px;padding:6px 16px;background:var(--fill2);border-bottom:1px solid var(--g-border);flex-shrink:0;font-size:12px}.admin-table{flex:1;min-height:0;display:flex;flex-direction:column;outline:none}.admin-table:focus-visible{outline:2px solid var(--blue);outline-offset:-2px}.admin-table-toolbar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--g-bg);border-bottom:1px solid var(--g-border);flex:0 0 auto}.admin-table-search{flex:1;min-width:200px;padding:8px 14px;border-radius:10px;border:1px solid var(--g-border);background:var(--fill2);color:var(--label);font-size:13px;font-family:inherit;outline:none;transition:border-color .15s}.admin-table-search:focus{border-color:var(--blue);box-shadow:0 0 0 3px #0052a51a}.admin-table-search::placeholder{color:var(--label3)}.admin-table-toolbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.admin-table-toolbar-hint{font-size:11px;color:var(--label3)}.admin-table-filters{display:flex;flex-wrap:wrap;align-items:center;gap:4px;padding:6px 16px;background:var(--g-bg);border-bottom:1px solid var(--g-border);position:sticky;top:0;z-index:2;flex:0 0 auto}.admin-table-filters-group-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--label3);margin-right:4px}.admin-table-filters-divider{display:inline-block;width:1px;height:16px;background:var(--g-border);margin:0 6px}.admin-table-chip{display:inline-flex;align-items:center;padding:2px 10px;height:22px;border-radius:999px;border:1px solid var(--g-border);background:transparent;color:var(--label2);font-size:11px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s ease;white-space:nowrap}.admin-table-chip:hover{background:var(--fill2);color:var(--label)}.admin-table-chip.is-active{background:#0052a529;border-color:var(--blue);color:var(--blue)}.admin-table-header{display:grid;align-items:center;gap:12px;padding:8px 16px;background:var(--g-bg);border-bottom:1px solid var(--g-border);position:sticky;top:38px;z-index:1;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--label3);flex:0 0 auto}.admin-table-header-cell{text-align:left;background:none;border:none;color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;text-transform:inherit;letter-spacing:inherit;padding:0;cursor:default}.admin-table-header-cell.is-sortable{cursor:pointer;color:var(--label2)}.admin-table-header-cell.is-sortable:hover{color:var(--label)}.admin-table-header-cell[data-align=right]{text-align:right}.admin-table-header-cell[data-align=center]{text-align:center}.admin-table-body{flex:1;min-height:0;overflow-y:auto;contain:content}.admin-table-row{display:grid;align-items:center;gap:12px;padding:8px 16px;border-bottom:1px solid var(--sep);cursor:pointer;transition:background .1s;font-size:13px;min-height:56px}.admin-table-row:hover{background:var(--fill2)}.admin-table-row.is-focused{background:#0052a514}.admin-table-row.is-selected{background:#0052a51f}.admin-table-cell{min-width:0;overflow:hidden}.admin-table-cell[data-align=right]{text-align:right}.admin-table-cell[data-align=center]{text-align:center}.admin-table-cell-id{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:12px;color:var(--label2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.admin-table-cell-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;color:var(--label)}.admin-table-cell-bilingual{display:flex;flex-direction:column;gap:1px;min-width:0}.admin-table-cell-bilingual-fi{font-size:13px;font-weight:600;color:var(--label);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-table-cell-bilingual-en{font-size:11px;color:var(--label2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-table-cell-dots{display:inline-flex;align-items:center;gap:5px}.admin-table-dot{width:8px;height:8px;border-radius:50%;display:inline-block;background:var(--g-border);flex-shrink:0}.admin-table-dot.is-populated{background:var(--blue)}.admin-table-dot.is-empty{background:var(--fill2);border:1px solid var(--g-border)}.admin-table-status{display:inline-block;padding:1px 8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-radius:8px;background:var(--fill2);color:var(--label2)}.admin-table-status-published{background:#22c55e24;color:#4ade80}.admin-table-status-draft{background:#f59e0b24;color:#f59e0b}.admin-table-checkbox{width:20px;height:20px;border-radius:6px;border:1.5px solid var(--g-border);background:transparent;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;color:transparent;transition:all .12s ease;padding:0}.admin-table-checkbox:hover{border-color:var(--blue)}.admin-table-checkbox.is-checked{background:var(--blue);border-color:var(--blue);color:#fff}.admin-table-empty{padding:32px;text-align:center;color:var(--label3);font-size:13px}.admin-table-footer{padding:6px 16px;font-size:11px;color:var(--label3);border-top:1px solid var(--g-border);background:var(--g-bg);flex:0 0 auto}.admin-full{display:flex;flex-direction:column;height:100%;min-height:0;background:var(--bg)}.admin-full-breadcrumb{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--g-bg);border-bottom:1px solid var(--g-border);font-size:13px;flex:0 0 auto}.admin-full-back{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;color:var(--accent);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;padding:2px 6px;border-radius:6px}.admin-full-back:hover{background:var(--fill2)}.admin-full-breadcrumb-sep{color:var(--label3)}.admin-full-breadcrumb-title{color:var(--label);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.admin-full-position{margin-left:10px;padding:2px 8px;border-radius:999px;background:var(--fill2);color:var(--label2);font-size:11px;font-weight:500;flex:0 0 auto}.admin-full-breadcrumb-spacer{flex:1}.admin-full-nav-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:28px;height:28px;border-radius:8px;border:1px solid var(--g-border);background:var(--fill1);color:var(--label);font-family:inherit;font-size:15px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.admin-full-nav-btn:hover:not(:disabled){background:var(--fill2)}.admin-full-nav-btn:disabled{opacity:.4;cursor:not-allowed}.admin-full-tabs{position:sticky;top:46px;z-index:4;display:flex;gap:2px;padding:6px 16px;background:var(--bg);border-bottom:1px solid var(--g-border);overflow-x:auto;flex:0 0 auto}.admin-full-tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:1px solid transparent;border-radius:8px;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:500;color:var(--label2);cursor:pointer;white-space:nowrap}.admin-full-tab:hover{background:var(--fill2)}.admin-full-tab.is-active{background:var(--accent-light, var(--fill2));border-color:var(--accent);color:var(--accent);font-weight:600}.admin-full-body{flex:1;min-height:0;overflow-y:auto;padding:16px 16px 80px}.admin-full-meta{margin-bottom:24px;padding:12px 14px;background:var(--fill1);border:1px solid var(--g-border);border-radius:10px;display:flex;flex-direction:column;gap:10px}.admin-full-actionbar{position:sticky;bottom:0;z-index:5;display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--g-bg);border-top:1px solid var(--g-border);font-size:12px;flex:0 0 auto}.admin-full-actionbar-spacer{flex:1}.admin-full-dirty{color:var(--label2);font-size:12px}.admin-full-error{color:var(--danger, #e53935);font-size:12px;font-weight:500}.admin-full-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:8px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--g-border);background:var(--fill1);color:var(--label)}.admin-full-btn:hover:not(:disabled){background:var(--fill2)}.admin-full-btn:disabled{opacity:.45;cursor:not-allowed}.admin-full-btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.admin-full-btn-primary:hover:not(:disabled){background:var(--accent);filter:brightness(.95)}.admin-full-btn-secondary{background:var(--fill1)}.admin-full-empty{padding:48px 24px;text-align:center;color:var(--label2);font-size:13px}.admin-field{display:flex;flex-direction:column;gap:4px;font-size:12px;min-width:0}.admin-field-label{font-size:11px;font-weight:600;color:var(--label2);text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center;gap:4px}.admin-field-required{color:var(--danger, #e53935)}.admin-field-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--g-border);background:var(--fill1);color:var(--label);padding:6px 10px;font-family:inherit;font-size:13px;border-radius:8px;width:100%;box-sizing:border-box}.admin-field-input:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:transparent}.admin-field-textarea{font-family:inherit;line-height:1.45;resize:vertical;min-height:60px}.admin-field-json{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.admin-field-select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.admin-field-inline{display:flex;align-items:center;gap:6px}.admin-field-suffix{color:var(--label3);font-size:11px;font-variant-numeric:tabular-nums}.admin-field-hint{color:var(--label3);font-size:11px}.admin-field-error{color:var(--danger, #e53935);font-size:11px;font-weight:500}.admin-field.has-error .admin-field-input{border-color:var(--danger, #e53935)}.admin-field-bilingual{display:flex;flex-direction:column;gap:4px}.admin-field-bilingual-row{display:flex;align-items:stretch;gap:6px}.admin-field-bilingual-tag{display:inline-flex;align-items:center;justify-content:center;min-width:28px;padding:0 6px;font-size:10px;font-weight:700;letter-spacing:.06em;color:var(--label2);background:var(--fill2);border-radius:6px}.admin-field-tags{display:flex;flex-wrap:wrap;gap:4px;padding:4px;border:1px solid var(--g-border);background:var(--fill1);border-radius:8px;min-height:32px}.admin-field-tag{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;background:var(--fill2);border-radius:12px;font-size:11px;color:var(--label)}.admin-field-tag-x{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;color:var(--label3);cursor:pointer;font-size:13px;line-height:1;padding:0}.admin-field-tag-x:hover{color:var(--danger, #e53935)}.admin-field-tag-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;color:var(--label);font-family:inherit;font-size:12px;outline:none;min-width:80px;flex:1;padding:2px 4px}.admin-field-group{display:flex;flex-direction:column;gap:6px}.admin-field-group-title{font-size:11px;font-weight:700;color:var(--label3);text-transform:uppercase;letter-spacing:.06em}.admin-field-group-body{display:flex;gap:12px;flex-wrap:wrap}.admin-field-group-row .admin-field-group-body>*{flex:1 1 220px;min-width:220px}.admin-field-group-stack .admin-field-group-body{flex-direction:column}.admin-section-accordion{display:flex;flex-direction:column;gap:16px}.admin-section{border:1px solid var(--g-border);border-radius:10px;background:var(--fill1);scroll-margin-top:110px}.admin-section-header{border-bottom:1px solid var(--g-border);padding:6px 12px;display:flex;align-items:center}.admin-section.is-collapsed .admin-section-header{border-bottom:none}.admin-section-toggle{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;color:var(--label);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px;padding:4px 0;width:100%;text-align:left}.admin-section-chevron{color:var(--label3);font-size:10px;width:12px}.admin-section-icon{font-size:14px}.admin-section-label{flex:1}.admin-section-dot{width:8px;height:8px;border-radius:50%}.admin-section-dot.is-populated{background:#4ade80}.admin-section-dot.is-empty{background:transparent;border:1px solid var(--g-border)}.admin-section-body{padding:12px 14px;display:flex;flex-direction:column;gap:12px}.admin-vocab-morph{border:1px solid var(--g-border);border-radius:10px;padding:10px 12px;background:var(--fill1);display:flex;flex-direction:column;gap:8px}.admin-vocab-morph-header{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--label)}.admin-vocab-morph-title{text-transform:uppercase;letter-spacing:.04em;font-size:11px;color:var(--label2)}.admin-vocab-morph-pill{display:inline-flex;align-items:center;padding:1px 8px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.admin-vocab-morph-populated{background:#4ade8026;color:#16a34a}.admin-vocab-morph-missing{background:var(--fill2);color:var(--label3)}.admin-vocab-morph-partial{background:#f59e0b26;color:#c2710c}.admin-vocab-morph-source{color:var(--label3);font-size:11px;font-weight:500}.admin-vocab-morph-btn{margin-left:auto;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--g-border);background:var(--fill2);color:var(--label2);padding:3px 10px;border-radius:8px;font-family:inherit;font-size:11px;font-weight:600;cursor:pointer}.admin-vocab-morph-btn:disabled{opacity:.5;cursor:not-allowed}.admin-vocab-morph-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:4px 16px}.admin-vocab-morph-row{display:flex;align-items:baseline;gap:8px;padding:2px 0;border-bottom:1px dashed var(--g-border);font-size:12px}.admin-vocab-morph-slot{color:var(--label3);font-size:11px;flex:0 0 auto;min-width:96px}.admin-vocab-morph-val{color:var(--label);font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.admin-vocab-morph-val.is-empty{color:var(--label3);font-style:italic}.admin-vocab-morph-empty{color:var(--label3);font-size:12px;padding:6px 0;font-style:italic}
