@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.top-1{top:calc(var(--spacing) * 1)}.top-3{top:calc(var(--spacing) * 3)}.top-4{top:calc(var(--spacing) * 4)}.top-5{top:calc(var(--spacing) * 5)}.top-10{top:calc(var(--spacing) * 10)}.top-20{top:calc(var(--spacing) * 20)}.top-50{top:calc(var(--spacing) * 50)}.isolate{isolation:isolate}.row-1{grid-row:1}.row-2{grid-row:2}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.block\!{display:block!important}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.shrink{flex-shrink:1}.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.border{border-style:var(--tw-border-style);border-width:1px}.capitalize{text-transform:capitalize}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.line-through{text-decoration-line:line-through}.underline{text-decoration-line:underline}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg:#faf9f6;--bg-elevated:#fff;--bg-sunken:#f3f1ec;--bg-tint:#efece5;--fg:#16181d;--fg-muted:#5a5e69;--fg-subtle:#8b8e97;--fg-faint:#b8b9bd;--border:#e7e4dc;--border-strong:#d5d1c5;--border-faint:#efece5;--accent:#2347d9;--accent-fg:#fff;--accent-soft:#eaeefc;--accent-soft-fg:#1a36ad;--accent-tint:#f4f6fe;--tone-practice-bg:#eef6ee;--tone-practice-fg:#2e5b34;--tone-practice-icon:#4a8550;--tone-prompt-bg:#eef0fc;--tone-prompt-fg:#2c3a85;--tone-prompt-icon:#4c5fcc;--tone-mistakes-bg:#fbeeea;--tone-mistakes-fg:#8a3a23;--tone-mistakes-icon:#c66a48;--tone-hacks-bg:#f4eef9;--tone-hacks-fg:#5d2e7d;--tone-hacks-icon:#8a55b3;--tone-when-bg:#eaf4f3;--tone-when-fg:#1e5a55;--tone-when-icon:#3e8a83;--tone-not-bg:#f9ecec;--tone-not-fg:#883a3a;--tone-not-icon:#b85555;--tone-sources-bg:#f2eee5;--tone-sources-fg:#5a4a25;--tone-sources-icon:#8a743f;--s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:20px;--s-6:24px;--s-8:32px;--s-10:40px;--s-12:48px;--s-16:64px;--s-20:80px;--s-24:96px;--t-12:12px;--t-13:13px;--t-14:14px;--t-15:15px;--t-16:16px;--t-18:18px;--t-21:21px;--t-24:24px;--t-32:32px;--t-40:40px;--t-56:56px;--t-72:72px;--radius-sm:6px;--radius:10px;--radius-lg:16px;--radius-xl:24px;--shadow-card:0 1px 0 #14161c08, 0 1px 2px #14161c0a;--shadow-lift:0 1px 0 #14161c08, 0 8px 24px #14161c0f;--shadow-inset:inset 0 0 0 1px var(--border);--sidebar-w:248px;--topbar-h:64px;--content-max:1200px;--reading-max:720px;--density:1;--section-y:calc(var(--s-20) * var(--density))}[data-density=cozy]{--density:.72}[data-density=comfy]{--density:1}[data-density=airy]{--density:1.3}*{box-sizing:border-box}html,body{background:var(--bg);color:var(--fg);font-feature-settings:"ss01", "cv11";font-family:Mona Sans,Söhne,Helvetica Neue,Helvetica,Segoe UI,sans-serif;font-size:var(--t-16);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;padding:0;line-height:1.5}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit;font-size:inherit;color:inherit}::selection{background:var(--accent);color:var(--accent-fg)}.app{grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--border);background:var(--bg);flex-direction:column;gap:22px;height:100vh;padding:18px 16px 20px;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}.brand{align-items:center;gap:10px;padding:2px 8px;display:flex}.brand-mark{background:var(--fg);width:28px;height:28px;color:var(--bg);letter-spacing:-.02em;border-radius:7px;place-items:center;font-size:13px;font-weight:600;display:grid}.brand-mark:after{content:"";position:absolute}.brand-name{letter-spacing:-.015em;font-size:15px;font-weight:600}.brand-sub{color:var(--fg-subtle);border-left:1px solid var(--border);margin-left:6px;padding-left:8px;font-size:11px}.nav-group{flex-direction:column;gap:1px;display:flex}.nav-label{letter-spacing:.06em;text-transform:uppercase;color:var(--fg-subtle);padding:6px 10px 8px;font-size:11px;font-weight:600}.nav-item{color:var(--fg-muted);cursor:pointer;-webkit-user-select:none;user-select:none;text-align:left;letter-spacing:-.005em;background:0 0;border:0;border-radius:7px;align-items:center;gap:11px;width:100%;padding:7px 10px;font-size:14px;font-weight:450;display:flex}.nav-item:hover{background:var(--bg-sunken);color:var(--fg)}.nav-item[aria-current=page]{background:var(--bg-elevated);color:var(--fg);box-shadow:var(--shadow-card), inset 0 0 0 1px var(--border);font-weight:550}.nav-icon{width:16px;height:16px;color:var(--fg-subtle);flex:none}.nav-item[aria-current=page] .nav-icon{color:var(--accent)}.nav-count{color:var(--fg-faint);font-variant-numeric:tabular-nums;margin-left:auto;font-size:11px}.sidebar-foot{border-top:1px solid var(--border);flex-direction:column;gap:6px;margin-top:auto;padding:14px 8px 4px;display:flex}.profile{border-radius:8px;align-items:center;gap:10px;padding:6px;display:flex}.profile:hover{background:var(--bg-sunken)}.avatar{color:#fff;letter-spacing:.02em;background:linear-gradient(135deg,#d5cfb8,#b8b1a0);border-radius:50%;flex:none;place-items:center;width:28px;height:28px;font-size:11px;font-weight:600;display:grid}.profile-info{flex-direction:column;min-width:0;display:flex}.profile-name{font-size:13px;font-weight:550;line-height:1.2}.profile-meta{color:var(--fg-subtle);font-size:11px}.main{flex-direction:column;min-width:0;display:flex}.topbar{z-index:50;height:var(--topbar-h);background:var(--bg);position:sticky;top:0}@supports (color:color-mix(in lab, red, red)){.topbar{background:color-mix(in srgb, var(--bg) 86%, transparent)}}.topbar{-webkit-backdrop-filter:saturate(160%)blur(14px);border-bottom:1px solid var(--border);align-items:center;gap:16px;padding:0 36px;display:flex}.breadcrumbs{color:var(--fg-subtle);white-space:nowrap;flex:1;align-items:center;gap:6px;min-width:0;font-size:13px;display:flex;overflow:hidden}.breadcrumbs a,.breadcrumbs button{color:var(--fg-subtle);cursor:pointer;background:0 0;border:0;padding:0}.breadcrumbs a:hover,.breadcrumbs button:hover{color:var(--fg)}.breadcrumb-current{color:var(--fg);font-weight:500}.crumb-sep{color:var(--fg-faint)}.search-input{width:280px;position:relative}.search-input input{border:1px solid var(--border);background:var(--bg-elevated);width:100%;color:var(--fg);border-radius:8px;outline:none;padding:7px 10px 7px 32px;font-size:13px}.search-input input::placeholder{color:var(--fg-faint)}.search-input input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-tint)}.search-input svg{width:14px;height:14px;color:var(--fg-faint);position:absolute;top:50%;left:10px;transform:translateY(-50%)}.kbd{border:1px solid var(--border);background:var(--bg-sunken);min-width:18px;height:18px;color:var(--fg-subtle);border-radius:4px;justify-content:center;align-items:center;padding:0 5px;font:500 11px/1 Mona Sans,sans-serif;display:inline-flex}.topbar-actions{align-items:center;gap:10px;margin-left:auto;display:flex}.icon-btn{width:32px;height:32px;color:var(--fg-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:7px;place-items:center;display:grid}.icon-btn:hover{background:var(--bg-sunken);color:var(--fg)}.content{padding:var(--s-10) var(--s-12) var(--s-20);max-width:var(--content-max);flex:1;width:100%;margin:0 auto}.content-wide{max-width:none;padding-left:var(--s-12);padding-right:var(--s-12)}@media (max-width:760px){.app{grid-template-columns:1fr}.sidebar{display:none}.content{padding:var(--s-8) var(--s-6) var(--s-12)}}@media (max-width:880px){:root{--sidebar-w:200px}}.eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-size:12px;font-weight:600}.eyebrow-muted{color:var(--fg-subtle)}h1.page-title{letter-spacing:-.025em;text-wrap:balance;margin:0 0 18px;font-size:clamp(36px,5vw,56px);font-weight:600;line-height:1.04}h2.section-title{letter-spacing:-.018em;margin:0 0 8px;font-size:26px;font-weight:600;line-height:1.15}.section-lede{color:var(--fg-muted);text-wrap:pretty;max-width:620px;margin:0 0 28px;font-size:17px;line-height:1.55}.lede{color:var(--fg-muted);text-wrap:pretty;max-width:640px;font-size:20px;line-height:1.5}.text-muted{color:var(--fg-muted)}.text-subtle{color:var(--fg-subtle)}.mono{font-family:JetBrains Mono,SF Mono,ui-monospace,monospace;font-size:.92em}.tabular{font-variant-numeric:tabular-nums}.btn{background:var(--fg);height:40px;color:var(--bg-elevated);letter-spacing:-.005em;cursor:pointer;border:1px solid #0000;border-radius:8px;align-items:center;gap:8px;padding:0 18px;font-size:14px;font-weight:500;transition:transform 50ms,background .12s;display:inline-flex}.btn:hover{background:#000}.btn:active{transform:translateY(1px)}.btn.btn-accent,.btn.btn-accent:hover{background:var(--accent)}@supports (color:color-mix(in lab, red, red)){.btn.btn-accent:hover{background:color-mix(in srgb, var(--accent) 88%, #000)}}.btn.btn-ghost{color:var(--fg);border-color:var(--border-strong);background:0 0}.btn.btn-ghost:hover{background:var(--bg-sunken)}.btn.btn-soft{background:var(--bg-elevated);color:var(--fg);border-color:var(--border);box-shadow:var(--shadow-card)}.btn.btn-soft:hover{background:var(--bg)}.btn.btn-sm{border-radius:7px;height:32px;padding:0 12px;font-size:13px}.btn.btn-lg{border-radius:9px;height:48px;padding:0 22px;font-size:15px}.chip{background:var(--bg-sunken);height:26px;color:var(--fg-muted);letter-spacing:-.005em;white-space:nowrap;border:1px solid #0000;border-radius:999px;align-items:center;gap:6px;padding:0 10px;font-size:12px;font-weight:500;display:inline-flex}.chip-outline{border-color:var(--border);color:var(--fg-muted);background:0 0}.chip-accent{background:var(--accent-soft);color:var(--accent-soft-fg)}.chip-dot{opacity:.7;background:currentColor;border-radius:50%;width:6px;height:6px}.badge-level{letter-spacing:.02em;text-transform:uppercase;border-radius:5px;align-items:center;gap:4px;height:22px;padding:0 8px;font-size:11.5px;font-weight:600;display:inline-flex}.badge-level.lv-beginner{color:#2e5b34;background:#eef6ee}.badge-level.lv-intermediate{color:#6f4a17;background:#fdf3e3}.badge-level.lv-advanced{color:#5d2e7d;background:#f0eaf7}.card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:22px}.card-hover{cursor:pointer;transition:border-color .12s,transform .12s,box-shadow .12s}.card-hover:hover{border-color:var(--border-strong);box-shadow:var(--shadow-lift)}.grid{gap:18px;display:grid}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}@media (max-width:980px){.grid-3,.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.filter-bar{background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:24px;padding:14px 16px;display:flex}.filter-label{color:var(--fg-subtle);margin-right:4px;font-size:12px;font-weight:500}.filter-chip{border:1px solid var(--border);background:var(--bg);height:30px;color:var(--fg-muted);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;border-radius:999px;align-items:center;gap:6px;padding:0 12px;font-size:13px;display:inline-flex}.filter-chip:hover{border-color:var(--border-strong);color:var(--fg)}.filter-chip[aria-pressed=true]{background:var(--fg);color:var(--bg-elevated);border-color:var(--fg)}.filter-divider{background:var(--border);width:1px;height:22px;margin:0 4px}.hero{padding:calc(36px * var(--density)) 0 calc(48px * var(--density))}.hero-eyebrow{color:var(--fg-muted);border:1px solid var(--border);background:var(--bg-elevated);border-radius:999px;align-items:center;gap:8px;margin-bottom:22px;padding:5px 10px 5px 8px;font-size:12px;font-weight:500;display:inline-flex}.hero-eyebrow .dot{background:#28a745;border-radius:50%;width:7px;height:7px;box-shadow:0 0 0 3px #28a7452e}.hero h1{letter-spacing:-.03em;text-wrap:balance;max-width:14ch;margin:0 0 22px;font-size:clamp(40px,5.6vw,72px);font-weight:600;line-height:1.02}.hero h1 em{color:var(--accent);font-style:normal}.hero-sub{color:var(--fg-muted);text-wrap:pretty;max-width:580px;margin:0 0 28px;font-size:19px;line-height:1.5}.hero-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.hero-meta{border-top:1px solid var(--border);flex-wrap:wrap;gap:22px;margin-top:36px;padding-top:22px;display:flex}.hero-meta-item{flex-direction:column;gap:2px;display:flex}.hero-meta-item b{letter-spacing:-.01em;font-size:22px;font-weight:600}.hero-meta-item span{color:var(--fg-subtle);font-size:12px}.hero-grid-cards{grid-template-columns:repeat(3,1fr);gap:12px;margin-top:30px;display:grid}.hero-track-card{border:1px solid var(--border);background:var(--bg-elevated);text-align:left;cursor:pointer;font:inherit;color:inherit;border-radius:10px;flex-direction:column;gap:6px;padding:16px;display:flex}.hero-track-card:hover{border-color:var(--fg)}.hero-track-card h4{letter-spacing:-.005em;margin:0;font-size:14px;font-weight:600}.hero-track-card p{color:var(--fg-subtle);margin:0;font-size:12px}.marquee{border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-top:36px;padding:18px 0;position:relative;overflow:hidden}.marquee:before,.marquee:after{content:"";z-index:2;pointer-events:none;width:80px;position:absolute;top:0;bottom:0}.marquee:before{background:linear-gradient(to right, var(--bg), transparent);left:0}.marquee:after{background:linear-gradient(to left, var(--bg), transparent);right:0}.marquee-track{align-items:center;gap:56px;width:max-content;animation:32s linear infinite marquee;display:flex}.marquee-item{color:var(--fg-muted);letter-spacing:-.01em;white-space:nowrap;align-items:center;gap:12px;font-size:17px;font-weight:500;display:flex}.marquee-item:before{content:"";background:var(--fg-faint);border-radius:50%;width:5px;height:5px}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}.chooser{border:1px solid var(--border);background:var(--bg-elevated);box-shadow:var(--shadow-card);border-radius:14px;margin-top:36px;padding:22px 26px 26px}.chooser-head{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.chooser-step-label{color:var(--fg-subtle);letter-spacing:.02em;font-size:12px;font-weight:500}.chooser-q{letter-spacing:-.015em;margin:0 0 16px;font-size:20px;font-weight:600;line-height:1.25}.chooser-options{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}@media (max-width:720px){.chooser-options{grid-template-columns:1fr}}.chooser-option{border:1px solid var(--border);background:var(--bg);cursor:pointer;font:inherit;color:inherit;text-align:left;border-radius:9px;align-items:center;gap:12px;padding:13px 16px;display:flex}.chooser-option:hover{border-color:var(--fg);background:var(--bg-elevated)}.chooser-option .opt-mark{border:1px solid var(--border-strong);width:22px;height:22px;color:var(--fg-subtle);background:var(--bg-elevated);border-radius:6px;flex:none;place-items:center;font-size:11px;font-weight:600;display:grid}.chooser-option .opt-text{flex-direction:column;gap:2px;display:flex}.chooser-option .opt-text b{font-size:14px;font-weight:550}.chooser-option .opt-text span{color:var(--fg-subtle);font-size:12px}.chooser-progress{flex:1;gap:4px;margin-left:20px;display:flex}.chooser-progress .seg{background:var(--bg-sunken);border-radius:2px;flex:1;height:3px}.chooser-progress .seg.on{background:var(--fg)}.chooser-result{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px;display:flex}.chooser-result-info{max-width:480px}.chooser-result-info h3{letter-spacing:-.015em;margin:0 0 6px;font-size:24px;font-weight:600}.chooser-result-info p{color:var(--fg-muted);margin:0;font-size:14px;line-height:1.5}.personas{background:var(--border);border:1px solid var(--border);margin:var(--section-y) 0;border-radius:12px;grid-template-columns:repeat(6,1fr);gap:1px;display:grid;overflow:hidden}@media (max-width:980px){.personas{grid-template-columns:repeat(3,1fr)}}@media (max-width:600px){.personas{grid-template-columns:repeat(2,1fr)}}.persona{background:var(--bg-elevated);cursor:pointer;flex-direction:column;gap:10px;padding:22px 18px;display:flex}.persona:hover{background:var(--bg)}.persona-mark{border-radius:8px;place-items:center;width:32px;height:32px;display:grid}.persona h4{margin:0;font-size:14px;font-weight:550}.persona p{color:var(--fg-subtle);margin:0;font-size:12px;line-height:1.4}.pillars{grid-template-columns:repeat(4,1fr);gap:18px;margin-top:20px;display:grid}@media (max-width:980px){.pillars{grid-template-columns:repeat(2,1fr)}}.pillar{border:1px solid var(--border);background:var(--bg-elevated);border-radius:10px;flex-direction:column;gap:6px;padding:22px;display:flex}.pillar .pillar-num{letter-spacing:.08em;color:var(--fg-faint);font-variant-numeric:tabular-nums;margin-bottom:18px;font-size:11px;font-weight:600}.pillar h4{letter-spacing:-.005em;margin:0;font-size:15px;font-weight:600}.pillar p{color:var(--fg-muted);margin:0;font-size:13px;line-height:1.5}.pillar-count{color:var(--fg-subtle);font-variant-numeric:tabular-nums;margin-top:14px;font-size:12px}.section{margin:var(--section-y) 0}.section-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:28px;display:flex}.section-head h2{letter-spacing:-.02em;text-wrap:balance;max-width:580px;margin:0;font-size:32px;font-weight:600;line-height:1.1}.section-head p{color:var(--fg-muted);max-width:540px;margin:6px 0 0;font-size:15px}.track-card,.course-card{border:1px solid var(--border);background:var(--bg-elevated);cursor:pointer;text-align:left;font:inherit;color:inherit;border-radius:12px;flex-direction:column;gap:12px;padding:22px;transition:border-color .12s,transform .12s,box-shadow .12s;display:flex}.track-card:hover,.course-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-lift)}.track-card-head,.course-card-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.track-card h3,.course-card h3{letter-spacing:-.01em;margin:0;font-size:17px;font-weight:600;line-height:1.25}.track-card p,.course-card p{color:var(--fg-muted);margin:0;font-size:13.5px;line-height:1.5}.track-meta,.course-meta{border-top:1px dashed var(--border);color:var(--fg-subtle);align-items:center;gap:12px;margin-top:auto;padding-top:12px;font-size:12px;display:flex}.track-meta span,.course-meta span{align-items:center;gap:5px;display:inline-flex}.course-card .course-modules{flex-direction:column;gap:4px;margin:4px 0 0;padding:0;list-style:none;display:flex}.course-card .course-modules li{color:var(--fg-muted);gap:8px;font-size:12.5px;display:flex}.course-card .course-modules li:before{content:"·";color:var(--fg-faint)}.with-filters{grid-template-columns:220px 1fr;align-items:start;gap:36px;display:grid}@media (max-width:1180px){.with-filters{grid-template-columns:200px 1fr;gap:24px}}@media (max-width:1000px){.with-filters{grid-template-columns:1fr;gap:16px}.filters-side{border:1px solid var(--border);background:var(--bg-elevated);border-radius:10px;flex-flow:wrap;align-items:center;gap:12px 18px;padding:12px 14px;position:static}.filters-side .filter-group{flex:none;min-width:0}.filters-side .filter-group h5{margin:0 0 6px;font-size:10.5px}.filters-side .filter-list{flex-flow:wrap;gap:6px}.filters-side .filter-row{border:1px solid var(--border);background:var(--bg);border-radius:999px;width:auto;padding:4px 10px;font-size:12.5px}.filters-side .filter-row[aria-pressed=true]{background:var(--fg);color:var(--bg-elevated);border-color:var(--fg)}.filters-side .filter-row .count{opacity:.6;margin-left:4px}.filters-side .filter-group:first-child{flex:100%}.filters-side .filter-group:first-child input.twk-field{width:100%!important}}.filters-side{top:calc(var(--topbar-h) + 16px);flex-direction:column;gap:22px;display:flex;position:sticky}.filter-group h5{text-transform:uppercase;letter-spacing:.08em;color:var(--fg-subtle);margin:0 0 10px;font-size:11px;font-weight:600}.filter-list{flex-direction:column;gap:2px;display:flex}.filter-row{cursor:pointer;color:var(--fg-muted);text-align:left;font-size:13px;font:inherit;background:0 0;border:0;border-radius:6px;justify-content:space-between;align-items:center;gap:8px;width:100%;padding:4px 8px;display:flex}.filter-row:hover{background:var(--bg-sunken);color:var(--fg)}.filter-row[aria-pressed=true]{background:var(--bg-sunken);color:var(--fg);font-weight:550}.filter-row .count{color:var(--fg-faint);font-variant-numeric:tabular-nums;font-size:11.5px}.filter-row .check{border:1.2px solid var(--border-strong);background:var(--bg-elevated);border-radius:3px;flex:none;place-items:center;width:14px;height:14px;display:grid}.filter-row[aria-pressed=true] .check{background:var(--fg);border-color:var(--fg);color:var(--bg-elevated)}.tool-card{border:1px solid var(--border);background:var(--bg-elevated);cursor:pointer;text-align:left;font:inherit;color:inherit;border-radius:12px;flex-direction:column;gap:10px;padding:22px;display:flex}.tool-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-lift)}.tool-card-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.tool-logo{color:#fff;letter-spacing:-.01em;border-radius:9px;flex:none;place-items:center;width:38px;height:38px;font-size:14px;font-weight:600;display:grid}.tool-card h3{letter-spacing:-.005em;margin:0;font-size:16px;font-weight:600}.tool-card .tool-provider{color:var(--fg-subtle);margin-top:2px;font-size:11.5px}.tool-card p{color:var(--fg-muted);margin:0;font-size:13px;line-height:1.5}.tool-card .tool-tags{flex-wrap:wrap;gap:5px;margin-top:auto;padding-top:10px;display:flex}.prompt-card{border:1px solid var(--border);background:var(--bg-elevated);border-radius:12px;flex-direction:column;gap:10px;padding:20px 20px 16px;display:flex}.prompt-card h3{letter-spacing:-.005em;margin:0;font-size:15.5px;font-weight:600}.prompt-card .prompt-meta{color:var(--fg-subtle);flex-wrap:wrap;align-items:center;gap:8px;font-size:11.5px;display:flex}.prompt-text{background:var(--bg-sunken);color:var(--fg);border:1px solid var(--border);white-space:pre-wrap;word-break:break-word;border-radius:8px;max-height:8.2em;padding:12px 14px;font-family:JetBrains Mono,SF Mono,ui-monospace,monospace;font-size:12.5px;line-height:1.55;position:relative;overflow:hidden}.prompt-text.expanded{max-height:none}.prompt-text:after{content:"";background:linear-gradient(to top, var(--bg-sunken), transparent);pointer-events:none;height:38px;position:absolute;bottom:0;left:0;right:0}.prompt-text.expanded:after{display:none}.prompt-foot{color:var(--fg-subtle);justify-content:space-between;align-items:center;gap:12px;font-size:12px;display:flex}.copy-btn{border:1px solid var(--border);background:var(--bg-elevated);cursor:pointer;color:var(--fg-muted);border-radius:6px;align-items:center;gap:6px;padding:6px 10px;font-size:12px;display:inline-flex}.copy-btn:hover{border-color:var(--fg);color:var(--fg)}.copy-btn.copied{color:#2e5b34;background:var(--tone-practice-bg);border-color:#4a8550}.wf-card{border:1px solid var(--border);background:var(--bg-elevated);cursor:pointer;text-align:left;font:inherit;color:inherit;border-radius:12px;flex-direction:column;gap:14px;padding:22px;display:flex}.wf-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-lift)}.wf-card h3{letter-spacing:-.01em;margin:0;font-size:17px;font-weight:600}.wf-card p{color:var(--fg-muted);margin:0;font-size:13.5px;line-height:1.5}.wf-steps{flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;display:flex}.wf-step{background:var(--bg-sunken);color:var(--fg-muted);font-variant-numeric:tabular-nums;border:1px solid var(--border);border-radius:5px;padding:4px 8px;font-size:11.5px}.wf-arrow{color:var(--fg-faint);font-size:11px}.wf-tools{flex-wrap:wrap;gap:4px;display:flex}.compare-table{border-collapse:separate;border-spacing:0;border:1px solid var(--border);background:var(--bg-elevated);border-radius:12px;width:100%;font-size:13.5px;overflow:hidden}.compare-table th,.compare-table td{text-align:left;border-bottom:1px solid var(--border);vertical-align:top;padding:14px 16px}.compare-table thead th{text-transform:uppercase;letter-spacing:.06em;color:var(--fg-subtle);background:var(--bg-sunken);font-size:12px;font-weight:600}.compare-table tbody tr:hover{background:var(--bg)}.compare-table tbody tr:last-child td{border-bottom:0}.compare-table td:first-child,.compare-table th:first-child{color:var(--fg);background:inherit;border-right:1px solid var(--border);min-width:180px;font-weight:600;position:sticky;left:0}.compare-table .score{font-variant-numeric:tabular-nums;align-items:center;gap:8px;display:inline-flex}.compare-table .bar{background:var(--bg-sunken);border-radius:3px;width:56px;height:5px;position:relative;overflow:hidden}.compare-table .bar i{background:var(--accent);width:var(--w,0%);border-radius:3px;position:absolute;inset:0}.compare-best{color:var(--accent-soft-fg);font-weight:600;background:var(--accent-tint)!important}.compare-foot{color:var(--fg-subtle);justify-content:space-between;margin-top:14px;font-size:12px;display:flex}.lesson-shell{max-width:1280px;padding:var(--s-10) var(--s-10) var(--s-16);grid-template-columns:240px minmax(0,720px) 220px;align-items:start;gap:48px;margin:0 auto;display:grid}@media (max-width:1180px){.lesson-shell{grid-template-columns:220px 1fr}.lesson-shell .lesson-toc{display:none}}@media (max-width:880px){.lesson-shell{grid-template-columns:1fr}.lesson-shell .lesson-side{display:none}}.lesson-side{top:calc(var(--topbar-h) + 24px);font-size:13px;position:sticky}.lesson-side .side-course{color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;font-size:11px}.lesson-side h4{letter-spacing:-.005em;margin:0 0 14px;font-size:14px;font-weight:600}.lesson-side .module{text-transform:uppercase;letter-spacing:.06em;color:var(--fg-subtle);margin:16px 0 6px;font-size:11px}.lesson-side .les{color:var(--fg-muted);cursor:pointer;border-left:2px solid #0000;border-radius:6px;align-items:center;gap:8px;padding:5px 8px;font-size:12.5px;display:flex}.lesson-side .les:hover{background:var(--bg-sunken);color:var(--fg)}.lesson-side .les.active{background:var(--bg-sunken);color:var(--fg);border-left-color:var(--accent);font-weight:550}.lesson-side .les .num{color:var(--fg-faint);font-variant-numeric:tabular-nums;flex:none;width:18px;font-size:11px}.lesson-side .les.done .num{color:#4a8550}.lesson-side .les.done .num:after{content:"✓"}.lesson-toc{top:calc(var(--topbar-h) + 24px);font-size:12.5px;position:sticky}.lesson-toc h5{text-transform:uppercase;letter-spacing:.08em;color:var(--fg-subtle);margin:0 0 10px;font-size:11px}.lesson-toc a{color:var(--fg-muted);border-left:2px solid #0000;margin-left:-10px;padding:4px 0 4px 10px;display:block}.lesson-toc a.active{color:var(--fg);border-left-color:var(--accent)}.lesson-progress-bar{top:var(--topbar-h);z-index:40;background:var(--border);height:3px;position:sticky}.lesson-progress-bar i{background:var(--accent);height:100%;width:var(--p,0%);transition:width .2s;display:block}.lesson-head .eyebrow{margin-bottom:16px}.lesson-head h1{letter-spacing:-.025em;text-wrap:balance;margin:0 0 14px;font-size:40px;font-weight:600;line-height:1.1}.lesson-head .lesson-sum{color:var(--fg-muted);text-wrap:pretty;max-width:640px;font-size:17px;line-height:1.55}.lesson-meta-row{border-top:1px solid var(--border);border-bottom:1px solid var(--border);color:var(--fg-subtle);flex-wrap:wrap;align-items:center;gap:14px;margin:22px 0 30px;padding:14px 0;font-size:12.5px;display:flex}.lesson-meta-row .dot{background:var(--fg-faint);border-radius:50%;width:3px;height:3px}.lesson-body{color:#25282f;font-size:16.5px;line-height:1.65}.lesson-body h2{letter-spacing:-.015em;scroll-margin-top:calc(var(--topbar-h) + 24px);margin:36px 0 12px;font-size:24px;font-weight:600}.lesson-body h3{letter-spacing:-.005em;margin:24px 0 8px;font-size:18px;font-weight:600}.lesson-body p{text-wrap:pretty;margin:0 0 14px}.lesson-body ul,.lesson-body ol{margin:6px 0 18px;padding-left:22px}.lesson-body li{margin:4px 0}.lesson-body code{background:var(--bg-sunken);border:1px solid var(--border);border-radius:4px;padding:1px 5px;font-family:JetBrains Mono,SF Mono,ui-monospace,monospace;font-size:.9em}.lesson-body strong{font-weight:600}.l-block{border-radius:12px;margin:18px 0;padding:20px 22px 22px;position:relative}.l-block-head{align-items:center;gap:10px;margin-bottom:10px;display:flex}.l-block-icon{color:#fff;border-radius:8px;flex:none;place-items:center;width:30px;height:30px;display:grid}.l-block-icon svg{width:16px;height:16px}.l-block-label{text-transform:uppercase;letter-spacing:.08em;font-size:11.5px;font-weight:600}.l-block-title{letter-spacing:-.005em;font-size:16px;font-weight:600}.l-block-body{font-size:15px;line-height:1.55}.l-block-body p:last-child{margin-bottom:0}.l-block ul{margin:4px 0 0}.t-practice{background:var(--tone-practice-bg)}.t-practice .l-block-icon{background:var(--tone-practice-icon)}.t-practice .l-block-label{color:var(--tone-practice-fg)}.t-prompt{background:var(--tone-prompt-bg)}.t-prompt .l-block-icon{background:var(--tone-prompt-icon)}.t-prompt .l-block-label{color:var(--tone-prompt-fg)}.t-mistakes{background:var(--tone-mistakes-bg)}.t-mistakes .l-block-icon{background:var(--tone-mistakes-icon)}.t-mistakes .l-block-label{color:var(--tone-mistakes-fg)}.t-hacks{background:var(--tone-hacks-bg)}.t-hacks .l-block-icon{background:var(--tone-hacks-icon)}.t-hacks .l-block-label{color:var(--tone-hacks-fg)}.t-when{background:var(--tone-when-bg)}.t-when .l-block-icon{background:var(--tone-when-icon)}.t-when .l-block-label{color:var(--tone-when-fg)}.t-not{background:var(--tone-not-bg)}.t-not .l-block-icon{background:var(--tone-not-icon)}.t-not .l-block-label{color:var(--tone-not-fg)}.t-sources{background:var(--tone-sources-bg)}.t-sources .l-block-icon{background:var(--tone-sources-icon)}.t-sources .l-block-label{color:var(--tone-sources-fg)}[data-lesson-blocks=outline] .l-block{background:var(--bg-elevated);border:1px solid var(--border);border-left:3px solid var(--accent)}[data-lesson-blocks=outline] .l-block.t-practice{border-left-color:var(--tone-practice-icon)}[data-lesson-blocks=outline] .l-block.t-prompt{border-left-color:var(--tone-prompt-icon)}[data-lesson-blocks=outline] .l-block.t-mistakes{border-left-color:var(--tone-mistakes-icon)}[data-lesson-blocks=outline] .l-block.t-hacks{border-left-color:var(--tone-hacks-icon)}[data-lesson-blocks=outline] .l-block.t-when{border-left-color:var(--tone-when-icon)}[data-lesson-blocks=outline] .l-block.t-not{border-left-color:var(--tone-not-icon)}[data-lesson-blocks=outline] .l-block.t-sources{border-left-color:var(--tone-sources-icon)}[data-lesson-blocks=plain] .l-block{border-top:1px solid var(--border);background:0 0;border-radius:0;margin-top:30px;padding:22px 0 0}[data-lesson-blocks=plain] .l-block-icon{display:none}[data-lesson-blocks=plain] .l-block-label{letter-spacing:.12em}.prompt-inline{white-space:pre-wrap;background:#ffffff8c;border:1px solid #4c5fcc2e;border-radius:8px;margin-top:8px;padding:12px 14px;font-family:JetBrains Mono,SF Mono,ui-monospace,monospace;font-size:13px;line-height:1.55}.quiz{border:1px solid var(--border);background:var(--bg-elevated);border-radius:14px;margin:36px 0 28px;padding:24px 26px 26px}.quiz-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.quiz-head h3{letter-spacing:-.01em;margin:0;font-size:18px;font-weight:600}.quiz-q{margin-bottom:18px}.quiz-q-text{margin-bottom:10px;font-size:15.5px;font-weight:550}.quiz-options{flex-direction:column;gap:6px;display:flex}.quiz-opt{border:1px solid var(--border);background:var(--bg);cursor:pointer;font:inherit;color:inherit;text-align:left;border-radius:9px;align-items:flex-start;gap:10px;padding:10px 14px;display:flex}.quiz-opt:hover{border-color:var(--fg)}.quiz-opt .mark{border:1.5px solid var(--border-strong);width:18px;height:18px;color:var(--fg-subtle);border-radius:50%;flex:none;place-items:center;margin-top:1px;font-size:10px;font-weight:600;display:grid}.quiz-opt.selected{border-color:var(--fg)}.quiz-opt.selected .mark{border-color:var(--fg);background:var(--fg);color:var(--bg-elevated)}.quiz-opt.correct{background:var(--tone-practice-bg);border-color:#4a8550}.quiz-opt.correct .mark{color:#fff;background:#4a8550;border-color:#4a8550}.quiz-opt.wrong{background:var(--tone-mistakes-bg);border-color:#c66a48}.quiz-opt.wrong .mark{color:#fff;background:#c66a48;border-color:#c66a48}.quiz-explain{background:var(--bg-sunken);border-left:3px solid var(--accent);color:var(--fg-muted);border-radius:0 8px 8px 0;margin-top:8px;padding:10px 14px;font-size:13.5px;line-height:1.5}.quiz-foot{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:22px;padding-top:18px;display:flex}.quiz-score{color:var(--fg-muted);font-size:13px}.complete-bar{background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-top:36px;padding:18px 22px;display:flex}.complete-bar.done{background:var(--tone-practice-bg);border-color:#c5d8c4}.complete-bar p{color:var(--fg-muted);margin:0;font-size:14px}.dash-grid{grid-template-columns:1.4fr 1fr;gap:24px;display:grid}@media (max-width:980px){.dash-grid{grid-template-columns:1fr}}.stat-row{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;display:grid}@media (max-width:720px){.stat-row{grid-template-columns:repeat(2,1fr)}}.stat{border:1px solid var(--border);background:var(--bg-elevated);border-radius:10px;padding:16px 18px}.stat b{letter-spacing:-.018em;font-size:26px;font-weight:600;line-height:1.1;display:block}.stat span{color:var(--fg-subtle);font-size:12.5px}.stat .delta{color:#4a8550;margin-top:6px;font-size:11.5px;font-weight:500}.dash-list{flex-direction:column;gap:0;display:flex}.dash-list-item{border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:14px 0;display:flex}.dash-list-item:last-child{border-bottom:0}.dash-list-item .prog-ring{flex:none;width:36px;height:36px}.dash-list-item .info{flex:1;min-width:0}.dash-list-item .info b{letter-spacing:-.005em;font-size:14px;font-weight:550;display:block}.dash-list-item .info span{color:var(--fg-subtle);font-size:12.5px}.dash-list-item .info .next{color:var(--fg-muted);margin-top:2px;font-size:12px}.heatmap{grid-template-columns:repeat(26,1fr);gap:3px;margin-top:14px;display:grid}.heat-cell{aspect-ratio:1;background:var(--bg-sunken);border-radius:3px}.heat-cell.l1{background:#dfe5f6}.heat-cell.l2{background:#b9c6ee}.heat-cell.l3{background:#7a8ee0}.heat-cell.l4{background:var(--accent)}.dash-section h3{letter-spacing:-.01em;margin:0 0 4px;font-size:17px;font-weight:600}.dash-section .dash-section-sub{color:var(--fg-subtle);margin-bottom:14px;font-size:13px}.course-shell{grid-template-columns:minmax(0,1fr) 320px;align-items:start;gap:36px;display:grid}@media (max-width:980px){.course-shell{grid-template-columns:1fr}}.course-aside{top:calc(var(--topbar-h) + 16px);border:1px solid var(--border);background:var(--bg-elevated);border-radius:12px;flex-direction:column;gap:16px;padding:22px;display:flex;position:sticky}.course-aside .progress-track{background:var(--bg-sunken);border-radius:3px;height:6px;overflow:hidden}.course-aside .progress-track i{background:var(--accent);height:100%;width:var(--p,0%);border-radius:3px;display:block}.course-aside .aside-meta{border-top:1px dashed var(--border);border-bottom:1px dashed var(--border);grid-template-columns:1fr 1fr;gap:14px;padding:12px 0;display:grid}.course-aside .aside-meta span{color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.05em;font-size:11px}.course-aside .aside-meta b{margin-top:2px;font-size:14px;font-weight:600;display:block}.module-list{flex-direction:column;gap:14px;margin-top:12px;display:flex}.module{border:1px solid var(--border);background:var(--bg-elevated);border-radius:12px;padding:18px 22px 6px}.module-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.module-head h4{letter-spacing:-.005em;margin:0;font-size:16px;font-weight:600}.module-head .module-meta{color:var(--fg-subtle);font-size:11.5px}.module-lessons{flex-direction:column;display:flex}.les-row{border-top:1px solid var(--border-faint);cursor:pointer;align-items:center;gap:14px;padding:12px 0;display:flex}.les-row:first-child{border-top:0}.les-row:hover{background:var(--bg)}.les-row .les-num{width:22px;color:var(--fg-faint);font-variant-numeric:tabular-nums;font-size:12px}.les-row .les-info{flex:1}.les-row .les-info b{font-size:14px;font-weight:500;display:block}.les-row .les-info span{color:var(--fg-subtle);font-size:12px}.les-row .les-time{color:var(--fg-subtle);align-items:center;gap:6px;font-size:12px;display:flex}.les-row .les-mark{border:1.5px solid var(--border-strong);color:#0000;border-radius:50%;flex:none;place-items:center;width:18px;height:18px;display:grid}.les-row.done .les-mark{color:#fff;background:#4a8550;border-color:#4a8550}.foot{border-top:1px solid var(--border);margin-top:calc(72px * var(--density));padding:36px var(--s-12) 60px;color:var(--fg-subtle);font-size:12.5px;line-height:1.6}.foot-grid{max-width:var(--content-max);grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;margin:0 auto;display:grid}@media (max-width:880px){.foot-grid{grid-template-columns:1fr 1fr}}.foot-col h5{text-transform:uppercase;letter-spacing:.08em;color:var(--fg);margin:0 0 10px;font-size:11px}.foot-col a{color:var(--fg-muted);padding:3px 0;display:block}.foot-col a:hover{color:var(--fg)}.foot-legal{max-width:var(--content-max);border-top:1px solid var(--border);color:var(--fg-faint);margin:32px auto 0;padding-top:22px;font-size:11.5px;line-height:1.55}.fade-in{animation:.28s fade-in}@keyframes fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.col{flex-direction:column;gap:8px;display:flex}.between{justify-content:space-between}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.sb-cta{border:1px solid var(--border);background:var(--bg-elevated);cursor:pointer;text-align:left;font:inherit;color:inherit;border-radius:10px;align-items:center;gap:10px;width:100%;margin-top:6px;padding:12px;display:flex}.sb-cta:hover{border-color:var(--border-strong)}.sb-cta-icon{background:var(--accent);color:#fff;border-radius:7px;flex:none;place-items:center;width:28px;height:28px;display:grid}.sb-cta-icon svg{width:14px;height:14px}.sb-cta-info{flex-direction:column;min-width:0;display:flex}.sb-cta-info b{letter-spacing:-.005em;font-size:12px;font-weight:600}.sb-cta-info span{color:var(--fg-subtle);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.sb-divider{background:var(--border);height:1px;margin:4px -4px}.sb-status{color:var(--fg-subtle);align-items:center;gap:6px;padding:0 8px;font-size:11px;display:flex}.sb-status .dot{background:#4a8550;border-radius:50%;width:6px;height:6px}.topbar{gap:14px;padding:0 28px}.topbar-mid{border-left:1px solid var(--border);color:var(--fg-subtle);align-items:center;gap:8px;margin-left:4px;padding-left:14px;font-size:12px;display:flex}.topbar-mid .live-dot{background:#4a8550;border-radius:50%;width:6px;height:6px;box-shadow:0 0 0 3px #4a85502e}@media (max-width:1100px){.topbar-mid{display:none}.search-input{width:200px}}.display-num{letter-spacing:-.05em;color:var(--fg);font-feature-settings:"ss01";font-size:clamp(120px,14vw,220px);font-weight:600;line-height:.85}.display-num em{color:var(--accent);font-style:normal}.display-h{letter-spacing:-.035em;text-wrap:balance;font-size:clamp(52px,6vw,96px);font-weight:600;line-height:.96}.display-thin{font-weight:200}.hero-row{grid-template-columns:1.4fr 1fr;align-items:end;gap:40px;display:grid}@media (max-width:900px){.hero-row{grid-template-columns:1fr}}.hero-art{background:var(--bg-elevated);border:1px solid var(--border);border-radius:14px;height:340px;position:relative;overflow:hidden}.hero-art svg{width:100%;height:100%;display:block}.hero-art-cap{color:var(--fg-subtle);letter-spacing:.02em;text-transform:uppercase;font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;position:absolute;bottom:14px;left:16px;right:16px}.bigstats{border-top:1px solid var(--border);border-bottom:1px solid var(--border);grid-template-columns:repeat(4,1fr);gap:0;margin:48px 0;padding:36px 0;display:grid}@media (max-width:760px){.bigstats{grid-template-columns:repeat(2,1fr)}}.bigstat{border-right:1px solid var(--border);padding:0 28px}.bigstat:last-child{border-right:0}.bigstat b{letter-spacing:-.03em;font-feature-settings:"ss01";font-size:clamp(40px,5vw,68px);font-weight:600;line-height:1;display:block}.bigstat b em{color:var(--accent);font-style:normal}.bigstat .lbl{text-transform:uppercase;letter-spacing:.08em;color:var(--fg-subtle);margin-top:14px;font-size:12px}.bigstat .desc{color:var(--fg-muted);margin-top:8px;font-size:13px;line-height:1.45}.pullquote{text-align:left;max-width:800px;margin:56px auto;padding:0 24px}.pullquote q{letter-spacing:-.018em;text-wrap:balance;color:var(--fg);quotes:none;font-size:clamp(24px,3.2vw,36px);font-weight:500;line-height:1.25;display:block}.pullquote q:before{color:var(--accent);margin-right:4px}.pullquote q:after{color:var(--accent);margin-left:2px}.pullquote footer{color:var(--fg-subtle);align-items:center;gap:10px;margin-top:18px;font-size:13px;display:flex}.pullquote footer .av{color:#fff;background:linear-gradient(135deg,#d5cfb8,#b8b1a0);border-radius:50%;place-items:center;width:32px;height:32px;font-size:11px;font-weight:600;display:grid}.steps{grid-template-columns:repeat(3,1fr);gap:16px;margin-top:22px;display:grid}@media (max-width:760px){.steps{grid-template-columns:1fr}}.step{border:1px solid var(--border);background:var(--bg-elevated);border-radius:12px;padding:26px 22px 22px;position:relative}.step-num{color:var(--fg-faint);letter-spacing:.08em;margin-bottom:32px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;display:block}.step h4{letter-spacing:-.01em;margin:0 0 6px;font-size:18px;font-weight:600}.step p{color:var(--fg-muted);margin:0;font-size:13.5px;line-height:1.55}.step-glyph{width:32px;height:32px;color:var(--fg-faint);position:absolute;top:22px;right:22px}.featured{background:var(--bg-elevated);border:1px solid var(--border);border-radius:16px;grid-template-columns:1fr 1fr;gap:0;min-height:320px;margin:36px 0;display:grid;overflow:hidden}@media (max-width:900px){.featured{grid-template-columns:1fr}}.featured-info{flex-direction:column;justify-content:center;gap:14px;padding:36px 38px;display:flex}.featured-info .tag{color:var(--accent);letter-spacing:.08em;text-transform:uppercase;font-size:11px;font-weight:600}.featured-info h3{letter-spacing:-.022em;text-wrap:balance;margin:0;font-size:clamp(28px,3.4vw,38px);font-weight:600;line-height:1.1}.featured-info p{color:var(--fg-muted);max-width:460px;margin:0;font-size:15px;line-height:1.55}.featured-art{background:var(--bg-sunken);border-left:1px solid var(--border);position:relative;overflow:hidden}.featured-art svg{width:100%;height:100%;display:block}.img-ph{background:repeating-linear-gradient(135deg, var(--bg-sunken), var(--bg-sunken) 6px, var(--bg) 6px, var(--bg) 12px);border:1px solid var(--border);color:var(--fg-subtle);letter-spacing:.02em;text-transform:uppercase;text-align:center;border-radius:10px;place-items:center;min-height:160px;padding:12px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;display:grid;position:relative}.tcard{border:1px solid var(--border);background:var(--bg-elevated);border-radius:12px;flex-direction:column;gap:14px;padding:22px;display:flex}.tcard q{color:var(--fg);text-wrap:pretty;quotes:"«" "»";font-size:15px;line-height:1.5}.tcard footer{color:var(--fg-subtle);align-items:center;gap:10px;margin-top:auto;font-size:12.5px;display:flex}.tcard footer .av{color:#fff;letter-spacing:.02em;border-radius:50%;flex:none;place-items:center;width:30px;height:30px;font-size:11px;font-weight:600;display:grid}.tcard footer b{color:var(--fg);font-size:13px;font-weight:600;display:block}.logos{border-top:1px solid var(--border);border-bottom:1px solid var(--border);color:var(--fg-subtle);flex-wrap:wrap;align-items:center;gap:32px;margin:32px 0;padding:20px 0;font-size:13px;display:flex}.logos b{color:var(--fg);letter-spacing:-.005em;margin-right:8px;font-weight:600}.logos-list{flex-wrap:wrap;align-items:center;gap:28px;font-weight:500;display:flex}.logos-list span{letter-spacing:-.01em;color:var(--fg-muted);font-family:Mona Sans,sans-serif}.faq{flex-direction:column;margin:20px 0;display:flex}.faq-item{border-top:1px solid var(--border);padding:22px 0}.faq-item:last-child{border-bottom:1px solid var(--border)}.faq-q{cursor:pointer;text-align:left;width:100%;font:inherit;color:inherit;background:0 0;border:0;justify-content:space-between;align-items:flex-start;gap:20px;padding:0;display:flex}.faq-q span:first-child{letter-spacing:-.01em;text-wrap:balance;flex:1;font-size:17px;font-weight:600}.faq-q .ic{border:1.5px solid var(--border-strong);width:22px;height:22px;color:var(--fg-subtle);border-radius:50%;flex:none;place-items:center;margin-top:2px;font-size:14px;font-weight:400;display:grid}.faq-a{color:var(--fg-muted);max-width:720px;margin:10px 0 0;font-size:15px;line-height:1.6}.tagcloud{flex-wrap:wrap;gap:6px 8px;margin:14px 0 4px;display:flex}.tag{border:1px solid var(--border);color:var(--fg-muted);background:var(--bg-elevated);cursor:pointer;white-space:nowrap;border-radius:999px;padding:4px 10px;font-size:12px}.tag:hover{border-color:var(--border-strong);color:var(--fg)}.model-cell{align-items:center;gap:10px;display:flex}.model-cell .swatch{color:#fff;letter-spacing:.02em;border-radius:6px;flex:none;place-items:center;width:22px;height:22px;font-size:10px;font-weight:600;display:grid}.wf-diagram{flex-direction:column;gap:0;margin-top:14px;display:flex}.wf-line{border:1px solid var(--border);background:var(--bg-elevated);border-radius:10px;margin-bottom:8px;padding:14px 14px 14px 50px;position:relative}.wf-line .n{background:var(--accent-soft);width:24px;height:24px;color:var(--accent-soft-fg);font-variant-numeric:tabular-nums;border-radius:50%;place-items:center;font-size:11px;font-weight:600;display:grid;position:absolute;top:14px;left:14px}.wf-line b{letter-spacing:-.005em;font-size:14px;font-weight:600;display:block}.wf-line span{color:var(--fg-muted);font-size:13px}.track-hero{border:1px solid var(--border);background:var(--bg-elevated);border-radius:16px;grid-template-columns:1fr auto;align-items:center;gap:32px;margin:26px 0 32px;padding:36px 40px;display:grid}@media (max-width:760px){.track-hero{grid-template-columns:1fr;padding:26px}}.track-hero h1{letter-spacing:-.025em;margin:8px 0 12px;font-size:clamp(36px,4.6vw,56px);font-weight:600;line-height:1.04}.track-hero p{color:var(--fg-muted);max-width:580px;margin:0;font-size:17px;line-height:1.5}.track-glyph{background:var(--bg-sunken);width:140px;height:140px;color:var(--accent);border-radius:14px;place-items:center;display:grid}.track-glyph svg{width:80px;height:80px}.geom-bg{pointer-events:none;position:absolute;inset:0}.mobile-nav{display:none}@media (max-width:760px){.mobile-nav{z-index:60;background:var(--bg);display:block;position:sticky;top:0}@supports (color:color-mix(in lab, red, red)){.mobile-nav{background:color-mix(in srgb, var(--bg) 92%, transparent)}}.mobile-nav{-webkit-backdrop-filter:saturate(160%)blur(14px);border-bottom:1px solid var(--border)}.mobile-nav-bar{justify-content:space-between;align-items:center;height:56px;padding:0 16px;display:flex}.mobile-nav-toggle{border:1px solid var(--border);background:var(--bg-elevated);width:40px;height:40px;color:var(--fg);cursor:pointer;border-radius:8px;place-items:center;display:grid}.mobile-nav-menu{border-top:1px solid var(--border-faint);background:var(--bg);flex-direction:column;padding:8px 12px 16px;display:flex}.mobile-nav-menu a{color:var(--fg);border-radius:8px;padding:12px 10px;font-size:15px}.mobile-nav-menu a:active{background:var(--bg-sunken)}.mobile-nav-auth{border-top:1px solid var(--border-faint);gap:10px;margin-top:10px;padding-top:12px;display:flex}.mobile-nav-auth a{text-align:center;border:1px solid var(--border-strong);border-radius:8px;flex:1;font-size:14px}.topbar{padding:0 16px}.content{padding:24px 16px 56px}}@keyframes aia-spin{to{transform:rotate(360deg)}}.fav-btn{border:1px solid var(--border);background:var(--bg-elevated);width:32px;height:32px;color:var(--fg-subtle);cursor:pointer;border-radius:8px;flex:none;place-items:center;transition:color .12s,border-color .12s,background .12s;display:inline-grid}.fav-btn:hover{color:var(--fg);border-color:var(--border-strong)}.fav-btn.on{color:#d8a200;background:#fff9e6;border-color:#e6c200}.bug-report-fab{z-index:9000;background:var(--bg-card);border:1px solid var(--border);cursor:pointer;opacity:.55;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;transition:opacity .15s,box-shadow .15s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 2px 8px #00000024}.bug-report-fab:hover{opacity:1;box-shadow:0 4px 16px #0003}.bug-report-dialog{border:1px solid var(--border);background:var(--bg-card);width:min(420px,92vw);color:var(--fg);border-radius:12px;padding:24px;box-shadow:0 8px 32px #0000002e}.bug-report-dialog::backdrop{background:#0006}.bug-report-title{margin:0 0 14px;font-size:1rem;font-weight:600}.bug-report-textarea{border:1px solid var(--border);resize:vertical;background:var(--bg);width:100%;color:var(--fg);box-sizing:border-box;border-radius:8px;padding:10px 12px;font-size:.9rem}.bug-report-textarea:focus{outline:2px solid var(--accent);outline-offset:-1px}.bug-report-actions{justify-content:flex-end;gap:8px;margin-top:12px;display:flex}.bug-report-thanks{text-align:center;color:var(--accent);padding:12px 0;font-size:.95rem}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
