:root{--primary:#d97706;--primary-strong:#b45309;--primary-light:#fef3c7;--primary-glow:#d977062e;--secondary:#0f766e;--secondary-soft:#ccfbf1;--accent:#7c3aed;--bg:#fafaf9;--bg-accent:#f5f0e8;--surface:#fff;--surface-muted:#f5f5f4;--surface-raised:#ffffffeb;--border:#00000014;--border-strong:#00000024;--text:#1c1917;--muted:#78716c;--subtle:#a8a29e;--success:#15803d;--danger:#b91c1c;--warning:#b45309;--info:#1d4ed8;--shadow-xs:0 1px 2px #0000000f;--shadow-sm:0 2px 8px #00000014;--shadow:0 4px 20px #0000001a;--shadow-lg:0 16px 48px #0000001f;--shadow-xl:0 32px 80px #00000029;--radius-sm:10px;--radius:16px;--radius-lg:22px;--radius-xl:28px;--radius-full:999px;--nav-h:60px;--bottom-nav-h:68px;--page-max:1200px;--page-px:20px}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{min-height:100vh;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;margin:0;font-family:Inter,Segoe UI,system-ui,sans-serif;font-size:15px;line-height:1.6}@media (max-width:767px){body{padding-bottom:var(--bottom-nav-h)}}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}h1,h2,h3,h4,p{margin-top:0}img{max-width:100%}body{background:radial-gradient(ellipse 60% 40% at 0% 0%, #d9770614, transparent), radial-gradient(ellipse 50% 35% at 100% 0%, #0f766e12, transparent), var(--bg)}.gradient-text{background:linear-gradient(135deg, var(--primary-strong) 0%, var(--secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.page-shell{width:min(var(--page-max), calc(100% - var(--page-px) * 2));margin:0 auto;padding:24px 0 48px}.study-shell{width:min(860px, calc(100% - var(--page-px) * 2));margin:0 auto;padding:20px 0 48px}@media (max-width:640px){.page-shell,.study-shell{width:calc(100% - 28px);padding-top:16px;padding-bottom:24px}}.surface{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow)}.hero-card,.panel,.deck-card,.study-card,.login-hero,.auth-panel{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.hero-card{padding:32px;position:relative;overflow:hidden}.panel{padding:24px}.deck-card{gap:14px;padding:22px;display:grid}.study-card{padding:24px}.topbar{min-height:var(--nav-h);justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.brand-lockup{align-items:center;gap:12px;display:flex}.brand-mark{border-radius:var(--radius);color:#fff;background:linear-gradient(135deg, var(--primary), #f59e0b);width:44px;height:44px;box-shadow:0 8px 20px var(--primary-glow);flex-shrink:0;place-items:center;font-size:1rem;font-weight:800;display:grid}.nav-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.app-nav{border-radius:var(--radius-full);border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#fffc;gap:6px;width:fit-content;margin-bottom:20px;padding:6px;display:flex}.nav-link{border-radius:var(--radius-full);color:var(--muted);white-space:nowrap;padding:10px 18px;font-size:.9rem;font-weight:600;transition:background .15s,color .15s}.nav-link:hover{color:var(--text);background:#0000000a}.nav-link.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}@media (max-width:767px){.app-nav{display:none}.topbar{margin-bottom:12px}.topbar .nav-actions .pill{display:none}}.bottom-nav{display:none}@media (max-width:767px){.bottom-nav{height:var(--bottom-nav-h);border-top:1px solid var(--border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:100;background:#fffffff5;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{color:var(--subtle);cursor:pointer;padding-bottom:env(safe-area-inset-bottom,0);background:0 0;border:0;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;font-size:.72rem;font-weight:600;text-decoration:none;transition:color .15s;display:flex}.bottom-nav-item.active{color:var(--primary)}.bottom-nav-icon{font-size:1.4rem;line-height:1}}.offline-banner{background:var(--warning);color:#fff;text-align:center;z-index:200;padding:8px 16px;font-size:.85rem;font-weight:600;position:fixed;top:0;left:0;right:0}.eyebrow{border-radius:var(--radius-full);border:1px solid var(--border);color:var(--muted);background:#ffffffc7;align-items:center;gap:6px;margin-bottom:14px;padding:6px 12px;font-size:.82rem;font-weight:600;display:inline-flex}.pill{border-radius:var(--radius-full);background:var(--surface-muted);color:var(--muted);align-items:center;gap:6px;padding:6px 12px;font-size:.82rem;font-weight:600;display:inline-flex}.pill.public{color:var(--secondary);background:#f0fdf9}.pill.private{color:var(--primary-strong);background:#fef9ec}.pill.easy{color:#15803d;background:#f0fdf4}.pill.medium{color:var(--primary-strong);background:#fef9ec}.pill.hard{color:var(--danger);background:#fff1f2}.tag{border-radius:var(--radius-full);border:1px solid var(--border);color:var(--muted);background:#ffffffb3;padding:6px 12px;font-size:.82rem}.tag-row{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.btn{appearance:none;border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:0;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px 20px;font-size:.92rem;font-weight:700;transition:transform .15s,box-shadow .15s,opacity .15s;display:inline-flex}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{color:#fff;background:linear-gradient(135deg, var(--primary), #f59e0b);box-shadow:0 6px 20px var(--primary-glow)}.btn-primary:hover:not(:disabled){box-shadow:0 10px 28px var(--primary-glow)}.btn-secondary{color:var(--text);background:var(--surface);border:1px solid var(--border-strong);box-shadow:var(--shadow-xs)}.btn-ghost{color:var(--muted);border:1px dashed var(--border-strong);background:0 0}.btn-danger{color:var(--danger);background:#fff1f2;border:1px solid #b91c1c26}.btn-google{color:#3c4043;background:var(--surface);border:1px solid var(--border-strong);box-shadow:var(--shadow-sm);gap:10px}.btn-icon{border-radius:var(--radius-sm);width:auto;padding:10px}.input-field,.textarea-field,.select-field,.file-field{border-radius:var(--radius);border:1px solid var(--border-strong);background:var(--surface);width:100%;color:var(--text);outline:none;padding:13px 16px;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.input-field:focus,.textarea-field:focus,.select-field:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.textarea-field{resize:vertical;min-height:130px}.hero{grid-template-columns:minmax(0,1.5fr) minmax(300px,.85fr);gap:20px;margin-bottom:20px;display:grid}.hero-card h1{letter-spacing:-.05em;margin-bottom:12px;font-size:clamp(2rem,5vw,3.8rem);line-height:1}.hero-copy{max-width:54ch;color:var(--muted);font-size:1rem;line-height:1.7}.hero-sidebar{gap:16px;display:grid}.hero-grid{grid-template-columns:repeat(3,1fr);gap:10px;margin-top:24px;display:grid}.metric-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:#fff9;padding:14px 16px}.metric-label{color:var(--muted);margin-bottom:4px;font-size:.82rem;font-weight:500}.metric-value{letter-spacing:-.04em;font-size:1.7rem;font-weight:800}@media (max-width:960px){.hero{grid-template-columns:1fr}.hero-sidebar{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}}@media (max-width:640px){.hero-grid{grid-template-columns:repeat(2,1fr)}}.dashboard-grid{grid-template-columns:minmax(0,1.4fr) minmax(280px,.75fr);align-items:start;gap:20px;display:grid}@media (max-width:960px){.dashboard-grid{grid-template-columns:1fr}}.section-head{justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:16px;display:flex}.section-head p{color:var(--muted);margin-bottom:0;font-size:.9rem}.deck-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.deck-title{letter-spacing:-.03em;font-size:1.2rem;font-weight:700}.deck-description{color:var(--muted);margin-bottom:0;font-size:.88rem;line-height:1.5}.deck-meta{flex-wrap:wrap;gap:6px;display:flex}.deck-actions{grid-template-columns:1fr 1fr;gap:8px;display:grid}.progress-row{color:var(--muted);justify-content:space-between;align-items:center;gap:8px;font-size:.85rem;font-weight:500;display:flex}.progress-track{border-radius:var(--radius-full);background:var(--surface-muted);width:100%;height:8px;margin-top:6px;overflow:hidden}.progress-bar{border-radius:inherit;background:linear-gradient(90deg, var(--secondary), #34d399);height:100%;transition:width .4s}.composer{grid-template-columns:1fr auto;gap:10px;margin-top:14px;display:grid}@media (max-width:480px){.composer{grid-template-columns:1fr}}.hero-actions,.inline-actions,.deck-actions,.cta-row{flex-wrap:wrap;gap:10px;display:flex}.tab-row{border-radius:var(--radius-lg);background:var(--surface-muted);border:1px solid var(--border);gap:4px;padding:5px;display:inline-flex}.tab-chip{color:var(--muted);border-radius:var(--radius);cursor:pointer;background:0 0;border:0;padding:8px 14px;font-size:.88rem;font-weight:600;transition:background .15s,color .15s}.tab-chip.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-xs)}.step-list,.feature-list,.insight-list{gap:12px;display:grid}.step-item,.feature-item,.insight-item{align-items:flex-start;gap:12px;display:flex}.step-index,.feature-icon{border-radius:var(--radius-sm);background:var(--surface-muted);width:32px;height:32px;color:var(--secondary);flex:none;place-items:center;font-size:.88rem;font-weight:800;display:grid}.helper-text{color:var(--muted);font-size:.88rem;line-height:1.5}.muted{color:var(--muted)}.status-note{border-radius:var(--radius-full);background:var(--primary-light);color:var(--primary-strong);align-items:center;gap:8px;padding:8px 14px;font-size:.88rem;font-weight:700;display:inline-flex}.login-shell{place-items:center;min-height:100vh;padding:20px;display:grid}.login-card{grid-template-columns:minmax(0,1.2fr) minmax(300px,.7fr);gap:20px;width:min(1040px,100%);display:grid}.login-hero{padding:36px}.login-hero p{max-width:56ch;color:var(--muted);line-height:1.7}.auth-panel{align-content:center;gap:20px;padding:32px;display:grid}.google-btn-wrap{justify-content:center;display:flex}@media (max-width:860px){.login-card{grid-template-columns:1fr}.login-hero,.auth-panel{padding:28px}}.study-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.study-title{letter-spacing:-.04em;margin-bottom:6px;font-size:clamp(1.6rem,3.5vw,2.6rem)}.study-copy{color:var(--muted);font-size:.9rem}.study-stage{gap:14px;display:grid}.study-top{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}@media (max-width:640px){.study-header,.study-top{flex-direction:column;align-items:flex-start}}.flip-card-wrapper{perspective:1400px;cursor:pointer;-webkit-tap-highlight-color:transparent;width:100%;min-height:340px}.flip-card-inner{width:100%;min-height:340px;transform-style:preserve-3d;transition:transform .55s cubic-bezier(.4,0,.2,1);position:relative}.flip-card-wrapper.flipped .flip-card-inner{transform:rotateY(180deg)}.flip-card-front,.flip-card-back{backface-visibility:hidden;border-radius:var(--radius-xl);border:1px solid var(--border);flex-direction:column;justify-content:space-between;gap:16px;padding:28px;display:flex;position:absolute;inset:0}.flip-card-front{background:linear-gradient(160deg,#fffefb 0%,#f8f2e6 100%)}.flip-card-back{background:linear-gradient(160deg,#f0fdf9 0%,#e0f2ef 100%);transform:rotateY(180deg)}.card-kicker{color:var(--secondary);align-items:center;gap:6px;font-size:.82rem;font-weight:700;display:inline-flex}.card-body{letter-spacing:-.03em;flex:1;align-items:center;font-size:clamp(1.2rem,2.8vw,1.9rem);line-height:1.4;display:flex}.card-footnote{color:var(--muted);font-size:.85rem}@media (max-width:640px){.flip-card-wrapper,.flip-card-inner{min-height:300px}}.swipe-wrapper{touch-action:pan-y;-webkit-user-select:none;user-select:none;position:relative}.swipe-card{transition:transform .15s,box-shadow .15s}.swipe-card.is-dragging{transition:none}.swipe-hint{border-radius:var(--radius-full);pointer-events:none;opacity:0;z-index:10;padding:10px 20px;font-size:1.1rem;font-weight:800;transition:opacity .1s;position:absolute;top:50%;transform:translateY(-50%)}.swipe-hint-right{color:#15803d;background:#dcfce7;border:2px solid #22c55e;left:20px}.swipe-hint-left{color:#b91c1c;background:#fee2e2;border:2px solid #ef4444;right:20px}.rating-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.rating-btn{border-radius:var(--radius-lg);cursor:pointer;text-align:left;border:0;padding:14px 12px;font-size:.9rem;font-weight:800;transition:transform .15s,opacity .15s}.rating-btn:hover{transform:translateY(-2px)}.rating-btn span{opacity:.7;margin-top:3px;font-size:.75rem;font-weight:500;display:block}.rating-again{color:var(--danger);background:#fff1f2}.rating-hard{color:var(--warning);background:#fef9ec}.rating-good{color:var(--info);background:#eff6ff}.rating-easy{color:var(--success);background:#f0fdf4}@media (max-width:540px){.rating-grid{grid-template-columns:repeat(2,1fr)}}.preview-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.preview-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;max-height:65vh;padding-right:4px;display:grid;overflow-y:auto}.preview-card{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);gap:10px;padding:16px;display:grid;position:relative}.preview-card.editing{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.preview-card-actions{justify-content:flex-end;gap:6px;display:flex}.difficulty-badge{border-radius:var(--radius-full);align-items:center;padding:3px 9px;font-size:.75rem;font-weight:700;display:inline-flex}.difficulty-badge.easy{color:#15803d;background:#f0fdf4}.difficulty-badge.medium{color:var(--warning);background:#fef9ec}.difficulty-badge.hard{color:var(--danger);background:#fff1f2}.upload-zone{border:2px dashed var(--border-strong);border-radius:var(--radius-xl);text-align:center;cursor:pointer;padding:40px 20px;transition:border-color .2s,background .2s}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--primary);background:var(--primary-light)}.upload-zone input[type=file]{display:none}.analytics-card{gap:16px;display:grid}.heatmap{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.heatmap-cell{aspect-ratio:1;background:var(--surface-muted);border-radius:6px;transition:background .2s}.heatmap-cell.level-1{background:#a7f3d0}.heatmap-cell.level-2{background:#34d399}.heatmap-cell.level-3{background:#059669}.forgetting-bar{border-radius:var(--radius-full);background:var(--surface-muted);height:10px;margin-top:6px;overflow:hidden}.forgetting-fill{border-radius:inherit;background:linear-gradient(90deg,#fde68a,#ef4444);height:100%;transition:width .4s}.hardest-card-item{border-radius:var(--radius-lg);background:var(--surface-muted);align-items:flex-start;gap:12px;padding:12px;display:flex}.ef-badge{border-radius:var(--radius-sm);width:38px;height:38px;color:var(--danger);background:#fff1f2;flex:none;place-items:center;font-size:.8rem;font-weight:800;display:grid}.modal-backdrop{z-index:300;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000073;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-box{background:var(--surface);border-radius:var(--radius-xl);width:100%;max-width:440px;box-shadow:var(--shadow-xl);padding:28px}.share-link-box{align-items:stretch;gap:8px;margin-top:12px;display:flex}.share-link-input{border-radius:var(--radius);border:1px solid var(--border-strong);background:var(--surface-muted);color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;padding:11px 14px;font-size:.85rem;overflow:hidden}.empty-state{text-align:center;color:var(--muted);gap:20px;padding:48px 24px;display:grid}.empty-icon{margin:0 auto;font-size:3rem;display:block}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.skeleton{border-radius:var(--radius);background:linear-gradient(90deg, var(--surface-muted) 25%, #ececec 50%, var(--surface-muted) 75%);background-size:600px 100%;animation:1.4s infinite shimmer}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.65s linear infinite spin}.spinner-dark{border-color:#0000001f;border-top-color:var(--primary)}.study-layout{flex-direction:column;gap:20px;display:flex}.study-layout.explain-active{grid-template-columns:350px 1fr;align-items:start;display:grid}@media (max-width:800px){.study-layout.explain-active{grid-template-columns:1fr}}.explain-sidebar{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;height:clamp(400px,100vh - 180px,800px);display:flex;position:sticky;top:20px;overflow:hidden;box-shadow:0 4px 20px #0000000d}.explain-header{border-bottom:1px solid var(--border);background:var(--background);padding:16px}.explain-header h3{margin:0 0 4px;font-size:1.1rem}.chat-messages{flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.empty-chat{text-align:center;margin-top:40px}.chat-bubble{border-radius:12px;max-width:90%;padding:10px 14px;font-size:.95rem;line-height:1.4}.chat-bubble.user{background:var(--primary);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.chat-bubble.assistant{background:var(--background);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:4px;align-self:flex-start}.chat-bubble.typing{opacity:.7;font-style:italic}.chat-input-area{border-top:1px solid var(--border);background:var(--background);gap:8px;padding:12px;display:flex}.instruction-box{background:var(--surface);border:1px dashed var(--secondary);border-radius:12px;margin-top:24px;padding:16px}.instruction-box code{background:var(--background);border:1px solid var(--border);border-radius:4px;padding:2px 6px;font-family:monospace;font-weight:600}
