@import "https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&family=Nunito:wght@400;600;700;800&display=swap";:root{--bg:#fffaf2;--bg-soft:#fff3db;--surface:#fffc;--surface-strong:#fff;--border:#482e0f1f;--text:#43311d;--muted:#7f6a56;--primary:coral;--primary-strong:#f2542d;--secondary:#2a9d8f;--sky:#4d96ff;--gold:#ffb703;--berry:#ef476f;--shadow:0 24px 60px #75572924;--radius-xl:32px;--radius-lg:24px;--radius-md:18px;--radius-sm:12px;--max-width:1220px;color:var(--text);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at 0 0,#ffb70333,#0000 24%),radial-gradient(circle at 100% 0,#4d96ff2e,#0000 30%),linear-gradient(#fff9ef 0%,#fff3df 100%);font-family:Nunito,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:320px;min-height:100vh;margin:0}body:before,body:after{content:"";filter:blur(30px);pointer-events:none;z-index:0;background:#ff7f501f;border-radius:999px;width:16rem;height:16rem;position:fixed;inset:auto auto 8% 3%}body:after{background:#4d96ff24;inset:8% 3% auto auto}a{color:inherit;text-decoration:none}button,input{font:inherit}#root{z-index:1;position:relative}h1,h2,h3,h4,p{margin:0}h1,h2,h3,h4,.brand-title,.hero-title,.page-title{font-family:Fredoka,sans-serif}.app-shell{width:min(var(--max-width), calc(100% - 24px));margin:18px auto 32px}.app-header{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid var(--border);box-shadow:var(--shadow);z-index:10;background:#ffffffb8;border-radius:28px;grid-template-columns:auto 1fr auto;align-items:center;gap:20px;padding:18px 22px;transition:padding .18s,gap .18s,top .18s;display:grid;position:sticky;top:14px}.app-shell.is-compact .app-main{margin-top:12px}.app-header.is-compact{grid-template-columns:auto 1fr;gap:12px;padding:10px 14px;top:8px}.app-header.is-compact .main-nav,.app-header.is-compact .header-meta{display:none}.app-header.is-compact .brand-badge{border-radius:12px;width:38px;height:38px;font-size:1.1rem}.app-header.is-compact .brand-title{font-size:1.1rem}.app-header.is-compact .brand-lockup{gap:10px}.app-header.is-compact .brand-lockup .eyebrow{display:none}.brand-lockup{align-items:center;gap:14px;display:flex}.brand-badge{color:#fff;background:linear-gradient(135deg, var(--primary) 0%, var(--gold) 100%);border-radius:18px;place-items:center;width:54px;height:54px;font-family:Fredoka,sans-serif;font-size:1.5rem;display:grid;box-shadow:0 14px 24px #f2542d47}.brand-title{font-size:1.45rem}.eyebrow{text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-size:.72rem;font-weight:800}.main-nav,.dock-nav,.chip-row,.button-row,.header-meta,.question-progress{align-items:center;gap:12px;display:flex}.main-nav{flex-wrap:wrap;justify-content:center}.nav-link,.dock-link{color:var(--muted);z-index:2;pointer-events:auto;border-radius:999px;justify-content:center;align-items:center;padding:.8rem 1.1rem;font-weight:800;transition:all .18s;display:inline-flex;position:relative}.nav-link:hover,.dock-link:hover,.nav-link.is-active,.dock-link.is-active{color:var(--text);background:#ff7f5024}.status-pill,.avatar-pill,.chip,.strong,.inline-banner,.inline-note,.recent-meta{border-radius:999px}.status-pill,.avatar-pill{background:#fff;border:1px solid #43311d14;padding:.75rem 1rem}.status-pill{line-height:1.05;display:grid}.status-value{font-weight:800}.status-label{color:var(--muted);font-size:.74rem}.avatar-pill{align-items:center;gap:10px;font-weight:700;display:inline-flex}.avatar-pill.is-link:hover{background:#4d96ff1f}.avatar-dot{background:linear-gradient(135deg, var(--secondary), var(--sky));border-radius:999px;width:10px;height:10px}.app-main,.page-stack{flex-direction:column;gap:22px;display:flex}.app-main{margin-top:22px}.page-stack{padding-bottom:90px}.panel,.band-section,.hero-panel,.question-card,.session-start-card,.session-complete-card,.chart-panel,.feature-panel,.form-panel,.empty-panel,.recent-card,.band-overview-card,.stat-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);box-shadow:var(--shadow);background:#fffc}.panel,.band-section,.hero-panel,.question-card,.session-start-card,.session-complete-card,.chart-panel,.feature-panel,.form-panel,.empty-panel,.band-overview-card,.stat-card{border-radius:var(--radius-xl)}.panel,.band-section,.hero-panel,.question-card,.session-start-card,.session-complete-card,.chart-panel,.feature-panel,.form-panel,.empty-panel{padding:24px}.section-heading{justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:20px;display:flex}.page-title{font-size:clamp(1.7rem,3vw,2.6rem);line-height:1.05}.hero-panel{grid-template-columns:1.4fr 1fr;gap:28px;min-height:320px;display:grid;position:relative;overflow:hidden}.home-hero{z-index:3;grid-template-columns:1.2fr 1fr;gap:24px;display:grid;position:relative}.home-hero-actions{align-items:center}.home-value-list{margin:0}.home-value-list li{color:var(--text);font-weight:700}.home-hero-cards{align-content:center;gap:14px;display:grid}.guest-slide{border-radius:var(--radius-xl);border:1px solid var(--border);height:320px;box-shadow:var(--shadow);flex-direction:column;justify-content:space-between;gap:18px;padding:24px;display:flex}.guest-slide h3{font-size:clamp(1.25rem,2.4vw,1.7rem);line-height:1.3}.guest-slide-ai{background:linear-gradient(155deg, color-mix(in srgb, var(--sky) 26%, white), color-mix(in srgb, var(--secondary) 24%, white))}.guest-slide-foundation{background:linear-gradient(155deg, color-mix(in srgb, var(--gold) 30%, white), color-mix(in srgb, var(--primary) 20%, white))}.guest-slide-efficiency{background:linear-gradient(155deg, color-mix(in srgb, var(--primary) 26%, white), color-mix(in srgb, var(--sky) 18%, white))}.slide-dots{gap:8px;display:inline-flex}.slide-controls{justify-content:space-between;align-items:center;gap:12px;display:flex}.slide-nav-buttons{gap:8px;display:inline-flex}.slide-arrow{border:1px solid color-mix(in srgb, var(--text) 16%, white);width:34px;height:34px;color:var(--text);cursor:pointer;background:#ffffffbf;border-radius:999px;place-items:center;font-size:1.15rem;font-weight:800;line-height:1;transition:transform .16s,background .16s;display:grid}.slide-arrow:hover{background:#fffffff2;transform:translateY(-1px)}.slide-dot{cursor:pointer;background:#43311d3d;border:0;border-radius:999px;width:10px;height:10px;padding:0}.slide-dot.is-active{background:var(--text)}.quick-practice-card{border:1px solid color-mix(in srgb, var(--accent,var(--primary)) 35%, white);background:linear-gradient(180deg, color-mix(in srgb, var(--accent,var(--primary)) 14%, white), #fffffff0)}.hero-panel:after{content:"";background:radial-gradient(circle,#ffb7034d 0%,#0000 68%);width:220px;height:220px;position:absolute;inset:auto -40px -40px auto}.hero-copy{flex-direction:column;justify-content:center;gap:16px;display:flex}.hero-title{max-width:13ch;font-size:clamp(2.25rem,6vw,4.2rem);line-height:.95}.guest-hero-title{max-width:12ch;font-size:clamp(1.9rem,4.2vw,3rem);line-height:1.02}.hero-body,.skill-body,.feature-panel p,.form-panel p,.recent-card p,.empty-panel p,.inline-note{color:var(--muted);line-height:1.55}.welcome-emoji{vertical-align:-.22em;font-size:1.9em;line-height:.8;display:inline-block}.hero-orbit{min-height:260px;position:relative}.orbit-card{color:#3e2b16;border-radius:22px;gap:8px;width:170px;padding:18px;display:grid;position:absolute;box-shadow:0 18px 30px #36271824}.orbit-card strong{font-family:Fredoka,sans-serif;font-size:2rem}.orbit-card.coral{background:linear-gradient(160deg,#ff7f50f2,#ffb703c7);top:8%;left:18%}.orbit-card.aqua{background:linear-gradient(160deg,#2a9d8feb,#4d96ffd1);top:48%;left:0}.orbit-card.lemon{background:linear-gradient(160deg,#ffb703eb,#fff380e0);top:24%;right:8%}.stat-grid,.skill-grid,.band-overview-grid,.card-grid{gap:18px;display:grid}.stat-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.stat-card{padding:18px}.stat-label,.stat-hint{color:var(--muted)}.stat-value{margin:8px 0;font-family:Fredoka,sans-serif;font-size:1.8rem;display:block}.card-grid.two-up,.band-overview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.band-overview-grid{column-count:2;column-gap:18px;display:block}.band-overview-card{border:1px solid color-mix(in srgb, var(--text) 8%, white);break-inside:avoid;background:linear-gradient(#fffffff5,#ffffffc7);flex-direction:column;gap:14px;width:100%;min-width:0;margin-bottom:18px;padding:20px 22px;display:flex;overflow:hidden;box-shadow:0 16px 28px #7557291a}.band-overview-top{gap:2px;display:grid}.band-overview-top h4{font-size:2rem;line-height:1.05}.band-overview-list{gap:.55rem;margin:0;padding-left:1rem;display:grid}.band-overview-list li{color:var(--muted);overflow-wrap:anywhere;word-break:break-word;line-height:1.35}.band-overview-y1-y6{background:linear-gradient(180deg, color-mix(in srgb, var(--gold) 10%, white), #ffffffe6)}.band-overview-y7-9{background:linear-gradient(180deg, color-mix(in srgb, var(--sky) 10%, white), #ffffffe6)}.band-overview-y10-13{background:linear-gradient(180deg, color-mix(in srgb, var(--secondary) 10%, white), #ffffffe6)}.feature-panel.contrast,.session-complete-card,.chart-panel{background:linear-gradient(#ffffffeb,#fff3dbd1)}.charts-grid,.chart-panel,.chart-frame{min-width:0}.chart-frame{width:100%}.primary-link,.primary-button,.secondary-button,.ghost-button{cursor:pointer;border:0;border-radius:999px;padding:.95rem 1.25rem;font-weight:800;transition:transform .18s,box-shadow .18s,background .18s}.auth-cta{white-space:nowrap}.auth-menu{z-index:50;display:inline-flex;position:relative}.auth-menu-panel{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface-strong);min-width:220px;box-shadow:var(--shadow);z-index:70;gap:8px;padding:10px;display:grid;position:absolute;top:calc(100% + 8px)}.auth-menu-panel-right{right:0}.auth-menu-panel-left{left:0}.auth-menu-item{background:color-mix(in srgb, var(--sky) 12%, white);color:var(--text);text-align:left;cursor:pointer;border:0;border-radius:12px;padding:.7rem .85rem;font-weight:800}.auth-menu-item:disabled{opacity:.7;cursor:default}.auth-menu-note,.auth-menu-error{margin:0;font-size:.82rem;line-height:1.35}.auth-menu-note{color:var(--muted)}.auth-menu-error{color:var(--berry)}.primary-link,.primary-button{color:#fff;background:linear-gradient(135deg, var(--primary-strong), var(--primary));box-shadow:0 16px 28px #f2542d3d}.secondary-button{color:var(--sky);background:#4d96ff1f}.ghost-button{color:var(--text);background:#43311d14}.primary-link:hover,.primary-button:hover,.secondary-button:hover,.ghost-button:hover,.skill-card:hover{transform:translateY(-1px)}.band-section{flex-direction:column;gap:18px;display:flex}.skill-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.skill-card{text-align:left;border-radius:var(--radius-lg);background:#fff;border:1px solid #43311d14;gap:10px;padding:18px;display:grid;box-shadow:0 14px 30px #75572914}.skill-card-select{text-align:left;cursor:pointer;background:0 0;border:0;gap:10px;width:100%;margin:0;padding:0;display:grid}.skill-card-start{letter-spacing:.01em;width:auto;color:var(--primary-strong);background:color-mix(in srgb, var(--primary) 14%, white);box-shadow:none;border-radius:999px;place-self:end start;align-items:center;gap:.4rem;padding:.55rem .9rem;font-size:.82rem;font-weight:800;line-height:1;display:inline-flex}.skill-card-start:hover{background:color-mix(in srgb, var(--primary) 22%, white)}.skill-card-start-icon{font-size:.74rem;line-height:1}.skill-card.is-selected{background:linear-gradient(180deg, #fffffffa, color-mix(in srgb, var(--accent,var(--primary)) 14%, white));border-color:color-mix(in srgb, var(--accent,var(--primary)) 44%, white)}.skill-phase{color:var(--muted);font-size:.8rem;font-weight:800}.skill-title{font-family:Fredoka,sans-serif;font-size:1.2rem}.chip-row{flex-wrap:wrap}.chip{color:var(--text);background:#43311d14;padding:.45rem .75rem;font-size:.8rem;font-weight:800}.chip.strong{color:var(--secondary);background:#2a9d8f24}.recent-list{gap:14px;display:grid}.recent-list.compact{gap:10px}.recent-card{border-radius:var(--radius-md);justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;display:flex}.recent-meta,.inline-note,.error-note{color:var(--muted);background:#43311d14;padding:.4rem .7rem;font-size:.82rem;font-weight:800}.error-note{color:var(--berry);background:#ef476f1f;display:inline-flex}.session-panel{overflow:hidden}.practice-page .session-panel{border-width:2px}.practice-focus-panel{padding:12px 16px}.practice-top-bar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.practice-top-title{font-size:1.25rem;line-height:1}.practice-focus-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.session-start-card,.session-complete-card,.question-shell{gap:18px;display:grid}.result-hero{background:linear-gradient(135deg,#ffb7032e,#4d96ff24);border-radius:18px;align-items:center;gap:14px;padding:12px 14px;display:flex}.result-hero--superstar{background:linear-gradient(135deg,#ffd70047,#ffb70338,#ffffffb3)}.result-hero--explorer{background:linear-gradient(135deg,#4d96ff42,#7a6dff33,#ffffffb3)}.result-hero--climber{background:linear-gradient(135deg,#57cc993d,#4d96ff29,#ffffffb3)}.result-hero--hero{background:linear-gradient(135deg,#ff7f503d,#ffb7032e,#ffffffb8)}.result-hero-badge{background:#ffffffc7;border-radius:14px;place-items:center;width:48px;height:48px;font-size:1.6rem;display:grid}.result-stars{gap:4px;font-size:1.1rem;display:flex}.result-summary{gap:6px;display:grid}.result-meter{gap:8px;display:grid}.result-meter-track{background:#43311d1a;border-radius:999px;width:100%;height:12px;overflow:hidden}.result-meter-fill{border-radius:inherit;background:linear-gradient(135deg,#57cc99,#4d96ff,#ffb703);height:100%;transition:width .4s;display:block}.question-shell{max-width:880px;margin:0 auto}.practice-question-card{align-content:center;gap:20px;min-height:420px;display:grid}.practice-question-card .eyebrow{text-align:center}.practice-question-card .math-block{text-align:center;font-size:clamp(1.7rem,4.2vw,2.6rem)}.practice-question-card .math-inline{justify-content:center}.practice-question-card>p{text-align:center}.question-progress{justify-content:space-between}.test-toolbar{gap:10px;display:grid}.test-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.test-clock{min-width:70px;color:var(--text);font-variant-numeric:tabular-nums;background:#43311d14;border-radius:999px;justify-content:center;align-items:center;padding:.45rem .7rem;font-weight:800;display:inline-flex}.save-state-badge{color:var(--muted);background:#43311d14;border-radius:999px;justify-content:center;align-items:center;padding:.42rem .7rem;font-size:.78rem;font-weight:800;display:inline-flex}.save-state-badge.is-saving{color:#9a5c00;background:#ffb70333}.save-state-badge.is-saved{color:#0d6e62;background:#57cc9938}.progress-bar{background:#43311d14;border-radius:999px;flex:1;height:12px;overflow:hidden}.progress-bar span{border-radius:inherit;background:linear-gradient(135deg, var(--secondary), var(--sky));height:100%;display:block}.answer-form,.form-panel{gap:14px;display:grid}.answer-preview{background:#ffffffb8;border:1px solid #43311d1a;border-radius:16px;min-height:76px;padding:10px 12px}.answer-preview .eyebrow{margin-bottom:8px}.answer-preview-math{font-size:clamp(1rem,2.2vw,1.3rem)}.answer-input{width:100%;color:var(--text);background:#fff;border:1px solid #43311d1f;border-radius:18px;padding:.95rem 1rem}.answer-input:focus{border-color:#4d96ff6b;outline:2px solid #4d96ff38}.math-block,.math-inline{color:var(--text)}.math-block{width:100%;padding:.1rem 0;font-size:clamp(1.2rem,2.6vw,1.75rem);line-height:1.25;overflow:auto hidden}.math-inline{align-items:center;font-size:1.03em;line-height:1.15;display:inline-flex}.math-block mjx-container,.math-inline mjx-container{margin:0!important}.question-card .math-block{font-size:clamp(1.35rem,3.2vw,2rem)}.review-item .math-block{font-size:1.1rem}.chart-frame{height:280px}.heatmap-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;margin-top:16px;display:grid}.heatmap-cell{aspect-ratio:1;color:var(--muted);background:#43311d0f;border-radius:16px;place-items:center;font-size:.74rem;display:grid}.heatmap-cell[data-intensity="1"]{background:#ffb7032e}.heatmap-cell[data-intensity="2"]{background:#ffb70352}.heatmap-cell[data-intensity="3"]{background:#4d96ff47}.heatmap-cell[data-intensity="4"]{background:#2a9d8f59}.compact-list{color:var(--muted);padding-left:1rem}.compact-list li+li{margin-top:.4rem}.history-layout,.calendar-layout,.review-columns{gap:18px;display:grid}.history-layout{grid-template-columns:minmax(280px,360px) minmax(0,1fr)}.calendar-layout{grid-template-columns:minmax(0,1fr) minmax(280px,360px)}.history-sidebar,.review-panel{align-self:start}.history-list,.review-list{gap:12px;display:grid}.history-item,.review-item{text-align:left;background:#fff;border:1px solid #43311d14;border-radius:18px;width:100%;padding:14px 16px}.history-item{cursor:pointer;justify-content:space-between;gap:12px;display:flex}.history-item.is-selected{background:#4d96ff14;border-color:#4d96ff59}.review-columns{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:18px}.month-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;display:grid}.weekday-row{grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;margin-bottom:10px;display:grid}.weekday-cell{text-align:center;letter-spacing:.02em;color:#43311d9e;font-size:.8rem;font-weight:700}.month-cell{text-align:left;cursor:pointer;background:#fff;border:1px solid #43311d14;border-radius:18px;flex-direction:column;justify-content:space-between;gap:8px;min-height:92px;padding:14px 10px;transition:transform .12s,box-shadow .12s,border-color .12s,background .12s;display:flex}.month-cell:hover{transform:translateY(-1px);box-shadow:0 8px 20px #43311d14}.month-cell-activity{justify-content:space-between;align-items:center;gap:8px;display:flex}.month-count-badge{background:#ffffffb8;border:1px solid #43311d24;border-radius:999px;justify-content:center;align-items:center;min-width:1.65rem;height:1.65rem;font-size:.8rem;font-weight:700;display:inline-flex}.session-dots{gap:4px;display:inline-flex}.session-dot{opacity:.55;background:currentColor;border-radius:999px;width:6px;height:6px}.month-cell.is-selected{outline:2px solid #4d96ff4d;box-shadow:0 10px 24px #4d96ff33}.month-cell[data-intensity="1"]{color:#43311df2;background:linear-gradient(#ffb7032e,#ffb70314);border-color:#ffb70347}.month-cell[data-intensity="2"]{color:#43311df2;background:linear-gradient(#ffb70347,#ffb70324);border-color:#ffb7035c}.month-cell[data-intensity="3"]{color:#19294df2;background:linear-gradient(#4d96ff4d,#4d96ff29);border-color:#4d96ff5c}.month-cell[data-intensity="4"]{color:#0c423cfa;background:linear-gradient(#2a9d8f52,#2a9d8f33);border-color:#2a9d8f66;box-shadow:0 10px 20px #2a9d8f2e}.month-cell[data-intensity="0"]{color:#43311d8f;background:#ffffffb8;border-color:#43311d0f}.month-cell[data-intensity="0"] strong{color:#43311da3}.month-cell--placeholder{cursor:default;pointer-events:none;background:#ffffff5c;border-style:dashed;border-color:#43311d0d}.form-label-inline{gap:8px;display:grid}.form-panel label{gap:8px;font-weight:700;display:grid}.button-row.wrap{flex-wrap:wrap}.dock-nav{display:none}@media (width<=960px){.app-header,.hero-panel,.home-hero,.card-grid.two-up,.band-overview-grid,.stat-grid{grid-template-columns:1fr}.app-header{position:static}.main-nav{display:none}.header-meta{flex-wrap:wrap;justify-content:space-between}.dock-nav{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow);z-index:15;background:#ffffffeb;border:1px solid #43311d14;border-radius:999px;justify-content:space-around;padding:.7rem;display:flex;position:fixed;bottom:12px;left:12px;right:12px}.page-stack{padding-bottom:110px}.history-layout,.calendar-layout,.review-columns{grid-template-columns:1fr}.hero-orbit{min-height:320px}.band-overview-grid{column-count:1}.guest-slide{height:340px}}@media (width<=640px){.app-shell{width:min(var(--max-width), calc(100% - 12px));margin:10px auto 24px}.app-header,.panel,.band-section,.hero-panel,.question-card,.session-start-card,.session-complete-card,.chart-panel,.feature-panel,.form-panel,.empty-panel,.stat-card{padding:18px}.hero-title{max-width:10ch}.orbit-card{width:145px}.heatmap-grid,.month-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.practice-question-card{min-height:340px}.practice-question-card .math-block{font-size:clamp(1.45rem,6vw,2rem)}.guest-slide{height:370px}}
