:root {
  --ink: #061f46;
  --muted: #647083;
  --line: #dbe2eb;
  --paper: #f7f9fc;
  --white: #ffffff;
  --green: #082856;
  --green-dark: #061f46;
  --gold: #d49a2a;
  --blue: #082856;
  --danger: #bd101b;
  --red: #bd101b;
  --shadow: 0 22px 60px rgba(6, 31, 70, 0.12);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: Inter, ui-sans-serif, system-ui, "Segoe UI", sans-serif; }
button, input, textarea, select { font: inherit; }
button { cursor: pointer; }
button:disabled { cursor: not-allowed; opacity: 0.55; }
.hidden { display: none !important; }

.login-view { min-height: 100vh; min-height: 100svh; position: relative; display: grid; place-items: center; overflow: hidden; background: #020714; }
.login-visual { position: absolute; inset: 0; overflow: hidden; }
.login-hero-image { width: 100%; height: 100%; object-fit: cover; display: block; }
.login-visual::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(2,7,20,0.92) 0%, rgba(2,7,20,0.62) 36%, rgba(2,7,20,0.18) 66%, rgba(2,7,20,0.74) 100%), linear-gradient(0deg, rgba(2,7,20,0.92), transparent 38%); }
.visual-overlay { position: absolute; inset: 0; }
.front-hero { position: relative; z-index: 2; width: 100%; min-height: 100vh; min-height: 100svh; padding: clamp(18px, 2.4vw, 34px); color: #fff; }
.front-nav { display: grid; grid-template-columns: minmax(210px, 320px) 1fr auto; align-items: center; gap: 28px; }
.front-nav img { width: min(250px, 20vw); min-width: 176px; height: auto; padding: 8px 12px; border-radius: 8px; background: rgba(255,255,255,0.92); border: 1px solid rgba(255,255,255,0.64); box-shadow: 0 18px 44px rgba(0,0,0,0.24); backdrop-filter: blur(10px); }
.front-nav nav { display: flex; justify-content: center; gap: clamp(18px, 3vw, 48px); }
.front-nav nav a { color: rgba(255,255,255,0.86); text-decoration: none; font-weight: 800; padding: 10px 0; border-bottom: 3px solid transparent; }
.front-nav nav a.active, .front-nav nav a:hover { color: #fff; border-color: var(--red); }
.front-nav nav a small, .sidebar nav a small { margin-left: 4px; color: var(--gold); font-size: 0.68em; text-transform: uppercase; }
.front-login-btn, .glass-btn { min-height: 48px; padding: 0 22px; border-radius: 999px; border: 1px solid rgba(255,255,255,0.65); background: rgba(255,255,255,0.08); color: #fff; font-weight: 900; backdrop-filter: blur(10px); }
.front-copy { width: min(680px, 52vw); margin-top: clamp(42px, 6vh, 78px); }
.front-kicker { margin: 0 0 16px; color: rgba(255,255,255,0.92); font-size: clamp(0.9rem, 1.15vw, 1.06rem); font-weight: 850; letter-spacing: 0.02em; text-transform: uppercase; }
.front-kicker strong, .front-copy h1 span { color: var(--red); }
.front-copy h1 { margin: 0; font-size: clamp(3.6rem, 7.2vw, 6.7rem); line-height: 0.92; letter-spacing: 0; color: #fff; text-shadow: 0 16px 50px rgba(0,0,0,0.28); }
.front-line { width: 72px; height: 4px; margin: 22px 0 18px; border-radius: 999px; background: var(--gold); }
.front-copy p:not(.front-kicker) { max-width: 520px; color: rgba(255,255,255,0.86); font-size: clamp(1rem, 1.25vw, 1.18rem); line-height: 1.48; }
.front-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 26px; }
.hero-cta, .glass-btn { min-height: 54px; padding: 0 24px; font-size: 1rem; }
.trust-row { display: flex; align-items: center; gap: 14px; margin-top: 24px; }
.trust-badge { display: grid; place-items: center; width: 54px; height: 54px; border-radius: 999px; background: var(--red); color: #fff; font-weight: 950; box-shadow: 0 14px 38px rgba(189,16,27,0.28); }
.trust-row p { margin: 0; max-width: 280px !important; font-size: 0.98rem !important; }
.coach-teaser { position: absolute; right: clamp(24px, 4vw, 62px); bottom: clamp(22px, 4vh, 52px); width: min(470px, 36vw); display: grid; grid-template-columns: 112px 1fr; gap: 18px; align-items: center; padding: 18px; border: 1px solid rgba(255,255,255,0.28); border-radius: 8px; background: rgba(2,7,20,0.72); box-shadow: 0 24px 70px rgba(0,0,0,0.34); backdrop-filter: blur(16px); }
.coach-avatar { display: grid; place-items: center; width: 112px; aspect-ratio: 1; border-radius: 8px; background: linear-gradient(135deg, #f8fafc, #dfe7ef); color: var(--red); font-size: 2rem; font-weight: 950; }
.coach-teaser strong { color: #fff; }
.coach-teaser h2 { margin: 10px 0 5px; font-size: clamp(1.25rem, 1.7vw, 1.65rem); }
.coach-teaser p { margin: 0 0 14px; color: rgba(255,255,255,0.82); line-height: 1.42; font-size: 0.94rem; }
.online-dot { display: inline-block; width: 10px; height: 10px; margin-right: 7px; border-radius: 50%; background: #27d17f; }
.hero-logo { width: clamp(150px, 18vw, 240px); height: auto; display: block; margin-bottom: 24px; padding: 10px; background: rgba(255, 255, 255, 0.94); border-radius: 8px; box-shadow: 0 16px 44px rgba(0,0,0,0.22); }
.visual-overlay h1, .topbar h1, .module-page-header h1 { margin: 0; font-size: clamp(2.4rem, 6vw, 5rem); line-height: 0.98; letter-spacing: 0; }
.visual-overlay p:not(.eyebrow) { max-width: 600px; color: rgba(255,255,255,0.84); line-height: 1.7; }

.login-card { position: relative; z-index: 4; align-self: center; justify-self: center; width: min(420px, calc(100% - 42px)); display: grid; gap: 18px; padding: 32px; background: rgba(255,255,255,0.97); border: 1px solid var(--line); border-radius: 8px; box-shadow: 0 26px 70px rgba(0,0,0,0.34); }
.access-gate { width: min(460px, calc(100% - 42px)); }
.access-error { margin: -4px 0 0; padding: 11px 12px; border-radius: 8px; background: #fff4f5; color: var(--red); font-weight: 800; }
.register-card { width: min(760px, calc(100% - 42px)); max-height: calc(100vh - 48px); overflow: auto; }
.form-logo { width: 190px; max-width: 72%; height: auto; justify-self: center; margin-bottom: 4px; }
.login-card h2, .panel h2, .content-section h2, .mock-interview h2, .hero-panel h2 { margin: 0; font-size: clamp(1.35rem, 2.3vw, 2.2rem); line-height: 1.15; }
.eyebrow { margin: 0 0 8px; color: var(--gold); font-size: 0.74rem; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; }
.muted { color: var(--muted); line-height: 1.6; }
label { display: grid; gap: 7px; color: #2f423d; font-weight: 800; }
input, textarea, select { width: 100%; border: 1px solid #cdd9d4; background: #fbfdfc; color: var(--ink); border-radius: 8px; padding: 13px 14px; outline: none; }
textarea { min-height: 180px; resize: vertical; line-height: 1.55; }
input:focus, textarea:focus, select:focus { border-color: var(--green); box-shadow: 0 0 0 4px rgba(8, 40, 86, 0.12); }

.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.wide-field { grid-column: 1 / -1; }
.plan-list { display: grid; gap: 10px; }
.plan-option { display: grid; grid-template-columns: auto minmax(0, 1fr) auto; align-items: center; gap: 12px; padding: 14px; border: 1px solid var(--line); border-radius: 8px; background: #fbfdfc; cursor: pointer; }
.plan-option:has(input:checked) { border-color: var(--red); background: #fff8f8; box-shadow: 0 0 0 3px rgba(189,16,27,0.08); }
.plan-option input { width: auto; }
.plan-option span { display: grid; gap: 4px; }
.plan-option small { color: var(--muted); font-weight: 650; line-height: 1.4; }
.plan-option b { color: var(--red); }
.disabled-option { opacity: 0.62; }
.disabled-option input { pointer-events: none; }
.checkout-summary { display: grid; gap: 8px; padding: 16px; border-radius: 8px; background: #f4faf7; border: 1px solid #d8e7e1; }
.checkout-summary strong { font-size: 1.2rem; color: var(--green-dark); }
.checkout-summary span { color: var(--muted); font-weight: 800; }

.primary-btn, .secondary-btn, .text-btn { min-height: 44px; border-radius: 8px; border: 0; font-weight: 900; }
.primary-btn { padding: 0 18px; color: #fff; background: var(--red); }
.primary-btn:hover { background: var(--green-dark); }
.secondary-btn { padding: 0 16px; color: var(--green-dark); background: #edf2f8; border: 1px solid #d7e1ee; }
.text-btn { background: transparent; color: var(--red); }

.dashboard { min-height: 100vh; display: grid; grid-template-columns: 280px minmax(0, 1fr); }
.sidebar { position: sticky; top: 0; height: 100vh; display: flex; flex-direction: column; gap: 28px; padding: 24px; background: #061f46; color: #fff; }
.brand, .student-card { display: flex; align-items: center; gap: 12px; }
.brand img { width: 58px; height: 58px; object-fit: contain; padding: 5px; background: #fff; border-radius: 8px; }
.brand small, .student-card small { display: block; color: rgba(255,255,255,0.64); }
nav { display: grid; gap: 8px; }
nav a { color: rgba(255,255,255,0.8); text-decoration: none; padding: 12px 14px; border-radius: 8px; font-weight: 800; }
nav a.active, nav a:hover { color: #fff; background: rgba(255,255,255,0.11); }
.student-card { margin-top: auto; padding: 14px; border: 1px solid rgba(255,255,255,0.16); border-radius: 8px; }
.status-dot { width: 10px; height: 10px; background: #63d09b; border-radius: 50%; }
.workspace { min-width: 0; padding: 32px; }
.topbar, .section-heading, .interview-header { display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.topbar { margin-bottom: 28px; }
.topbar h1, .module-page-header h1 { color: var(--green-dark); }
.topbar-actions { display: flex; align-items: center; gap: 12px; }
.brand-chip { display: flex; align-items: center; gap: 10px; min-height: 44px; padding: 6px 12px 6px 7px; border: 1px solid var(--line); border-radius: 8px; background: #fff; color: var(--green-dark); font-weight: 900; box-shadow: 0 8px 24px rgba(6,31,70,0.06); }
.brand-chip img { width: 34px; height: 34px; object-fit: contain; }

.hero-panel { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(300px, 0.8fr); gap: 24px; padding: clamp(24px, 4vw, 42px); background: linear-gradient(135deg, #fff, #eef4fb); border: 1px solid var(--line); border-radius: 8px; box-shadow: 0 10px 32px rgba(6,31,70,0.08); }
.hero-panel p { color: var(--muted); max-width: 720px; line-height: 1.7; }
.intro-step-card { display: grid; grid-template-columns: auto minmax(0, 1fr) auto; align-items: center; gap: 16px; max-width: 860px; margin-top: 22px; padding: 18px; border: 1px solid #ecd7aa; border-radius: 8px; background: #fffaf1; }
.intro-step-card h3 { margin: 0 0 4px; color: var(--green-dark); font-size: 1.1rem; }
.intro-step-card p { margin: 0; line-height: 1.45; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; }
.metrics-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.metrics-grid article { display: grid; align-content: center; gap: 8px; min-height: 132px; padding: 22px; background: var(--white); border: 1px solid var(--line); border-radius: 8px; }
.metrics-grid article:first-child { grid-column: span 2; }
.metrics-grid strong { font-size: 2.1rem; color: var(--blue); }
.metrics-grid span, .score-pill { color: var(--muted); font-weight: 800; }

.content-section, .panel, .mock-interview, .admin-view { margin-top: 28px; }
.module-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(245px, 1fr)); gap: 16px; margin-top: 18px; }
.module-card { min-height: 240px; display: flex; flex-direction: column; justify-content: flex-end; gap: 12px; padding: 18px; color: #fff; border-radius: 8px; border: 0; text-align: left; background: linear-gradient(150deg, #061f46, #163b72); position: relative; overflow: hidden; }
.module-card::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 78% 22%, rgba(212,154,42,0.34), transparent 32%), linear-gradient(180deg, transparent, rgba(6,31,70,0.9)); }
.module-card > * { position: relative; }
.module-card small { width: fit-content; padding: 6px 9px; border-radius: 999px; background: rgba(255,255,255,0.14); font-weight: 900; }
.module-card h3 { margin: 0; font-size: 1.35rem; }
.module-card p { margin: 0; color: rgba(255,255,255,0.78); line-height: 1.45; }

.module-page-header { display: grid; grid-template-columns: auto minmax(0, 1fr); gap: 22px; align-items: start; margin-bottom: 24px; padding-bottom: 22px; border-bottom: 1px solid var(--line); }
.module-page-header p:not(.eyebrow) { max-width: 820px; color: var(--muted); line-height: 1.65; }
.module-page-grid { display: grid; grid-template-columns: minmax(0, 1fr) 310px; gap: 22px; align-items: start; }
.panel, .side-panel, .mock-interview, .admin-view { background: var(--white); border: 1px solid var(--line); border-radius: 8px; padding: 22px; }
.side-panel { position: sticky; top: 24px; display: grid; gap: 14px; }
.episode-frame { min-height: 310px; display: grid; align-content: end; gap: 10px; margin-bottom: 22px; padding: 24px; color: #fff; border-radius: 8px; background: linear-gradient(180deg, rgba(11,28,24,0.08), rgba(11,28,24,0.86)), url("assets/visa-training-hero.png") center/cover; }
.episode-frame span, .question-card span, .feedback-card span { color: #f3c667; font-weight: 900; text-transform: uppercase; font-size: 0.76rem; letter-spacing: 0.1em; }
.episode-frame h3, .question-card h3 { margin: 0; font-size: clamp(1.45rem, 2vw, 2rem); }
.coach-card, .resource-card, .progress-card { display: grid; gap: 12px; padding: 18px; border: 1px solid #cfe0d9; border-radius: 8px; background: #f4faf7; }
.resource-card { background: #fffaf1; border-color: #ecd7aa; }
.coach-card.empty { background: #fafbfa; border-style: dashed; }
.coach-card h2, .resource-card h2 { margin: 0; color: var(--green-dark); font-size: 1.18rem; }
.coach-card p, .resource-card p, .progress-card p { margin: 0; color: var(--muted); line-height: 1.55; }
.coach-link, .resource-link { display: inline-grid; place-items: center; min-height: 44px; text-decoration: none; text-align: center; }
.lesson-coach-card { margin-top: 22px; grid-template-columns: minmax(0, 1fr) auto; align-items: center; border-color: #d9b765; background: #fffaf1; }
.lesson-coach-card .eyebrow, .lesson-coach-card h2, .lesson-coach-card p { grid-column: 1; }
.lesson-coach-card .coach-link, .lesson-coach-card button { grid-column: 2; min-width: 210px; }
.module-time { font-weight: 800; color: var(--green-dark) !important; }
.sequence-list { display: grid; gap: 8px; margin: 0; padding-left: 20px; color: var(--muted); font-weight: 800; }
.sequence-list li.complete { color: var(--green-dark); }
.sequence-list li.complete::marker { content: "✓ "; color: var(--red); }
.lock-message { margin-top: 16px; padding: 14px 16px; border: 1px dashed #d4b15f; border-radius: 8px; background: #fffaf1; color: var(--green-dark); font-weight: 800; line-height: 1.5; }
.panel.locked { background: #fbfcfe; }

.questions-panel { margin-top: 22px; }
.sample-answer-list { display: grid; gap: 12px; margin-top: 18px; }
.sample-answer { border: 1px solid var(--line); border-radius: 8px; background: #fbfdfc; overflow: hidden; }
.sample-answer button { width: 100%; min-height: 64px; display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; padding: 15px 16px; border: 0; background: transparent; color: var(--ink); font-weight: 900; text-align: left; }
.sample-answer button span { display: grid; gap: 5px; line-height: 1.45; }
.sample-answer button small { color: var(--gold); font-size: 0.72rem; font-weight: 900; letter-spacing: 0.1em; text-transform: uppercase; }
.sample-answer button strong { flex: 0 0 auto; display: grid; place-items: center; width: 28px; aspect-ratio: 1; border-radius: 50%; background: #e8f1ed; color: var(--green-dark); }
.answer-body { border-top: 1px solid var(--line); background: #fff; }
.answer-body p { margin: 0; padding: 16px; color: #3d504b; line-height: 1.65; }
.question-audio { display: grid; gap: 9px; margin: 0 16px 16px; padding: 12px; border-radius: 8px; background: #f4faf7; border: 1px solid #d8e7e1; }
.question-audio span { color: var(--green-dark); font-size: 0.8rem; font-weight: 900; letter-spacing: 0.08em; text-transform: uppercase; }
.question-audio audio { width: 100%; min-height: 38px; }
.question-audio.empty { background: #fafbfa; border-style: dashed; color: var(--muted); }

.quiz-form { display: grid; gap: 12px; margin-top: 16px; }
.quiz-item { display: grid; gap: 10px; padding: 14px; border: 1px solid var(--line); border-radius: 8px; background: #fbfdfc; }
.quiz-options { display: grid; gap: 8px; }
.quiz-options label { display: flex; align-items: flex-start; gap: 9px; font-weight: 650; color: #3c504a; }
.quiz-options input { width: auto; margin-top: 4px; }
.score-pill { padding: 8px 11px; border-radius: 999px; background: #eef4f1; white-space: nowrap; }
.interview-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(300px, 0.82fr); gap: 18px; margin-top: 18px; }
.question-card, .feedback-card { display: grid; gap: 14px; align-content: start; padding: 20px; background: #f9fbfa; border: 1px solid var(--line); border-radius: 8px; }
.coming-soon-panel { display: grid; gap: 14px; padding: clamp(22px, 4vw, 42px); border: 1px dashed #d4b15f; border-radius: 8px; background: #fffaf1; }
.coming-soon-panel h3 { margin: 0; color: var(--green-dark); font-size: clamp(1.4rem, 2vw, 2rem); }
.coming-soon-panel p { margin: 0; max-width: 760px; color: var(--muted); line-height: 1.7; }
.coming-soon-panel .primary-btn { width: fit-content; }
.feedback-card ul { margin: 0; padding-left: 20px; color: #324842; line-height: 1.7; }
.good { color: var(--green); }
.warn { color: var(--danger); }
.mock-score { display: grid; grid-template-columns: auto minmax(0, 1fr); gap: 14px; align-items: center; padding: 14px; border: 1px solid #d8e7e1; border-radius: 8px; background: #f4faf7; }
.mock-score > strong { display: grid; place-items: center; width: 68px; aspect-ratio: 1; border-radius: 50%; background: #e8f1ed; color: var(--green-dark); font-size: 1.4rem; }
.mock-score b { display: block; color: var(--green-dark); }
.mock-score small { display: block; margin-top: 4px; color: var(--muted); line-height: 1.45; }
.mock-score.warn { background: #fffaf1; border-color: #ecd7aa; }
.mock-score.warn > strong { background: #fff0d2; color: #946200; }
.mock-score.danger { background: #fff4f5; border-color: #f0c7cc; }
.mock-score.danger > strong { background: #ffe1e5; color: var(--danger); }
.score-bar { height: 9px; overflow: hidden; border-radius: 999px; background: #e8edf4; }
.score-bar i { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--red), var(--gold), #2f9e69); }
.coach-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 8px; }
.coach-grid article { display: grid; gap: 4px; padding: 10px; border: 1px solid var(--line); border-radius: 8px; background: #fff; }
.coach-grid strong { color: var(--green-dark); font-size: 1.1rem; }
.coach-grid span { color: var(--muted); font-size: 0.74rem; font-weight: 850; line-height: 1.3; }
.officer-view, .better-answer, .practice-task, .red-flags { display: grid; gap: 8px; padding: 14px; border-radius: 8px; }
.officer-view { border-left: 5px solid var(--red); background: #fff4f5; }
.better-answer { border-left: 5px solid var(--gold); background: #fffaf1; }
.practice-task { border-left: 5px solid var(--green-dark); background: #f4faf7; }
.red-flags { border: 1px solid #f0c7cc; background: #fff4f5; }
.officer-view strong, .better-answer strong, .practice-task strong, .red-flags strong { color: var(--green-dark); }
.officer-view p, .better-answer p, .practice-task p { margin: 0; color: #324842; line-height: 1.6; }
.red-flags ul { margin: 0; padding-left: 20px; color: var(--danger); line-height: 1.6; }
.admin-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.admin-summary { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin-top: 18px; }
.admin-summary article { padding: 16px; border: 1px solid var(--line); border-radius: 8px; background: #f9fbfa; }
.admin-summary strong { display: block; margin-bottom: 6px; color: var(--green-dark); font-size: 1.7rem; }
.admin-summary span { color: var(--muted); font-weight: 800; }
.admin-table-wrap { margin-top: 18px; overflow-x: auto; border: 1px solid var(--line); border-radius: 8px; }
.admin-table { width: 100%; border-collapse: collapse; min-width: 920px; background: #fff; }
.admin-table th, .admin-table td { padding: 13px 14px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
.admin-table th { background: #f4f7fb; color: var(--green-dark); font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.08em; }
.admin-table td { color: #30445a; line-height: 1.45; }
.admin-table tr:last-child td { border-bottom: 0; }
.help-pill { display: inline-grid; place-items: center; min-height: 28px; padding: 4px 10px; border-radius: 999px; background: #eef7f2; color: var(--green-dark); font-weight: 900; white-space: nowrap; }
.help-pill.warn { background: #fff4e5; color: #946200; }
.help-pill.danger { background: #fff0f1; color: var(--danger); }
.student-meta { display: grid; gap: 3px; }
.student-meta small { color: var(--muted); }

@media (max-width: 980px) {
  .dashboard, .hero-panel, .module-page-grid, .interview-grid { grid-template-columns: 1fr; }
  .front-nav { grid-template-columns: 1fr auto; }
  .front-nav nav { display: none; }
  .front-copy { width: min(680px, 92vw); margin-top: 70px; }
  .coach-teaser { position: relative; right: auto; bottom: auto; width: min(680px, 92vw); margin-top: 42px; }
  .sidebar { position: static; height: auto; }
  nav { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .module-page-header { grid-template-columns: 1fr; }
  .side-panel { position: static; }
  .lesson-coach-card { grid-template-columns: 1fr; }
  .lesson-coach-card .coach-link, .lesson-coach-card button { grid-column: 1; width: 100%; }
  .intro-step-card { grid-template-columns: 1fr; }
}

@media (max-width: 680px) {
  .workspace, .sidebar { padding: 18px; }
  .topbar, .section-heading, .interview-header { align-items: flex-start; flex-direction: column; }
  nav { grid-template-columns: 1fr 1fr; }
  .metrics-grid { grid-template-columns: 1fr; }
  .admin-summary { grid-template-columns: 1fr 1fr; }
  .coach-grid { grid-template-columns: 1fr 1fr; }
  .metrics-grid article:first-child { grid-column: auto; }
  .login-card { padding: 24px; }
  .form-grid { grid-template-columns: 1fr; }
  .front-copy h1 { font-size: clamp(3.2rem, 16vw, 5.2rem); }
  .coach-teaser { grid-template-columns: 1fr; }
  .coach-avatar { width: 104px; }
}
