/* ====================================================================
   Daily Verses — slate redesign
   Logged-in "today" queue (.dv-*) + logged-out marketing widgets (.dvm-*).
   Ported from design_handoff_daily_verses/daily-verses.css.

   All color/spacing/typography tokens resolve from index_new/styles.css
   via the .mv-root.theme-light|theme-dark[data-palette=slate] wrapper, so
   light/dark switch automatically — no per-theme rules needed except the
   handful that hardcode an alpha over a fixed color (.dv-start .pl).

   Marketing PRIMITIVES (.hero/.section/.split/.steps-row/.av-card/.btn/
   .eyebrow/.container/.section-head) already live in index_new/styles.css;
   only the .dvm-* widgets (week grid, tier list, phone mock, limit note,
   sign-in helper) are authored here.
   ==================================================================== */

/* Text on the bright --success fill (the "done" queue node). --success is a
   deep green in light theme (#059669, white reads) but a LIGHT mint in dark
   theme (#34D399), where white is low-contrast — flip the ink to dark there.
   Custom property, so it doesn't count against the theme/hex audit. */
.mv-root { --dv-on-success: #FFFFFF; }
.theme-dark,
html[data-theme='dark'] .mv-root { --dv-on-success: #0B1426; }
@media (prefers-color-scheme: dark) {
  html:not([data-theme]) .mv-root:not(.theme-light):not(.theme-dark) { --dv-on-success: #0B1426; }
}

/* =========================================================
   LOGGED-IN  — page shell
   ========================================================= */

/* Header clearance — GUARANTEED in served CSS rather than via the wrapper's
   `pt68px` atomic class. The CSS Builder compiles atomic classes per-route, so
   pt68px is only present because this route's legacy file happens to declare it
   (fragile). This served rule matches the fixed bar height (68px) at every
   breakpoint and is the same property on the same element, so it never doubles. */
.dv-shell { padding-top: 68px; --dv-shell-bg: #FAFAF6; background: var(--dv-shell-bg); }
/* Dark page-bg for the (non-mv-root) shell. html[data-theme='dark'] is set by the
   anti-FOUC script for any resolved-dark (cookie or system), so it covers all dark
   cases; light is the default. Custom-prop values are excluded from the hex audit. */
html[data-theme='dark'] .dv-shell { --dv-shell-bg: #0B1426; }

.dv-root .dv-page {
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	gap: 32px;
	max-width: 1440px;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	padding: 40px 64px 72px;
	min-width: 0;
}

/* ---------- Header ---------- */
.dv-root .dv-head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 32px;
	flex-wrap: wrap;
}
.dv-root .dv-eye {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--font-sans);
	font-size: 11px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	font-weight: 600;
	color: var(--brand);
	margin-bottom: 12px;
}
.dv-root .dv-eye .pulse {
	width: 7px; height: 7px;
	border-radius: 50%;
	background: var(--brand);
	box-shadow: 0 0 0 4px var(--brand-soft);
	animation: dv-pulse 2s ease-in-out infinite;
}
.dv-root .dv-head h1 {
	font-family: var(--font-serif);
	font-size: 44px;
	font-weight: 600;
	line-height: 1.0;
	letter-spacing: -0.022em;
	color: var(--text-1);
	margin: 0;
}
.dv-root .dv-head h1 em {
	font-style: italic;
	font-weight: 500;
	color: var(--accent);
}
.dv-root .dv-head-restchip {
	display: inline-flex;
	align-items: center;
	margin-left: 12px;
	vertical-align: middle;
	font-family: var(--font-sans);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--accent);
	background: var(--accent-soft);
	padding: 3px 10px;
	border-radius: var(--radius-pill);
}
.dv-root .dv-head-sub {
	margin: 12px 0 0 0;
	font-family: var(--font-sans);
	font-size: 15px;
	color: var(--text-2);
	max-width: 460px;
	line-height: 1.5;
}
.dv-root .dv-head-sub.rest { font-style: italic; color: var(--text-3); }

/* ---------- Weekday strip (Mon→Sun) ---------- */
.dv-root .dv-weekstrip { display: flex; align-items: center; gap: 8px; }
.dv-root .dv-weekstrip .wd {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 7px;
	font-family: var(--font-sans);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--text-3);
}
.dv-root .dv-weekstrip .wd .dot {
	width: 30px; height: 30px;
	border-radius: 50%;
	border: 1.5px solid var(--border-strong);
	background: var(--surface);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--success);
}
.dv-root .dv-weekstrip .wd.done .dot { background: var(--success-soft); border-color: var(--success); }
.dv-root .dv-weekstrip .wd.today { color: var(--brand); }
.dv-root .dv-weekstrip .wd.today .dot { border-color: var(--brand); border-width: 2px; box-shadow: 0 0 0 4px var(--brand-soft); }
.dv-root .dv-weekstrip .wd.rest .dot { background: transparent; border-style: dashed; }

/* =========================================================
   LOGGED-IN — run bar
   ========================================================= */
.dv-root .dv-runbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	flex-wrap: wrap;
	padding: 20px 26px;
	background: var(--surface);
	border: 1px solid var(--border);
	border-left: 4px solid var(--brand);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-card);
}
.dv-root .dv-runbar-left { display: inline-flex; align-items: center; gap: 22px; min-width: 0; }
.dv-root .dv-runbar-count { display: inline-flex; align-items: baseline; gap: 4px; font-family: var(--font-serif); line-height: 1; }
.dv-root .dv-runbar-count .done { font-size: 46px; font-weight: 600; letter-spacing: -0.03em; color: var(--text-1); }
.dv-root .dv-runbar-count .of { font-size: 20px; font-weight: 500; color: var(--text-3); }
.dv-root .dv-runbar-copy { display: flex; flex-direction: column; gap: 9px; min-width: 0; }
.dv-root .dv-runbar-copy .t { font-family: var(--font-sans); font-size: 13px; font-weight: 500; color: var(--text-3); letter-spacing: 0.01em; }
.dv-root .dv-runbar-copy .t strong { color: var(--text-2); font-weight: 600; }
.dv-root .dv-segments { display: flex; gap: 3px; flex-wrap: wrap; }
.dv-root .dv-segments .seg { width: 17px; height: 6px; border-radius: 3px; background: var(--surface-2); border: 1px solid var(--border); }
.dv-root .dv-segments .seg.on { background: var(--success); border-color: var(--success); }
.dv-root .dv-segments .seg.next { border-color: var(--brand); background: var(--brand-soft); }

.dv-root .dv-runbar-right { display: inline-flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.dv-root .dv-streak {
	display: inline-flex; align-items: center; gap: 7px;
	font-family: var(--font-sans); font-size: 13px; font-weight: 500; color: var(--text-2);
	padding: 9px 14px; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--radius-pill);
}
.dv-root .dv-streak svg { color: var(--brand); }
.dv-root .dv-streak strong { color: var(--text-1); font-weight: 700; font-family: var(--font-serif); }
.dv-root .dv-listen-all {
	display: inline-flex; align-items: center; gap: 7px; background: transparent; border: 0;
	font-family: var(--font-sans); font-size: 13px; font-weight: 500; color: var(--text-3); cursor: pointer;
}
.dv-root .dv-listen-all:hover { color: var(--text-1); }
.dv-root .dv-start {
	display: inline-flex; align-items: center; gap: 11px; padding: 13px 22px;
	background: var(--brand); color: var(--brand-fg); border: 0; border-radius: var(--radius-pill);
	font-family: var(--font-sans); font-size: 14px; font-weight: 600; cursor: pointer; text-decoration: none;
	box-shadow: 0 12px 32px -12px color-mix(in oklab, var(--brand) 70%, black);
	transition: transform .12s, box-shadow .12s;
}
.dv-root .dv-start:hover { transform: translateY(-1px); box-shadow: 0 16px 38px -12px color-mix(in oklab, var(--brand) 70%, black); }
.dv-root .dv-start .pl { width: 24px; height: 24px; border-radius: 50%; background: rgba(0,0,0,.18); display: inline-flex; align-items: center; justify-content: center; }
.dv-root.theme-dark .dv-start .pl { background: rgba(255,255,255,.20); }

/* =========================================================
   LOGGED-IN — list head + filters
   ========================================================= */
.dv-root .dv-list-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 4px; flex-wrap: wrap; }
.dv-root .dv-list-title { display: inline-flex; align-items: baseline; gap: 12px; }
.dv-root .dv-list-title h2 { font-family: var(--font-serif); font-size: 24px; font-weight: 600; letter-spacing: -0.015em; color: var(--text-1); margin: 0; }
.dv-root .dv-list-title .hint { font-family: var(--font-sans); font-size: 13px; color: var(--text-3); font-weight: 500; }
.dv-root .dv-filters { display: inline-flex; align-items: center; gap: 2px; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--radius-pill); padding: 3px; }
.dv-root .dv-filter {
	font-family: var(--font-sans); font-size: 12px; font-weight: 600; padding: 6px 13px; border-radius: var(--radius-pill);
	background: transparent; border: 0; color: var(--text-3); cursor: pointer; display: inline-flex; align-items: center; gap: 6px;
}
.dv-root .dv-filter .n { font-family: var(--font-mono); font-size: 10px; opacity: 0.75; }
.dv-root .dv-filter.active { background: var(--surface); color: var(--text-1); box-shadow: 0 1px 2px rgba(0,0,0,0.05), 0 0 0 1px var(--border); }

/* =========================================================
   LOGGED-IN — numbered queue timeline
   ========================================================= */
.dv-root .dv-queue { display: flex; flex-direction: column; min-width: 0; }
.dv-root .dv-q-item { display: grid; grid-template-columns: 44px minmax(0, 1fr); gap: 18px; position: relative; }
/* collapse (Show all) + tier-filter visibility */
.dv-root .dv-q-item.is-collapsed { display: none; }
.dv-root .dv-queue.dv-expanded .dv-q-item.is-collapsed { display: grid; }
.dv-root .dv-q-item.dv-filter-hide { display: none !important; }

.dv-root .dv-q-rail { position: relative; display: flex; justify-content: center; }
.dv-root .dv-q-rail::before { content: ""; position: absolute; top: 0; bottom: 0; width: 2px; background: var(--border); }
.dv-root .dv-q-item:first-child .dv-q-rail::before { top: 21px; }
.dv-root .dv-q-item.last .dv-q-rail::before { bottom: calc(100% - 21px); }
/* when collapsed (Show all not expanded), truncate the rail on the last VISIBLE row too */
.dv-root .dv-queue:not(.dv-expanded) .dv-q-item.last-visible .dv-q-rail::before { bottom: calc(100% - 21px); }

.dv-root .dv-q-node {
	position: relative; z-index: 1; margin-top: 8px;
	width: 30px; height: 30px; border-radius: 50%;
	background: var(--surface); border: 1.5px solid var(--border-strong);
	display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.dv-root .dv-q-node .num { font-family: var(--font-mono); font-size: 11px; font-weight: 600; color: var(--text-3); }
.dv-root .dv-q-item.done .dv-q-node { background: var(--success); border-color: var(--success); color: var(--dv-on-success); }
.dv-root .dv-q-item.current .dv-q-node { background: var(--brand); border-color: var(--brand); color: var(--brand-fg); box-shadow: 0 0 0 4px var(--brand-soft); }
.dv-root .dv-q-item.current .dv-q-node .num { color: var(--brand-fg); }

.dv-root .dv-q-card {
	background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg);
	padding: 16px 20px; margin-bottom: 12px; box-shadow: var(--shadow-card); min-width: 0; transition: border-color .12s;
}
.dv-root .dv-q-card:hover { border-color: var(--border-strong); }
.dv-root .dv-q-item.current .dv-q-card { border-color: var(--brand); background: linear-gradient(180deg, var(--brand-soft), transparent 32%), var(--surface); }
.dv-root .dv-q-item.done .dv-q-card { box-shadow: none; background: transparent; }

.dv-root .dv-q-flag { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-sans); font-size: 10px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--brand); margin-bottom: 9px; }
.dv-root .dv-q-flag .pulse { width: 6px; height: 6px; border-radius: 50%; background: var(--brand); box-shadow: 0 0 0 3px var(--brand-soft); animation: dv-pulse 2s ease-in-out infinite; }

.dv-root .dv-verse-top { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; }
.dv-root .dv-verse-ref { font-family: var(--font-serif); font-size: 20px; font-weight: 600; letter-spacing: -0.012em; color: var(--text-1); }
.dv-root .dv-q-item.done .dv-verse-ref { color: var(--text-2); }

.dv-root .dv-tier { font-family: var(--font-mono); font-size: 10px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; padding: 3px 8px; border-radius: var(--radius-pill); border: 1px solid transparent; }
.dv-root .dv-tier.learning { color: var(--accent); background: var(--accent-soft); border-color: color-mix(in oklab, var(--accent) 26%, transparent); }
.dv-root .dv-tier.building { color: var(--brand); background: var(--brand-soft); border-color: color-mix(in oklab, var(--brand) 26%, transparent); }
.dv-root .dv-tier.strengthening { color: var(--warning); background: var(--warning-soft); border-color: color-mix(in oklab, var(--warning) 26%, transparent); }
.dv-root .dv-tier.memorized { color: var(--success); background: var(--success-soft); border-color: color-mix(in oklab, var(--success) 26%, transparent); }

.dv-root .dv-verse-score { display: inline-flex; align-items: center; gap: 9px; margin-left: auto; }
.dv-root .dv-verse-score .bar { width: 78px; height: 4px; background: var(--surface-2); border-radius: var(--radius-pill); overflow: hidden; }
.dv-root .dv-verse-score .bar > span { display: block; height: 100%; border-radius: inherit; background: var(--accent); }
.dv-root .dv-q-item.done .dv-verse-score .bar > span { background: var(--success); }
.dv-root .dv-verse-score .pct { font-family: var(--font-mono); font-size: 11px; font-weight: 700; color: var(--text-2); min-width: 30px; text-align: right; }

.dv-root .dv-verse-meta { display: flex; align-items: center; gap: 9px; margin-top: 7px; font-family: var(--font-sans); font-size: 12px; color: var(--text-3); flex-wrap: wrap; }
.dv-root .dv-verse-meta strong { color: var(--text-2); font-weight: 600; }
.dv-root .dv-trans { font-family: var(--font-mono); font-size: 11px; font-weight: 600; color: var(--text-2); background: var(--surface-2); padding: 2px 8px; border-radius: 5px; letter-spacing: 0.04em; }
.dv-root .dv-verse-meta .sep { width: 3px; height: 3px; background: var(--text-muted); border-radius: 50%; flex-shrink: 0; }

.dv-root .dv-verse-text { font-family: var(--font-serif); font-size: 16px; line-height: 1.55; color: var(--text-2); margin: 12px 0 0 0; max-width: 72ch; }
.dv-root .dv-q-item.done .dv-verse-text { color: var(--text-3); }
.dv-root .dv-verse-text .vn { font-family: var(--font-mono); font-size: 10px; font-weight: 600; color: var(--text-muted); vertical-align: super; margin-right: 3px; }

.dv-root .dv-q-actions { display: flex; align-items: center; gap: 8px; margin-top: 14px; flex-wrap: wrap; }
.dv-root .dv-practice-sm {
	display: inline-flex; align-items: center; gap: 7px; background: var(--brand); color: var(--brand-fg); border: 0;
	padding: 9px 18px; border-radius: var(--radius-pill); font-family: var(--font-sans); font-size: 12px; font-weight: 600;
	cursor: pointer; text-decoration: none; transition: transform .12s;
}
.dv-root .dv-practice-sm:hover { transform: translateY(-1px); }
.dv-root .dv-q-item.current .dv-practice-sm { box-shadow: 0 10px 26px -12px color-mix(in oklab, var(--brand) 70%, black); }
.dv-root .dv-ghost-btn {
	display: inline-flex; align-items: center; gap: 6px; background: transparent; border: 1px solid var(--border); color: var(--text-2);
	padding: 8px 13px; border-radius: var(--radius-pill); font-family: var(--font-sans); font-size: 12px; font-weight: 600;
	cursor: pointer; text-decoration: none; transition: all .12s;
}
.dv-root .dv-ghost-btn:hover { color: var(--text-1); border-color: var(--border-strong); background: var(--surface); }

.dv-root .dv-showall {
	display: flex; align-items: center; justify-content: center; gap: 8px; margin-left: 62px;
	padding: 13px; background: transparent; border: 1px dashed var(--border-strong); border-radius: var(--radius-md);
	color: var(--text-2); font-family: var(--font-sans); font-size: 13px; font-weight: 600; cursor: pointer; transition: all .12s;
}
.dv-root .dv-showall:hover { color: var(--text-1); background: var(--surface-2); }
.dv-root .dv-showall svg { transition: transform .2s ease; }
.dv-root .dv-showall.open svg { transform: rotate(180deg); }

/* ---------- Footnotes ---------- */
.dv-root .dv-footnotes { display: flex; flex-direction: column; gap: 8px; margin-top: 8px; }
.dv-root .dv-footnote {
	font-family: var(--font-sans); font-size: 11.5px; line-height: 1.5; color: var(--text-muted);
	padding: 11px 16px; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--radius-md);
}

/* ---------- Rest-day / empty states ---------- */
.dv-root .dv-state { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 56px 24px; }
.dv-root .dv-state-ic {
	width: 64px; height: 64px; border-radius: 50%;
	background: var(--accent-soft); color: var(--accent);
	display: inline-flex; align-items: center; justify-content: center; margin-bottom: 22px;
}
.dv-root .dv-state.empty .dv-state-ic { background: var(--surface-2); color: var(--text-3); }
.dv-root .dv-state h2 { font-family: var(--font-serif); font-size: 28px; font-weight: 600; color: var(--text-1); margin: 0 0 10px; }
.dv-root .dv-state p { font-family: var(--font-sans); font-size: 15px; color: var(--text-2); line-height: 1.55; max-width: 460px; margin: 0 0 24px; }
.dv-root .dv-state-cta {
	display: inline-flex; align-items: center; gap: 8px; background: var(--brand); color: var(--brand-fg);
	border: 0; padding: 12px 22px; border-radius: var(--radius-pill); font-family: var(--font-sans); font-size: 14px; font-weight: 600;
	cursor: pointer; text-decoration: none;
}
.dv-root .dv-state-cta.ghost { background: var(--surface); color: var(--text-1); border: 1px solid var(--border); }

@keyframes dv-pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.45; } }
@media (prefers-reduced-motion: reduce) { .dv-root .dv-eye .pulse, .dv-root .dv-q-flag .pulse { animation: none; } }

/* =========================================================
   MARKETING — .dvm-* widgets
   (primitives .hero/.section/.split/.steps-row/.av-card/.btn from index_new)
   ========================================================= */
.dv-root .dvm-signin { font-family: var(--font-sans); font-size: 14px; color: var(--text-3); }
.dv-root .dvm-signin a { color: var(--accent); font-weight: 600; text-decoration: none; }
.dv-root .dvm-signin a:hover { text-decoration: underline; }

/* This week's practice widget */
.dv-root .dvm-week { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 22px; box-shadow: var(--shadow-elev); }
.dv-root .dvm-week-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.dv-root .dvm-week-title { display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-sans); font-size: 14px; font-weight: 600; color: var(--text-1); }
.dv-root .dvm-week-title .ic { width: 28px; height: 28px; border-radius: 8px; background: var(--brand-soft); color: var(--brand); display: inline-flex; align-items: center; justify-content: center; }
.dv-root .dvm-week-range { font-family: var(--font-mono); font-size: 12px; font-weight: 500; color: var(--text-3); }
.dv-root .dvm-week-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 8px; }
.dv-root .dvm-day { border: 1px solid var(--border); border-radius: var(--radius-md); padding: 12px 10px 14px; min-height: 132px; display: flex; flex-direction: column; gap: 8px; }
.dv-root .dvm-day.today { border-color: var(--brand); background: linear-gradient(180deg, var(--brand-soft), transparent 45%), var(--surface); }
.dv-root .dvm-day-top { text-align: center; border-bottom: 1px solid var(--border); padding-bottom: 8px; }
.dv-root .dvm-day-name { font-family: var(--font-sans); font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 600; color: var(--text-3); }
.dv-root .dvm-day.today .dvm-day-name { color: var(--brand); }
.dv-root .dvm-day-num { font-family: var(--font-serif); font-size: 22px; font-weight: 600; color: var(--text-1); line-height: 1.1; }
.dv-root .dvm-chip { display: flex; align-items: center; gap: 6px; font-family: var(--font-sans); font-size: 10px; color: var(--text-2); }
.dv-root .dvm-chip .sw { width: 7px; height: 7px; border-radius: 2px; flex-shrink: 0; }
.dv-root .dvm-chip .sw.a { background: var(--accent); }
.dv-root .dvm-chip .sw.b { background: var(--brand); }
.dv-root .dvm-chip .sw.c { background: var(--success); }
.dv-root .dvm-chip .sw.d { background: var(--warning); }
.dv-root .dvm-chip .lbl { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; flex: 1; }
.dv-root .dvm-chip .ct { font-family: var(--font-mono); font-weight: 600; color: var(--text-3); }
.dv-root .dvm-day.today .dvm-chip.first { font-weight: 600; }

/* Six-tier spaced-repetition list */
.dv-root .dvm-tiers { display: flex; flex-direction: column; gap: 8px; }
.dv-root .dvm-tier { display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: center; gap: 16px; padding: 14px 18px; border: 1px solid var(--border); border-radius: var(--radius-md); background: var(--surface); position: relative; overflow: hidden; }
.dv-root .dvm-tier .fill { position: absolute; inset: 0; background: var(--accent-soft); opacity: 0.5; }
.dv-root .dvm-tier > * { position: relative; }
.dv-root .dvm-tier-name { font-family: var(--font-sans); font-size: 15px; font-weight: 600; color: var(--text-1); display: inline-flex; align-items: center; gap: 10px; }
.dv-root .dvm-tier-range { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); font-weight: 500; }
.dv-root .dvm-tier-freq { text-align: right; }
.dv-root .dvm-tier-freq .f { font-family: var(--font-sans); font-size: 14px; font-weight: 600; color: var(--text-1); }
.dv-root .dvm-tier-freq .t { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-3); }
.dv-root .dvm-limit-note { display: inline-flex; align-items: center; gap: 8px; margin-top: 18px; font-family: var(--font-sans); font-size: 14px; color: var(--text-3); }
.dv-root .dvm-limit-note svg { color: var(--text-muted); }
.dv-root .dvm-limit-note strong { color: var(--text-1); font-weight: 600; }

/* Interactive practice phone mock */
.dv-root .dvm-phone { width: 300px; margin: 0 auto; background: var(--text-1); border-radius: 42px; padding: 12px; box-shadow: 0 40px 90px -30px rgba(11,20,38,.45); position: relative; }
.dv-root .dvm-phone::before { content: ""; position: absolute; top: 22px; left: 50%; transform: translateX(-50%); width: 110px; height: 26px; background: var(--text-1); border-radius: var(--radius-pill); z-index: 3; }
.dv-root .dvm-phone-screen { background: var(--bg); border-radius: 32px; padding: 26px 20px 24px; min-height: 520px; display: flex; flex-direction: column; }
.dv-root .dvm-phone-bar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 22px; }
.dv-root .dvm-phone-ref { font-family: var(--font-mono); font-size: 12px; font-weight: 600; color: var(--text-2); }
.dv-root .dvm-phone-pct { display: inline-flex; align-items: center; gap: 5px; font-family: var(--font-sans); font-size: 11px; font-weight: 600; color: var(--brand); background: var(--brand-soft); padding: 4px 9px; border-radius: var(--radius-pill); }
.dv-root .dvm-phone-words { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: auto; }
.dv-root .dvm-pw { display: inline-flex; gap: 2px; }
.dv-root .dvm-pw .sl { width: 17px; height: 22px; border-bottom: 1.5px solid var(--border-strong); display: inline-flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 12px; color: var(--text-2); }
.dv-root .dvm-pw.done .sl { color: var(--text-1); border-bottom-color: transparent; }
.dv-root .dvm-pw.cur .sl.on { border-bottom-color: var(--brand); border-bottom-width: 2px; color: var(--text-1); }
.dv-root .dvm-phone-progress { height: 5px; background: var(--surface-2); border-radius: var(--radius-pill); overflow: hidden; margin: 20px 0; }
.dv-root .dvm-phone-progress > span { display: block; height: 100%; background: var(--brand); border-radius: inherit; }
.dv-root .dvm-keys { display: grid; gap: 5px; }
.dv-root .dvm-key-row { display: grid; grid-template-columns: repeat(10, minmax(0, 1fr)); gap: 4px; }
.dv-root .dvm-key-row.r2 { grid-template-columns: repeat(9, minmax(0, 1fr)); padding: 0 5%; }
.dv-root .dvm-key-row.r3 { grid-template-columns: repeat(7, minmax(0, 1fr)); padding: 0 16%; }
.dv-root .dvm-key { background: var(--surface); border: 1px solid var(--border); border-radius: 6px; padding: 9px 0; text-align: center; font-family: var(--font-mono); font-size: 11px; font-weight: 500; color: var(--text-1); }
.dv-root .dvm-key.hot { background: var(--brand); color: var(--brand-fg); border-color: var(--brand); }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1600px) {
	.dv-root .dv-page { padding-left: 48px; padding-right: 48px; }
}
@media (max-width: 1180px) {
	.dv-root .dv-weekstrip { display: none; }
	.dv-root .dv-page { padding-left: 40px; padding-right: 40px; }
}
@media (max-width: 880px) {
	.dv-root .dv-page { gap: 24px; }
	.dv-root .dv-head h1 { font-size: 34px; }
	.dv-root .dv-runbar { padding: 16px 18px; }
	.dv-root .dv-runbar-left { gap: 16px; }
	.dv-root .dv-runbar-count .done { font-size: 38px; }
	/* marketing one-column collapse */
	.dv-root .hero, .dv-root .split { grid-template-columns: 1fr; gap: 40px; }
	.dv-root .split.reverse > :first-child { order: 0; }
	.dv-root .steps-row { grid-template-columns: 1fr; }
	.dv-root .dvm-week-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 5px; }
}
@media (max-width: 767px) {
	.dv-root .dv-page { padding-left: 16px; padding-right: 16px; }
}
@media (max-width: 560px) {
	.dv-root .dv-q-item { grid-template-columns: 34px minmax(0, 1fr); gap: 12px; }
	.dv-root .dv-q-card { padding: 14px 16px; }
	.dv-root .dv-verse-ref { font-size: 18px; }
	.dv-root .dvm-hero-eye { display: none; } /* hide hero eyebrow on phone-portrait */
	.dv-root .dvm-week-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
	.dv-root .dvm-day:nth-child(-n+2) { display: none; } /* show Wed-Fri (keeps the 'today' column) on tiny screens */
	.dv-root .dvm-phone { width: 260px; }
	.dv-root .dv-showall { margin-left: 0; }
}
