*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.mx-auto{margin-left:auto;margin-right:auto}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-8{margin-bottom:2rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.block{display:block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.h-11{height:2.75rem}.h-5{height:1.25rem}.h-8{height:2rem}.min-h-10{min-height:2.5rem}.min-h-11{min-height:2.75rem}.min-h-12{min-height:3rem}.min-h-dvh{min-height:100dvh}.w-11{width:2.75rem}.w-5{width:1.25rem}.w-8{width:2rem}.w-full{width:100%}.min-w-0{min-width:0px}.flex-1{flex:1 1 0%}.flex-none{flex:none}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.place-items-center{place-items:center}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:8px}.rounded-md{border-radius:6px}.border{border-width:1px}.border-l-4{border-left-width:4px}.border-border{border-color:var(--color-border)}.border-danger{border-color:var(--color-danger)}.border-secondary{border-color:var(--color-secondary)}.border-success{border-color:var(--color-success)}.border-warning{border-color:var(--color-warning)}.border-l-primary{border-left-color:var(--color-primary)}.bg-\[var\(--color-accent-soft\)\]{background-color:var(--color-accent-soft)}.bg-\[var\(--color-danger-soft\)\]{background-color:var(--color-danger-soft)}.bg-\[var\(--color-secondary-soft\)\]{background-color:var(--color-secondary-soft)}.bg-\[var\(--color-success-soft\)\]{background-color:var(--color-success-soft)}.bg-\[var\(--color-warning-soft\)\]{background-color:var(--color-warning-soft)}.bg-danger{background-color:var(--color-danger)}.bg-muted{background-color:var(--color-surface-muted)}.bg-primary{background-color:var(--color-primary)}.bg-success{background-color:var(--color-success)}.bg-surface{background-color:var(--color-surface)}.p-0{padding:0}.p-1{padding:.25rem}.p-3{padding:.75rem}.p-4{padding:1rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.text-left{text-align:left}.text-center{text-align:center}.font-brand{font-family:Aptos Display,Segoe UI Variable Display,Avenir Next,Montserrat,Trebuchet MS,sans-serif}.text-2xl{font-size:1.5rem;line-height:2rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-\[0\.7rem\]{font-size:.7rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.font-semibold{font-weight:600}.leading-relaxed{line-height:1.625}.leading-snug{line-height:1.375}.leading-tight{line-height:1.25}.text-accent{color:var(--color-accent)}.text-danger{color:var(--color-danger)}.text-secondary{color:var(--color-secondary)}.text-subtle{color:var(--color-text-subtle)}.text-success{color:var(--color-success)}.text-text{color:var(--color-text)}.text-warning{color:var(--color-warning)}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.accent-\[var\(--color-primary\)\]{accent-color:var(--color-primary)}.opacity-70{opacity:.7}.shadow-soft{--tw-shadow: var(--shadow-sm);--tw-shadow-colored: var(--shadow-sm);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-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,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root,html[data-theme=light]{color-scheme:light;--color-canvas: #f6f7f9;--color-surface: #ffffff;--color-surface-raised: #ffffff;--color-surface-muted: #eef1f5;--color-border: #d8dee8;--color-border-strong: #b8c1cf;--color-text: #1d232f;--color-text-muted: #596273;--color-text-subtle: #747f91;--color-inverse: #ffffff;--color-primary: #b42318;--color-primary-hover: #9f1f16;--color-primary-active: #842018;--color-primary-soft: #fff0ee;--color-primary-border: #f2b8b2;--color-primary-contrast: #ffffff;--color-secondary: #294c7a;--color-secondary-hover: #223f67;--color-secondary-soft: #edf4ff;--color-secondary-border: #b9d1f3;--color-accent: #007f73;--color-accent-soft: #e8f7f4;--color-accent-border: #9bd8cf;--color-success: #1f7a4d;--color-success-soft: #e9f7ef;--color-success-border: #a7d9bd;--color-warning: #a05f00;--color-warning-soft: #fff5df;--color-warning-border: #efc36f;--color-danger: #b42318;--color-danger-soft: #fff0ee;--color-danger-border: #f2b8b2;--shadow-sm: 0 1px 2px rgba(20, 25, 34, .08);--shadow-md: 0 8px 24px rgba(20, 25, 34, .12);--shadow-focus: 0 0 0 3px rgba(41, 76, 122, .28);--font-brand: "Aptos Display", "Segoe UI Variable Display", "Avenir Next", Montserrat, "Trebuchet MS", Inter, ui-sans-serif, system-ui, sans-serif;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-md: 1.0625rem;--text-lg: 1.25rem;--text-xl: 1.5rem;--line-tight: 1.2;--line-normal: 1.45;--line-relaxed: 1.65;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--tap-target: 44px;--app-max-width: 430px;--topbar-height: 64px}html[data-theme=dark]{color-scheme:dark;--color-canvas: #101114;--color-surface: #191b20;--color-surface-raised: #20232a;--color-surface-muted: #262a33;--color-border: #3c4350;--color-border-strong: #586171;--color-text: #eef1f6;--color-text-muted: #b8c0cd;--color-text-subtle: #929baa;--color-inverse: #15171c;--color-primary: #ff8a80;--color-primary-hover: #ffb4ab;--color-primary-active: #ffc8c2;--color-primary-soft: #421411;--color-primary-border: #8f342d;--color-primary-contrast: #2f0805;--color-secondary: #9ccaff;--color-secondary-hover: #c9e0ff;--color-secondary-soft: #102844;--color-secondary-border: #38608d;--color-accent: #72d9cb;--color-accent-soft: #073630;--color-accent-border: #257e72;--color-success: #7bd99f;--color-success-soft: #0e3320;--color-success-border: #2e7d50;--color-warning: #f3bf61;--color-warning-soft: #392700;--color-warning-border: #86600c;--color-danger: #ff8a80;--color-danger-soft: #421411;--color-danger-border: #8f342d;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .35);--shadow-md: 0 10px 28px rgba(0, 0, 0, .42);--shadow-focus: 0 0 0 3px rgba(156, 202, 255, .34)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){color-scheme:dark;--color-canvas: #101114;--color-surface: #191b20;--color-surface-raised: #20232a;--color-surface-muted: #262a33;--color-border: #3c4350;--color-border-strong: #586171;--color-text: #eef1f6;--color-text-muted: #b8c0cd;--color-text-subtle: #929baa;--color-inverse: #15171c;--color-primary: #ff8a80;--color-primary-hover: #ffb4ab;--color-primary-active: #ffc8c2;--color-primary-soft: #421411;--color-primary-border: #8f342d;--color-primary-contrast: #2f0805;--color-secondary: #9ccaff;--color-secondary-hover: #c9e0ff;--color-secondary-soft: #102844;--color-secondary-border: #38608d;--color-accent: #72d9cb;--color-accent-soft: #073630;--color-accent-border: #257e72;--color-success: #7bd99f;--color-success-soft: #0e3320;--color-success-border: #2e7d50;--color-warning: #f3bf61;--color-warning-soft: #392700;--color-warning-border: #86600c;--color-danger: #ff8a80;--color-danger-soft: #421411;--color-danger-border: #8f342d;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .35);--shadow-md: 0 10px 28px rgba(0, 0, 0, .42);--shadow-focus: 0 0 0 3px rgba(156, 202, 255, .34)}}*,*:before,*:after{box-sizing:border-box}html{min-height:100%;background:var(--color-canvas);font-size:16px;letter-spacing:0;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}body{min-height:100dvh;margin:0;background:var(--color-canvas);color:var(--color-text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.45;letter-spacing:0;-webkit-font-smoothing:antialiased}button,input,select,textarea{font:inherit;letter-spacing:0}button:focus-visible,a:focus-visible,select:focus-visible{outline:none;box-shadow:var(--shadow-focus)}#root{min-height:100dvh}.app-shell{min-height:100dvh;max-width:430px;margin:0 auto;background:var(--color-canvas)}.app-topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);min-height:calc(var(--topbar-height) + env(safe-area-inset-top));padding:calc(var(--space-3) + env(safe-area-inset-top)) var(--space-4) var(--space-3);background:color-mix(in srgb,var(--color-surface) 92%,transparent);border-bottom:1px solid var(--color-border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.main-topbar{overflow:hidden;background:linear-gradient(180deg,color-mix(in srgb,var(--color-secondary-soft) 24%,var(--color-surface)) 0%,var(--color-surface) 88%);border-bottom-color:color-mix(in srgb,var(--color-secondary-border) 58%,var(--color-border));box-shadow:0 4px 18px #1419220f}.main-topbar:before{position:absolute;right:0;bottom:0;left:0;height:3px;content:"";background:linear-gradient(90deg,var(--color-primary) 0 30%,var(--color-warning) 30% 66%,var(--color-accent) 66% 100%)}.main-topbar>*{position:relative;z-index:1}.welcome-topbar{position:relative;background:transparent;border-bottom:0;-webkit-backdrop-filter:none;backdrop-filter:none}.topbar-title{min-width:0}.app-brand-lockup{display:flex;flex:1 1 auto;min-width:0;align-items:center;gap:var(--space-3)}.app-logo-mark{position:relative;display:inline-flex;width:46px;height:44px;flex:0 0 auto}.app-logo-mark:before{position:absolute;inset:3px;content:"";background:linear-gradient(145deg,var(--color-primary-soft),var(--color-secondary-soft) 56%,var(--color-accent-soft));border:1px solid color-mix(in srgb,var(--color-secondary-border) 72%,transparent);border-radius:var(--radius-lg);transform:rotate(-4deg)}.app-logo-card{position:absolute;border:1px solid var(--color-border);border-radius:var(--radius-md)}.app-logo-card-back{inset:9px 10px 7px 5px;background:var(--color-warning-soft);border-color:var(--color-warning-border);transform:rotate(7deg)}.app-logo-card-front{inset:5px 5px 8px 10px;display:flex;flex-direction:column;gap:3px;padding:6px;background:var(--color-surface);border-color:var(--color-border-strong);box-shadow:var(--shadow-sm)}.app-logo-band{height:3px;background:linear-gradient(90deg,var(--color-primary) 0 32%,var(--color-warning) 32% 68%,var(--color-accent) 68% 100%);border-radius:999px}.app-logo-line{display:block;height:4px;background:var(--color-surface-muted);border-radius:999px}.app-logo-line.is-long{width:100%}.app-logo-line.is-short{width:68%}.app-logo-check{position:absolute;right:0;bottom:2px;display:inline-flex;align-items:center;justify-content:center;width:17px;height:17px;background:var(--color-accent);border:2px solid var(--color-surface);border-radius:999px;color:var(--color-inverse);font-size:.62rem;font-weight:860;line-height:1;box-shadow:var(--shadow-sm)}.app-name{margin:0;color:var(--color-text);font-family:var(--font-brand);font-size:var(--text-md);font-weight:880;line-height:1.08;letter-spacing:0;overflow-wrap:anywhere}.wordmark{display:inline-flex;align-items:baseline;gap:.16em;color:var(--color-text);letter-spacing:0}.wordmark-ccse{color:var(--color-primary);font-weight:900}.wordmark-trainer{color:var(--color-secondary);font-weight:850}.app-context{margin:2px 0 0;overflow:hidden;color:var(--color-text-muted);font-size:var(--text-xs);font-weight:700;line-height:var(--line-normal);text-overflow:ellipsis;overflow-wrap:anywhere}.topbar-actions{display:inline-flex;flex:0 0 auto;align-items:center;gap:var(--space-2)}.back-link{display:inline-flex;align-items:center;justify-content:center;width:var(--tap-target);height:var(--tap-target);flex:0 0 auto;padding:0;background:transparent;border:0;border-radius:999px;color:var(--color-text-muted);text-decoration:none}.back-link:hover{color:var(--color-secondary)}.back-link:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.back-link-glyph{width:24px;height:24px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2.3}.activity-start-topbar{justify-content:flex-start}.activity-start-topbar .topbar-title{flex:1 1 auto}.utility-pill{display:inline-flex;align-items:center;justify-content:center;min-width:var(--tap-target);min-height:var(--tap-target);padding:0 var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-muted);font-size:var(--text-xs);font-weight:760;line-height:1;text-decoration:none}.utility-pill:hover{background:var(--color-surface-muted);border-color:var(--color-border-strong);color:var(--color-text)}.language-dropdown{position:relative}.language-dropdown-menu{position:absolute;top:calc(100% + var(--space-2));right:0;z-index:40;display:grid;min-width:190px;gap:var(--space-1);padding:var(--space-1);background:color-mix(in srgb,var(--color-surface) 92%,transparent);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.language-dropdown-trigger{cursor:pointer}.settings-language-trigger{display:flex;width:100%;min-height:44px;align-items:center;justify-content:space-between;padding:0 var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:var(--text-sm);font-weight:720;text-align:left}.settings-language-trigger:after{display:inline-block;width:8px;height:8px;margin-left:var(--space-3);border-right:2px solid currentcolor;border-bottom:2px solid currentcolor;content:"";opacity:.7;transform:rotate(45deg) translateY(-2px)}.language-dropdown-option{display:flex;min-height:40px;align-items:center;justify-content:space-between;padding:0 var(--space-3);background:transparent;border:0;border-radius:var(--radius-md);color:var(--color-text);font-size:var(--text-sm);font-weight:720;text-align:left}.language-dropdown-option:hover,.language-dropdown-option[aria-checked=true]{background:var(--color-secondary-soft);color:var(--color-text)}.theme-toggle{display:inline-flex;align-items:center;gap:var(--space-2);min-height:var(--tap-target);padding:0 var(--space-2);background:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-muted)}.theme-toggle-label{color:var(--color-text-muted);font-size:var(--text-xs);font-weight:680}.theme-toggle-track{position:relative;width:42px;height:24px;background:var(--color-border-strong);border-radius:999px}.theme-toggle-thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;background:var(--color-surface);border-radius:50%;box-shadow:var(--shadow-sm);transition:transform .16s ease}html[data-theme=dark] .theme-toggle-thumb{transform:translate(18px)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .theme-toggle-thumb{transform:translate(18px)}}.screen{min-height:100dvh;padding:16px}.main-screen{background:linear-gradient(180deg,color-mix(in srgb,var(--color-secondary-soft) 44%,transparent) 0 132px,transparent 132px),var(--color-canvas)}.activity-card{position:relative;display:grid;grid-template-columns:46px minmax(0,1fr);gap:var(--space-3);align-items:start;overflow:hidden;padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:inherit;text-decoration:none;box-shadow:var(--shadow-sm)}.activity-card:before{position:absolute;top:0;bottom:0;left:0;width:5px;content:"";background:var(--color-secondary)}.activity-card:hover{background:var(--color-surface-raised);border-color:var(--color-border-strong);color:inherit}.activity-card.is-primary{border-color:var(--color-primary-border)}.activity-card.is-primary:before{background:var(--color-primary)}.activity-card.is-secondary{border-color:var(--color-secondary-border)}.activity-card.is-secondary:before{background:var(--color-secondary)}.activity-card.is-metrics{border-color:var(--color-accent-border)}.activity-card.is-metrics:before{background:var(--color-accent)}.activity-icon{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;flex:0 0 auto;background:var(--color-secondary-soft);border:1px solid var(--color-secondary-border);border-radius:var(--radius-lg);color:var(--color-secondary);font-family:var(--font-brand);font-size:var(--text-lg);font-weight:820;line-height:1}.activity-card.is-primary .activity-icon,.activity-icon.is-learning{background:var(--color-primary-soft);border-color:var(--color-primary-border);color:var(--color-primary)}.activity-card.is-metrics .activity-icon,.activity-icon.is-metrics{background:var(--color-accent-soft);border-color:var(--color-accent-border);color:var(--color-accent)}.activity-icon.is-compact{width:36px;height:36px;border-radius:var(--radius-md);font-size:var(--text-md)}.activity-content{display:flex;min-width:0;flex-direction:column;gap:var(--space-2)}.activity-title{color:var(--color-text);font-size:var(--text-base);font-weight:780;line-height:var(--line-tight)}.activity-copy{color:var(--color-text-muted);font-size:var(--text-sm);line-height:var(--line-normal);overflow-wrap:anywhere}.activity-action{color:var(--color-secondary);font-size:var(--text-sm);font-weight:760;line-height:var(--line-tight)}.activity-hero-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;flex:0 0 auto;background:var(--color-secondary-soft);border:1px solid var(--color-secondary-border);border-radius:var(--radius-lg);color:var(--color-secondary);font-family:var(--font-brand);font-size:var(--text-xl);font-weight:900;line-height:1}.activity-hero-icon.is-learning{background:var(--color-primary-soft);border-color:var(--color-primary-border);color:var(--color-primary)}.welcome-screen{position:relative;display:flex;min-height:calc(100dvh - var(--topbar-height));flex-direction:column;justify-content:space-between;gap:var(--space-5);overflow:hidden}.welcome-splash{gap:var(--space-6);min-height:calc(100dvh - var(--topbar-height));padding-top:var(--space-5);background:var(--color-canvas)}.welcome-splash:before{position:absolute;inset:0 0 auto;height:238px;content:"";background:linear-gradient(145deg,var(--color-primary-soft) 0%,var(--color-secondary-soft) 54%,var(--color-accent-soft) 100%);clip-path:polygon(0 0,100% 0,100% 78%,0 100%)}.welcome-splash:after{position:absolute;top:108px;right:var(--space-4);left:var(--space-4);height:96px;content:"";background:repeating-linear-gradient(-8deg,transparent 0 15px,color-mix(in srgb,var(--color-surface) 52%,transparent) 15px 16px);border:1px solid color-mix(in srgb,var(--color-border) 56%,transparent);border-radius:var(--radius-lg);opacity:0;transform:rotate(-2deg)}.welcome-splash>*{position:relative;z-index:1}.section{display:flex;flex-direction:column;gap:var(--space-3)}.welcome-identity{display:flex;flex-direction:column;align-items:center;gap:var(--space-5);padding-top:var(--space-2);text-align:center}.brand-mark{position:relative;display:inline-flex;width:156px;height:142px;align-items:center;justify-content:center;overflow:visible;background:transparent;border:0;border-radius:0;box-shadow:none}.brand-mark:before{position:absolute;inset:18px 2px 4px;content:"";background:color-mix(in srgb,var(--color-secondary-soft) 78%,var(--color-surface));border:1px solid var(--color-secondary-border);border-radius:var(--radius-lg);transform:rotate(-5deg)}.brand-card{position:absolute;border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.brand-card-back{inset:18px 20px 20px;background:var(--color-warning-soft);border-color:var(--color-warning-border);transform:rotate(6deg)}.brand-card-front{right:16px;bottom:10px;left:12px;display:flex;min-height:102px;flex-direction:column;align-items:flex-start;gap:var(--space-2);padding:var(--space-4);background:var(--color-surface);border-color:var(--color-border-strong);text-align:left}.brand-mark-text{display:inline-flex;min-height:22px;align-items:center;padding:0 var(--space-2);background:var(--color-primary-soft);border:1px solid var(--color-primary-border);border-radius:var(--radius-sm);color:var(--color-primary);font-family:var(--font-brand);font-size:var(--text-xs);font-weight:900;line-height:1;letter-spacing:0}.brand-mark-title{color:var(--color-text);font-family:var(--font-brand);font-size:var(--text-lg);font-weight:880;line-height:1;letter-spacing:0}.brand-card-lines{display:flex;width:100%;flex-direction:column;gap:var(--space-1)}.brand-card-lines span{display:block;height:6px;background:var(--color-surface-muted);border-radius:999px}.brand-card-lines span:first-child{width:86%}.brand-card-lines span:last-child{width:58%}.brand-check{position:absolute;top:10px;right:6px;z-index:2;display:inline-flex;width:42px;height:42px;align-items:center;justify-content:center;background:var(--color-success);border:3px solid var(--color-surface);border-radius:var(--radius-lg);color:var(--color-inverse);font-size:var(--text-lg);font-weight:860;line-height:1;box-shadow:var(--shadow-md);transform:rotate(4deg)}.welcome-copy{display:flex;max-width:338px;flex-direction:column;align-items:center;gap:var(--space-2)}.welcome-kicker{display:inline-flex;min-height:26px;align-items:center;padding:0 var(--space-3);margin:0;border:1px solid transparent;border-radius:999px;color:var(--color-secondary);font-size:var(--text-xs);font-weight:760;line-height:var(--line-normal)}.welcome-title{margin:0;color:var(--color-text);font-family:var(--font-brand);font-size:2.25rem;font-weight:880;line-height:1.05;letter-spacing:0;overflow-wrap:anywhere}.welcome-title .wordmark{justify-content:center;gap:.14em}.welcome-subtitle{margin:0;color:var(--color-text-muted);font-size:var(--text-base);line-height:var(--line-relaxed);overflow-wrap:anywhere}.trust-list{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-2);margin:0;padding:0;list-style:none}.trust-item{display:inline-flex;max-width:100%;min-height:36px;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:color-mix(in srgb,var(--color-surface) 78%,transparent);border:1px solid var(--color-border);border-radius:999px;box-shadow:none}.trust-marker{display:inline-flex;width:20px;height:20px;flex:0 0 auto;align-items:center;justify-content:center;background:var(--color-accent-soft);border:1px solid var(--color-accent-border);border-radius:999px;color:var(--color-accent);font-size:var(--text-xs);font-weight:820}.trust-copy{min-width:0;margin:0;color:var(--color-text);font-size:var(--text-xs);font-weight:700;line-height:var(--line-normal);overflow-wrap:anywhere}.welcome-actions{display:flex;flex-direction:column;gap:var(--space-3);margin-top:auto}.btn{display:inline-flex;min-width:var(--tap-target);min-height:var(--tap-target);align-items:center;justify-content:center;gap:var(--space-2);padding:0 var(--space-4);border:1px solid transparent;border-radius:var(--radius-lg);font-size:var(--text-base);font-weight:720;line-height:var(--line-tight);text-align:center;text-decoration:none;white-space:normal;overflow-wrap:anywhere;transition:background-color .16s ease,border-color .16s ease,color .16s ease,transform .12s ease}.btn:active{transform:translateY(1px)}.btn:disabled{cursor:not-allowed;opacity:.58}.btn-primary{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-primary-contrast)}.btn-primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-quiet{background:transparent;border-color:transparent;color:var(--color-secondary)}.btn-quiet:hover{background:var(--color-secondary-soft);color:var(--color-secondary-hover)}.btn-full{width:100%}.btn-with-tag{flex-wrap:wrap;min-height:52px}.button-tag{display:inline-flex;min-height:24px;align-items:center;padding:0 var(--space-2);background:var(--color-warning-soft);border:1px solid var(--color-warning-border);border-radius:var(--radius-md);color:var(--color-warning);font-size:var(--text-xs);font-weight:760;line-height:1}.welcome-actions .btn-primary{min-height:56px;box-shadow:var(--shadow-md)}.welcome-actions .btn-quiet{min-height:40px;color:var(--color-text-muted)}.welcome-actions .btn-quiet:disabled{background:transparent;border-color:transparent}html[data-theme=light] .welcome-splash{background:linear-gradient(180deg,#fffaf0,#f7f9fc 52%,#eef8f6)}html[data-theme=light] .welcome-topbar .app-name{color:#7c251e}html[data-theme=light] .welcome-splash:before{height:278px;background:linear-gradient(145deg,#b4231838,#f0b42957 42%,#007f7338),linear-gradient(12deg,#fff0 0 54%,#ffffffb3 54% 58%,#fff0 58%)}html[data-theme=light] .welcome-splash:after{background:repeating-linear-gradient(-8deg,#fff0 0 15px,#ffffffa8 15px 16px),linear-gradient(90deg,#b4231814,#f0b4291a,#007f7314);border-color:#b423181f;opacity:1}html[data-theme=light] .brand-mark:before{background:#e9f4ff;border-color:#a9caef}html[data-theme=light] .brand-card-back{background:linear-gradient(135deg,#fff0b8,#ffd66b);border-color:#d59915}html[data-theme=light] .brand-card-front{background:linear-gradient(180deg,#fffdf8,#fff 64%),var(--color-surface);border-color:#9fb1c8;box-shadow:0 14px 30px #294c7a33}html[data-theme=light] .brand-card-front:before{position:absolute;top:0;right:0;left:0;height:6px;content:"";background:linear-gradient(90deg,#b42318 0 28%,#f0b429 28% 68%,#007f73 68% 100%);border-radius:var(--radius-lg) var(--radius-lg) 0 0}html[data-theme=light] .brand-mark-text{background:#fff0ee;border-color:#e69b93;color:#8f1d15}html[data-theme=light] .brand-check{background:#007f73;border-color:#fffdf8;color:#fff}html[data-theme=light] .welcome-kicker{background:#fff1bf;border:1px solid #e5b237;color:#7b4a00}html[data-theme=light] .welcome-title{color:#18243a}html[data-theme=light] .welcome-subtitle{color:#485467}html[data-theme=light] .trust-item{background:#ffffffb8;border-color:#9bb2cddb;box-shadow:0 6px 18px #294c7a17}html[data-theme=light] .trust-marker{background:#e3f8f3;border-color:#76c8bd;color:#006f65}html[data-theme=light] .welcome-actions .btn-primary{background:#9f1f16;border-color:#9f1f16;box-shadow:0 14px 28px #9f1f163d}html[data-theme=light] .welcome-actions .btn-primary:hover{background:#842018;border-color:#842018}html[data-theme=light] .theme-toggle,html[data-theme=light] .utility-pill{background:#ffffffbd;border-color:#9bb2cdd1;color:#485467;box-shadow:0 6px 16px #294c7a14}@media(prefers-color-scheme:light){:root:not([data-theme]) .welcome-splash{background:linear-gradient(180deg,#fffaf0,#f7f9fc 52%,#eef8f6)}:root:not([data-theme]) .welcome-topbar .app-name{color:#7c251e}:root:not([data-theme]) .welcome-splash:before{height:278px;background:linear-gradient(145deg,#b4231838,#f0b42957 42%,#007f7338),linear-gradient(12deg,#fff0 0 54%,#ffffffb3 54% 58%,#fff0 58%)}:root:not([data-theme]) .welcome-splash:after{background:repeating-linear-gradient(-8deg,#fff0 0 15px,#ffffffa8 15px 16px),linear-gradient(90deg,#b4231814,#f0b4291a,#007f7314);border-color:#b423181f;opacity:1}:root:not([data-theme]) .brand-mark:before{background:#e9f4ff;border-color:#a9caef}:root:not([data-theme]) .brand-card-back{background:linear-gradient(135deg,#fff0b8,#ffd66b);border-color:#d59915}:root:not([data-theme]) .brand-card-front{background:linear-gradient(180deg,#fffdf8,#fff 64%),var(--color-surface);border-color:#9fb1c8;box-shadow:0 14px 30px #294c7a33}:root:not([data-theme]) .brand-card-front:before{position:absolute;top:0;right:0;left:0;height:6px;content:"";background:linear-gradient(90deg,#b42318 0 28%,#f0b429 28% 68%,#007f73 68% 100%);border-radius:var(--radius-lg) var(--radius-lg) 0 0}:root:not([data-theme]) .brand-mark-text{background:#fff0ee;border-color:#e69b93;color:#8f1d15}:root:not([data-theme]) .brand-check{background:#007f73;border-color:#fffdf8;color:#fff}:root:not([data-theme]) .welcome-kicker{background:#fff1bf;border:1px solid #e5b237;color:#7b4a00}:root:not([data-theme]) .welcome-title{color:#18243a}:root:not([data-theme]) .welcome-subtitle{color:#485467}:root:not([data-theme]) .trust-item{background:#ffffffb8;border-color:#9bb2cddb;box-shadow:0 6px 18px #294c7a17}:root:not([data-theme]) .trust-marker{background:#e3f8f3;border-color:#76c8bd;color:#006f65}:root:not([data-theme]) .welcome-actions .btn-primary{background:#9f1f16;border-color:#9f1f16;box-shadow:0 14px 28px #9f1f163d}:root:not([data-theme]) .welcome-actions .btn-primary:hover{background:#842018;border-color:#842018}:root:not([data-theme]) .theme-toggle,:root:not([data-theme]) .utility-pill{background:#ffffffbd;border-color:#9bb2cdd1;color:#485467;box-shadow:0 6px 16px #294c7a14}}html[data-theme=dark] .welcome-splash:before{height:278px}html[data-theme=dark] .welcome-splash:after{background:repeating-linear-gradient(-8deg,#fff0 0 15px,#9ccaff21 15px 16px),linear-gradient(90deg,#ff8a801a,#f3bf6117,#72d9cb1c);border-color:#9ccaff2e;opacity:.82;box-shadow:0 14px 32px #00000029}html[data-theme=dark] .welcome-kicker{background:#f3bf6124;border-color:#f3bf615c;color:#f3bf61;box-shadow:0 8px 18px #0000002e}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .welcome-splash:before{height:278px}:root:not([data-theme=light]) .welcome-splash:after{background:repeating-linear-gradient(-8deg,#fff0 0 15px,#9ccaff21 15px 16px),linear-gradient(90deg,#ff8a801a,#f3bf6117,#72d9cb1c);border-color:#9ccaff2e;opacity:.82;box-shadow:0 14px 32px #00000029}:root:not([data-theme=light]) .welcome-kicker{background:#f3bf6124;border-color:#f3bf615c;color:#f3bf61;box-shadow:0 8px 18px #0000002e}}@media(max-width:360px){.welcome-title{font-size:1.875rem}.brand-mark{width:142px;height:130px}.brand-card-front{min-height:96px;padding:var(--space-3)}}.screen-with-bottom-bar{padding-bottom:104px}.activity-complete-screen{display:flex;flex-direction:column;gap:var(--space-4);background:linear-gradient(180deg,color-mix(in srgb,var(--color-accent-soft) 36%,transparent) 0 126px,transparent 126px),var(--color-canvas)}.completion-hero{--completion-accent: var(--color-accent);--completion-accent-soft: var(--color-accent-soft);--completion-accent-border: var(--color-accent-border);position:relative;display:grid;grid-template-columns:58px minmax(0,1fr);gap:var(--space-3);align-items:start;overflow:hidden;padding:var(--space-4);background:var(--color-surface);border:1px solid var(--completion-accent-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.completion-hero:before{position:absolute;top:0;bottom:0;left:0;width:5px;content:"";background:var(--completion-accent)}.completion-hero:after{position:absolute;right:var(--space-3);bottom:var(--space-3);width:88px;height:48px;content:"";background:repeating-linear-gradient(-8deg,transparent 0 13px,color-mix(in srgb,var(--completion-accent) 22%,transparent) 13px 14px);border:1px solid color-mix(in srgb,var(--completion-accent) 20%,transparent);border-radius:var(--radius-lg);opacity:.34;transform:rotate(-3deg)}.completion-hero>*{position:relative;z-index:1}.completion-hero.is-learning{--completion-accent: var(--color-primary);--completion-accent-soft: var(--color-primary-soft);--completion-accent-border: var(--color-primary-border)}.completion-hero.is-exam{--completion-accent: var(--color-accent);--completion-accent-soft: var(--color-accent-soft);--completion-accent-border: var(--color-accent-border)}.completion-icon{position:relative;display:inline-flex;align-items:center;justify-content:center;width:58px;height:58px;background:var(--completion-accent-soft);border:1px solid var(--completion-accent-border);border-radius:var(--radius-lg);color:var(--completion-accent);font-family:var(--font-brand);font-size:var(--text-xl);font-weight:900;line-height:1}.completion-icon-check{position:absolute;right:-5px;bottom:-5px;display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--color-success);border:2px solid var(--color-surface);border-radius:999px;color:var(--color-inverse);font-size:.72rem;font-weight:900;line-height:1}.completion-copy{display:flex;min-width:0;flex-direction:column;gap:var(--space-2)}.completion-title-row{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:var(--space-2)}.completion-title{flex:1 1 8rem;min-width:0;margin:0;color:var(--color-text);font-size:var(--text-xl);font-weight:840;line-height:var(--line-tight);overflow-wrap:anywhere}.completion-status-badge{display:inline-flex;flex:none;align-items:center;gap:var(--space-1);min-height:24px;margin-left:auto;padding:0 var(--space-2);border:1px solid transparent;border-radius:999px;font-size:var(--text-xs);font-weight:720;line-height:1;white-space:nowrap}.completion-status-badge.status-success{background:var(--color-success-soft);border-color:var(--color-success-border);color:var(--color-success)}.completion-status-badge.status-danger{background:var(--color-danger-soft);border-color:var(--color-danger-border);color:var(--color-danger)}.completion-message{margin:0;color:var(--color-text-muted);font-size:var(--text-sm);line-height:var(--line-relaxed);overflow-wrap:anywhere}.completion-stat-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-2)}.completion-stat-grid.is-two{grid-template-columns:repeat(2,minmax(0,1fr))}.completion-stat{display:flex;min-height:72px;flex-direction:column;justify-content:center;gap:var(--space-1);padding:var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.completion-stat.is-success{background:linear-gradient(180deg,color-mix(in srgb,var(--color-success-soft) 76%,var(--color-surface)) 0%,var(--color-surface) 100%);border-color:var(--color-success-border)}.completion-stat.is-warning{background:linear-gradient(180deg,color-mix(in srgb,var(--color-warning-soft) 76%,var(--color-surface)) 0%,var(--color-surface) 100%);border-color:var(--color-warning-border)}.completion-stat.is-info{background:linear-gradient(180deg,color-mix(in srgb,var(--color-secondary-soft) 76%,var(--color-surface)) 0%,var(--color-surface) 100%);border-color:var(--color-secondary-border)}.completion-stat-label{margin:0;color:var(--color-text-muted);font-size:var(--text-xs);font-weight:720;line-height:var(--line-tight);overflow-wrap:anywhere}.completion-stat-value{margin:0;color:var(--color-text);font-size:var(--text-xl);font-weight:840;line-height:1;font-variant-numeric:tabular-nums}.completion-actions{display:flex;flex-direction:column;gap:var(--space-3)}.completion-action-heading{margin:0;color:var(--color-text);font-size:var(--text-base);font-weight:780;line-height:var(--line-tight);overflow-wrap:anywhere}.completion-action-list{display:flex;flex-direction:column;gap:var(--space-3)}.completion-action-list.is-learning{--completion-accent: var(--color-primary);--completion-accent-soft: var(--color-primary-soft);--completion-accent-border: var(--color-primary-border)}.completion-action-list.is-exam{--completion-accent: var(--color-accent);--completion-accent-soft: var(--color-accent-soft);--completion-accent-border: var(--color-accent-border)}.completion-action-row{--action-accent: var(--completion-accent, var(--color-secondary));--action-accent-soft: var(--completion-accent-soft, var(--color-secondary-soft));--action-accent-border: var(--completion-accent-border, var(--color-secondary-border));position:relative;display:grid;grid-template-columns:44px minmax(0,1fr);gap:var(--space-3);align-items:center;overflow:hidden;min-height:72px;padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--action-accent-border);border-radius:var(--radius-lg);color:inherit;text-align:left;text-decoration:none;box-shadow:var(--shadow-sm)}.completion-action-row:before{position:absolute;top:0;bottom:0;left:0;width:5px;content:"";background:var(--action-accent)}.completion-action-row>*{position:relative;z-index:1}.completion-action-row:hover{background:var(--color-surface-muted);color:inherit}.completion-action-row:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.completion-action-row.is-exam-action{--action-accent: var(--color-secondary);--action-accent-soft: var(--color-secondary-soft);--action-accent-border: var(--color-secondary-border)}.completion-action-row.is-lesson-action{--action-accent: var(--color-primary);--action-accent-soft: var(--color-primary-soft);--action-accent-border: var(--color-primary-border)}.completion-action-row.is-review-action{--action-accent: var(--color-warning);--action-accent-soft: var(--color-warning-soft);--action-accent-border: var(--color-warning-border)}.completion-action-row.is-home-action{--action-accent: var(--color-accent);--action-accent-soft: var(--color-accent-soft);--action-accent-border: var(--color-accent-border)}.completion-action-icon{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--action-accent-soft);border:1px solid var(--action-accent-border);border-radius:var(--radius-lg);color:var(--action-accent);font-family:var(--font-brand);font-size:var(--text-md);font-weight:900;line-height:1}.completion-action-copy{display:flex;min-width:0;flex-direction:column;gap:2px}.completion-action-title{color:var(--color-text);font-size:var(--text-base);font-weight:760;line-height:var(--line-tight);overflow-wrap:anywhere}.completion-action-detail{color:var(--color-text-muted);font-size:var(--text-xs);line-height:var(--line-normal);overflow-wrap:anywhere}.activity-start-screen{padding-bottom:calc(104px + env(safe-area-inset-bottom))}.topbar{position:sticky;top:0;z-index:10;margin:-16px -16px 16px;padding:12px 16px;background:color-mix(in srgb,var(--color-canvas) 92%,transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--color-border)}.quick-advance-bar{position:fixed;top:0;right:max(0px,calc((100vw - 430px)/2));left:max(0px,calc((100vw - 430px)/2));z-index:30;height:3px;overflow:hidden;background:transparent}.quick-advance-bar>span{display:block;width:100%;height:100%;background:var(--color-success);transform-origin:left center;animation:quick-advance .5s linear forwards}.screen-interaction-blocker{position:fixed;inset:0;z-index:25;cursor:wait;background:transparent}.screen-advance-click-layer{position:fixed;inset:0;z-index:24;padding:0;background:transparent;border:0;cursor:pointer}@keyframes quick-advance{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.identity-line{height:4px;overflow:hidden;border-radius:999px;background:linear-gradient(90deg,var(--color-primary) 0 33%,var(--color-warning) 33% 66%,var(--color-accent) 66% 100%)}.study-mark{position:relative;width:54px;height:42px;flex:none}.study-card{position:absolute;inset:0;border:1px solid var(--color-border-strong);border-radius:8px;background:var(--color-surface-raised);box-shadow:var(--shadow-sm)}.study-card:nth-child(1){transform:translate(8px,-5px) rotate(5deg);border-color:var(--color-warning-border)}.study-card:nth-child(2){transform:translate(3px) rotate(-3deg);border-color:var(--color-accent-border)}.study-card:nth-child(3){display:grid;place-items:center;color:var(--color-primary);font-weight:800;letter-spacing:0}.bottom-action{position:fixed;right:max(16px,calc((100vw - 430px)/2 + 16px));bottom:0;left:max(16px,calc((100vw - 430px)/2 + 16px));z-index:20;padding:12px 0 16px;background:linear-gradient(180deg,transparent,var(--color-canvas) 24%)}.bottom-action-bar{position:fixed;right:0;bottom:0;left:0;z-index:20;display:flex;justify-content:center;padding:12px 16px calc(12px + env(safe-area-inset-bottom));background:color-mix(in srgb,var(--color-surface) 94%,transparent);border-top:1px solid var(--color-border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.bottom-action-inner{display:grid;grid-template-columns:1fr;gap:var(--space-2);width:100%;max-width:calc(var(--app-max-width) - 32px)}.bottom-action-inner.two-actions{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.bottom-action-inner>*{width:100%;min-width:0}.bottom-action-inner .bottom-action-button{padding-right:var(--space-3);padding-left:var(--space-3);font-size:var(--text-sm);line-height:var(--line-tight);white-space:nowrap}.metric-bar{display:grid;gap:2px;height:12px;overflow:hidden;padding:2px;background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:999px}.metric-bar-segment{min-width:4px;height:100%;background:var(--segment-fill);border:1px solid var(--segment-border);border-radius:999px}.metric-bar-segment.is-learned{--segment-fill: linear-gradient( 180deg, var(--color-accent-soft) 0%, color-mix(in srgb, var(--color-accent) 58%, var(--color-accent-soft)) 100% );--segment-border: var(--color-accent-border)}.metric-bar-segment.is-practice{--segment-fill: linear-gradient( 180deg, var(--color-warning-soft) 0%, color-mix(in srgb, var(--color-warning) 58%, var(--color-warning-soft)) 100% );--segment-border: var(--color-warning-border)}.metric-bar-segment.is-recent-fail{--segment-fill: linear-gradient( 180deg, var(--color-danger-soft) 0%, color-mix(in srgb, var(--color-danger) 58%, var(--color-danger-soft)) 100% );--segment-border: var(--color-danger-border)}.metric-bar-segment.is-unseen{--segment-fill: linear-gradient( 180deg, var(--color-surface-muted) 0%, color-mix(in srgb, var(--color-border-strong) 58%, var(--color-surface-muted)) 100% );--segment-border: var(--color-border-strong)}.metric-card-tone-accent{background:linear-gradient(180deg,color-mix(in srgb,var(--color-accent-soft) 72%,var(--color-surface)) 0%,var(--color-surface) 100%);border-color:var(--color-accent-border)}.metric-card-tone-warning{background:linear-gradient(180deg,color-mix(in srgb,var(--color-warning-soft) 72%,var(--color-surface)) 0%,var(--color-surface) 100%);border-color:var(--color-warning-border)}.metric-card-tone-danger{background:linear-gradient(180deg,color-mix(in srgb,var(--color-danger-soft) 72%,var(--color-surface)) 0%,var(--color-surface) 100%);border-color:var(--color-danger-border)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hover\:border-\[var\(--color-border-strong\)\]:hover{border-color:var(--color-border-strong)}.hover\:bg-\[var\(--color-primary-hover\)\]:hover{background-color:var(--color-primary-hover)}.hover\:bg-\[var\(--color-secondary-soft\)\]:hover{background-color:var(--color-secondary-soft)}.hover\:bg-\[var\(--color-surface-muted\)\]:hover{background-color:var(--color-surface-muted)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:opacity-55:disabled{opacity:.55}
