@import"https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700;800&display=swap";*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%}:root{--crimson: #B50042;--crimson-dark: #8A0033;--crimson-ink: #5E0B2A;--yellow: #FFD600;--orange: #FF8500;--green: #1F8A4C;--green-soft: #EAF6EE;--red-soft: #FCEBEF;--bg: #FBF7F5;--surface: #FFFFFF;--ink: #2A1A20;--muted: #8C7A80;--line: #EFE4E8;--line-strong: #E2D2D8;--r-lg: 22px;--r-md: 14px;--r-sm: 10px;--shadow: 0 1px 2px rgba(94,11,42,.04), 0 12px 30px -16px rgba(94,11,42,.18);--shadow-sm: 0 1px 2px rgba(94,11,42,.05), 0 6px 16px -12px rgba(94,11,42,.16);--font: "Hanken Grotesk", system-ui, sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.5}button{font-family:inherit;cursor:pointer}::selection{background:var(--yellow);color:var(--crimson-ink)}.app{min-height:100vh;background:radial-gradient(1200px 480px at 88% -8%,rgba(255,214,0,.1),transparent 60%),radial-gradient(1000px 420px at -6% 4%,rgba(181,0,66,.06),transparent 55%)}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px clamp(16px,4vw,44px);background:#fbf7f5d1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}.brand{display:flex;align-items:center;gap:12px;cursor:pointer}.brand img{height:34px;width:auto;display:block}.brand .tag{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding-left:12px;border-left:1px solid var(--line-strong)}.topnav{display:flex;align-items:center;gap:8px}.wrap{max-width:1080px;margin:0 auto;padding:clamp(20px,4vw,48px) clamp(16px,4vw,44px) 80px}.wrap.narrow{max-width:760px}.btn{border:1px solid transparent;border-radius:999px;font-weight:700;font-size:15px;line-height:1;padding:13px 22px;display:inline-flex;align-items:center;gap:9px;transition:transform .12s ease,background .15s ease,box-shadow .15s ease,border-color .15s ease;background:var(--surface);color:var(--ink);border-color:var(--line-strong)}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-primary{background:var(--crimson);color:#fff;box-shadow:0 10px 22px -10px #b50042b3}.btn-primary:hover{background:var(--crimson-dark)}.btn-ghost{background:transparent;border-color:transparent;color:var(--crimson)}.btn-ghost:hover{background:#b5004212}.btn-lg{font-size:17px;padding:17px 30px}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-block{width:100%;justify-content:center}.hero{display:grid;grid-template-columns:1fr 1.1fr;gap:40px;align-items:center;padding:18px 0 8px}.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;letter-spacing:.04em;color:var(--crimson);background:#b5004212;padding:7px 14px;border-radius:999px;margin-bottom:18px}.hero h1{font-size:clamp(32px,5vw,52px);line-height:1.04;letter-spacing:-.02em;margin:0 0 16px;font-weight:800}.hero h1 .accent{color:var(--crimson)}.hero p.lede{font-size:clamp(16px,2vw,19px);color:var(--muted);margin:0 0 28px;max-width:46ch}.hero-cta{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.hero-meta{margin-top:22px;display:flex;gap:26px;flex-wrap:wrap}.hero-meta .stat .v{font-size:22px;font-weight:800}.hero-meta .stat .k{font-size:13px;color:var(--muted);font-weight:600}.hero-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:22px;position:relative;overflow:hidden}.hero-card:before{content:"";position:absolute;inset:0 0 auto 0;height:6px;background:linear-gradient(90deg,var(--crimson),var(--orange) 60%,var(--yellow))}.hero-card h3{margin:6px 0 4px;font-size:15px;letter-spacing:.02em}.hero-card .eq{font-size:12px;white-space:nowrap}.hero-card .barrels{display:flex;gap:7px;align-items:flex-end;height:40px;margin-bottom:12px}.hero-card .barrels i{display:block;width:16px;border-radius:3px 3px 2px 2px}.section-head{margin:56px 0 18px}.section-head h2{font-size:clamp(22px,3vw,28px);margin:0 0 6px;letter-spacing:-.01em}.section-head p{color:var(--muted);margin:0}.formula-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.formula-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:22px;box-shadow:var(--shadow-sm)}.formula-card .step{font-size:12px;font-weight:800;color:var(--crimson);letter-spacing:.08em;text-transform:uppercase}.formula-card h4{margin:8px 0 12px;font-size:17px}.eq{font-size:15px;line-height:1.9;color:var(--ink);background:var(--bg);border:1px dashed var(--line-strong);border-radius:var(--r-sm);padding:14px 16px}.eq b{color:var(--crimson)}.eq .op{color:var(--muted);padding:0 3px;font-weight:700}.eq .res{color:var(--green);font-weight:800}.level-preview-grid{display:grid;gap:10px}.level-preview-card{display:flex;align-items:center;gap:14px;text-align:left;padding:14px 16px;border-radius:var(--r-md);border:1.5px solid var(--line);background:var(--surface);cursor:pointer;transition:border-color .15s ease,background .15s ease,transform .1s ease}.level-preview-card:hover{border-color:var(--crimson);background:#b500420a;transform:translate(2px)}.level-preview-card .lt{font-weight:700;font-size:16px}.level-preview-card .lb{font-size:13px;color:var(--muted)}.level-preview-card .lc{margin-left:auto;font-size:13px;color:var(--muted);font-weight:600;white-space:nowrap}.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:clamp(20px,4vw,34px)}.panel h2{margin:0 0 4px;font-size:clamp(22px,3vw,28px);letter-spacing:-.01em}.panel .sub{color:var(--muted);margin:0 0 24px}.field{margin-bottom:22px}.field>label{display:block;font-weight:700;font-size:14px;margin-bottom:10px}.input{width:100%;padding:14px 16px;font-size:16px;font-family:inherit;border:1.5px solid var(--line-strong);border-radius:var(--r-md);background:var(--surface);color:var(--ink);transition:border-color .15s ease,box-shadow .15s ease}.input:focus{outline:none;border-color:var(--crimson);box-shadow:0 0 0 4px #b500421f}.mode-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px}.mode-card{display:flex;flex-direction:column;align-items:flex-start;gap:4px;text-align:left;padding:18px 20px;border-radius:var(--r-md);border:2px solid var(--line);background:var(--surface);cursor:pointer;width:100%;transition:border-color .15s ease,background .15s ease,transform .1s ease}.mode-card:hover{border-color:var(--crimson);background:#b500420a;transform:translateY(-1px)}.mode-card.sel{border-color:var(--crimson);background:#b500420f}.mode-title{font-size:17px;font-weight:800;color:var(--ink)}.mode-card.sel .mode-title{color:var(--crimson)}.mode-count{font-size:22px;font-weight:800;color:var(--crimson);margin:2px 0}.mode-note{font-size:12px;color:var(--muted);line-height:1.4}.level-list{display:grid;gap:10px}.level-opt{display:flex;align-items:center;gap:14px;text-align:left;width:100%;padding:14px 16px;border-radius:var(--r-md);border:1.5px solid var(--line);background:var(--surface);transition:border-color .15s ease,background .15s ease,transform .1s ease}.level-opt:hover{border-color:var(--line-strong);transform:translate(2px)}.level-opt.sel{border-color:var(--crimson);background:#b500420a;box-shadow:0 0 0 3px #b5004214}.level-badge{flex:0 0 auto;width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-weight:800;font-size:18px;color:#fff}.level-opt .lt{font-weight:700;font-size:16px}.level-opt .lb{font-size:13px;color:var(--muted)}.level-opt .lc{margin-left:auto;font-size:13px;color:var(--muted);font-weight:600;white-space:nowrap}.chips{display:flex;gap:10px;flex-wrap:wrap}.chip{padding:11px 20px;border-radius:999px;border:1.5px solid var(--line-strong);background:var(--surface);font-weight:700;font-size:15px;color:var(--ink);transition:all .12s ease}.chip:hover{border-color:var(--crimson)}.chip.sel{background:var(--crimson);color:#fff;border-color:var(--crimson)}.auth-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);overflow:hidden;max-width:440px;margin:40px auto 0}.auth-tabs{display:flex;border-bottom:1px solid var(--line)}.auth-tab{flex:1;padding:16px;font-size:15px;font-weight:700;background:none;border:none;cursor:pointer;color:var(--muted);transition:color .15s}.auth-tab.active{color:var(--crimson);border-bottom:2px solid var(--crimson);margin-bottom:-1px}.auth-tab:hover:not(.active){color:var(--ink)}.auth-form{padding:28px 28px 8px;display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:14px;font-weight:700;color:var(--ink)}.auth-error{color:#c02448;font-size:14px;font-weight:600;margin:0;background:var(--red-soft);border:1px solid #F2C2CE;border-radius:8px;padding:10px 14px}.auth-switch{text-align:center;color:var(--muted);font-size:14px;padding:18px 28px 24px;margin:0}.link-btn{background:none;border:none;color:var(--crimson);font-weight:700;cursor:pointer;font-size:inherit;padding:0;text-decoration:underline}.user-greeting{font-size:14px;font-weight:600;color:var(--muted);white-space:nowrap}.quiz-top{display:flex;align-items:center;gap:16px;margin-bottom:22px}.progress-track{flex:1;height:10px;border-radius:999px;background:var(--line);overflow:hidden}.progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--crimson),var(--orange));transition:width .4s cubic-bezier(.2,.8,.2,1)}.score-pill,.streak-pill{display:inline-flex;align-items:center;gap:7px;font-weight:800;font-size:14px;padding:8px 14px;border-radius:999px;white-space:nowrap}.score-pill{background:#b5004214;color:var(--crimson)}.streak-pill{background:#ff85001f;color:#c05600}.streak-pill.cold{background:var(--line);color:var(--muted)}.q-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:clamp(20px,4vw,36px)}.q-count{font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--crimson)}.q-text{font-size:clamp(18px,3vw,23px);font-weight:700;letter-spacing:-.01em;margin:6px 0 12px;line-height:1.25}.formula-hint{font-size:12.5px;color:#7a5c00;background:#fff8e6;border:1px solid #F2E2A8;border-radius:6px;padding:5px 10px;margin:-6px 0 10px;line-height:1.4}.stable-wrap{overflow-x:auto;margin:4px 0 14px;padding-bottom:4px}.stable{border-collapse:separate;border-spacing:0;width:100%;min-width:580px;font-size:13px}.stable th{background:var(--crimson-ink);color:#fff;font-weight:700;font-size:11px;padding:6px 5px;text-align:center;letter-spacing:.01em;line-height:1.2}.stable th:first-child{border-top-left-radius:10px}.stable th:last-child{border-top-right-radius:10px}.stable td{padding:8px 5px;text-align:center;border-bottom:1px solid var(--line);border-right:1px solid var(--line);font-variant-numeric:tabular-nums;font-weight:600}.stable td:first-child{border-left:1px solid var(--line)}.stable tr:last-child td:first-child{border-bottom-left-radius:10px}.stable .dash{color:var(--line-strong);font-weight:700}.stable td.blank{background:#fffbea;position:relative}.stable .cell-input{width:74px;padding:9px 6px;text-align:center;font-size:15px;font-weight:800;font-family:inherit;border:2px solid var(--orange);border-radius:8px;background:#fff;color:var(--crimson-ink)}.stable .cell-input:focus{outline:none;box-shadow:0 0 0 4px #ff850033}.stable td.solved{background:var(--green-soft);color:var(--green)}.x-hint{color:var(--orange);font-weight:800}.options{display:grid;gap:10px}.opt-btn{text-align:left;padding:15px 18px;border-radius:var(--r-md);border:1.5px solid var(--line-strong);background:var(--surface);font-size:16px;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:13px;transition:all .12s ease}.opt-btn:hover:not(:disabled){border-color:var(--crimson);background:#b5004208}.opt-btn .marker{flex:0 0 auto;width:26px;height:26px;border-radius:50%;border:2px solid var(--line-strong);display:grid;place-items:center;font-weight:800;font-size:13px;color:var(--muted)}.opt-btn.sel{border-color:var(--crimson);background:#b500420d}.opt-btn.sel .marker{border-color:var(--crimson);background:var(--crimson);color:#fff}.opt-btn.correct{border-color:var(--green);background:var(--green-soft)}.opt-btn.correct .marker{border-color:var(--green);background:var(--green);color:#fff}.opt-btn.wrong{border-color:#d8345b;background:var(--red-soft)}.opt-btn.wrong .marker{border-color:#d8345b;background:#d8345b;color:#fff}.opt-btn:disabled{cursor:default}.q-actions{margin-top:14px;display:flex;gap:12px;align-items:center}.feedback{margin-top:18px;border-radius:var(--r-md);padding:16px 18px;animation:pop .25s ease}@keyframes pop{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.feedback.ok{background:var(--green-soft);border:1px solid #B6E0C4}.feedback.no{background:var(--red-soft);border:1px solid #F2C2CE}.feedback .fb-head{font-weight:800;font-size:16px;display:flex;align-items:center;gap:9px}.feedback.ok .fb-head{color:var(--green)}.feedback.no .fb-head{color:#c02448}.feedback .fb-correct{margin-top:6px;font-size:15px}.feedback .fb-correct b{color:var(--ink)}.feedback .explainer{margin-top:10px;font-size:14.5px;color:var(--ink);background:#fff9;border-radius:8px;padding:10px 12px}.feedback .explainer .lbl{font-weight:800;color:var(--crimson);margin-right:6px}.complete{text-align:center}.ring-wrap{display:grid;place-items:center;margin:8px auto 18px;position:relative;width:168px;height:168px}.ring-wrap .num{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center}.ring-wrap .num .big{font-size:44px;font-weight:800;line-height:1}.ring-wrap .num .small{font-size:13px;color:var(--muted);font-weight:700}.complete h2{font-size:clamp(26px,4vw,34px);margin:6px 0}.complete .msg{color:var(--muted);font-size:17px;margin:0 0 26px}.complete .actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.badge-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:0 0 26px}.pill-tag{display:inline-flex;align-items:center;gap:7px;padding:8px 15px;border-radius:999px;font-weight:700;font-size:14px;background:#ff85001f;color:#c05600}.review-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:18px 20px;margin-bottom:12px;box-shadow:var(--shadow-sm)}.review-item .rh{display:flex;align-items:center;gap:10px;margin-bottom:8px}.review-item .rq{font-weight:700;font-size:16px}.tick{flex:0 0 auto;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:14px;font-weight:800;color:#fff}.tick.ok{background:var(--green)}.tick.no{background:#d8345b}.review-row{font-size:14.5px;margin-top:3px}.review-row .lbl{color:var(--muted);font-weight:600;width:110px;display:inline-block}.review-row .yours.bad{color:#c02448;font-weight:700}.review-row .right{color:var(--green);font-weight:700}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:22px}.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:18px;box-shadow:var(--shadow-sm)}.stat-card .v{font-size:30px;font-weight:800;line-height:1}.stat-card .k{font-size:13px;color:var(--muted);font-weight:600;margin-top:6px}.trend-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:20px;box-shadow:var(--shadow-sm);margin-bottom:22px}.trend-card h3{margin:0 0 14px;font-size:16px}.results-table{width:100%;border-collapse:collapse;font-size:14.5px}.results-table th{text-align:left;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.06em;padding:8px 10px;border-bottom:2px solid var(--line)}.results-table td{padding:12px 10px;border-bottom:1px solid var(--line);font-weight:600}.results-table .sc{font-weight:800}.empty-state{text-align:center;padding:50px 20px;color:var(--muted)}.link-back{background:none;border:none;color:var(--muted);font-weight:700;font-size:14px;display:inline-flex;align-items:center;gap:6px;padding:6px 4px}.link-back:hover{color:var(--crimson)}.barrels{display:flex;gap:7px;align-items:flex-end}.barrels i{display:block;width:16px;border-radius:3px 3px 2px 2px}@media (max-width: 820px){.hero{grid-template-columns:1fr;gap:24px}.hero-card{order:-1}.hero-card .eq{white-space:normal}.formula-grid,.stat-grid{grid-template-columns:1fr}.brand .tag{display:none}}@media (max-width: 480px){.topnav .btn{padding:11px 15px;font-size:14px}.hero-meta{gap:18px}}.admin-wrap{max-width:1200px;margin:0 auto;padding:clamp(20px,4vw,48px) clamp(16px,4vw,44px) 80px}.admin-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px}.admin-stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:20px;text-align:center}.admin-stat .v{font-size:32px;font-weight:800}.admin-stat .k{font-size:13px;color:var(--muted);font-weight:600;margin-top:2px}.admin-toolbar{display:flex;gap:12px;align-items:center;margin-bottom:18px;flex-wrap:wrap}.admin-search{flex:1;min-width:200px;padding:10px 14px;border:1.5px solid var(--line-strong);border-radius:var(--r-md);font-size:15px;font-family:inherit;background:var(--surface);color:var(--ink)}.admin-search:focus{outline:none;border-color:var(--crimson)}.user-table{width:100%;border-collapse:separate;border-spacing:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}.user-table th{background:var(--bg);padding:12px 14px;text-align:left;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);border-bottom:1px solid var(--line)}.user-table td{padding:14px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle}.user-table tr:last-child td{border-bottom:none}.user-table tr:hover td{background:var(--bg)}.role-badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700}.role-badge.admin{background:var(--crimson);color:#fff}.role-badge.learner{background:var(--line);color:var(--ink)}.active-badge{width:8px;height:8px;border-radius:50%;display:inline-block}.active-badge.on{background:var(--green)}.active-badge.off{background:var(--muted)}.add-user-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;margin-bottom:24px}.add-user-panel h3{margin:0 0 18px;font-size:17px}.add-user-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}.sub-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:8px}.sub-table th{text-align:left;padding:6px 10px;color:var(--muted);font-size:11px;font-weight:800;text-transform:uppercase}.sub-table td{padding:8px 10px;border-top:1px solid var(--line)}.action-btns{display:flex;gap:6px}.btn-sm{padding:6px 12px;font-size:13px;border-radius:var(--r-sm);border:1.5px solid var(--line-strong);background:none;cursor:pointer;font-weight:600;color:var(--ink)}.btn-sm:hover{border-color:var(--crimson);color:var(--crimson)}.btn-sm.danger:hover{border-color:#c02448;color:#c02448}.cert-wrap{max-width:800px;margin:40px auto;padding:0 20px 60px}.certificate{background:#fff;border:3px solid var(--crimson);border-radius:16px;padding:60px;position:relative;overflow:hidden;box-shadow:0 8px 40px #0000001f}.certificate:before{content:"";position:absolute;inset:0 0 auto 0;height:8px;background:linear-gradient(90deg,var(--crimson),var(--orange) 60%,var(--yellow))}.cert-title{font-size:13px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--crimson);margin-bottom:16px}.cert-heading{font-size:clamp(28px,5vw,42px);font-weight:800;letter-spacing:-.02em;margin:0 0 8px}.cert-sub{font-size:17px;color:var(--muted);margin:0 0 36px}.cert-recipient{font-size:22px;margin:0 0 32px}.cert-recipient strong{font-size:clamp(28px,4vw,38px);color:var(--crimson);display:block}.cert-date{font-size:15px;color:var(--muted);margin-bottom:36px}.cert-levels{width:100%;border-collapse:collapse;margin-bottom:36px}.cert-levels th{text-align:left;padding:8px 12px;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);border-bottom:2px solid var(--line)}.cert-levels td{padding:12px;border-bottom:1px solid var(--line);font-size:15px}.cert-footer{font-size:13px;color:var(--muted);border-top:1px solid var(--line);padding-top:20px;margin-top:8px}.cert-actions{display:flex;gap:12px;margin-bottom:24px}.not-earned{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:36px;text-align:center}.level-checklist{list-style:none;padding:0;margin:20px auto;max-width:320px;text-align:left}.level-checklist li{padding:10px 14px;border-bottom:1px solid var(--line);font-size:15px;display:flex;justify-content:space-between;align-items:center}@media print{.cert-actions,.topbar,button{display:none!important}.cert-wrap{margin:0;padding:0}.certificate{box-shadow:none;border-radius:0}body{background:#fff}}
