*{box-sizing:border-box}body{margin:0;min-height:100vh;background:#f8fafc}:root{font-family:Inter,system-ui,-apple-system,sans-serif;color:#0f172a;background-color:#f8fafc}#root{width:100%}.review-shell{min-height:100vh;display:flex;flex-direction:column;padding:2rem 1.25rem 3rem;gap:1.5rem;background:radial-gradient(circle at top,#fff,#f1f5f9 40%,#e2e8f0)}.review-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem}.deck-label{margin:0;font-weight:600}.deck-count{margin:0;color:#475569}.review-card-wrapper{flex:1;display:flex;flex-direction:column;gap:1rem;align-items:center;justify-content:center}.flashcard.review{width:min(600px,100%);min-height:260px;padding:2rem;background:#fff;color:#0f172a;border-radius:1.5rem;border:1px solid rgba(15,23,42,.1);box-shadow:0 40px 80px #0f172a40;display:flex;flex-direction:column;justify-content:center;gap:.5rem}.flashcard.review .hint{color:#64748b}.flashcard.review .tip{color:#475569}.flashcard-image{margin-top:.5rem;max-width:100%;max-height:220px;object-fit:contain;border-radius:16px;border:1px solid rgba(15,23,42,.08);background:#f8fafc}.audio-button{align-self:flex-start;margin-top:.5rem;background:#0f172a;color:#fff;border:none;border-radius:999px;padding:.35rem .75rem;font-size:.85rem;cursor:pointer}.audio-button:hover{background:#1e293b}.review-actions{display:flex;gap:1rem}.review-progress{font-weight:600}.review-complete{width:min(600px,100%);background:#fff;border-radius:1.5rem;padding:2rem;border:1px solid rgba(15,23,42,.1);box-shadow:0 30px 70px #0f172a2e;display:flex;flex-direction:column;gap:1.25rem;text-align:center}.review-complete h2{margin:0}.review-score{font-size:1.6rem;font-weight:700;margin:0}.review-complete-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.review-pill{background:#f8fafc;border-radius:16px;padding:1rem;border:1px solid rgba(15,23,42,.08);display:flex;flex-direction:column;gap:.5rem}.review-pill span{font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:#64748b}.review-pill strong{font-size:1.4rem}.resume-overlay{position:fixed;inset:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:40}.resume-card{width:min(520px,100%);background:#fff;border-radius:20px;padding:2rem;box-shadow:0 30px 80px #0f172a33;display:flex;flex-direction:column;gap:1rem}.resume-card h2{margin:0}.resume-stats{display:flex;gap:1rem;color:#64748b;font-size:.9rem}.resume-actions{display:flex;gap:.75rem;flex-wrap:wrap}.page{max-width:1100px;margin:0 auto;padding:2rem 1.25rem 3rem;display:flex;flex-direction:column;gap:2rem}.topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem}.brand{font-weight:700;font-size:1.1rem;letter-spacing:.02em}.topbar-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.user-pill{font-size:.85rem;color:#475569;background:#f1f5f9;border-radius:999px;padding:.3rem .75rem}.login-panel,.access-denied,.access-check{background:#fff;border-radius:24px;padding:2rem;box-shadow:0 20px 60px #0f172a14}.stats-panel{background:#fff;border-radius:24px;padding:2rem;box-shadow:0 20px 60px #0f172a14;display:flex;flex-direction:column;gap:2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.stat-card{background:#f8fafc;border-radius:20px;padding:1.25rem;border:1px solid rgba(15,23,42,.08)}.stat-label{font-size:.85rem;text-transform:uppercase;letter-spacing:.12em;color:#64748b;margin:0 0 .5rem}.stat-muted{margin:0;color:#94a3b8}.stat-value{font-size:1.8rem;font-weight:700;margin:0}.chart-card{background:#f8fafc;border-radius:20px;padding:1.5rem;border:1px solid rgba(15,23,42,.08)}.chart{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;align-items:end;height:140px;margin-top:1rem}.chart-bar{display:flex;flex-direction:column;align-items:center;gap:.35rem;height:100%;justify-content:flex-end}.chart-fill{width:100%;border-radius:12px;background:#0f172a;min-height:6px}.chart-bar span{font-size:.75rem;color:#64748b}.chart-axis{margin-top:.75rem;display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;font-size:.75rem;color:#94a3b8}.deck-progress{display:flex;flex-direction:column;gap:1rem}.deck-progress-list{display:flex;flex-direction:column;gap:.75rem}.deck-progress-item{background:#f8fafc;border-radius:16px;padding:1rem;border:1px solid rgba(15,23,42,.08)}.deck-progress-header{display:flex;justify-content:space-between;font-weight:600;color:#0f172a;margin-bottom:.5rem}.deck-progress-bar{width:100%;height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden}.deck-progress-fill{height:100%;background:#0f172a;border-radius:999px}.deck-progress-inline{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.deck-progress-inline .deck-title{margin:0}.access-actions{margin-top:1.5rem;display:flex;gap:.75rem;flex-wrap:wrap}.primary-link{background:#0f172a;color:#fff;border-radius:999px;padding:.55rem 1rem;text-decoration:none;font-weight:600}.primary-link:hover{background:#1e293b}.status-link{margin-left:.5rem;color:#0f172a;font-weight:600;text-decoration:underline}.hero{background:#fff;border-radius:24px;padding:2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;box-shadow:0 20px 60px #0f172a14}.eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.75rem;color:#64748b}.hero h1{font-size:clamp(2.5rem,4vw,3.5rem);margin-bottom:1rem}.hero p{color:#475569;line-height:1.6}.hero-actions{margin-top:1.5rem;display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.auth-card{display:flex;flex-direction:column;gap:.75rem;width:100%}.auth-card input{padding:.75rem 1rem;border-radius:999px;border:1px solid rgba(15,23,42,.2)}.inline-link-button{background:transparent;color:#0f172a;border:none;padding:0;width:fit-content;text-decoration:underline;font-weight:500}.inline-link-button:hover{transform:none;box-shadow:none}.oauth-button{display:inline-flex;align-items:center;justify-content:center;gap:.6rem}.user-bar{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}button{background:#0f172a;color:#fff;border:none;padding:.85rem 1.5rem;border-radius:999px;font-weight:600;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}button:hover{transform:translateY(-1px);box-shadow:0 10px 20px #0f172a33}button.outline{background:transparent;border:1px solid #0f172a;color:#0f172a}.card{background:#0f172a;color:#fff;border-radius:1.25rem;padding:1.5rem}.flashcard{background:#ffffff0d;border-radius:1.25rem;padding:1.25rem;min-height:140px;cursor:pointer;border:1px solid rgba(255,255,255,.12);display:flex;flex-direction:column;justify-content:center;gap:.5rem}.flashcard .hint{font-size:.8rem;color:#ffffffb3;margin:0}.flashcard .content{font-size:1.75rem;font-weight:600;margin:0}.flashcard .tip{font-size:.9rem;color:#fffc;margin:0}section{background:#fff;border-radius:24px;padding:2rem;box-shadow:0 20px 60px #02061714}section h2{margin-bottom:1.25rem;font-size:1.75rem}.deck-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.deck-card{border:1px solid rgba(15,23,42,.08);border-radius:1rem;padding:1.25rem;background:#f8fafc;min-height:160px;cursor:pointer;transition:transform .15s ease,border-color .15s ease;display:flex;flex-direction:column;gap:.35rem}.deck-card:hover{transform:translateY(-2px);border-color:#0f172a}.deck-card.active{border-color:#0f172a;box-shadow:0 10px 30px #0f172a26}.deck-title{font-weight:600}.deck-language{font-size:.85rem;color:#475569}.deck-description{flex:1;color:#64748b}.status-banner{background:#e0f2fe;color:#0f172a;border-radius:1rem;padding:1rem 1.25rem;font-weight:500}footer{text-align:center;color:#475569;font-size:.95rem}@media(max-width:600px){.hero{padding:1.5rem}section{padding:1.5rem}.hero-actions{flex-direction:column;align-items:stretch}button{width:100%}}
