:root{color-scheme:light;--bg: #f3efe7;--bg-deep: #efe8db;--surface: rgba(255, 252, 246, .82);--surface-strong: rgba(252, 247, 239, .96);--ink: #201813;--muted: #6b5d52;--line: rgba(53, 37, 26, .11);--brand: #375b6d;--brand-soft: rgba(55, 91, 109, .12);--accent: #b57646;--ok: #1f7a5c;--error: #a54431;--shadow: 0 20px 60px rgba(45, 30, 20, .08);font-family:Avenir Next,Segoe UI,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color:var(--ink);background:radial-gradient(circle at top,#fbf6ee 0%,var(--bg) 38%,var(--bg-deep) 100%)}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{min-height:100vh}button,input,textarea,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.64}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid rgba(55,91,109,.35);outline-offset:2px}a{color:inherit;text-decoration:none}.marketing-shell,.product-shell{min-height:100vh}.marketing-shell{padding:4rem 2rem 3rem}.hero-shell,.glass-card,.app-rail,.page-shell{border:1px solid var(--line);border-radius:28px;background:var(--surface);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.hero-shell{max-width:1080px;margin:0 auto 2rem;padding:3rem}.brand-logo{display:block;max-width:100%;height:auto}.brand-logo--full{width:min(460px,100%)}.brand-logo--mark{width:76px;height:76px}.hero-brand-logo{margin-bottom:1rem}.hero-title,.page-title{font-family:Georgia,Times New Roman,serif;letter-spacing:-.03em;line-height:1;margin:0 0 1rem}.hero-title{font-size:clamp(3rem,6vw,5.6rem);max-width:14ch}.hero-copy,.page-copy,.muted-copy,.app-footnote{color:var(--muted)}.hero-copy{max-width:58ch;font-size:1.12rem}.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2rem}.primary-button,.secondary-button,.nav-link{transition:all .16s ease}.primary-button,.secondary-button{border-radius:999px;padding:.95rem 1.4rem;font-weight:700}.primary-button{background:var(--brand);color:#fff}.secondary-button{background:var(--surface-strong);border:1px solid var(--line)}.marketing-grid{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.glass-card{padding:1.5rem}.section-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.24em;color:var(--accent);font-weight:700;margin-bottom:.85rem}.section-label--tight{margin-bottom:.45rem}.card-title,.app-brand{font-size:1.5rem;margin:0 0 .75rem}.feature-list,.highlight-list{margin:0;padding:0;list-style:none}.feature-list li,.highlight-item{padding:.85rem 0;border-top:1px solid var(--line)}.status-grid,.meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-top:1rem}.status-label{color:var(--muted);font-size:.82rem;margin-bottom:.35rem}.status-value{font-weight:700}.status-value--compact{font-size:.92rem;overflow-wrap:anywhere}.status-pill{display:inline-flex;align-items:center;border-radius:999px;padding:.35rem .75rem;font-size:.82rem;font-weight:700}.status-pill--ok{background:#1f7a5c24;color:var(--ok)}.status-pill--error{background:#a5443124;color:var(--error)}.mini-divider{margin:1.25rem 0 0;border-top:1px solid var(--line)}.meta-chip{background:var(--brand-soft);border-radius:20px;padding:.85rem 1rem;display:flex;justify-content:space-between;gap:1rem}.status-error{margin-top:1rem;color:var(--error)}.product-shell{display:grid;grid-template-columns:236px minmax(0,1fr);gap:1rem;padding:1rem}.app-rail{padding:1.1rem 1rem;display:flex;flex-direction:column;gap:1.1rem;position:sticky;top:1rem;height:calc(100vh - 2rem)}.app-brand-lockup{display:flex;align-items:center;gap:.85rem}.rail-brand-mark{width:64px;height:64px;flex:0 0 64px}.nav-stack{display:flex;flex-direction:column;gap:.35rem}.nav-link{border-radius:14px;padding:.72rem .8rem;font-size:.95rem;color:var(--muted)}.nav-link--active,.nav-link:hover{background:var(--surface-strong);color:var(--ink);border:1px solid var(--line)}.app-main{padding:0;border:0;box-shadow:none;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}.app-footnote{margin-top:auto}.app-account-card{margin-top:auto;display:grid;gap:.75rem;padding:1rem;border-radius:20px;background:var(--surface-strong);border:1px solid var(--line)}.rail-button{width:100%;justify-content:center}.simple-form{margin-top:1.5rem;display:grid;gap:1rem;max-width:420px}.form-field{display:grid;gap:.45rem;font-size:.95rem}.form-field input{border:1px solid var(--line);border-radius:14px;padding:.9rem 1rem;background:var(--surface-strong);font:inherit}.code-block{margin:.75rem 0 0;padding:1rem;background:#18120f0d;border:1px solid var(--line);border-radius:16px;overflow-x:auto;font-size:.85rem}.page-shell{padding:1.4rem}.login-brand-logo{width:min(360px,100%);margin-bottom:.8rem}.page-title{font-size:clamp(2.3rem,4vw,3.5rem)}.page-copy{max-width:64ch;margin:0 0 1.5rem}.workspace-page{display:grid;gap:1.5rem}.workspace-page--minimal{gap:.75rem;position:relative;overflow:hidden;background:radial-gradient(1000px 320px at 10% -12%,#e8f7fff2,#d8eefa8c 70%,#d8eefa00),linear-gradient(180deg,#edf8ff,#e5f3fc 48%,#ddecf8)}.workspace-page--minimal:before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;background:radial-gradient(18px 8px at 12px 6px,rgba(255,255,255,.6) 0 56%,transparent 58%) 0 0 / 170px 36px repeat,radial-gradient(20px 9px at 14px 7px,rgba(102,175,214,.22) 0 52%,transparent 54%) 20px 18px / 180px 40px repeat;animation:water-surface-drift 24s linear infinite}.workspace-page--minimal>*{position:relative;z-index:1}.teacher-chat-canvas{display:grid;gap:.8rem;padding:.8rem;border-radius:20px;border:1px solid var(--line);background:#fffcf6b3}.teacher-chat-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.teacher-chat-bubble{position:relative;padding:.45rem .85rem;border-radius:16px;border:1px solid var(--line);background:var(--surface-strong);font-family:Georgia,Times New Roman,serif;font-size:1rem;font-weight:700}.teacher-chat-bubble:after{content:"";position:absolute;left:18px;bottom:-10px;width:14px;height:14px;border-left:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--surface-strong);transform:rotate(-40deg)}.teacher-chat-main{display:grid;grid-template-columns:minmax(320px,.92fr) minmax(380px,1.08fr);gap:.75rem}.teacher-chat-whale-lane,.teacher-chat-thread-lane{border:1px solid rgba(53,37,26,.08);border-radius:18px;background:#fffcf6db;padding:.8rem}.teacher-chat-thread-lane .chat-thread{max-height:50vh}.teacher-chat-composer{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:.55rem;align-items:center}.teacher-chat-mic{min-width:154px;min-height:58px;font-size:.98rem}.teacher-chat-input-wrap{margin:0}.teacher-chat-input{min-height:64px;resize:none}.teacher-chat-send{min-width:80px;min-height:54px}.workspace-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}.summary-card{padding:1.15rem 1.25rem}.teacher-chat-layout{display:grid;grid-template-columns:minmax(320px,.95fr) minmax(420px,1.25fr);gap:1rem}.status-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.whale-stage-card,.chat-column{display:grid;gap:1rem}.whale-stage{display:grid;justify-items:center;gap:.8rem;min-height:332px;padding:1.2rem;border-radius:24px;border:1px solid var(--line);background:radial-gradient(circle at top,#375b6d26,#375b6d0d 35%,#fffcf666 70%),var(--surface-strong)}.whale-stage--active{border-color:#375b6d59;background:radial-gradient(circle at top,#375b6d33,#375b6d17 35%,#fffcf680 70%),var(--surface-strong)}.whale-sprite-shell{--whale-size: min(320px, 70vw);width:var(--whale-size);height:var(--whale-size);position:relative;overflow:visible;border-radius:999px;display:grid;place-items:center;border:1px solid rgba(55,91,109,.2);background:radial-gradient(circle at 34% 20%,#fffffff5,#375b6d1f 54%,#375b6d3d);box-shadow:inset 0 2px 8px #ffffff59,0 16px 36px #12212c1f}.whale-sprite-shell--swimming{animation:whale-swim 5.4s ease-in-out infinite}.whale-sprite-shell--error{border-color:#b9584873;box-shadow:inset 0 2px 8px #ffffff59,0 0 0 10px #b958481f}.whale-spout{position:absolute;top:24px;left:54%;width:8px;height:14px;border-radius:999px;background:#83c9eb59;opacity:0;transform:translate(-50%)}.whale-spout:before,.whale-spout:after{content:"";position:absolute;border-radius:50%;background:#99d9f6b3}.whale-spout:before{width:8px;height:8px;left:-8px;top:-8px}.whale-spout:after{width:10px;height:10px;right:-10px;top:-10px}.whale-spout--active{opacity:1;animation:whale-spout-pop .95s ease-in-out infinite}.whale-sprite{width:calc(var(--whale-size) * .96);height:calc(var(--whale-size) * .96);background-image:url(/whale/whale_sprite_sheet.png);background-size:600% 400%;background-position:0% 0%;background-repeat:no-repeat;image-rendering:auto;animation:whale-frames 1.05s steps(5) infinite}.whale-sprite--idle{background-position-y:0%}.whale-sprite--listening{background-position-y:33.333%;animation-duration:.82s}.whale-sprite--explaining{background-position-y:66.666%;animation-duration:.72s}.whale-sprite--celebrating{background-position-y:100%;animation-duration:.52s}.whale-mouth{position:absolute;left:50%;top:64%;transform:translate(-50%,-50%);border:3px solid rgba(29,53,72,.88);border-radius:999px;background:#ffa7b7ad;opacity:.9;pointer-events:none}.whale-mouth--shape-0{width:22px;height:8px}.whale-mouth--shape-1{width:28px;height:13px}.whale-mouth--shape-2{width:16px;height:16px}.whale-mouth--shape-3{width:30px;height:10px}.whale-stage-copy{text-align:center;max-width:42ch}.whale-stage-copy h3{margin:0}.side-stack{display:grid;gap:1.25rem}.compact-list,.session-list{display:grid;gap:.75rem;list-style:none;padding:0;margin:0}.compact-list li,.session-row{display:grid;gap:.35rem;padding:.85rem 0;border-top:1px solid var(--line)}.compact-list strong,.session-row strong{display:block}.chat-thread{display:grid;gap:.65rem;align-content:start;max-height:52vh;overflow:auto;padding-right:.25rem}.chat-bubble{max-width:min(100%,48rem);position:relative;padding:.82rem .95rem;border-radius:16px;border:1px solid var(--line);background:var(--surface-strong)}.chat-bubble--teacher{justify-self:start}.chat-bubble--system{justify-self:start;background:#375b6d14}.chat-bubble--student{justify-self:end;background:#b5764617}.chat-bubble--shape-small{border-radius:20px 16px 20px 12px;max-width:min(100%,28rem)}.chat-bubble--shape-medium{border-radius:22px 14px}.chat-bubble--shape-wide{border-radius:16px 22px;max-width:min(100%,52rem)}.composer-shell{display:grid;gap:1rem;padding-top:.5rem;border-top:1px solid var(--line)}.chat-input{resize:vertical;min-height:120px;border:1px solid var(--line);border-radius:16px;padding:1rem;background:var(--surface-strong);font:inherit}.composer-actions{display:grid;gap:.75rem}.mic-button{border:0;border-radius:999px;padding:1.05rem 1.4rem;font:inherit;font-weight:700;color:#fff;background:var(--brand);cursor:pointer}.mic-button--active{background:var(--accent)}@keyframes whale-frames{0%{background-position-x:0%}to{background-position-x:100%}}@keyframes whale-thinking-pulse{0%{box-shadow:0 0 #375b6d47;transform:translateY(0)}50%{box-shadow:0 0 0 12px #375b6d14;transform:translateY(-2px)}to{box-shadow:0 0 #375b6d05;transform:translateY(0)}}@keyframes whale-swim{0%{transform:translate(-10px,2px) rotate(-1deg)}50%{transform:translate(10px,-3px) rotate(1deg)}to{transform:translate(-10px,2px) rotate(-1deg)}}@keyframes whale-spout-pop{0%{transform:translate(-50%,10px) scale(.8);opacity:0}25%{transform:translate(-50%,-8px) scale(1);opacity:.9}55%{transform:translate(-50%,-16px) scale(1.1);opacity:.95}to{transform:translate(-50%,-24px) scale(.8);opacity:0}}@keyframes water-surface-drift{0%{transform:translate(0)}to{transform:translate(-170px)}}.recorded-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.assignments-stack,.assignment-card{display:grid;gap:1rem}.review-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.community-layout{display:grid;grid-template-columns:minmax(220px,.75fr) minmax(360px,1.15fr) minmax(360px,1.15fr);gap:1rem}.assignment-body{white-space:pre-wrap;max-height:320px;overflow:auto}.live-track-video{width:100%;min-height:220px;max-height:320px;object-fit:cover;border-radius:14px;border:1px solid var(--line);background:#111}.session-row{grid-template-columns:minmax(0,1fr) auto;align-items:start}.session-meta{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}.session-title-small{font-size:.86rem;line-height:1.25;letter-spacing:.01em}.muted-copy--tight{font-size:.82rem;line-height:1.25;max-width:58ch}.meta-tag{display:inline-flex;align-items:center;border-radius:999px;padding:.35rem .7rem;font-size:.82rem;background:var(--brand-soft);color:var(--brand)}.session-pagination{margin-top:.75rem;display:flex;align-items:center;justify-content:space-between;gap:.65rem}.recorded-video-shell{display:grid;gap:.5rem;margin-top:.75rem}.recorded-video-player{width:100%;max-height:420px;border-radius:16px;border:1px solid var(--line);background:#111}.study-plan-page{display:grid;gap:1rem}.study-plan-input-card{display:grid;gap:.75rem}.study-plan-layout{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);gap:1rem}.study-plan-days{display:grid;gap:.85rem}.study-plan-day{border-top:1px solid var(--line);padding-top:.75rem;display:grid;gap:.5rem}.study-plan-day .card-title{font-size:1.1rem;margin:0}.study-plan-day input{border:1px solid var(--line);border-radius:12px;padding:.65rem .75rem;background:var(--surface-strong);font:inherit}.study-plan-side{display:grid;gap:.75rem;align-content:start}.study-toggle{display:flex;align-items:center;gap:.6rem}@media(max-width:960px){.product-shell{grid-template-columns:1fr}.app-rail{gap:1rem;position:static;top:auto;height:auto}.workspace-summary-grid,.teacher-chat-layout,.teacher-chat-main,.community-layout,.recorded-grid,.review-grid,.teacher-chat-composer{grid-template-columns:1fr}.teacher-chat-mic,.teacher-chat-send{width:100%}.session-pagination{flex-wrap:wrap}.study-plan-layout{grid-template-columns:1fr}}
