/* ============================================================
   refine.css — Responsive polish for learnfinlingo.online
   ------------------------------------------------------------
   Loaded LAST so it wins the cascade.

   TWO worlds, one codebase:

   • MOBILE (< 900px): the original app is left ALONE — the
     centered phone frame and bottom navigation are preserved.
     We only restyle content (icons, cards, heroes, the path).

   • DESKTOP (>= 900px): a contained, premium web app — a single
     centered 1100–1200px frame (NOT full-bleed), a top nav bar,
     internal scrolling, and a two-column Learn dashboard.

   Design language everywhere: white surfaces, black type, soft
   gray hairline borders, the smallest shadows, tiny green accent.
   Delete this file + its <link> to fully revert.
   ============================================================ */

:root {
  --app-max:        1200px;   /* desktop contained frame */
  --read-max:       720px;    /* quiz / course / result  */
  --single-max:     860px;    /* single-column pages     */
  --rail-w:         330px;    /* Learn right sidebar      */
  --header-h:       60px;
  --nav-h:          52px;
}


/* ════════════════════════════════════════════════════════════
   UNIVERSAL CONTENT POLISH  (mobile + desktop)
   No layout/shell changes here — only how things look.
   ════════════════════════════════════════════════════════════ */

/* Brand wordmark — quiet green accent on "lingo". */
.brand-lingo { color: var(--green-text); }

/* Heroes are typographic now — no decorative illustrations.
   They stack as plain blocks (the old flex + art layout is gone). */
.learn-hero,
.market-hero,
.mastery-hero { display: block; }
.learn-hero-art,
.market-hero-art,
.mastery-hero-art { display: none !important; }
.learn-h1,
.market-h1,
.mastery-h1 {
  letter-spacing: -0.038em;
  line-height: 1.05;
  font-weight: 800;
}
.learn-accent, .market-accent, .mastery-accent { color: var(--green-text); }

/* Lesson icon — monochrome line glyph in a rounded square,
   green only on hover and completion. */
.ls-icon {
  background: var(--bg2);
  border: 1px solid var(--border);
  color: var(--text-sub);
}
.ls-icon svg { stroke: currentColor; fill: none; }
.ls-card:hover .ls-icon { border-color: var(--green); color: var(--green-text); }
.ls-card-completed .ls-icon { background: var(--green-dim); border-color: transparent; color: var(--green-text); }

/* Flat, hairline cards with the faintest lift — no heavy shadows. */
.ls-card,
.rail-card,
.learn-path-card,
.fl-continue,
.fluency-card,
.practice-daily,
.profile-card,
.market-simplified-hero,
.market-qa-item {
  box-shadow: none;
  border: 1px solid var(--border);
}
.ls-card { transition: border-color 0.15s ease, box-shadow 0.15s ease; }
.ls-card:hover { border-color: var(--border2); box-shadow: 0 6px 18px rgba(15,18,24,0.05); transform: none; }

/* ── Right-rail cards (used on Learn; stack on mobile) ─────── */
.rail-card { padding: 20px; border-radius: 16px; background: var(--bg); }
.rail-card-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 14px; }
.rail-kicker {
  font-family: var(--font-b);
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.07em;
  text-transform: uppercase; color: var(--muted);
}
.rail-pct {
  font-family: var(--font-num); font-size: 1.45rem; font-weight: 600;
  color: var(--green-text); font-variant-numeric: tabular-nums;
}
.rail-level { font-family: var(--font-d); font-size: 1rem; font-weight: 700; color: var(--text); margin-bottom: 12px; }
.rail-bar { height: 8px; border-radius: 99px; background: var(--bg3); overflow: hidden; }
.rail-bar > span { display: block; height: 100%; border-radius: 99px; background: var(--green); }
.rail-meta { font-family: var(--font-b); font-size: 0.78rem; color: var(--muted); margin-top: 10px; }
.rail-link {
  display: inline-block; margin-top: 14px; padding: 0;
  background: none; border: 0; cursor: pointer;
  font-family: var(--font-b); font-size: 0.82rem; font-weight: 600; color: var(--green-text);
}
.rail-link:hover { text-decoration: underline; }
.rail-recs { display: flex; flex-direction: column; gap: 4px; }
.rail-rec {
  display: flex; align-items: center; gap: 12px; width: 100%; text-align: left;
  padding: 10px 8px; background: none; border: 0; border-radius: 10px; cursor: pointer;
  transition: background 0.12s ease;
}
.rail-rec:hover { background: var(--bg2); }
.rail-rec-icon {
  flex-shrink: 0; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  border-radius: 10px; background: var(--bg2); border: 1px solid var(--border); color: var(--text-sub);
}
.rail-rec-icon svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 1.6; }
.rail-rec-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.rail-rec-title {
  font-family: var(--font-d); font-size: 0.86rem; font-weight: 600; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.rail-rec-min { font-family: var(--font-num); font-size: 0.7rem; color: var(--muted); }
.rail-rec .ls-chev svg { width: 16px; height: 16px; }

/* ── Horizontal "financial journey" path (.fp-*) ──────────── */
.fp-wrap { width: 100%; }
.fp-svg { width: 100%; height: auto; display: block; overflow: visible; }
.fp-line-base { fill: none; stroke: var(--border2); stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.fp-line-done { fill: none; stroke: var(--green); stroke-width: 2.75; stroke-linecap: round; stroke-linejoin: round; }
.fp-node-completed { fill: var(--green); }
.fp-node-current   { fill: var(--green); }
.fp-node-available { fill: var(--bg); stroke: var(--border2); stroke-width: 2; }
.fp-node-locked    { fill: var(--bg3); }
.fp-halo { fill: var(--green-dim); }
.fp-num { font-family: var(--font-num); font-size: 11px; font-weight: 600; fill: var(--muted); }
.fp-num-current { fill: var(--green-text); font-weight: 700; }
.fp-num-locked { fill: var(--muted2); }
.fp-flag-pole { stroke: var(--muted2); stroke-width: 2; stroke-linecap: round; }
.fp-flag-cloth { fill: var(--muted2); }
.fp-flag-reached .fp-flag-pole { stroke: var(--green); }
.fp-flag-reached .fp-flag-cloth { fill: var(--green); }
.fp-node-g:focus-visible { outline: none; }
.fp-node-g:focus-visible .fp-node-available,
.fp-node-g:focus-visible .fp-node-current,
.fp-node-g:focus-visible .fp-node-completed { stroke: var(--green); stroke-width: 3; }

/* Mastery: journey path leads, level rows are quiet detail. */
.fl-journey { padding: 8px 2px 14px; }
.fl-level-current { background: var(--bg2); border: 1px solid var(--border); border-radius: 14px; }
.fl-level-current .fl-eyebrow { color: var(--green-text); }
.fl-node-current { box-shadow: 0 0 0 4px var(--green-dim); }


/* ════════════════════════════════════════════════════════════
   DESKTOP  (>= 900px)  — contained, premium web app
   Everything below is scoped so mobile is never touched.
   ════════════════════════════════════════════════════════════ */
@media (min-width: 900px) {

  /* Page = soft gray; the product is a centered white frame. */
  body {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 28px;
    background: var(--shell-bg);
  }

  /* The contained app frame — NOT full-bleed. */
  .app {
    max-width: var(--app-max);
    width: 100%;
    height: calc(100vh - 56px);
    min-height: 620px;
    margin: 0 auto;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 18px;
    box-shadow: var(--shell-shadow);
    overflow: hidden;            /* clips header corners; screen scrolls inside */
    display: flex;
    flex-direction: column;
  }

  /* Header order: logo bar → tab strip → scrolling screen. */
  #mainTopbar { order: 0; }
  #mainNav    { order: 1; }
  .screen     { order: 2; }

  /* Logo bar — topbar keeps its inline display:block (set by auth.js);
     the inner row fills the height and centers its content. */
  .topbar {
    position: static;
    height: var(--header-h);
    padding: 0;
    background: var(--bg);
    border-bottom: 0;
  }
  .topbar-row { width: 100%; height: 100%; margin: 0; padding: 0 28px; }
  .brand { font-size: 1.16rem; letter-spacing: -0.022em; }

  /* Tab strip */
  .nav {
    position: static;
    height: var(--nav-h);
    align-items: stretch;
    gap: 4px;
    padding: 0 20px;
    background: var(--bg);
    border-top: 0;
    border-bottom: 1px solid var(--border);
  }
  .nb {
    flex: 0 0 auto;
    flex-direction: row;
    align-items: center;
    gap: 8px;
    padding: 0 14px;
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--muted);
    border-radius: 0;
  }
  .nb svg { width: 18px; height: 18px; }
  .nb:hover:not(.active) { color: var(--text); }
  .nb.active { color: var(--green-text); }
  .nb.active svg { opacity: 1; }
  .nb.active::after {
    bottom: -1px; left: 0; width: 100%; height: 2px;
    transform: none; border-radius: 0; background: var(--green);
  }

  /* Scrolling content area, centered per page type. */
  .screen {
    flex: 1;
    overflow-y: auto;
    padding: 40px max(40px, calc((100% - var(--single-max)) / 2)) 56px;
  }
  /* Learn = wide two-column dashboard (uses most of the frame). */
  #pathScreen { padding: 40px 44px 56px; }
  /* Reading / answering screens stay in a focused narrow column. */
  #quizScreen, #courseScreen, #resultScreen, #practiceSessionScreen {
    padding-inline: max(40px, calc((100% - var(--read-max)) / 2));
  }
  /* Auth: centered card. */
  #authScreen { display: flex; align-items: center; justify-content: center; }
  #authScreen .auth-wrap { max-width: 380px; }

  /* Heroes scale up on desktop. */
  .learn-hero, .market-hero, .mastery-hero { margin: 4px 0 34px; max-width: 32ch; }
  .learn-h1, .market-h1, .mastery-h1 { font-size: 2.5rem; }
  .learn-sub, .market-h-sub, .mastery-sub {
    font-size: 1.02rem; line-height: 1.55; color: var(--muted); margin-top: 14px; max-width: 46ch;
  }

  /* ── Learn two-column grid ─────────────────────────────── */
  .learn-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) var(--rail-w);
    gap: 44px;
    align-items: start;
  }
  .learn-main { min-width: 0; }
  .learn-rail {
    position: sticky;
    top: 4px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    min-width: 0;
  }

  .learn-section { margin-bottom: 30px; }
  .learn-sec-title { font-size: 1.05rem; font-weight: 700; }
  .learn-lessons { gap: 12px; }
  .ls-card { padding: 18px; border-radius: 14px; }

  /* Chips — Linear-style segmented look. */
  .learn-chips { margin: 0 0 22px; gap: 8px; }
  .learn-chip { padding: 7px 14px; font-size: 0.82rem; font-weight: 500; border-radius: 8px; border: 1px solid var(--border); background: var(--bg); color: var(--muted); }
  .learn-chip:hover:not(.is-active) { background: var(--bg2); color: var(--text); }
  .learn-chip.is-active { background: var(--text); color: var(--bg); border-color: var(--text); }
}


/* ════════════════════════════════════════════════════════════
   MOBILE  (< 900px) — keep the app frame + bottom nav as-is.
   The Learn grid simply stacks (main, then progress rail).
   ════════════════════════════════════════════════════════════ */
@media (max-width: 899px) {
  .learn-rail { margin-top: 8px; }
  .learn-h1, .market-h1, .mastery-h1 { font-size: 1.9rem; }
  .learn-hero, .market-hero, .mastery-hero { margin: 4px 0 22px; }
  .learn-sub, .market-h-sub, .mastery-sub { color: var(--muted); margin-top: 12px; }
}

/* ── Authentication overlay ───────────────────────────────── */
.app { position: relative; }
#authScreen.auth-modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 500;
  padding: 24px;
  align-items: center;
  justify-content: center;
  overflow-y: auto;
  background: rgba(15, 18, 22, 0.34);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}
#authScreen.auth-modal-open { display: flex; }
#authScreen .auth-wrap {
  position: relative;
  width: min(420px, 100%);
  max-width: 420px;
  max-height: calc(100vh - 48px);
  overflow-y: auto;
  padding: 30px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: var(--bg);
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.22);
}
.auth-modal-close {
  position: absolute;
  top: 14px;
  right: 14px;
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
}
.auth-modal-close:hover { background: var(--bg2); color: var(--text); }
.auth-modal-close svg { width: 17px; height: 17px; fill: none; stroke: currentColor; stroke-width: 1.8; }
.auth-modal-close[hidden] { display: none; }
#authScreen .auth-logo { margin-top: 2px; }
#authScreen .auth-tagline { margin-bottom: 24px; }
.auth-google-btn { display: flex; align-items: center; justify-content: center; gap: 10px; }
.google-mark {
  display: inline-grid;
  place-items: center;
  width: 19px;
  height: 19px;
  border: 1px solid var(--border2);
  border-radius: 50%;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--text);
  background: var(--bg);
}

/* ── Learn desktop product layout ─────────────────────────── */
.lesson-path {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
.learn-eyebrow,
.learn-card-kicker,
.learn-sec-count {
  font-family: var(--font-b);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.035em;
  color: var(--muted);
}
.learn-eyebrow {
  margin-bottom: 10px;
  color: var(--green-text);
  text-transform: uppercase;
}
.continue-learning-card {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 18px;
  padding: 24px;
  border: 1px solid var(--border2);
  border-radius: 16px;
  background: var(--bg2);
}
.continue-learning-copy h2 {
  margin: 7px 0 6px;
  font-family: var(--font-d);
  font-size: 1.28rem;
  letter-spacing: -0.02em;
  color: var(--text);
}
.continue-learning-copy p,
.learn-insight-card p {
  margin: 0;
  color: var(--text-sub);
  font-size: 0.84rem;
  line-height: 1.5;
}
.continue-learning-meta {
  margin-top: 12px;
  font-family: var(--font-num);
  font-size: 0.7rem;
  color: var(--muted);
}
.continue-learning-card .btn { flex: 0 0 auto; min-width: 124px; }
.continue-learning-copy { flex: 1 1 auto; min-width: 0; }
.continue-learning-card .btn { width: auto; }
.learn-insight-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}
.learn-insight-card {
  min-height: 150px;
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--bg);
}
.learn-insight-card h3 {
  margin: 10px 0 6px;
  font-family: var(--font-d);
  font-size: 1rem;
  color: var(--text);
}
.daily-concept-card { border-left: 3px solid var(--green); }
.text-link-button {
  margin-top: 15px;
  padding: 0;
  border: 0;
  background: none;
  color: var(--green-text);
  font: 600 0.78rem var(--font-b);
  cursor: pointer;
}
.recent-concepts { display: flex; flex-direction: column; gap: 4px; margin-top: 9px; }
.recent-concepts button {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 0;
  border: 0;
  background: transparent;
  color: var(--text-sub);
  font: 500 0.8rem var(--font-b);
  text-align: left;
  cursor: pointer;
}
.recent-concepts button:hover { color: var(--text); }
.recent-concepts button span { color: var(--green-text); }
.learn-sec-count { letter-spacing: 0; font-weight: 500; }

/* Lesson details are revealed on hover, focus, or explicit click. */
.ls-card { flex-wrap: nowrap; }
.ls-preview {
  display: none;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.ls-card:hover .ls-preview,
.ls-card:focus-within .ls-preview,
.ls-card.is-previewing .ls-preview { display: flex; flex-direction: column; }
.ls-preview-copy { color: var(--text-sub); font-size: 0.78rem; line-height: 1.5; }
.ls-preview-meta { margin-top: 9px; color: var(--muted); font: 0.68rem var(--font-num); }
.ls-preview-concepts { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.ls-preview-concepts span {
  padding: 5px 8px;
  border: 1px solid var(--border);
  border-radius: 7px;
  background: var(--bg);
  color: var(--text-sub);
  font-size: 0.68rem;
  line-height: 1.3;
}
.ls-preview-start { align-self: flex-start; margin-top: 13px; padding: 8px 14px; }

.journey-legend {
  display: flex;
  gap: 12px;
  margin-top: 2px;
  color: var(--muted);
  font-size: 0.65rem;
}
.journey-legend span { display: flex; align-items: center; gap: 5px; }
.journey-legend i {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--bg3);
  border: 1px solid var(--border2);
}
.journey-legend i.is-complete { background: var(--green); border-color: var(--green); }
.journey-legend i.is-current { background: var(--bg); border: 2px solid var(--green); }
.fp-line-done {
  stroke-dasharray: 420;
  stroke-dashoffset: 420;
  animation: journey-draw 900ms ease-out forwards;
}
.fp-node-g { transition: opacity 0.15s ease; }
.fp-node-g:hover { opacity: 0.72; }
@keyframes journey-draw { to { stroke-dashoffset: 0; } }

@media (min-width: 900px) {
  #pathScreen { padding-inline: 40px; }
  .learn-hero { max-width: 720px; margin-bottom: 30px; }
  .learn-grid { grid-template-columns: minmax(0, 1fr) 330px; gap: 36px; }
}

@media (max-width: 899px) {
  #authScreen.auth-modal-overlay { padding: 14px; }
  #authScreen .auth-wrap { padding: 26px 20px 22px; border-radius: 16px; }
  .continue-learning-card { align-items: stretch; flex-direction: column; padding: 20px; }
  .continue-learning-card .btn { width: 100%; }
  .learn-insight-grid { grid-template-columns: 1fr; }
}

/* ── Ask tutor ─────────────────────────────────────────────── */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.ask-finlingo-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex: 0 0 auto;
  width: auto;
  padding: 9px 13px;
  border: 1px solid var(--border2);
  border-radius: 9px;
  background: var(--bg);
  color: var(--text);
  font: 600 0.78rem var(--font-b);
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: background 0.12s, border-color 0.12s;
}
.ask-finlingo-btn:hover { background: var(--bg2); border-color: var(--muted2); }
.ask-finlingo-btn svg {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.course-header-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
}
.course-header-top > div { min-width: 0; }
.learn-hero,
.market-hero { align-items: flex-start; }

.ask-tutor-backdrop {
  position: fixed;
  inset: 0;
  z-index: 440;
  visibility: hidden;
  opacity: 0;
  background: rgba(15, 18, 22, 0.12);
  transition: opacity 0.2s, visibility 0.2s;
}
.ask-tutor-backdrop.open { visibility: visible; opacity: 1; }
.ask-tutor-panel {
  position: fixed;
  z-index: 450;
  top: 0;
  right: 0;
  display: flex;
  flex-direction: column;
  width: min(420px, 100vw);
  height: 100dvh;
  border-left: 1px solid var(--border);
  background: var(--bg);
  box-shadow: -18px 0 48px rgba(0, 0, 0, 0.14);
  transform: translateX(104%);
  transition: transform 0.22s ease;
}
.ask-tutor-panel.open { transform: translateX(0); }
.ask-tutor-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 22px 18px;
  border-bottom: 1px solid var(--border);
}
.ask-tutor-eyebrow {
  margin-bottom: 4px;
  color: var(--green-text);
  font: 600 0.66rem var(--font-b);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.ask-tutor-title {
  color: var(--text);
  font: 700 1.12rem var(--font-d);
  letter-spacing: -0.02em;
}
.ask-tutor-claude-badge {
  display: inline-flex;
  width: fit-content;
  margin-top: 7px;
  padding: 4px 8px;
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--muted);
  background: var(--bg2);
  font: 700 0.58rem/1 var(--font-b);
  letter-spacing: 0.035em;
  text-transform: uppercase;
}
.ask-tutor-context {
  max-width: 280px;
  margin-top: 4px;
  overflow: hidden;
  color: var(--muted);
  font: 0.75rem var(--font-b);
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ask-tutor-close {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
}
.ask-tutor-close:hover { background: var(--bg2); color: var(--text); }
.ask-tutor-close svg,
.ask-tutor-send svg {
  width: 17px;
  height: 17px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.ask-tutor-messages {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 20px 22px;
}
.ask-tutor-quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  padding: 12px 22px;
  border-bottom: 1px solid var(--border);
}
.ask-tutor-quick-actions button {
  padding: 7px 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg);
  color: var(--text-sub);
  font: 600 0.68rem var(--font-b);
  cursor: pointer;
}
.ask-tutor-quick-actions button:hover { border-color: var(--green); color: var(--green-text); background: var(--green-dim); }
.ask-message {
  width: fit-content;
  max-width: 88%;
  margin-bottom: 12px;
  padding: 11px 13px;
  border-radius: 12px;
  color: var(--text);
  font: 0.84rem/1.55 var(--font-b);
  white-space: pre-wrap;
}
.ask-message-assistant small {
  display: block;
  margin-top: 9px;
  padding-top: 8px;
  border-top: 1px solid var(--border);
  color: var(--muted2);
  font: 0.59rem var(--font-b);
}
.ask-message-user {
  margin-left: auto;
  border-bottom-right-radius: 4px;
  background: var(--contrast-strong-bg, #0b0d10);
  color: var(--contrast-strong-text, #fff);
}
.ask-message-assistant {
  border: 1px solid var(--border);
  border-bottom-left-radius: 4px;
  background: var(--bg2);
}
.ask-welcome-state {
  padding: 4px 0;
  color: var(--text);
}
.ask-welcome-state h3 {
  margin: 0 0 6px;
  color: var(--text);
  font: 700 1.05rem/1.2 var(--font-d);
  letter-spacing: -0.02em;
}
.ask-welcome-state p {
  margin: 0;
  color: var(--text-sub);
  font: 0.86rem/1.45 var(--font-b);
}
.ask-welcome-context {
  margin-top: 12px;
  padding: 9px 10px;
  border: 1px solid var(--border);
  border-radius: 9px;
  color: var(--muted);
  background: var(--bg2);
  font: 0.73rem/1.35 var(--font-b);
}
.ask-response-sections {
  display: grid;
  gap: 12px;
}
.ask-response-section h4 {
  margin: 0 0 4px;
  color: var(--green-text);
  font: 700 0.68rem/1.2 var(--font-b);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.ask-response-section p {
  margin: 0;
  color: var(--text);
  font: 0.84rem/1.52 var(--font-b);
}
.ask-message-loading-text {
  color: var(--text-sub);
  font-weight: 650;
}
.ask-message-loading-rich {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--text-sub);
}
.ask-message-loading-rich strong {
  color: var(--text);
  font: 650 0.82rem/1.2 var(--font-b);
}
.ask-message-loading-rich ol {
  display: grid;
  gap: 3px;
  margin: 5px 0 0;
  padding: 0;
  list-style: none;
  color: var(--muted);
  font: 500 0.7rem/1.25 var(--font-b);
}
.ask-message-loading-rich li {
  position: relative;
  padding-left: 12px;
}
.ask-message-loading-rich li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.5em;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: currentColor;
}
.ask-message-loading-rich li.is-active { color: var(--green-text); }
.ask-message-loading { display: flex; align-items: center; gap: 5px; min-width: 52px; }
.ask-message-loading span {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--muted);
  animation: ask-tutor-pulse 1s infinite ease-in-out;
}
.ask-message-loading span:nth-child(2) { animation-delay: 0.15s; }
.ask-message-loading span:nth-child(3) { animation-delay: 0.3s; }
.ask-loading-orbit {
  position: relative;
  flex: 0 0 auto;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 1px solid var(--border);
}
.ask-loading-orbit span {
  position: absolute;
  inset: 5px;
  border-radius: 50%;
  border: 2px solid transparent;
  border-top-color: var(--green-text);
  animation: ask-orbit 1.05s linear infinite;
}
.ask-loading-orbit span:nth-child(2) {
  inset: 8px;
  border-top-color: var(--muted);
  animation-duration: 1.35s;
  animation-direction: reverse;
}
.ask-loading-orbit span:nth-child(3) {
  inset: 11px;
  border-top-color: var(--text-sub);
  animation-duration: .9s;
}
@keyframes ask-tutor-pulse {
  0%, 70%, 100% { opacity: 0.35; transform: translateY(0); }
  35% { opacity: 1; transform: translateY(-2px); }
}
@keyframes ask-orbit {
  to { transform: rotate(360deg); }
}
@media (prefers-reduced-motion: reduce) {
  .ask-message-loading span,
  .ask-loading-orbit span {
    animation: none !important;
  }
}
.ask-tutor-boundary {
  padding: 10px 22px;
  border-top: 1px solid var(--border);
  color: var(--muted);
  font: 0.66rem/1.4 var(--font-b);
}
.ask-tutor-form {
  margin: 0 16px 16px;
  padding: 10px;
  border: 1px solid var(--border2);
  border-radius: 12px;
  background: var(--bg);
}
.ask-tutor-form:focus-within { border-color: var(--green); }
.ask-tutor-form textarea {
  display: block;
  width: 100%;
  min-height: 62px;
  resize: none;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--text);
  font: 0.84rem/1.45 var(--font-b);
}
.ask-tutor-form textarea::placeholder { color: var(--muted2); }
.ask-tutor-form-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 8px;
}
.ask-tutor-form-foot > span { color: var(--muted2); font: 0.6rem var(--font-b); }
.ask-tutor-send {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  padding: 0;
  border: 0;
  border-radius: 9px;
  background: var(--contrast-strong-bg, #0b0d10);
  color: var(--contrast-strong-text, #fff);
  cursor: pointer;
}
.ask-tutor-send:disabled { cursor: wait; opacity: 0.45; }
.ask-artifact {
  margin-bottom: 14px;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--bg2);
}
.ask-artifact-kicker {
  margin-bottom: 8px;
  color: var(--green-text);
  font: 700 0.62rem var(--font-b);
  letter-spacing: 0.07em;
  text-transform: uppercase;
}
.ask-artifact h3 { margin: 0 0 12px; color: var(--text); font: 700 1rem var(--font-d); }
.ask-artifact-disclaimer {
  margin-top: 14px;
  padding-top: 10px;
  border-top: 1px solid var(--border);
  color: var(--muted2);
  font: 0.59rem var(--font-b);
}
.ask-market-section { padding: 11px 0; border-top: 1px solid var(--border); }
.ask-market-section:first-of-type { border-top: 0; }
.ask-market-section strong { color: var(--text); font: 700 0.72rem var(--font-b); }
.ask-market-section p { margin: 5px 0 0; color: var(--text-sub); font: 0.78rem/1.5 var(--font-b); }
.ask-quiz-question { padding: 14px 0; border-top: 1px solid var(--border); }
.ask-quiz-question > strong { display: block; color: var(--text); font: 650 0.8rem/1.45 var(--font-b); }
.ask-quiz-choices { display: flex; flex-direction: column; gap: 6px; margin-top: 10px; }
.ask-quiz-choices button {
  width: 100%;
  padding: 9px 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg);
  color: var(--text-sub);
  font: 0.74rem/1.35 var(--font-b);
  text-align: left;
  cursor: pointer;
}
.ask-quiz-choices button:hover:not(:disabled) { border-color: var(--green); color: var(--text); }
.ask-quiz-choices button.is-correct { border-color: var(--green); background: var(--green-dim); color: var(--green-text); }
.ask-quiz-choices button.is-wrong { border-color: var(--red); background: var(--red-dim); color: var(--red-text); }
.ask-quiz-feedback { margin-top: 9px; color: var(--text-sub); font: 0.72rem/1.5 var(--font-b); }
.ask-quiz-feedback b { margin-right: 3px; color: var(--green-text); }
.ask-quiz-feedback.is-note b { color: var(--red-text); }
.ask-next-artifact > p { color: var(--text-sub); font: 0.78rem/1.5 var(--font-b); }
.ask-next-meta { margin: 10px 0; color: var(--muted); font: 0.66rem var(--font-num); }
.ask-next-artifact > button {
  width: 100%;
  padding: 9px 12px;
  border: 0;
  border-radius: 8px;
  background: var(--contrast-strong-bg, #0b0d10);
  color: var(--contrast-strong-text, #fff);
  font: 600 0.74rem var(--font-b);
  cursor: pointer;
}
.ask-floating-button {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 360;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 14px;
  border: 1px solid var(--border2);
  border-radius: 999px;
  background: var(--contrast-strong-bg, #0b0d10);
  color: var(--contrast-strong-text, #fff);
  box-shadow: 0 10px 28px rgba(0,0,0,0.18);
  font: 600 0.74rem var(--font-b);
  cursor: pointer;
  transition: transform 0.15s, opacity 0.15s;
}
.ask-floating-button:hover { transform: translateY(-2px); }
.ask-floating-button svg {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.ask-tutor-visible .ask-floating-button { opacity: 0; pointer-events: none; }
.lesson-ai-tools {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 3px;
}
.lesson-ai-tools button {
  padding: 7px 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg);
  color: var(--text-sub);
  font: 600 0.68rem var(--font-b);
  cursor: pointer;
}
.lesson-ai-tools button:hover { border-color: var(--green); color: var(--green-text); background: var(--green-dim); }
.result-ai-card {
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin: 18px 0;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--bg2);
}
.result-ai-card span { display: block; color: var(--green-text); font: 700 0.62rem var(--font-b); letter-spacing: 0.06em; text-transform: uppercase; }
.result-ai-card strong { display: block; margin-top: 5px; color: var(--text); font: 650 0.84rem var(--font-b); }
.result-ai-card button {
  flex: 0 0 auto;
  padding: 9px 14px;
  border: 0;
  border-radius: 8px;
  background: var(--contrast-strong-bg, #0b0d10);
  color: var(--contrast-strong-text, #fff);
  font: 600 0.74rem var(--font-b);
  cursor: pointer;
}
.lesson-confusion-card {
  gap: 12px;
  margin: 18px 0;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--bg2);
}
.lesson-confusion-card span {
  display: block;
  color: var(--green-text);
  font: 700 0.62rem var(--font-b);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.lesson-confusion-card strong {
  display: block;
  margin-top: 5px;
  color: var(--text);
  font: 650 0.88rem var(--font-b);
}
.lesson-confusion-card p {
  margin: 5px 0 0;
  color: var(--muted);
  font: 0.72rem/1.45 var(--font-b);
}
.lesson-confusion-card textarea {
  width: 100%;
  resize: vertical;
  min-height: 62px;
  padding: 10px 11px;
  border: 1px solid var(--border);
  border-radius: 9px;
  outline: 0;
  background: var(--bg);
  color: var(--text);
  font: 0.8rem/1.45 var(--font-b);
}
.lesson-confusion-card textarea:focus { border-color: var(--green); }
.lesson-confusion-card button {
  justify-self: start;
  padding: 9px 14px;
  border: 0;
  border-radius: 8px;
  background: var(--contrast-strong-bg, #0b0d10);
  color: var(--contrast-strong-text, #fff);
  font: 600 0.74rem var(--font-b);
  cursor: pointer;
}

@media (max-width: 899px) {
  .learn-hero,
  .market-hero { flex-direction: column; align-items: flex-start; }
  .course-header-top { flex-direction: column; }
  .ask-finlingo-btn { width: auto; }
  .ask-tutor-panel { width: 100vw; border-left: 0; }
  .ask-tutor-backdrop { display: none; }
  .ask-floating-button { right: 16px; bottom: 82px; padding: 12px; }
  .ask-floating-button span { display: none; }
  .result-ai-card { align-items: stretch; flex-direction: column; }
  .result-ai-card button { width: 100%; }
}

/* ════════════════════════════════════════════════════════════
   PRODUCT DIRECTION PASS — Learn, Mastery, Market
   ════════════════════════════════════════════════════════════ */
.learn-hero .ask-finlingo-btn,
.market-hero .ask-finlingo-btn { margin-top: 18px; }
.learn-flow-section { margin: 0 0 30px; }
.learn-flow-heading,
.mastery-section-heading {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 12px;
}
.learn-flow-heading > span,
.mastery-section-heading h2 {
  margin: 0;
  color: var(--text);
  font: 700 1rem var(--font-d);
  letter-spacing: -0.015em;
}
.learn-flow-heading small,
.mastery-section-heading > span {
  color: var(--muted);
  font: 0.7rem var(--font-b);
}
.learn-level-card {
  padding: 20px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--bg);
}
.learn-level-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}
.learn-level-top h3 { margin: 4px 0 0; color: var(--text); font: 700 1.05rem var(--font-d); }
.learn-level-top > strong { color: var(--green-text); font: 600 1.35rem var(--font-num); }
.learn-level-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 16px;
}
.learn-level-stats span {
  display: flex;
  flex-direction: column;
  gap: 4px;
  color: var(--muted);
  font: 0.68rem var(--font-b);
}
.learn-level-stats strong { color: var(--text); font: 600 0.9rem var(--font-num); }
.learn-recommended { margin-bottom: 2px; }
.ls-card { align-items: center; padding: 15px 16px; }
.ls-card.is-selected { border-color: var(--green); box-shadow: 0 0 0 1px var(--green-dim); }
.ls-value-line {
  margin-top: 8px;
  color: var(--muted);
  font: 0.68rem var(--font-b);
}
.ls-value-line i { margin: 0 4px; font-style: normal; color: var(--muted2); }
.ls-card .ls-preview { display: none !important; }
.ls-card .ls-side { justify-content: center; }
.lesson-preview-card { padding: 22px; }
.lesson-preview-kicker {
  color: var(--muted);
  font: 700 0.65rem var(--font-b);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.lesson-preview-card h2 {
  margin: 8px 0 5px;
  color: var(--text);
  font: 750 1.35rem var(--font-d);
  letter-spacing: -0.025em;
}
.lesson-preview-card > p {
  margin: 0;
  color: var(--text-sub);
  font: 0.82rem/1.5 var(--font-b);
}
.lesson-preview-meta {
  margin: 11px 0 18px;
  color: var(--muted);
  font: 0.66rem var(--font-num);
}
.lesson-preview-section {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 14px 0;
  border-top: 1px solid var(--border);
}
.lesson-preview-section strong { color: var(--text); font: 700 0.72rem var(--font-b); }
.lesson-preview-section span,
.lesson-preview-section li { color: var(--text-sub); font: 0.76rem/1.5 var(--font-b); }
.lesson-preview-section > span {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}
.lesson-preview-section ul { display: flex; flex-direction: column; gap: 7px; margin: 0; padding: 0; list-style: none; }
.lesson-preview-section li { position: relative; padding-left: 16px; }
.lesson-preview-section li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--green-text);
  font-weight: 700;
}
.lesson-preview-start { margin-top: 6px; }
.lesson-preview-ask {
  width: 100%;
  margin-top: 9px;
  padding: 9px 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: transparent;
  color: var(--text-sub);
  font: 600 0.72rem var(--font-b);
  cursor: pointer;
}
.lesson-preview-ask:hover { background: var(--bg2); color: var(--text); }
.rail-empty-copy { color: var(--muted); font: 0.76rem/1.5 var(--font-b); }

/* Mastery */
.mastery-product-shell { width: 100%; max-width: 1200px; margin: 0 auto; }
.mastery-journey-strip {
  margin-bottom: 26px;
  padding: 18px 20px 10px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--bg);
}
.mastery-journey-strip .fp-node-completed { fill: #0b6b3a; }
.mastery-journey-strip .fp-node-current { fill: var(--green); }
.mastery-journey-strip .fp-node-locked { fill: var(--bg3); stroke: var(--border2); stroke-width: 1; }
.mastery-journey-strip .fl-journey {
  width: 100%;
  max-width: 700px;
  margin-inline: auto;
  padding: 0;
}
.mastery-journey-strip .fp-svg { width: 100%; height: 142px; }
.mastery-journey-labels {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  width: 100%;
  max-width: 700px;
  margin: -12px auto 8px;
  text-align: center;
}
.mastery-journey-labels span { color: var(--muted); font: 0.66rem var(--font-b); }
.mastery-journey-labels span.is-current { color: var(--green-text); font-weight: 700; }
.mastery-product-grid {
  display: grid;
  grid-template-columns: minmax(0, 7fr) minmax(280px, 3fr);
  gap: 30px;
  align-items: start;
}
.mastery-product-main,
.mastery-product-rail { min-width: 0; }
.mastery-product-rail { display: flex; flex-direction: column; gap: 14px; }
.mastery-current-card {
  padding: 26px;
  border: 1px solid var(--border2);
  border-radius: 16px;
  background: var(--bg2);
}
.mastery-current-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
}
.mastery-current-kicker,
.mastery-side-kicker {
  color: var(--green-text);
  font: 700 0.64rem var(--font-b);
  letter-spacing: 0.07em;
  text-transform: uppercase;
}
.mastery-current-head h2 { margin: 6px 0 0; color: var(--text); font: 750 1.45rem var(--font-d); }
.mastery-current-head > strong { color: var(--green-text); font: 650 1.6rem var(--font-num); }
.mastery-current-track {
  height: 9px;
  margin: 20px 0;
  overflow: hidden;
  border-radius: 99px;
  background: var(--bg3);
}
.mastery-current-track span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--green);
  animation: product-progress 700ms ease-out;
}
@keyframes product-progress { from { width: 0; } }
.mastery-current-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.mastery-current-stats div {
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--bg);
}
.mastery-current-stats strong { display: block; color: var(--text); font: 650 1.05rem var(--font-num); }
.mastery-current-stats span { display: block; margin-top: 5px; color: var(--muted); font: 0.68rem var(--font-b); }
.mastery-primary-action { margin-top: 20px; }
.mastery-upcoming { margin-top: 28px; }
.mastery-upcoming-list {
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 14px;
}
.mastery-upcoming-row {
  display: flex;
  align-items: center;
  gap: 13px;
  width: 100%;
  padding: 14px 16px;
  border: 0;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  text-align: left;
  cursor: pointer;
}
.mastery-upcoming-row:last-child { border-bottom: 0; }
.mastery-upcoming-row:hover:not(:disabled) { background: var(--bg2); }
.mastery-upcoming-row:disabled { cursor: default; opacity: 0.58; }
.mastery-upcoming-number {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border: 1px solid var(--border2);
  border-radius: 50%;
  color: var(--muted);
  font: 600 0.78rem var(--font-num);
}
.mastery-upcoming-row > span:nth-child(2) { flex: 1; min-width: 0; }
.mastery-upcoming-row strong { display: block; color: var(--text); font: 650 0.86rem var(--font-d); }
.mastery-upcoming-row small { display: block; margin-top: 3px; color: var(--muted); font: 0.68rem var(--font-b); }
.mastery-side-card {
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--bg);
}
.mastery-side-card p { margin: 10px 0 0; color: var(--muted); font: 0.72rem/1.5 var(--font-b); }
.mastery-side-score { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; margin: 10px 0 12px; }
.mastery-side-score strong { color: var(--green-text); font: 650 1.55rem var(--font-num); }
.mastery-side-score span { color: var(--text); font: 650 0.76rem var(--font-b); }
.mastery-confidence-score { margin-top: 10px; color: var(--text); font: 650 1.7rem var(--font-num); }
.mastery-confidence-score small { color: var(--muted); font-size: 0.72rem; }
.mastery-confidence-line { display: block; width: 100%; height: 48px; margin-top: 8px; }
.mastery-confidence-line path { fill: none; stroke: var(--green); stroke-width: 2; stroke-linecap: round; }
.mastery-weekly-dots { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; margin-top: 14px; }
.mastery-weekly-dots span { height: 8px; border-radius: 99px; background: var(--bg3); }
.mastery-weekly-dots span.is-active { background: var(--green); }
.mastery-review-card h3 { margin: 9px 0 0; color: var(--text); font: 700 0.92rem var(--font-d); }
.mastery-secondary-action {
  width: 100%;
  margin-top: 14px;
  padding: 9px 12px;
  border: 1px solid var(--border2);
  border-radius: 8px;
  background: transparent;
  color: var(--text);
  font: 600 0.72rem var(--font-b);
  cursor: pointer;
}
.mastery-secondary-action:hover { background: var(--bg2); }

/* Market */
.market-edu-shell { width: 100%; max-width: 1200px; gap: 22px; }
.market-hero-actions { display: flex; align-items: center; gap: 10px; margin-top: 20px; }
.market-hero-actions .ask-finlingo-btn { margin-top: 0; }
.market-story-action { width: auto; }
.market-story-grid {
  display: grid;
  grid-template-columns: minmax(0, 7fr) minmax(280px, 3fr);
  gap: 30px;
  align-items: start;
}
.market-story-main { display: flex; flex-direction: column; gap: 14px; }
.market-story-rail { display: flex; flex-direction: column; gap: 14px; }
.market-story-card,
.market-snapshot-panel,
.market-side-explainer {
  padding: 22px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--bg);
}
.market-story-card:first-child { border-left: 3px solid var(--green); }
.market-story-label,
.market-panel-head span,
.market-side-explainer > span {
  color: var(--muted);
  font: 700 0.65rem var(--font-b);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.market-story-card h2 { margin: 9px 0 8px; color: var(--text); font: 750 1.45rem var(--font-d); letter-spacing: -0.025em; }
.market-story-card h3 { margin: 9px 0 8px; color: var(--text); font: 700 1rem var(--font-d); }
.market-story-card p,
.market-side-explainer p { margin: 0; color: var(--text-sub); font: 0.84rem/1.65 var(--font-b); }
.market-story-takeaway { background: var(--green-dim); border-color: transparent; }
.market-panel-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.market-panel-head > div:first-child { display: flex; flex-direction: column; gap: 4px; }
.market-panel-head small { color: var(--muted); font: 0.67rem var(--font-b); }
.market-snapshot-note { color: var(--green-text); font: 600 0.62rem var(--font-b); }
.market-snapshot-panel .snap-card { padding: 12px; background: var(--bg2); }
.market-secondary-section { margin-top: 6px; }

/* Lesson reading is one focused action, with quieter supporting content. */
.course-header { padding-top: 4px; }
.course-header-top { align-items: center; }
.course-title { max-width: 560px; font-size: 1.65rem; }
.course-body { font-size: 0.9rem; }
.lesson-structure-shell { gap: 10px; }
.lesson-structure-card { padding: 16px 18px; box-shadow: none; }
.course-action-row { position: sticky; bottom: 0; padding: 12px 0; background: linear-gradient(to bottom, transparent, var(--bg) 24%); }

@media (min-width: 900px) {
  #pathScreen,
  #ranksScreen,
  #marketScreen { padding: 34px 40px 56px; }
  .learn-hero,
  .mastery-hero,
  .market-hero { max-width: 660px; }
  .learn-grid { grid-template-columns: minmax(0, 7fr) minmax(300px, 3fr); gap: 30px; }
  .learn-rail { position: static; }
}

@media (max-width: 899px) {
  .learn-level-stats,
  .mastery-current-stats { grid-template-columns: 1fr; }
  .mastery-product-grid,
  .market-story-grid { grid-template-columns: 1fr; }
  .market-hero-actions { align-items: stretch; flex-direction: column; width: 100%; }
  .market-story-action,
  .market-hero-actions .ask-finlingo-btn { width: 100%; }
  .lesson-preview-card { order: -1; }
}

/* ════════════════════════════════════════════════════════════
   FOCUSED LEARNING WORKSPACE — desktop Option B
   ════════════════════════════════════════════════════════════ */
.workspace-sidebar { display: none; }

@media (min-width: 1100px) {
  :root {
    --workspace-side: 232px;
    --workspace-tutor: 350px;
    --app-max: 1500px;
  }
  body { padding: 18px; }
  .app {
    position: relative;
    max-width: var(--app-max);
    height: calc(100vh - 36px);
    min-height: 680px;
    display: block;
  }
  #mainTopbar,
  #mainNav { display: none !important; }

  .workspace-sidebar {
    position: absolute;
    inset: 0 auto 0 0;
    z-index: 30;
    display: flex;
    flex-direction: column;
    width: var(--workspace-side);
    overflow: hidden;
    border-right: 1px solid var(--border);
    background: var(--bg);
    transition: width 0.2s ease;
  }
  .workspace-sidebar-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 64px;
    padding: 0 14px 0 16px;
    border-bottom: 1px solid var(--border);
  }
  .workspace-brand {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
    padding: 0;
    border: 0;
    background: none;
    color: var(--text);
    cursor: pointer;
  }
  .workspace-brand-mark {
    display: grid;
    flex: 0 0 auto;
    place-items: center;
    width: 30px;
    height: 30px;
    border-radius: 8px;
    background: var(--contrast-strong-bg, #0b0d10);
    color: #fff;
    font: 700 0.9rem var(--font-d);
  }
  .workspace-brand-name { font: 700 1rem var(--font-d); white-space: nowrap; }
  .workspace-collapse {
    display: grid;
    flex: 0 0 auto;
    place-items: center;
    width: 30px;
    height: 30px;
    padding: 0;
    border: 0;
    border-radius: 7px;
    background: transparent;
    color: var(--muted);
    cursor: pointer;
  }
  .workspace-collapse:hover { background: var(--bg2); color: var(--text); }
  .workspace-collapse svg,
  .workspace-primary-nav svg {
    width: 17px;
    height: 17px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.7;
    stroke-linecap: round;
    stroke-linejoin: round;
  }
  .workspace-primary-nav {
    display: flex;
    flex-direction: column;
    gap: 3px;
    padding: 14px 10px;
  }
  .workspace-primary-nav button {
    display: flex;
    align-items: center;
    gap: 11px;
    width: 100%;
    min-height: 38px;
    padding: 0 11px;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: var(--muted);
    font: 550 0.78rem var(--font-b);
    text-align: left;
    cursor: pointer;
    white-space: nowrap;
  }
  .workspace-primary-nav button:hover { background: var(--bg2); color: var(--text); }
  .workspace-primary-nav button.active { background: var(--green-dim); color: var(--green-text); }
  .workspace-sidebar-section { padding: 13px 10px; border-top: 1px solid var(--border); }
  .workspace-sidebar-label {
    padding: 0 10px 8px;
    color: var(--muted2);
    font: 700 0.6rem var(--font-b);
    letter-spacing: 0.07em;
    text-transform: uppercase;
    white-space: nowrap;
  }
  .workspace-unit-nav,
  .workspace-lesson-path { display: flex; flex-direction: column; gap: 3px; }
  .workspace-unit-nav button,
  .workspace-lesson-path button {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 8px 9px;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: var(--text-sub);
    text-align: left;
    cursor: pointer;
  }
  .workspace-unit-nav button:hover,
  .workspace-lesson-path button:hover { background: var(--bg2); }
  .workspace-unit-nav button.active,
  .workspace-lesson-path button.active { background: var(--green-dim); color: var(--green-text); }
  .workspace-unit-number,
  .workspace-lesson-node {
    display: grid;
    flex: 0 0 auto;
    place-items: center;
    width: 23px;
    height: 23px;
    border: 1px solid var(--border2);
    border-radius: 50%;
    color: var(--muted);
    font: 600 0.63rem var(--font-num);
  }
  .workspace-lesson-node.completed { border-color: var(--green); background: var(--green); color: #fff; }
  .workspace-unit-copy,
  .workspace-lesson-path button > span:last-child {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 2px;
  }
  .workspace-unit-copy strong,
  .workspace-lesson-path strong {
    overflow: hidden;
    color: inherit;
    font: 600 0.7rem var(--font-b);
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .workspace-unit-copy small,
  .workspace-lesson-path small { color: var(--muted); font: 0.58rem var(--font-b); }
  .workspace-sidebar-foot {
    margin-top: auto;
    padding: 14px 20px 18px;
    border-top: 1px solid var(--border);
    color: var(--muted2);
    font: 0.6rem/1.45 var(--font-b);
  }

  body.workspace-sidebar-collapsed { --workspace-side: 68px; }
  body.workspace-sidebar-collapsed .workspace-sidebar-head { padding-inline: 18px; }
  body.workspace-sidebar-collapsed .workspace-brand,
  body.workspace-sidebar-collapsed .workspace-primary-nav span,
  body.workspace-sidebar-collapsed .workspace-sidebar-label,
  body.workspace-sidebar-collapsed .workspace-unit-copy,
  body.workspace-sidebar-collapsed .workspace-sidebar-foot,
  body.workspace-sidebar-collapsed .workspace-current-section { display: none; }
  body.workspace-sidebar-collapsed .workspace-primary-nav { padding-inline: 9px; }
  body.workspace-sidebar-collapsed .workspace-primary-nav button,
  body.workspace-sidebar-collapsed .workspace-unit-nav button { justify-content: center; padding-inline: 0; }
  body.workspace-sidebar-collapsed .workspace-sidebar-section { padding-inline: 9px; }
  body.workspace-sidebar-collapsed .workspace-sidebar-head { justify-content: center; }
  body.workspace-sidebar-collapsed .workspace-collapse svg { transform: rotate(180deg); }

  .screen:not(#authScreen) {
    width: auto;
    height: 100%;
    margin: 0 var(--workspace-tutor) 0 var(--workspace-side);
    padding: 0;
    overflow-y: auto;
    background: var(--bg);
    transition: margin-left 0.2s ease;
  }
  #pathScreen,
  #courseScreen,
  #quizScreen,
  #resultScreen,
  #practiceSessionScreen,
  #ranksScreen,
  #marketScreen,
  #profileScreen { padding: 0 !important; }
  #practiceRoot,
  #marketFeatureList,
  #profileScreen > *,
  #practiceSessionRoot { max-width: 820px; margin-inline: auto; }

  .ask-tutor-panel {
    position: absolute;
    inset: 0 0 0 auto;
    z-index: 35;
    width: var(--workspace-tutor);
    height: 100%;
    transform: none;
    box-shadow: none;
    border-left: 1px solid var(--border);
  }
  .ask-tutor-panel.open { transform: none; }
  .ask-tutor-backdrop,
  .ask-tutor-close,
  .ask-floating-button { display: none !important; }
  .ask-tutor-head { padding: 20px 20px 16px; }
  .ask-tutor-quick-actions { padding: 11px 20px; }
  .ask-tutor-messages { padding: 18px 20px; }

  /* Focused lesson center */
  .lesson-path { max-width: none; height: 100%; }
  .focused-workspace {
    max-width: 760px;
    margin: 0 auto;
    padding: 56px 58px 80px;
  }
  .focused-lesson-head { padding-bottom: 32px; border-bottom: 1px solid var(--border); }
  .focused-lesson-breadcrumb {
    color: var(--green-text);
    font: 700 0.64rem var(--font-b);
    letter-spacing: 0.06em;
    text-transform: uppercase;
  }
  .focused-lesson-progress {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 13px;
  }
  .focused-lesson-progress > span {
    width: 140px;
    height: 4px;
    overflow: hidden;
    border-radius: 99px;
    background: var(--bg3);
  }
  .focused-lesson-progress i { display: block; height: 100%; border-radius: inherit; background: var(--green); }
  .focused-lesson-progress small { color: var(--muted); font: 0.62rem var(--font-b); }
  .focused-lesson-head h1 {
    margin: 28px 0 8px;
    color: var(--text);
    font: 800 2.5rem/1.05 var(--font-d);
    letter-spacing: -0.045em;
  }
  .focused-lesson-head > p { margin: 0; color: var(--text-sub); font: 1rem/1.55 var(--font-b); }
  .focused-lesson-meta { margin-top: 14px; color: var(--muted); font: 0.68rem var(--font-num); }
  .focused-lesson-meta i { margin: 0 5px; font-style: normal; color: var(--muted2); }
  .focused-lesson-sections section { padding: 30px 0; border-bottom: 1px solid var(--border); }
  .focused-section-label {
    margin-bottom: 10px;
    color: var(--green-text);
    font: 700 0.63rem var(--font-b);
    letter-spacing: 0.07em;
    text-transform: uppercase;
  }
  .focused-lesson-sections h2 {
    margin: 0 0 10px;
    color: var(--text);
    font: 700 1.08rem/1.35 var(--font-d);
    letter-spacing: -0.015em;
  }
  .focused-lesson-sections p { margin: 0; color: var(--text-sub); font: 0.88rem/1.7 var(--font-b); }
  .focused-text-action {
    margin-top: 13px;
    padding: 0;
    border: 0;
    background: none;
    color: var(--green-text);
    font: 600 0.72rem var(--font-b);
    cursor: pointer;
  }
  .focused-check-preview {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-top: 14px;
  }
  .focused-check-preview span {
    padding: 10px 12px;
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text-sub);
    font: 0.74rem var(--font-b);
  }
  .focused-term-list { margin: 0; }
  .focused-term-list > div {
    display: grid;
    grid-template-columns: 120px minmax(0, 1fr);
    gap: 18px;
    padding: 10px 0;
  }
  .focused-term-list dt { color: var(--text); font: 650 0.76rem var(--font-b); }
  .focused-term-list dd { margin: 0; color: var(--text-sub); font: 0.76rem/1.5 var(--font-b); }
  .focused-lesson-action {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    margin-top: 34px;
    padding-top: 22px;
  }
  .focused-lesson-action div { display: flex; flex-direction: column; gap: 4px; }
  .focused-lesson-action strong { color: var(--text); font: 700 0.86rem var(--font-d); }
  .focused-lesson-action span { color: var(--muted); font: 0.72rem var(--font-b); }
  .focused-lesson-action .btn { width: auto; min-width: 128px; }

  /* Existing focused screens inherit the workspace center. */
  #courseScreen,
  #quizScreen,
  #resultScreen,
  #practiceSessionScreen {
    padding: 48px max(40px, calc((100% - 720px) / 2)) 72px !important;
  }
  .course-img-wrap,
  .mastery-hero-art,
  .market-hero-art { display: none !important; }
  .market-story-grid,
  .mastery-product-grid { grid-template-columns: 1fr; }
  .market-story-rail,
  .mastery-product-rail { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 1099px) {
  .workspace-sidebar { display: none; }
  .focused-workspace { padding: 28px 22px 120px; }
  .focused-lesson-head h1 { margin: 22px 0 8px; font-size: 2rem; }
  .focused-lesson-head { padding-bottom: 24px; border-bottom: 1px solid var(--border); }
  .focused-lesson-breadcrumb,
  .focused-section-label { color: var(--green-text); font: 700 0.63rem var(--font-b); text-transform: uppercase; letter-spacing: 0.06em; }
  .focused-lesson-progress { display: flex; align-items: center; gap: 8px; margin-top: 12px; }
  .focused-lesson-progress > span { width: 120px; height: 4px; overflow: hidden; border-radius: 99px; background: var(--bg3); }
  .focused-lesson-progress i { display: block; height: 100%; background: var(--green); }
  .focused-lesson-progress small,
  .focused-lesson-meta { color: var(--muted); font: 0.65rem var(--font-b); }
  .focused-lesson-head > p,
  .focused-lesson-sections p { color: var(--text-sub); line-height: 1.65; }
  .focused-lesson-meta { margin-top: 12px; }
  .focused-lesson-meta i { font-style: normal; margin: 0 4px; }
  .focused-lesson-sections section { padding: 24px 0; border-bottom: 1px solid var(--border); }
  .focused-lesson-sections h2 { margin: 8px 0; color: var(--text); font: 700 1rem var(--font-d); }
  .focused-text-action { margin-top: 12px; border: 0; background: none; color: var(--green-text); font-weight: 600; }
  .focused-check-preview { display: flex; flex-direction: column; gap: 7px; }
  .focused-check-preview span { padding: 10px; border: 1px solid var(--border); border-radius: 8px; color: var(--text-sub); }
  .focused-term-list > div { padding: 9px 0; }
  .focused-term-list dt { color: var(--text); font-weight: 650; }
  .focused-term-list dd { margin: 3px 0 0; color: var(--text-sub); }
  .focused-lesson-action { display: flex; flex-direction: column; gap: 14px; padding-top: 26px; }
  .focused-lesson-action div { display: flex; flex-direction: column; gap: 4px; }
  .focused-lesson-action span { color: var(--muted); font-size: 0.76rem; }
  .focused-lesson-action .btn { width: 100%; }
}

/* ════════════════════════════════════════════════════════════
   SIMPLIFIED PRODUCT WORKSPACE
   ════════════════════════════════════════════════════════════ */
.workspace-account {
  position: absolute;
  top: 16px;
  right: 18px;
  z-index: 48;
}

body.entry-gate-visible .workspace-sidebar,
body.entry-gate-visible .workspace-account,
body.entry-gate-visible .screen:not(#authScreen),
body.entry-gate-visible #mainTopbar,
body.entry-gate-visible #mainNav,
body.entry-gate-visible .ask-tutor-panel,
body.entry-gate-visible .ask-floating-button {
  visibility: hidden !important;
  pointer-events: none !important;
}
body.entry-gate-visible #authScreen.auth-modal-open {
  visibility: visible !important;
  pointer-events: auto !important;
}

@media (min-width: 1100px) {
  .workspace-primary-nav { overflow-y: auto; }
  #workspaceLearnButton .workspace-learn-chevron {
    width: 13px;
    height: 13px;
    margin-left: auto;
    transition: transform .18s ease;
  }
  #workspaceLearnButton[aria-expanded="true"] .workspace-learn-chevron { transform: rotate(180deg); }
  .workspace-learn-menu {
    display: none;
    max-height: min(62vh, 620px);
    margin: 1px 0 7px;
    padding: 0 3px 8px 9px;
    overflow-y: auto;
  }
  .workspace-learn-menu.open { display: block; }
  .workspace-curriculum-unit { border-left: 1px solid var(--border); }
  .workspace-primary-nav .workspace-unit-toggle {
    display: grid;
    grid-template-columns: 20px minmax(0, 1fr) 13px;
    gap: 7px;
    min-height: 36px;
    padding: 6px 7px 6px 8px;
    border-radius: 0 7px 7px 0;
  }
  .workspace-unit-index {
    display: grid;
    place-items: center;
    width: 19px;
    height: 19px;
    border: 1px solid var(--border2);
    border-radius: 50%;
    color: var(--muted);
    font: 600 .55rem var(--font-num);
  }
  .workspace-unit-title {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 1px;
  }
  .workspace-unit-title strong {
    overflow: hidden;
    color: var(--text-sub);
    font: 600 .64rem var(--font-b);
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .workspace-unit-title small { color: var(--muted2); font: .53rem var(--font-b); }
  .workspace-unit-toggle > svg {
    width: 12px;
    height: 12px;
    transition: transform .16s ease;
  }
  .workspace-curriculum-unit.open .workspace-unit-toggle > svg { transform: rotate(180deg); }
  .workspace-unit-lessons { display: none; padding: 2px 0 7px 16px; }
  .workspace-curriculum-unit.open .workspace-unit-lessons { display: grid; }
  .workspace-primary-nav .workspace-curriculum-lesson {
    display: grid;
    grid-template-columns: 20px minmax(0, 1fr);
    gap: 7px;
    min-height: 30px;
    padding: 5px 7px;
    border-radius: 6px;
  }
  .workspace-curriculum-lesson > span {
    color: var(--muted);
    font: 600 .53rem var(--font-num);
    text-align: center;
  }
  .workspace-curriculum-lesson > strong {
    overflow: hidden;
    color: var(--muted);
    font: 550 .61rem var(--font-b);
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .workspace-primary-nav .workspace-curriculum-lesson.active { background: var(--green-dim); }
  .workspace-curriculum-lesson.active > span,
  .workspace-curriculum-lesson.active > strong { color: var(--green-text); }
  body.workspace-sidebar-collapsed .workspace-learn-menu,
  body.workspace-sidebar-collapsed #workspaceLearnButton .workspace-learn-chevron { display: none !important; }
}
.workspace-account-button {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 50%;
  background: var(--bg);
  color: var(--text-sub);
  cursor: pointer;
}
.workspace-account-button:hover { border-color: var(--border2); color: var(--text); background: var(--bg2); }
.workspace-account-button svg {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.7;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.workspace-account-menu {
  position: absolute;
  top: 42px;
  right: 0;
  display: none;
  width: 176px;
  padding: 6px;
  border: 1px solid var(--border);
  border-radius: 11px;
  background: var(--bg);
  box-shadow: 0 14px 38px rgba(15, 23, 42, 0.12);
}
.workspace-account-menu.open { display: grid; }
.workspace-account-menu button {
  width: 100%;
  padding: 9px 10px;
  border: 0;
  border-radius: 7px;
  background: transparent;
  color: var(--text-sub);
  font: 550 0.75rem var(--font-b);
  text-align: left;
  cursor: pointer;
}
.workspace-account-menu button:hover { background: var(--bg2); color: var(--text); }
.workspace-account-menu .workspace-account-signout {
  margin-top: 4px;
  border-top: 1px solid var(--border);
  border-radius: 0 0 7px 7px;
}

.simple-page-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 280px;
  gap: 56px;
  width: min(100%, 1120px);
  margin: 0 auto;
  padding: 64px 48px 88px;
}
.simple-page-main { min-width: 0; }
.simple-page-header { max-width: 680px; margin-bottom: 42px; }
.simple-eyebrow,
.simple-rail-label,
.simple-market-story > span,
.simple-market-section > span {
  color: var(--green-text);
  font: 700 0.63rem var(--font-b);
  letter-spacing: 0.075em;
  text-transform: uppercase;
}
.simple-page-header h1 {
  margin: 12px 0 10px;
  color: var(--text);
  font: 700 clamp(2rem, 3.2vw, 3rem)/1.04 var(--font-d);
  letter-spacing: -0.045em;
}
.simple-page-header p {
  max-width: 560px;
  margin: 0;
  color: var(--text-sub);
  font: 0.94rem/1.65 var(--font-b);
}
.simple-page-rail {
  padding-top: 92px;
  border-left: 1px solid var(--border);
}
.simple-rail-section { padding: 4px 0 28px 28px; }
.simple-rail-section + .simple-rail-section { padding-top: 28px; border-top: 1px solid var(--border); }
.simple-rail-section h2 { margin: 10px 0 8px; color: var(--text); font: 650 1rem/1.35 var(--font-d); }
.simple-rail-section p { margin: 7px 0 14px; color: var(--text-sub); font: 0.76rem/1.55 var(--font-b); }
.simple-rail-section > small { display: block; margin-top: 9px; color: var(--muted); font: 0.64rem/1.4 var(--font-b); }
.simple-fluency-score { display: block; margin-top: 10px; color: var(--text); font: 700 2.2rem var(--font-num); }
.simple-progress { height: 5px; overflow: hidden; margin: 12px 0 8px; border-radius: 99px; background: var(--bg3); }
.simple-progress span { display: block; height: 100%; border-radius: inherit; background: var(--green); transition: width .5s ease; }

.simple-continue-card {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 30px;
  padding: 28px 0 34px;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.simple-continue-card > div > span { color: var(--green-text); font: 700 0.66rem var(--font-b); text-transform: uppercase; letter-spacing: .06em; }
.simple-continue-card h2 { margin: 10px 0 6px; color: var(--text); font: 700 1.55rem var(--font-d); letter-spacing: -.025em; }
.simple-continue-card p { margin: 0 0 12px; color: var(--text-sub); font: .82rem/1.55 var(--font-b); }
.simple-continue-card small { color: var(--muted); font: .64rem var(--font-b); }
.simple-continue-card .btn { width: auto; min-width: 140px; }
.simple-content-section { margin-top: 36px; }
.simple-section-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.simple-section-heading > span { color: var(--text); font: 700 .92rem var(--font-d); }
.simple-section-heading > small { color: var(--muted); font: .63rem var(--font-b); }
.simple-daily-concept > button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  width: 100%;
  padding: 20px 0;
  border: 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: transparent;
  color: var(--green-text);
  text-align: left;
  cursor: pointer;
}
.simple-daily-concept strong { color: var(--text); font: 650 .94rem var(--font-d); }
.simple-daily-concept p { margin: 5px 0 0; color: var(--text-sub); font: .75rem/1.45 var(--font-b); }
.simple-daily-concept button > span { white-space: nowrap; font: 600 .7rem var(--font-b); }
.simple-lesson-list { border-top: 1px solid var(--border); }
.simple-lesson-row {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto 18px;
  align-items: center;
  gap: 14px;
  width: 100%;
  padding: 16px 4px;
  border: 0;
  border-bottom: 1px solid var(--border);
  background: transparent;
  text-align: left;
  cursor: pointer;
}
.simple-lesson-row:hover { background: color-mix(in srgb, var(--bg2) 60%, transparent); }
.simple-lesson-state {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border: 1px solid var(--border2);
  border-radius: 50%;
  color: var(--muted);
  font: 600 .58rem var(--font-num);
}
.simple-lesson-copy { display: flex; min-width: 0; flex-direction: column; gap: 4px; }
.simple-lesson-copy strong { color: var(--text); font: 650 .78rem var(--font-b); }
.simple-lesson-copy small { overflow: hidden; color: var(--muted); font: .65rem var(--font-b); text-overflow: ellipsis; white-space: nowrap; }
.simple-lesson-meta { color: var(--muted); font: .61rem var(--font-b); white-space: nowrap; }
.simple-lesson-arrow { color: var(--muted); }
.simple-recommendations { display: grid; margin-top: 10px; }
.simple-recommendations button {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 0;
  border: 0;
  border-bottom: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  text-align: left;
  cursor: pointer;
}
.simple-recommendations strong { font: 600 .72rem var(--font-b); }
.simple-recommendations small { color: var(--muted); font: .59rem var(--font-b); white-space: nowrap; }

.simple-journey-score {
  padding: 26px 0 30px;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.simple-journey-score > div:first-child { display: grid; grid-template-columns: 1fr auto; align-items: baseline; }
.simple-journey-score span { color: var(--text); font: 650 .85rem var(--font-b); }
.simple-journey-score strong { grid-row: span 2; color: var(--text); font: 700 2.25rem var(--font-num); }
.simple-journey-score p { margin: 5px 0 0; color: var(--muted); font: .68rem var(--font-b); }
.simple-journey-path { padding-bottom: 28px; border-bottom: 1px solid var(--border); }
.simple-journey-path .fl-journey { margin-top: 16px; }
.simple-journey-path .fp-svg { width: 100%; height: 170px; }
.simple-current-level { margin-top: 34px; }
.simple-daily-practice .btn,
.simple-ask-card .btn { width: 100%; }

.simple-market-primary { width: auto; margin-top: 22px; }
.simple-market-story,
.simple-market-section {
  padding: 28px 0 32px;
  border-top: 1px solid var(--border);
}
.simple-market-story h2,
.simple-market-section h2 { margin: 10px 0 8px; color: var(--text); font: 700 1.25rem/1.35 var(--font-d); letter-spacing: -.02em; }
.simple-market-story p,
.simple-market-section p { max-width: 680px; margin: 0; color: var(--text-sub); font: .84rem/1.7 var(--font-b); }
.simple-market-snapshot .snap-cards { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.simple-market-snapshot .snap-card { min-width: 0; }

.ob-product-welcome { max-width: 620px; }
.ob-product-welcome .ob-features { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 24px; margin-top: 28px; }
.ob-product-welcome .ob-feature { align-items: flex-start; padding: 14px 0; }
.ob-entry-actions { display: grid; gap: 10px; width: 100%; margin-top: 28px; }
.ob-signin-link { padding: 8px; border: 0; background: transparent; color: var(--text-sub); font: 600 .72rem var(--font-b); cursor: pointer; }
.ob-signin-link:hover { color: var(--green-text); }

@media (min-width: 1100px) {
  :root { --workspace-tutor: 0px; }
  .screen:not(#authScreen) { margin-right: 0; }
  #practiceRoot,
  #marketFeatureList,
  #profileScreen > *,
  #practiceSessionRoot { max-width: none; }

  .ask-tutor-panel {
    position: fixed;
    inset: 18px 18px 18px auto;
    z-index: 70;
    width: min(390px, calc(100vw - 36px));
    height: auto;
    border: 1px solid var(--border);
    border-radius: 14px;
    box-shadow: 0 24px 70px rgba(15, 23, 42, .18);
    transform: translateX(calc(100% + 40px));
  }
  .ask-tutor-panel.open { transform: translateX(0); }
  .ask-tutor-close { display: grid !important; }
  .ask-tutor-backdrop { display: none !important; }
  .ask-tutor-backdrop.open { display: block !important; position: fixed; inset: 0; z-index: 69; background: rgba(15, 23, 42, .16); backdrop-filter: blur(2px); }
  .ask-floating-button { display: none !important; }
}

@media (max-width: 1099px) {
  .workspace-account { top: 0; right: 0; }
  .workspace-account-button { display: none; }
  .workspace-account-menu { position: fixed; top: 58px; right: 14px; z-index: 90; }
  .simple-page-shell { display: block; width: 100%; padding: 30px 20px 120px; }
  .simple-page-header { margin-bottom: 30px; }
  .simple-page-header h1 { font-size: 2.2rem; }
  .simple-page-rail { margin-top: 36px; padding-top: 0; border-top: 1px solid var(--border); border-left: 0; }
  .simple-rail-section { padding: 26px 0; }
  .simple-continue-card { align-items: stretch; flex-direction: column; }
  .simple-continue-card .btn { width: 100%; }
  .simple-lesson-row { grid-template-columns: 32px minmax(0, 1fr) 16px; }
  .simple-lesson-meta { display: none; }
  .simple-market-snapshot .snap-cards { grid-template-columns: 1fr; }
  .ob-product-welcome .ob-features { grid-template-columns: 1fr; }
  #mainNav { grid-template-columns: repeat(3, 1fr); }
}

/* ════════════════════════════════════════════════════════════
   FINLINGO LIGHT WORKSPACE — image target
   ════════════════════════════════════════════════════════════ */
@media (min-width: 1100px) {
  :root {
    --workspace-side: 270px;
    --app-max: none;
  }

  body {
    padding: 0;
    background: #ffffff;
  }

  .app {
    max-width: none;
    width: 100vw;
    height: 100vh;
    min-height: 720px;
    border: 0;
    border-radius: 0;
    background: #ffffff;
    box-shadow: none;
  }

  .screen:not(#authScreen) {
    margin: 0 0 0 var(--workspace-side);
    background: #ffffff;
  }

  #pathScreen {
    padding: 0 !important;
    background: #ffffff;
  }

  .lesson-path {
    min-height: 100%;
    background:
      radial-gradient(circle at 34% 8%, rgba(18, 128, 68, 0.045), transparent 30%),
      #ffffff;
  }

  .workspace-sidebar {
    width: var(--workspace-side);
    padding: 28px 18px;
    border-right: 1px solid #e5e7eb;
    background: #fbfcfb;
  }

  .workspace-sidebar-head {
    min-height: 38px;
    padding: 0 0 40px;
    border-bottom: 0;
  }

  .workspace-brand {
    gap: 12px;
    color: #0b1117;
  }

  .workspace-brand-mark {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: #ffffff;
    color: #ffffff;
    font-size: 0;
    position: relative;
  }

  .workspace-brand-mark::before {
    content: "";
    position: absolute;
    inset: 8px 7px 7px;
    background:
      linear-gradient(#ffffff, #ffffff) 0 9px / 4px 5px no-repeat,
      linear-gradient(#ffffff, #ffffff) 6px 5px / 4px 9px no-repeat,
      linear-gradient(#ffffff, #ffffff) 12px 1px / 4px 13px no-repeat;
    border-radius: 2px;
  }

  .workspace-brand-name {
    font: 800 1.55rem/1 var(--font-d);
    letter-spacing: -0.055em;
  }

  .workspace-brand-name .brand-fin { color: #0b1117; }
  .workspace-brand-name .brand-lingo { color: #0f7d45; }

  .workspace-collapse {
    width: 28px;
    height: 28px;
    color: #111827;
  }

  .workspace-collapse svg {
    width: 18px;
    height: 18px;
    stroke-width: 2.1;
  }

  .workspace-primary-nav {
    flex: 0 0 auto;
    gap: 16px;
    padding: 0;
    overflow: visible;
  }

  .workspace-primary-nav button {
    min-height: 56px;
    gap: 18px;
    padding: 0 17px;
    border: 1px solid transparent;
    border-radius: 10px;
    color: #111827;
    font: 650 1rem/1 var(--font-b);
  }

  .workspace-primary-nav button:hover {
    background: #f3f7f4;
    color: #063f24;
  }

  .workspace-primary-nav button.active {
    border-color: #d9e7df;
    background: linear-gradient(135deg, rgba(15, 125, 69, 0.10), rgba(15, 125, 69, 0.04));
    color: #065f35;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.6);
  }

  .workspace-primary-nav svg {
    width: 22px;
    height: 22px;
    stroke-width: 1.85;
  }

  .workspace-learn-menu,
  #workspaceLearnButton .workspace-learn-chevron {
    display: none !important;
  }

  .workspace-motivation-card {
    margin-top: auto;
    min-height: 246px;
    padding: 28px 20px 18px;
    border: 1px solid #dfe7e2;
    border-radius: 11px;
    background:
      radial-gradient(circle at 18% 18%, rgba(15, 125, 69, 0.08), transparent 34%),
      linear-gradient(160deg, #f9fcfa 0%, #f2f8f4 100%);
    color: #111827;
  }

  .workspace-motivation-spark {
    display: block;
    margin-bottom: 18px;
    color: #ffffff;
    font-size: 1rem;
  }

  .workspace-motivation-card p {
    margin: 0;
    font: 0.94rem/1.5 var(--font-b);
    letter-spacing: -0.01em;
  }

  .workspace-motivation-card strong { color: #065f35; font-weight: 800; }

  .workspace-motivation-card svg {
    display: block;
    width: 150px;
    height: 76px;
    margin: 16px 0 0 8px;
    fill: none;
    stroke: #0b7d44;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .workspace-motivation-card svg circle { fill: #0b7d44; stroke: none; }

  .workspace-account {
    top: 24px;
    right: 28px;
  }

  .install-banner {
    display: none !important;
  }

  .workspace-account-button {
    width: 42px;
    height: 42px;
    border: 0;
    background: #f1f4f8;
    color: #111827;
  }

  .workspace-account-button svg {
    display: block;
    width: 21px;
    height: 21px;
  }

  .target-learn-shell {
    display: grid;
    grid-template-columns: minmax(620px, 760px) 362px;
    gap: 60px;
    width: min(1180px, calc(100vw - var(--workspace-side) - 72px));
    min-height: 100%;
    margin: 0 auto;
    padding: 96px 0 60px;
    color: #0b1117;
  }

  .target-learn-main {
    min-width: 0;
  }

  .target-learn-header {
    padding-bottom: 30px;
    border-bottom: 1px solid #e3e7ec;
  }

  .target-learn-header > span,
  .target-section-heading > span,
  .target-rail-label {
    color: #006b37;
    font: 800 0.78rem/1 var(--font-b);
    letter-spacing: 0.055em;
    text-transform: uppercase;
  }

  .target-learn-header h1 {
    margin: 22px 0 14px;
    color: #05070a;
    font: 800 clamp(2.6rem, 4.1vw, 3.85rem)/0.97 var(--font-d);
    letter-spacing: -0.07em;
  }

  .target-learn-header h1::after {
    content: "";
    display: inline-block;
    width: 8px;
    height: 8px;
    margin-left: 4px;
    border-radius: 50%;
    background: #0b7d44;
    vertical-align: baseline;
  }

  .target-learn-header p {
    margin: 0;
    color: #667085;
    font: 1.05rem/1.6 var(--font-b);
    letter-spacing: -0.015em;
  }

  .target-section {
    margin-top: 32px;
  }

  .target-section-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
  }

  .target-section-heading small {
    color: #667085;
    font: 0.92rem/1 var(--font-b);
  }

  .target-continue-card,
  .target-daily-card,
  .target-lesson-list,
  .target-rail-card {
    border: 1px solid #dfe5eb;
    border-radius: 12px;
    background: rgba(255,255,255,0.92);
    box-shadow: 0 10px 30px rgba(16, 24, 40, 0.035);
  }

  .target-continue-card {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr) auto;
    align-items: center;
    gap: 28px;
    min-height: 138px;
    padding: 22px 19px;
  }

  .target-card-icon {
    display: grid;
    place-items: center;
    width: 56px;
    height: 56px;
    border-radius: 15px;
    background: rgba(255,255,255,0.08);
    color: #ffffff;
  }

  .target-card-icon svg {
    width: 32px;
    height: 32px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .target-continue-card h2 {
    margin: 0 0 8px;
    color: #05070a;
    font: 800 1.36rem/1.15 var(--font-d);
    letter-spacing: -0.035em;
  }

  .target-continue-card p,
  .target-daily-card p {
    margin: 0;
    color: #4b5565;
    font: 0.94rem/1.45 var(--font-b);
  }

  .target-continue-card small {
    display: block;
    margin-top: 18px;
    color: #4b5565;
    font: 0.82rem/1 var(--font-b);
  }

  .target-continue-card small i,
  .target-lesson-meta i {
    margin: 0 9px;
    color: #667085;
    font-style: normal;
  }

  .target-continue-card .btn {
    width: auto;
    min-width: 156px;
    height: 46px;
    border-radius: 8px;
    background: #ffffff;
    color: #0B0D0F;
    font: 750 0.92rem/1 var(--font-b);
    box-shadow: none;
  }

  .target-daily-card {
    display: grid;
    grid-template-columns: 56px minmax(0, 1fr) auto;
    align-items: center;
    gap: 28px;
    width: 100%;
    min-height: 92px;
    padding: 16px 20px;
    color: #006b37;
    text-align: left;
    cursor: pointer;
  }

  .target-daily-card strong {
    display: block;
    margin-bottom: 6px;
    color: #05070a;
    font: 800 1.12rem/1.15 var(--font-d);
    letter-spacing: -0.03em;
  }

  .target-daily-card > span:last-child,
  .target-text-link,
  .target-view-all {
    color: #006b37;
    font: 750 0.87rem/1 var(--font-b);
  }

  .target-daily-card > span:last-child i,
  .target-text-link span,
  .target-view-all span {
    margin-left: 10px;
    font-style: normal;
  }

  .target-lesson-list {
    overflow: hidden;
  }

  .target-lesson-row {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr) auto 18px;
    align-items: center;
    gap: 12px;
    width: 100%;
    min-height: 71px;
    padding: 14px 20px 14px 16px;
    border: 0;
    border-bottom: 1px solid #e5e7eb;
    background: transparent;
    color: #111827;
    text-align: left;
    cursor: pointer;
  }

  .target-lesson-row:hover {
    background: #f8fbf9;
  }

  .target-lesson-number {
    display: grid;
    place-items: center;
    width: 36px;
    height: 36px;
    border: 1px solid #dce9e1;
    border-radius: 50%;
    background: #eff8f2;
    color: #ffffff;
    font: 750 0.9rem/1 var(--font-num);
  }

  .target-lesson-copy {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 6px;
  }

  .target-lesson-copy strong {
    overflow: hidden;
    color: #05070a;
    font: 750 0.98rem/1.1 var(--font-b);
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .target-lesson-copy small {
    overflow: hidden;
    color: #4b5565;
    font: 0.84rem/1.15 var(--font-b);
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .target-lesson-meta {
    color: #334155;
    font: 0.83rem/1 var(--font-b);
    white-space: nowrap;
  }

  .target-arrow {
    color: #111827;
    font-size: 1.25rem;
  }

  .target-view-all {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 48px;
    border: 0;
    background: #ffffff;
    cursor: pointer;
  }

  .target-learn-rail {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding-top: 0;
  }

  .target-rail-card {
    padding: 24px 22px;
  }

  .target-fluency-card {
    min-height: 288px;
  }

  .target-fluency-row {
    display: flex;
    align-items: center;
    min-height: 110px;
    margin-top: 10px;
  }

  .target-fluency-ring {
    display: grid;
    place-items: center;
    width: 94px;
    height: 94px;
    border-radius: 50%;
    background:
      radial-gradient(circle closest-side, #ffffff 73%, transparent 75% 100%),
      conic-gradient(#ffffff calc(var(--pct) * 1%), #e6e8ed 0);
  }

  .target-fluency-ring strong {
    color: #05070a;
    font: 800 1.5rem/1 var(--font-num);
  }

  .target-fluency-card p {
    margin: 6px 0 12px;
    color: #111827;
    font: 0.9rem/1.3 var(--font-b);
  }

  .target-fluency-card p strong {
    font-weight: 800;
  }

  .target-progress {
    height: 7px;
    overflow: hidden;
    margin: 0 8px 12px 0;
    border-radius: 99px;
    background: #e6e8ed;
  }

  .target-progress span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: #ffffff;
  }

  .target-rail-card small {
    color: #667085;
    font: 0.84rem/1.35 var(--font-b);
  }

  .target-text-link {
    display: inline-flex;
    align-items: center;
    margin-top: 22px;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
  }

  .target-rec-list {
    display: grid;
    gap: 16px;
    margin-top: 18px;
  }

  .target-rec-row {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr) auto;
    align-items: center;
    gap: 13px;
    width: 100%;
    border: 0;
    background: transparent;
    color: #111827;
    text-align: left;
    cursor: pointer;
  }

  .target-rec-icon {
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border-radius: 9px;
    background: #eef8f2;
    color: #ffffff;
  }

  .target-rec-icon svg {
    width: 18px;
    height: 18px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .target-rec-row strong {
    overflow: hidden;
    color: #05070a;
    font: 750 0.9rem/1.2 var(--font-b);
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .target-rec-row small {
    color: #667085;
    font: 0.84rem/1 var(--font-b);
    white-space: nowrap;
  }

  .target-ask-title {
    display: flex;
    align-items: center;
    gap: 10px;
    color: #05070a;
    font: 800 0.98rem/1 var(--font-b);
  }

  .target-ask-title span {
    color: #05070a;
    font-size: 1.05rem;
  }

  .target-ask-title em {
    padding: 4px 8px;
    border-radius: 8px;
    background: #eaf6ee;
    color: #ffffff;
    font: 800 0.72rem/1 var(--font-b);
    font-style: normal;
  }

  .target-ask-card p {
    margin: 13px 0 14px;
    color: #4b5565;
    font: 0.9rem/1.4 var(--font-b);
  }

  .target-ask-card button {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    min-height: 34px;
    margin-top: 8px;
    padding: 0 14px;
    border: 1px solid #dfe5eb;
    border-radius: 8px;
    background: #fbfcfd;
    color: #111827;
    font: 0.86rem/1 var(--font-b);
    text-align: left;
    cursor: pointer;
  }

  .target-ask-card button:hover {
    border-color: #cbd5df;
    background: #f8fafc;
  }

  .target-ask-card button span {
    color: #334155;
  }

  .target-ask-card .target-ask-input {
    justify-content: space-between;
    min-height: 54px;
    margin-top: 24px;
    color: #667085;
    background: #ffffff;
  }

  .target-ask-card .target-ask-input span {
    margin-left: auto;
    color: #ffffff;
    font-size: 1.1rem;
  }

  .target-roadmap-card {
    display: grid;
    gap: 16px;
  }

  .target-roadmap-block strong,
  .target-roadmap-time {
    color: #111827;
    font: 750 0.9rem/1.25 var(--font-b);
  }

  .target-roadmap-block ul {
    display: grid;
    gap: 7px;
    margin: 10px 0 0;
    padding: 0;
    list-style: none;
  }

  .target-roadmap-block li {
    position: relative;
    padding-left: 18px;
    color: #4b5565;
    font: 0.88rem/1.35 var(--font-b);
  }

  .target-roadmap-block li::before {
    content: "✓";
    position: absolute;
    left: 0;
    color: #ffffff;
    font-weight: 800;
  }

  .target-roadmap-block p {
    margin: 8px 0 0;
    color: #ffffff;
    font: 800 0.95rem/1.35 var(--font-b);
  }

  .target-roadmap-time {
    padding-top: 12px;
    border-top: 1px solid #e5e7eb;
    color: #4b5565;
  }

  .target-roadmap-time strong { color: #111827; }

  .market-translator-card {
    padding-bottom: 32px;
  }

  .market-translator-input-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    margin-top: 18px;
  }

  .market-translator-input-row textarea {
    width: 100%;
    min-height: 72px;
    resize: vertical;
    padding: 13px 14px;
    border: 1px solid #dfe5eb;
    border-radius: 10px;
    outline: 0;
    background: #ffffff;
    color: #111827;
    font: 0.92rem/1.45 var(--font-b);
  }

  .market-translator-input-row textarea:focus {
    border-color: #ffffff;
    box-shadow: none;
  }

  .market-translator-input-row .btn {
    align-self: start;
    width: auto;
    min-width: 120px;
    height: 44px;
    border-radius: 8px;
    background: #ffffff;
    color: #0B0D0F;
  }

  .market-translator-output {
    display: grid;
    gap: 10px;
    margin-top: 14px;
    padding: 16px;
    border: 1px solid #dfe5eb;
    border-radius: 12px;
    background: #fbfcfd;
  }

  .market-translator-output strong {
    color: #111827;
    font: 800 0.82rem/1 var(--font-b);
  }

  .market-translator-output p {
    margin: 5px 0 0;
    color: #4b5565;
    font: 0.86rem/1.5 var(--font-b);
  }

  .market-translator-loading,
  .market-translator-error {
    color: #4b5565;
    font: 0.86rem/1.45 var(--font-b);
  }

  .market-translator-error { color: #b42318; }

  .market-learning-shell {
    display: grid;
    grid-template-columns: minmax(620px, 780px) 340px;
    gap: 56px;
    width: min(1180px, calc(100vw - var(--workspace-side) - 72px));
    min-height: 100%;
    margin: 0 auto;
    padding: 88px 0 64px;
    color: #0b1117;
  }

  .market-learning-main,
  .market-learning-rail { min-width: 0; }

  .market-learning-header {
    max-width: 720px;
    padding-bottom: 28px;
    border-bottom: 1px solid #e3e7ec;
  }

  .market-learning-header > span,
  .market-card-kicker {
    color: #006b37;
    font: 800 0.78rem/1 var(--font-b);
    letter-spacing: 0.055em;
    text-transform: uppercase;
  }

  .market-learning-header h1 {
    margin: 20px 0 12px;
    color: #05070a;
    font: 800 clamp(2.25rem, 3.4vw, 3.35rem)/1 var(--font-d);
    letter-spacing: -0.065em;
  }

  .market-learning-header p {
    margin: 0;
    color: #667085;
    font: 1.02rem/1.6 var(--font-b);
  }

  .market-story-card,
  .market-learning-card {
    margin-top: 24px;
    border: 1px solid #dfe5eb;
    border-radius: 14px;
    background: rgba(255,255,255,0.94);
    box-shadow: 0 10px 30px rgba(16, 24, 40, 0.035);
  }

  .market-story-card {
    padding: 26px;
  }

  .market-story-grid {
    display: grid;
    gap: 20px;
    margin-top: 18px;
  }

  .market-story-primary {
    padding-bottom: 20px;
    border-bottom: 1px solid #e5e7eb;
  }

  .market-story-primary > span,
  .market-story-point > span {
    display: block;
    margin-bottom: 8px;
    color: #667085;
    font: 750 0.78rem/1 var(--font-b);
    letter-spacing: 0.02em;
  }

  .market-story-primary h2 {
    max-width: 660px;
    margin: 0;
    color: #05070a;
    font: 800 1.75rem/1.16 var(--font-d);
    letter-spacing: -0.045em;
  }

  .market-story-point p {
    max-width: 650px;
    margin: 0;
    color: #344054;
    font: 0.96rem/1.58 var(--font-b);
  }

  .market-learning-card {
    padding: 24px;
  }

  .market-section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 18px;
  }

  .market-section-head h2,
  .market-learning-card h2 {
    margin: 9px 0 0;
    color: #05070a;
    font: 800 1.25rem/1.22 var(--font-d);
    letter-spacing: -0.035em;
  }

  .market-learning-card > p,
  .market-personal-card p,
  .market-ask-card small {
    color: #4b5565;
    font: 0.9rem/1.5 var(--font-b);
  }

  .market-mini-snapshot {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
  }

  .market-mini-snapshot .snap-card {
    min-width: 0;
    padding: 14px;
    border: 1px solid #e1e7ed;
    border-radius: 12px;
    background: #fbfcfd;
    box-shadow: none;
  }

  .market-mini-snapshot .snap-card-head {
    margin-bottom: 12px;
  }

  .market-mini-snapshot .snap-sym {
    color: #05070a;
    font: 800 0.86rem/1 var(--font-b);
  }

  .market-mini-snapshot .snap-name {
    margin-top: 4px;
    color: #667085;
    font: 0.72rem/1.2 var(--font-b);
  }

  .market-mini-snapshot .snap-card-body {
    display: block;
  }

  .market-mini-snapshot .snap-price {
    color: #05070a;
    font: 800 1.08rem/1 var(--font-num);
  }

  .market-mini-snapshot .snap-change {
    margin-top: 7px;
    font: 0.72rem/1.2 var(--font-b);
  }

  .market-mini-snapshot .snap-card-skeleton .snap-spark-wrap,
  .market-mini-snapshot .snap-spark-wrap {
    display: none;
  }

  .market-decision-card > p {
    margin: 8px 0 0;
  }

  .market-decision-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-top: 18px;
  }

  .market-decision-choice {
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 48px;
    padding: 0 13px;
    border: 1px solid #dfe5eb;
    border-radius: 10px;
    background: #ffffff;
    color: #111827;
    font: 700 0.88rem/1.25 var(--font-b);
    text-align: left;
    cursor: pointer;
  }

  .market-decision-choice span {
    display: grid;
    place-items: center;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: #eef8f2;
    color: #ffffff;
    font: 800 0.75rem/1 var(--font-b);
  }

  .market-decision-choice:hover,
  .market-decision-choice.is-selected {
    border-color: #ffffff;
    background: #f4fbf7;
  }

  .market-decision-choice:disabled {
    cursor: wait;
  }

  .market-decision-response {
    display: none;
    margin-top: 16px;
    padding: 14px;
    border: 1px solid #dfe5eb;
    border-radius: 11px;
    background: #fbfcfd;
    color: #344054;
    font: 0.88rem/1.55 var(--font-b);
  }

  .market-decision-response.show {
    display: block;
  }

  .market-concept-links {
    display: grid;
    gap: 10px;
    margin-top: 18px;
  }

  .market-concept-links button {
    display: grid;
    grid-template-columns: 24px minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    min-height: 54px;
    padding: 0 13px;
    border: 1px solid #dfe5eb;
    border-radius: 10px;
    background: #ffffff;
    color: #111827;
    text-align: left;
    cursor: pointer;
  }

  .market-concept-links button > span {
    color: #ffffff;
    font-weight: 900;
  }

  .market-concept-links strong {
    color: #05070a;
    font: 800 0.93rem/1 var(--font-b);
  }

  .market-concept-links small {
    color: #667085;
    font: 0.76rem/1 var(--font-b);
  }

  .market-learning-rail {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding-top: 116px;
  }

  .market-learning-rail .market-learning-card {
    margin-top: 0;
  }

  .market-personal-card p {
    margin: 12px 0 0;
  }

  .market-personal-card button {
    width: 100%;
    margin-top: 16px;
    padding: 13px 14px;
    border: 1px solid #dfe5eb;
    border-radius: 10px;
    background: #f8fbf9;
    color: #006b37;
    font: 750 0.84rem/1.35 var(--font-b);
    text-align: left;
    cursor: pointer;
  }

  .market-personal-card button strong {
    display: block;
    margin-top: 4px;
    color: #05070a;
  }

  .market-ask-prompts {
    display: grid;
    gap: 9px;
    margin-top: 16px;
  }

  .market-ask-prompts button {
    min-height: 38px;
    padding: 0 12px;
    border: 1px solid #dfe5eb;
    border-radius: 9px;
    background: #ffffff;
    color: #111827;
    font: 0.84rem/1 var(--font-b);
    text-align: left;
    cursor: pointer;
  }

  .market-ask-prompts button:hover {
    border-color: #ffffff;
    background: #f4fbf7;
  }

  .market-ask-card small {
    display: block;
    margin-top: 14px;
  }

  body.workspace-sidebar-collapsed {
    --workspace-side: 72px;
  }

  body.workspace-sidebar-collapsed .workspace-sidebar {
    padding-inline: 10px;
  }

  body.workspace-sidebar-collapsed .workspace-motivation-card {
    display: none;
  }
}

@media (max-width: 1099px) {
  .target-learn-shell {
    display: block;
    padding: 28px 20px 120px;
  }

  .target-learn-header {
    padding-bottom: 24px;
    border-bottom: 1px solid var(--border);
  }

  .target-learn-header h1 {
    margin: 14px 0 8px;
    font: 800 2.2rem/1.02 var(--font-d);
    letter-spacing: -0.05em;
  }

  .target-section { margin-top: 28px; }

  .target-continue-card,
  .target-daily-card {
    display: flex;
    align-items: flex-start;
    flex-direction: column;
    gap: 16px;
    padding: 18px;
  }

  .target-continue-card .btn { width: 100%; }

  .target-lesson-row {
    grid-template-columns: 40px minmax(0, 1fr) 18px;
  }

  .target-lesson-meta { display: none; }

  .target-learn-rail {
    display: grid;
    gap: 16px;
    margin-top: 28px;
  }
}

/* ════════════════════════════════════════════════════════════
   CLAUDE CORPS APP DEMO SHELL
   Desktop returns to a contained app canvas. The product keeps the
   mobile-native shell, while Learn/Market/Journey remain the only
   primary navigation surfaces. Intelligence is embedded as Ask.
   ════════════════════════════════════════════════════════════ */
@media (min-width: 900px) {
  :root {
    --app-max: 440px;
    --header-h: 62px;
    --nav-h: 68px;
  }

  html,
  body {
    min-height: 100%;
  }

  body {
    padding: 24px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background:
      none,
      #f4f6f5 !important;
    overflow: hidden;
  }

  .app {
    width: min(440px, calc(100vw - 48px)) !important;
    max-width: 440px !important;
    height: min(900px, calc(100vh - 48px)) !important;
    min-height: 720px !important;
    border: 1px solid #dfe5eb !important;
    border-radius: 28px !important;
    background: #ffffff !important;
    box-shadow: 0 24px 70px rgba(15, 23, 42, 0.13) !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
  }

  .workspace-sidebar,
  .workspace-account,
  .ask-floating-button {
    display: none !important;
  }

  body:not(.entry-gate-visible) #mainTopbar {
    display: block !important;
    order: 0;
    position: relative !important;
    inset: auto !important;
    height: var(--header-h) !important;
    min-height: var(--header-h) !important;
    padding: 0 !important;
    border-bottom: 1px solid #eef1f4 !important;
    background: rgba(255, 255, 255, 0.94) !important;
    backdrop-filter: blur(18px);
    z-index: 8;
  }

  .topbar-row {
    width: 100% !important;
    height: 100% !important;
    padding: 0 18px !important;
    margin: 0 !important;
  }

  .brand {
    font: 800 1.28rem/1 var(--font-d) !important;
    letter-spacing: -0.055em;
  }

  .pills {
    gap: 8px !important;
  }

  .topbar-icon-btn {
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    border: 1px solid #e4e8ed !important;
    background: #f8faf9 !important;
    box-shadow: none !important;
  }

  body:not(.entry-gate-visible) #mainNav {
    display: grid !important;
    order: 3;
    position: relative !important;
    inset: auto !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 6px !important;
    min-height: var(--nav-h) !important;
    padding: 7px 12px 10px !important;
    margin: 0 !important;
    border-top: 1px solid #eef1f4 !important;
    background: rgba(255, 255, 255, 0.96) !important;
    backdrop-filter: blur(18px);
    z-index: 8;
  }

  .nav .nb {
    min-width: 0 !important;
    min-height: 48px !important;
    padding: 6px 4px !important;
    border: 0 !important;
    border-radius: 14px !important;
    background: transparent !important;
    color: #667085 !important;
    font: 700 0.68rem/1 var(--font-b) !important;
    letter-spacing: -0.01em;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
  }

  .nav .nb svg {
    width: 19px !important;
    height: 19px !important;
    stroke-width: 1.9 !important;
  }

  .nav .nb.active {
    background: #eef8f2 !important;
    color: #ffffff !important;
  }

  .screen:not(#authScreen) {
    order: 2;
    flex: 1 1 auto !important;
    min-height: 0 !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: #ffffff !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }

  #pathScreen,
  #marketScreen,
  #practiceScreen,
  #courseScreen,
  #quizScreen,
  #resultScreen,
  #profileScreen,
  #settingsScreen,
  #practiceSessionScreen {
    margin: 0 !important;
    padding: 0 !important;
    background: #ffffff !important;
  }

  .lesson-path {
    min-height: auto !important;
    background: #ffffff !important;
  }

  .target-learn-shell,
  .market-learning-shell,
  .simple-page-shell {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    min-height: auto !important;
    padding: 24px 20px 30px !important;
    margin: 0 !important;
  }

  .target-learn-main,
  .market-learning-main,
  .simple-page-main,
  .target-learn-rail,
  .market-learning-rail,
  .simple-page-rail {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
  }

  .target-learn-header,
  .market-learning-header,
  .simple-page-header {
    padding: 0 0 22px !important;
    margin: 0 !important;
    border-bottom: 1px solid #edf1f4 !important;
  }

  .target-learn-header span,
  .market-learning-header span,
  .simple-page-eyebrow {
    font: 800 0.72rem/1 var(--font-b) !important;
    letter-spacing: 0.075em !important;
    text-transform: uppercase !important;
    color: #ffffff !important;
  }

  .target-learn-header h1,
  .market-learning-header h1,
  .simple-page-header h1 {
    margin: 14px 0 8px !important;
    color: #05070a !important;
    font: 850 2.05rem/1.02 var(--font-d) !important;
    letter-spacing: -0.06em !important;
  }

  .target-learn-header p,
  .market-learning-header p,
  .simple-page-header p {
    max-width: 34ch !important;
    color: #667085 !important;
    font: 0.95rem/1.55 var(--font-b) !important;
  }

  .target-section,
  .market-learning-card,
  .simple-section {
    margin-top: 24px !important;
  }

  .target-section-heading {
    margin-bottom: 12px !important;
  }

  .target-section-heading span,
  .market-card-kicker,
  .target-rail-label {
    color: #4b5563 !important;
    font: 800 0.68rem/1 var(--font-b) !important;
    letter-spacing: 0.065em !important;
    text-transform: uppercase !important;
  }

  .target-continue-card,
  .target-daily-card {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 14px !important;
    padding: 18px !important;
  }

  .target-continue-card .btn,
  .target-daily-card > span:last-child {
    width: 100% !important;
  }

  .target-card-icon {
    width: 54px !important;
    height: 54px !important;
    border-radius: 16px !important;
  }

  .target-lesson-row {
    grid-template-columns: 38px minmax(0, 1fr) 18px !important;
    min-height: 74px !important;
    padding: 0 14px !important;
  }

  .target-lesson-number {
    width: 32px !important;
    height: 32px !important;
  }

  .target-lesson-meta {
    display: none !important;
  }

  .target-view-all {
    min-height: 48px !important;
  }

  .target-learn-rail,
  .market-learning-rail,
  .simple-page-rail {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    margin-top: 24px !important;
    padding: 0 !important;
    border: 0 !important;
  }

  .target-rail-card,
  .market-learning-card,
  .simple-rail-section,
  .simple-content-card {
    border: 1px solid #dfe5eb !important;
    border-radius: 16px !important;
    background: #ffffff !important;
    box-shadow: none !important;
  }

  .target-rail-card,
  .market-learning-card {
    padding: 18px !important;
  }

  .target-fluency-row {
    justify-content: flex-start !important;
    margin-top: 14px !important;
  }

  .target-rec-row {
    grid-template-columns: 36px minmax(0, 1fr) auto !important;
  }

  .target-ask-card {
    background: linear-gradient(180deg, #ffffff, #fbfdfc) !important;
  }

  .market-story-card {
    padding: 20px !important;
  }

  .market-story-head h2,
  .market-learning-card h2 {
    font-size: 1.12rem !important;
    line-height: 1.18 !important;
  }

  .market-story-block {
    padding: 14px 0 !important;
  }

  .market-mini-snapshot {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .market-decision-grid {
    grid-template-columns: 1fr !important;
  }

  .market-concept-links button {
    grid-template-columns: 24px minmax(0, 1fr) 16px !important;
  }

  .simple-journey-path .fp-svg,
  .mastery-journey-strip .fp-svg {
    height: 132px !important;
  }

  #practiceRoot,
  #practiceSessionRoot {
    max-width: none !important;
    margin: 0 !important;
  }

  #courseScreen,
  #quizScreen,
  #resultScreen,
  #practiceSessionScreen {
    padding: 22px 20px 30px !important;
  }

  .course-header,
  .quiz-meta-row,
  .result-card {
    max-width: none !important;
  }

  .ask-tutor-panel {
    position: absolute !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    max-width: none !important;
    border-left: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
  }

  .ask-tutor-backdrop {
    position: absolute !important;
  }

  #authScreen.auth-modal-overlay {
    position: absolute !important;
    inset: 0 !important;
    padding: 18px !important;
  }

  #authScreen .auth-wrap {
    max-width: 360px !important;
    border-radius: 22px !important;
  }
}

.ask-floating-button {
  display: none !important;
}
