:root{--bg:#0e0f13;--bg2:#15161c;--panel:#16171e;--panel2:#1c1e26;--border:#262932;--text:#c2c6d0;--text-dim:#868b98;--head:#f2f3f7;--accent:#c9a25c;--accent-ink:#1a1206;--accent2:#7e93ad;--good:#6cc0a0;--bad:#d98d8d;--hot:#d9a441;--stage-a:#1b1e28;--stage-b:#090a0e;--glow-1:#1a1d27;--glow-2:#17151f;--serif:"Fraunces", Georgia, "Times New Roman", serif;--sans:"Inter", system-ui, "Segoe UI", Roboto, sans-serif;font:16px/1.55 var(--sans);color:var(--text);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility}:root[data-theme=light]{--bg:#f6f5f1;--bg2:#fff;--panel:#fff;--panel2:#f2f0ea;--border:#e5e1d8;--text:#4b4842;--text-dim:#8b877d;--head:#1b1a16;--accent:#a87f37;--accent-ink:#fffaf0;--accent2:#5c7a92;--good:#2f9d76;--bad:#c85c5c;--hot:#c08a2c;--glow-1:#ece6da;--glow-2:#efe9f0;--stage-a:#cdc8bc;--stage-b:#a29d90;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*{box-sizing:border-box}html,body,#root{min-height:100vh;margin:0}body{background:radial-gradient(1100px 560px at 72% -12%, var(--glow-1) 0%, transparent 62%), radial-gradient(820px 460px at -5% 108%, var(--glow-2) 0%, transparent 58%), var(--bg)}h1,h2,h3{color:var(--head);margin:0}button{cursor:pointer;font-family:inherit}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}.app{max-width:1280px;margin:0 auto;padding:0 18px 48px}.topbar{z-index:20;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(var(--bg) 60%, transparent);justify-content:space-between;align-items:center;padding:16px 4px;display:flex;position:sticky;top:0}.brand{color:var(--head);background:0 0;border:0;align-items:center;gap:12px;font-size:20px;display:flex}.brand .logo{filter:drop-shadow(0 2px 8px color-mix(in srgb, var(--accent) 45%, transparent));font-size:38px}.brand-txt{line-height:1;font-family:var(--serif);flex-direction:column;align-items:flex-start;display:flex}.brand-name{letter-spacing:-.8px;color:var(--head);white-space:nowrap;font-size:40px;font-weight:600;line-height:1}.brand-name b{color:var(--accent);font-weight:600}.brand-txt small{font-family:var(--sans);color:var(--text-dim);letter-spacing:1.4px;text-transform:uppercase;margin-top:4px;font-size:10px;font-weight:400}nav{align-items:center;gap:8px;display:flex}.nav,.voice{border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:10px;padding:8px 14px;font-size:14px}.nav.on{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);font-weight:700}.voice{background:var(--panel2)}.theme-toggle{border:1px solid var(--border);background:var(--panel2);border-radius:10px;padding:8px 11px;font-size:15px;line-height:1}.theme-toggle:hover{border-color:var(--accent)}.lang-switch{border:1px solid var(--border);background:var(--panel);border-radius:10px;display:inline-flex;overflow:hidden}.lang-switch button{color:var(--text-dim);letter-spacing:.3px;background:0 0;border:0;padding:8px 11px;font-size:13px;font-weight:700}.lang-switch button+button{border-left:1px solid var(--border)}.lang-switch button.on{background:var(--accent);color:var(--accent-ink)}.lang-switch.compact button{padding:6px 9px;font-size:12px}.soon-lang{justify-content:center;align-items:center;gap:8px;margin-bottom:20px;display:flex}.home{padding-top:20px;animation:.4s fade}.hero{text-align:center;max-width:680px;margin:28px auto 44px}.hero h1{font-family:var(--serif);letter-spacing:-1.2px;color:var(--head);font-size:clamp(34px,5.5vw,56px);font-weight:400;line-height:1.05}.hero p{color:var(--text-dim);margin-top:20px;font-size:17px;line-height:1.65}.hero b{color:var(--text)}.mode-cards{grid-template-columns:repeat(3,1fr);gap:18px;max-width:1000px;margin:0 auto;display:grid}.mode-card.quiz:hover{border-color:var(--hot);box-shadow:0 22px 50px -26px #0000008c}.mode-card.quiz .mc-go{color:var(--hot)}.home-secondary{justify-content:center;margin-top:20px;display:flex}.table-link{border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:999px;padding:10px 20px;font-size:14px}.table-link:hover{border-color:var(--accent);color:var(--head)}.mode-card{text-align:left;border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:14px;padding:30px 28px;transition:transform .18s,border-color .18s,box-shadow .18s}.mode-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 22px 50px -26px #0000008c}.mode-card.identify:hover{border-color:var(--accent2)}.mc-emoji{opacity:.9;font-size:32px}.mode-card h2{font-family:var(--serif);letter-spacing:-.3px;margin:16px 0 8px;font-size:27px;font-weight:500}.mode-card p{color:var(--text-dim);font-size:14.5px;line-height:1.6}.mc-go{color:var(--accent);margin-top:18px;font-size:14px;font-weight:600;display:inline-block}.mode-card.identify .mc-go{color:var(--accent2)}.tests-strip{flex-wrap:wrap;justify-content:center;gap:10px;margin:30px auto 0;display:flex}.tests-strip span{background:var(--panel);border:1px solid var(--border);border-radius:999px;padding:7px 13px;font-size:13px}.tests-strip .count{background:color-mix(in srgb, var(--accent) 14%, transparent);border-color:color-mix(in srgb, var(--accent) 50%, transparent);color:var(--accent);font-weight:600}.mode{animation:.4s fade}.shelf,.scoreboard{background:var(--panel);border:1px solid var(--border);border-radius:14px;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;display:flex}.shelf-label{text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);font-size:12px}.shelf-items{flex-wrap:wrap;gap:8px;display:flex}.shelf-chip{border:1px solid var(--border);background:var(--panel2);color:var(--text);border-radius:999px;align-items:center;gap:7px;padding:7px 12px;font-size:14px;display:inline-flex}.shelf-chip .dot{background:var(--c);width:12px;height:12px;box-shadow:0 0 8px var(--c);border-radius:50%}.shelf-chip.on{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 15%, transparent);color:var(--head)}.scoreboard{justify-content:space-between;font-size:15px}.scoreboard b{color:var(--accent)}.bench{grid-template-columns:minmax(300px,360px) minmax(0,1fr);grid-template-areas:"tools stage""log info";align-items:start;gap:26px;animation:.4s fade;display:grid}.tools{grid-area:tools}.sample-stage{grid-area:stage}.specimen{grid-area:info}.log{grid-area:log}.stage-hero{display:contents}.sample-stage{background:radial-gradient(circle at 50% 42%, var(--stage-a) 0%, var(--stage-b) 78%);border:1px solid var(--border);border-radius:18px;width:100%;max-width:none;height:clamp(440px,62vh,680px);position:relative;overflow:hidden;box-shadow:0 46px 100px -55px #000000d9,inset 0 1px #ffffff0a}.hint{text-align:center;color:var(--text-dim);pointer-events:none;letter-spacing:.2px;font-size:11px;position:absolute;bottom:12px;left:0;right:0}.model-credit{color:var(--text-dim);opacity:.6;letter-spacing:.3px;pointer-events:none;font-size:10px;position:absolute;top:11px;right:14px}.stage-remove{z-index:2;border:1px solid var(--border);background:color-mix(in srgb, var(--panel) 82%, transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:var(--text);border-radius:999px;padding:7px 13px;font-size:12px;font-weight:600;position:absolute;top:12px;left:12px}.stage-remove:hover{border-color:var(--bad);color:var(--bad)}.stage-mode{z-index:2;border:1px solid var(--border);background:color-mix(in srgb, var(--panel) 85%, transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:999px;display:inline-flex;position:absolute;bottom:12px;left:50%;overflow:hidden;transform:translate(-50%)}.stage-mode button{color:var(--text-dim);background:0 0;border:0;padding:8px 16px;font-size:12.5px;font-weight:600}.stage-mode button+button{border-left:1px solid var(--border)}.stage-mode button.on{background:var(--accent);color:var(--accent-ink)}.specimen{text-align:left;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:30px 34px 32px;box-shadow:0 26px 60px -44px #0009}.sample-name{font-family:var(--serif);letter-spacing:-.6px;font-size:clamp(32px,3.8vw,46px);font-weight:500;line-height:1.02}.sample-name:after{content:"";background:var(--accent);border-radius:2px;width:46px;height:3px;margin-top:14px;display:block}.specimen-stats{border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:flex-start;gap:18px 46px;margin:22px 0 0;padding:22px 0;display:flex}.specimen-stats>div{flex-direction:column;gap:6px;display:flex}.specimen-stats span{text-transform:uppercase;letter-spacing:1.3px;color:var(--text-dim);font-size:10px}.specimen-stats b{color:var(--head);font-size:18px;font-weight:600}.fato{border-left:2px solid var(--accent);max-width:640px;font-family:var(--serif);color:var(--text);margin:22px 0 0;padding-left:18px;font-size:17px;font-style:italic;line-height:1.55}.mystery{max-width:560px;color:var(--text-dim);margin:20px auto 0;font-size:15px}.bench-lower{display:contents}.log{flex-direction:column;align-self:stretch;min-height:130px;max-height:60vh;display:flex;overflow:hidden}.bench-lower section{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:20px 22px}.bench-lower h3{text-transform:uppercase;letter-spacing:1.4px;color:var(--text-dim);margin-bottom:16px;font-size:11px;font-weight:600}.tool-tabs{grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:14px;display:grid}.tool-tab{border:1px solid var(--border);background:var(--panel2);color:var(--text-dim);text-align:center;border-radius:10px;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;font-size:11px;display:flex}.tool-tab .te{font-size:20px}.tool-tab.on{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 15%, transparent);color:var(--head)}.tool-panel{min-height:210px}.tp-desc{color:var(--text-dim);margin-bottom:12px;font-size:13px}.hardness-tools{grid-template-columns:1fr 1fr;gap:8px;display:grid}.htool{border:1px solid var(--border);background:var(--panel2);color:var(--text);border-radius:10px;flex-direction:column;align-items:flex-start;gap:2px;padding:10px;display:flex}.htool .te{font-size:20px}.htool .hn{font-size:14px;font-weight:600}.htool .hh{color:var(--text-dim);font-size:11px}.htool:hover:not(.used){border-color:var(--accent)}.htool.used{opacity:.4;cursor:default}.htool.equipped{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 16%, transparent);box-shadow:0 0 0 1px var(--accent) inset}.range-box{background:var(--bg2);border:1px solid var(--border);border-radius:10px;margin-top:12px;padding:10px 12px;font-size:14px}.range-box b{color:var(--accent)}.single-test{flex-direction:column;gap:12px;display:flex}.run-btn{background:var(--accent);color:var(--accent-ink);letter-spacing:.2px;border:0;border-radius:10px;padding:12px 18px;font-size:14px;font-weight:600;transition:filter .15s,transform .1s}.run-btn:hover{filter:brightness(1.06)}.run-btn:active{transform:translateY(1px)}.run-btn.big{width:100%}.streak-plate{background:repeating-linear-gradient(45deg,#eef0f2,#eef0f2 10px,#e4e7ea 10px 20px);border:3px solid #cfd3d8;border-radius:10px;height:90px;position:relative;overflow:hidden}.streak-line{border-radius:8px;width:0;height:14px;animation:.5s forwards streak;position:absolute;top:38px;left:12%}@keyframes streak{to{width:76%}}.log-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.log-head h3{margin-bottom:0}.log-actions{gap:6px;display:flex}.log-clear{border:1px solid var(--border);background:var(--panel2);color:var(--text-dim);border-radius:8px;padding:5px 12px;font-size:12px}.log-clear:hover{border-color:var(--accent);color:var(--accent)}.log-actions .log-clear:last-child:hover{border-color:var(--bad);color:var(--bad)}.log-empty{color:var(--text-dim);font-size:13px}.log ul{flex-direction:column;flex:auto;gap:10px;min-height:0;margin:0;padding:0 6px 0 0;list-style:none;display:flex;overflow-y:auto}.log ul::-webkit-scrollbar{width:8px}.log ul::-webkit-scrollbar-thumb{background:var(--border);border-radius:999px}.log ul::-webkit-scrollbar-track{background:0 0}.log-item{border:1px solid var(--border);background:var(--bg2);border-radius:11px;padding:10px 12px;animation:.25s pop}.log-item.hot{border-color:var(--hot);box-shadow:0 0 0 1px var(--hot) inset}.li-head{align-items:center;gap:8px;margin-bottom:4px;display:flex}.li-tag{text-transform:uppercase;letter-spacing:.5px;background:var(--panel2);border:1px solid var(--border);color:var(--text-dim);border-radius:6px;padding:2px 6px;font-size:10px}.li-title{color:var(--head);font-size:14px;font-weight:700}.log-item p{color:var(--text-dim);font-size:13px}.li-swatch{border:1px solid #ffffff40;border-radius:5px;width:60px;height:14px;margin-top:8px;display:inline-block}.identify-box{border-top:1px dashed var(--border);margin-top:14px;padding-top:14px}.guess-grid{grid-template-columns:1fr 1fr;gap:8px;margin:10px 0;display:grid}.guess-btn{border:1px solid var(--border);background:var(--panel2);color:var(--text);border-radius:10px;padding:10px;font-size:14px}.guess-btn:hover:not(:disabled){border-color:var(--accent2);background:color-mix(in srgb, var(--accent2) 15%, transparent)}.guess-btn:disabled{opacity:.32;cursor:default;text-decoration:line-through}.guess-wrong{color:var(--bad);margin:0 0 4px;font-size:13px}.link-btn{color:var(--text-dim);background:0 0;border:0;padding:4px;font-size:13px}.verdict{border:1px solid var(--border);border-radius:12px;padding:14px}.verdict.ok{border-color:var(--good);background:#37d19a1f}.verdict.no{border-color:var(--bad);background:#ff6b6b1f}.verdict strong{color:var(--head);font-size:17px}.verdict p{margin:8px 0;font-size:14px}.verdict .run-btn{margin-top:6px}.solve-score{align-items:baseline;gap:10px;margin:8px 0 2px;display:flex}.solve-score .stars{letter-spacing:2px;color:var(--accent);font-size:22px;line-height:1}.solve-score .stars.s2{opacity:.9}.solve-score .stars.s3{opacity:.75}.solve-score .stars.s4{opacity:.55}.solve-score .solve-pts{color:var(--good);font-size:15px;font-weight:700}.solve-tries{color:var(--text-dim);margin:0 0 4px!important;font-size:13px!important}.score-points b{color:var(--accent)}.identify-actions{flex-direction:column;gap:8px;display:flex}.hint-btn{border:1px solid var(--hot);color:var(--hot);background:#ffb3471f;border-radius:10px;padding:9px 14px;font-size:14px;font-weight:600}.hint-btn:disabled{opacity:.55;cursor:default}.hints{background:var(--bg2);border:1px solid var(--border);border-radius:10px;margin-bottom:12px;padding:10px 12px}.hints-title{color:var(--hot);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:700}.hints ul{margin:6px 0 0;padding-left:18px}.hints li{color:var(--text);margin-bottom:3px;font-size:13px}.quiz-done{text-align:center;background:var(--panel);border:1px solid var(--border);border-radius:18px;max-width:460px;margin:40px auto;padding:40px 32px}.qd-emoji{font-size:56px}.quiz-done h2{font-family:var(--serif);margin:10px 0;font-size:28px;font-weight:500}.qd-score{font-family:var(--serif);color:var(--accent);margin:8px 0;font-size:52px;font-weight:500}.qd-points{font-size:16px;font-weight:700;color:var(--accent)!important;margin:0 0 6px!important}.quiz-done p{color:var(--text-dim);margin-bottom:18px}.qd-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;display:flex}.table-title{text-align:center;font-family:var(--serif);letter-spacing:-.3px;margin-bottom:22px;font-size:30px;font-weight:500}.table-wrap{border:1px solid var(--border);background:var(--panel);border-radius:14px;overflow-x:auto}.ref-table{border-collapse:collapse;width:100%;min-width:900px;font-size:13px}.ref-table th,.ref-table td{text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 12px}.ref-table th{background:var(--panel2);color:var(--head);text-transform:uppercase;letter-spacing:.4px;font-size:12px;position:sticky;top:0}.ref-table tbody tr:hover{background:var(--panel2)}.ref-table .tm-name{color:var(--head);font-weight:700}.ref-table .tm-num{text-align:center}.tm-dot,.tm-streak{vertical-align:middle;border:1px solid #80808059;border-radius:50%;width:12px;height:12px;margin-right:7px;display:inline-block}.tm-streak{border-radius:3px;width:22px;height:10px}.bubbles{pointer-events:none;position:absolute;inset:0}.bubbles span{background:radial-gradient(circle at 35% 30%,#fff,#b4e6ff80);border-radius:50%;width:10px;height:10px;animation:2.4s ease-in infinite rise;position:absolute;bottom:30%}@keyframes rise{0%{opacity:0;transform:translateY(0)scale(.5)}20%{opacity:.9}to{opacity:0;transform:translateY(-180px)scale(1.2)}}@keyframes fade{0%{opacity:0;transform:translateY(6px)}}@keyframes pop{0%{opacity:0;transform:scale(.97)}}.soon{place-items:center;min-height:100vh;padding:24px;display:grid}.soon-card{text-align:center;background:var(--panel);border:1px solid var(--border);border-radius:18px;max-width:480px;padding:48px 40px;box-shadow:0 40px 90px -45px #000000b3}.soon-logo{filter:drop-shadow(0 4px 14px color-mix(in srgb, var(--accent) 45%, transparent));font-size:46px}.soon-card h1{font-family:var(--serif);letter-spacing:-.8px;margin:16px 0 2px;font-size:42px;font-weight:400}.soon-card h1 b{color:var(--accent)}.soon-tag{color:var(--text-dim);letter-spacing:.4px;font-size:14px}.soon-badge{color:#1a1204;background:linear-gradient(120deg, #ffd479, var(--hot));border-radius:999px;margin:22px 0 16px;padding:8px 18px;font-size:15px;font-weight:800;display:inline-block}.soon-txt{color:var(--text-dim);font-size:15px;line-height:1.6}.soon-link{color:var(--text-dim);opacity:.6;background:0 0;border:0;margin-top:24px;font-size:13px}.soon-link:hover{opacity:1;color:var(--accent)}.soon-form{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:22px;display:flex}.soon-form input{background:var(--bg);border:1px solid var(--border);color:var(--head);border-radius:10px;padding:10px 14px;font-family:inherit;font-size:15px}.soon-form input:focus{border-color:var(--accent);outline:none}.soon-form button{background:var(--accent);color:var(--accent-ink);border:0;border-radius:10px;padding:10px 18px;font-weight:700}.soon-erro{width:100%;color:var(--bad);margin-top:2px;font-size:13px}.acct-badge{color:var(--text);background:var(--panel);border:1px solid var(--border);border-radius:999px;align-items:center;gap:8px;padding:6px 8px 6px 13px;font-size:13px;display:inline-flex}.acct-badge button{background:var(--panel2);color:var(--text-dim);border:0;border-radius:999px;padding:4px 10px;font-size:11px}.acct-badge button:hover{color:var(--bad)}.tea{max-width:900px;margin:10px auto 0;animation:.4s fade}.tea-auth{text-align:center;max-width:380px;margin:44px auto;animation:.4s fade}.tea h2,.tea-auth h2{font-family:var(--serif);letter-spacing:-.3px;margin:0 0 18px;font-size:28px;font-weight:500}.tea-head{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.tea-head h2{margin:0}.tea input,.tea-auth input,.modal input{background:var(--bg2);border:1px solid var(--border);width:100%;color:var(--head);border-radius:10px;padding:12px 14px;font-family:inherit;font-size:15px}.tea input:focus,.tea-auth input:focus,.modal input:focus{border-color:var(--accent);outline:none}.tea-auth form{gap:10px;margin-bottom:14px;display:grid}.tea-err{color:var(--bad);margin:0;font-size:13px}.tea-new{gap:10px;margin-bottom:22px;display:flex}.tea-new input{flex:1}.tea-empty{color:var(--text-dim);font-size:14px}.tea-classes{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;display:grid}.tea-card{text-align:left;background:var(--panel);border:1px solid var(--border);color:var(--text);border-radius:14px;padding:20px}.tea-card:hover{border-color:var(--accent)}.tc-name{font-family:var(--serif);color:var(--head);margin-bottom:8px;font-size:19px}.tc-code{color:var(--text-dim);font-size:14px}.tc-code b{color:var(--accent);font-family:var(--sans);letter-spacing:2px}.tc-meta{color:var(--text-dim);margin-top:10px;font-size:12px}.tea-cols{grid-template-columns:1fr 1.4fr;gap:22px;display:grid}.tea-cols h3{text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);margin:0 0 12px;font-size:12px}.tea-roster,.tea-results{gap:8px;margin:0;padding:0;list-style:none;display:grid}.tea-roster li{background:var(--panel);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;padding:10px 14px;font-size:14px;display:flex}.tea-roster small{color:var(--text-dim);font-size:12px}.tea-results li{background:var(--panel);border:1px solid var(--border);border-radius:10px;align-items:center;gap:10px;padding:10px 14px;font-size:13px;display:flex}.tea-results .res-info{color:var(--text-dim)}.res-dot{background:var(--text-dim);border-radius:50%;flex:none;width:9px;height:9px}.res-dot.ok{background:var(--good)}.res-dot.no{background:var(--bad)}.modal-overlay{z-index:50;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0000008c;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal{text-align:center;background:var(--panel);border:1px solid var(--border);border-radius:16px;width:100%;max-width:380px;padding:32px 28px;animation:.2s pop;position:relative;box-shadow:0 40px 90px -45px #000000b3}.modal h2{font-family:var(--serif);margin:0 0 18px;font-size:24px;font-weight:500}.modal form{gap:12px;display:grid}.modal-x{color:var(--text-dim);background:0 0;border:0;font-size:15px;position:absolute;top:12px;right:14px}.modal-x:hover{color:var(--head)}@media (width<=900px){.bench{grid-template-columns:1fr;grid-template-areas:"stage""info""tools""log"}.tea-cols{grid-template-columns:1fr}.mode-cards{grid-template-columns:1fr;max-width:460px}}@media (width<=640px){.specimen-stats{gap:12px 22px}}.score-right{align-items:center;gap:12px;display:flex}.rank-btn{border:1px solid var(--border);background:var(--panel);color:var(--head);cursor:pointer;border-radius:999px;padding:6px 12px;font-size:13px;font-weight:600;transition:border-color .15s,background .15s}.rank-btn:hover{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, transparent)}.rank-overlay{z-index:60;background:#0000008c;justify-content:center;align-items:center;padding:20px;animation:.2s fade;display:flex;position:fixed;inset:0}.rank-modal{background:var(--bg);border:1px solid var(--border);border-radius:18px;width:min(440px,100%);max-height:80vh;padding:20px 22px 24px;overflow-y:auto;box-shadow:0 24px 60px #00000059}.rank-modal-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.rank-modal-head h3{color:var(--head);font-size:18px}.rank-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.rank-row{border:1px solid var(--border);background:var(--panel);border-radius:12px;grid-template-columns:32px 1fr auto;align-items:center;gap:10px;padding:10px 12px;display:grid}.rank-row.top{border-color:color-mix(in srgb, var(--accent) 45%, var(--border))}.rank-row.me{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, transparent)}.rank-pos{text-align:center;color:var(--text-dim);font-size:18px;font-weight:700}.rank-row.top .rank-pos{font-size:20px}.rank-name{color:var(--head);text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.rank-you{color:var(--accent);font-size:12px;font-weight:700}.rank-stats{text-align:right;color:var(--text-dim);font-size:14px;line-height:1.25}.rank-stats b{color:var(--accent);font-size:16px}.rank-stats small{opacity:.8;font-size:11px;display:block}.rank-loading,.rank-empty{color:var(--text-dim);text-align:center;padding:16px 4px;font-size:13px}.tea-rank{margin-bottom:22px}.tea-rank h3{margin-bottom:10px}.term{border-bottom:1px dotted color-mix(in srgb, var(--accent) 70%, transparent);cursor:help;outline:none;display:inline;position:relative}.term:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}.term-i{color:var(--accent);vertical-align:super;margin-left:2px;font-size:.72em;line-height:0}.term-pop{z-index:40;background:var(--head);width:max-content;max-width:260px;color:var(--bg);white-space:normal;pointer-events:none;border-radius:10px;padding:9px 11px;line-height:1.4;position:absolute;top:calc(100% + 8px);left:0;box-shadow:0 10px 30px #00000047;text-transform:none!important;letter-spacing:0!important;font-size:12.5px!important;font-weight:400!important}.term-pop:before{content:"";border:6px solid #0000;border-bottom-color:var(--head);position:absolute;bottom:100%;left:14px}.glossary{max-width:900px;margin-top:32px}.glossary h3{font-family:var(--serif);color:var(--head);margin-bottom:4px;font-size:22px;font-weight:500}.gl-intro{color:var(--text-dim);margin-bottom:16px;font-size:13px}.gl-list{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin:0;display:grid}.gl-item{border:1px solid var(--border);background:var(--panel);border-radius:12px;padding:12px 14px}.gl-item dt{color:var(--head);margin-bottom:4px;font-weight:700}.gl-item dd{color:var(--text-dim);margin:0;font-size:13.5px;line-height:1.5}.nav-icon{border:1px solid var(--border);background:var(--panel);width:32px;height:32px;color:var(--text-dim);cursor:pointer;border-radius:50%;font-size:15px;font-weight:700;transition:border-color .15s,color .15s}.nav-icon:hover{border-color:var(--accent);color:var(--accent)}.tour{z-index:90;position:fixed;inset:0}.tour-block{background:0 0;position:fixed;inset:0}.tour-hole{border:2px solid var(--accent);pointer-events:none;border-radius:16px;transition:top .25s,left .25s,width .25s,height .25s;position:fixed;box-shadow:0 0 0 9999px #08080ca8}.tour-tip{z-index:92;background:var(--bg);border:1px solid color-mix(in srgb, var(--accent) 40%, var(--border));border-radius:16px;padding:18px;animation:.25s fade;position:fixed;box-shadow:0 24px 60px #00000073}.tour-tip h4{font-family:var(--serif);color:var(--head);margin-bottom:6px;font-size:19px;font-weight:500}.tour-tip p{color:var(--text-dim);margin-bottom:14px;font-size:14px;line-height:1.5}.tour-foot{justify-content:space-between;align-items:center;gap:10px;display:flex}.tour-skip{color:var(--text-dim);cursor:pointer;background:0 0;border:0;padding:4px;font-size:13px}.tour-dots{gap:5px;display:flex}.tour-dots span{background:var(--border);border-radius:50%;width:6px;height:6px}.tour-dots span.on{background:var(--accent);transform:scale(1.3)}.tour-btns{gap:8px;display:flex}.tour-back{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:8px;padding:6px 12px;font-size:13px}.tour-next{background:var(--accent);color:#1a1408;cursor:pointer;border:0;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:700}.cmp-stages{grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;margin-bottom:22px;display:grid}.cmp-col{flex-direction:column;gap:10px;display:flex}.cmp-stage{background:radial-gradient(circle at 50% 42%, var(--stage-a) 0%, var(--stage-b) 78%);border:1px solid var(--border);border-radius:16px;height:300px;overflow:hidden}.cmp-vs{font-family:var(--serif);color:var(--text-dim);font-size:22px;font-style:italic}.cmp-select{border:1px solid var(--border);background:var(--panel);width:100%;color:var(--head);cursor:pointer;border-radius:10px;padding:10px 12px;font-size:15px;font-weight:600}.cmp-table td{font-size:14px}.cmp-table .cmp-lbl{color:var(--text-dim);font-weight:600}.cmp-table tr,.cmp-table .cmp-diff td{background:color-mix(in srgb, var(--accent) 5%, transparent)}.cmp-table .cmp-win{color:var(--accent);font-weight:700}@media (width<=700px){.cmp-stages{grid-template-columns:1fr}.cmp-vs{text-align:center}.cmp-stage{height:220px}}.ach{max-width:940px;margin:40px auto 0}.ach-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:18px;display:flex}.ach-head h2{font-family:var(--serif);color:var(--head);font-size:26px;font-weight:500}.ach-sub{color:var(--text-dim);margin-top:2px;font-size:14px}.ach-meta{align-items:center;gap:12px;display:flex}.ach-streak{color:var(--head);background:color-mix(in srgb, var(--accent) 14%, transparent);border:1px solid color-mix(in srgb, var(--accent) 40%, var(--border));white-space:nowrap;border-radius:999px;padding:6px 12px;font-size:14px;font-weight:700}.ach-count{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:13px}.ach-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;display:grid}.ach-badge{text-align:center;border:1px solid var(--border);background:var(--panel);border-radius:14px;flex-direction:column;align-items:center;gap:4px;padding:18px 14px;transition:transform .15s,border-color .15s;display:flex}.ach-badge.earned{border-color:color-mix(in srgb, var(--accent) 55%, var(--border));background:color-mix(in srgb, var(--accent) 8%, var(--panel))}.ach-badge.earned:hover{transform:translateY(-2px)}.ach-emoji{font-size:30px;line-height:1}.ach-badge.locked .ach-emoji{filter:grayscale();opacity:.32}.ach-name{color:var(--head);font-size:14px;font-weight:700}.ach-badge.locked .ach-name{color:var(--text-dim)}.ach-desc{color:var(--text-dim);font-size:11.5px;line-height:1.35}.toast-stack{z-index:80;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:20px;right:20px}.toast{background:var(--bg);border:1px solid color-mix(in srgb, var(--accent) 45%, var(--border));border-radius:14px;align-items:center;gap:12px;min-width:220px;padding:12px 16px;animation:.35s cubic-bezier(.2,.9,.3,1.3) toast-in;display:flex;box-shadow:0 16px 40px #0000004d}.toast-emoji{font-size:26px;line-height:1}.toast strong{color:var(--accent);text-transform:uppercase;letter-spacing:.04em;font-size:12px;display:block}.toast-name{color:var(--head);font-size:15px;font-weight:700}@keyframes toast-in{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.inst-code{background:color-mix(in srgb, var(--accent) 10%, var(--panel));border:1px solid color-mix(in srgb, var(--accent) 40%, var(--border));border-radius:14px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:8px;padding:16px 20px;display:flex}.inst-code-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);font-size:12px;display:block}.inst-code-val{letter-spacing:4px;color:var(--accent);font-variant-numeric:tabular-nums;font-size:28px;font-weight:800}.inst-code-hint{color:var(--text-dim);max-width:640px;margin-bottom:22px;font-size:13px}.inst-stats{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:26px;display:grid}.inst-stat{background:var(--panel);border:1px solid var(--border);text-align:center;border-radius:14px;padding:16px}.inst-stat b{font-family:var(--serif);color:var(--head);font-size:30px;line-height:1;display:block}.inst-stat span{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;font-size:12px}.inst-section{margin-bottom:26px}.inst-section h3{margin-bottom:12px}.inst-section-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.inst-course{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;margin:0;padding:0;list-style:none;display:grid}.inst-course li{border:1px solid var(--border);background:var(--panel);border-radius:10px;justify-content:space-between;align-items:center;padding:10px 14px;font-size:14px;display:flex}.inst-course li b{color:var(--accent)}.tea-head-actions{flex-wrap:wrap;gap:8px;display:flex}.tea-classname{align-items:center;gap:10px;display:flex}.tea-edit{color:var(--text-dim);cursor:pointer;background:0 0;border:0;font-size:16px}.tea-edit:hover{color:var(--accent)}.tea-arch-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);border:1px solid var(--border);border-radius:999px;padding:2px 8px;font-size:11px}.tea-arch-title{color:var(--text-dim);margin:24px 0 10px;font-size:15px}.tea-card.arch{opacity:.6}.tea-rename{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;display:flex}.tea-rename input{border:1px solid var(--border);background:var(--panel);min-width:180px;color:var(--head);border-radius:8px;flex:1;padding:8px 12px}.tea-roster-name{color:var(--head);cursor:pointer;text-align:left;background:0 0;border:0;padding:0;font-size:14px}.tea-roster-name:hover{color:var(--accent)}.tr-course{color:var(--text-dim);font-weight:400}.tea-roster-right{align-items:center;gap:8px;display:flex}.tea-remove{color:var(--text-dim);cursor:pointer;opacity:.6;background:0 0;border:0;font-size:13px}.tea-remove:hover{color:var(--bad);opacity:1}.sd-profile{flex-direction:column;gap:2px;margin-bottom:14px;display:flex}.sd-profile b{color:var(--head);font-size:17px}.sd-profile span{color:var(--text-dim);font-size:13px}.sd-h{color:var(--head);margin-bottom:8px;font-size:14px}.sd-list{flex-direction:column;gap:6px;max-height:240px;margin:0 0 16px;padding:0;list-style:none;display:flex;overflow-y:auto}.sd-list li{align-items:center;gap:8px;font-size:13px;display:flex}.tea-remove-btn{border:1px solid color-mix(in srgb, var(--bad) 50%, var(--border));color:var(--bad);cursor:pointer;background:0 0;border-radius:8px;width:100%;padding:8px 14px;font-size:13px}.tea-remove-btn:hover{background:color-mix(in srgb, var(--bad) 12%, transparent)}.log-clear.danger{color:var(--bad);border-color:color-mix(in srgb, var(--bad) 40%, var(--border))}.log-clear.danger:hover{background:color-mix(in srgb, var(--bad) 12%, transparent)}.sd-actions{margin-bottom:12px}.audit-list{flex-direction:column;gap:6px;max-height:320px;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.audit-list li{border:1px solid var(--border);background:var(--panel);border-radius:10px;flex-wrap:wrap;align-items:baseline;gap:10px;padding:8px 12px;font-size:13px;display:flex}.audit-when{color:var(--text-dim);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:12px}.audit-who{color:var(--text)}.audit-target{color:var(--text-dim);font-style:italic}.inst-danger{border:1px solid color-mix(in srgb, var(--bad) 40%, var(--border));background:color-mix(in srgb, var(--bad) 6%, transparent);border-radius:14px;margin-top:30px;padding:18px 20px}.inst-danger h3{color:var(--bad);margin-bottom:12px}.inst-danger .tea-remove-btn{width:auto}.landing{max-width:1000px;margin:0 auto;padding:0 18px 60px;animation:.4s fade}.landing-top{justify-content:space-between;align-items:center;padding:18px 4px;display:flex}.brand-mini{font-family:var(--serif);align-items:center;gap:10px;display:flex}.brand-mini .logo{font-size:30px}.brand-mini .brand-name{color:var(--head);font-size:30px;font-weight:600}.brand-mini .brand-name b{color:var(--accent);font-weight:600}.landing-top-actions{align-items:center;gap:8px;display:flex}.landing-hero{text-align:center;max-width:640px;margin:40px auto 30px}.landing-hero h1{font-family:var(--serif);color:var(--head);letter-spacing:-1.5px;font-size:clamp(44px,8vw,80px);font-weight:400}.landing-hero h1 b{color:var(--accent);font-weight:400}.landing-hero p{color:var(--text-dim);margin-top:12px;font-size:18px}.landing-choose{text-align:center;font-family:var(--serif);color:var(--head);margin-bottom:20px;font-size:22px;font-weight:500}.landing-cards{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.landing-card{text-align:left;border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:16px;padding:26px 24px;transition:transform .18s,border-color .18s,box-shadow .18s}.landing-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 22px 50px -26px #0000008c}.lc-emoji{font-size:34px}.landing-card h3{font-family:var(--serif);color:var(--head);margin:14px 0 6px;font-size:22px;font-weight:500}.landing-card p{color:var(--text-dim);font-size:14px;line-height:1.55}.landing-demo{border:1px solid var(--border);background:var(--panel2);color:var(--text);border-radius:999px;margin:26px auto 0;padding:11px 22px;font-size:14px;display:block}.landing-demo:hover{border-color:var(--accent);color:var(--head)}.landing.framed{max-width:520px}.landing-back{margin:4px 0 8px;display:block}.brand-wrap{align-items:center;gap:12px;min-width:0;display:flex}.uni-pill{text-overflow:ellipsis;white-space:nowrap;max-width:220px;color:var(--head);background:color-mix(in srgb, var(--accent) 12%, transparent);border:1px solid color-mix(in srgb, var(--accent) 40%, var(--border));border-radius:999px;align-items:center;gap:5px;padding:5px 12px;font-size:13px;font-weight:600;display:inline-flex;overflow:hidden}.acct-badge.demo{border-style:dashed}.settings-menu{position:relative}.settings-pop{z-index:40;background:var(--bg);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:10px;width:max-content;padding:12px;display:flex;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 18px 44px #00000052}.settings-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.rk-tabs{flex-wrap:wrap;gap:8px;margin-bottom:18px;display:flex}.rk-tabs button{border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:999px;padding:9px 16px;font-size:14px;font-weight:600}.rk-tabs button.on{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.rk-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;display:grid}.rk-grid h3{color:var(--head);margin-bottom:12px;font-size:16px}@media (width<=760px){.landing-cards{grid-template-columns:1fr}}
