/* ============================================================================
 * Critical-Path Dashboard — Essential Audio / AV Ninjas command-center system.
 * Tokens + chrome from tools/projects-gantt (mirrors the Inbox Triage tool).
 * Dark-first, indigo accent, 13px system type, color = signal.
 * ========================================================================== */
:root {
  --bg: #0d1017; --surface: #161b22; --surface-2: #1b2230; --surface-3: #212a3a;
  --border: #232b39; --text: #f5f9fd; --dim: #aab4c0; --faint: #7a8696;
  --accent: #6366f1; --accent-2: #22d3ee; --green: #3fb950; --red: #f85149;
  --amber: #d29922; --violet: #a371f7; --cyan: #39c5cf;
  --radius: 10px; --radius-sm: 6px; --radius-pill: 20px;
  --scrollbar-track: var(--surface); --scrollbar-thumb: #3a4456; --scrollbar-thumb-hover: #4c596e;
  --space-xs: 4px; --space-sm: 8px; --space-md: 11px; --space-lg: 14px; --space-xl: 18px; --space-2xl: 22px;
  --font-stack: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --text-base: 13px; --line-base: 1.45; --text-kpi: 24px; --text-logo: 15px; --text-h3: 15px;
  --text-label: 11px; --text-eyebrow: 11px; --text-table-head: 10.5px; --text-chip: 9.5px;
  --content-max: 1040px; font-synthesis: none;
}
[data-theme="light"] {
  --bg: #f4f6fa; --surface: #ffffff; --surface-2: #f7f9fc; --surface-3: #eef2f8;
  --border: #e2e8f0; --text: #0a0d12; --dim: #3c4656; --faint: #5f6a7c;
  --scrollbar-track: var(--surface-2); --scrollbar-thumb: #9aa6b6; --scrollbar-thumb-hover: #7e8b9d;
}
* { box-sizing: border-box; }
html, body { margin: 0; min-height: 100%; }
body { background: var(--bg); color: var(--text); font-family: var(--font-stack); font-size: var(--text-base); line-height: var(--line-base); -webkit-font-smoothing: antialiased; }
* { scrollbar-width: thin; scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track); }
::-webkit-scrollbar { width: 13px; height: 13px; }
::-webkit-scrollbar-track { background: var(--scrollbar-track); }
::-webkit-scrollbar-thumb { background: var(--scrollbar-thumb); border-radius: 7px; border: 3px solid var(--scrollbar-track); background-clip: padding-box; }
.tnum { font-variant-numeric: tabular-nums; }
.eyebrow { font-size: var(--text-eyebrow); font-weight: 700; text-transform: uppercase; letter-spacing: .10em; color: var(--dim); }

/* ---- a11y utilities ---- */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }
.skip-link { position: absolute; left: 8px; top: -48px; z-index: 100; background: var(--surface); color: var(--text); border: 1px solid var(--accent); border-radius: var(--radius-sm); padding: 8px 14px; font-size: 13px; font-weight: 600; text-decoration: none; transition: top .15s ease; }
.skip-link:focus { top: 8px; outline: 2px solid var(--accent); outline-offset: 2px; }
.table-scroll { overflow-x: auto; }
.pagenav a:focus-visible, .acard--link:focus-visible, .hub-link:focus-visible, .mnode:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* ---- topbar + page nav ---- */
.topbar { background: var(--surface); border-bottom: 1px solid var(--border); padding: var(--space-md) var(--space-2xl); position: sticky; top: 0; z-index: 30; }
.topbar-inner { width: 100%; max-width: var(--content-max); margin: 0 auto; display: flex; align-items: center; gap: var(--space-lg); }
.logo { display: flex; align-items: center; gap: 9px; font-size: var(--text-logo); font-weight: 700; color: var(--text); text-decoration: none; }
.logo:hover span { color: var(--text); }
.pagenav a.hub-link { color: var(--faint); font-weight: 600; }
.pagenav a.hub-link:hover { color: var(--accent); }
.logo .dot { width: 10px; height: 10px; border-radius: 3px; background: var(--accent); box-shadow: 0 0 12px var(--accent); }
.logo span { font-weight: 400; color: var(--dim); font-size: var(--text-base); }
.topbar-right { margin-left: auto; display: flex; align-items: center; gap: var(--space-sm); }
.pagenav { background: var(--surface-2); border-bottom: 1px solid var(--border); padding: 0 var(--space-2xl); position: sticky; top: 45px; z-index: 29; }
.pagenav-inner { max-width: var(--content-max); margin: 0 auto; display: flex; gap: var(--space-xs); flex-wrap: wrap; }
.pagenav a { display: inline-flex; align-items: center; text-decoration: none; color: var(--dim); font-size: 12.5px; padding: var(--space-md); border-bottom: 2px solid transparent; margin-bottom: -1px; }
.pagenav a:hover { color: var(--text); }
.pagenav a.active { color: var(--text); border-bottom-color: var(--accent); font-weight: 600; }

/* ---- buttons + badges ---- */
.btn { display: inline-flex; align-items: center; gap: 6px; font: inherit; font-size: 12px; color: var(--dim); background: var(--surface); border: 1px solid var(--border); border-radius: 8px; padding: 6px 11px; cursor: pointer; }
.btn:hover { color: var(--text); border-color: var(--faint); }
.btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }
.btn.small { padding: 4px 9px; font-size: 11.5px; }
.badge { display: inline-flex; align-items: center; gap: var(--space-xs); font-size: var(--text-table-head); font-weight: 700; text-transform: uppercase; letter-spacing: .06em; padding: 3px 9px; border-radius: var(--radius-pill); color: var(--dim); border: 1px solid var(--border); background: var(--surface); font-variant-numeric: tabular-nums; }
.badge.ok { color: var(--green); border-color: color-mix(in srgb, var(--green) 40%, transparent); background: color-mix(in srgb, var(--green) 12%, transparent); }
.badge.bad { color: var(--red); border-color: color-mix(in srgb, var(--red) 40%, transparent); background: color-mix(in srgb, var(--red) 12%, transparent); }
.badge.warn { color: var(--amber); border-color: color-mix(in srgb, var(--amber) 40%, transparent); background: color-mix(in srgb, var(--amber) 12%, transparent); }
.badge.live { color: var(--accent); border-color: color-mix(in srgb, var(--accent) 40%, transparent); background: color-mix(in srgb, var(--accent) 12%, transparent); }
.badge.cyan { color: var(--cyan); border-color: color-mix(in srgb, var(--cyan) 40%, transparent); background: color-mix(in srgb, var(--cyan) 12%, transparent); }
.badge.violet { color: var(--violet); border-color: color-mix(in srgb, var(--violet) 40%, transparent); background: color-mix(in srgb, var(--violet) 12%, transparent); }

/* ---- page wrap + head ---- */
.wrap { max-width: var(--content-max); margin: 0 auto; padding: var(--space-2xl); }
.page-head h1 { margin: 2px 0 var(--space-xs); font-size: 21px; font-weight: 700; letter-spacing: -.01em; }
.page-head p { margin: 0; color: var(--dim); font-size: 13px; max-width: 760px; }
.group-eyebrow { margin: var(--space-2xl) 0 var(--space-sm); font-size: 12px; color: var(--accent); }

/* ---- KPI summary + overall bar ---- */
.summary { display: flex; flex-wrap: wrap; gap: var(--space-md); margin: var(--space-xl) 0 var(--space-md); }
.kpi { flex: 1; min-width: 110px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: var(--space-lg); }
.kpi .num { font-size: var(--text-kpi); font-weight: 700; font-variant-numeric: tabular-nums; line-height: 1; }
.kpi .lbl { margin-top: var(--space-sm); font-size: var(--text-table-head); text-transform: uppercase; letter-spacing: .06em; color: var(--faint); font-weight: 700; }
.kpi.pct .num { color: var(--accent); } .kpi.done .num { color: var(--green); } .kpi.prog .num { color: var(--amber); } .kpi.todo .num { color: var(--dim); } .kpi.block .num { color: var(--red); }
.overall { margin: 0 0 var(--space-2xl); }
.bar { height: 8px; border-radius: var(--radius-pill); background: var(--surface-3); overflow: hidden; display: flex; }
.bar > i, .lane-bar > i { display: block; height: 100%; transition: width .6s ease; }
.bar > i.s-done, .lane-bar > i.s-done { background: var(--green); }
.bar > i.s-prog, .lane-bar > i.s-prog { background: var(--amber); }
.bar > i.s-block, .lane-bar > i.s-block { background: var(--red); }

/* ---- collapsible lane ---- */
.lane { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); margin-bottom: var(--space-md); overflow: hidden; }
.lane-head { display: block; width: 100%; text-align: left; background: var(--surface-2); border: none; border-bottom: 1px solid transparent; padding: var(--space-lg) var(--space-xl); cursor: pointer; font: inherit; color: inherit; }
.lane.open .lane-head { border-bottom-color: var(--border); }
.lane-head:focus-visible { outline: 2px solid var(--accent); outline-offset: -2px; }
.lane-head-top { display: flex; align-items: center; gap: var(--space-md); }
.chev { color: var(--faint); font-size: 19px; line-height: 1; transition: transform .18s ease; display: inline-block; }
.lane.open .chev { transform: rotate(90deg); color: var(--accent); }
.lane-head h2 { margin: 0; font-size: var(--text-h3); font-weight: 700; flex: 1; }
.lane-count { display: flex; gap: var(--space-sm); }
.lane-bar { height: 6px; border-radius: var(--radius-pill); background: var(--surface-3); overflow: hidden; display: flex; margin-top: var(--space-md); }

/* collapsed-only: the single next step */
.next-step { display: flex; align-items: center; gap: var(--space-sm); flex-wrap: wrap; margin-top: var(--space-md); padding: var(--space-sm) var(--space-md); background: color-mix(in srgb, var(--accent) 8%, var(--surface)); border: 1px dashed color-mix(in srgb, var(--accent) 40%, transparent); border-radius: var(--radius-sm); }
.next-step .lbl { font-size: var(--text-table-head); font-weight: 800; text-transform: uppercase; letter-spacing: .06em; color: var(--accent); white-space: nowrap; }
.next-step .nx { font-size: 13px; color: var(--text); flex: 1; }
.next-step.all-done { background: color-mix(in srgb, var(--green) 8%, var(--surface)); border-style: solid; border-color: color-mix(in srgb, var(--green) 40%, transparent); }
.next-step.all-done .lbl { color: var(--green); }
.next-step.is-blocked { background: color-mix(in srgb, var(--red) 7%, var(--surface)); border-color: color-mix(in srgb, var(--red) 35%, transparent); }
.next-step.is-blocked .lbl { color: var(--red); }

.lane-body { display: none; }
.lane.open .lane-body { display: block; }
.lane.open .next-step { display: none; }
.lane-summary { margin: 0; padding: var(--space-md) var(--space-xl); background: color-mix(in srgb, var(--accent) 6%, transparent); border-bottom: 1px solid var(--border); font-size: 12.5px; color: var(--text); }
.lane-summary .eyebrow { display: block; margin-bottom: 3px; color: var(--accent); }

/* ---- the step-by-step path (critical path with connectors + arrows) ---- */
.steps { list-style: none; margin: 0; padding: var(--space-lg) var(--space-xl) var(--space-lg); }
.step { position: relative; padding: 0 0 var(--space-xl) 42px; }
.step:last-child { padding-bottom: 2px; }
.step-node { position: absolute; left: 5px; top: -2px; width: 27px; height: 27px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 800; z-index: 1; border: 2px solid var(--faint); background: var(--surface-3); color: transparent; }
.step:not(:last-child)::before { content: ""; position: absolute; left: 18px; top: 27px; bottom: 2px; width: 2px; background: var(--border); }
.step:not(:last-child)::after { content: ""; position: absolute; left: 14px; bottom: 6px; width: 0; height: 0; border-left: 5px solid transparent; border-right: 5px solid transparent; border-top: 6px solid var(--border); }
.step.s-done .step-node { border-color: var(--green); background: color-mix(in srgb, var(--green) 22%, transparent); color: var(--green); }
.step.s-done:not(:last-child)::before { background: var(--green); }
.step.s-done:not(:last-child)::after { border-top-color: var(--green); }
.step.s-in_progress .step-node { border-color: var(--amber); background: color-mix(in srgb, var(--amber) 22%, transparent); color: var(--amber); }
.step.s-blocked .step-node { border-color: var(--red); background: color-mix(in srgb, var(--red) 22%, transparent); color: var(--red); }
.step.is-next .step-node { border-color: var(--accent); color: var(--accent); background: color-mix(in srgb, var(--accent) 22%, transparent); box-shadow: 0 0 0 5px color-mix(in srgb, var(--accent) 16%, transparent); animation: pulse 1.9s ease-in-out 6; }
.step.is-next { background: color-mix(in srgb, var(--accent) 6%, transparent); border-radius: var(--radius-sm); margin: 0 calc(-1 * var(--space-sm)); padding-left: 50px; padding-right: var(--space-sm); padding-top: 4px; }
.step-label { font-size: 13.5px; color: var(--text); }
.step.s-done .step-label .t { color: var(--dim); text-decoration: line-through; text-decoration-color: color-mix(in srgb, var(--green) 60%, transparent); }
.next-tag { display: inline-flex; margin-left: 8px; font-size: var(--text-chip); font-weight: 800; letter-spacing: .06em; color: var(--accent); background: color-mix(in srgb, var(--accent) 14%, transparent); border: 1px solid color-mix(in srgb, var(--accent) 40%, transparent); border-radius: var(--radius-pill); padding: 1px 8px; vertical-align: middle; }
.step-note { margin-top: 3px; color: var(--faint); font-size: 11.5px; }
.step-meta { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 7px; }
.chip { display: inline-flex; align-items: center; gap: 4px; font-size: var(--text-chip); font-weight: 700; text-transform: uppercase; letter-spacing: .05em; padding: 2px 8px; border-radius: var(--radius-pill); border: 1px solid var(--border); background: var(--surface-2); color: var(--dim); }
.chip.owner { text-transform: none; letter-spacing: 0; font-weight: 600; }
.chip.quick { color: var(--cyan); border-color: color-mix(in srgb, var(--cyan) 40%, transparent); background: color-mix(in srgb, var(--cyan) 12%, transparent); }
.chip.appr { color: var(--amber); border-color: color-mix(in srgb, var(--amber) 40%, transparent); background: color-mix(in srgb, var(--amber) 12%, transparent); text-transform: none; letter-spacing: 0; font-weight: 600; }

/* ---- animations ---- */
@keyframes pulse { 0%, 100% { box-shadow: 0 0 0 5px color-mix(in srgb, var(--accent) 16%, transparent); } 50% { box-shadow: 0 0 0 10px color-mix(in srgb, var(--accent) 3%, transparent); } }
@keyframes pop { 0% { transform: scale(.5); } 60% { transform: scale(1.18); } 100% { transform: scale(1); } }
@keyframes rowflash { 0% { background: color-mix(in srgb, var(--green) 30%, transparent); } 100% { background: transparent; } }
.step.just-done .step-node { animation: pop .55s ease-out; }
.step.just-done { animation: rowflash 1.9s ease-out; border-radius: var(--radius-sm); }
.step.just-improved .step-node { animation: pop .5s ease-out; }

/* ---- toast + confetti ---- */
.toast { position: fixed; left: 50%; bottom: 26px; transform: translate(-50%, 22px); opacity: 0; transition: opacity .35s ease, transform .35s ease; background: var(--surface); border: 1px solid color-mix(in srgb, var(--green) 50%, var(--border)); border-radius: var(--radius-pill); padding: 11px 22px; font-size: 14px; font-weight: 700; color: var(--text); box-shadow: 0 10px 30px rgba(0,0,0,.45); z-index: 60; }
.toast.show { opacity: 1; transform: translate(-50%, 0); }
.confetti { position: fixed; inset: 0; pointer-events: none; z-index: 55; overflow: hidden; }
.confetti i { position: absolute; top: -16px; width: 9px; height: 14px; border-radius: 2px; animation: fall 1.9s linear forwards; }
@keyframes fall { to { transform: translateY(105vh) rotate(560deg); opacity: .8; } }

/* ---- creatives ---- */
.cre-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(255px, 1fr)); gap: var(--space-md); margin: var(--space-sm) 0 var(--space-xl); }
.cre { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: var(--space-lg); display: flex; flex-direction: column; gap: var(--space-sm); }
.cre.s-winner { border-color: color-mix(in srgb, var(--green) 45%, transparent); }
.cre.s-flopped { opacity: .72; }
.cre-top { display: flex; align-items: center; gap: var(--space-sm); }
.cre-brand { font-size: var(--text-table-head); text-transform: uppercase; letter-spacing: .06em; color: var(--faint); font-weight: 700; flex: 1; }
.cre-headline { font-size: 15px; font-weight: 700; line-height: 1.3; }
.cre-body { font-size: 12.5px; color: var(--dim); }
.cre-cta { display: inline-flex; align-items: center; font-size: 11.5px; font-weight: 700; color: var(--accent); border: 1px solid color-mix(in srgb, var(--accent) 45%, transparent); background: color-mix(in srgb, var(--accent) 12%, transparent); border-radius: 8px; padding: 5px 12px; }
.cre-foot { margin-top: auto; display: flex; flex-direction: column; gap: 4px; padding-top: var(--space-sm); border-top: 1px solid var(--border); }
.cre-result { font-size: 12px; font-weight: 700; color: var(--green); }
.cre.s-flopped .cre-result { color: var(--red); }
.cre-note { font-size: 11px; color: var(--faint); }

/* ---- analytics ---- */
.analytics-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: var(--space-md); margin: var(--space-sm) 0 var(--space-xl); }
.acard { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: var(--space-lg); }
.acard--wide { margin-bottom: var(--space-xl); }
.acard-head { display: flex; align-items: center; gap: var(--space-sm); margin-bottom: var(--space-md); }
.acard-head h3 { margin: 0; font-size: var(--text-h3); font-weight: 700; flex: 1; }
.metric { display: flex; justify-content: space-between; gap: var(--space-md); padding: 5px 0; border-bottom: 1px solid var(--border); font-size: 12.5px; color: var(--dim); }
.metric:last-child { border-bottom: none; }
.metric .v { color: var(--text); }
.metric-row { display: flex; flex-wrap: wrap; gap: var(--space-lg); margin-top: var(--space-md); }
.metric-cell { min-width: 110px; }
.metric-cell .v { font-size: var(--text-kpi); font-weight: 700; color: var(--accent); line-height: 1; }
.metric-cell-lbl { margin-top: 4px; font-size: var(--text-table-head); text-transform: uppercase; letter-spacing: .06em; color: var(--faint); font-weight: 700; }
.lane-note { margin: var(--space-sm) 0 0; color: var(--dim); font-size: 12px; }

/* ---- panel + action-log table ---- */
.panel { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); margin-bottom: var(--space-xl); overflow: hidden; }
.panel-head { padding: var(--space-lg) var(--space-xl); border-bottom: 1px solid var(--border); background: var(--surface-2); display: flex; align-items: center; gap: var(--space-md); }
.panel-head h2 { margin: 0; font-size: var(--text-h3); font-weight: 700; flex: 1; }
table.log { width: 100%; border-collapse: collapse; }
table.log th { text-align: left; font-size: var(--text-table-head); text-transform: uppercase; letter-spacing: .06em; color: var(--faint); font-weight: 700; padding: var(--space-sm) var(--space-xl); border-bottom: 1px solid var(--border); background: var(--surface-2); }
table.log td { padding: var(--space-md) var(--space-xl); border-bottom: 1px solid var(--border); vertical-align: top; font-size: 12.5px; }
table.log td.dim { color: var(--dim); }
table.log tr:last-child td { border-bottom: none; }
table.log tbody tr:hover td { background: var(--surface-2); }

footer.foot { max-width: var(--content-max); margin: 0 auto; padding: var(--space-2xl); color: var(--faint); font-size: 11.5px; border-top: 1px solid var(--border); }
footer.foot code { background: var(--surface-2); border: 1px solid var(--border); border-radius: 4px; padding: 1px 5px; color: var(--dim); }

@media (max-width: 640px) {
  .wrap, .topbar, .pagenav { padding-left: var(--space-md); padding-right: var(--space-md); }
  .kpi { min-width: calc(50% - var(--space-md)); }
}
/* ---- avatars / personas ---- */
.portrait { width: 92px; height: 92px; border-radius: 14px; overflow: hidden; flex-shrink: 0; border: 1px solid var(--border); }
.portrait svg { display: block; width: 100%; height: 100%; }
.portrait--sm { width: 30px; height: 30px; border-radius: 8px; }
.av-role { font-weight: 400; color: var(--dim); font-size: 12.5px; }
.persona { display: flex; gap: var(--space-xl); padding: var(--space-lg) var(--space-xl); flex-wrap: wrap; align-items: flex-start; }
.persona-cols { flex: 1; min-width: 240px; display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg); }
.persona-sec.span2 { grid-column: 1 / -1; }
.persona-sec h4 { margin: 0 0 5px; font-size: var(--text-table-head); text-transform: uppercase; letter-spacing: .06em; color: var(--faint); }
.persona-sec ul { margin: 0; padding-left: 16px; font-size: 12.5px; color: var(--dim); }
.persona-sec ul li { margin-bottom: 3px; }
.persona-sec p, .persona-sec .who, .persona-sec .awareness { margin: 0; font-size: 12.5px; color: var(--dim); }
.persona-sec .who { color: var(--text); margin-bottom: 5px; }
.persona-meta { display: flex; gap: var(--space-sm); flex-wrap: wrap; margin: 0 var(--space-xl) var(--space-lg); }
.av-creatives { margin: 0 var(--space-xl) var(--space-lg); padding: var(--space-lg); border: 1px dashed var(--border); border-radius: var(--radius-sm); }
.av-creatives .eyebrow { margin-bottom: var(--space-sm); }
.av-creatives .empty { color: var(--faint); font-size: 12.5px; }
.archive-group { padding: 0 var(--space-xl) var(--space-md); }

/* ---- analytics card as link + channel page ---- */
.acard--link { display: block; text-decoration: none; color: inherit; transition: border-color .15s ease; }
.acard--link:hover { border-color: var(--faint); }
.acard-more { margin-top: var(--space-md); color: var(--accent); font-size: 12px; font-weight: 600; }
.hero-metrics { margin: var(--space-md) 0 var(--space-xl); gap: var(--space-2xl); }
.hero-metrics .v { font-size: 30px; }
.backline { margin-top: var(--space-md); }

.portrait-img { display: block; width: 100%; height: 100%; object-fit: cover; }
.have-list { list-style: none; margin: 0; padding: 0; }
.have-list li { padding: 7px 0; border-bottom: 1px solid var(--border); font-size: 12.5px; color: var(--text); }
.have-list li:last-child { border-bottom: none; }
.have-list .hn { color: var(--faint); }
.have-list .badge { margin-right: 6px; vertical-align: middle; }

/* ---- category headers (Get-to-Launch tracks) ---- */
.cat-head { margin: var(--space-2xl) 0 var(--space-md); padding-bottom: var(--space-sm); border-bottom: 2px solid var(--accent); }
.cat-head:first-of-type { margin-top: var(--space-lg); }
.cat-head-row { display: flex; align-items: center; gap: var(--space-md); }
.cat-title { font-size: 17px; font-weight: 700; flex: 1; letter-spacing: -.01em; }
.cat-blurb { margin: 6px 0 0; color: var(--dim); font-size: 12.5px; max-width: 760px; }

/* ---- placeholder ad mockups ---- */
.mock-wrap { background: transparent; border: none; padding: var(--space-md) var(--space-xl) var(--space-lg); }
.ph-note { font-size: 11.5px; color: var(--amber); margin: 4px 0 var(--space-md); font-weight: 600; }
.mock-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: var(--space-md); }
.mock { background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.mock-tag { display: flex; align-items: center; gap: var(--space-sm); padding: 7px var(--space-md); font-size: var(--text-table-head); text-transform: uppercase; letter-spacing: .06em; font-weight: 700; color: var(--faint); border-bottom: 1px solid var(--border); background: var(--surface); }
.ph-badge { margin-left: auto; font-size: 8.5px; font-weight: 800; letter-spacing: .08em; color: var(--amber); border: 1px solid color-mix(in srgb, var(--amber) 45%, transparent); background: color-mix(in srgb, var(--amber) 14%, transparent); border-radius: var(--radius-pill); padding: 1px 7px; }

/* Google search ad */
.mock-google { padding: var(--space-md); background: var(--surface); }
.g-row { display: flex; align-items: center; gap: 7px; font-size: 12px; color: var(--dim); }
.g-ad { font-weight: 700; color: var(--text); }
.g-url { color: var(--green); }
.g-head { margin: 6px 0 4px; color: #8ab4f8; font-size: 15px; line-height: 1.3; font-weight: 500; }
.g-sep { color: var(--faint); }
.g-desc { font-size: 12.5px; color: var(--dim); }

/* Meta + LinkedIn social ad */
.mock-meta, .mock-li { padding: var(--space-md); background: var(--surface); }
.s-head { display: flex; align-items: center; gap: 8px; margin-bottom: var(--space-sm); }
.s-av { width: 30px; height: 30px; border-radius: 50%; background: linear-gradient(135deg, var(--accent), var(--accent-2)); flex-shrink: 0; }
.mock-li .s-av { background: linear-gradient(135deg, #0a66c2, #22d3ee); }
.s-page { font-size: 12.5px; font-weight: 700; color: var(--text); display: flex; flex-direction: column; line-height: 1.2; }
.s-page small { font-weight: 400; color: var(--faint); font-size: 10.5px; }
.s-primary { font-size: 12.5px; color: var(--text); margin-bottom: var(--space-sm); }
.s-img { height: 92px; display: flex; align-items: center; justify-content: center; background: var(--surface-3); border-radius: var(--radius-sm); color: var(--faint); font-size: 11.5px; margin-bottom: var(--space-sm); }
.s-foot { display: flex; align-items: center; gap: var(--space-sm); padding: var(--space-sm); background: var(--surface-2); border-radius: var(--radius-sm); }
.s-hl { font-size: 12.5px; font-weight: 700; color: var(--text); flex: 1; }
.s-cta { font-size: 11px; font-weight: 700; color: var(--dim); border: 1px solid var(--border); background: var(--surface); border-radius: 6px; padding: 5px 10px; white-space: nowrap; }

/* ============================================================================
 * THE MACHINE — reactor control panel
 * ========================================================================== */
.wrap--wide { max-width: 1280px; }

.machine-legend { display: flex; flex-wrap: wrap; gap: var(--space-lg); align-items: center; margin: var(--space-lg) 0 var(--space-md); }
.mleg { display: inline-flex; align-items: center; gap: 7px; font-size: 11.5px; color: var(--dim); font-weight: 600; }
.led { display: inline-block; width: 11px; height: 11px; border-radius: 50%; background: #48526a; }
.is-live .led, .mleg.live .led { background: var(--green); box-shadow: 0 0 8px var(--green); }
.is-building .led, .mleg.building .led { background: var(--amber); box-shadow: 0 0 8px var(--amber); }
.is-planned .led, .mleg.planned .led { background: #48526a; box-shadow: none; }
.is-blocked .led, .mleg.blocked .led { background: var(--red); box-shadow: 0 0 8px var(--red); }

.machine-routes { display: flex; flex-wrap: wrap; gap: var(--space-md); margin: var(--space-md) 0 var(--space-lg); }
.mroute { flex: 1; min-width: 210px; background: var(--surface); border: 1px solid var(--border); border-left: 3px solid var(--accent); border-radius: var(--radius-sm); padding: 9px 13px; }
.mroute b { font-size: 12.5px; } .mroute span { display: block; color: var(--dim); font-size: 11.5px; margin-top: 3px; line-height: 1.35; }
.mroute.r-direct { border-left-color: var(--cyan); } .mroute.r-audit { border-left-color: var(--violet); } .mroute.r-magnet { border-left-color: var(--accent); }

.machine-avatars { display: flex; flex-wrap: wrap; gap: var(--space-sm); margin: 0 0 var(--space-lg); }
.av-btn { display: inline-flex; align-items: center; gap: 8px; padding: 5px 13px 5px 5px; border: 1px solid var(--border); background: var(--surface); border-radius: var(--radius-pill); cursor: pointer; color: var(--dim); font: inherit; font-size: 12.5px; font-weight: 600; }
.av-btn .av-dot { width: 24px; height: 24px; border-radius: 50%; background: var(--surface-3); display: inline-flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 800; color: var(--text); overflow: hidden; }
.av-btn img { width: 24px; height: 24px; border-radius: 50%; object-fit: cover; display: block; }
.av-btn:hover { color: var(--text); border-color: var(--faint); }
.av-btn.active { color: var(--text); border-color: var(--accent); background: color-mix(in srgb, var(--accent) 13%, var(--surface)); box-shadow: 0 0 0 1px var(--accent); }

.machine-frame { position: relative; border: 2px solid var(--border); border-radius: 16px; overflow: hidden; padding: 0; cursor: grab;
  width: 100%; height: 76vh; min-height: 360px; min-width: 640px; max-width: 100%;
  background: radial-gradient(130% 100% at 50% 0%, color-mix(in srgb, var(--accent) 8%, transparent), transparent 55%), linear-gradient(180deg, var(--surface), var(--bg));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 16px 44px rgba(0,0,0,.38); }
.machine-frame.grabbing { cursor: grabbing; }
.frame-resize { position: absolute; right: 0; bottom: 0; width: 24px; height: 24px; z-index: 10; cursor: nwse-resize; pointer-events: auto; opacity: .85;
  background: linear-gradient(135deg, transparent 38%, var(--faint) 38%, var(--faint) 52%, transparent 52%, transparent 66%, var(--faint) 66%, var(--faint) 80%, transparent 80%); border-bottom-right-radius: 14px; }
.frame-resize:hover { opacity: 1; background: linear-gradient(135deg, transparent 38%, var(--accent) 38%, var(--accent) 52%, transparent 52%, transparent 66%, var(--accent) 66%, var(--accent) 80%, transparent 80%); }
.machine-plate { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin: 0 4px 8px; }
.machine-plate .mp-title { font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--faint); }
.machine-plate .mp-title b { color: var(--dim); }
.mp-zoom { display: flex; align-items: center; gap: 12px; }
.mp-hint { font-size: 11px; color: var(--faint); }

/* No will-change/translateZ here on purpose: promoting the world to a cached
 * GPU layer makes zoom-in render a stretched bitmap (grainy). Letting it repaint
 * keeps the HTML + SVG crisp (true vector) at any zoom. */
.machine-stage { position: absolute; top: 0; left: 0; width: 1800px; height: 1012.5px; transform-origin: 0 0; }
.machine-frame.editing { cursor: default; }
.machine-frame.editing .mnode { cursor: move; }
.mnode.dragging { opacity: .9; box-shadow: 0 0 0 2px var(--accent), 0 8px 24px rgba(0,0,0,.5) !important; z-index: 9; }
.md-coords { font-family: ui-monospace, Menlo, Consolas, monospace; font-size: 11px; line-height: 1.45; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 10px 12px; max-height: 320px; overflow: auto; white-space: pre; color: var(--dim); margin-top: 8px; }
.mp-zoom { flex-wrap: wrap; }
.machine-edges { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; z-index: 1; }
/* HUE = layer (customer vs system); INTENSITY = built status. All arrows march. */
.medge { fill: none; stroke-width: 3.4; stroke-linejoin: round; stroke-linecap: round; stroke-dasharray: 9 7; transition: opacity .25s; }
.medge.flow-customer { stroke: var(--accent-2); color: var(--accent-2); }
.medge.flow-system { stroke: var(--violet); color: var(--violet); }
.medge.es-planned { opacity: .55; }
.medge.es-building { opacity: .82; }
.medge.es-live { opacity: 1; }
.medge.flow-customer.es-live { filter: drop-shadow(0 0 3px color-mix(in srgb, var(--accent-2) 60%, transparent)); }
.medge.flow-system.es-live { filter: drop-shadow(0 0 3px color-mix(in srgb, var(--violet) 60%, transparent)); }
.medge.es-blocked { stroke: var(--red); color: var(--red); opacity: .85; }
.medge.instrument { stroke-width: 2.2; opacity: .5; }
.medge.dim { opacity: .05 !important; }
@media (prefers-reduced-motion: no-preference) {
  .medge { animation: mflow .8s linear infinite; }
  @keyframes mflow { to { stroke-dashoffset: -32; } }
}
.mlabel-pill.flow-customer { border-color: color-mix(in srgb, var(--accent-2) 45%, var(--border)); }
.mlabel-pill.flow-system { border-color: color-mix(in srgb, var(--violet) 45%, var(--border)); }

.mlabels { position: absolute; inset: 0; pointer-events: none; z-index: 2; }
.mlabel-pill { position: absolute; transform: translate(-50%, -50%); background: var(--surface); border: 1px solid var(--border); color: var(--dim); font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: var(--radius-pill); white-space: nowrap; box-shadow: 0 2px 7px rgba(0,0,0,.34); transition: opacity .25s; }
.mlabel-pill.dim { opacity: .1; }

.mnode { position: absolute; transform: translate(-50%, -50%); width: 130px; min-height: 56px; z-index: 3;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px; text-align: center;
  padding: 9px 8px; border-radius: 12px; background: var(--surface-2); border: 1.5px solid var(--border); color: var(--text);
  cursor: pointer; font: inherit; transition: opacity .25s, box-shadow .2s, border-color .2s, transform .12s; }
.mnode:hover { transform: translate(-50%, -50%) scale(1.045); z-index: 7; }
.mnode .led { position: absolute; top: 7px; right: 7px; }
.mnode .micon { display: inline-flex; color: var(--text); }
.mnode .micon svg { width: 23px; height: 23px; display: block; }
.mnode .mlabel { font-size: 11.5px; font-weight: 700; line-height: 1.15; }
.mnode .msub { font-size: 9.5px; color: var(--faint); line-height: 1.2; }
.mnode.dim { opacity: .13; }
.mnode.sel { outline: 2px solid var(--accent); outline-offset: 2px; z-index: 8; }

.mnode.k-inroad { width: 142px; border-radius: 10px; background: var(--surface); }
.mnode.k-mech { border-radius: 52px; width: 122px; background: linear-gradient(180deg, var(--surface-2), var(--surface)); }
.mnode.k-offer { border-style: dashed; }
.mnode.k-milestone { background: var(--surface-3); }
.mnode.major { width: 152px; min-height: 64px; }
.mnode.major .mlabel { font-size: 13px; letter-spacing: .03em; }

.mnode.is-live { border-color: color-mix(in srgb, var(--green) 60%, var(--border)); box-shadow: 0 0 0 1px color-mix(in srgb, var(--green) 30%, transparent), 0 0 18px color-mix(in srgb, var(--green) 22%, transparent); }
.mnode.is-building { border-color: color-mix(in srgb, var(--amber) 55%, var(--border)); box-shadow: 0 0 0 1px color-mix(in srgb, var(--amber) 24%, transparent); }
.mnode.is-planned { border-color: var(--border); background: var(--surface); color: var(--dim); }
.mnode.is-planned .micon, .mnode.is-planned .mlabel { color: var(--dim); }
.mnode.is-planned .micon { opacity: .65; }
.mnode.is-blocked { border-color: color-mix(in srgb, var(--red) 55%, var(--border)); box-shadow: 0 0 0 1px color-mix(in srgb, var(--red) 25%, transparent); }
.mnode.major.is-building { box-shadow: 0 0 0 1px color-mix(in srgb, var(--amber) 30%, transparent), 0 0 24px color-mix(in srgb, var(--amber) 25%, transparent); }
.mnode.major.is-live { box-shadow: 0 0 0 1px color-mix(in srgb, var(--green) 40%, transparent), 0 0 28px color-mix(in srgb, var(--green) 30%, transparent); }

.mnode.critical { animation: mcrit 2.1s ease-in-out infinite; }
@keyframes mcrit { 0%, 100% { box-shadow: 0 0 0 1px color-mix(in srgb, var(--red) 30%, transparent); } 50% { box-shadow: 0 0 0 3px color-mix(in srgb, var(--red) 35%, transparent), 0 0 17px color-mix(in srgb, var(--red) 30%, transparent); } }

@media (prefers-reduced-motion: no-preference) {
  .mnode.k-mech.is-live .micon svg { transform-origin: 50% 50%; animation: mspin 7s linear infinite; }
  @keyframes mspin { to { transform: rotate(360deg); } }
}

.glyph { width: 23px; height: 23px; border-radius: 6px; display: inline-flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 800; color: #fff; }
.g-google { background: #4285f4; } .g-meta { background: #0866ff; } .g-li { background: #0a66c2; font-size: 10px; }

/* avatar portrait nodes (the actual buyers) */
.mnode.k-avatar { width: 104px; min-height: 0; gap: 7px; padding: 0; background: transparent; border: none; box-shadow: none; }
.mnode.k-avatar:hover { box-shadow: none; }
.mnode.k-avatar .led { display: none; }
.mnode.k-avatar .av-portrait { width: 74px; height: 74px; border-radius: 50%; overflow: hidden; background: var(--surface-3); border: 2.5px solid var(--accent); box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 18%, transparent), 0 5px 16px rgba(0,0,0,.42); }
.mnode.k-avatar .av-portrait img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mnode.k-avatar { cursor: pointer; }
.mnode.k-avatar.av-active .av-portrait { border-color: var(--green); box-shadow: 0 0 0 5px color-mix(in srgb, var(--green) 32%, transparent), 0 0 22px color-mix(in srgb, var(--green) 45%, transparent); }
.mnode.k-avatar.av-active .mlabel { color: var(--green); }
.mnode.k-avatar:not(.av-active):hover .av-portrait { border-color: var(--text); }
.mnode.k-avatar.lane-a .av-portrait { border-color: var(--accent); box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 20%, transparent), 0 5px 16px rgba(0,0,0,.42); }
.mnode.k-avatar.lane-b .av-portrait { border-color: var(--cyan); box-shadow: 0 0 0 4px color-mix(in srgb, var(--cyan) 20%, transparent), 0 5px 16px rgba(0,0,0,.42); }
.mnode.k-avatar.lane-c .av-portrait { border-color: var(--violet); box-shadow: 0 0 0 4px color-mix(in srgb, var(--violet) 20%, transparent), 0 5px 16px rgba(0,0,0,.42); }
.mnode.k-avatar .mlabel { font-size: 12.5px; }
.mnode.k-avatar .msub { max-width: 104px; }
.mnode.k-avatar.dim { opacity: .13; }

.machine-detail { margin-top: var(--space-lg); background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: var(--space-lg) var(--space-xl); min-height: 100px; }
.machine-detail .md-eyebrow { font-size: 10.5px; text-transform: uppercase; letter-spacing: .08em; color: var(--accent); font-weight: 700; }
.machine-detail h3 { margin: 3px 0 9px; font-size: 16px; }
.md-status { display: inline-flex; align-items: center; gap: 7px; font-size: 12px; font-weight: 600; padding: 4px 11px; border-radius: var(--radius-pill); border: 1px solid var(--border); }
.md-status.is-live { color: var(--green); border-color: color-mix(in srgb, var(--green) 40%, transparent); }
.md-status.is-building { color: var(--amber); border-color: color-mix(in srgb, var(--amber) 40%, transparent); }
.md-status.is-planned { color: var(--dim); }
.md-status.is-blocked { color: var(--red); border-color: color-mix(in srgb, var(--red) 40%, transparent); }
.md-sub { margin: 11px 0 4px; color: var(--text); font-size: 13px; }
.md-note { margin: 7px 0; color: var(--dim); font-size: 12.5px; line-height: 1.45; }
.md-tasks { list-style: none; margin: 8px 0 0; padding: 0; display: flex; flex-direction: column; gap: 7px; }
.md-tasks li { font-size: 12.5px; color: var(--dim); }
.md-tasks .badge { margin-right: 4px; }
.md-hint { color: var(--faint); font-size: 13px; }

@media (max-width: 720px) { .machine-frame { padding: 12px 8px; min-width: 100%; } .machine-plate { margin: 0 8px 10px; } }
/* QA-DEFER: M1 — the 641–768px KPI wrap band needs live re-check at deploy. */

/* ===== The Machine v3 — wide canvas, layers, temperature, creatives ===== */
.wrap--wide { max-width: min(2400px, 97vw); }

/* bigger nodes for the wider canvas */
.mnode { width: 148px; min-height: 60px; }
.mnode .micon svg { width: 26px; height: 26px; }
.mnode .mlabel { font-size: 12.5px; }
.mnode .msub { font-size: 10px; }
.mnode.k-inroad { width: 160px; }
.mnode.k-mech { width: 138px; }
.mnode.major { width: 172px; min-height: 70px; }
.mnode.major .mlabel { font-size: 14px; }
.mnode.k-avatar { width: 120px; }
.mnode.k-avatar .av-portrait { width: 86px; height: 86px; }

/* line-layer toggle controls + temperature legend */
.machine-controls { display: flex; flex-wrap: wrap; gap: var(--space-lg); align-items: center; margin: var(--space-md) 0 var(--space-lg); }
.layer-toggles { display: flex; gap: var(--space-sm); flex-wrap: wrap; }
.layer-btn { display: flex; align-items: center; gap: 10px; padding: 8px 14px; border: 1px solid var(--border); background: var(--surface); border-radius: var(--radius); cursor: pointer; color: var(--dim); font: inherit; text-align: left; }
.layer-btn .lswatch { width: 28px; height: 5px; border-radius: 3px; background: var(--faint); flex: none; }
.layer-btn .ltxt { display: flex; flex-direction: column; line-height: 1.18; }
.layer-btn .ltxt b { font-size: 12.5px; color: var(--dim); }
.layer-btn .ltxt small { font-size: 10.5px; color: var(--faint); }
.layer-btn:not(.active) { opacity: .55; }
.layer-btn.flow-customer.active { border-color: color-mix(in srgb, var(--accent-2) 55%, transparent); box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent-2) 35%, transparent); }
.layer-btn.flow-system.active { border-color: color-mix(in srgb, var(--violet) 55%, transparent); box-shadow: 0 0 0 1px color-mix(in srgb, var(--violet) 35%, transparent); }
.layer-btn.flow-customer.active .lswatch { background: var(--accent-2); }
.layer-btn.flow-system.active .lswatch { background: var(--violet); }
.layer-btn.active .ltxt b { color: var(--text); }

.temp-legend { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-left: auto; }
.tchip { font-size: 10.5px; font-weight: 700; padding: 4px 11px; border-radius: var(--radius-pill); border: 1px solid var(--border); }
.tchip.t-hot { color: #ff8a63; border-color: color-mix(in srgb, #ff7a59 45%, transparent); background: color-mix(in srgb, #ff7a59 13%, transparent); }
.tchip.t-warm { color: var(--amber); border-color: color-mix(in srgb, var(--amber) 45%, transparent); background: color-mix(in srgb, var(--amber) 12%, transparent); }
.tchip.t-cold { color: #6ea8ff; border-color: color-mix(in srgb, #5b9bff 45%, transparent); background: color-mix(in srgb, #5b9bff 13%, transparent); }

/* temperature tab on platform nodes */
.temp-tab { position: absolute; top: 7px; left: 7px; font-size: 8.5px; font-weight: 800; letter-spacing: .04em; padding: 2px 6px; border-radius: 5px; color: #fff; }
.temp-tab.t-hot { background: linear-gradient(180deg, #ff7a59, #ef4424); }
.temp-tab.t-warm { background: linear-gradient(180deg, #e0a92a, #c4831a); }
.temp-tab.t-cold { background: linear-gradient(180deg, #5b9bff, #3866c8); }

/* temperature intake box (outer bounding box around platforms) */
.intake-box { position: absolute; z-index: 0; pointer-events: none; border: 1.5px solid color-mix(in srgb, #ff7a59 22%, var(--border)); border-radius: 16px;
  background: linear-gradient(180deg, color-mix(in srgb, #ff7a59 14%, transparent) 0%, color-mix(in srgb, var(--amber) 9%, transparent) 48%, color-mix(in srgb, #5b9bff 14%, transparent) 100%);
  box-shadow: inset 0 0 34px rgba(0,0,0,.28); }
.intake-label { position: absolute; top: -10px; left: 18px; background: var(--surface); padding: 2px 11px; border: 1px solid var(--border); border-radius: var(--radius-pill); font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--dim); }
.intake-scale { position: absolute; top: 10px; bottom: 10px; right: -5px; width: 8px; border-radius: 5px; overflow: hidden; display: flex; flex-direction: column; box-shadow: 0 0 0 1px var(--border); }
.intake-scale i { flex: 1; }
.intake-scale i.t-hot { background: #ef4424; } .intake-scale i.t-warm { background: #d29922; } .intake-scale i.t-cold { background: #3866c8; }
.intake-resize { position: absolute; right: -2px; bottom: -2px; width: 18px; height: 18px; pointer-events: none; }
.machine-frame.editing .intake-box { pointer-events: none; z-index: 7; border-style: dashed; border-color: color-mix(in srgb, var(--accent) 55%, transparent); }
.intake-label, .intake-resize { z-index: 8; }
.machine-frame.editing .intake-label { pointer-events: auto; cursor: move; border-color: var(--accent); color: var(--text); }
.machine-frame.editing .intake-resize { pointer-events: auto; cursor: nwse-resize; background: linear-gradient(135deg, transparent 50%, var(--accent) 50%); border-bottom-right-radius: 14px; }

/* per-avatar ad-creative blocks (by platform) */
.machine-creatives { margin-top: var(--space-lg); background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: var(--space-lg) var(--space-xl); }
.machine-creatives[hidden] { display: none; }
.mc-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: var(--space-md); flex-wrap: wrap; }
.mc-head .ph-note { font-size: 11px; color: var(--amber); }
.mc-cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--space-lg); }
.mc-col { display: flex; flex-direction: column; gap: var(--space-sm); }
.mc-col .eyebrow { color: var(--accent); }

/* ad-hook slots to the left of each platform (shown for the selected avatar) */
.hooks-layer { position: absolute; inset: 0; pointer-events: none; z-index: 4; }
.hooks-expand-layer { position: absolute; inset: 0; pointer-events: none; z-index: 9; }
.machine-frame.editing .hook-block { cursor: move; }
.hook-block.dragging { box-shadow: 0 0 0 2px var(--accent), 0 8px 24px rgba(0,0,0,.5) !important; opacity: .95; z-index: 7; }
.hook-block { position: absolute; transform: translate(-50%, -50%); width: 132px; pointer-events: auto; cursor: pointer;
  display: flex; flex-direction: column; gap: 3px; padding: 9px 11px; border-radius: 10px;
  background: var(--surface-2); border: 1px solid var(--border); border-left: 3px solid var(--faint);
  box-shadow: 0 5px 16px rgba(0,0,0,.36); transition: transform .12s, box-shadow .2s; }
.hook-block:hover { transform: translate(-50%, -50%) scale(1.045); box-shadow: 0 8px 24px rgba(0,0,0,.5); z-index: 6; }
.hook-block .hk-plat { font-size: 9px; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; color: var(--faint); }
.hook-block .hk-head { font-size: 12px; font-weight: 700; color: var(--text); line-height: 1.2; }
.hook-block .hk-line { font-size: 10.5px; color: var(--dim); line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.hook-block .hk-more { font-size: 9px; color: var(--accent); font-weight: 700; margin-top: 1px; }
.hook-block.t-hot { border-left-color: #ff7a59; } .hook-block.t-warm { border-left-color: var(--amber); } .hook-block.t-cold { border-left-color: #5b9bff; }

.hook-expand { position: absolute; transform: translateY(-50%); pointer-events: auto; }
.hook-expand .mock { width: 300px; box-shadow: 0 20px 54px rgba(0,0,0,.62); }
.hook-close { position: absolute; top: -11px; right: -11px; z-index: 2; width: 26px; height: 26px; border-radius: 50%; border: 1px solid var(--border); background: var(--surface-3); color: var(--text); font-size: 17px; line-height: 1; cursor: pointer; box-shadow: 0 2px 8px rgba(0,0,0,.45); }
.hook-close:hover { border-color: var(--faint); }

@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; } }
