:root{--bg:#fbf4ec;--surface:#fffaf3;--surface-strong:#fff;--ink:#201815;--muted:#7f6f67;--line:#ead9c9;--primary:#c94c3f;--primary-dark:#93332b;--green:#1b8a5a;--amber:#b46c1b;--blue:#2f657f;--shadow:0 18px 48px #5e3f2a29;--radius:8px}*{box-sizing:border-box}html,body{min-height:100%;margin:0}body{background:var(--bg);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button{color:inherit;font:inherit}.shell{width:min(1180px,100% - 32px);min-height:100dvh;padding:calc(18px + env(safe-area-inset-top)) 0 32px;margin:0 auto}.topbar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.brand,.quiet,.primary,.deck-card,.rating,.audio,.segmented button{cursor:pointer;border:0}.brand{text-align:left;background:0 0;align-items:center;gap:12px;min-width:0;padding:0;display:flex}.brand img{object-fit:contain;width:44px;height:44px}.brand span,.deck-copy{min-width:0;display:grid}.brand strong{font-size:16px}.brand small,.deck-copy small,.session,.stat span,.tap-hint,.tips,.notice,.card-meta,.rating small{color:var(--muted)}.session{justify-content:flex-end;align-items:center;gap:10px;min-width:0;font-size:14px;display:flex}.sync-dot{background:var(--amber);border-radius:999px;flex:none;width:10px;height:10px;box-shadow:0 0 0 4px #b46c1b1f}.sync-dot.online{background:var(--green);box-shadow:0 0 0 4px #1b8a5a24}.primary,.quiet{border-radius:var(--radius);justify-content:center;align-items:center;min-height:40px;padding:0 16px;font-weight:750;display:inline-flex}.primary{background:var(--primary);color:#fff}.primary:hover{background:var(--primary-dark)}.primary.small{min-height:34px;padding:0 12px}.quiet{border:1px solid var(--line);background:#ffffffa3}.quiet:hover{background:#fff}.notice{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);margin-bottom:14px;padding:12px 14px}.notice.error{color:#7f1d1d;background:#fff0ec;border-color:#e8b5aa}.loading-panel,.complete-panel,.hero-panel,.today-panel{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);justify-content:space-between;align-items:center;gap:24px;padding:24px;display:flex}.loading-panel{justify-content:center;min-height:280px}.loading-panel.compact{min-height:420px}.loading-panel img,.complete-panel img{object-fit:contain;width:72px;height:72px}.home-grid{gap:18px;display:grid}.hero-panel{overflow:hidden}.hero-panel h1{letter-spacing:0;max-width:720px;margin:0;font-size:clamp(30px,5vw,62px);line-height:.96}.hero-panel p:not(.eyebrow){max-width:680px;color:var(--muted);margin:14px 0 0;font-size:17px;line-height:1.55}.hero-panel img{object-fit:contain;flex:none;width:clamp(96px,16vw,178px);height:clamp(96px,16vw,178px)}.today-panel{overflow:hidden}.today-copy{gap:14px;min-width:0;display:grid}.today-panel h1{letter-spacing:0;max-width:700px;margin:0;font-size:clamp(34px,5vw,64px);line-height:.98}.today-panel p:not(.eyebrow){max-width:650px;color:var(--muted);margin:0;font-size:17px;line-height:1.55}.today-panel img{object-fit:contain;flex:none;width:clamp(104px,16vw,188px);height:clamp(104px,16vw,188px)}.today-actions{flex-wrap:wrap;gap:10px;margin-top:4px;display:flex}.eyebrow{color:var(--primary-dark);letter-spacing:0;text-transform:uppercase;margin:0 0 8px;font-size:12px;font-weight:850}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.stat{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-strong);gap:8px;min-height:92px;padding:16px;display:grid}.stat strong{font-size:30px}.deck-toolbar{justify-content:space-between;align-items:end;gap:16px;margin-top:10px;display:flex}.deck-tools{justify-content:flex-end;align-items:end;gap:10px;min-width:min(100%,520px);display:flex}.deck-search{gap:6px;min-width:220px;display:grid}.deck-search span{color:var(--muted);text-transform:uppercase;font-size:12px;font-weight:850}.deck-search input{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-strong);width:100%;min-height:44px;color:var(--ink);font:inherit;padding:0 12px}.deck-search input:focus{border-color:#c94c3f8c;outline:none;box-shadow:0 0 0 4px #c94c3f1f}.deck-toolbar h2{margin:0;font-size:26px}.segmented{border:1px solid var(--line);border-radius:var(--radius);background:#ffffffb3;grid-template-columns:repeat(3,minmax(74px,1fr));gap:4px;padding:4px;display:inline-grid}.segmented button{background:0 0;border-radius:6px;min-height:34px;font-size:13px;font-weight:800}.segmented button.active{background:var(--ink);color:#fff}.deck-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.deck-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-strong);text-align:left;grid-template-columns:54px minmax(0,1fr) auto;align-items:center;gap:12px;min-height:92px;padding:14px;display:grid}.deck-card:hover{border-color:#c94c3f80;box-shadow:0 10px 24px #5e3f2a1a}.deck-image{border-radius:var(--radius);background:#f8eadc;place-items:center;width:54px;height:54px;display:grid}.deck-image img{object-fit:contain;width:42px;height:42px}.deck-copy strong{overflow-wrap:anywhere;font-size:15px}.deck-copy small{-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.35;display:-webkit-box;overflow:hidden}.deck-count{text-align:center;background:#f5e4d4;border-radius:999px;min-width:38px;padding:6px 9px;font-size:13px;font-weight:850}.empty-state{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-strong);min-height:120px;color:var(--muted);gap:6px;padding:24px;display:grid}.empty-state strong{color:var(--ink)}.study-layout{grid-template-columns:minmax(230px,320px) minmax(0,1fr);align-items:start;gap:18px;display:grid}.study-side{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);gap:18px;padding:18px;display:grid;position:sticky;top:18px}.study-side h1{margin:0;font-size:28px;line-height:1.08}.study-side p{color:var(--muted);margin:8px 0 0}.back{justify-self:start}.meter{gap:8px;display:grid}.meter-head{color:var(--muted);justify-content:space-between;font-size:13px;font-weight:800;display:flex}.meter-track{background:#ead9c9;border-radius:999px;height:10px;overflow:hidden}.meter-track span{border-radius:inherit;background:var(--green);height:100%;transition:width .18s;display:block}.tips{border-top:1px solid var(--line);gap:6px;padding-top:14px;font-size:13px;line-height:1.35;display:grid}.tips strong{color:var(--ink)}.session-score,.summary-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;display:grid}.session-score span,.summary-row span{border:1px solid var(--line);min-height:30px;color:var(--muted);background:#ffffffa3;border-radius:6px;padding:7px 9px;font-size:12px;font-weight:850}.study-main{gap:14px;display:grid}.card-stage{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-strong);min-height:min(62dvh,620px);box-shadow:var(--shadow);-webkit-user-select:none;user-select:none;touch-action:pan-y;align-content:space-between;gap:24px;padding:clamp(20px,4vw,36px);display:grid}.card-stage:focus-visible{outline:3px solid #c94c3f59}.card-meta{text-transform:uppercase;justify-content:space-between;align-items:center;gap:10px;font-size:13px;font-weight:850;display:flex}.prompt{overflow-wrap:anywhere;word-break:break-word;-webkit-hyphens:auto;hyphens:auto;letter-spacing:0;text-align:center;align-self:center;max-width:100%;font-size:clamp(38px,7vw,82px);font-weight:900;line-height:1.04}.prompt.long-prompt{font-size:clamp(30px,5vw,58px);line-height:1.1}.audio{border-radius:var(--radius);background:#f1e4da;justify-self:center;min-height:38px;padding:0 14px;font-weight:800}.answer{border-radius:var(--radius);opacity:0;background:#f8eadc;gap:14px;min-height:116px;padding:18px;transition:opacity .16s,transform .16s;display:grid;transform:translateY(8px)}.revealed .answer{opacity:1;transform:translateY(0)}.answer section{gap:6px;display:grid}.answer span{color:var(--muted);text-transform:uppercase;font-size:12px;font-weight:900}.answer strong{overflow-wrap:anywhere;font-size:clamp(24px,4vw,42px);line-height:1.05}.answer p{color:#5d4d45;margin:0;line-height:1.45}.answer section+section{border-top:1px solid #2018151a;padding-top:8px}.tap-hint{text-align:center;margin:0;font-weight:750}.rating-row{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.rating{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-strong);text-align:left;gap:4px;min-height:72px;padding:12px;display:grid}.rating:hover{border-color:#20181547}.rating span{font-weight:900}.rating.again span{color:var(--primary-dark)}.rating.hard span{color:var(--amber)}.rating.good span{color:var(--green)}.rating.easy span{color:var(--blue)}.rating:disabled{cursor:wait;opacity:.6}.complete-panel{text-align:center;justify-items:center;min-height:520px;display:grid}.complete-panel h2{margin:0;font-size:clamp(32px,5vw,58px);line-height:1}.complete-panel p{max-width:520px;color:var(--muted);margin:0}.summary-row{width:min(520px,100%)}.actions{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}@media (max-width:900px){.shell{width:min(100% - 22px,760px)}.topbar,.deck-toolbar,.deck-tools{flex-direction:column;align-items:stretch}.session{justify-content:flex-start}.hero-panel,.today-panel{align-items:start}.deck-tools{justify-content:flex-start}.stats-grid,.deck-grid,.study-layout,.rating-row{grid-template-columns:1fr}.study-side{position:static}.card-stage{min-height:54dvh}}@media (max-width:560px){.shell{width:calc(100% - 16px);padding-bottom:calc(18px + env(safe-area-inset-bottom))}.brand img{width:38px;height:38px}.session{grid-template-columns:auto minmax(0,1fr) auto;display:grid}.hero-panel,.today-panel{padding:18px}.hero-panel img,.today-panel img{display:none}.today-panel h1{font-size:clamp(32px,12vw,48px)}.today-actions .primary,.today-actions .quiet{width:100%}.deck-card{grid-template-columns:48px minmax(0,1fr) auto}.deck-image{width:48px;height:48px}.study-side{padding:14px}.prompt{font-size:clamp(30px,12vw,58px)}.prompt.long-prompt{font-size:clamp(24px,9vw,42px)}.card-stage{padding:18px}}.category-filter{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;gap:8px;margin-bottom:14px;padding-bottom:6px;display:flex;overflow-x:auto}.category-filter::-webkit-scrollbar{display:none}.cat-pill{border:1px solid var(--line);background:var(--surface-strong);color:var(--muted);cursor:pointer;white-space:nowrap;border-radius:999px;flex:none;align-items:center;gap:6px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.cat-pill:hover{border-color:var(--primary);color:var(--primary)}.cat-pill.active{background:var(--primary);border-color:var(--primary);color:#fff}.cat-pill .cat-count{opacity:.75;font-size:11px;font-weight:700}
