/* ═══════════════════════════════════════════════════════════════════
   Yolt v11 — CD-5 Round 4 polish (D-N31).

   Visual primitives for the polished renderers:
     §1 page-hero-traffic-light → .tone-{good,warn,bad} + .is-active + 3D glow
     §2 power-metrics-bar       → .pm-ic stroke-icon slot
     §3 page-structure-template → .ps-zone / .ps-thumb thumbnails
     §4 page-warning-banner     → .wb.tier-{info,warn,bad,critical}
     §5 modal.critical-kpi-alert → .alert-modal + .alert-scrim + .alert-big-ic

   All colors via oklch tokens (CLAUDE.md hard rule). Animations defined
   у styles/tokens.css (--anim-* tokens). Pull this file AFTER tokens.css
   у v11/index.html + every page template.
   ═══════════════════════════════════════════════════════════════════ */

/* ─── §1 · Traffic-light hero polish ───────────────────────────── */
.page-hero-card {
  position: relative;
  border-radius: var(--r-lg);
  padding: 20px 22px 18px;
  background: linear-gradient(160deg,
    color-mix(in oklch, var(--bg-2) 70%, transparent) 0%,
    var(--bg-1) 60%);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-low);
  overflow: hidden;
}
.page-hero-card.is-active::after {
  content: ""; position: absolute; inset: auto -8% -40px -8%;
  height: 80px; border-radius: 50%; z-index: -1;
  filter: blur(28px); opacity: 0.55;
  pointer-events: none;
}
.page-hero-card.tone-good.is-active {
  border-color: color-mix(in oklch, var(--good) 45%, var(--line));
  box-shadow: var(--shadow-mid), inset 0 0 0 1px color-mix(in oklch, var(--good) 18%, transparent);
}
.page-hero-card.tone-good.is-active::after { background: var(--good); }
.page-hero-card.tone-warn.is-active {
  border-color: color-mix(in oklch, var(--warn) 45%, var(--line));
  box-shadow: var(--shadow-mid), inset 0 0 0 1px color-mix(in oklch, var(--warn) 18%, transparent);
}
.page-hero-card.tone-warn.is-active::after { background: var(--warn); }
.page-hero-card.tone-bad.is-active {
  border-color: color-mix(in oklch, var(--bad) 55%, var(--line));
  box-shadow: var(--shadow-high), inset 0 0 0 1px color-mix(in oklch, var(--bad) 26%, transparent);
  animation: var(--anim-pulse-red);
}
.page-hero-card.tone-bad.is-active::after {
  background: var(--bad);
  opacity: 0.75;
  animation: var(--anim-glow-active);
}

/* traffic-light stack of 3 lamps */
.ph-tl {
  display: flex; flex-direction: column; gap: 6px; padding: 10px 8px;
  border-radius: 14px;
  background: color-mix(in oklch, var(--bg-0) 70%, transparent);
  border: 1px solid var(--line-soft);
  align-items: center;
}
.tl-light {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--bg-3); opacity: 0.22;
  border: 1px solid color-mix(in oklch, var(--line) 60%, transparent);
  position: relative;
}
.tl-light.on.tl-green,
.tl-light.on.tone-good {
  background: var(--good); opacity: 1;
  box-shadow: 0 0 14px var(--good), 0 0 28px color-mix(in oklch, var(--good) 45%, transparent);
}
.tl-light.on.tl-amber,
.tl-light.on.tone-warn {
  background: var(--warn); opacity: 1;
  box-shadow: 0 0 14px var(--warn), 0 0 28px color-mix(in oklch, var(--warn) 45%, transparent);
}
.tl-light.on.tl-red,
.tl-light.on.tone-bad {
  background: var(--bad); opacity: 1;
  animation: var(--anim-tl-dot-pulse);
}
/* 3D specular highlight — tiny shine on the active lamp */
.tl-light.on::before {
  content: ""; position: absolute; top: 3px; left: 4px;
  width: 7px; height: 5px; border-radius: 50%;
  background: oklch(1 0 0 / 0.55);
  filter: blur(1px);
  pointer-events: none;
}

/* ─── §2 · Power-metrics with icons ───────────────────────────── */
.power-metrics { display: grid; grid-template-columns: repeat(6, 1fr); gap: 10px; }
.pm-card {
  position: relative;
  padding: 12px 13px;
  border-radius: var(--r-md);
  background: var(--bg-1);
  border: 1px solid var(--line-soft);
  border-left: 3px solid var(--line);
  display: grid; grid-template-columns: 28px 1fr; gap: 10px; align-items: start;
}
.pm-card.good { border-left-color: var(--good); }
.pm-card.warn { border-left-color: var(--warn); }
.pm-card.bad  { border-left-color: var(--bad); }
.pm-card.flat,
.pm-card.neutral { border-left-color: var(--ink-3); }
.pm-ic {
  width: 28px; height: 28px; border-radius: var(--r-sm);
  background: color-mix(in oklch, var(--bg-2) 90%, transparent);
  border: 1px solid var(--line-soft);
  display: grid; place-items: center; color: var(--ink-1);
}
.pm-ic svg {
  width: 16px; height: 16px;
  fill: none; stroke: currentColor;
  stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round;
}
.pm-card.good .pm-ic {
  color: var(--good);
  background: color-mix(in oklch, var(--good) 10%, var(--bg-2));
  border-color: color-mix(in oklch, var(--good) 25%, var(--line-soft));
}
.pm-card.warn .pm-ic {
  color: var(--warn);
  background: color-mix(in oklch, var(--warn) 10%, var(--bg-2));
  border-color: color-mix(in oklch, var(--warn) 25%, var(--line-soft));
}
.pm-card.bad .pm-ic {
  color: var(--bad);
  background: color-mix(in oklch, var(--bad) 10%, var(--bg-2));
  border-color: color-mix(in oklch, var(--bad) 25%, var(--line-soft));
}
.pm-lbl {
  font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--ink-3); font-weight: 600; line-height: 1; margin-bottom: 4px;
}
.pm-val {
  font-family: var(--font-mono); font-size: 16px; font-weight: 600;
  color: var(--ink-0); line-height: 1; margin-bottom: 4px;
}
.pm-d { font-family: var(--font-mono); font-size: 10.5px; line-height: 1; }
.pm-d.up,
.pm-d.good { color: var(--good); }
.pm-d.dn,
.pm-d.down,
.pm-d.bad { color: var(--bad); }
.pm-d.flat,
.pm-d.neutral { color: var(--ink-3); }

/* ─── §3 · Page structure thumbnails ─────────────────────────── */
.page-structure.with-thumbs { display: flex; flex-direction: column; gap: 8px; }
.ps-zone {
  display: grid; grid-template-columns: 32px 220px 168px 1fr;
  gap: 16px; align-items: center;
  padding: 10px 14px; border-radius: var(--r-md);
  background: var(--bg-1); border: 1px solid var(--line-soft);
  transition: border-color 0.15s ease;
}
.ps-zone:hover { border-color: color-mix(in oklch, var(--brand) 35%, var(--line)); }
.ps-num {
  width: 26px; height: 26px; border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--font-mono); font-size: 11px; font-weight: 600;
  color: var(--ink-1); background: var(--bg-2); border: 1px solid var(--line);
}
.ps-name {
  font-size: 13px; color: var(--ink-0); font-weight: 600; line-height: 1.3;
}
.ps-name small {
  display: block; font-family: var(--font-mono); font-size: 10.5px;
  color: var(--ink-3); font-weight: 500; margin-top: 2px; letter-spacing: 0.02em;
}
.ps-desc { font-size: 11.5px; color: var(--ink-2); line-height: 1.4; }
.ps-thumb {
  height: 64px; border-radius: 8px;
  background: color-mix(in oklch, var(--bg-0) 70%, var(--bg-1));
  border: 1px solid var(--line-soft);
  padding: 6px 8px; overflow: hidden; position: relative;
  display: flex; flex-direction: column; gap: 4px;
}

/* ─── §4 · Warning banner tiers ──────────────────────────────── */
.page-warning-banner.wb {
  display: grid; grid-template-columns: 36px 1fr auto; gap: 14px; align-items: center;
  padding: 14px 18px; border-radius: var(--r-md);
  border: 1px solid var(--line);
  border-left: 4px solid var(--line);
  background: var(--bg-1);
  position: relative;
}
.page-warning-banner.tier-info {
  background: color-mix(in oklch, var(--info) 7%, var(--bg-1));
  border-color: color-mix(in oklch, var(--info) 30%, var(--line));
  border-left-color: var(--info);
}
.page-warning-banner.tier-warn {
  background: color-mix(in oklch, var(--warn) 8%, var(--bg-1));
  border-color: color-mix(in oklch, var(--warn) 30%, var(--line));
  border-left-color: var(--warn);
}
.page-warning-banner.tier-bad {
  background: color-mix(in oklch, var(--bad) 8%, var(--bg-1));
  border-color: color-mix(in oklch, var(--bad) 30%, var(--line));
  border-left-color: var(--bad);
}
.page-warning-banner.tier-critical {
  background: color-mix(in oklch, var(--bad) 12%, var(--bg-1));
  border: 1px solid var(--bad);
  border-left: 4px solid var(--bad);
  animation: var(--anim-banner-crit);
}
.page-warning-banner .wb-ic {
  width: 36px; height: 36px; border-radius: 50%;
  display: grid; place-items: center;
  background: color-mix(in oklch, var(--bg-0) 60%, transparent);
  border: 1px solid var(--line-soft);
  color: var(--ink-1);
}
.page-warning-banner .wb-ic svg {
  width: 22px; height: 22px;
  fill: none; stroke: currentColor;
  stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round;
}
.page-warning-banner.tier-info .wb-ic    { color: var(--info); border-color: color-mix(in oklch, var(--info) 40%, var(--line-soft)); }
.page-warning-banner.tier-warn .wb-ic    { color: var(--warn); border-color: color-mix(in oklch, var(--warn) 40%, var(--line-soft)); }
.page-warning-banner.tier-bad .wb-ic     { color: var(--bad);  border-color: color-mix(in oklch, var(--bad) 50%, var(--line-soft)); }
.page-warning-banner.tier-critical .wb-ic {
  color: var(--bad);
  background: color-mix(in oklch, var(--bad) 18%, var(--bg-0));
  border-color: var(--bad);
}
.page-warning-banner .wb-title {
  font-size: 12px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.05em; margin-bottom: 2px;
  color: var(--ink-2);
}
.page-warning-banner.tier-info .wb-title    { color: var(--info); }
.page-warning-banner.tier-warn .wb-title    { color: var(--warn); }
.page-warning-banner.tier-bad .wb-title,
.page-warning-banner.tier-critical .wb-title { color: var(--bad); }
.page-warning-banner .wb-msg {
  font-size: 13px; color: var(--ink-1); line-height: 1.4;
}
.page-warning-banner .wb-msg b { color: var(--ink-0); font-weight: 600; }
.page-warning-banner .wb-action {
  appearance: none;
  padding: 8px 14px; border-radius: var(--r-sm);
  background: var(--bg-2); color: var(--ink-1); border: 1px solid var(--line);
  font-family: var(--font-ui); font-size: 12px; font-weight: 600;
  cursor: pointer; white-space: nowrap;
}
.page-warning-banner.tier-bad .wb-action,
.page-warning-banner.tier-critical .wb-action {
  background: var(--bad); color: var(--ink-0); border-color: var(--bad);
}
.page-warning-banner.tier-warn .wb-action { background: var(--warn); color: var(--bg-0); border-color: var(--warn); }
.page-warning-banner.tier-info .wb-action { background: var(--info); color: var(--bg-0); border-color: var(--info); }

/* ─── §5 · Critical KPI alert overlay (modal variant) ────────── */
.modal.critical-kpi-alert .modal-backdrop {
  position: fixed; inset: 0;
  backdrop-filter: blur(8px) saturate(1.1);
  -webkit-backdrop-filter: blur(8px) saturate(1.1);
  background: color-mix(in oklch, var(--bg-0) 60%, transparent);
  z-index: var(--z-modal-bg);
}
.modal.critical-kpi-alert .modal-dialog {
  position: fixed; left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: 460px; max-width: 90vw;
  background: linear-gradient(180deg,
    color-mix(in oklch, var(--bg-2) 70%, var(--bg-1)) 0%,
    var(--bg-1) 100%);
  border: 1px solid color-mix(in oklch, var(--bad) 50%, var(--line));
  border-radius: var(--r-lg);
  padding: 26px 26px 22px;
  box-shadow:
    var(--shadow-high),
    inset 0 0 0 1px color-mix(in oklch, var(--bad) 26%, transparent),
    0 0 80px -10px color-mix(in oklch, var(--bad) 50%, transparent);
  text-align: center;
  animation: var(--anim-modal-in);
  z-index: var(--z-modal);
}
.modal.critical-kpi-alert .alert-big-ic {
  width: 64px; height: 64px; margin: 0 auto 16px;
  border-radius: 50%;
  display: grid; place-items: center;
  color: var(--bad);
  background: color-mix(in oklch, var(--bad) 14%, var(--bg-2));
  border: 1px solid var(--bad);
  animation: var(--anim-alert-ic);
}
.modal.critical-kpi-alert .alert-big-ic svg {
  width: 28px; height: 28px;
  fill: none; stroke: currentColor;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}
.modal.critical-kpi-alert .alert-kicker {
  font-family: var(--font-mono); font-size: 11px; color: var(--bad);
  text-transform: uppercase; letter-spacing: 0.12em; font-weight: 600;
  margin-bottom: 8px;
}
.modal.critical-kpi-alert .alert-title {
  font-family: var(--font-ui); font-size: 22px; font-weight: 700;
  color: var(--ink-0); margin: 0 0 10px; letter-spacing: -0.01em;
}
.modal.critical-kpi-alert .alert-msg {
  font-size: 13.5px; color: var(--ink-1); line-height: 1.5;
  margin: 0 auto 18px; max-width: 380px;
}
.modal.critical-kpi-alert .alert-msg b { color: var(--ink-0); }
.modal.critical-kpi-alert .alert-msg .bad-num {
  color: var(--bad); font-family: var(--font-mono); font-weight: 600;
}
.modal.critical-kpi-alert .alert-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
  margin-bottom: 20px; padding: 10px 4px;
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
}
.modal.critical-kpi-alert .alert-stat .lbl {
  font-size: 10px; text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--ink-3); font-weight: 600; margin-bottom: 4px;
}
.modal.critical-kpi-alert .alert-stat .v {
  font-family: var(--font-mono); font-size: 14px; font-weight: 600; color: var(--ink-0);
}
.modal.critical-kpi-alert .alert-stat .v.bad  { color: var(--bad); }
.modal.critical-kpi-alert .alert-stat .v.warn { color: var(--warn); }
.modal.critical-kpi-alert .modal-foot,
.modal.critical-kpi-alert .alert-actions {
  display: flex; gap: 10px; justify-content: center;
}
.modal.critical-kpi-alert .modal-foot .btn,
.modal.critical-kpi-alert .alert-actions .alert-btn {
  appearance: none;
  padding: 10px 18px; border-radius: var(--r-sm);
  font-family: var(--font-ui); font-size: 13px; font-weight: 600;
  cursor: pointer;
  border: 1px solid var(--line);
  background: var(--bg-2); color: var(--ink-1);
}
.modal.critical-kpi-alert .modal-foot .btn-danger,
.modal.critical-kpi-alert .modal-foot .btn-primary,
.modal.critical-kpi-alert .alert-actions .alert-btn.primary {
  background: var(--bad); color: var(--ink-0); border-color: var(--bad);
  box-shadow: 0 4px 14px color-mix(in oklch, var(--bad) 40%, transparent);
}
