:root{color:#14201b;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f3f7ef;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button:focus-visible{outline-offset:2px;outline:3px solid #f0b23d}.app-shell{color:#152016;background:radial-gradient(circle at 8% 10%,#ffde596b,#0000 26%),radial-gradient(circle at 92% 4%,#37b96c61,#0000 28%),linear-gradient(135deg,#effceb 0%,#fff8dc 48%,#e8f6ff 100%);min-height:100vh;padding:28px;position:relative;overflow-x:hidden}.app-shell:before{content:"";pointer-events:none;background-image:linear-gradient(90deg,#1520160b 1px,#0000 1px),linear-gradient(#1520160b 1px,#0000 1px);background-size:42px 42px;position:fixed;inset:0;-webkit-mask-image:linear-gradient(#000,#0000 72%);mask-image:linear-gradient(#000,#0000 72%)}.topbar,.progress-track,.reward-strip,.learning-grid{z-index:1;position:relative}.topbar{justify-content:space-between;align-items:end;gap:24px;max-width:1180px;margin:0 auto 16px;display:flex}.eyebrow{color:#207243;letter-spacing:.12em;text-transform:uppercase;background:#fff;border:2px solid #2072432e;border-radius:999px;margin:0 0 10px;padding:7px 12px;font-size:.78rem;font-weight:950;display:inline-flex;box-shadow:0 5px #20724329}.eyebrow.mini{width:fit-content;margin-bottom:12px;padding:5px 10px;font-size:.68rem;box-shadow:0 4px #2072431f}h1,h2,h3,p{margin:0}h1{letter-spacing:0;text-wrap:balance;max-width:680px;font-size:clamp(2.3rem,4.5vw,4.7rem);line-height:.92}.stats{flex-wrap:wrap;justify-content:end;gap:10px;display:flex}.stats span,.lesson-meta span,.level-pill{color:#244134;background:#ffffffeb;border:2px solid #d7ebdc;border-radius:999px;align-items:center;gap:7px;min-height:40px;padding:0 13px;font-weight:950;display:inline-flex;box-shadow:0 5px #316f4924}.stats span:nth-child(2){color:#c76300}.stats span:nth-child(4){color:#7052d7}.progress-track{background:#fff;border:2px solid #b7dec6;border-radius:999px;max-width:1180px;height:18px;margin:0 auto 12px;overflow:hidden;box-shadow:inset 0 2px #14201b14,0 8px #1a6b3914}.progress-track div,.level-track div{border-radius:inherit;background:linear-gradient(90deg,#37b96c,#9be15d,#ffd24d);height:100%;transition:width .32s cubic-bezier(.2,.9,.25,1.25)}.reward-strip{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffb3;border:2px solid #173c2a1f;border-radius:8px;grid-template-columns:auto minmax(160px,1fr) auto;align-items:center;gap:12px;max-width:1180px;margin:0 auto 22px;padding:12px;display:grid}.level-track{background:#e7e1ff;border-radius:999px;height:12px;overflow:hidden}.reward-strip strong{color:#5a4aac;font-size:.9rem}.learning-grid{grid-template-columns:minmax(220px,.8fr) minmax(320px,1.5fr) minmax(230px,.8fr);gap:18px;max-width:1180px;margin:0 auto;display:grid}.lesson-path,.challenge-panel,.reference-panel{background:#ffffffe6;border:2px solid #235b3d24;border-radius:8px;box-shadow:0 18px #27623912,0 26px 60px #2a493624}.lesson-path{align-content:start;gap:12px;padding:14px;display:grid}.lesson-node{color:#22382d;text-align:left;cursor:pointer;background:#fff;border:2px solid #dbe8de;border-radius:8px;grid-template-columns:46px 1fr;align-items:center;gap:11px;width:100%;min-height:78px;padding:12px;transition:transform .14s,box-shadow .14s,border-color .14s;display:grid;box-shadow:0 6px #dcece2}.lesson-node:hover,.lesson-node.active{border-color:#2ca65f;transform:translateY(-2px);box-shadow:0 8px #bfe8cd}.lesson-node:disabled{cursor:not-allowed}.lesson-node.locked{color:#6a756f;background:#f4f7f5;border-color:#e0e6e2;box-shadow:0 5px #dfe8e3}.lesson-node.locked:hover{border-color:#e0e6e2;transform:none;box-shadow:0 5px #dfe8e3}.lesson-node.locked .lesson-icon{color:#75827b;background:#e8eeeb}.lesson-node.complete .lesson-icon{color:#fff;background:linear-gradient(135deg,#2ca65f,#9be15d)}.lesson-icon{color:#237344;background:#e7f5ec;border-radius:50%;place-items:center;width:42px;height:42px;display:grid;box-shadow:inset 0 -4px #13572d14}.lesson-node strong,.lesson-node small{display:block}.lesson-node strong{font-size:1.02rem}.lesson-node small{color:#66766e;margin-top:4px;font-size:.78rem;line-height:1.25}.challenge-panel{padding:clamp(20px,4vw,36px)}.lesson-meta{justify-content:space-between;align-items:center;gap:8px;margin-bottom:24px;display:flex}.theory-toggle,.question-count{color:#244134;background:#fff;border:2px solid #d7ebdc;border-radius:999px;align-items:center;gap:7px;width:fit-content;min-height:40px;padding:0 13px;font-weight:950;display:inline-flex;box-shadow:0 5px #316f4924}.theory-toggle{cursor:pointer}.theory-toggle:hover{border-color:#2ca65f;transform:translateY(-1px)}.question-count{margin-bottom:18px}.theory-card{background:linear-gradient(135deg,#ffffffeb,#f7ffe5eb),linear-gradient(90deg,#0000,#37b96c1f);border:2px solid #cfebd8;border-radius:8px;padding:clamp(18px,3vw,28px);position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #fffc,0 8px #d8efdf}.theory-card h2{margin-bottom:12px}.theory-card h3{margin:24px 0 12px;font-size:1.1rem}.theory-icon{color:#102414;background:linear-gradient(135deg,#37b96c,#ffd24d);border-radius:50%;place-items:center;width:58px;height:58px;margin-bottom:18px;display:grid;box-shadow:0 8px #1b7a3d2e}.theory-progress-header{justify-content:space-between;align-items:start;gap:18px;display:flex}.theory-progress-header span{color:#1f3b26;background:#fff;border:2px solid #d7ebdc;border-radius:999px;flex:none;padding:8px 12px;font-weight:950;box-shadow:0 4px #e0ece5}.theory-page-track{background:#fff;border:2px solid #cbe5d5;border-radius:999px;height:14px;margin:18px 0;overflow:hidden;box-shadow:inset 0 2px #14201b14}.theory-page-track div{border-radius:inherit;background:linear-gradient(90deg,#37b96c,#ffd24d);height:100%;transition:width .22s}.theory-body{max-width:760px;font-size:1.08rem;line-height:1.65}.theory-card ul{gap:10px;margin:0;padding:0;list-style:none;display:grid}.theory-card li{color:#33463a;background:#fff;border:2px solid #dce8df;border-radius:8px;grid-template-columns:22px 1fr;align-items:start;gap:10px;padding:12px;display:grid;box-shadow:0 4px #e4efe8}.theory-card li svg{color:#2ca65f;margin-top:2px}.public-health-example{color:#4c3a06;background:#fff8dc;border:2px solid #ffe08a;border-radius:8px;gap:6px;margin-top:18px;padding:16px;display:grid;box-shadow:0 6px #f3dfa4}.public-health-example strong{color:#1f3b26}.lesson-support{gap:16px;margin-top:20px;display:grid}.lesson-support.single{margin-top:18px}.lesson-support section{gap:10px;display:grid}.lesson-support h3{margin:0}.lesson-support pre{color:#f3ffe9;background:#102414;border:2px solid #dce8df;border-radius:8px;margin:0;padding:14px;overflow-x:auto;box-shadow:0 6px #d7e5dc}.lesson-support pre code{color:inherit;white-space:pre;font-size:.9rem;line-height:1.55}.documentation-links{gap:10px;margin-top:18px;display:grid}.documentation-links>strong{color:#1f3b26}.documentation-links div{gap:12px;display:grid}.doc-note{background:#fff;border:2px solid #dce8df;border-radius:8px;gap:7px;padding:13px;display:grid;box-shadow:0 5px #e2ece6}.doc-note>span{color:#405548;line-height:1.35}.doc-note a,.concept-link,.reference-panel a{color:#1f6740;align-items:center;gap:7px;font-weight:900;text-decoration:none;display:inline-flex}.doc-note a{background:#fff;border:2px solid #cfe8d8;border-radius:999px;width:fit-content;min-height:40px;padding:0 12px;font-size:.88rem;box-shadow:0 4px #e1eee5}.doc-note a:hover,.reference-panel a:hover{color:#7052d7}.theory-actions{margin-top:22px}.theory-nav{flex-wrap:wrap;justify-content:end;gap:12px;display:flex}.challenge-panel h2{letter-spacing:0;text-wrap:balance;max-width:760px;font-size:clamp(1.75rem,3vw,2.75rem);line-height:1.02}.context{color:#54665d;margin-top:12px;font-size:1rem}.challenge-code{background:#0f1f16;border:2px solid #1d3327;border-radius:8px;margin-top:18px;padding:14px 16px;overflow-x:auto;box-shadow:0 6px #cfe0d5}.challenge-code code{color:#d7f5e2;white-space:pre}.choice-list{gap:13px;margin-top:28px;display:grid}.choice{text-align:left;cursor:pointer;background:#fff;border:2px solid #dce7df;border-radius:8px;width:100%;min-height:66px;padding:13px 16px;transition:transform .15s,box-shadow .15s,border-color .15s,background .15s;box-shadow:0 6px #e0e9e4}.choice:hover:not(:disabled),.choice.chosen{border-color:#278f52;transform:translateY(-2px);box-shadow:0 8px #c3ead1}.choice:active:not(:disabled){transform:translateY(4px);box-shadow:0 2px #c3ead1}.choice.correct{background:linear-gradient(135deg,#e8f8ed,#f8ffe9);border-color:#2ca65f;animation:.42s answer-pop;box-shadow:0 8px #9be15d}.choice.wrong{background:#fff0ee;border-color:#d95b4f;box-shadow:0 6px #ffc9c2}.write-card{background:#fff;border:2px solid #dce7df;border-radius:8px;gap:12px;margin-top:28px;padding:16px;display:grid;box-shadow:0 6px #e0e9e4}.write-card label{color:#244134;font-weight:950}.write-card input{color:#18211d;background:#fafffb;border:2px solid #cfe3d7;border-radius:8px;width:100%;min-height:56px;padding:0 14px;font:900 1rem SFMono-Regular,Consolas,Liberation Mono,monospace}.write-card input:focus{border-color:#2ca65f;outline:none;box-shadow:0 0 0 4px #2ca65f24}.write-card.correct{background:linear-gradient(135deg,#e8f8ed,#f8ffe9);border-color:#2ca65f;box-shadow:0 8px #9be15d}.write-card.wrong{background:#fff0ee;border-color:#d95b4f;box-shadow:0 6px #ffc9c2}.write-card small{color:#68420a;font-weight:800}.gap-line{background:#f7fff9;border:2px dashed #cfe3d7;border-radius:8px;padding:10px 12px}.token-bank{background:#fff;border:2px solid #dce7df;border-radius:8px;gap:12px;margin-top:28px;padding:16px;display:grid;box-shadow:0 6px #e0e9e4}.token-bank.correct{background:linear-gradient(135deg,#e8f8ed,#f8ffe9);border-color:#2ca65f;box-shadow:0 8px #9be15d}.token-bank.wrong{background:#fff0ee;border-color:#d95b4f;box-shadow:0 6px #ffc9c2}.token-label{color:#244134;font-weight:950}.token-line{background:#f7fff9;border:2px dashed #cfe3d7;border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;min-height:64px;padding:12px;display:flex}.token-placeholder{color:#6b7f71;font-size:.9rem;font-weight:800}.token-pool{flex-wrap:wrap;gap:10px;display:flex}.token-chip{cursor:pointer;background:#fff;border:2px solid #dce7df;border-radius:8px;padding:10px 14px;transition:transform .15s,box-shadow .15s,border-color .15s,opacity .15s;box-shadow:0 5px #e0e9e4}.token-chip:hover:not(:disabled){border-color:#278f52;transform:translateY(-2px);box-shadow:0 7px #c3ead1}.token-chip:active:not(:disabled){transform:translateY(3px);box-shadow:0 1px #c3ead1}.token-chip.used{opacity:.35}.token-chip.placed{background:#f0fbf4;border-color:#278f52}.match-board{gap:14px;margin-top:28px;display:grid}.match-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.match-column{align-content:start;gap:10px;display:grid}.match-option{text-align:left;cursor:pointer;background:#fff;border:2px solid #dce7df;border-radius:8px;min-height:58px;padding:12px 14px;font-weight:800;transition:transform .15s,box-shadow .15s,border-color .15s,opacity .15s;box-shadow:0 5px #e0e9e4}.match-option:hover:not(:disabled){border-color:#278f52;transform:translateY(-2px);box-shadow:0 7px #c3ead1}.match-option.selected{background:#f0fbf4;border-color:#278f52;box-shadow:0 7px #c3ead1}.match-option.matched{opacity:.65;pointer-events:none;background:linear-gradient(135deg,#e8f8ed,#f8ffe9);border-color:#2ca65f}.match-option.shake{background:#fff0ee;border-color:#d95b4f;animation:.4s match-shake}@keyframes match-shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}code{color:#18211d;white-space:normal;word-break:break-word;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:clamp(.86rem,1.5vw,1rem)}.feedback{border:2px solid #0000;border-radius:8px;gap:4px;margin-top:20px;padding:16px 18px;line-height:1.35;display:grid}.feedback.good{color:#14572f;background:linear-gradient(135deg,#e5f8ec,#faffcf);border-color:#7edc9e;box-shadow:0 7px #c5edc9}.feedback.try-again{color:#68420a;background:#fff1e0;border-color:#ffd19b;box-shadow:0 7px #ffd8a8}.feedback-hint{font-weight:800}.concept-link{cursor:pointer;background:#fff;border:2px solid #1f674033;border-radius:999px;width:fit-content;min-height:38px;margin-top:8px;padding:0 12px;box-shadow:0 4px #1f67401f}.concept-link:hover{transform:translateY(-1px)}.actions{justify-content:space-between;gap:12px;margin-top:26px;display:flex}button{font:inherit}.primary,.secondary{cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-width:124px;min-height:50px;padding:0 19px;font-weight:950;transition:transform .13s,box-shadow .13s;display:inline-flex}.primary{color:#fff;background:linear-gradient(#41c873,#229852);border:0;box-shadow:0 7px #126d36}.primary:hover:not(:disabled),.secondary:hover{transform:translateY(-2px)}.primary:active:not(:disabled),.secondary:active{transform:translateY(4px)}.primary:disabled{cursor:not-allowed;background:#b9c8bf;box-shadow:0 5px #8c9d94}.secondary{color:#234333;background:#fff;border:2px solid #cadbd0;box-shadow:0 6px #d5e5db}.reference-panel{padding:18px}.daily-goal{color:#fff;background:linear-gradient(135deg,#173c2a,#286f44);border-radius:8px;gap:10px;padding:15px;display:flex;box-shadow:0 8px #173c2a38}.daily-goal span{color:#d8f5df;margin-top:4px;font-size:.88rem;line-height:1.35;display:block}.reference-panel h3{margin:22px 0 12px;font-size:1.15rem}.reference-panel ul{gap:10px;margin:0;padding:0;list-style:none;display:grid}.reference-panel li{background:#fff;border:2px solid #dce8df;border-radius:8px;gap:4px;padding:13px;display:grid;box-shadow:0 5px #e2ece6}.reference-panel li span,.reference-panel li a{color:#5f7067;font-size:.88rem}.reference-panel li a{width:fit-content}.celebration{z-index:20;pointer-events:none;background:#ffffff47;place-items:center;animation:1.6s forwards overlay-fade;display:grid;position:fixed;inset:0}.celebration-card{color:#102414;background:linear-gradient(135deg,#37b96c,#ffd24d);border:3px solid #fff;border-radius:8px;place-items:center;gap:8px;min-width:min(320px,100vw - 48px);padding:30px;animation:.76s cubic-bezier(.18,1.32,.32,1) both celebration-pop;display:grid;box-shadow:0 18px #0d5e2c42,0 30px 70px #25543447}.celebration.level .celebration-card{color:#fff;background:linear-gradient(135deg,#7a5cff,#ffcf4a)}.celebration.unit .celebration-card{color:#102414;background:linear-gradient(135deg,#2ca65f,#40c8ff 48%,#ffd24d);min-width:min(460px,100vw - 42px);padding:38px 30px;animation-duration:.92s}.celebration-card strong{font-size:clamp(2.4rem,8vw,4.7rem);line-height:.9}.celebration-card span{font-weight:950}.confetti{position:absolute;inset:0;overflow:hidden}.confetti i{--pop:0;left:calc(8% + (var(--pop) * 5%));background:hsl(calc(var(--pop) * 32), 88%, 58%);width:12px;height:18px;animation:1.2s cubic-bezier(.17,.67,.2,1) forwards confetti-burst;animation-delay:calc(var(--pop) * 18ms);border-radius:3px;position:absolute;top:48%;transform:translate(-50%,-50%)}@keyframes answer-pop{0%{transform:scale(1)}45%{transform:scale(1.025)}to{transform:scale(1)}}@keyframes celebration-pop{0%{opacity:0;transform:scale(.74)translateY(28px)rotate(-2deg)}55%{opacity:1;transform:scale(1.05)translateY(0)rotate(1deg)}to{opacity:1;transform:scale(1)translateY(0)rotate(0)}}@keyframes overlay-fade{0%,70%{opacity:1}to{opacity:0}}@keyframes confetti-burst{0%{opacity:1;transform:translate(-50%,-50%)rotate(0)}to{opacity:0;transform:translate(calc(-240px + var(--pop) * 28px), calc(-220px + var(--pop) * 18px)) rotate(calc(260deg + var(--pop) * 18deg))}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:1ms!important;animation-duration:1ms!important}}@media (width<=940px){.app-shell{padding:18px}.topbar{flex-direction:column;align-items:start}.stats{justify-content:start}.reward-strip,.learning-grid{grid-template-columns:1fr}.lesson-path{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=1180px) and (width>=761px){.topbar,.progress-track,.reward-strip,.learning-grid{max-width:920px}.learning-grid{grid-template-columns:minmax(240px,.75fr) minmax(420px,1.25fr)}.lesson-path{grid-template-columns:1fr}.reference-panel{grid-column:1/-1}.reference-panel ul{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (width<=760px){.app-shell{padding:14px}.match-grid{grid-template-columns:1fr}h1{font-size:clamp(2rem,11vw,3.1rem)}.stats{gap:8px}.reward-strip{gap:10px}.lesson-path{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:12px;padding:12px;display:flex;overflow-x:auto}.lesson-node{scroll-snap-align:start;flex:0 0 min(280px,82vw)}.challenge-panel,.reference-panel{padding:16px}.documentation-links div{grid-template-columns:1fr}.theory-progress-header{flex-direction:column}.theory-progress-header span{width:fit-content}}@media (width<=640px){.app-shell{padding:12px}.lesson-path{display:flex}.lesson-meta,.actions{flex-direction:column}.primary,.secondary,.theory-nav{width:100%}}
