/* =========================================================
   ChefVerse · App styles
   Layered on top of tokens.css (UFS design tokens)
   ========================================================= */

* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
  background: var(--canvas-bg);
  color: var(--foreground);
  font-family: var(--font-sans);
  -webkit-font-smoothing: antialiased;
  font-size: 14px;
}
button { font-family: inherit; cursor: pointer; }
input, textarea, select { font-family: inherit; color: inherit; }
input:focus, textarea:focus { outline: none; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: var(--mushroom); border-radius: 999px; border: 2px solid transparent; background-clip: padding-box; }
::-webkit-scrollbar-thumb:hover { background: var(--smoke); border: 2px solid transparent; background-clip: padding-box; }
::-webkit-scrollbar-track { background: transparent; }

/* ─── Buttons ─── */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  height: 36px; padding: 0 14px; border-radius: 6px;
  font: 600 14px/1 var(--font-sans);
  border: 0; cursor: pointer; transition: background .14s ease, transform .14s ease, box-shadow .14s ease;
  white-space: nowrap; }
.btn:disabled { opacity: 0.4; cursor: not-allowed; }
.btn-primary { background: var(--ufs-orange); color: #fff; }
.btn-primary:hover:not(:disabled) { background: var(--primary-hover); }
.btn-secondary { background: var(--secondary); color: var(--foreground); }
.btn-secondary:hover:not(:disabled) { background: var(--secondary-hover); }
.btn-outline { background: transparent; color: var(--foreground); border: 1px solid var(--border); }
.btn-outline:hover:not(:disabled) { background: var(--muted); }
.btn-ghost { background: transparent; color: var(--foreground); }
.btn-ghost:hover:not(:disabled) { background: var(--muted); }
.btn-sm { height: 28px; padding: 0 10px; font-size: 12px; gap: 4px; border-radius: 5px; }
.btn-block { width: 100%; }

.icon-btn { display: inline-flex; align-items: center; justify-content: center; gap: 4px;
  background: transparent; border: 0; color: var(--foreground);
  height: 32px; min-width: 32px; padding: 0 6px; border-radius: 6px;
  cursor: pointer; transition: background .14s ease;
  position: relative;
}
.icon-btn:hover { background: var(--muted); }
.icon-btn.ghost { color: var(--foreground); }
.icon-btn.solid { background: var(--squid-ink); color: #fff; }
.icon-btn.solid:hover { background: #312a52; }
.icon-btn .dot-red {
  position: absolute; top: 8px; right: 8px;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--ufs-orange); border: 2px solid var(--background);
}

.link-btn {
  background: transparent; border: 0;
  font: 600 13px/1 var(--font-sans);
  color: var(--ufs-orange);
  cursor: pointer; padding: 4px 6px;
  display: inline-flex; align-items: center; gap: 4px;
  border-radius: 4px;
  white-space: nowrap;
  flex-shrink: 0;
}
.link-btn:hover { background: var(--accent); }

.eyebrow {
  font: 700 11px/1 var(--font-sans);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ufs-orange);
}
.display-italic {
  font-family: var(--font-display);
  font-style: normal;
  font-weight: 400;
}
.subtle { font: 400 13px/1.5 var(--font-sans); color: var(--muted-foreground); }
.lead   { font: 400 17px/1.55 var(--font-sans); color: var(--foreground); }
h1 { font: 700 32px/1.1 var(--font-sans); letter-spacing: -0.012em; margin: 0; }
h2 { font: 700 22px/1.25 var(--font-sans); letter-spacing: -0.007em; margin: 0; }
h3 { font: 700 17px/1.3 var(--font-sans); letter-spacing: -0.005em; margin: 0; }

/* Avatars */
.av { width: 32px; height: 32px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font: 700 12px/1 var(--font-sans); color: #fff; flex-shrink: 0;
  background: var(--squid-ink);
}
.av-sm { width: 28px; height: 28px; font-size: 11px; }
.av-mr { background: var(--ufs-orange); }

/* ─── App layout ─── */
.app {
  height: 100vh; width: 100%;
  display: grid;
  grid-template-rows: 100vh;
  overflow: hidden;
}
.app.with-sidebar {
  grid-template-columns: 244px 1fr;
}
.app-main {
  display: grid;
  grid-template-rows: 49px 1fr;
  overflow: hidden;
  min-width: 0;
}
.scroll-area { overflow: auto; }

/* ─── Sidebar ─── */
.sidebar {
  background: var(--sidebar-background);
  border-right: 1px solid var(--sidebar-border);
  display: flex; flex-direction: column;
  overflow: hidden;
  min-width: 0;
}
.sb-head {
  padding: 14px 16px 12px;
  display: flex; align-items: center; gap: 12px;
  border-bottom: 1px solid var(--sidebar-border);
}
.sb-head img { width: 72px; height: 72px; object-fit: contain; flex-shrink: 0; }
.sb-brand { display: flex; flex-direction: column; min-width: 0; }
.sb-brand-name { font: 700 18px/1.1 var(--font-sans); color: var(--sidebar-foreground); letter-spacing: -0.005em; }
.sb-group { padding: 12px 8px 4px; }
.sb-label {
  font: 600 11px/1 var(--font-sans);
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--smoke);
  padding: 4px 12px 8px;
}
.sb-item {
  display: flex; align-items: center; gap: 10px;
  height: 34px; width: 100%;
  padding: 0 12px; border-radius: 8px;
  font: 500 14px/1 var(--font-sans);
  color: var(--sidebar-foreground);
  background: transparent; border: 0;
  cursor: pointer; transition: background .14s ease, color .14s ease;
  text-align: left;
}
.sb-item:hover { background: var(--muted); }
.sb-item.active { background: var(--sidebar-accent); color: var(--sidebar-accent-foreground); font-weight: 600; }
.sb-item.active svg { color: var(--ufs-orange); }
.sb-item svg { color: var(--sidebar-foreground); flex-shrink: 0; }
.sb-spacer { flex: 1; }
.sb-foot {
  border-top: 1px solid var(--sidebar-border);
  padding: 10px 12px;
  display: flex; align-items: center; gap: 10px;
  background: transparent; border-left: 0; border-right: 0; border-bottom: 0;
  width: 100%; cursor: pointer;
  text-align: left;
}
.sb-foot:hover { background: var(--muted); }
.sb-who { display: flex; flex-direction: column; min-width: 0; }
.sb-name { font: 600 13px/1.2 var(--font-sans); color: var(--sidebar-foreground); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 130px; }
.sb-email { font: 400 12px/1.2 var(--font-display); font-style: normal; color: var(--smoke); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 130px; }

/* ─── Top bar ─── */
.topbar {
  background: var(--background);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 8px;
  padding: 0 20px;
  height: 49px;
}
.topbar .sep { width: 1px; height: 16px; background: var(--border); margin: 0 4px; }
.crumbs { display: flex; align-items: center; gap: 6px; }
.crumb { font: 500 13px/1 var(--font-sans); color: var(--foreground); }
.crumb.muted { color: var(--smoke); }
.crumb-sep { color: var(--smoke); }
.topbar-right { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.tb-search {
  display: flex; align-items: center; gap: 8px;
  height: 32px; min-width: 220px;
  padding: 0 10px;
  background: var(--muted);
  border: 1px solid transparent;
  border-radius: 6px;
  color: var(--smoke);
}
.tb-search:focus-within { border-color: var(--ufs-orange); background: var(--background); }
.tb-search input { flex: 1; border: 0; background: transparent; font-size: 13px; color: var(--foreground); }
.tb-search input::placeholder { color: var(--smoke); }
.tb-search kbd {
  font: 600 10px/1 var(--font-sans);
  padding: 3px 5px; border: 1px solid var(--border); border-radius: 3px;
  color: var(--smoke); background: var(--background);
}

/* ─── Top nav (alt) ─── */
/* ─── Locale chip ─── */
.locale-chip { position: relative; }
.chip-btn {
  display: inline-flex; align-items: center; gap: 8px;
  height: 32px; padding: 0 10px;
  background: var(--muted);
  border: 1px solid transparent;
  border-radius: 6px;
  font: 500 13px/1 var(--font-sans); color: var(--foreground);
}
.chip-btn:hover { background: var(--mushroom-100); }
[data-theme="dark"] .chip-btn:hover { background: #4a4366; }
.chip-btn .flag { font-size: 14px; line-height: 1; }
.chip-menu {
  position: absolute; right: 0; top: calc(100% + 6px);
  z-index: 50;
  width: 240px;
  background: var(--popover);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: var(--shadow-md);
  padding: 4px;
  display: flex; flex-direction: column; gap: 2px;
}
.chip-opt {
  display: flex; align-items: center; gap: 10px;
  background: transparent; border: 0;
  padding: 8px 10px; border-radius: 6px;
  text-align: left;
  color: var(--foreground);
}
.chip-opt:hover { background: var(--muted); }
.chip-opt.on { background: var(--accent); }
.chip-opt .flag { font-size: 18px; }
.opt-text { display: flex; flex-direction: column; flex: 1; min-width: 0; }
.opt-name { font: 600 13px/1.2 var(--font-sans); }
.opt-sub { font: 400 12px/1.2 var(--font-display); font-style: normal; color: var(--smoke); }

/* ─── Page chrome ─── */
.page { padding: 28px 40px 64px; max-width: 1400px; margin: 0 auto; }
.page-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 24px; margin-bottom: 28px;
}
.page-head h1 { margin: 4px 0 6px; }
.page-head .lead { color: var(--smoke); max-width: 620px; }
.head-actions { display: flex; gap: 8px; flex-shrink: 0; }
.section-h { display: flex; align-items: baseline; justify-content: space-between; margin: 24px 0 14px; }

/* ─── Stats ─── */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 28px; }
.stat { background: var(--card); border: 1px solid var(--border); border-radius: 12px; padding: 16px 18px; }
.stat-lab { font: 500 12px/1 var(--font-sans); color: var(--smoke); margin-bottom: 10px; }
.stat-val { font: 700 28px/1.05 var(--font-sans); letter-spacing: -0.012em; color: var(--foreground); font-feature-settings: "tnum"; }
.stat-delta { font: 600 12px/1 var(--font-sans); margin-top: 8px; display: inline-flex; align-items: center; gap: 4px; }
.stat-delta.up { color: #2e7d4f; }
.stat-delta.down { color: var(--destructive); }
.stat-delta.muted { color: var(--smoke); font-weight: 400; font-style: normal; font-family: var(--font-display); }

/* =========================================================
   ONBOARDING
   ========================================================= */
.ob-shell {
  height: 100vh; width: 100%;
  display: grid; grid-template-columns: 380px 1fr;
  background: var(--background);
}
.ob-side {
  background: linear-gradient(180deg, var(--squid-ink) 0%, #1a1530 100%);
  color: #fff;
  padding: 36px 32px;
  display: flex; flex-direction: column;
  position: relative;
  overflow: hidden;
}
.ob-side::before {
  content: ""; position: absolute; inset: -50% -30% auto auto;
  width: 80%; aspect-ratio: 1;
  background: radial-gradient(circle, rgba(255,90,0,0.18), transparent 60%);
  pointer-events: none;
}
.ob-brand { display: flex; flex-direction: column; align-items: flex-start; gap: 0; margin-bottom: auto; position: relative; }
.ob-brand img { width: 150px; height: auto; object-fit: contain; display: block; }
.ob-brand-name { font: 700 22px/1 var(--font-sans); letter-spacing: -0.01em; text-align: left; margin: 4px 0 0; }
.ob-tagline {
  font-family: var(--font-display); font-style: normal;
  font-size: 24px; line-height: 1.35;
  color: #fff;
  margin: 60px 0 32px;
  position: relative;
}
.ob-tagline::before {
  content: ""; display: block; width: 32px; height: 2px; background: var(--ufs-orange);
  margin-bottom: 16px;
}
.ob-steps { display: flex; flex-direction: column; gap: 4px; position: relative; }
.ob-step {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0;
  font: 500 14px/1 var(--font-sans);
  color: rgba(255,255,255,0.5);
}
.ob-step.on { color: #fff; }
.ob-step.done { color: rgba(255,255,255,0.75); }
.ob-step-dot {
  width: 24px; height: 24px; border-radius: 50%;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  display: inline-flex; align-items: center; justify-content: center;
  font: 600 11px/1 var(--font-sans);
}
.ob-step.on .ob-step-dot { background: var(--ufs-orange); border-color: var(--ufs-orange); color: #fff; }
.ob-step.done .ob-step-dot { background: rgba(255,255,255,0.15); border-color: transparent; }
.ob-foot { font: 400 13px/1 var(--font-display); font-style: normal; color: rgba(255,255,255,0.5); margin-top: 24px; position: relative; }

.ob-main {
  display: flex; flex-direction: column;
  padding: 36px 56px;
  overflow: auto;
  position: relative;
}
.ob-progress {
  display: flex; align-items: center; gap: 16px;
  margin-bottom: 32px; max-width: 720px;
}
.ob-progress .eyebrow { flex-shrink: 0; }
.ob-progress-bar { flex: 1; height: 4px; background: var(--mushroom-100); border-radius: 999px; overflow: hidden; }
.ob-progress-bar > div { height: 100%; background: var(--ufs-orange); transition: width .35s ease; }

.ob-content { max-width: 720px; flex: 1; }
.ob-h1 { font: 700 38px/1.1 var(--font-sans); letter-spacing: -0.014em; margin: 0 0 12px; }
.ob-lead { font-size: 18px; line-height: 1.5; color: var(--smoke); margin: 0 0 32px; }

.ob-markets { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.ob-market {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 12px; padding: 24px;
  display: flex; flex-direction: column; gap: 6px;
  cursor: pointer; transition: border-color .14s ease, background .14s ease;
  position: relative;
  text-align: left;
}
.ob-market:hover { border-color: var(--smoke); }
.ob-market.on { border-color: var(--ufs-orange); background: var(--accent); }
.ob-market-flag { font-size: 36px; line-height: 1; margin-bottom: 8px; }
.ob-market-name { font: 700 18px/1.2 var(--font-sans); }
.ob-market-sub { color: var(--smoke); font-size: 13px; }
.ob-market-check {
  position: absolute; top: 12px; right: 12px;
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--ufs-orange); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
}

.ob-note {
  margin-top: 24px;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 14px; border-radius: 8px;
  background: var(--accent);
  color: var(--squid-ink);
}
.ob-note span { font-size: 13px; }

.ob-form { display: flex; flex-direction: column; gap: 18px; max-width: 560px; }
.ob-field { display: flex; flex-direction: column; gap: 6px; }
.ob-field-label { font: 500 13px/1 var(--font-sans); color: var(--foreground); }
.ob-field input, .ob-field textarea {
  height: 40px; padding: 0 12px;
  background: var(--background);
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 14px;
}
.ob-field textarea { padding: 10px 12px; height: auto; resize: vertical; }
.ob-field input:focus, .ob-field textarea:focus {
  border-color: var(--ufs-orange);
  box-shadow: 0 0 0 3px var(--accent);
}
.ob-role-grid { display: flex; flex-wrap: wrap; gap: 6px; }
.ob-role {
  background: var(--muted); border: 1px solid var(--border);
  height: 36px; padding: 0 14px; border-radius: 999px;
  font: 500 13px/1 var(--font-sans); color: var(--foreground);
}
.ob-role:hover { background: var(--secondary); }
.ob-role.on { background: var(--squid-ink); color: #fff; border-color: var(--squid-ink); }
[data-theme="dark"] .ob-role.on { background: var(--ufs-orange); border-color: var(--ufs-orange); }

.ob-socials { display: flex; flex-direction: column; gap: 10px; max-width: 560px; }
.ob-social {
  display: flex; align-items: center; gap: 12px;
  padding: 6px 14px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 8px;
}
.ob-social svg { color: var(--smoke); flex-shrink: 0; }
.ob-social input {
  flex: 1; border: 0; background: transparent;
  height: 40px; font-size: 14px;
}
.ob-social-name {
  font: 500 12px/1 var(--font-sans); color: var(--smoke);
  padding-left: 12px; border-left: 1px solid var(--border);
}

.ob-goals { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; max-width: 720px; }
.ob-goal {
  display: flex; align-items: center; gap: 14px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; padding: 14px 18px;
  text-align: left; color: var(--foreground);
}
.ob-goal:hover { border-color: var(--smoke); }
.ob-goal.on { border-color: var(--ufs-orange); background: var(--accent); }
.ob-goal-icon {
  width: 36px; height: 36px; border-radius: 8px;
  background: var(--muted);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--squid-ink); flex-shrink: 0;
}
.ob-goal.on .ob-goal-icon { background: var(--ufs-orange); color: #fff; }
.ob-goal span { flex: 1; font: 500 15px/1 var(--font-sans); }
.ob-goal-check {
  width: 20px; height: 20px; border-radius: 50%;
  border: 1px solid var(--border);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.ob-goal.on .ob-goal-check { background: var(--ufs-orange); border-color: var(--ufs-orange); color: #fff; }

.ob-welcome { text-align: left; max-width: 600px; padding-top: 8px; }
.ob-welcome-header {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 32px;
}
.ob-welcome-header .eyebrow {
  font-size: 14px;
}
.ob-welcome-art {
  position: relative;
  width: 90px; height: 90px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--ufs-orange) 0%, var(--ufs-orange-warm) 100%);
  display: inline-flex; align-items: center; justify-content: center;
  color: #fff;
  flex-shrink: 0;
}
.ob-confetti { position: absolute; inset: -20px; pointer-events: none; }
.ob-confetti span {
  position: absolute; width: 6px; height: 6px; border-radius: 2px;
}
.ob-confetti span:nth-child(1) { background: var(--pillar-roots-primary); top: 0; left: 50%; transform: rotate(20deg); }
.ob-confetti span:nth-child(2) { background: var(--pillar-streetfood-primary); top: 30%; right: 0; }
.ob-confetti span:nth-child(3) { background: var(--pillar-borderless-primary); bottom: 10%; right: 20%; transform: rotate(45deg); }
.ob-confetti span:nth-child(4) { background: var(--pillar-diner-primary); bottom: 20%; left: 0; }
.ob-confetti span:nth-child(5) { background: var(--ufs-orange); top: 20%; left: 0; transform: rotate(45deg); }

.ob-summary {
  margin: 28px 0 24px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 12px; padding: 4px 20px;
}
.ob-summary-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 0; border-bottom: 1px solid var(--border);
  gap: 16px;
}
.ob-summary-row:last-child { border-bottom: 0; }
.ob-summary-label { font: 500 13px/1.4 var(--font-sans); color: var(--smoke); }
.ob-summary-value { font: 500 14px/1.4 var(--font-sans); color: var(--foreground); text-align: right; }

.ob-starter { margin-top: 8px; }
.ob-starter-head { display: flex; align-items: baseline; gap: 8px; margin-bottom: 10px; }

.ob-video { max-width: 600px; }
.ob-video-hero { margin-bottom: 24px; }
.ob-video-poster {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  aspect-ratio: 16/9;
  background: linear-gradient(135deg, var(--ufs-orange) 0%, var(--ufs-orange-warm) 100%);
  cursor: pointer;
}
.ob-video-poster img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.ob-video-play {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
.ob-video-ring {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: rgba(255,255,255,0.95);
  color: var(--squid-ink);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 32px rgba(0,0,0,0.25);
  transition: transform .15s ease, box-shadow .15s ease;
}
.ob-video-poster:hover .ob-video-ring {
  transform: scale(1.08);
  box-shadow: 0 12px 40px rgba(0,0,0,0.35);
}
.ob-video-play-label {
  font: 600 12px/1 var(--font-sans);
  color: #fff;
  text-shadow: 0 2px 8px rgba(0,0,0,0.5);
}
.ob-video-copy { display: flex; flex-direction: column; gap: 8px; }
.ob-starter-card {
  display: grid; grid-template-columns: 80px 1fr;
  gap: 16px; align-items: center;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; padding: 10px;
}
.ob-starter-cover { aspect-ratio: 1; border-radius: 8px; }
.ob-starter-title { font: 700 16px/1.3 var(--font-sans); margin-bottom: 2px; }

.ob-actions {
  margin-top: 32px;
  display: flex; align-items: center; gap: 16px;
  max-width: 720px;
  padding-top: 24px; border-top: 1px solid var(--border);
}
.ob-dots { display: flex; gap: 6px; flex: 1; justify-content: center; }
.ob-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--mushroom); transition: background .14s ease, width .14s ease; }
.ob-dot.on { background: var(--ufs-orange); width: 18px; border-radius: 999px; }

/* =========================================================
   DASHBOARD
   ========================================================= */
.page-dash { padding-top: 24px; }
.dash-hero {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 28px 32px;
  margin-bottom: 24px;
  display: grid; grid-template-columns: 1fr auto;
  gap: 24px; align-items: center;
  position: relative; overflow: hidden;
}
.dash-hero::before {
  content: ""; position: absolute; right: -10%; top: -50%;
  width: 380px; aspect-ratio: 1; border-radius: 50%;
  background: radial-gradient(circle, var(--accent), transparent 70%);
  opacity: 0.6; pointer-events: none;
}
.dash-greet { font: 700 32px/1.1 var(--font-sans); letter-spacing: -0.014em; margin: 8px 0 6px; position: relative; }
.dash-sub { font-size: 16px; max-width: 560px; color: var(--smoke); margin: 0 0 18px; position: relative; }
.dash-actions { display: flex; gap: 8px; position: relative; }
.dash-hero-right { position: relative; }

.dash-streak {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 22px;
  background: var(--squid-ink); color: #fff;
  border-radius: 12px;
}
.streak-icon {
  width: 44px; height: 44px; border-radius: 10px;
  background: var(--ufs-orange);
  display: inline-flex; align-items: center; justify-content: center;
}
.streak-num { font: 700 28px/1 var(--font-sans); letter-spacing: -0.014em; font-feature-settings: "tnum"; }
.streak-lab { font: 400 13px/1.1 var(--font-display); font-style: normal; color: rgba(255,255,255,0.7); margin-top: 2px; }

.dash-row {
  display: grid; grid-template-columns: 1fr 380px; gap: 28px;
}

.continue-card {
  display: grid; grid-template-columns: 240px 1fr 36px;
  gap: 20px; align-items: stretch;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 14px; padding: 0;
  text-align: left; cursor: pointer;
  transition: box-shadow .14s ease, border-color .14s ease;
  width: 100%; overflow: hidden;
  margin-bottom: 16px;
}
.continue-card:hover { box-shadow: var(--shadow-md); border-color: var(--smoke); }
.continue-cover {
  position: relative;
  background: linear-gradient(135deg, var(--ufs-orange) 0%, var(--ufs-orange-warm) 100%);  min-height: 150px;
  overflow: hidden;
}
.continue-cover > * { position: relative; z-index: 1; }
.continue-cover > img { position: absolute; z-index: 0; }
.continue-play {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: 56px; height: 56px; border-radius: 50%;
  background: rgba(255,255,255,0.95); color: var(--squid-ink);
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: var(--shadow-md);
}
.continue-cc {
  position: absolute; bottom: 12px; left: 12px;
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 8px;
  background: rgba(0,0,0,0.55); color: #fff;
  font: 600 10px/1 var(--font-sans);
  border-radius: 4px;
}
.continue-body { padding: 20px 0; display: flex; flex-direction: column; justify-content: center; gap: 6px; min-width: 0; }
.continue-meta { display: flex; align-items: center; gap: 8px; }
.continue-title { font: 700 18px/1.3 var(--font-sans); letter-spacing: -0.005em; }
.continue-course { font: 400 13px/1.4 var(--font-display); font-style: normal; color: var(--smoke); }
.continue-progress { display: flex; align-items: center; gap: 10px; margin-top: 8px; }
.continue-go { display: flex; align-items: center; padding-right: 20px; color: var(--smoke); }

.cp-bar { flex: 1; height: 6px; background: var(--mushroom-100); border-radius: 999px; overflow: hidden; }
.cp-bar > div { height: 100%; background: var(--ufs-orange); transition: width .35s ease; }
.cp-bar.light { background: rgba(255,255,255,0.3); }
.cp-bar.light > div { background: #fff; }

.dash-mini-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.mini-course {
  display: grid; grid-template-columns: 70px 1fr;
  gap: 12px; align-items: center;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; padding: 10px;
  text-align: left; cursor: pointer;
  transition: border-color .14s ease;
}
.mini-course:hover { border-color: var(--smoke); }
.mini-cover { aspect-ratio: 1; border-radius: 8px; width: 70px; height: 70px; object-fit: cover; }
.mini-body { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.mini-title { font: 600 14px/1.3 var(--font-sans); }
.mini-bar { height: 4px; background: var(--mushroom-100); border-radius: 999px; overflow: hidden; margin-top: 4px; }
.mini-bar > div { height: 100%; background: var(--ufs-orange); }

.brief-mini-list { display: flex; flex-direction: column; gap: 8px; }
.brief-mini {
  display: grid; grid-template-columns: 4px 1fr;
  gap: 14px; align-items: stretch;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; padding: 0;
  text-align: left; cursor: pointer;
  transition: border-color .14s ease, box-shadow .14s ease;
  overflow: hidden;
}
.brief-mini:hover { border-color: var(--smoke); box-shadow: var(--shadow-sm); }
.brief-mini-stripe { width: 4px; }
.brief-mini-body { padding: 12px 14px 12px 0; display: flex; flex-direction: column; gap: 4px; }
.brief-mini-brand { font: 600 11px/1 var(--font-sans); color: var(--smoke); letter-spacing: 0.04em; text-transform: uppercase; }
.brief-mini-title { font: 600 14px/1.3 var(--font-sans); }
.brief-mini-meta { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--smoke); flex-wrap: wrap; }
.brief-mini-meta .brief-pill { font-size: 10px; padding: 3px 6px; border-radius: 999px; font-weight: 600; }
.brief-payout { margin-left: auto; font: 700 13px/1 var(--font-sans); color: var(--ufs-orange); }

.community-list { display: flex; flex-direction: column; gap: 4px; }
.comm-item { display: flex; align-items: center; gap: 10px; padding: 8px 4px; }
.comm-body { flex: 1; min-width: 0; }
.comm-line { display: flex; align-items: baseline; gap: 6px; }
.comm-name { font: 600 13px/1 var(--font-sans); }
.comm-time { font-size: 12px; flex-shrink: 0; }

/* =========================================================
   COURSES
   ========================================================= */
.featured-path {
  display: grid; grid-template-columns: 1fr 1.2fr;
  gap: 0;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 14px;
  margin-bottom: 32px;
  overflow: hidden;
}
.featured-cover {
  position: relative; min-height: 280px;
  display: flex; align-items: flex-end;
  padding: 28px;
  overflow: hidden;
}
.featured-cover > * { position: relative; z-index: 1; }
.featured-cover > img { position: absolute; z-index: 0; }
.featured-cover-inner { color: #fff; max-width: 360px; }
.featured-cover-inner .featured-h { font: 700 28px/1.15 var(--font-sans); letter-spacing: -0.012em; margin-top: 8px; }
.featured-meta { padding: 32px 36px; display: flex; flex-direction: column; gap: 12px; justify-content: center; }
.featured-pill {
  display: inline-flex; align-self: flex-start;
  font: 400 14px/1 var(--font-display); font-style: normal;
  color: var(--ufs-orange);
}
.featured-stats { display: flex; gap: 32px; padding: 16px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); margin: 8px 0; }
.fs-item { display: flex; flex-direction: column; gap: 4px; }
.fs-val { font: 700 22px/1 var(--font-sans); letter-spacing: -0.01em; font-feature-settings: "tnum"; }
.fs-lab { font: 400 12px/1 var(--font-display); font-style: normal; color: var(--smoke); text-transform: lowercase; }

.track-tabs {
  display: inline-flex; padding: 4px;
  background: var(--muted); border-radius: 8px;
  gap: 2px; margin-bottom: 20px;
}
.track-tab {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 14px; border-radius: 6px;
  background: transparent; border: 0;
  font: 500 13px/1 var(--font-sans); color: var(--smoke);
}
.track-tab.on { background: var(--background); color: var(--foreground); box-shadow: var(--shadow-sm); font-weight: 600; }
.track-tab .count {
  font: 600 10px/1 var(--font-sans);
  background: var(--mushroom-100);
  color: var(--smoke);
  padding: 3px 6px; border-radius: 999px;
}
.track-tab.on .count { background: var(--accent); color: var(--ufs-orange); }

.course-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }

/* =========================================================
   V2 · Module cards = V1 course cards, with status overrides
   ========================================================= */
.mod-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
@media (max-width: 1280px) { .mod-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 720px)  { .mod-grid { grid-template-columns: 1fr; } }
.mod-grid-dash { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 980px) { .mod-grid-dash { grid-template-columns: 1fr; } }

.course-card.mod-as-course.is-locked {
  cursor: pointer;
}
.course-card.mod-as-course.is-locked .course-cta {
  color: var(--mushroom);
}
.course-card.mod-as-course.is-current {
  border-color: var(--ufs-orange);
  box-shadow: 0 0 0 1px var(--ufs-orange) inset, 0 4px 14px rgba(204,68,0,0.10);
}


.course-card {
  display: flex; flex-direction: column;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 14px; padding: 0;
  text-align: left; cursor: pointer;
  transition: box-shadow .14s ease, border-color .14s ease, transform .14s ease;
  overflow: hidden;
}
.course-card:hover { box-shadow: var(--shadow-md); border-color: var(--smoke); }
.course-cover {
  position: relative; aspect-ratio: 16/9;
  overflow: hidden;
}
.course-cover > * { position: relative; z-index: 1; }
.course-cover > img { position: absolute; z-index: 0; }
.course-pillar-tag {
  position: absolute; top: 12px; left: 12px;
  font: 600 10px/1 var(--font-sans); letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 5px 10px; border-radius: 4px;
}
.course-cover-prog { position: absolute; bottom: 0; left: 0; right: 0; padding: 12px; }
.course-done {
  position: absolute; top: 12px; right: 12px;
  display: inline-flex; align-items: center; gap: 4px;
  background: rgba(0,0,0,0.55); color: #fff;
  font: 600 10px/1 var(--font-sans); letter-spacing: 0.04em;
  padding: 5px 8px; border-radius: 4px;
}
.course-body { padding: 16px 18px 18px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.course-instructor { font-size: 12px; color: var(--smoke); }
.course-title { font: 700 17px/1.3 var(--font-sans); letter-spacing: -0.005em; }
.course-desc { font-size: 13px; line-height: 1.5; flex: 1; }
.course-meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; font: 500 12px/1 var(--font-sans); color: var(--smoke); margin-top: 4px; }
.course-meta-item { display: inline-flex; align-items: center; gap: 4px; }
.course-dot { width: 3px; height: 3px; border-radius: 50%; background: var(--mushroom); }
.course-footer { display: flex; align-items: center; justify-content: space-between; padding-top: 10px; margin-top: 4px; border-top: 1px solid var(--border); }
.course-cta {
  display: inline-flex; align-items: center; gap: 4px;
  font: 600 13px/1 var(--font-sans); color: var(--ufs-orange);
}
.course-cta.on { color: var(--squid-ink); }
[data-theme="dark"] .course-cta.on { color: var(--salt); }

/* =========================================================
   PLAYER
   ========================================================= */
.page-player { padding: 16px 32px 64px; max-width: 1500px; }
.player-crumbs { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; }
.player-grid { display: grid; grid-template-columns: 1fr 380px; gap: 24px; align-items: start; }
.player-main { display: flex; flex-direction: column; gap: 24px; min-width: 0; }
.video-frame { background: var(--card); border: 1px solid var(--border); border-radius: 14px; overflow: hidden; }
.video-stage {
  position: relative;
  aspect-ratio: 16/9;
  background: #0a0815;
  overflow: hidden;
}
.video-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 30% 40%, rgba(255,140,60,0.4), transparent 50%),
    radial-gradient(ellipse at 70% 60%, rgba(220,77,139,0.25), transparent 60%),
    radial-gradient(ellipse at 50% 80%, rgba(255,90,0,0.3), transparent 60%),
    linear-gradient(135deg, #1a0f06, #2a1a0e, #1a0815);
}
.video-bg::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(45deg, rgba(255,255,255,0.02) 0 2px, transparent 2px 8px);
  mix-blend-mode: overlay;
}
.video-vignette {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,0.5) 100%);
  pointer-events: none;
}
.video-overlay-text {
  position: absolute; left: 32px; bottom: 96px;
  color: #fff;
  max-width: 60%;
  pointer-events: none;
}
.vot-eyebrow { font: 400 14px/1 var(--font-display); font-style: normal; color: rgba(255,255,255,0.75); margin-bottom: 8px; }
.vot-h { font: 700 28px/1.15 var(--font-sans); letter-spacing: -0.012em; }
.vot-instructor { font: 400 13px/1 var(--font-display); font-style: normal; color: rgba(255,255,255,0.55); margin-top: 8px; }

.video-caption {
  position: absolute; left: 50%; bottom: 32px;
  transform: translateX(-50%);
  max-width: 75%;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
}
.vc-pill {
  display: inline-flex; align-items: center; gap: 4px;
  font: 600 10px/1 var(--font-sans);
  padding: 4px 8px;
  background: rgba(0,0,0,0.6); color: rgba(255,255,255,0.95);
  border-radius: 999px;
}
.vc-line {
  font: 700 19px/1.4 var(--font-sans); letter-spacing: -0.005em;
  text-align: center;
  background: rgba(0,0,0,0.78); color: #fff;
  padding: 8px 18px; border-radius: 4px;
  text-shadow: 0 2px 6px rgba(0,0,0,0.4);
}
.video-play-big {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: 88px; height: 88px; border-radius: 50%;
  background: rgba(255,255,255,0.94);
  border: 0; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--squid-ink);
  box-shadow: var(--shadow-lg);
}

.video-controls { padding: 14px 16px; background: var(--card); }
.vc-scrub { position: relative; height: 24px; cursor: pointer; display: flex; align-items: center; padding: 0 6px; }
.vc-track { width: 100%; height: 4px; background: var(--mushroom-100); border-radius: 999px; overflow: hidden; }
.vc-progress { height: 100%; background: var(--ufs-orange); transition: width .3s linear; }
.vc-thumb {
  position: absolute; top: 50%; transform: translate(-50%, -50%);
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--ufs-orange); border: 2px solid var(--card);
  pointer-events: none;
  transition: left .3s linear;
}
.vc-tick {
  position: absolute; top: 50%; transform: translate(-50%, -50%);
  width: 2px; height: 8px; background: var(--smoke);
  z-index: 1; opacity: 0.6;
}
.vc-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 6px; }
.vc-row-l, .vc-row-r { display: flex; align-items: center; gap: 4px; }
.vc-time { font: 600 12px/1 var(--font-sans); color: var(--foreground); margin-left: 8px; font-feature-settings: "tnum"; }
.vc-btn {
  display: inline-flex; align-items: center; gap: 5px;
  height: 28px; padding: 0 8px;
  background: transparent; border: 0;
  font: 500 12px/1 var(--font-sans); color: var(--foreground);
  border-radius: 5px;
}
.vc-btn:hover { background: var(--muted); }
.vc-btn .flag { font-size: 12px; }

.cc-menu { position: relative; }
.cc-pop {
  position: absolute; right: 0; bottom: calc(100% + 4px);
  z-index: 30;
  min-width: 200px;
  background: var(--popover);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: var(--shadow-md);
  padding: 4px;
  display: flex; flex-direction: column; gap: 2px;
}
.cc-pop.sm { min-width: 100px; }
.cc-opt {
  display: flex; align-items: center; gap: 10px;
  background: transparent; border: 0;
  padding: 7px 10px; border-radius: 5px;
  text-align: left; font: 500 13px/1.2 var(--font-sans);
  color: var(--foreground);
}
.cc-opt:hover { background: var(--muted); }
.cc-opt.on { background: var(--accent); }
.cc-opt .flag { font-size: 16px; }

.player-meta {
  display: grid; grid-template-columns: 1fr auto; gap: 16px;
  align-items: end;
  padding: 4px 0 8px;
}
.player-meta-text { min-width: 0; max-width: 100%; }
.player-meta-actions { display: flex; gap: 8px; }
.player-title { font: 700 24px/1.2 var(--font-sans); letter-spacing: -0.01em; margin: 10px 0 0; }

.player-applybar {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 18px;
  background: var(--accent);
  border: 1px solid #ffd6bb;
  border-radius: 12px;
}
[data-theme="dark"] .player-applybar { border-color: var(--ufs-orange); }
.applybar-h { font: 700 14px/1.3 var(--font-sans); }

/* Player side panel — static, no sticky/scroll follow */
.player-side {
  display: flex; flex-direction: column;
  gap: 16px;
  align-self: start;
}
.player-side-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 14px; overflow: hidden;
  display: flex; flex-direction: column;
  flex-shrink: 0;
}
.side-tabs { display: grid; grid-template-columns: repeat(3, 1fr); border-bottom: 1px solid var(--border); }
.side-tab {
  display: inline-flex; align-items: center; justify-content: center; gap: 5px;
  background: transparent; border: 0;
  padding: 12px 6px;
  font: 500 12px/1 var(--font-sans); color: var(--smoke);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.side-tab:hover { background: var(--muted); color: var(--foreground); }
.side-tab.on { color: var(--ufs-orange); border-bottom-color: var(--ufs-orange); font-weight: 600; }
.side-content { max-height: 520px; overflow: auto; padding: 14px; }

.tr-scroll { max-height: calc(100vh - 260px); overflow-y: auto; padding-right: 4px; }
.tr-list { display: flex; flex-direction: column; gap: 4px; }
.tr-line {
  display: grid; grid-template-columns: 48px 1fr;
  gap: 10px; align-items: start;
  background: transparent; border: 0;
  padding: 8px 10px; border-radius: 6px;
  text-align: left; cursor: pointer;
  transition: background .14s ease;
}
.tr-line:hover { background: var(--muted); }
.tr-line.active { background: var(--accent); }
.tr-line.active .tr-text { color: var(--foreground); font-weight: 500; }
.tr-time {
  font: 600 11px/1.5 var(--font-sans);
  color: var(--ufs-orange);
  font-feature-settings: "tnum";
  padding-top: 1px;
}
.tr-text { font: 400 13px/1.55 var(--font-sans); color: var(--foreground); }

.ch-list { display: flex; flex-direction: column; gap: 4px; }
.ch-item {
  display: grid; grid-template-columns: 28px 1fr;
  gap: 12px; align-items: center;
  background: transparent; border: 0;
  padding: 10px 10px; border-radius: 8px;
  text-align: left;
  transition: background .14s ease;
  position: relative;
}
.ch-item:hover { background: var(--muted); }
.ch-item.on { background: var(--accent); }
.ch-num {
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--mushroom-100);
  display: inline-flex; align-items: center; justify-content: center;
  font: 600 12px/1 var(--font-sans); color: var(--squid-ink);
}
.ch-item.done .ch-num { background: var(--squid-ink); color: #fff; }
.ch-item.on .ch-num { background: var(--ufs-orange); color: #fff; }
.ch-title { font: 500 13.5px/1.35 var(--font-sans); }
.ch-item.on .ch-title { font-weight: 600; }

.notes-panel { display: flex; flex-direction: column; gap: 14px; }
.note-input {
  display: grid; grid-template-columns: auto 1fr auto;
  gap: 8px; align-items: start;
  padding: 10px;
  background: var(--muted);
  border-radius: 8px;
}
.note-input svg { margin-top: 8px; }
.note-input textarea {
  border: 0; background: transparent;
  font: 400 13px/1.5 var(--font-sans);
  resize: none; padding: 6px 0;
}
.note-saved-h { display: flex; align-items: baseline; justify-content: space-between; }
.notes-list { display: flex; flex-direction: column; gap: 6px; }
.note {
  display: grid; grid-template-columns: 48px 1fr 24px;
  gap: 10px; align-items: start;
  padding: 10px; border: 1px solid var(--border); border-radius: 8px;
  background: var(--background);
}
.note-time {
  font: 600 11px/1.4 var(--font-sans);
  color: var(--ufs-orange); font-feature-settings: "tnum";
  background: var(--accent); border: 0;
  padding: 4px 6px; border-radius: 4px;
  cursor: pointer;
  align-self: start;
}
.note-text { font: 400 13px/1.5 var(--font-sans); }
.note-x {
  background: transparent; border: 0; color: var(--smoke);
  width: 24px; height: 24px; border-radius: 4px;
  display: inline-flex; align-items: center; justify-content: center;
}
.note-x:hover { background: var(--muted); color: var(--destructive); }

.res-list { display: flex; flex-direction: column; gap: 6px; }

.player-resources {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 14px;
}
.player-resources-head { margin-bottom: 10px; }
.res-row {
  display: grid; grid-template-columns: 36px 1fr auto;
  gap: 12px; align-items: center;
  padding: 10px;
  border: 1px solid var(--border); border-radius: 8px;
  background: var(--background);
}
.res-icon {
  width: 36px; height: 36px; border-radius: 8px;
  background: var(--muted);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--squid-ink);
}
[data-theme="dark"] .res-icon { color: var(--salt); }
.res-name { font: 600 13px/1.3 var(--font-sans); }

/* =========================================================
   BRIEFS
   ========================================================= */
.brief-featured {
  display: grid; grid-template-columns: 1.1fr 1fr;
  margin-bottom: 32px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 14px; overflow: hidden;
}
.brief-featured-cover {
  padding: 28px 32px;
  display: flex; flex-direction: column; gap: 8px; justify-content: flex-end;
  color: #fff; min-height: 280px;
  position: relative;
}
.brief-featured-cover > * { position: relative; z-index: 1; }
.brief-featured-cover > img { position: absolute; z-index: 0; }
.brief-featured-cover::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 30%, rgba(0,0,0,0.3));
  pointer-events: none;
}
.bf-brand { font: 600 13px/1 var(--font-sans); color: rgba(255,255,255,0.8); position: relative; }
.bf-title { font: 700 28px/1.15 var(--font-sans); letter-spacing: -0.012em; max-width: 360px; position: relative; }
.brief-featured-meta { padding: 32px 36px; display: flex; flex-direction: column; gap: 16px; justify-content: center; }
.brief-featured-stats {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  padding: 16px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.brief-stat { display: flex; flex-direction: column; gap: 2px; }
.brief-stat-label { font: 500 11px/1 var(--font-sans); color: var(--smoke); text-transform: uppercase; letter-spacing: 0.04em; }
.brief-stat-value { font: 700 18px/1.2 var(--font-sans); }
.brief-stat.high .brief-stat-value { color: var(--ufs-orange); font-size: 22px; }

.brief-filters {
  display: flex; flex-direction: column; gap: 12px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 24px;
}
.bf-group { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.bf-group-label { font: 600 11px/1 var(--font-sans); letter-spacing: 0.04em; text-transform: uppercase; color: var(--smoke); min-width: 70px; }
.bf-pills { display: flex; gap: 6px; flex-wrap: wrap; }
.filter-pill {
  height: 30px; padding: 0 12px; border-radius: 999px;
  background: var(--background); border: 1px solid var(--border);
  font: 500 12px/1 var(--font-sans); color: var(--foreground);
  display: inline-flex; align-items: center; gap: 4px;
}
.filter-pill:hover { background: var(--muted); }
.filter-pill.on { background: var(--squid-ink); color: #fff; border-color: var(--squid-ink); }

.brief-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.brief-card {
  display: grid; grid-template-columns: 6px 1fr;
  grid-template-rows: auto auto;
  background: var(--card); border: 1px solid var(--border);
  border-left: 0;
  border-radius: 12px;
  text-align: left; cursor: pointer;
  overflow: hidden;
  transition: box-shadow .14s ease, border-color .14s ease;
  padding: 0; margin: 0;
}
.brief-card:hover { box-shadow: var(--shadow-md); border-color: var(--smoke); }
.brief-card-stripe {
  grid-row: 1 / -1;
  width: 6px;
}
.brief-card-cover {
  grid-column: 2 / -1;
  grid-row: 1;
  height: 140px;
  position: relative;
  overflow: hidden;
  border-top-right-radius: 11px;
}
.brief-card-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-top-right-radius: 11px;
}
.brief-card-body {
  grid-column: 2 / -1;
  grid-row: 2;
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.brief-card-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.brief-card-brand { font: 600 12px/1 var(--font-sans); color: var(--smoke); letter-spacing: 0.04em; text-transform: uppercase; }
.brief-card-title { font: 700 17px/1.3 var(--font-sans); letter-spacing: -0.005em; }
.brief-card-desc { font-size: 13px; line-height: 1.55; }
.brief-card-markets { display: flex; align-items: center; gap: 6px; font-size: 12px; }
.brief-card-markets .m-flag { font-size: 14px; }
.brief-card-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding-top: 10px; border-top: 1px solid var(--border); margin-top: 4px; }
.brief-card-payout { font: 700 18px/1 var(--font-sans); color: var(--ufs-orange); letter-spacing: -0.01em; }
.brief-card-meta { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--smoke); }
.brief-deadline { display: inline-flex; align-items: center; gap: 3px; font-weight: 500; }
.brief-deadline.urgent { color: var(--destructive); font-weight: 600; }
.brief-pill {
  display: inline-flex; align-items: center;
  font: 600 10px/1 var(--font-sans); letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 4px 8px; border-radius: 4px;
  white-space: nowrap;
}

.brief-card.list { grid-template-columns: 6px 1fr; }
/* Brief detail */
.page-brief-detail { padding-top: 16px; }
.brief-detail-grid { display: grid; grid-template-columns: 1fr 360px; gap: 32px; align-items: start; }
.brief-detail-main { display: flex; flex-direction: column; gap: 28px; }
.brief-detail-hero {
  border-radius: 14px; padding: 32px 36px; color: #fff;
  display: flex; flex-direction: column; gap: 10px; align-items: flex-start;
  min-height: 240px; justify-content: flex-end;
  position: relative;
}
.bdh-brand { font: 600 13px/1 var(--font-sans); color: rgba(255,255,255,0.8); }
.bdh-title { font: 700 32px/1.1 var(--font-sans); letter-spacing: -0.014em; max-width: 600px; margin: 0; }
.bdh-markets { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }
.bdh-market {
  background: rgba(255,255,255,0.18);
  font: 500 12px/1 var(--font-sans);
  padding: 6px 10px; border-radius: 999px;
}
.brief-block { display: flex; flex-direction: column; gap: 8px; }
.brief-block .lead { line-height: 1.6; max-width: 720px; color: var(--smoke); font-size: 16px; }
.brief-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.brief-list li { display: flex; align-items: center; gap: 10px; font: 400 14px/1.5 var(--font-sans); }
.dos-dont { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.dos, .donts { padding: 16px 18px; border: 1px solid var(--border); border-radius: 10px; background: var(--card); }
.dd-h { display: flex; align-items: center; gap: 6px; font: 700 13px/1 var(--font-sans); margin-bottom: 8px; }
.dos .dd-h { color: #2e7d4f; }
.donts .dd-h { color: var(--destructive); }
.dos ul, .donts ul { list-style: none; margin: 0; padding-left: 0; display: flex; flex-direction: column; gap: 4px; font-size: 13px; line-height: 1.5; }
.dos ul li, .donts ul li { padding-left: 12px; position: relative; color: var(--foreground); }
.dos ul li::before { content: "·"; color: #2e7d4f; position: absolute; left: 4px; font-weight: 800; }
.donts ul li::before { content: "·"; color: var(--destructive); position: absolute; left: 4px; font-weight: 800; }

.rec-mods { display: flex; flex-direction: column; gap: 8px; }
.rec-mod { display: flex; align-items: center; gap: 12px; padding: 10px; border: 1px solid var(--border); border-radius: 10px; background: var(--card); }
.rec-mod-cover { width: 44px; height: 44px; border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.rec-mod-title { font: 600 14px/1.3 var(--font-sans); }

.brief-detail-side { display: flex; flex-direction: column; gap: 16px; position: sticky; top: 16px; }
.brief-side-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 14px; padding: 22px 22px;
  display: flex; flex-direction: column; gap: 14px;
}
.bsc-payout { padding-bottom: 12px; border-bottom: 1px solid var(--border); }
.bsc-amount { font: 700 36px/1 var(--font-sans); color: var(--ufs-orange); letter-spacing: -0.014em; margin: 6px 0 4px; font-feature-settings: "tnum"; }
.bsc-rows { display: flex; flex-direction: column; gap: 6px; padding-bottom: 4px; }
.bsc-row { display: flex; justify-content: space-between; padding: 4px 0; font-size: 13px; }
.bsc-row-val { font-weight: 600; }
.bsc-row-val.accent { color: var(--destructive); }
.bsc-note { font-size: 12px; color: var(--smoke); padding-top: 4px; border-top: 1px dashed var(--border); }

.recent-subs { display: flex; flex-direction: column; gap: 8px; }
.recent-sub {
  display: grid; grid-template-columns: auto 1fr 40px;
  gap: 10px; align-items: center;
}
.recent-sub-name { font: 600 13px/1.2 var(--font-sans); }
.rs-thumb { width: 40px; height: 40px; border-radius: 6px; }

/* Modal */
.modal-back { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 90;
  display: flex; align-items: center; justify-content: center; padding: 24px; }
.modal {
  background: var(--background); border: 1px solid var(--border);
  border-radius: 14px;
  width: min(640px, 100%); max-height: 90vh;
  display: flex; flex-direction: column;
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}
.modal-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; padding: 22px 24px 14px; border-bottom: 1px solid var(--border); }
.modal-progress { display: flex; padding: 14px 24px; gap: 24px; background: var(--muted); border-bottom: 1px solid var(--border); }
.mp-step { display: flex; align-items: center; gap: 8px; font: 500 13px/1 var(--font-sans); color: var(--smoke); }
.mp-step.on { color: var(--foreground); font-weight: 600; }
.mp-num { width: 22px; height: 22px; border-radius: 50%; background: var(--mushroom-100); color: var(--smoke); font: 600 11px/1 var(--font-sans); display: inline-flex; align-items: center; justify-content: center; }
.mp-step.on .mp-num { background: var(--ufs-orange); color: #fff; }
.modal-body { padding: 24px; flex: 1; overflow: auto; }
.modal-foot { padding: 14px 24px; border-top: 1px solid var(--border); display: flex; justify-content: space-between; align-items: center; }

.upload-zone {
  border: 2px dashed var(--border);
  border-radius: 12px;
  padding: 40px 24px;
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  cursor: pointer;
  transition: border-color .14s ease, background .14s ease;
  margin-bottom: 16px;
}
.upload-zone:hover { border-color: var(--ufs-orange); background: var(--accent); }
.upload-h { font: 600 16px/1.3 var(--font-sans); margin-top: 4px; }
.upload-checklist { display: flex; flex-direction: column; gap: 6px; }
.checklist { display: flex; align-items: center; gap: 8px; padding: 8px 0; font-size: 13px; color: var(--smoke); }
.checklist.on { color: var(--foreground); }
.cl-icon { width: 18px; height: 18px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: var(--muted); color: var(--smoke); }
.checklist.on .cl-icon { background: var(--ufs-orange); color: #fff; }

.cc-upload {
  display: flex; align-items: center; gap: 8px;
  height: 40px; padding: 0 12px;
  background: var(--background);
  border: 1px solid var(--border); border-radius: 6px;
  font-size: 13px;
}

.review-thumb { aspect-ratio: 16/9; border-radius: 12px; display: flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.review-rows { display: flex; flex-direction: column; }
.rev-row { display: flex; justify-content: space-between; padding: 12px 0; border-bottom: 1px solid var(--border); font-size: 13px; }
.rev-row:last-child { border-bottom: 0; }

/* Generic page placeholder for community/profile/settings/help */
.placeholder-page {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 60px 40px;
  text-align: center;
}
.placeholder-page h2 { margin-bottom: 8px; }
.placeholder-page p { color: var(--smoke); max-width: 480px; margin: 0 auto; }

/* Tweaks panel offset */
[data-tweaks-panel] { z-index: 80; }

/* ─────────────────────────────────────────────────────────
   V2 · Sequential modules (in courses)
   ───────────────────────────────────────────────────────── */
.seq-modules { margin-bottom: 32px; }
.seq-list {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
}
.seq-mod {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 16px;
  align-items: center;
  width: 100%;
  padding: 14px 18px;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--border);
  text-align: left;
  cursor: pointer;
  transition: background 150ms ease;
  font-family: inherit;
  color: inherit;
}
.seq-mod:last-child { border-bottom: 0; }
.seq-mod:hover:not(:disabled) { background: var(--mushroom-50); }
.seq-mod:disabled { cursor: not-allowed; opacity: 0.55; }
.seq-num {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--mushroom-100);
  color: var(--smoke);
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 600;
}
.seq-mod.done .seq-num { background: var(--ufs-orange); color: #fff; }
.seq-mod.current .seq-num { background: var(--squid-ink); color: #fff; }
.seq-mod.next .seq-num { background: var(--card); border: 1.5px solid var(--ufs-orange); color: var(--ufs-orange); }
.seq-title { font-weight: 600; font-size: 14px; margin-bottom: 2px; }
.seq-cta { color: var(--smoke); }

/* ─────────────────────────────────────────────────────────
   V2 · Private video chrome + watermark
   ───────────────────────────────────────────────────────── */
.video-frame.private { border-color: var(--squid-ink); }
.video-private-bar {
  display: flex; justify-content: space-between; align-items: center;
  background: var(--squid-ink); color: #fff;
  padding: 6px 14px;
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.video-private-bar .vpb-l, .video-private-bar .vpb-r { display: flex; align-items: center; gap: 6px; }
.video-private-bar .vpb-l { color: #fff; }
.video-private-bar .vpb-r { color: var(--mushroom); }
.video-watermark {
  position: absolute;
  bottom: 12px; right: 12px;
  z-index: 5;
  padding: 4px 8px;
  background: rgba(0,0,0,0.4);
  color: rgba(255,255,255,0.65);
  font-size: 10px; font-weight: 500;
  border-radius: 4px;
  letter-spacing: 0.02em;
  pointer-events: none;
  user-select: none;
}

/* ─────────────────────────────────────────────────────────
   V2 · Brief claim pills
   ───────────────────────────────────────────────────────── */
.claim-pill {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px;
  font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.05em;
  border-radius: 4px;
  margin-left: auto;
  white-space: nowrap;
}

/* Default / list-view colors (in card body head) */
.brief-card-head .claim-pill.claimed { background: #fff0e8; color: var(--ufs-orange); }
.brief-card-head .claim-pill.submitted { background: #e8f5ed; color: #679641; }

/* Cover overlay badge — grid view */
.brief-card-cover .claim-pill {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
  margin-left: 0;
  background: rgba(0,0,0,0.65);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.25);
  backdrop-filter: blur(4px);
}
.brief-card-cover .claim-pill.claimed { background: rgba(46, 125, 79, 0.9); }
.brief-card-cover .claim-pill.submitted { background: rgba(204, 68, 0, 0.9); }

/* ─────────────────────────────────────────────────────────
   V2 · Notification button + popover
   ───────────────────────────────────────────────────────── */
.notif-btn { position: relative; }
.notif-btn .dot-red {
  position: absolute; top: 6px; right: 6px;
  width: 8px; height: 8px;
  background: var(--ufs-orange);
  border: 2px solid var(--card);
  border-radius: 50%;
}
.notif-pop {
  position: fixed;
  top: 60px; right: 20px;
  width: 380px;
  max-height: 540px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 10px 24px rgba(15,23,42,.15);
  z-index: 90;
  display: flex; flex-direction: column;
  overflow: hidden;
}
.notif-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px; border-bottom: 1px solid var(--border);
}
.notif-list { overflow-y: auto; flex: 1; }
.notif {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 12px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  position: relative;
}
.notif.unread { background: rgba(255, 90, 0, 0.03); }
.notif:last-child { border-bottom: 0; }
.notif-icon {
  width: 32px; height: 32px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
}
.notif-title { font-weight: 600; font-size: 13px; margin-bottom: 2px; }
.notif-foot { display: flex; align-items: center; gap: 4px; margin-top: 4px; font-size: 11px; }
.notif-tag { font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; }
.notif-dot {
  width: 8px; height: 8px;
  background: var(--ufs-orange);
  border-radius: 50%;
  align-self: start;
  margin-top: 6px;
}
.notif-foot-bar {
  padding: 10px 16px;
  border-top: 1px solid var(--border);
  text-align: center;
}
.link-btn {
  background: transparent; border: 0; cursor: pointer;
  color: var(--ufs-orange);
  font-weight: 600; font-size: 12px;
  display: inline-flex; align-items: center; gap: 4px;
  font-family: inherit;
}

/* ─────────────────────────────────────────────────────────
   V2 · Rewards page
   ───────────────────────────────────────────────────────── */
.page-rewards .page-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 32px; gap: 24px; }
.rw-points {
  text-align: center;
  padding: 16px 24px;
  background: var(--ufs-orange);
  color: #fff;
  border-radius: 12px;
  min-width: 120px;
}
.rw-points-num { font-size: 36px; font-weight: 700; line-height: 1; }
.rw-points-lab { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; margin-top: 6px; opacity: 0.9; }

.rw-progress-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 24px;
  margin-bottom: 24px;
}
.rw-prog-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.rw-track {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 8px;
  position: relative;
}
.rw-track::before {
  content: ""; position: absolute;
  top: 14px; left: 14px; right: 14px;
  height: 2px;
  background: var(--mushroom-100);
  z-index: 0;
}
.rw-track-step { position: relative; z-index: 1; text-align: center; }
.rw-track-dot {
  width: 28px; height: 28px;
  margin: 0 auto 8px;
  background: var(--card);
  border: 2px solid var(--mushroom);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700;
  color: var(--smoke);
}
.rw-track-step.done .rw-track-dot {
  background: var(--ufs-orange);
  border-color: var(--ufs-orange);
  color: #fff;
}
.rw-track-lab { font-size: 11px; color: var(--smoke); }
.rw-track-step.done .rw-track-lab { color: var(--squid-ink); font-weight: 600; }

.rw-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 24px;
}
.rw-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 20px;
  position: relative;
  display: flex; flex-direction: column;
  transition: all 200ms ease;
}
.rw-card.unlocked { border-color: var(--ufs-orange); }
.rw-card.locked { opacity: 0.6; }
.rw-card-head { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; }
.rw-icon {
  width: 36px; height: 36px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  background: var(--mushroom-100);
  color: var(--squid-ink);
}
.rw-icon.physical { background: #fff0e8; color: var(--ufs-orange); }
.rw-tag {
  font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--smoke);
}
.rw-check {
  margin-left: auto;
  width: 22px; height: 22px;
  background: var(--ufs-orange); color: #fff;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.rw-card-title { font-weight: 700; font-size: 16px; margin-bottom: 6px; }
.rw-card-sub { font-size: 13px; line-height: 1.5; margin-bottom: 14px; flex: 1; }
.rw-card-foot {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 12px;
  border-top: 1px solid var(--border);
  font-size: 11px;
}
.rw-trigger { display: inline-flex; align-items: center; gap: 4px; color: var(--smoke); font-weight: 600; }
.rw-card.unlocked .rw-trigger { color: #679641; }
.rw-points-pill {
  background: var(--mushroom-100);
  color: var(--squid-ink);
  padding: 3px 8px;
  border-radius: 4px;
  font-weight: 700;
}
.rw-card.unlocked .rw-points-pill { background: #fff0e8; color: var(--ufs-orange); }
.rw-ship {
  margin-top: 12px;
  padding: 8px 12px;
  background: #e8f5ed;
  color: #679641;
  border-radius: 6px;
  font-size: 11px; font-weight: 600;
  display: flex; align-items: center; gap: 6px;
}
.rw-inventory {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 11px;
  color: var(--smoke);
}
.rw-inventory-bar-wrap {
  width: 100%;
  height: 6px;
  background: var(--mushroom-100);
  border-radius: 999px;
  overflow: hidden;
}
.rw-inventory-bar {
  height: 100%;
  background: var(--ufs-orange);
  border-radius: 999px;
  transition: width .3s ease;
}
.rw-inventory-labels {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.rw-inventory-left { font-weight: 600; color: var(--ufs-orange); }

.rw-address-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 24px;
  display: flex; justify-content: space-between; align-items: center;
}
.rw-addr { margin-top: 8px; font-size: 14px; line-height: 1.6; }

/* Smaller-height adjustments */
@media (max-width: 1200px) {
  .player-grid { grid-template-columns: 1fr; }
  .player-side { align-self: stretch; }
  .dash-row { grid-template-columns: 1fr; }
  .brief-detail-grid { grid-template-columns: 1fr; }
  .brief-detail-side { position: relative; }
  .course-grid { grid-template-columns: repeat(2, 1fr); }
  .stats { grid-template-columns: repeat(2, 1fr); }
}


/* =========================================================
   FIRST-RUN GUIDE (new chefs)
   ========================================================= */
.fr-page { padding-top: 18px; padding-bottom: 80px; }
.fr-header {
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; margin-bottom: 22px;
  padding-bottom: 16px; border-bottom: 1px solid var(--border);
}
.fr-greet {
  font: 400 32px/1.1 var(--font-display); font-style: italic;
  letter-spacing: -0.02em; margin: 4px 0 2px; color: var(--foreground);
}
.fr-sub { font-size: 14px; color: var(--muted-fg); max-width: 520px; margin: 0; }
.fr-progress-card {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px; background: var(--card); border: 1px solid var(--border);
  border-radius: 12px; box-shadow: var(--shadow-sm); flex-shrink: 0;
}
.fr-progress-ring {
  width: 48px; height: 48px; border-radius: 50%;
  background: conic-gradient(var(--ufs-orange) var(--p), var(--mushroom-100) 0);
  display: grid; place-items: center; flex-shrink: 0;
  transition: --p .5s ease;
}
.fr-progress-ring-inner {
  width: 38px; height: 38px; border-radius: 50%; background: var(--card);
  display: grid; place-items: center;
}
.fr-progress-num { font: 700 18px/1 var(--font-sans); color: var(--foreground); }
.fr-progress-num span { font-size: 12px; color: var(--muted-fg); font-weight: 500; }
.fr-progress-lab { font: 600 13px/1.2 var(--font-sans); color: var(--foreground); margin-bottom: 4px; }
.fr-skip { font-size: 12px; padding: 0; gap: 4px; }

/* Canvas — 12-col grid */
.fr-canvas {
  display: grid; grid-template-columns: repeat(12, 1fr);
  gap: 24px;
}
.fr-tile {
  background: var(--card); border: 1px solid var(--border); border-radius: 18px;
  padding: 28px; position: relative; overflow: hidden;
}
.fr-tile-paths   { grid-column: span 12; }
.fr-tile-briefs  { grid-column: span 12; }
.fr-tile-rewards { grid-column: span 12; }

/* Briefs rail uses the standard BriefCard component — 2-up at full width */
.fr-briefs-rail.brief-grid { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 760px)  { .fr-briefs-rail.brief-grid { grid-template-columns: 1fr; } }

@media (max-width: 1100px) {
  .fr-tile-paths, .fr-tile-briefs, .fr-tile-rewards { grid-column: span 12; }
}

.fr-tile-h {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 16px; margin-bottom: 20px;
}
.fr-tile-num {
  display: inline-block;
  font: 400 13px/1 var(--font-display); font-style: italic;
  color: var(--ufs-orange); letter-spacing: 0.04em; margin-bottom: 8px;
}
.fr-tile-title {
  font: 700 22px/1.15 var(--font-sans); letter-spacing: -0.012em;
  color: var(--foreground); margin: 0 0 6px;
}
.fr-tile-sub { font-size: 14px; color: var(--muted-fg); max-width: 380px; }
.fr-tile-meter { display: flex; align-items: center; gap: 8px; }
.fr-tile-meter-bar {
  width: 80px; height: 6px; background: var(--mushroom-100);
  border-radius: 99px; overflow: hidden;
}
.fr-tile-meter-bar > div { height: 100%; background: var(--ufs-orange); transition: width .35s ease; }

/* SETUP list */
.fr-setup-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.fr-setup-item {
  display: grid; grid-template-columns: 28px 36px 1fr auto;
  gap: 14px; align-items: center;
  padding: 14px 16px; border-radius: 12px;
  background: var(--mushroom-50); border: 1px solid var(--border);
  transition: background .2s ease;
}
.fr-setup-item.done { background: color-mix(in oklab, var(--ufs-orange) 6%, var(--card)); }
.fr-setup-item.done .fr-setup-label { text-decoration: line-through; color: var(--muted-fg); }
.fr-setup-check {
  width: 24px; height: 24px; border-radius: 50%;
  border: 1.5px solid var(--smoke); background: var(--card);
  display: grid; place-items: center; cursor: pointer;
  transition: all .15s ease;
}
.fr-setup-item.done .fr-setup-check {
  background: var(--ufs-orange); border-color: var(--ufs-orange); color: white;
}
.fr-setup-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--smoke); }
.fr-setup-icon {
  width: 36px; height: 36px; border-radius: 10px; display: grid; place-items: center;
  background: var(--card); border: 1px solid var(--border); color: var(--ufs-orange);
}
.fr-setup-label { font: 600 14px/1.3 var(--font-sans); color: var(--foreground); margin-bottom: 2px; }

/* STARTER PATH (paths tile) */
.fr-starter {
  display: grid; grid-template-columns: 220px 1fr; gap: 20px;
  width: 100%; padding: 0; background: var(--mushroom-50);
  border: 1px solid var(--border); border-radius: 14px; overflow: hidden;
  text-align: left; cursor: pointer; transition: all .2s ease;
  margin-bottom: 16px;
}
.fr-starter:hover { box-shadow: var(--shadow-md); border-color: var(--smoke); }
.fr-starter-cover {
  position: relative; min-height: 200px;
  display: grid; place-items: center;
}
.fr-starter-tag {
  position: absolute; top: 12px; left: 12px;
  padding: 5px 10px; border-radius: 99px;
  background: rgba(255,255,255,0.92); color: var(--ufs-orange);
  font: 700 10px/1 var(--font-sans); letter-spacing: 0.1em; text-transform: uppercase;
}
.fr-starter-play {
  width: 56px; height: 56px; border-radius: 50%; background: rgba(255,255,255,0.95);
  display: grid; place-items: center; color: var(--ufs-orange);
  box-shadow: 0 8px 24px rgba(0,0,0,0.2);
}
.fr-starter-body { padding: 18px 20px 18px 0; }
.fr-starter-title {
  font: 700 19px/1.25 var(--font-sans); letter-spacing: -0.012em;
  margin: 6px 0 4px; color: var(--foreground);
}
.fr-starter-instr { font-size: 13px; color: var(--muted-fg); margin-bottom: 12px; }
.fr-starter-modlist {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.fr-mod-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 5px 10px; border-radius: 99px;
  font: 500 11px/1 var(--font-sans);
  background: var(--card); border: 1px solid var(--border);
  color: var(--foreground);
}
.fr-mod-pill.done { background: color-mix(in oklab, var(--ufs-orange) 8%, var(--card)); border-color: var(--ufs-orange); color: var(--ufs-orange); }
.fr-mod-pill.current { background: var(--ufs-orange); border-color: var(--ufs-orange); color: white; }
.fr-mod-pill.locked { opacity: 0.5; }
.fr-mod-i { font-weight: 700; opacity: 0.6; }
.fr-mod-d { font-style: italic; opacity: 0.7; }

/* Path rail — secondary courses */
.fr-paths-rail {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
}
.fr-path-card {
  position: relative;
  background: var(--card); border: 1px solid var(--border); border-radius: 16px;
  overflow: hidden; padding: 0; text-align: left; cursor: pointer;
  transition: all .25s cubic-bezier(.2,.6,.2,1);
  display: flex; flex-direction: column;
}
.fr-path-card:hover {
  box-shadow: 0 18px 40px rgba(0,0,0,0.14);
  border-color: var(--ufs-orange); transform: translateY(-4px);
}
.fr-path-card:hover .fr-path-cover-img { transform: scale(1.05); }
.fr-path-cover {
  aspect-ratio: 16/10; position: relative; overflow: hidden;
}
.fr-path-cover-img {
  position: absolute; inset: 0;
  transition: transform .5s cubic-bezier(.2,.6,.2,1);
}
.fr-path-cover::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.05) 0%, transparent 35%, rgba(0,0,0,0.55) 100%);
}
.fr-path-cover-badge {
  position: absolute; top: 12px; left: 12px; z-index: 1;
  padding: 5px 10px; border-radius: 99px;
  background: rgba(255,255,255,0.96); backdrop-filter: blur(6px);
  font: 700 9px/1 var(--font-sans); letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--foreground);
  display: inline-flex; align-items: center; gap: 5px;
}
.fr-path-cover-badge::before {
  content: ""; width: 5px; height: 5px; border-radius: 50%;
  background: var(--ufs-orange);
}
.fr-path-cover-pill {
  position: absolute; top: 12px; right: 12px; z-index: 1;
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(255,255,255,0.96);
  display: grid; place-items: center; color: var(--ufs-orange);
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  transition: transform .25s ease;
}
.fr-path-card:hover .fr-path-cover-pill { transform: scale(1.1); }
.fr-path-cover-meta {
  position: absolute; bottom: 12px; left: 14px; right: 14px; z-index: 1;
  display: flex; gap: 14px;
  font: 600 11px/1 var(--font-sans); color: white;
  text-shadow: 0 1px 4px rgba(0,0,0,0.5);
}
.fr-path-cover-meta-item {
  display: inline-flex; align-items: center; gap: 5px;
}
.fr-path-body {
  padding: 14px 16px 14px; flex: 1;
  display: flex; flex-direction: column; gap: 6px;
}
.fr-path-title {
  font: 600 15px/1.3 var(--font-sans); margin: 0;
  color: var(--foreground); letter-spacing: -0.005em;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.fr-path-instr {
  display: flex; align-items: center; gap: 8px;
  font: 500 12px/1 var(--font-sans); color: var(--muted-fg);
  margin-top: auto; padding-top: 10px;
  border-top: 1px solid var(--border);
}
.fr-path-avatar {
  width: 22px; height: 22px; border-radius: 50%;
  background: linear-gradient(135deg, var(--ufs-orange), var(--ufs-yellow));
  display: grid; place-items: center;
  font: 700 9px/1 var(--font-sans); color: white;
  flex-shrink: 0; letter-spacing: 0.04em;
}

/* BRIEFS rail */
.fr-briefs-rail {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px;
}
.fr-brief-card {
  position: relative;
  display: flex; flex-direction: column;
  background: var(--card); border: 1px solid var(--border); border-radius: 16px;
  overflow: hidden; padding: 0; text-align: left; cursor: pointer;
  transition: all .2s ease;
  isolation: isolate;
}
.fr-brief-card::before {
  content: ""; position: absolute; inset: 0 0 auto 0; height: 4px;
  background: var(--brief-stripe, var(--ufs-orange));
  z-index: 1;
}
.fr-brief-card:hover {
  box-shadow: 0 12px 28px rgba(0,0,0,0.10);
  border-color: var(--brief-stripe, var(--smoke));
  transform: translateY(-3px);
}
.fr-brief-stripe { display: none; }
.fr-brief-body {
  padding: 18px 18px 16px; display: flex; flex-direction: column; gap: 8px;
  height: 100%;
}
.fr-brief-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 2px;
}
.fr-brief-brand {
  font: 700 10px/1 var(--font-sans); letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--muted-fg);
}
.fr-brief-title {
  font: 600 16px/1.3 var(--font-sans); margin: 2px 0 6px;
  color: var(--foreground); letter-spacing: -0.005em;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.fr-brief-tag {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 9px; border-radius: 99px;
  font: 600 10px/1.4 var(--font-sans); letter-spacing: 0.04em;
  width: fit-content;
}
.fr-brief-tag::before {
  content: ""; width: 5px; height: 5px; border-radius: 50%;
  background: currentColor; opacity: 0.85;
}
.fr-brief-foot {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-top: auto; padding-top: 12px; border-top: 1px solid var(--border);
}
.fr-brief-payout {
  font: 700 18px/1 var(--font-sans); color: var(--foreground);
  letter-spacing: -0.01em;
}
.fr-brief-payout-lab {
  font: 500 9px/1 var(--font-sans); letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--muted-fg);
  margin-bottom: 5px; display: block;
}
.fr-brief-deadline {
  display: inline-flex; align-items: center; gap: 4px;
  font: 500 11px/1 var(--font-sans); color: var(--muted-fg);
  padding: 5px 9px; border-radius: 99px;
  background: var(--mushroom-50); border: 1px solid var(--border);
}
.fr-brief-deadline.urgent {
  color: var(--ufs-orange); border-color: color-mix(in oklab, var(--ufs-orange) 30%, var(--border));
  background: color-mix(in oklab, var(--ufs-orange) 6%, var(--card));
}

/* REWARDS LADDER — v2 cards */
.fr-rewards-ladder.v2 {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 10px;
}
.fr-reward-row.v2 {
  display: grid; grid-template-columns: 64px 1fr auto;
  gap: 14px; align-items: center;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 14px; padding: 12px;
  transition: all .2s ease;
}
.fr-reward-row.v2:hover {
  box-shadow: 0 8px 20px rgba(0,0,0,0.06);
  border-color: var(--smoke); transform: translateX(2px);
}
.fr-reward-thumb {
  position: relative; width: 64px; height: 64px;
  border-radius: 12px;
  display: grid; place-items: center;
  flex-shrink: 0;
}
.fr-reward-row.is-physical .fr-reward-thumb {
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--ufs-orange) 18%, var(--mushroom-50)),
    color-mix(in oklab, var(--ufs-yellow) 22%, var(--mushroom-50))
  );
  color: var(--ufs-orange);
  border: 1px solid var(--border);
}
.fr-reward-row.is-digital .fr-reward-thumb {
  background: linear-gradient(135deg, var(--mushroom-100), var(--mushroom-50));
  color: var(--ink);
  border: 1px solid var(--border);
}
.fr-reward-thumb-icon {
  display: grid; place-items: center;
}
.fr-reward-thumb-tag {
  position: absolute; bottom: -6px; left: 50%; transform: translateX(-50%);
  font: 700 8px/1 var(--font-sans); letter-spacing: 0.16em;
  padding: 3px 6px; border-radius: 99px;
  background: var(--card); border: 1px solid var(--border); color: var(--muted-fg);
  white-space: nowrap;
}
.fr-reward-body {
  min-width: 0;
}
.fr-reward-row.v2 .fr-reward-title {
  font: 600 14px/1.25 var(--font-sans); color: var(--foreground);
  margin-bottom: 3px; letter-spacing: -0.005em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.fr-reward-sub {
  font: 400 12px/1.4 var(--font-sans); color: var(--muted-fg);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.fr-reward-trigger {
  text-align: center; flex-shrink: 0;
  padding: 6px 12px; border-left: 1px dashed var(--border);
  min-width: 70px;
}
.fr-reward-trigger-num {
  font: 700 24px/1 var(--font-display); font-style: italic;
  color: var(--ufs-orange); letter-spacing: -0.02em;
}
.fr-reward-trigger-lab {
  font: 500 9px/1 var(--font-sans); letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--muted-fg); margin-top: 4px;
}


/* =========================================================
   FIRST-RUN — additions
   ========================================================= */
.fr-mod-pill.not-started { background: var(--card); border: 1px solid var(--border); color: var(--foreground); }
.fr-mod-pill.not-started .fr-mod-i { color: var(--ufs-orange); opacity: 1; }

/* Reward pin in icon mode (no numbers) */
.fr-reward-pin { color: var(--muted-fg); }
.fr-reward-step.reached .fr-reward-pin { color: white; }

/* =========================================================
   COURSE OVERVIEW (pre-enrollment)
   ========================================================= */
.cov-page { padding-top: 24px; padding-bottom: 80px; max-width: 1100px; margin: 0 auto; }
.cov-back { margin-bottom: 16px; padding-left: 0; }

.cov-hero {
  display: grid; grid-template-columns: 1.05fr 1fr; gap: 32px;
  align-items: stretch; margin-bottom: 48px;
}
.cov-cover {
  position: relative; border-radius: 18px; overflow: hidden;
  min-height: 420px; display: grid; place-items: center;
  box-shadow: var(--shadow-md);
}
.cov-cover > * { position: relative; z-index: 1; }
.cov-cover > img { position: absolute; z-index: 0; }
.cov-cover-tag {
  position: absolute; top: 16px; left: 16px;
  padding: 6px 12px; border-radius: 99px;
  font: 700 10px/1 var(--font-sans); letter-spacing: 0.14em; text-transform: uppercase;
}
.cov-cover-play {
  width: 88px; height: 88px; border-radius: 50%;
  background: rgba(255,255,255,0.95); color: var(--ufs-orange);
  display: grid; place-items: center;
  box-shadow: 0 12px 32px rgba(0,0,0,0.22);
  transition: transform .2s ease;
}
.cov-cover:hover .cov-cover-play { transform: scale(1.05); }

.cov-meta { display: flex; flex-direction: column; }
.cov-title {
  font: 400 44px/1.05 var(--font-display); font-style: italic;
  letter-spacing: -0.018em; margin: 12px 0 12px; color: var(--foreground);
}
.cov-desc { font-size: 17px; color: var(--muted-fg); margin-bottom: 24px; max-width: 480px; }

.cov-stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
  margin-bottom: 24px; padding: 16px 0;
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
}
.cov-stat-val { font: 700 22px/1 var(--font-sans); color: var(--foreground); margin-bottom: 4px; }
.cov-stat-lab { font: 500 11px/1 var(--font-sans); letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted-fg); }

.cov-actions { display: flex; gap: 10px; margin-bottom: 20px; flex-wrap: wrap; }

.cov-perks { display: flex; flex-direction: column; gap: 6px; }
.cov-perk {
  display: flex; align-items: center; gap: 8px;
  font: 500 13px/1.4 var(--font-sans); color: var(--muted-fg);
}
.cov-perk svg { color: var(--ufs-orange); flex-shrink: 0; }

@media (max-width: 900px) {
  .cov-hero { grid-template-columns: 1fr; }
  .cov-cover { min-height: 280px; }
  .cov-stats { grid-template-columns: repeat(2, 1fr); }
}

/* Sections */
.cov-section { margin-bottom: 40px; }
.cov-h2 {
  font: 700 22px/1.2 var(--font-sans); letter-spacing: -0.012em;
  color: var(--foreground); margin: 0 0 18px;
}

.cov-outcomes { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.cov-outcome {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 16px 18px; background: var(--mushroom-50);
  border: 1px solid var(--border); border-radius: 12px;
  font: 500 15px/1.4 var(--font-sans); color: var(--foreground);
}
.cov-outcome-pin {
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--ufs-orange); color: white;
  display: grid; place-items: center; flex-shrink: 0;
}
@media (max-width: 700px) { .cov-outcomes { grid-template-columns: 1fr; } }

.cov-syllabus { display: flex; flex-direction: column; gap: 6px; }
.cov-mod {
  display: grid; grid-template-columns: 44px 1fr 24px;
  gap: 14px; align-items: center;
  padding: 14px 18px; background: var(--card);
  border: 1px solid var(--border); border-radius: 10px;
  transition: all .15s ease;
  text-align: left; width: 100%;
  font-family: inherit; cursor: pointer;
}
.cov-mod:hover:not(:disabled) { border-color: var(--smoke); box-shadow: var(--shadow-sm); transform: translateY(-1px); }
.cov-mod:disabled { cursor: not-allowed; opacity: 0.7; background: var(--mushroom-50); }
.cov-mod-num {
  font: 700 14px/1 var(--font-sans); color: var(--ufs-orange);
  display: grid; place-items: center;
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--accent);
}
.cov-mod.is-done .cov-mod-num { background: var(--squid-ink); color: #fff; }
.cov-mod.is-current .cov-mod-num {
  background: #fff; color: var(--ufs-orange);
  border: 2px solid var(--ufs-orange);
  box-shadow: 0 0 0 4px rgba(217, 119, 87, 0.18);
}
.cov-mod.is-locked .cov-mod-num {
  background: var(--mushroom-100); color: var(--smoke);
}
.cov-mod-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--ufs-orange); animation: pulse-dot 1.6s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%      { transform: scale(0.7); opacity: 0.6; }
}
.cov-mod-title { font: 600 14px/1.3 var(--font-sans); color: var(--foreground); margin-bottom: 4px; }
.cov-mod.is-done .cov-mod-title { color: var(--smoke); text-decoration: line-through; text-decoration-color: rgba(0,0,0,0.2); }
.cov-mod.is-locked .cov-mod-title { color: var(--smoke); }
.cov-mod-meta { display: flex; align-items: center; gap: 12px; }
.cov-mod svg:last-child { color: var(--smoke); }

.cov-footer {
  display: flex; justify-content: center;
  padding-top: 24px; border-top: 1px solid var(--border);
}
.btn-lg { height: 48px; padding: 0 24px; font-size: 15px; }


/* =========================================================
   GUIDED TOUR overlay — coach-marks + spotlight
   ========================================================= */
.tour-root {
  position: fixed; inset: 0; z-index: 1000;
  pointer-events: none;
  font-family: var(--font-sans);
}
.tour-dim {
  position: fixed; inset: 0;
  background: rgba(15, 14, 12, 0.62);
  pointer-events: auto;
  transition: clip-path .35s cubic-bezier(.6,.05,.3,1);
}
.tour-ring {
  position: fixed;
  border: 2px solid var(--ufs-orange);
  border-radius: 14px;
  box-shadow:
    0 0 0 4px rgba(237, 108, 0, 0.25),
    0 12px 32px rgba(0,0,0,0.18);
  pointer-events: none;
  transition: all .35s cubic-bezier(.6,.05,.3,1);
  animation: tour-pulse 2s ease-in-out infinite;
}
@keyframes tour-pulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(237, 108, 0, 0.25), 0 12px 32px rgba(0,0,0,0.18); }
  50%      { box-shadow: 0 0 0 8px rgba(237, 108, 0, 0.12), 0 12px 32px rgba(0,0,0,0.18); }
}

.tour-pop {
  position: fixed;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px 18px 14px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.28);
  pointer-events: auto;
  transition: top .35s cubic-bezier(.6,.05,.3,1), left .35s cubic-bezier(.6,.05,.3,1);
}
.tour-pop-h {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 8px;
}
.tour-step-lab {
  font: 700 10px/1 var(--font-sans); letter-spacing: 0.16em;
  color: var(--ufs-orange); text-transform: uppercase;
}
.tour-close {
  width: 24px; height: 24px; border: none; background: transparent;
  border-radius: 6px; cursor: pointer; color: var(--muted-fg);
  display: grid; place-items: center;
}
.tour-close:hover { background: var(--mushroom-100); color: var(--foreground); }

.tour-pop-title {
  font: 700 17px/1.25 var(--font-sans); letter-spacing: -0.01em;
  margin: 4px 0 6px; color: var(--foreground);
}
.tour-pop-body {
  font: 400 14px/1.5 var(--font-sans);
  color: var(--muted-fg); margin: 0 0 14px;
}

.tour-dots {
  display: flex; gap: 6px; margin-bottom: 12px;
}
.tour-dot {
  width: 6px; height: 6px; border-radius: 50%;
  border: none; padding: 0; background: var(--mushroom-100);
  cursor: pointer; transition: all .2s ease;
}
.tour-dot.past { background: var(--ufs-orange); opacity: 0.45; }
.tour-dot.on { background: var(--ufs-orange); width: 18px; border-radius: 99px; }

.tour-pop-actions {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px; padding-top: 10px;
  border-top: 1px solid var(--border);
}
.tour-skip-btn {
  background: transparent; border: none; padding: 0; cursor: pointer;
  font: 500 12px/1 var(--font-sans); color: var(--muted-fg);
  text-decoration: underline; text-underline-offset: 3px;
}
.tour-skip-btn:hover { color: var(--foreground); }
.tour-pop-right { display: flex; gap: 6px; }


/* =========================================================
   MODULE DETAIL screen
   ========================================================= */
.md-page { padding: 24px 32px 56px; max-width: 1100px; }
.md-back {
  display: inline-flex; align-items: center; gap: 6px;
  background: transparent; border: 0; padding: 0;
  cursor: pointer; margin-bottom: 18px;
  font: 500 13px/1 var(--font-sans); color: var(--smoke);
}
.md-back:hover { color: var(--ufs-orange); }

/* Hero */
.md-hero {
  display: grid; grid-template-columns: 360px 1fr; gap: 32px;
  align-items: stretch; margin-bottom: 40px;
}
.md-hero-cover {
  position: relative; min-height: 280px;
  border-radius: 14px; overflow: hidden;
  display: grid; place-items: center;
}
.md-hero-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
}
.md-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(0,0,0,0.25) 0%, rgba(0,0,0,0.55) 100%);
  z-index: 1;
}
.md-hero-num, .md-hero-play, .md-hero-lock, .md-hero-tag { position: relative; z-index: 2; }
.md-hero-num {
  position: absolute; top: 18px; left: 22px;
  font: 700 italic 56px/1 var(--font-display);
  color: rgba(255,255,255,0.85);
  letter-spacing: -0.02em;
}
.md-hero-tag {
  position: absolute; bottom: 18px; left: 22px;
  font: 600 11px/1 var(--font-sans);
  text-transform: uppercase; letter-spacing: 0.08em;
  padding: 6px 10px; border-radius: 999px;
}
.md-hero-play, .md-hero-lock {
  width: 78px; height: 78px; border-radius: 50%;
  background: rgba(255,255,255,0.94); color: var(--squid-ink);
  border: 0; cursor: pointer;
  display: grid; place-items: center;
  box-shadow: 0 8px 24px rgba(0,0,0,0.2);
  transition: transform .15s ease;
}
.md-hero-play:hover { transform: scale(1.05); }
.md-hero-lock { background: rgba(255,255,255,0.85); color: var(--smoke); }

.md-hero-meta { display: flex; flex-direction: column; gap: 14px; justify-content: center; }
.md-eyebrow-row { display: flex; align-items: center; gap: 12px; }
.md-title {
  font: 700 italic 36px/1.1 var(--font-display);
  color: var(--squid-ink); margin: 0;
  letter-spacing: -0.01em;
}
.md-course { font-size: 14px; color: var(--smoke); margin: 0; }
.md-course-link {
  background: transparent; border: 0; padding: 0; cursor: pointer;
  font: inherit; color: var(--ufs-orange); text-decoration: underline;
  text-underline-offset: 3px;
}
.md-course-link:hover { text-decoration-thickness: 2px; }

.md-stats {
  display: flex; flex-wrap: wrap; gap: 18px;
  padding: 12px 0; margin: 4px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.md-stat {
  display: inline-flex; align-items: center; gap: 6px;
  font: 500 13px/1 var(--font-sans); color: var(--smoke);
}
.md-stat svg { color: var(--ufs-orange); }

.md-actions { display: flex; gap: 10px; flex-wrap: wrap; }

.md-locked-card {
  display: grid; grid-template-columns: auto 1fr; gap: 14px; align-items: center;
  background: var(--mushroom-50); border: 1px dashed var(--border);
  padding: 16px 18px; border-radius: 12px;
}
.md-locked-card svg { color: var(--smoke); }
.md-locked-title { font: 700 14px/1.2 var(--font-sans); color: var(--foreground); margin-bottom: 4px; }
.md-locked-sub { font: 400 13px/1.45 var(--font-sans); color: var(--smoke); }

@media (max-width: 900px) {
  .md-hero { grid-template-columns: 1fr; }
  .md-title { font-size: 28px; }
}

/* Sections */
.md-section { margin-bottom: 40px; }
.md-h2 {
  font: 700 italic 22px/1.2 var(--font-display);
  color: var(--squid-ink); margin: 0 0 16px;
}

/* Outcomes */
.md-outcomes {
  list-style: none; padding: 0; margin: 0;
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.md-outcome {
  display: grid; grid-template-columns: auto 1fr; gap: 12px;
  padding: 14px 16px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px;
  font: 400 14px/1.5 var(--font-sans); color: var(--foreground);
}
.md-outcome-pin {
  width: 24px; height: 24px; border-radius: 50%;
  background: var(--ufs-orange); color: white;
  display: grid; place-items: center; flex-shrink: 0;
  margin-top: 1px;
}
@media (max-width: 700px) { .md-outcomes { grid-template-columns: 1fr; } }

/* Chapters */
.md-chapters {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 4px;
}
.md-chapter {
  display: grid; grid-template-columns: 44px 1fr auto;
  gap: 14px; align-items: center;
  padding: 12px 16px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px;
}
.md-chapter-num {
  width: 32px; height: 32px; border-radius: 8px;
  background: var(--accent); color: var(--ufs-orange);
  display: grid; place-items: center;
  font: 700 12px/1 var(--font-sans);
}
.md-chapter-title { font: 500 14px/1.3 var(--font-sans); color: var(--foreground); }
.md-chapter-time { font: 600 12px/1 var(--font-mono, var(--font-sans)); color: var(--smoke); }

/* Practice brief */
.md-practice {
  display: grid; grid-template-columns: 56px 1fr;
  gap: 18px; align-items: center;
  padding: 20px 24px;
  background: linear-gradient(135deg, rgba(217, 119, 87, 0.10), rgba(217, 119, 87, 0.02));
  border: 1px solid var(--border); border-radius: 12px;
  margin-top: -16px;
}
.md-practice-icon {
  width: 56px; height: 56px; border-radius: 50%;
  background: white; color: var(--ufs-orange);
  display: grid; place-items: center;
  border: 1px solid var(--border);
}
.md-practice-h { font: 700 italic 18px/1.2 var(--font-display); color: var(--squid-ink); margin-bottom: 4px; }
.md-practice-sub { font: 400 13px/1.5 var(--font-sans); color: var(--smoke); }

/* Prev/Next nav */
.md-prev-next {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
.md-nav-card {
  text-align: left; cursor: pointer;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 12px; padding: 18px 20px;
  display: flex; flex-direction: column; gap: 12px;
  font-family: inherit;
  transition: all .15s ease;
}
.md-nav-card:hover:not(:disabled) {
  border-color: var(--ufs-orange); transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
}
.md-nav-card.is-locked { cursor: not-allowed; opacity: 0.65; background: var(--mushroom-50); }
.md-nav-card.next { border-color: rgba(217, 119, 87, 0.3); background: rgba(217, 119, 87, 0.04); }
.md-nav-card.prev { text-align: left; }
.md-nav-card.next .md-nav-meta { justify-content: flex-end; }
.md-nav-meta {
  display: flex; align-items: center; gap: 8px;
  font: 600 11px/1 var(--font-sans); color: var(--smoke);
  text-transform: uppercase; letter-spacing: 0.08em;
}
.md-nav-card.next .md-nav-meta { color: var(--ufs-orange); }
.md-nav-title-row { display: flex; align-items: center; gap: 10px; flex: 1; }
.md-nav-num {
  font: 700 italic 22px/1 var(--font-display);
  color: var(--ufs-orange); flex-shrink: 0;
}
.md-nav-card.is-locked .md-nav-num { color: var(--smoke); }
.md-nav-title {
  font: 600 15px/1.3 var(--font-sans);
  color: var(--foreground); flex: 1;
}
.md-nav-foot {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px;
}
.md-nav-dur {
  display: inline-flex; align-items: center; gap: 5px;
  font: 500 12px/1 var(--font-sans); color: var(--smoke);
}
@media (max-width: 700px) { .md-prev-next { grid-template-columns: 1fr; } }

/* =========================================================
   Module Status Pill — used in detail, overview & player
   ========================================================= */
.md-pill {
  display: inline-flex; align-items: center; gap: 5px;
  font: 600 11px/1 var(--font-sans);
  text-transform: uppercase; letter-spacing: 0.08em;
  padding: 5px 9px; border-radius: 999px;
  white-space: nowrap;
}
.md-pill.done    { background: rgba(36, 50, 25, 0.08); color: #2c4a1e; }
.md-pill.current { background: rgba(217, 119, 87, 0.12); color: var(--ufs-orange); }
.md-pill.next    { background: var(--accent); color: var(--ufs-orange); }
.md-pill.locked  { background: var(--mushroom-100); color: var(--smoke); }
.md-pill-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--ufs-orange);
  animation: pulse-dot 1.6s ease-in-out infinite;
}

/* =========================================================
   Player · Up-next tile
   ========================================================= */
.player-upnext {
  display: flex; flex-direction: column; gap: 10px;
  padding: 18px 22px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 12px;
  text-align: left; cursor: pointer;
  font-family: inherit;
  transition: all .15s ease;
  margin-top: 2px;
}
.player-upnext:hover:not(:disabled) {
  border-color: var(--ufs-orange); transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
}
.player-upnext.is-locked {
  cursor: not-allowed; opacity: 0.7; background: var(--mushroom-50);
}
.player-upnext-meta {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
}
.player-upnext-title {
  display: flex; align-items: center; gap: 12px;
  font: 600 16px/1.3 var(--font-sans); color: var(--squid-ink);
}
.player-upnext-num {
  font: 700 italic 22px/1 var(--font-display);
  color: var(--ufs-orange);
}
.player-upnext-foot {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
}
.player-upnext-cta {
  display: inline-flex; align-items: center; gap: 6px;
  font: 600 13px/1 var(--font-sans); color: var(--ufs-orange);
}
.player-upnext.is-locked .player-upnext-cta { color: var(--smoke); }

/* Player · Learning path list (left column) */
.player-path { margin-top: 4px; }
.player-path-h {
  font: 700 18px/1.2 var(--font-display);
  color: var(--squid-ink);
  margin: 0 0 14px;
}
.player-path-list { display: flex; flex-direction: column; gap: 10px; }
.path-item {
  display: flex; align-items: flex-start; gap: 14px;
  width: 100%; text-align: left;
  padding: 14px 16px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  cursor: pointer;
  transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}
.path-item:hover:not(:disabled) {
  border-color: var(--ufs-orange);
  box-shadow: var(--shadow-sm);
}
.path-item.is-active {
  border-color: var(--ufs-orange);
  background: color-mix(in oklab, var(--ufs-orange) 5%, var(--card));
  box-shadow: 0 0 0 1px var(--ufs-orange) inset;
}
.path-item.is-locked {
  background: var(--mushroom-50);
  cursor: not-allowed;
  opacity: .75;
}
.path-item.is-done .path-title {
  color: var(--smoke);
}
.path-num {
  width: 36px; height: 36px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  font: 700 italic 14px/1 var(--font-display);
  background: var(--squid-ink);
  color: #fff;
}
.path-item.is-active .path-num {
  background: var(--ufs-orange-light, #FFE8DC);
  color: var(--ufs-orange);
}
.path-item.is-locked .path-num {
  background: var(--mushroom-100);
  color: var(--smoke);
}
.path-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 6px; }
.path-title {
  font: 600 15px/1.3 var(--font-sans);
  color: var(--squid-ink);
}
.path-meta {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  font: 500 12px/1 var(--font-sans);
  color: var(--smoke);
}
.path-meta-dot { color: var(--mushroom-200); }
.path-pill {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px;
  border-radius: 999px;
  font: 700 10px/1 var(--font-sans);
  letter-spacing: .04em;
  margin-left: 4px;
}
.path-pill.in-progress {
  background: color-mix(in oklab, var(--ufs-orange) 15%, transparent);
  color: var(--ufs-orange);
}
.path-pill.done {
  background: color-mix(in oklab, var(--green, #2D5F2E) 15%, transparent);
  color: var(--green, #2D5F2E);
}
.path-pill.next {
  background: color-mix(in oklab, var(--ufs-orange) 15%, transparent);
  color: var(--ufs-orange);
}
.path-pill.locked {
  background: var(--mushroom-100);
  color: var(--smoke);
}
.path-track {
  height: 3px; border-radius: 999px;
  background: var(--mushroom-100);
  overflow: hidden;
  margin-top: 4px;
}
.path-fill {
  height: 100%;
  background: var(--mushroom-200);
  transition: width .3s ease;
}
.path-fill.active { background: var(--ufs-orange); }
.path-fill.done { background: var(--green, #2D5F2E); }


/* =========================================================
   PROGRESS V2 · syllabus row, module-detail, player toast
   ========================================================= */

/* Syllabus row: per-module progress bar */
.cov-mod {
  grid-template-columns: 44px 1fr 24px;
  align-items: stretch;
}
.cov-mod-body { padding: 2px 0; }
.cov-mod-meta {
  display: flex; align-items: center; gap: 8px;
  flex-wrap: wrap;
}
.cov-mod-progress {
  margin-top: 8px;
  height: 4px; border-radius: 2px;
  background: var(--border); overflow: hidden;
}
.cov-mod-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--ufs-orange), #e89270);
  transition: width .35s ease;
}
.cov-mod.is-done .cov-mod-progress-fill { background: #2c4a1e; }

/* Module-detail · progress strip in hero */
.md-progress-strip {
  margin-top: 4px; display: flex; flex-direction: column; gap: 6px;
}
.md-progress-meta {
  display: flex; align-items: center; justify-content: space-between;
  font: 500 12px/1 var(--font-sans); color: var(--smoke);
}
.md-progress-meta svg { color: var(--ufs-orange); }
.md-progress-meta > span:first-child {
  display: inline-flex; align-items: center; gap: 6px;
}
.md-progress-pct { color: var(--ufs-orange); font-weight: 700; }
.md-progress-track {
  height: 6px; border-radius: 3px;
  background: var(--border); overflow: hidden;
}
.md-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--ufs-orange), #e89270);
  transition: width .4s ease;
}

/* Module-detail · chapter done state */
.md-chapter.is-done .md-chapter-num {
  background: #2c4a1e; color: #fff;
}
.md-chapter.is-done .md-chapter-title {
  color: var(--smoke); text-decoration: line-through;
  text-decoration-color: rgba(0,0,0,0.18);
}

/* =========================================================
   Player · progress strip + toast
   ========================================================= */
.player-progress-strip {
  margin-top: 22px; max-width: 480px;
  display: flex; flex-direction: column; gap: 6px;
}
.player-progress-meta {
  display: flex; align-items: center; justify-content: space-between;
  font: 500 12px/1 var(--font-sans); color: var(--smoke);
}
.player-progress-num {
  display: inline-flex; align-items: center; gap: 6px;
}
.player-progress-num svg { color: var(--ufs-orange); }
.player-progress-pct { font: 700 13px/1 var(--font-sans); color: var(--ufs-orange); }
.player-progress-track {
  height: 6px; border-radius: 3px;
  background: var(--border); overflow: hidden;
}
.player-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--ufs-orange), #e89270);
  transition: width .4s ease;
}

/* Toast — top-center, subtle slide in */
.player-toast {
  position: fixed;
  top: 84px; left: 50%; transform: translateX(-50%);
  z-index: 1200;
  display: flex; align-items: center; gap: 12px;
  padding: 14px 20px;
  background: var(--squid-ink); color: #fff;
  border-radius: 999px;
  box-shadow: 0 16px 36px rgba(0,0,0,0.25);
  animation: toast-pop .3s ease-out forwards;
  max-width: calc(100vw - 48px);
}
.player-toast.module {
  background: linear-gradient(135deg, var(--ufs-orange) 0%, #e89270 100%);
}
.player-toast-icon {
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255,255,255,0.18); color: #fff;
  display: grid; place-items: center; flex-shrink: 0;
}
.player-toast-h {
  font: 700 14px/1.2 var(--font-sans); color: #fff;
  margin-bottom: 2px;
}
.player-toast-sub {
  font: 400 italic 13px/1.3 var(--font-display); color: rgba(255,255,255,0.85);
}
@keyframes toast-pop {
  from { opacity: 0; transform: translate(-50%, -16px) scale(0.96); }
  to   { opacity: 1; transform: translate(-50%, 0)     scale(1); }
}

/* "Continue learning" hero/mini cards already use cp-bar / mini-bar — keep as-is */
