﻿/* ───────────────────────────────────────────────────
   Dating Coach — design system
   Inherits tgplay portal tokens (oklch, dark),
   but shifts hue to warm magenta/coral pairing.
   ─────────────────────────────────────────────────── */

:root {
  /* ——— hues ——— */
  --hue-primary: 340;      /* deep rose */
  --hue-warm: 20;          /* coral */
  --hue-cool: 280;         /* plum */

  /* ——— ink / surfaces (cool slightly-warm near-blacks) ——— */
  --ink-0: oklch(0.115 0.018 340);
  --ink-1: oklch(0.155 0.022 340);
  --ink-2: oklch(0.195 0.024 340);
  --ink-3: oklch(0.245 0.026 340);
  --ink-4: oklch(0.30 0.028 340);
  --ink-5: oklch(0.40 0.030 340);

  /* ——— text ——— */
  --text-1: oklch(0.98 0.005 340);
  --text-2: oklch(0.80 0.015 340);
  --text-3: oklch(0.60 0.022 340);
  --text-4: oklch(0.45 0.022 340);

  /* ——— brand ——— */
  --rose:       oklch(0.70 0.185 var(--hue-primary));
  --rose-hi:    oklch(0.80 0.155 var(--hue-primary));
  --rose-lo:    oklch(0.52 0.200 var(--hue-primary));
  --rose-glow:  oklch(0.70 0.185 var(--hue-primary) / 0.35);

  --coral:      oklch(0.74 0.175 var(--hue-warm));
  --plum:       oklch(0.58 0.17 var(--hue-cool));

  --ok:         oklch(0.78 0.17 150);
  --warn:       oklch(0.80 0.17 80);
  --alert:      oklch(0.68 0.22 28);

  /* ——— radius ——— */
  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 20px;
  --r-xl: 28px;

  /* ——— typography ——— */
  --font-display: 'Manrope', 'Inter', system-ui, sans-serif;
  --font-body:    'Inter',   system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;

  /* ——— shadows ——— */
  --sh-card: 0 1px 0 oklch(1 0 0 / 0.05) inset, 0 10px 28px -14px oklch(0 0 0 / 0.6);
  --sh-pop:  0 1px 0 oklch(1 0 0 / 0.08) inset, 0 30px 70px -24px oklch(0 0 0 / 0.75);

  --tap: cubic-bezier(0.2, 0.9, 0.2, 1);
}

/* ——— reset ——— */
* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background: oklch(0.08 0.015 340);
  color: var(--text-1);
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
button { font: inherit; color: inherit; background: none; border: 0; padding: 0; cursor: pointer; }
a { color: inherit; text-decoration: none; }

/* ═══════════════════════════════════════════════════
   SCREEN shell — lives inside iOS frame (390×844)
   ═══════════════════════════════════════════════════ */

.dc {
  width: 100%;
  height: 100%;
  background:
    radial-gradient(60% 40% at 80% -5%, oklch(0.45 0.22 var(--hue-primary) / 0.22), transparent 60%),
    radial-gradient(50% 35% at 0% 10%, oklch(0.45 0.22 var(--hue-cool) / 0.14), transparent 60%),
    var(--ink-0);
  color: var(--text-1);
  font-family: var(--font-body);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  position: relative;
}

.dc--scroll { overflow-y: auto; }

.dc-topbar {
  padding: 14px 20px 6px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}
.dc-topbar__back {
  width: 36px; height: 36px;
  display: grid; place-items: center;
  background: oklch(1 0 0 / 0.06);
  border: 1px solid oklch(1 0 0 / 0.08);
  border-radius: 12px;
  color: var(--text-1);
  font-size: 15px;
}
.dc-topbar__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: -0.01em;
  margin: 0;
  flex: 1;
}
.dc-topbar__action {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-3);
  padding: 8px 12px;
  border-radius: 10px;
  background: oklch(1 0 0 / 0.04);
}

.dc-body {
  flex: 1;
  overflow-y: auto;
  padding: 4px 20px 88px;
}
.dc-body::-webkit-scrollbar { display: none; }

/* ———————————————— tab bar (bottom) ———————————————— */

.dc-tabbar {
  position: absolute;
  left: 12px; right: 12px; bottom: 18px;
  height: 62px;
  background: oklch(0.22 0.025 340 / 0.75);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border: 1px solid oklch(1 0 0 / 0.08);
  border-radius: 20px;
  padding: 8px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  box-shadow: 0 20px 40px -20px oklch(0 0 0 / 0.6);
  z-index: 10;
}
.dc-tab {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  border-radius: 14px;
  color: var(--text-3);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.02em;
  transition: background .15s, color .15s;
}
.dc-tab svg { width: 20px; height: 20px; }
.dc-tab--active {
  background: linear-gradient(180deg, oklch(0.70 0.185 var(--hue-primary) / 0.25), oklch(0.55 0.20 var(--hue-primary) / 0.08));
  color: var(--rose-hi);
  border: 1px solid oklch(0.70 0.185 var(--hue-primary) / 0.25);
}

/* ———————————————— shared ui primitives ———————————————— */

.eyebrow {
  font-family: var(--font-display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--rose-hi);
  display: inline-flex; align-items: center; gap: 6px;
}
.eyebrow::before {
  content: '';
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--rose);
  box-shadow: 0 0 8px var(--rose-glow);
}

.h1 {
  font-family: var(--font-display);
  font-size: 28px; font-weight: 800;
  letter-spacing: -0.032em;
  line-height: 1.05;
  margin: 0;
}
.h2 {
  font-family: var(--font-display);
  font-size: 20px; font-weight: 800;
  letter-spacing: -0.025em;
  line-height: 1.15;
  margin: 0;
}
.h3 {
  font-family: var(--font-display);
  font-size: 15px; font-weight: 700;
  letter-spacing: -0.01em;
  margin: 0;
}
.muted  { color: var(--text-3); }
.muted-deep { color: var(--text-4); }
.num-mono { font-variant-numeric: tabular-nums; font-family: var(--font-display); }

.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px;
  height: 44px;
  padding: 0 18px;
  border-radius: 12px;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.005em;
  transition: transform .1s var(--tap), background .15s, box-shadow .15s;
}
.btn--primary {
  background: linear-gradient(180deg, var(--rose-hi), var(--rose-lo));
  color: white;
  box-shadow: 0 8px 24px -10px var(--rose-glow), inset 0 1px 0 oklch(1 0 0 / 0.2);
}
.btn--primary:active { transform: translateY(1px); }
.btn--ghost {
  background: oklch(1 0 0 / 0.06);
  color: var(--text-1);
  border: 1px solid oklch(1 0 0 / 0.08);
}
.btn--block { width: 100%; }

/* chips */
.chip-row {
  display: flex; gap: 8px;
  overflow-x: auto;
  scrollbar-width: none;
  padding-bottom: 2px;
  margin: 0 -20px;
  padding-left: 20px;
  padding-right: 20px;
}
.chip-row::-webkit-scrollbar { display: none; }
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 12px;
  border-radius: 999px;
  background: oklch(1 0 0 / 0.05);
  border: 1px solid oklch(1 0 0 / 0.08);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-2);
  white-space: nowrap;
  flex-shrink: 0;
}
.chip strong {
  color: var(--text-1);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.chip--rose {
  background: oklch(0.70 0.185 var(--hue-primary) / 0.15);
  border-color: oklch(0.70 0.185 var(--hue-primary) / 0.35);
  color: var(--rose-hi);
}
.chip--rose strong { color: var(--rose-hi); }
.chip-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: currentColor;
}

/* cards */
.card-surface {
  background: oklch(1 0 0 / 0.035);
  border: 1px solid oklch(1 0 0 / 0.07);
  border-radius: var(--r-lg);
}

/* progress */
.pbar {
  height: 6px;
  background: oklch(1 0 0 / 0.06);
  border-radius: 999px;
  overflow: hidden;
}
.pbar > span {
  display: block; height: 100%;
  background: linear-gradient(90deg, var(--coral), var(--rose));
  border-radius: inherit;
}
.pbar--thin { height: 3px; }

/* ═══════════════════════════════════════════════════
   AUTH screen
   ═══════════════════════════════════════════════════ */

.auth {
  flex: 1;
  padding: 56px 28px 40px;
  display: flex; flex-direction: column;
  position: relative;
  overflow: hidden;
}
.auth::before {
  content: '';
  position: absolute;
  inset: -50% -30% auto -30%;
  height: 120%;
  background:
    radial-gradient(40% 30% at 30% 30%, var(--rose-glow), transparent 70%),
    radial-gradient(40% 30% at 80% 40%, oklch(0.6 0.18 var(--hue-cool) / 0.25), transparent 70%);
  filter: blur(8px);
  pointer-events: none;
}
.auth__mark {
  position: relative;
  width: 88px; height: 88px;
  border-radius: 24px;
  background: linear-gradient(140deg, var(--rose) 0%, var(--plum) 100%);
  display: grid; place-items: center;
  box-shadow: 0 24px 60px -20px var(--rose-glow), inset 0 1px 0 oklch(1 0 0 / 0.25);
  margin-bottom: 28px;
}
.auth__mark svg { width: 44px; height: 44px; color: white; }
.auth__kicker {
  position: relative;
  font-family: var(--font-display);
  font-size: 11px; font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 12px;
}
.auth__title {
  position: relative;
  font-family: var(--font-display);
  font-size: 40px; font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 1.0;
  margin: 0 0 14px;
  text-wrap: balance;
}
.auth__title em {
  font-style: normal;
  background: linear-gradient(100deg, var(--coral), var(--rose), var(--plum));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.auth__sub {
  position: relative;
  font-size: 15px;
  color: var(--text-2);
  margin: 0 0 36px;
  max-width: 28ch;
  line-height: 1.45;
}
.auth__bullets {
  position: relative;
  display: grid; gap: 12px;
  margin-bottom: auto;
  padding-bottom: 28px;
}
.auth__bullet {
  display: flex; gap: 12px; align-items: flex-start;
  font-size: 13px; color: var(--text-2);
}
.auth__bullet-dot {
  width: 20px; height: 20px;
  border-radius: 50%;
  background: oklch(0.70 0.185 var(--hue-primary) / 0.18);
  color: var(--rose-hi);
  display: grid; place-items: center;
  font-size: 11px;
  font-weight: 800;
  flex-shrink: 0;
  margin-top: 1px;
}
.auth__cta { position: relative; display: grid; gap: 10px; }
.auth__hint {
  position: relative;
  text-align: center;
  font-size: 11px;
  color: var(--text-4);
  margin: 12px 0 0;
}

/* ═══════════════════════════════════════════════════
   HOME dashboard
   ═══════════════════════════════════════════════════ */

.home-head {
  display: flex; align-items: center; gap: 12px;
  padding: 0 0 14px;
}
.avatar {
  width: 40px; height: 40px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--plum), var(--rose));
  display: grid; place-items: center;
  color: white;
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 800;
  letter-spacing: -0.02em;
  flex-shrink: 0;
  box-shadow: inset 0 1px 0 oklch(1 0 0 / 0.2);
}
.home-head__who { flex: 1; min-width: 0; }
.home-head__greet {
  font-size: 12px;
  color: var(--text-3);
  margin: 0;
}
.home-head__name {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 1px 0 0;
}
.icon-btn {
  width: 40px; height: 40px;
  border-radius: 14px;
  background: oklch(1 0 0 / 0.04);
  border: 1px solid oklch(1 0 0 / 0.06);
  display: grid; place-items: center;
  color: var(--text-2);
}
.icon-btn svg { width: 18px; height: 18px; }

/* streak hero */
.streak-hero {
  position: relative;
  margin-top: 4px;
  padding: 20px;
  border-radius: var(--r-xl);
  background:
    radial-gradient(80% 60% at 100% 0%, oklch(0.70 0.22 var(--hue-warm) / 0.35), transparent 60%),
    radial-gradient(80% 90% at -10% 110%, oklch(0.55 0.22 var(--hue-primary) / 0.45), transparent 70%),
    linear-gradient(135deg, oklch(0.30 0.08 var(--hue-primary)), oklch(0.18 0.04 var(--hue-primary)));
  border: 1px solid oklch(1 0 0 / 0.08);
  overflow: hidden;
  box-shadow: var(--sh-pop);
}
.streak-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(oklch(1 0 0 / 0.035) 1px, transparent 1px);
  background-size: 3px 3px;
  mix-blend-mode: overlay;
  pointer-events: none;
}
.streak-hero__top {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 18px;
  position: relative;
}
.streak-hero__label {
  font-family: var(--font-display);
  font-size: 11px; font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: oklch(0.95 0.08 var(--hue-warm));
  display: inline-flex; align-items: center; gap: 6px;
}
.streak-hero__label svg { width: 12px; height: 12px; }
.streak-hero__count {
  display: flex; align-items: baseline; gap: 6px;
  position: relative;
}
.streak-hero__num {
  font-family: var(--font-display);
  font-size: 76px;
  font-weight: 800;
  letter-spacing: -0.055em;
  line-height: 0.9;
  background: linear-gradient(150deg, oklch(0.98 0.04 var(--hue-warm)), var(--rose-hi));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-variant-numeric: tabular-nums;
}
.streak-hero__unit {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 700;
  color: var(--text-2);
  letter-spacing: -0.01em;
}
.streak-hero__sub {
  font-size: 12px;
  color: var(--text-2);
  margin: 6px 0 16px;
  position: relative;
}
.streak-week {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  position: relative;
}
.streak-day {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  font-size: 10px;
  color: var(--text-3);
  font-weight: 600;
}
.streak-day__dot {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 10px;
  background: oklch(1 0 0 / 0.05);
  border: 1px solid oklch(1 0 0 / 0.08);
  display: grid; place-items: center;
}
.streak-day__dot svg { width: 14px; height: 14px; opacity: 0.7; }
.streak-day--done .streak-day__dot {
  background: linear-gradient(160deg, var(--coral), var(--rose));
  border-color: transparent;
  color: white;
}
.streak-day--done .streak-day__dot svg { opacity: 1; }
.streak-day--today .streak-day__dot {
  background: oklch(1 0 0 / 0.12);
  border: 1px dashed var(--rose-hi);
  color: var(--rose-hi);
}
.streak-day--today { color: var(--rose-hi); }

/* section head */
.sec-head {
  display: flex; justify-content: space-between; align-items: baseline;
  margin: 26px 0 12px;
}
.sec-head h3 { font-family: var(--font-display); font-size: 16px; font-weight: 800; letter-spacing: -0.02em; margin: 0; }
.sec-head a { font-size: 12px; color: var(--text-3); font-weight: 600; }

/* continue lesson card */
.cont-card {
  display: flex; gap: 14px;
  padding: 14px;
  border-radius: var(--r-lg);
  background: linear-gradient(140deg, oklch(0.22 0.04 var(--hue-primary) / 0.8), oklch(0.16 0.03 var(--hue-primary) / 0.8));
  border: 1px solid oklch(0.45 0.15 var(--hue-primary) / 0.35);
  position: relative;
  overflow: hidden;
}
.cont-card__art {
  flex: 0 0 76px;
  aspect-ratio: 1;
  border-radius: var(--r-md);
  position: relative;
  overflow: hidden;
  background: linear-gradient(160deg, var(--plum), var(--rose));
  display: grid; place-items: center;
}
.cont-card__art svg { width: 34px; height: 34px; color: white; }
.cont-card__body { flex: 1; min-width: 0; display: flex; flex-direction: column; justify-content: center; }
.cont-card__eyebrow {
  font-size: 10px; font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--rose-hi);
}
.cont-card__title {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.015em;
  margin: 4px 0 6px;
}
.cont-card__meta {
  font-size: 11px;
  color: var(--text-3);
  display: flex; gap: 10px;
  margin-bottom: 8px;
}
.cont-card__meta strong { color: var(--text-1); font-weight: 700; }
.cont-card__arrow {
  position: absolute;
  top: 14px; right: 14px;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--rose);
  color: white;
  display: grid; place-items: center;
  box-shadow: 0 6px 14px -6px var(--rose-glow);
}
.cont-card__arrow svg { width: 14px; height: 14px; }

/* daily quests */
.quest-list {
  display: grid; gap: 8px;
}
.quest {
  display: flex; gap: 12px; align-items: center;
  padding: 14px;
  border-radius: var(--r-md);
  background: oklch(1 0 0 / 0.035);
  border: 1px solid oklch(1 0 0 / 0.07);
}
.quest__icon {
  width: 38px; height: 38px;
  border-radius: 12px;
  background: oklch(1 0 0 / 0.05);
  display: grid; place-items: center;
  color: var(--rose-hi);
  flex-shrink: 0;
}
.quest__icon svg { width: 18px; height: 18px; }
.quest--done .quest__icon {
  background: oklch(0.78 0.17 150 / 0.18);
  color: var(--ok);
}
.quest__body { flex: 1; min-width: 0; }
.quest__title { font-size: 13px; font-weight: 700; color: var(--text-1); }
.quest__sub { font-size: 11px; color: var(--text-3); margin-top: 2px; }
.quest__reward {
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 800;
  color: var(--rose-hi);
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
}
.quest--done .quest__reward { color: var(--ok); }

/* focus area tiles */
.focus-rail {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 180px;
  gap: 10px;
  overflow-x: auto;
  scrollbar-width: none;
  margin: 0 -20px;
  padding: 0 20px 4px;
}
.focus-rail::-webkit-scrollbar { display: none; }
.focus-tile {
  padding: 16px;
  border-radius: var(--r-lg);
  background: oklch(1 0 0 / 0.04);
  border: 1px solid oklch(1 0 0 / 0.07);
  display: flex; flex-direction: column;
  gap: 10px;
  position: relative;
  overflow: hidden;
}
.focus-tile__num {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -0.05em;
  line-height: 1;
  background: linear-gradient(140deg, var(--rose-hi), var(--plum));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-variant-numeric: tabular-nums;
}
.focus-tile__title { font-size: 13px; font-weight: 700; color: var(--text-1); letter-spacing: -0.005em; }
.focus-tile__meta { font-size: 10px; color: var(--text-3); margin-top: auto; }

/* ═══════════════════════════════════════════════════
   LEARNING — path
   ═══════════════════════════════════════════════════ */

.level-hero {
  margin-top: 4px;
  padding: 20px;
  border-radius: var(--r-xl);
  background:
    radial-gradient(100% 100% at 100% 0%, oklch(0.55 0.22 var(--hue-primary) / 0.35), transparent 60%),
    linear-gradient(135deg, oklch(0.22 0.05 var(--hue-primary)), oklch(0.14 0.03 var(--hue-primary)));
  border: 1px solid oklch(1 0 0 / 0.08);
  position: relative;
  overflow: hidden;
  margin-bottom: 20px;
}
.level-hero__badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 10px;
  border-radius: 999px;
  background: oklch(1 0 0 / 0.08);
  border: 1px solid oklch(1 0 0 / 0.12);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-2);
  margin-bottom: 14px;
}
.level-hero__title {
  font-family: var(--font-display);
  font-size: 24px; font-weight: 800;
  letter-spacing: -0.03em;
  margin: 0 0 6px;
  line-height: 1.05;
}
.level-hero__sub {
  font-size: 13px;
  color: var(--text-2);
  margin: 0 0 16px;
}
.level-hero__stats {
  display: flex; gap: 16px;
  padding-top: 14px;
  border-top: 1px solid oklch(1 0 0 / 0.08);
}
.level-hero__stat-num {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.level-hero__stat-label {
  font-size: 10px; color: var(--text-3);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-top: 2px;
}

/* Path tree */
.path-list { display: grid; gap: 10px; margin-bottom: 24px; }
.path-level {
  padding: 14px;
  background: oklch(1 0 0 / 0.04);
  border: 1px solid oklch(1 0 0 / 0.07);
  border-radius: var(--r-lg);
  position: relative;
  overflow: hidden;
}
.path-level--current {
  background: linear-gradient(135deg, oklch(0.30 0.08 var(--hue-primary) / 0.8), oklch(0.20 0.04 var(--hue-primary) / 0.8));
  border-color: oklch(0.70 0.185 var(--hue-primary) / 0.45);
}
.path-level--locked { opacity: 0.58; }
.path-level__head { display: flex; align-items: center; gap: 12px; }
.path-level__mark {
  width: 42px; height: 42px;
  border-radius: 12px;
  display: grid; place-items: center;
  flex-shrink: 0;
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 800;
}
.path-level--current .path-level__mark {
  background: linear-gradient(135deg, var(--coral), var(--rose));
  color: white;
  box-shadow: inset 0 1px 0 oklch(1 0 0 / 0.2);
}
.path-level--locked .path-level__mark,
.path-level--done .path-level__mark {
  background: oklch(1 0 0 / 0.05);
  border: 1px solid oklch(1 0 0 / 0.08);
  color: var(--text-3);
}
.path-level--done .path-level__mark {
  background: oklch(0.78 0.17 150 / 0.2);
  border-color: oklch(0.78 0.17 150 / 0.4);
  color: var(--ok);
}
.path-level__body { flex: 1; min-width: 0; }
.path-level__title { font-family: var(--font-display); font-size: 15px; font-weight: 800; letter-spacing: -0.015em; margin: 0; }
.path-level__sub { font-size: 11px; color: var(--text-3); margin-top: 2px; }
.path-level__caret { color: var(--text-3); }
.path-level__caret svg { width: 18px; height: 18px; }

.path-level__bottom {
  margin-top: 12px;
  display: flex; align-items: center; gap: 10px;
}
.path-level__progress-meta {
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: 700;
  color: var(--text-2);
  font-variant-numeric: tabular-nums;
  min-width: 54px;
}
.path-level__bar { flex: 1; }

/* Modules list */
.mod-list { display: grid; gap: 10px; }
.mod {
  padding: 16px;
  border-radius: var(--r-lg);
  background: oklch(1 0 0 / 0.04);
  border: 1px solid oklch(1 0 0 / 0.07);
  display: flex; flex-direction: column; gap: 12px;
  position: relative;
}
.mod__head { display: flex; align-items: center; gap: 12px; }
.mod__index {
  width: 28px; height: 28px;
  border-radius: 8px;
  background: oklch(1 0 0 / 0.05);
  display: grid; place-items: center;
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: 800;
  color: var(--text-3);
  flex-shrink: 0;
  letter-spacing: 0.05em;
}
.mod--current .mod__index { background: oklch(0.70 0.185 var(--hue-primary) / 0.22); color: var(--rose-hi); }
.mod__title { font-family: var(--font-display); font-size: 14px; font-weight: 800; letter-spacing: -0.015em; flex: 1; }
.mod__pct {
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 800;
  color: var(--text-3);
  font-variant-numeric: tabular-nums;
}
.mod--done .mod__pct { color: var(--ok); }
.mod__lessons {
  display: grid; gap: 4px;
  padding-left: 0;
}
.mod-lesson {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  border-radius: 10px;
  font-size: 13px;
  color: var(--text-2);
}
.mod-lesson__dot {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: oklch(1 0 0 / 0.05);
  border: 1px solid oklch(1 0 0 / 0.1);
  display: grid; place-items: center;
  flex-shrink: 0;
}
.mod-lesson--done .mod-lesson__dot {
  background: var(--ok);
  border-color: transparent;
  color: oklch(0.15 0.03 150);
}
.mod-lesson--done .mod-lesson__dot svg { width: 10px; height: 10px; }
.mod-lesson--current .mod-lesson__dot {
  background: var(--rose);
  border-color: transparent;
  color: white;
}
.mod-lesson--current .mod-lesson__dot svg { width: 9px; height: 9px; }
.mod-lesson__title { flex: 1; }
.mod-lesson--done .mod-lesson__title { color: var(--text-3); text-decoration: line-through; text-decoration-color: var(--text-4); }
.mod-lesson--current { color: var(--text-1); font-weight: 700; }
.mod-lesson__mins { font-size: 10px; color: var(--text-4); font-variant-numeric: tabular-nums; }

/* ═══════════════════════════════════════════════════
   LESSON reader
   ═══════════════════════════════════════════════════ */

.lesson {
  padding: 10px 20px 140px;
  flex: 1;
  overflow-y: auto;
}
.lesson__progress {
  height: 3px;
  background: oklch(1 0 0 / 0.06);
  border-radius: 2px;
  overflow: hidden;
  margin: 0 20px 14px;
}
.lesson__progress > span {
  display: block; height: 100%;
  background: linear-gradient(90deg, var(--coral), var(--rose));
}
.lesson__crumbs {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-3);
  margin: 0 0 8px;
}
.lesson__title {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -0.033em;
  line-height: 1.05;
  margin: 0 0 12px;
}
.lesson__meta {
  display: flex; gap: 14px;
  font-size: 11px; color: var(--text-3);
  margin-bottom: 22px;
  padding-bottom: 16px;
  border-bottom: 1px solid oklch(1 0 0 / 0.06);
}
.lesson__meta-item { display: inline-flex; align-items: center; gap: 4px; }
.lesson__meta-item strong { color: var(--text-1); font-weight: 700; }

.lesson__intro {
  font-size: 15px;
  line-height: 1.55;
  color: var(--text-2);
  margin: 0 0 22px;
  max-width: 40ch;
}

.lesson h4 {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--rose-hi);
  margin: 22px 0 10px;
}

.lesson-callout {
  padding: 16px;
  border-radius: var(--r-lg);
  background: oklch(0.70 0.185 var(--hue-primary) / 0.08);
  border: 1px solid oklch(0.70 0.185 var(--hue-primary) / 0.22);
  display: flex; gap: 12px;
  margin: 16px 0;
}
.lesson-callout__icon {
  width: 26px; height: 26px;
  border-radius: 8px;
  display: grid; place-items: center;
  background: oklch(0.70 0.185 var(--hue-primary) / 0.3);
  color: var(--rose-hi);
  flex-shrink: 0;
}
.lesson-callout__icon svg { width: 14px; height: 14px; }
.lesson-callout__body { font-size: 13px; color: var(--text-1); line-height: 1.5; }
.lesson-callout__body b { color: var(--rose-hi); }

.lesson-bullets { list-style: none; padding: 0; margin: 10px 0 18px; display: grid; gap: 10px; }
.lesson-bullets li {
  display: flex; gap: 10px;
  font-size: 14px; color: var(--text-1); line-height: 1.5;
}
.lesson-bullets li::before {
  content: '';
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--rose);
  margin-top: 9px;
  flex-shrink: 0;
}
.lesson-bullets li strong { color: var(--rose-hi); font-weight: 700; }

.practice-card {
  padding: 18px;
  border-radius: var(--r-lg);
  background: linear-gradient(140deg, oklch(0.24 0.04 var(--hue-primary) / 0.7), oklch(0.16 0.03 var(--hue-primary) / 0.7));
  border: 1px solid oklch(0.45 0.15 var(--hue-primary) / 0.4);
  margin: 18px 0;
}
.practice-card__label {
  font-family: var(--font-display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--coral);
  margin-bottom: 8px;
}
.practice-card__title {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 6px;
}
.practice-card__body { font-size: 13px; color: var(--text-2); line-height: 1.5; margin: 0; }

.lesson-foot {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  padding: 16px 20px calc(16px + env(safe-area-inset-bottom));
  background: linear-gradient(180deg, transparent, oklch(0.08 0.015 340) 35%);
  display: flex; gap: 10px;
}
.lesson-foot .btn { flex: 1; }

/* ═══════════════════════════════════════════════════
   CELEBRATION screen
   ═══════════════════════════════════════════════════ */

.celeb {
  flex: 1;
  padding: 60px 28px 36px;
  display: flex; flex-direction: column; align-items: center;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.celeb::before {
  content: '';
  position: absolute;
  inset: -30% -30% auto -30%;
  height: 90%;
  background:
    radial-gradient(35% 35% at 50% 30%, var(--rose-glow), transparent 60%);
  filter: blur(4px);
  pointer-events: none;
}
.celeb__trophy {
  position: relative;
  width: 116px; height: 116px;
  border-radius: 32px;
  background: linear-gradient(140deg, var(--coral), var(--rose) 55%, var(--plum));
  display: grid; place-items: center;
  margin-bottom: 28px;
  box-shadow: 0 30px 60px -14px var(--rose-glow), inset 0 1px 0 oklch(1 0 0 / 0.25);
}
.celeb__trophy::after {
  content: '';
  position: absolute;
  inset: -12px;
  border-radius: 44px;
  border: 1px dashed oklch(1 0 0 / 0.12);
  pointer-events: none;
}
.celeb__trophy svg { width: 58px; height: 58px; color: white; }
.celeb__kicker {
  position: relative;
  font-family: var(--font-display);
  font-size: 11px; font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--rose-hi);
  margin-bottom: 10px;
}
.celeb__title {
  position: relative;
  font-family: var(--font-display);
  font-size: 32px; font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 1.05;
  margin: 0 0 10px;
  max-width: 15ch;
}
.celeb__sub {
  position: relative;
  font-size: 14px;
  color: var(--text-2);
  margin: 0 0 28px;
  max-width: 30ch;
}
.celeb-stats {
  position: relative;
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  width: 100%;
  margin-bottom: 24px;
}
.celeb-stat {
  padding: 14px 8px;
  border-radius: var(--r-md);
  background: oklch(1 0 0 / 0.04);
  border: 1px solid oklch(1 0 0 / 0.07);
}
.celeb-stat__num {
  font-family: var(--font-display);
  font-size: 22px; font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--rose-hi);
  font-variant-numeric: tabular-nums;
}
.celeb-stat__label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-top: 2px;
}
.celeb-ach {
  position: relative;
  width: 100%;
  padding: 14px;
  border-radius: var(--r-lg);
  background: linear-gradient(140deg, oklch(0.80 0.17 80 / 0.15), oklch(0.60 0.18 40 / 0.08));
  border: 1px solid oklch(0.80 0.17 80 / 0.3);
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 20px;
  text-align: left;
}
.celeb-ach__icon {
  width: 40px; height: 40px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--warn), var(--coral));
  display: grid; place-items: center;
  color: oklch(0.15 0.03 60);
  flex-shrink: 0;
}
.celeb-ach__icon svg { width: 18px; height: 18px; }
.celeb-ach__kicker { font-size: 10px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--warn); }
.celeb-ach__name { font-family: var(--font-display); font-size: 14px; font-weight: 800; margin-top: 2px; letter-spacing: -0.01em; }
.celeb__cta { position: relative; width: 100%; display: grid; gap: 10px; margin-top: auto; }

/* ═══════════════════════════════════════════════════
   ACHIEVEMENTS
   ═══════════════════════════════════════════════════ */

.ach-summary {
  padding: 18px;
  border-radius: var(--r-lg);
  background: oklch(1 0 0 / 0.04);
  border: 1px solid oklch(1 0 0 / 0.07);
  display: flex; gap: 16px; align-items: center;
  margin-bottom: 20px;
}
.ach-ring {
  position: relative;
  width: 68px; height: 68px;
  flex-shrink: 0;
}
.ach-ring svg { width: 100%; height: 100%; }
.ach-ring__num {
  position: absolute; inset: 0;
  display: grid; place-items: center;
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.03em;
}
.ach-ring__num small { font-size: 10px; color: var(--text-3); font-weight: 700; }
.ach-summary__body { flex: 1; }
.ach-summary__title { font-family: var(--font-display); font-size: 14px; font-weight: 800; }
.ach-summary__sub { font-size: 12px; color: var(--text-3); margin-top: 2px; }

.ach-group {
  font-family: var(--font-display);
  font-size: 11px; font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
  margin: 22px 0 10px;
  display: flex; justify-content: space-between;
}

.ach-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.ach {
  aspect-ratio: 1;
  padding: 10px 8px 10px;
  border-radius: var(--r-md);
  background: oklch(1 0 0 / 0.04);
  border: 1px solid oklch(1 0 0 / 0.07);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 6px;
  text-align: center;
  position: relative;
}
.ach__icon {
  width: 36px; height: 36px;
  border-radius: 10px;
  display: grid; place-items: center;
  color: var(--text-4);
  background: oklch(1 0 0 / 0.04);
}
.ach__icon svg { width: 18px; height: 18px; }
.ach__name { font-size: 10px; font-weight: 700; color: var(--text-2); line-height: 1.2; letter-spacing: -0.005em; }
.ach--unlocked .ach__icon {
  color: white;
  background: linear-gradient(140deg, var(--coral), var(--rose));
  box-shadow: inset 0 1px 0 oklch(1 0 0 / 0.2), 0 6px 14px -6px var(--rose-glow);
}
.ach--unlocked .ach__name { color: var(--text-1); }
.ach--unlocked { border-color: oklch(0.70 0.185 var(--hue-primary) / 0.25); background: oklch(0.70 0.185 var(--hue-primary) / 0.08); }
.ach--locked .ach__icon {
  background: oklch(1 0 0 / 0.03);
  border: 1px dashed oklch(1 0 0 / 0.12);
  color: var(--text-4);
}
.ach--locked { opacity: 0.7; }

/* ═══════════════════════════════════════════════════
   STATS
   ═══════════════════════════════════════════════════ */

.stat-top {
  padding: 18px;
  border-radius: var(--r-xl);
  background:
    radial-gradient(100% 100% at 100% 0%, oklch(0.55 0.22 var(--hue-primary) / 0.3), transparent 60%),
    linear-gradient(135deg, oklch(0.22 0.05 var(--hue-primary)), oklch(0.14 0.03 var(--hue-primary)));
  border: 1px solid oklch(1 0 0 / 0.08);
  margin-bottom: 14px;
}
.stat-top__row { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.stat-top__avatar {
  width: 48px; height: 48px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--plum), var(--rose));
  display: grid; place-items: center;
  color: white;
  font-family: var(--font-display);
  font-size: 18px; font-weight: 800;
}
.stat-top__name { font-family: var(--font-display); font-size: 17px; font-weight: 800; letter-spacing: -0.02em; }
.stat-top__level { font-size: 11px; color: var(--text-3); margin-top: 2px; letter-spacing: 0.04em; }
.stat-top__xp {
  margin-top: 10px;
  display: flex; justify-content: space-between; align-items: baseline;
}
.stat-top__xp-num {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -0.035em;
  font-variant-numeric: tabular-nums;
}
.stat-top__xp-next { font-size: 11px; color: var(--text-3); }

.stat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 16px;
}
.stat-kpi {
  padding: 14px;
  border-radius: var(--r-md);
  background: oklch(1 0 0 / 0.04);
  border: 1px solid oklch(1 0 0 / 0.07);
}
.stat-kpi__label {
  font-size: 10px; font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
  display: flex; align-items: center; gap: 5px;
}
.stat-kpi__label svg { width: 11px; height: 11px; }
.stat-kpi__num {
  font-family: var(--font-display);
  font-size: 26px; font-weight: 800;
  letter-spacing: -0.03em;
  margin-top: 8px;
  font-variant-numeric: tabular-nums;
}
.stat-kpi__delta { font-size: 11px; color: var(--ok); font-weight: 700; margin-top: 2px; }
.stat-kpi__delta--down { color: var(--alert); }
.stat-kpi__hint { font-size: 11px; color: var(--text-3); margin-top: 2px; }

/* activity heatmap */
.heat {
  padding: 16px;
  border-radius: var(--r-lg);
  background: oklch(1 0 0 / 0.04);
  border: 1px solid oklch(1 0 0 / 0.07);
  margin-bottom: 14px;
}
.heat__head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 14px; }
.heat__title { font-family: var(--font-display); font-size: 13px; font-weight: 800; letter-spacing: -0.01em; }
.heat__sub { font-size: 10px; color: var(--text-3); letter-spacing: 0.08em; text-transform: uppercase; }
.heat__grid {
  display: grid;
  grid-template-columns: repeat(16, 1fr);
  gap: 3px;
}
.heat__cell {
  aspect-ratio: 1;
  border-radius: 3px;
  background: oklch(1 0 0 / 0.04);
}
.heat__cell--1 { background: oklch(0.70 0.185 var(--hue-primary) / 0.18); }
.heat__cell--2 { background: oklch(0.70 0.185 var(--hue-primary) / 0.42); }
.heat__cell--3 { background: oklch(0.70 0.185 var(--hue-primary) / 0.70); }
.heat__cell--4 { background: oklch(0.70 0.185 var(--hue-primary) / 1); }
.heat__legend { display: flex; justify-content: space-between; margin-top: 10px; font-size: 10px; color: var(--text-4); letter-spacing: 0.05em; }
.heat__scale { display: inline-flex; gap: 2px; align-items: center; }
.heat__scale span { width: 9px; height: 9px; border-radius: 2px; }

/* breakdown bars */
.break {
  padding: 16px;
  border-radius: var(--r-lg);
  background: oklch(1 0 0 / 0.04);
  border: 1px solid oklch(1 0 0 / 0.07);
}
.break__title { font-family: var(--font-display); font-size: 13px; font-weight: 800; margin-bottom: 14px; }
.break__row { display: grid; grid-template-columns: 1fr auto; gap: 6px 10px; padding: 8px 0; }
.break__row + .break__row { border-top: 1px solid oklch(1 0 0 / 0.05); }
.break__name { font-size: 12px; color: var(--text-2); }
.break__val { font-family: var(--font-display); font-size: 12px; font-weight: 800; font-variant-numeric: tabular-nums; }
.break__bar { grid-column: 1/-1; height: 4px; border-radius: 3px; background: oklch(1 0 0 / 0.05); overflow: hidden; }
.break__bar > span { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--coral), var(--rose)); }

/* ═══════════════════════════════════════════════════
   SETTINGS
   ═══════════════════════════════════════════════════ */

.set-group-label {
  font-family: var(--font-display);
  font-size: 10px; font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-3);
  padding: 20px 4px 8px;
}
.set-card {
  background: oklch(1 0 0 / 0.035);
  border: 1px solid oklch(1 0 0 / 0.07);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.set-row {
  display: flex; align-items: center; gap: 12px;
  padding: 14px;
}
.set-row + .set-row { border-top: 1px solid oklch(1 0 0 / 0.05); }
.set-row__icon {
  width: 32px; height: 32px;
  border-radius: 10px;
  background: oklch(1 0 0 / 0.04);
  display: grid; place-items: center;
  color: var(--text-2);
  flex-shrink: 0;
}
.set-row__icon svg { width: 15px; height: 15px; }
.set-row__body { flex: 1; min-width: 0; }
.set-row__title { font-size: 14px; font-weight: 600; letter-spacing: -0.005em; }
.set-row__sub { font-size: 11px; color: var(--text-3); margin-top: 1px; }
.set-row__value { font-size: 13px; color: var(--text-3); font-variant-numeric: tabular-nums; }
.set-row__chev { color: var(--text-4); }
.set-row__chev svg { width: 16px; height: 16px; }

/* toggle switch */
.switch {
  position: relative;
  width: 42px; height: 24px;
  border-radius: 12px;
  background: oklch(1 0 0 / 0.1);
  border: 1px solid oklch(1 0 0 / 0.08);
  transition: background .15s;
  flex-shrink: 0;
}
.switch::after {
  content: '';
  position: absolute;
  top: 2px; left: 2px;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: #fff;
  transition: transform .2s var(--tap);
  box-shadow: 0 2px 6px oklch(0 0 0 / 0.35);
}
.switch--on { background: linear-gradient(180deg, var(--rose-hi), var(--rose-lo)); border-color: transparent; }
.switch--on::after { transform: translateX(18px); }

/* segmented */
.segmented {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 1fr;
  padding: 3px;
  border-radius: 12px;
  background: oklch(1 0 0 / 0.05);
  border: 1px solid oklch(1 0 0 / 0.06);
}
.seg {
  padding: 8px 10px;
  border-radius: 9px;
  font-size: 12px;
  font-weight: 700;
  color: var(--text-3);
  text-align: center;
}
.seg--active {
  background: oklch(1 0 0 / 0.08);
  color: var(--text-1);
  box-shadow: 0 2px 6px oklch(0 0 0 / 0.25);
}

/* ═══════════════════════════════════════════════════
   utility — iOS scaled artboard
   ═══════════════════════════════════════════════════ */

.phone-slot {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  background: oklch(0.08 0.015 340);
}

/* visual motifs — used as background art (SVG inlined) */
.motif {
  position: absolute; inset: 0;
  pointer-events: none;
  opacity: 0.9;
}

/* ═══════════════════════════════════════════════════
   Mini App runtime additions
   (поверх дизайн-системы — фуллскрин-контейнер, splash, тосты)
   ═══════════════════════════════════════════════════ */

html, body {
  height: 100%;
  height: 100dvh;
  margin: 0;
  overflow: hidden;
}

body {
  display: flex;
  flex-direction: column;
}

#root {
  flex: 1 1 0;
  min-height: 0;
  overflow: hidden;
}

#root {
  display: flex;
  justify-content: center;
  background: oklch(0.08 0.015 340);
}

/* В Telegram Mini App рендерим .dc на весь viewport, центрируя на широких экранах */
#root > .dc {
  width: 100%;
  max-width: 480px;
  height: 100%;
}

/* boot splash до загрузки Babel/React */
.boot-splash {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
}
.boot-splash__spinner {
  width: 28px; height: 28px;
  border: 2px solid oklch(1 0 0 / 0.1);
  border-top-color: var(--rose);
  border-radius: 50%;
  animation: dc-spin 0.8s linear infinite;
}
@keyframes dc-spin { to { transform: rotate(360deg); } }

/* generic loader */
.loader {
  display: grid;
  place-items: center;
  padding: 60px 20px;
  color: var(--text-3);
}
.loader__sp {
  width: 28px; height: 28px;
  border: 2px solid oklch(1 0 0 / 0.1);
  border-top-color: var(--rose);
  border-radius: 50%;
  animation: dc-spin 0.8s linear infinite;
}

/* error state */
.dc-error {
  margin: 24px;
  padding: 16px;
  background: oklch(0.68 0.22 28 / 0.1);
  border: 1px solid oklch(0.68 0.22 28 / 0.3);
  border-radius: 14px;
  color: var(--text-2);
  font-size: 13px;
  text-align: center;
}

/* toast */
.dc-toast {
  position: fixed;
  bottom: calc(env(safe-area-inset-bottom, 0) + 96px);
  left: 50%;
  transform: translateX(-50%) translateY(120%);
  background: oklch(0.22 0.025 340 / 0.96);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid oklch(1 0 0 / 0.1);
  border-radius: 14px;
  padding: 12px 18px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
  z-index: 1000;
  transition: transform 0.3s var(--tap);
  max-width: 88vw;
  text-align: center;
  pointer-events: none;
  box-shadow: var(--sh-pop);
}
.dc-toast--show { transform: translateX(-50%) translateY(0); }

/* динамический контент урока — стилизуем теги, что приходят из бэкенда */
.lesson__content { font-size: 14.5px; line-height: 1.65; color: var(--text-2); }
.lesson__content b, .lesson__content strong { color: var(--text-1); font-weight: 700; }
.lesson__content i, .lesson__content em { color: var(--rose-hi); font-style: normal; }
.lesson__content br + br { display: block; content: ''; margin-top: 8px; }

/* tab bar — кликабельность */
.dc-tab { cursor: pointer; -webkit-user-select: none; user-select: none; }
.dc-tab:active { transform: scale(0.96); }
