/* ===================================================
   CREWFORGE - Complete Clean Stylesheet v4
   Zero opacity:0 on any visible content. Ever.
   =================================================== */

/* ─── RESET ─────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  background: #000;
  color: #fff;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; }
a { text-decoration: none; color: inherit; }
button { font-family: inherit; }

/* ─── DESIGN TOKENS ──────────────────────────────── */
:root {
  --yellow:   #ffcd24;
  --black:    #000;
  --g950:     #0a0a0a;
  --g900:     #111;
  --g800:     #1a1a1a;
  --g700:     #242424;
  --g600:     #2e2e2e;
  --g500:     #3d3d3d;
  --g400:     #606060;
  --g300:     #909090;
  --g200:     #b8b8b8;
  --white:    #fff;
  --green:    #22c55e;
  --radius:   10px;
  --rad-lg:   16px;
  --trans:    0.3s ease;
}

/* ─── UTILITIES ─────────────────────────────────── */
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.yellow { color: var(--yellow); }
.yellow-icon { color: var(--yellow); }
.section { padding: 100px 0; position: relative; }

.section-eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--yellow);
  margin-bottom: 16px;
}
h2 {
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin-bottom: 20px;
}
.section-sub {
  font-size: 1.05rem;
  color: var(--g300);
  max-width: 600px;
  margin-bottom: 56px;
  line-height: 1.7;
}

/* Grid background decoration */
.grid-bg {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,205,36,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,205,36,0.025) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: 0;
}
.grid-bg + * { position: relative; z-index: 1; }

/* ─── BUTTONS ─────────────────────────────────────── */
.btn-yellow {
  display: inline-block;
  background: var(--yellow);
  color: #000;
  font-weight: 800;
  font-size: 0.9rem;
  padding: 12px 28px;
  border-radius: var(--radius);
  border: none;
  cursor: pointer;
  transition: box-shadow var(--trans), transform var(--trans);
  letter-spacing: 0.02em;
}
.btn-yellow:hover {
  box-shadow: 0 0 28px rgba(255,205,36,0.45);
  transform: translateY(-1px);
}
/* Ensure minimum touch target size */
.btn-yellow, .btn-ghost {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.btn-yellow.btn-lg { padding: 16px 36px; font-size: 1rem; }
.btn-yellow.btn-xl { padding: 20px 48px; font-size: 1.1rem; }

.btn-ghost {
  display: inline-block;
  background: transparent;
  color: var(--white);
  font-weight: 600;
  font-size: 0.9rem;
  padding: 12px 28px;
  border-radius: var(--radius);
  border: 1px solid var(--g600);
  cursor: pointer;
  transition: border-color var(--trans), color var(--trans);
}
.btn-ghost:hover { border-color: var(--yellow); color: var(--yellow); }
.btn-ghost.btn-lg { padding: 16px 36px; font-size: 1rem; }

/* ─── NAVIGATION ──────────────────────────────────── */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  background: rgba(0,0,0,0.9);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--g800);
  transition: background var(--trans);
  /* Support notched iPhones */
  padding-left: env(safe-area-inset-left);
  padding-right: env(safe-area-inset-right);
}
.nav-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  height: 64px;
  display: flex;
  align-items: center;
  gap: 40px;
}
.nav-logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.nav-logo-img {
  height: 36px;
  width: auto;
  display: block;
}
.nav-links {
  display: flex;
  gap: 28px;
  flex: 1;
}
.nav-links a {
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--g300);
  transition: color var(--trans);
}
.nav-links a:hover { color: var(--white); }
.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 10px 4px;
  margin-left: auto;
  min-width: 44px;
  min-height: 44px;
  align-items: center;
  justify-content: center;
}
.hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--white);
  border-radius: 2px;
}
.nav-drawer {
  display: none;
  flex-direction: column;
  padding: 16px 24px 24px;
  gap: 16px;
  border-top: 1px solid var(--g800);
}
.nav-drawer a { font-size: 1rem; color: var(--g300); }
.nav-drawer.open { display: flex; }

/* ─── HERO ────────────────────────────────────────── */
/* 
  KEY FIX: Hero background uses a real <img> tag inside a positioned wrapper.
  The overlay is a separate absolutely-positioned div OVER the image.
  This is the most reliable cross-browser approach.
*/
.hero {
  position: relative;
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  align-items: center;
  padding-top: 64px;
  background: #0a0a0a;
}

/* Background image layer */
.hero-bg-layer {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}
.hero-bg-layer img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  display: block;
  /* NO opacity, NO filter that would hide it */
}
/* Dark overlay on top of image */
.hero-bg-layer::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.72) 0%,
    rgba(0,0,0,0.65) 50%,
    rgba(0,0,0,0.80) 100%
  );
}

/* Hero content sits above background */
.hero-content {
  position: relative;
  z-index: 1;
  width: 100%;
}
.hero-grid {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 100px 24px 90px;
  max-width: 900px;
  margin: 0 auto;
}

.hero-logo-lockup {
  margin-bottom: 36px;
  display: flex;
  justify-content: center;
}
.hero-logo-img {
  height: 56px;
  width: auto;
  display: block;
  /* drop-shadow so it pops against any background */
  filter: drop-shadow(0 2px 12px rgba(0,0,0,0.5));
}
@keyframes pulse {
  0%,100% { transform: scale(1); }
  50% { transform: scale(0.7); }
}

.hero-copy h1 {
  font-size: clamp(3rem, 6vw, 5.5rem);
  font-weight: 900;
  line-height: 1.06;
  letter-spacing: -0.03em;
  margin-bottom: 28px;
}
.hero-sub {
  font-size: clamp(1.05rem, 1.5vw, 1.25rem);
  color: var(--g300);
  line-height: 1.7;
  max-width: 680px;
  margin-bottom: 40px;
}
.hero-btns { display: flex; gap: 16px; margin-bottom: 56px; flex-wrap: wrap; justify-content: center; }
.hero-stats { display: flex; align-items: center; gap: 32px; flex-wrap: wrap; justify-content: center; }
.stat { display: flex; flex-direction: column; }
.stat-n { font-size: 1.6rem; font-weight: 900; color: var(--yellow); }
.stat-l { font-size: 0.72rem; color: var(--g400); letter-spacing: 0.05em; }
.stat-div { width: 1px; height: 36px; background: var(--g700); }

/* ── Hero pills ── */
.hero-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
}
.hero-pill {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 10px 18px;
  border-radius: 100px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--g200);
  backdrop-filter: blur(6px);
  transition: border-color var(--trans), color var(--trans);
}
.hero-pill i {
  color: var(--yellow);
  font-size: 0.8rem;
}
.hero-pill:hover {
  border-color: rgba(255, 205, 36, 0.35);
  color: var(--white);
}

/* Hero is now single-column full-width */

/* ─── SCORE REPORT CARD ───────────────────────────── */
.score-report-card {
  background: rgba(15,15,15,0.96);
  border: 1px solid var(--g700);
  border-radius: var(--rad-lg);
  padding: 20px;
  width: 100%;
  max-width: 400px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.7);
  backdrop-filter: blur(20px);
  font-size: 0.82rem;
  max-height: 90vh;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--g700) transparent;
}
.score-report-card::-webkit-scrollbar { width: 4px; }
.score-report-card::-webkit-scrollbar-track { background: transparent; }
.score-report-card::-webkit-scrollbar-thumb { background: var(--g700); border-radius: 2px; }

.sr-header { margin-bottom: 16px; border-bottom: 1px solid var(--g800); padding-bottom: 16px; }
.sr-tier-badge {
  display: inline-block;
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  color: #3b82f6;
  background: rgba(59,130,246,0.1);
  border: 1px solid rgba(59,130,246,0.25);
  border-radius: 4px;
  padding: 3px 8px;
  margin-bottom: 8px;
  text-transform: uppercase;
}
.sr-name { font-size: 1rem; font-weight: 800; color: var(--white); margin-bottom: 2px; }
.sr-role { font-size: 0.7rem; color: var(--g400); margin-bottom: 10px; }
.sr-score-wrap { display: flex; align-items: baseline; gap: 4px; }
.sr-score-num { font-size: 2rem; font-weight: 900; color: var(--yellow); line-height: 1; }
.sr-score-denom { font-size: 0.78rem; color: var(--g400); }

.sr-section-label {
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--g300);
  margin-bottom: 10px;
  margin-top: 14px;
}
.sr-category { margin-bottom: 10px; }
.sr-cat-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.sr-cat-name { display: flex; align-items: center; gap: 6px; font-size: 0.75rem; font-weight: 600; color: var(--g200); }
.sr-dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.sr-cat-score { font-size: 0.72rem; font-weight: 700; color: var(--g300); }
.sr-bar-track { height: 5px; background: var(--g800); border-radius: 3px; overflow: hidden; margin-bottom: 4px; }
.sr-bar-fill { height: 100%; border-radius: 3px; }
.sr-cat-sub { display: flex; justify-content: space-between; font-size: 0.62rem; color: var(--g500); }

.sr-divider { height: 1px; background: var(--g800); margin: 12px 0; }

.sr-findings-list { display: flex; flex-direction: column; gap: 8px; }
.sr-finding { display: flex; gap: 10px; }
.sr-find-num { font-size: 0.65rem; font-weight: 900; width: 18px; flex-shrink: 0; padding-top: 1px; }
.sr-finding strong { display: block; font-size: 0.75rem; font-weight: 700; color: var(--white); margin-bottom: 3px; }
.sr-finding p { font-size: 0.7rem; color: var(--g400); line-height: 1.5; margin: 0; }

.sr-snapshot { display: flex; flex-direction: column; gap: 6px; }
.sr-snap-row { display: flex; justify-content: space-between; font-size: 0.72rem; padding: 5px 0; border-bottom: 1px solid var(--g800); }
.sr-snap-row:last-child { border-bottom: none; }
.sr-snap-row span { color: var(--g400); }
.sr-snap-row strong { color: var(--white); font-weight: 600; }

.sr-tier-ref {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--g800);
}
.sr-tier-ref span { display: flex; align-items: center; gap: 5px; font-size: 0.62rem; color: var(--g400); }
.sr-tier-ref b { font-weight: 700; }

/* ─── TRUST BAR ────────────────────────────────────── */
.trust-bar {
  background: var(--g900);
  border-top: 1px solid var(--g800);
  border-bottom: 1px solid var(--g800);
  padding: 20px 0;
}
.trust-bar .container {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.trust-label { font-size: 0.72rem; color: var(--g400); letter-spacing: 0.1em; text-transform: uppercase; }
.trust-item { font-size: 0.82rem; font-weight: 600; color: var(--g300); }
.trust-sep { color: var(--g600); }

/* ─── RISK STATEMENT BANNER ────────────────────────── */
.risk-banner {
  background: #0d0a00;
  border-top: 1px solid rgba(255, 205, 36, 0.2);
  border-bottom: 1px solid rgba(255, 205, 36, 0.2);
  padding: 36px 0;
  position: relative;
  overflow: hidden;
}
/* Subtle amber glow behind the content */
.risk-banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 100% at 50% 50%, rgba(255,205,36,0.05) 0%, transparent 70%);
  pointer-events: none;
}
.risk-banner__inner {
  display: grid;
  grid-template-columns: 48px 1fr auto;
  gap: 24px;
  align-items: center;
  position: relative;
  z-index: 1;
}
.risk-banner__alert {
  font-size: 1.6rem;
  color: var(--yellow);
  opacity: 0.9;
  line-height: 1;
  padding-top: 2px;
}
.risk-banner__copy {
  border-left: 2px solid rgba(255,205,36,0.3);
  padding-left: 20px;
}
.risk-banner__headline {
  font-size: 0.92rem;
  font-weight: 600;
  color: #e8e8e8;
  line-height: 1.6;
  margin-bottom: 8px;
}
.risk-banner__sub {
  font-size: 0.8rem;
  color: var(--g400);
  line-height: 1.5;
}
.risk-banner__sub strong {
  color: var(--yellow);
  font-weight: 700;
}
.risk-banner__pills {
  display: flex;
  flex-direction: column;
  gap: 8px;
  border-left: 1px solid var(--g800);
  padding-left: 28px;
  flex-shrink: 0;
}
.risk-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--g200);
  white-space: nowrap;
}
.risk-pill i {
  color: var(--yellow);
  font-size: 0.72rem;
  width: 14px;
  text-align: center;
}

/* Responsive */
@media (max-width: 900px) {
  .risk-banner__inner {
    grid-template-columns: 36px 1fr;
    gap: 16px;
  }
  .risk-banner__pills {
    grid-column: 1 / -1;
    border-left: none;
    border-top: 1px solid var(--g800);
    padding-left: 0;
    padding-top: 20px;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 12px 20px;
  }
}
@media (max-width: 480px) {
  .risk-banner__inner {
    grid-template-columns: 1fr;
  }
  .risk-banner__alert { display: none; }
  .risk-banner__copy { border-left: none; padding-left: 0; border-top: 2px solid rgba(255,205,36,0.3); padding-top: 16px; }

}

/* ─── PHOTO STRIP ──────────────────────────────────── */
/*
  KEY FIX: Simple flex row of images with explicit heights.
  No z-index tricks, no position:absolute on images.
*/
.photo-strip {
  border-top: 1px solid var(--g800);
  border-bottom: 1px solid var(--g800);
  overflow: hidden;
  background: var(--black);
}
.photo-strip-inner {
  display: flex;
  height: 260px;
  gap: 3px;
}
.ps-item {
  position: relative;
  flex: 1;
  overflow: hidden;
}
.ps-item.ps-wide { flex: 1; }
.ps-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform 0.5s ease;
}
.ps-item:hover img { transform: scale(1.05); }
.ps-label {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.8) 0%, transparent 100%);
  color: var(--white);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 24px 12px 10px;
}
@media (max-width: 768px) {
  .ps-label { font-size: 0.55rem; letter-spacing: 0.06em; padding: 16px 8px 7px; }
}
@media (max-width: 480px) {
  .ps-label { font-size: 0.48rem; letter-spacing: 0.04em; padding: 12px 6px 6px; }
}

/* ─── PAIN SECTION ─────────────────────────────────── */
.pain-section { background: var(--g950); }
.pain-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-bottom: 48px;
}
.pain-card {
  background: var(--g900);
  border: 1px solid var(--g800);
  border-radius: var(--rad-lg);
  padding: 28px 24px;
  transition: border-color var(--trans), transform var(--trans);
}
.pain-card:hover { border-color: rgba(255,205,36,0.3); transform: translateY(-4px); }
.pain-icon {
  width: 44px; height: 44px;
  border-radius: 10px;
  background: rgba(255,205,36,0.08);
  border: 1px solid rgba(255,205,36,0.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem;
  color: var(--yellow);
  margin-bottom: 18px;
}
.pain-label { font-size: 0.9rem; font-weight: 800; color: var(--white); margin-bottom: 10px; }
.pain-desc { font-size: 0.88rem; color: var(--g400); line-height: 1.65; }
.pain-quote {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  padding: 32px;
  background: var(--g900);
  border: 1px solid var(--g800);
  border-radius: var(--rad-lg);
}
.pq-line { width: 3px; min-height: 60px; background: var(--yellow); border-radius: 2px; flex-shrink: 0; }
.pain-quote p { font-size: 1.05rem; font-style: italic; color: var(--g200); margin-bottom: 8px; }
.pain-quote span { font-size: 0.78rem; color: var(--g500); }

/* ─── SYSTEM SECTION (redesign) ────────────────────── */
/* ─── SYSTEM / REFRAME ───────────────────────────── */
.system-section {
  background: var(--black);
  overflow: hidden;
}

/* Full-bleed split layout */
.sys-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 680px;
}

/* ── Photo side ── */
.sys-photo-side {
  position: relative;
  display: grid;
  grid-template-rows: 1fr auto;
  gap: 0;
  overflow: hidden;
}

.sys-photo-main {
  overflow: hidden;
}
.sys-photo-main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  display: block;
  filter: brightness(0.78) saturate(0.85);
  transition: transform 0.8s ease;
}
.sys-photo-main:hover img { transform: scale(1.03); }

.sys-photo-sub {
  display: grid;
  grid-template-columns: 1fr 1fr;
  height: 180px;
  border-top: 1px solid #1a1a1a;
}
.sys-photo-sub img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 40%;
  display: block;
  filter: brightness(0.65) saturate(0.8);
}

/* Stat overlay inside sub-photo row */
.sys-photo-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--g950);
  border-left: 1px solid #1a1a1a;
  gap: 6px;
  padding: 20px;
}
.sys-photo-stat-num {
  font-size: 3rem;
  font-weight: 900;
  color: var(--white);
  line-height: 1;
  letter-spacing: -0.03em;
}
.sys-photo-stat-unit {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--g400);
  margin-left: 2px;
}
.sys-photo-stat-label {
  font-size: 0.72rem;
  color: var(--g400);
  text-align: center;
  line-height: 1.5;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* ── Copy side ── */
.sys-copy-side {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 80px 64px;
  background: var(--g950);
  border-left: 1px solid #1a1a1a;
}

.sys-eyebrow-row {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 32px;
}
.sys-eyebrow-line {
  display: block;
  width: 32px;
  height: 2px;
  background: var(--yellow);
  flex-shrink: 0;
}
.sys-eyebrow-text {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--yellow);
}

.sys-heading {
  font-size: clamp(2.4rem, 3.5vw, 3.6rem);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: var(--white);
  margin-bottom: 24px;
}
.sys-heading em {
  font-style: normal;
  color: var(--yellow);
}

.sys-lead {
  font-size: 0.98rem;
  color: var(--g300);
  line-height: 1.75;
  margin-bottom: 40px;
  max-width: 420px;
}

/* Comparison table */
.sys-compare {
  display: flex;
  flex-direction: column;
  margin-bottom: 40px;
}

.sys-compare-head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  margin-bottom: 4px;
}
.sys-compare-head span {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--g500);
  padding: 0 14px 8px;
}
.sys-compare-head span:last-child { color: rgba(255,205,36,0.5); }

.sys-compare-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: #1a1a1a;
  border-radius: 0;
}
.sys-compare-row:first-of-type { border-radius: 8px 8px 0 0; overflow: hidden; }
.sys-compare-row:last-of-type  { border-radius: 0 0 8px 8px; overflow: hidden; }

.sys-compare-cell {
  padding: 13px 14px;
  font-size: 0.875rem;
  line-height: 1.4;
}
.sys-compare-cell--bad {
  background: #111;
  color: var(--g400);
  text-decoration: line-through;
  text-decoration-color: rgba(239,68,68,0.35);
}
.sys-compare-cell--good {
  background: rgba(255,205,36,0.04);
  color: var(--g100, #e8e8e8);
  font-weight: 500;
}

/* CTA link */
.sys-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--yellow);
  letter-spacing: 0.02em;
  border-bottom: 1px solid rgba(255,205,36,0.25);
  padding-bottom: 4px;
  width: fit-content;
  transition: gap var(--trans), border-color var(--trans);
}
.sys-cta:hover {
  gap: 16px;
  border-color: var(--yellow);
}

/* ── Responsive ── */
@media (max-width: 960px) {
  .sys-split {
    grid-template-columns: 1fr;
    min-height: auto;
  }
  .sys-photo-side {
    height: 360px;
    grid-template-rows: 1fr 120px;
  }
  .sys-photo-sub { height: 120px; }
  .sys-copy-side {
    padding: 52px 28px;
    border-left: none;
    border-top: 1px solid #1a1a1a;
  }
  .sys-lead { max-width: 100%; }
}

@media (max-width: 600px) {
  .sys-photo-side { height: 280px; grid-template-rows: 1fr 100px; }
  .sys-photo-sub { height: 100px; }
  .sys-photo-stat-num { font-size: 2.2rem; }
  .sys-copy-side { padding: 40px 20px; }
  .sys-heading { font-size: 2.2rem; }
  .sys-compare-cell { padding: 10px 10px; font-size: 0.8rem; }
}

/* ─── HOW IT WORKS ─────────────────────────────────── */
.how-section { background: var(--g950); }
.steps-grid {
  display: grid;
  /* 4 cards + 3 arrows: cards are flexible, arrows are fixed-width */
  grid-template-columns: 1fr 44px 1fr 44px 1fr 44px 1fr;
  gap: 0 8px;
  align-items: stretch;
}

/* ── Timeline Arrow ───────────────────────── */
.step-arrow {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  position: relative;
  height: 100%;
  min-height: 120px;
  pointer-events: none;
}
.step-arrow__line {
  width: 2px;
  flex: 1;
  background: linear-gradient(to bottom, transparent, rgba(255,205,36,0.35) 30%, rgba(255,205,36,0.35) 70%, transparent);
  min-height: 40px;
}
.step-arrow__label {
  font-size: 0.55rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,205,36,0.55);
}
.step-arrow__icon {
  font-size: 0.9rem;
  color: var(--yellow);
  opacity: 0.85;
  animation: arrowPulse 1.8s ease-in-out infinite;
}
/* Vertical icon hidden on desktop */
.step-arrow__icon--v { display: none; }

@keyframes arrowPulse {
  0%, 100% { opacity: 0.6; transform: translateX(0); }
  50%       { opacity: 1;   transform: translateX(3px); }
}
.step-card {
  background: var(--g900);
  border: 1px solid var(--g800);
  border-radius: var(--rad-lg);
  overflow: hidden;
  transition: border-color var(--trans), transform var(--trans);
  display: flex;
  flex-direction: column;
}
.step-card:hover { border-color: rgba(255,205,36,0.3); transform: translateY(-4px); }

/*
  KEY FIX for step images:
  Explicit height, object-fit cover, display block.
  NO opacity, NO grayscale, NO brightness < 1.
*/
.step-img-wrap {
  position: relative;
  height: 180px;
  overflow: hidden;
  background: var(--g800); /* fallback if image slow to load */
}
.step-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  /* Visible brightness */
  filter: brightness(0.8);
  transition: transform 0.5s ease, filter 0.3s ease;
}
.step-card:hover .step-img-wrap img {
  transform: scale(1.04);
  filter: brightness(0.9);
}
.step-num {
  position: absolute;
  top: 12px; left: 12px;
  font-size: 0.65rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  color: var(--yellow);
  background: rgba(0,0,0,0.8);
  border: 1px solid rgba(255,205,36,0.4);
  padding: 4px 9px;
  border-radius: 5px;
  z-index: 2;
}
.step-num.ai-num { color: #8b5cf6; border-color: rgba(139,92,246,0.4); }
.step-num.cv-num { color: var(--yellow); }
.step-body { padding: 20px; display: flex; flex-direction: column; flex: 1; }
.step-body p { flex: 1; }
.step-icon {
  width: 40px; height: 40px;
  background: rgba(255,205,36,0.08);
  border: 1px solid rgba(255,205,36,0.2);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: var(--yellow);
  margin-bottom: 14px;
}
.step-icon.ai-icon { background: rgba(139,92,246,0.1); border-color: rgba(139,92,246,0.25); color: #8b5cf6; }
.step-icon.cv-icon { background: rgba(255,205,36,0.12); border-color: rgba(255,205,36,0.3); color: var(--yellow); }
.step-body h3 { font-size: 1rem; font-weight: 800; margin-bottom: 8px; }
.step-body p { font-size: 0.82rem; color: var(--g400); line-height: 1.6; margin-bottom: 14px; }
.step-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.step-tags span { font-size: 0.65rem; font-weight: 700; padding: 3px 8px; border-radius: 4px; background: var(--g800); color: var(--g300); border: 1px solid var(--g700); }
.step-tags span.ai-tag { background: rgba(139,92,246,0.1); color: #8b5cf6; border-color: rgba(139,92,246,0.25); }
.ai-badge { font-size: 0.6rem; font-weight: 800; background: #8b5cf6; color: #fff; padding: 2px 6px; border-radius: 4px; vertical-align: middle; margin-left: 4px; }

/* ─── IMPACT SECTION ───────────────────────────────── */
.impact-section { background: var(--black); }
.impact-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.impact-card {
  background: var(--g900);
  border: 1px solid var(--g800);
  border-radius: var(--rad-lg);
  padding: 32px 24px;
  transition: border-color var(--trans), transform var(--trans);
}
.impact-card:hover { border-color: rgba(255,205,36,0.25); transform: translateY(-4px); }
.impact-card--accent { border-color: rgba(255,205,36,0.3); background: rgba(255,205,36,0.04); }
.impact-icon-wrap {
  width: 48px; height: 48px;
  border-radius: 12px;
  background: rgba(255,205,36,0.08);
  border: 1px solid rgba(255,205,36,0.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.15rem;
  color: var(--yellow);
  margin-bottom: 20px;
}
.impact-icon-wrap--accent {
  background: rgba(255,205,36,0.12);
  border-color: rgba(255,205,36,0.3);
}
.impact-label { font-size: 0.92rem; font-weight: 800; color: var(--white); margin-bottom: 12px; line-height: 1.3; }
.impact-card p { font-size: 0.85rem; color: var(--g400); line-height: 1.6; }

/* ─── PHOTO BAND ───────────────────────────────────── */
/*
  KEY FIX: Simple position:relative container.
  Image uses object-fit cover and is NOT hidden.
  Overlay sits on top with position:absolute.
*/
/* ─── PHOTO CAROUSEL ─────────────────────────────── */
.photo-carousel {
  position: relative;
  background: #0a0a0a;
  overflow: hidden;
  height: 480px;
  user-select: none;
}
.krane-copy-wrap {
  position: relative;
  z-index: 1;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px 48px;
}
.krane-copy-inner {
  display: flex;
  align-items: center;
  gap: 64px;
}
.krane-copy-text {
  flex: 1;
  min-width: 0;
}
.krane-logo-side {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.krane-logo-img {
  width: 340px;
  opacity: 0.92;
  filter: drop-shadow(0 0 40px rgba(255,255,255,0.08));
}
.krane-logo-mobile { display: none; }
@media (max-width: 860px) {
  .krane-copy-inner { flex-direction: row; }
  .krane-logo-side { display: none; }
  .krane-logo-mobile { display: block; width: 120px; margin-bottom: 20px; }
}
.krane-carousel {
  position: relative;
  z-index: 1;
  overflow: hidden;
  height: 520px;
  user-select: none;
}
@media (max-width: 768px) {
  .krane-carousel { height: 360px; }
  .krane-copy-wrap { padding: 0 16px 36px; }
}
.pc-track {
  display: flex;
  height: 100%;
  transition: transform 0.55s cubic-bezier(0.77, 0, 0.18, 1);
  will-change: transform;
}
.pc-slide {
  position: relative;
  flex: 0 0 100%;
  height: 100%;
  overflow: hidden;
}
.pc-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 35%;
  display: block;
  filter: brightness(0.78) saturate(0.9);
  transition: transform 0.8s ease;
  pointer-events: none;
}
.photo-carousel:not(.is-dragging) .pc-slide.active img { transform: scale(1.03); }
.pc-slide::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.55) 0%, transparent 50%);
  pointer-events: none;
}
.pc-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.15);
  color: #fff;
  font-size: 0.9rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 10;
  transition: background 0.3s ease, border-color 0.3s ease, transform 0.2s ease;
}
.pc-arrow:hover { background: rgba(255,205,36,0.18); border-color: rgba(255,205,36,0.5); transform: translateY(-50%) scale(1.08); }
.pc-arrow--prev { left: 20px; }
.pc-arrow--next { right: 20px; }
.pc-dots {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 10;
}
.pc-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(255,255,255,0.35);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background 0.3s ease, transform 0.3s ease, width 0.3s ease;
}
.pc-dot.active { background: var(--yellow); width: 24px; border-radius: 4px; }
.pc-counter {
  position: absolute;
  top: 18px;
  right: 20px;
  font-size: 0.7rem;
  font-weight: 700;
  color: rgba(255,255,255,0.6);
  letter-spacing: 0.08em;
  z-index: 10;
  background: rgba(0,0,0,0.4);
  backdrop-filter: blur(6px);
  padding: 4px 10px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,0.08);
}
@media (max-width: 768px) {
  .photo-carousel { height: 320px; }
  .pc-label { bottom: 48px; left: 16px; font-size: 0.68rem; padding: 6px 12px; }
  .pc-arrow { width: 38px; height: 38px; font-size: 0.78rem; }
  .pc-arrow--prev { left: 10px; }
  .pc-arrow--next { right: 10px; }
}

/* ─── DASHBOARD KPI STRIP ────────────────────────── */
.dash-kpi-strip {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}
.dash-kpi-card {
  background: var(--g900);
  border: 1px solid var(--g700);
  border-radius: var(--radius);
  padding: 16px 18px;
  transition: border-color var(--trans);
}
.dash-kpi-card:hover { border-color: rgba(255,205,36,0.25); }
.dkc-val {
  font-size: 1.6rem;
  font-weight: 900;
  color: var(--yellow);
  line-height: 1;
  margin-bottom: 4px;
}
.dkc-label {
  font-size: 0.7rem;
  color: var(--g400);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 6px;
}
.dkc-delta {
  font-size: 0.68rem;
  font-weight: 700;
}
.dkc-delta.up { color: var(--green); }
.dkc-delta.neutral { color: var(--g500); }

/* ─── DASHBOARD UI ─────────────────────────────────── */
.dash-section { background: var(--g950); }
.dash-ui {
  background: var(--g900);
  border: 1px solid var(--g700);
  border-radius: var(--rad-lg);
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,0.5);
}
.dash-ui-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 24px;
  border-bottom: 1px solid var(--g800);
  background: var(--g950);
}
.dash-ui-tabs { display: flex; gap: 4px; }
.dash-tab {
  font-family: inherit;
  font-size: 0.82rem;
  font-weight: 600;
  padding: 7px 14px;
  border-radius: 6px;
  border: none;
  background: transparent;
  color: var(--g400);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: background var(--trans), color var(--trans);
  position: relative;
}
.dash-tab:hover { background: rgba(255,255,255,0.04); color: var(--g200); }
.dash-tab.active { background: var(--g800); color: var(--white); }
.dash-tab-badge {
  font-size: 0.6rem;
  font-weight: 800;
  background: #f97316;
  color: #fff;
  border-radius: 100px;
  padding: 1px 5px;
  line-height: 1.4;
}
.dash-ui-meta { display: flex; align-items: center; gap: 8px; font-size: 0.75rem; color: var(--g500); }
.live-dot { width: 7px; height: 7px; background: var(--green); border-radius: 50%; animation: pulse 2s infinite; flex-shrink: 0; }

/* Tab panels */
.dash-tab-panel { display: none; }
.dash-tab-panel.active { display: block; }

/* Pipeline tab layout */
.dash-pipeline-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 380px;
}
.dash-funnel-col {
  border-right: 1px solid var(--g800);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.dash-panel-title {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--g300);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.dash-funnel { display: flex; flex-direction: column; gap: 14px; }
.df-stage {}
.df-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--g300);
  margin-bottom: 6px;
}
.df-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.df-count { margin-left: auto; font-size: 0.78rem; font-weight: 800; color: var(--white); }
.df-bar-track { height: 5px; background: var(--g800); border-radius: 3px; overflow: hidden; margin-bottom: 3px; }
.df-bar-fill { height: 100%; border-radius: 3px; }
.df-pct { font-size: 0.62rem; color: var(--g500); }

/* Filter chips */
.dash-filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: auto;
}
.dfc-chip {
  font-family: inherit;
  font-size: 0.68rem;
  font-weight: 700;
  padding: 6px 12px;
  border-radius: 100px;
  border: 1px solid var(--g700);
  background: var(--g800);
  color: var(--g400);
  cursor: pointer;
  min-height: 36px;
  transition: border-color var(--trans), color var(--trans), background var(--trans);
}
.dfc-chip:hover { border-color: var(--g500); color: var(--g200); }
.dfc-chip.active { border-color: var(--yellow); color: var(--yellow); background: rgba(255,205,36,0.06); }

/* Candidate table column */
.dash-table-col { padding: 20px; overflow: hidden; }
.dash-search-wrap { display: flex; align-items: center; gap: 6px; font-size: 0.75rem; font-weight: 400; }
.dash-search-wrap i { color: var(--g500); }
.dash-search {
  background: var(--g800);
  border: 1px solid var(--g700);
  border-radius: 6px;
  padding: 5px 10px;
  color: var(--white);
  font-family: inherit;
  font-size: 0.75rem;
  width: 180px;
  transition: border-color var(--trans);
}
.dash-search:focus { outline: none; border-color: var(--yellow); }
.dash-table-scroll { overflow-x: auto; }

/* Analytics tab */
.dash-analytics-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--g800);
}
.dash-chart-card {
  background: var(--g900);
  padding: 20px;
}

/* TTH list */
.dash-tth-list, .dash-source-list { display: flex; flex-direction: column; gap: 12px; margin-top: 12px; }
.dash-tth-row, .dash-src-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.78rem;
}
.dash-tth-role, .dash-src-name { color: var(--g300); flex: 1; font-weight: 600; }
.dash-tth-bar-wrap, .dash-src-bar-wrap { flex: 2; }
.dash-tth-bar, .dash-src-bar { height: 5px; background: var(--yellow); border-radius: 3px; }
.dash-tth-val, .dash-src-val { color: var(--g400); font-size: 0.72rem; min-width: 32px; text-align: right; }

/* Alerts tab */
.dash-alerts-layout { padding: 20px; display: flex; flex-direction: column; gap: 12px; }
.dash-alert {
  display: flex;
  gap: 14px;
  padding: 16px 18px;
  border-radius: var(--radius);
  border: 1px solid;
  align-items: flex-start;
}
.dash-alert.warn  { background: rgba(249,115,22,0.06); border-color: rgba(249,115,22,0.25); }
.dash-alert.info  { background: rgba(59,130,246,0.06); border-color: rgba(59,130,246,0.2); }
.dash-alert.success { background: rgba(34,197,94,0.06); border-color: rgba(34,197,94,0.2); }
.da-icon { font-size: 1rem; flex-shrink: 0; padding-top: 1px; }
.dash-alert.warn .da-icon { color: #f97316; }
.dash-alert.info .da-icon { color: #3b82f6; }
.dash-alert.success .da-icon { color: var(--green); }
.da-title { font-size: 0.82rem; font-weight: 700; color: var(--white); margin-bottom: 4px; }
.da-msg { font-size: 0.78rem; color: var(--g400); line-height: 1.55; margin-bottom: 6px; }
.da-meta { font-size: 0.68rem; color: var(--g600); }

/* ─── REQUISITION STATUS STRIP ──────────────────── */
.req-strip {
  border-top: 1px solid var(--g800);
  padding: 14px 20px 18px;
}
.req-strip-label {
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--g500);
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 10px;
}
.req-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.req-card {
  background: var(--g800);
  border: 1px solid var(--g700);
  border-radius: var(--radius);
  padding: 11px 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: border-color var(--trans);
}
.req-card:hover { border-color: var(--g500); }
.req-card--warn {
  border-color: rgba(249,115,22,0.35);
  background: rgba(249,115,22,0.05);
}
.req-card--warn:hover { border-color: rgba(249,115,22,0.6); }
.req-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}
.req-role {
  font-size: 0.8rem;
  font-weight: 800;
  color: var(--white);
}
.req-status-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.req-status--active { background: var(--green); box-shadow: 0 0 5px rgba(34,197,94,0.5); }
.req-status--warn   { background: #f97316;      box-shadow: 0 0 5px rgba(249,115,22,0.5); }
.req-card-loc {
  font-size: 0.68rem;
  color: var(--g500);
  display: flex;
  align-items: center;
  gap: 5px;
}
.req-card-loc i { font-size: 0.6rem; }
.req-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 2px;
}
.req-qualified {
  font-size: 0.68rem;
  font-weight: 700;
  color: var(--green);
  display: flex;
  align-items: center;
  gap: 5px;
}
.req-qualified i { font-size: 0.6rem; }
.req-thin {
  font-size: 0.68rem;
  font-weight: 700;
  color: #f97316;
  display: flex;
  align-items: center;
  gap: 5px;
}
.req-thin i { font-size: 0.6rem; }
.req-days {
  font-size: 0.62rem;
  color: var(--g600);
  font-weight: 600;
}

/* Mobile */
@media (max-width: 600px) {
  .req-strip { padding: 12px 16px 14px; }
  .req-cards { grid-template-columns: 1fr; gap: 8px; }
  .req-card { padding: 10px 12px; }
}

/* ─── MESSAGING HUB ─────────────────────────────── */
.msg-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 420px;
}

/* Sidebar */
.msg-sidebar {
  border-right: 1px solid var(--g800);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.msg-sidebar-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px 12px;
  border-bottom: 1px solid var(--g800);
  flex-shrink: 0;
}
.msg-compose-btn {
  width: 28px; height: 28px;
  border-radius: 6px;
  border: 1px solid var(--g700);
  background: var(--g800);
  color: var(--g300);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.72rem;
  transition: border-color var(--trans), color var(--trans);
}
.msg-compose-btn:hover { border-color: var(--yellow); color: var(--yellow); }

/* Thread list */
.msg-threads { display: flex; flex-direction: column; overflow-y: auto; flex: 1; }
.msg-thread {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--g800);
  cursor: pointer;
  transition: background var(--trans);
  position: relative;
}
.msg-thread:hover { background: rgba(255,255,255,0.03); }
.msg-thread.active { background: rgba(255,205,36,0.05); border-left: 2px solid var(--yellow); padding-left: 14px; }
.msg-thread-avatar {
  position: relative;
  flex-shrink: 0;
}
.msg-thread-avatar img {
  width: 36px; height: 36px;
  border-radius: 50%;
  object-fit: cover;
  object-position: center top;
  display: block;
  border: 2px solid var(--g700);
}
.msg-thread-avatar .msg-status-dot {
  position: absolute;
  bottom: 0; right: 0;
  width: 9px; height: 9px;
  border-radius: 50%;
  border: 2px solid var(--g900);
}
.msg-status-dot.online  { background: var(--green); }
.msg-status-dot.away    { background: #f97316; }
.msg-status-dot.offline { background: var(--g600); }
.msg-thread-info { flex: 1; min-width: 0; }
.msg-thread-name { font-size: 0.8rem; font-weight: 700; color: var(--white); margin-bottom: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.msg-thread-preview { font-size: 0.7rem; color: var(--g500); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.msg-thread-preview.unread { color: var(--g300); font-weight: 600; }
.msg-thread-meta { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; flex-shrink: 0; }
.msg-thread-time { font-size: 0.62rem; color: var(--g600); }
.msg-unread-badge {
  width: 16px; height: 16px;
  background: #3b82f6;
  color: #fff;
  border-radius: 50%;
  font-size: 0.58rem;
  font-weight: 800;
  display: flex; align-items: center; justify-content: center;
}

/* Main chat area */
.msg-main {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.msg-chat-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--g800);
  background: var(--g950);
  flex-shrink: 0;
}
.msg-chat-header img {
  width: 36px; height: 36px;
  border-radius: 50%;
  object-fit: cover;
  object-position: center top;
  border: 2px solid var(--g700);
}
.msg-chat-name { font-size: 0.9rem; font-weight: 800; color: var(--white); }
.msg-chat-sub  { font-size: 0.68rem; color: var(--g500); margin-top: 1px; }
.msg-chat-actions { margin-left: auto; display: flex; gap: 8px; }
.msg-chat-action-btn {
  font-family: inherit;
  font-size: 0.7rem;
  font-weight: 700;
  padding: 5px 12px;
  border-radius: 6px;
  border: 1px solid var(--g700);
  background: var(--g800);
  color: var(--g300);
  cursor: pointer;
  display: flex; align-items: center; gap: 5px;
  transition: border-color var(--trans), color var(--trans);
}
.msg-chat-action-btn:hover { border-color: var(--yellow); color: var(--yellow); }
.msg-chat-action-btn.primary { background: rgba(255,205,36,0.1); border-color: rgba(255,205,36,0.3); color: var(--yellow); }

/* Message bubbles */
.msg-bubbles {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.msg-bubble-row {
  display: flex;
  gap: 10px;
  align-items: flex-end;
}
.msg-bubble-row.outbound { flex-direction: row-reverse; }
.msg-bubble-row img {
  width: 28px; height: 28px;
  border-radius: 50%;
  object-fit: cover;
  object-position: center top;
  flex-shrink: 0;
  border: 1px solid var(--g700);
}
.msg-bubble {
  max-width: 68%;
  padding: 10px 14px;
  border-radius: 12px;
  font-size: 0.8rem;
  line-height: 1.5;
}
.msg-bubble-row.inbound .msg-bubble {
  background: var(--g800);
  border: 1px solid var(--g700);
  color: var(--g200);
  border-bottom-left-radius: 3px;
}
.msg-bubble-row.outbound .msg-bubble {
  background: rgba(255,205,36,0.1);
  border: 1px solid rgba(255,205,36,0.25);
  color: var(--white);
  border-bottom-right-radius: 3px;
}
.msg-bubble-time { font-size: 0.6rem; color: var(--g600); margin-top: 4px; display: block; }
.msg-bubble-row.outbound .msg-bubble-time { text-align: right; }

/* System / stage-change message */
.msg-system-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 4px 0;
}
.msg-system-row::before,
.msg-system-row::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--g800);
}
.msg-system-pill {
  font-size: 0.62rem;
  font-weight: 700;
  color: var(--g500);
  background: var(--g900);
  border: 1px solid var(--g800);
  border-radius: 100px;
  padding: 3px 10px;
  white-space: nowrap;
}

/* Quick-reply templates */
.msg-templates {
  border-top: 1px solid var(--g800);
  padding: 10px 16px 8px;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  background: var(--g950);
  flex-shrink: 0;
}
.msg-tpl-btn {
  font-family: inherit;
  font-size: 0.68rem;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 100px;
  border: 1px solid var(--g700);
  background: var(--g800);
  color: var(--g400);
  cursor: pointer;
  transition: border-color var(--trans), color var(--trans);
}
.msg-tpl-btn:hover { border-color: var(--yellow); color: var(--yellow); }

/* Compose bar */
.msg-compose {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-top: 1px solid var(--g800);
  background: var(--g950);
  flex-shrink: 0;
}
.msg-input {
  flex: 1;
  background: var(--g800);
  border: 1px solid var(--g700);
  border-radius: 8px;
  padding: 9px 14px;
  color: var(--white);
  font-family: inherit;
  font-size: 0.8rem;
  outline: none;
  transition: border-color var(--trans);
}
.msg-input:focus { border-color: var(--yellow); }
.msg-send-btn {
  width: 36px; height: 36px;
  border-radius: 8px;
  border: none;
  background: var(--yellow);
  color: var(--black);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.85rem;
  flex-shrink: 0;
  transition: opacity var(--trans);
}
.msg-send-btn:hover { opacity: 0.85; }

/* Mobile: stack sidebar above chat */
@media (max-width: 600px) {
  .msg-layout { grid-template-columns: 1fr; min-height: unset; }
  .msg-sidebar { border-right: none; border-bottom: 1px solid var(--g800); max-height: 200px; }
  .msg-chat-actions { display: none; }
  .msg-templates { gap: 4px; }
  .msg-tpl-btn { font-size: 0.62rem; padding: 3px 8px; }
  .msg-bubble { max-width: 85%; font-size: 0.76rem; }
}

.dash-ui-body { display: flex; }

.dash-sidebar {
  width: 180px;
  flex-shrink: 0;
  border-right: 1px solid var(--g800);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.ds-val { font-size: 1.6rem; font-weight: 900; }
.ds-label { font-size: 0.72rem; color: var(--g500); margin-top: 2px; }

/* KPI strip responsive */
@media (max-width: 1024px) {
  .dash-kpi-strip { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .dash-kpi-strip { grid-template-columns: repeat(2, 1fr); }
  .dash-pipeline-layout { grid-template-columns: 1fr; }
  .dash-funnel-col { border-right: none; border-bottom: 1px solid var(--g800); }
  .dash-analytics-layout { grid-template-columns: 1fr; }
}

/* ── Platform section: mobile ≤600px ── */
@media (max-width: 600px) {

  /* KPI strip: 2-column compact grid */
  .dash-kpi-strip {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
    margin-bottom: 14px;
  }
  .dash-kpi-card {
    padding: 12px 14px;
  }
  .dkc-val { font-size: 1.3rem; }
  .dkc-label { font-size: 0.62rem; margin-bottom: 4px; }
  .dkc-delta { font-size: 0.6rem; }

  /* Dashboard chrome */
  .dash-ui { border-radius: 10px; }
  .dash-ui-header {
    padding: 10px 14px;
    gap: 8px;
  }
  .dash-ui-tabs { gap: 2px; }
  .dash-tab {
    font-size: 0.75rem;
    padding: 6px 10px;
    gap: 5px;
  }
  /* Hide icon labels on mobile, keep icons */
  .dash-tab i { font-size: 0.8rem; }
  .dash-ui-meta { font-size: 0.66rem; gap: 5px; }
  .live-dot { width: 6px; height: 6px; }

  /* ── Pipeline tab ── */
  .dash-pipeline-layout {
    grid-template-columns: 1fr;
    min-height: unset;
  }

  /* Funnel: horizontal compact row instead of tall column */
  .dash-funnel-col {
    padding: 14px 16px;
    gap: 10px;
    border-right: none;
    border-bottom: 1px solid var(--g800);
  }
  .dash-funnel { gap: 8px; }
  .df-label { font-size: 0.7rem; margin-bottom: 4px; }
  .df-bar-track { height: 4px; }
  .df-pct { font-size: 0.58rem; }
  .df-count { font-size: 0.72rem; }

  /* Filter chips: wrap tightly */
  .dash-filter-chips { gap: 4px; margin-top: 8px; }
  .dfc-chip { font-size: 0.62rem; padding: 5px 10px; min-height: 30px; }

  /* Candidate table: convert 5-col grid to card-style rows */
  .dash-table-col { padding: 14px 16px; }
  .dash-panel-title { font-size: 0.7rem; flex-direction: column; align-items: flex-start; gap: 8px; }
  .dash-search-wrap { width: 100%; }
  .dash-search { width: 100%; font-size: 0.72rem; }

  /* Hide the header row and reshape data rows as cards */
  .dt-head { display: none; }
  .dt-row {
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    grid-template-areas:
      "cand  score"
      "role  status";
    padding: 12px 14px;
    gap: 4px 10px;
    font-size: 0.8rem;
    border-bottom: 1px solid var(--g800);
    border-radius: 0;
  }
  /* Map dt-row children to grid areas via nth-child */
  .dt-row > *:nth-child(1) { grid-area: cand; }
  .dt-row > *:nth-child(2) { grid-area: role; font-size: 0.7rem; color: var(--g500); }
  .dt-row > *:nth-child(3) { display: none; }      /* hide Exp. on mobile */
  .dt-row > *:nth-child(4) { grid-area: score; }
  .dt-row > *:nth-child(5) { grid-area: status; align-self: end; }
  .dt-row > *:nth-child(6) { display: none; }      /* hide Next Action col — shown in footer instead */

  /* Actions footer: compact on mobile */
  .dash-actions-footer { padding: 12px 16px; }
  .daf-label { font-size: 0.6rem; margin-bottom: 8px; }
  .daf-item { gap: 8px; font-size: 0.75rem; }
  .daf-btn { font-size: 0.68rem; padding: 4px 10px; }

  /* Candidate avatar in table */
  .dt-cand img { width: 28px; height: 28px; border-radius: 5px; }
  .dt-cand { font-size: 0.82rem; gap: 8px; }
  .score { width: 30px; height: 30px; font-size: 0.75rem; border-radius: 6px; }
  .status-chip { font-size: 0.62rem; padding: 3px 8px; }

  /* ── Analytics tab ── */
  .dash-analytics-layout { grid-template-columns: 1fr; }
  .dash-chart-card { padding: 14px 16px; }
  /* Span-2 override no longer needed on mobile */
  .dash-chart-card[style*="grid-column"] { grid-column: span 1 !important; }

  /* ── Alerts tab ── */
  .dash-alerts-layout { padding: 14px 16px; gap: 10px; }
  .dash-alert { padding: 12px 14px; gap: 10px; }
  .da-icon { font-size: 0.9rem; }
  .da-title { font-size: 0.78rem; }
  .da-msg { font-size: 0.72rem; line-height: 1.5; margin-bottom: 4px; }
  .da-meta { font-size: 0.62rem; }
}

.dash-table { flex: 1; overflow-x: auto; }
.dt-head {
  display: grid;
  grid-template-columns: 2fr 1.2fr 0.8fr 0.7fr 1fr;
  padding: 12px 20px;
  border-bottom: 1px solid var(--g800);
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--g500);
}
.dt-row {
  display: grid;
  grid-template-columns: 2fr 1.2fr 0.8fr 0.7fr 1fr;
  padding: 14px 20px;
  border-bottom: 1px solid var(--g800);
  align-items: center;
  font-size: 0.85rem;
  color: var(--g300);
  transition: background var(--trans);
}
.dt-row:last-child { border-bottom: none; }
.dt-row:hover { background: rgba(255,255,255,0.02); }

/* Next action button inside table */
.dt-action-btn {
  font-family: inherit;
  font-size: 0.7rem;
  font-weight: 700;
  padding: 5px 10px;
  border-radius: 6px;
  border: 1px solid;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
  transition: opacity var(--trans), transform var(--trans);
}
.dt-action-btn:hover { opacity: 0.8; transform: translateY(-1px); }
.dt-action-btn.act-interview { background: rgba(249,115,22,0.10); color: #f97316; border-color: rgba(249,115,22,0.3); }
.dt-action-btn.act-review    { background: rgba(139,92,246,0.10);  color: #a78bfa; border-color: rgba(139,92,246,0.3); }
.dt-action-btn.act-offer     { background: rgba(59,130,246,0.10);  color: #3b82f6; border-color: rgba(59,130,246,0.3); }

/* Today's actions footer */
.dash-actions-footer {
  border-top: 1px solid var(--g800);
  padding: 16px 20px;
  background: rgba(255,255,255,0.01);
}
.daf-label {
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--yellow);
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 12px;
}
.daf-items { display: flex; flex-direction: column; gap: 8px; }
.daf-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.8rem;
}
.daf-avatar img {
  width: 22px;
  height: 22px;
  border-radius: 4px;
  object-fit: cover;
  object-position: center top;
  display: block;
  border: 1px solid var(--g700);
}
.daf-name { font-weight: 700; color: var(--white); min-width: 48px; }
.daf-arrow { color: var(--g600); font-size: 0.75rem; }
.daf-btn {
  font-family: inherit;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 5px 12px;
  border-radius: 6px;
  border: 1px solid;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: opacity var(--trans), transform var(--trans);
}
.daf-btn:hover { opacity: 0.8; transform: translateY(-1px); }
.daf-btn.act-interview { background: rgba(249,115,22,0.10); color: #f97316; border-color: rgba(249,115,22,0.3); }
.daf-btn.act-review    { background: rgba(139,92,246,0.10);  color: #a78bfa; border-color: rgba(139,92,246,0.3); }
.daf-btn.act-offer     { background: rgba(59,130,246,0.10);  color: #3b82f6; border-color: rgba(59,130,246,0.3); }
.dt-cand {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 600;
  color: var(--white);
}
/*
  KEY FIX: Avatar images — explicit size, object-fit cover.
  These ARE visible (they're direct img tags in the table).
*/
.dt-cand img {
  width: 32px;
  height: 32px;
  border-radius: 6px;
  object-fit: cover;
  object-position: center top;
  display: block;
  flex-shrink: 0;
  border: 1px solid var(--g700);
}
.score {
  width: 34px; height: 34px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.82rem; font-weight: 900;
  flex-shrink: 0;
}
.score.high { background: rgba(34,197,94,0.12); color: var(--green); border: 1px solid rgba(34,197,94,0.25); }
.score.med  { background: rgba(255,205,36,0.12); color: var(--yellow); border: 1px solid rgba(255,205,36,0.25); }
.status-chip {
  font-size: 0.7rem;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 100px;
  display: inline-block;
  white-space: nowrap;
}
.status-chip.applied   { background: rgba(255,205,36,0.10); color: var(--yellow);  border: 1px solid rgba(255,205,36,0.25); }
.status-chip.screened  { background: rgba(230,184,32,0.12); color: #e6b820;        border: 1px solid rgba(230,184,32,0.30); }
.status-chip.interview { background: rgba(249,115,22,0.10); color: #f97316;        border: 1px solid rgba(249,115,22,0.25); }
.status-chip.offer     { background: rgba(59,130,246,0.12); color: #3b82f6;        border: 1px solid rgba(59,130,246,0.30); }
.status-chip.hired     { background: rgba(34,197,94,0.12);  color: var(--green);   border: 1px solid rgba(34,197,94,0.25); }

/* ═══════════════════════════════════════════════════
   CANDIDATE SCORE REPORT SECTION
   ═══════════════════════════════════════════════════ */
/* ─── AI SCORE REPORT (simplified) ─────────────────── */
.csr-section { background: var(--black); }

/* ── Tabs ── */
.csr-selector {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.csr-tab {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: var(--radius);
  border: 1px solid var(--g700);
  background: var(--g900);
  color: var(--g300);
  cursor: pointer;
  font-family: inherit;
  font-size: 0.82rem;
  transition: border-color var(--trans), background var(--trans);
  flex: 1;
  min-width: 160px;
  text-align: left;
}
.csr-tab:hover { border-color: var(--g500); background: var(--g800); }
.csr-tab.active { border-color: var(--yellow); background: rgba(255,205,36,0.05); color: var(--white); }
.csr-tab-tier { font-size: 1.3rem; font-weight: 900; line-height: 1; flex-shrink: 0; }
.csr-tab-info { display: flex; flex-direction: column; flex: 1; }
.csr-tab-name { font-size: 0.82rem; font-weight: 700; }
.csr-tab-role { font-size: 0.68rem; color: var(--g500); margin-top: 1px; }
.csr-tab-score { font-size: 1.05rem; font-weight: 900; flex-shrink: 0; }

/* ── Panel visibility ── */
.csr-panels { position: relative; }
.csr-panel { display: none; }
.csr-panel.active { display: block; }

/* ── Single card layout ── */
.csr-card {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 0;
  background: var(--g900);
  border: 1px solid var(--g800);
  border-radius: var(--rad-lg);
  overflow: hidden;
}

/* Left column */
.csr-card-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  padding: 32px 24px;
  border-right: 1px solid var(--g800);
  background: var(--g950);
  text-align: center;
}

/* Avatar */
.csr-avatar-wrap {
  position: relative;
  width: 88px;
  height: 88px;
  flex-shrink: 0;
}
.csr-avatar {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  object-fit: cover;
  object-position: center top;
  display: block;
  border: 3px solid var(--tier-color, var(--yellow));
  box-shadow: 0 0 0 4px rgba(0,0,0,0.4), 0 0 16px color-mix(in srgb, var(--tier-color, var(--yellow)) 30%, transparent);
}

/* Score ring */
.csr-score-ring {
  position: relative;
  flex-shrink: 0;
  width: 80px;
  height: 80px;
}
.csr-ring-val {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.csr-ring-num { font-size: 1.1rem; font-weight: 900; }
.csr-ring-denom { font-size: 0.58rem; color: var(--g500); margin-top: 2px; }

/* Candidate meta */
.csr-card-meta { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.csr-tier-badge {
  display: inline-flex;
  align-items: center;
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border: 1px solid;
  border-radius: 5px;
  padding: 3px 10px;
}
.csr-cand-name {
  font-size: 1.1rem;
  font-weight: 900;
  color: var(--white);
  line-height: 1.2;
  margin: 0;
}
.csr-cand-role { font-size: 0.72rem; color: var(--g400); }
.csr-quick-facts {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-top: 4px;
  align-items: center;
}
.csr-quick-facts span {
  font-size: 0.72rem;
  color: var(--g300);
  display: flex;
  align-items: center;
  gap: 6px;
}
.csr-quick-facts i { color: var(--yellow); font-size: 0.65rem; }

/* Right column */
.csr-card-right {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 28px 32px;
}

/* Bars */
.csr-bars { display: flex; flex-direction: column; gap: 10px; }
.csr-bar-row {
  display: grid;
  grid-template-columns: 140px 1fr 36px;
  align-items: center;
  gap: 12px;
}
.csr-bar-label { font-size: 0.78rem; font-weight: 600; color: var(--g300); }
.csr-bar-track {
  height: 7px;
  background: var(--g800);
  border-radius: 4px;
  overflow: hidden;
}
.csr-bar-fill {
  height: 100%;
  border-radius: 4px;
  width: 0;
  transition: width 0.9s cubic-bezier(0.22, 1, 0.36, 1);
}
.csr-bar-pct { font-size: 0.72rem; font-weight: 700; color: var(--g400); text-align: right; }

/* Finding pills */
.csr-findings-row { display: flex; flex-direction: column; gap: 8px; }
.csr-finding-pill {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: var(--radius);
  font-size: 0.8rem;
  font-weight: 500;
  line-height: 1.4;
}
.csr-finding-pill i { font-size: 0.7rem; flex-shrink: 0; }
.csr-finding-pill--good {
  background: rgba(34,197,94,0.07);
  border: 1px solid rgba(34,197,94,0.2);
  color: var(--g200);
}
.csr-finding-pill--good i { color: var(--green); }
.csr-finding-pill--warn {
  background: rgba(249,115,22,0.07);
  border: 1px solid rgba(249,115,22,0.2);
  color: var(--g200);
}
.csr-finding-pill--warn i { color: #f97316; }

/* Shared dot */
.csr-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }

/* ── Interview questions block ── */
.csr-interview-qs {
  background: rgba(139,92,246,0.06);
  border: 1px solid rgba(139,92,246,0.18);
  border-radius: var(--radius);
  padding: 16px 18px;
  margin-top: auto;
}
.csr-qs-label {
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.13em;
  color: #a78bfa;
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 12px;
}
.csr-qs-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 9px;
  padding: 0;
  margin: 0;
  counter-reset: qs-counter;
}
.csr-qs-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.8rem;
  color: var(--g300);
  line-height: 1.5;
  counter-increment: qs-counter;
}
.csr-qs-list li::before {
  content: counter(qs-counter);
  font-size: 0.65rem;
  font-weight: 900;
  color: #a78bfa;
  background: rgba(139,92,246,0.15);
  border-radius: 50%;
  width: 18px;
  height: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}

/* ── Footer: tier legend + footnote ── */
.csr-footer-strip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 16px;
  flex-wrap: wrap;
}
.csr-tier-legend {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.csr-legend-item {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 0.72rem;
  color: var(--g400);
  padding: 4px 10px;
  border-radius: 100px;
  border: 1px solid var(--g800);
  background: var(--g900);
}
.csr-legend-item b { font-weight: 700; }

.csr-footnote {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.75rem;
  color: var(--g500);
  line-height: 1.5;
  max-width: 480px;
}
.csr-footnote i { flex-shrink: 0; }

/* ── Responsive: tablet ── */
@media (max-width: 860px) {
  .csr-card { grid-template-columns: 1fr; }
  .csr-card-left {
    border-right: none;
    border-bottom: 1px solid var(--g800);
    flex-direction: row;
    text-align: left;
    flex-wrap: wrap;
    gap: 16px;
  }
  .csr-card-meta { align-items: flex-start; }
  .csr-quick-facts { align-items: flex-start; }
  .csr-bar-row { grid-template-columns: 110px 1fr 32px; }
  .csr-footer-strip { flex-direction: column; align-items: flex-start; }
  .csr-avatar { width: 72px; height: 72px; }
  .csr-avatar-wrap { width: 72px; height: 72px; }
}

/* ── Responsive: mobile ── */
@media (max-width: 600px) {
  /* Tabs: single row, compact */
  .csr-selector {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
    margin-bottom: 14px;
  }
  .csr-tab {
    min-width: 0;
    padding: 8px 10px;
    gap: 8px;
    flex: unset;
  }
  .csr-tab-tier { font-size: 1rem; }
  .csr-tab-name { font-size: 0.75rem; }
  .csr-tab-role { display: none; }           /* hide role label in tab on mobile */
  .csr-tab-score { font-size: 0.9rem; }

  /* Card: single column */
  .csr-card { grid-template-columns: 1fr; border-radius: 12px; }

  /* Left column: compact horizontal header strip */
  .csr-card-left {
    flex-direction: row;
    align-items: center;
    text-align: left;
    padding: 14px 16px;
    gap: 12px;
    border-right: none;
    border-bottom: 1px solid var(--g800);
    flex-wrap: nowrap;
  }
  .csr-avatar-wrap { width: 56px; height: 56px; flex-shrink: 0; }
  .csr-avatar { width: 56px; height: 56px; }

  /* Score ring: keep visible but compact on mobile */
  .csr-score-ring { display: flex; width: 56px; height: 56px; flex-shrink: 0; }
  .csr-score-ring svg { width: 56px; height: 56px; }
  .csr-ring-num { font-size: 0.82rem; }
  .csr-ring-denom { font-size: 0.48rem; }

  /* Meta: left-aligned, fills remaining space */
  .csr-card-meta {
    align-items: flex-start;
    gap: 3px;
    flex: 1;
    min-width: 0;
  }
  .csr-tier-badge { font-size: 0.55rem; padding: 2px 7px; }
  .csr-cand-name { font-size: 0.92rem; }
  .csr-cand-role { font-size: 0.65rem; }

  /* Quick facts: single horizontal row beneath name */
  .csr-quick-facts {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 4px 12px;
    margin-top: 2px;
    align-items: center;
  }
  .csr-quick-facts span { font-size: 0.66rem; }

  /* Right column: tighter padding */
  .csr-card-right { padding: 16px 18px; gap: 12px; }

  /* Bars: condensed label */
  .csr-bar-row {
    grid-template-columns: 100px 1fr 30px;
    gap: 8px;
  }
  .csr-bar-label { font-size: 0.72rem; }
  .csr-bar-track { height: 6px; }
  .csr-bar-pct { font-size: 0.66rem; }

  /* Finding pills: smaller text */
  .csr-finding-pill {
    font-size: 0.74rem;
    padding: 8px 12px;
    gap: 8px;
  }

  /* Interview questions: collapsed on mobile with toggle */
  .csr-interview-qs {
    padding: 12px 14px;
  }
  .csr-qs-label {
    font-size: 0.62rem;
    cursor: pointer;
    user-select: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0;
  }
  .csr-qs-label::after {
    content: '\f078';                        /* chevron-down */
    font-family: 'Font Awesome 6 Free';
    font-weight: 900;
    font-size: 0.6rem;
    color: #a78bfa;
    margin-left: auto;
  }
  .csr-interview-qs.qs-open .csr-qs-label::after {
    content: '\f077';                        /* chevron-up */
  }
  .csr-qs-list { display: none; }            /* hidden by default */
  .csr-interview-qs.qs-open .csr-qs-list { display: flex; }
  .csr-interview-qs.qs-open .csr-qs-label { margin-bottom: 10px; }
  .csr-qs-list li { font-size: 0.76rem; gap: 8px; }

  /* Footer strip: stack */
  .csr-footer-strip { flex-direction: column; align-items: flex-start; gap: 10px; margin-top: 12px; }
  .csr-tier-legend { gap: 4px; }
  .csr-legend-item { font-size: 0.65rem; padding: 3px 8px; }
  .csr-footnote { font-size: 0.68rem; }
}

/* ─── WHO WE ARE ────────────────────────────────────── */
.wwa-section { background: var(--g950); }
.wwa-container { position: relative; z-index: 1; }
.wwa-header { margin-bottom: 48px; }
.wwa-header .section-sub { margin-bottom: 0; }

/* ── Definition block ── */
.wwa-definition {
  display: flex;
  align-items: flex-start;
  gap: 24px;
  padding: 32px 36px;
  background: var(--g900);
  border: 1px solid var(--g800);
  border-radius: var(--rad-lg);
  margin-bottom: 64px;
}
.wwa-def-bar {
  width: 3px;
  min-height: 100%;
  align-self: stretch;
  background: var(--yellow);
  border-radius: 2px;
  flex-shrink: 0;
}
.wwa-def-text {
  font-size: 1.05rem;
  color: var(--g200);
  line-height: 1.8;
  font-weight: 400;
}

/* ── Two-column body ── */
.wwa-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}
.wwa-left {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.wwa-col-title {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--g400);
  margin-bottom: 20px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--g800);
}

/* ── LEFT copy ── */
.wwa-body {
  font-size: 0.95rem;
  color: var(--g300);
  line-height: 1.8;
  margin-bottom: 20px;
}

/* ── Capability list ── */
.wwa-caps {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 32px;
  border-top: 1px solid var(--g800);
}
.wwa-cap {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px 0;
  border-bottom: 1px solid var(--g800);
}
.wwa-cap-icon {
  width: 34px; height: 34px;
  border-radius: 8px;
  background: var(--g800);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.8rem;
  color: var(--yellow);
  flex-shrink: 0;
  margin-top: 1px;
}
.wwa-cap strong {
  display: block;
  font-size: 0.88rem;
  font-weight: 800;
  color: var(--white);
  margin-bottom: 3px;
}
.wwa-cap span {
  font-size: 0.82rem;
  color: var(--g400);
  line-height: 1.55;
}

/* ── RIGHT: Two mode cards ── */
.wwa-right { display: flex; flex-direction: column; gap: 16px; }

.wwa-mode {
  border-radius: var(--rad-lg);
  border: 1px solid var(--g800);
  overflow: hidden;
}
.wwa-mode--pipeline { background: var(--g900); }
.wwa-mode--targeted {
  background: rgba(255,205,36,0.03);
  border-color: rgba(255,205,36,0.2);
}
.wwa-mode-header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 20px 24px;
  border-bottom: 1px solid var(--g800);
}
.wwa-mode--targeted .wwa-mode-header {
  border-bottom-color: rgba(255,205,36,0.12);
}
.wwa-mode-icon {
  width: 38px; height: 38px;
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.9rem;
  flex-shrink: 0;
}
.wwa-mode--pipeline .wwa-mode-icon { background: var(--g800); color: var(--g300); }
.wwa-mode--targeted .wwa-mode-icon { background: rgba(255,205,36,0.12); color: var(--yellow); }
.wwa-mode-label {
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--g500);
  margin-bottom: 2px;
}
.wwa-mode--targeted .wwa-mode-label { color: rgba(255,205,36,0.6); }
.wwa-mode-title {
  font-size: 0.92rem;
  font-weight: 800;
  color: var(--white);
  line-height: 1.2;
}
.wwa-mode--targeted .wwa-mode-title { color: var(--yellow); }
.wwa-mode-desc {
  font-size: 0.84rem;
  color: var(--g400);
  line-height: 1.65;
  padding: 18px 24px 14px;
}
.wwa-mode-list {
  list-style: none;
  padding: 0 24px 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.wwa-mode-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.82rem;
  line-height: 1.5;
}
.wwa-mode--pipeline .wwa-mode-list li { color: var(--g300); }
.wwa-mode--targeted .wwa-mode-list li { color: var(--g200); }
.wwa-mode-list li i {
  font-size: 0.7rem;
  margin-top: 3px;
  flex-shrink: 0;
}
.wwa-mode--pipeline .wwa-mode-list li i { color: var(--g500); }
.wwa-mode--targeted .wwa-mode-list li i { color: var(--yellow); }

/* ─── KRANE SECTION ────────────────────────────────── */
/*
  KEY FIX: Background image using the same pattern as hero.
  img tag in an absolute wrapper, content div sits above.
*/
.krane-section {
  position: relative;
  overflow: hidden;
  padding: 100px 0;
  background: var(--g950);
}
.krane-bg-layer {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}
.krane-bg-layer img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  filter: brightness(0.15) saturate(0.5);
}
.krane-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
}
.krane-copy .section-sub { margin-bottom: 36px; }
.krane-features { display: flex; flex-direction: column; gap: 24px; }
.kf { display: flex; gap: 16px; align-items: flex-start; }
.kf i { font-size: 1.2rem; flex-shrink: 0; margin-top: 2px; }
.kf strong { display: block; font-size: 0.9rem; font-weight: 700; margin-bottom: 4px; }
.kf p { font-size: 0.82rem; color: var(--g400); margin: 0; }

/* ── Photo Mosaic ── */
.krane-mosaic {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 260px 200px;
  gap: 8px;
}
.km-photo {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
  border: 1px solid var(--g800);
}
.km-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 0.5s ease;
  filter: brightness(0.75);
}
.km-photo:hover img { transform: scale(1.04); filter: brightness(0.9); }
.km-photo--large {
  grid-column: 1 / -1; /* spans full width */
}
.km-photo--sm {
  /* each fills one column in second row */
}
.km-label {
  position: absolute;
  bottom: 10px;
  left: 10px;
  font-size: 0.6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.85);
  background: rgba(0,0,0,0.65);
  border: 1px solid rgba(255,255,255,0.1);
  padding: 4px 10px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  gap: 6px;
  backdrop-filter: blur(4px);
}
.km-badge {
  position: absolute;
  top: 276px; /* sits at junction of large + small row, offset from right */
  right: 12px;
  background: var(--yellow);
  color: #000;
  border-radius: 8px;
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.7rem;
  font-weight: 800;
  line-height: 1.4;
  box-shadow: 0 4px 20px rgba(255,205,36,0.35);
  z-index: 2;
  max-width: 180px;
}
.km-badge i { font-size: 1.3rem; flex-shrink: 0; }

/* ── Stats Strip ── */
.krane-stats-strip {
  position: relative;
  z-index: 1;
  max-width: 1200px;
  margin: 48px auto 0;
  padding: 0 24px;
}
.krane-stats-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
  padding: 28px 32px;
}
.ks-pill {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 11px 20px;
  border-radius: 100px;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--g800);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--g200);
  transition: border-color var(--trans), color var(--trans);
}
.ks-pill i {
  color: var(--yellow);
  font-size: 0.78rem;
}
.ks-pill:hover {
  border-color: rgba(255,205,36,0.3);
  color: var(--white);
}

/* ═══════════════════════════════════════════════════
   ROI CALCULATOR
   ═══════════════════════════════════════════════════ */
/* ─── ROI SECTION (simplified) ──────────────────────── */
.roi-section { background: var(--black); }

.roi-header {
  text-align: center;
  max-width: 560px;
  margin: 0 auto 56px;
}

/* Simple wrap: inputs left, results right */
.roi-simple-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: center;
  background: var(--g900);
  border: 1px solid var(--g800);
  border-radius: var(--rad-lg);
  padding: 48px;
}

/* Inputs */
.roi-simple-inputs {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.roi-simple-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.roi-simple-label {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--g300);
  display: flex;
  align-items: center;
  gap: 8px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.roi-simple-label i { color: var(--yellow); font-size: 0.75rem; }

/* Divider between inputs and results */
.roi-simple-wrap::before {
  display: none; /* handled by grid gap */
}

/* Results panel */
.roi-simple-results {
  display: flex;
  flex-direction: column;
  gap: 28px;
  padding-left: 32px;
  border-left: 1px solid var(--g800);
}

.roi-result-headline {
  font-size: 1rem;
  color: var(--g300);
  line-height: 1.6;
}

.roi-result-big {
  display: block;
  font-size: clamp(2.4rem, 5vw, 3.4rem);
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1;
  margin: 8px 0 4px;
}

@keyframes roiPop {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.06); }
  100% { transform: scale(1); }
}
.roi-pop { animation: roiPop 0.35s ease; }

.roi-result-stats {
  display: flex;
  align-items: center;
  gap: 0;
}
.roi-result-stat {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.roi-result-stat-val {
  font-size: 1.35rem;
  font-weight: 900;
  letter-spacing: -0.02em;
  line-height: 1;
}
.roi-result-stat-label {
  font-size: 0.72rem;
  color: var(--g500);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  font-weight: 600;
}
.roi-result-stat-divider {
  width: 1px;
  height: 40px;
  background: var(--g700);
  margin: 0 20px;
  flex-shrink: 0;
}

/* Action buttons row */


/* Share URL row inside modal */
.roi-share-url {
  display: flex;
  gap: 8px;
  margin-bottom: 12px;
}
.roi-share-url .roi-input { flex: 1; }
.roi-textarea { width: 100%; resize: vertical; min-height: 100px; line-height: 1.6; }
.roi-consent-label { display: flex; align-items: flex-start; gap: 10px; font-size: 0.78rem; color: var(--g300); cursor: pointer; line-height: 1.5; }
.roi-consent-label input { margin-top: 3px; flex-shrink: 0; }

.roi-pdf-bar {
  margin-bottom: 12px;
}
.roi-pdf-btn {
  font-family: inherit;
  font-size: 0.82rem;
  font-weight: 700;
  padding: 11px 20px;
  border-radius: var(--radius);
  border: 1px solid rgba(255,205,36,0.35);
  background: rgba(255,205,36,0.08);
  color: var(--yellow);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: background var(--trans), border-color var(--trans);
  width: 100%;
  justify-content: center;
}
.roi-pdf-btn:hover {
  background: rgba(255,205,36,0.15);
  border-color: rgba(255,205,36,0.6);
}
.roi-cta-btn {
  display: inline-block;
  background: var(--yellow);
  color: var(--black);
  font-weight: 800;
  font-size: 0.9rem;
  padding: 14px 24px;
  border-radius: var(--radius);
  text-decoration: none;
  transition: opacity var(--trans), transform var(--trans);
  width: fit-content;
}
.roi-cta-btn:hover { opacity: 0.88; transform: translateY(-2px); }

/* Shared input styles (still used) */
.roi-input-wrap { position: relative; display: flex; align-items: center; }
.roi-prefix, .roi-suffix {
  position: absolute;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--g400);
  pointer-events: none;
}
.roi-prefix { left: 12px; }
.roi-suffix { right: 12px; }

/* Responsive */
@media (max-width: 860px) {
  .roi-simple-wrap {
    grid-template-columns: 1fr;
    padding: 32px 24px;
  }
  .roi-simple-results {
    padding-left: 0;
    border-left: none;
    border-top: 1px solid var(--g800);
    padding-top: 28px;
  }
  .roi-result-big { font-size: 2.4rem; }
}
.roi-input {
  width: 100%;
  background: var(--g800);
  border: 1px solid var(--g700);
  border-radius: 8px;
  padding: 12px 14px;
  color: var(--white);
  font-family: inherit;
  font-size: 0.88rem;
  /* iOS prevents zoom on inputs with font-size >= 16px */
  font-size: max(16px, 0.88rem);
  transition: border-color var(--trans);
  -moz-appearance: textfield;
}
.roi-input::-webkit-outer-spin-button,
.roi-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.roi-input:focus { outline: none; border-color: var(--yellow); }
.roi-input--prefixed { padding-left: 28px; }
.roi-input--suffixed { padding-right: 32px; }
.roi-input.error { border-color: #ef4444; }
.roi-select {
  width: 100%;
  background: var(--g800);
  border: 1px solid var(--g700);
  border-radius: 8px;
  padding: 12px 14px;
  color: var(--white);
  font-family: inherit;
  font-size: max(16px, 0.88rem);
  cursor: pointer;
  min-height: 48px;
  transition: border-color var(--trans);
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23606060' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
}
.roi-select:focus { outline: none; border-color: var(--yellow); }
.roi-select option { background: var(--g800); }

/* ─── FINAL CTA ─────────────────────────────────────── */
.cta-section { background: var(--g950); border-top: 1px solid var(--g800); text-align: center; }
.cta-inner { max-width: 680px; margin: 0 auto; }
.cta-section .section-sub { margin-bottom: 40px; max-width: 100%; }
.cta-assurances {
  display: flex;
  justify-content: center;
  gap: 32px;
  margin-top: 24px;
  flex-wrap: wrap;
}
.cta-assurances span { font-size: 0.82rem; color: var(--g400); display: flex; align-items: center; gap: 8px; }
.cta-assurances .fa-check { color: var(--green); }

/* ─── FOOTER ────────────────────────────────────────── */
.footer {
  background: var(--black);
  border-top: 1px solid var(--g800);
  padding: 40px 0;
  text-align: center;
}
.footer-inner { display: flex; flex-direction: column; align-items: center; gap: 12px; }
.footer-logo { display: flex; align-items: center; margin-bottom: 4px; }
.footer-logo-img { height: 40px; width: auto; display: block; filter: drop-shadow(0 2px 8px rgba(0,0,0,0.4)); }
.footer-tag { font-size: 0.82rem; color: var(--g400); }
.footer-copy { font-size: 0.75rem; color: var(--g500); }

/* ─── MODALS ────────────────────────────────────────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.85);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 200;
  padding: 24px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  /* Allow scrolling inside modals on iOS */
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}
.modal-overlay.open { display: flex; }
.modal-box {
  background: var(--g900);
  border: 1px solid var(--g700);
  border-radius: var(--rad-lg);
  padding: 36px;
  max-width: 520px;
  width: 100%;
  position: relative;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 32px 80px rgba(0,0,0,0.7);
}
.modal-close {
  position: absolute;
  top: 16px; right: 20px;
  background: none;
  border: none;
  color: var(--g400);
  font-size: 1.5rem;
  cursor: pointer;
  line-height: 1;
  transition: color var(--trans);
}
.modal-close:hover { color: var(--white); }
.modal-box h2 { font-size: 1.4rem; font-weight: 800; margin-bottom: 8px; }
.modal-box p { font-size: 0.88rem; color: var(--g400); margin-bottom: 24px; }
.modal-form { display: flex; flex-direction: column; gap: 12px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.modal-form input,
.modal-form select,
.modal-form textarea {
  width: 100%;
  background: var(--g800);
  border: 1px solid var(--g700);
  border-radius: 8px;
  padding: 12px 16px;
  color: var(--white);
  font-family: inherit;
  font-size: 0.88rem;
  /* Prevent iOS zoom on focus (font-size must be >= 16px) */
  font-size: max(16px, 0.88rem);
  min-height: 48px;
  transition: border-color var(--trans);
}
.modal-form input:focus,
.modal-form select:focus { outline: none; border-color: var(--yellow); }
.modal-form select { appearance: none; cursor: pointer; }
.modal-form button[type="submit"] { margin-top: 8px; }

/* Share URL row */
.roi-share-url { display: flex; gap: 8px; margin-bottom: 12px; }
.roi-share-url .roi-input { flex: 1; }

/* ─── STICKY CTA ────────────────────────────────────── */
.sticky-cta {
  position: fixed;
  bottom: 24px;
  bottom: max(24px, env(safe-area-inset-bottom));
  right: 24px;
  z-index: 90;
  background: var(--yellow);
  color: #000;
  font-weight: 800;
  font-size: 0.88rem;
  padding: 12px 24px;
  min-height: 44px;
  border-radius: var(--radius);
  box-shadow: 0 8px 24px rgba(255,205,36,0.35);
  transform: translateY(80px);
  transition: transform 0.3s ease, box-shadow var(--trans);
  display: inline-flex;
  align-items: center;
}
.sticky-cta.visible { transform: translateY(0); }
.sticky-cta:hover { box-shadow: 0 12px 32px rgba(255,205,36,0.5); }

/* ═══════════════════════════════════════════════════
   RESPONSIVE — FULLY OPTIMIZED MOBILE EXPERIENCE
   Breakpoints: 1024px (tablet), 768px (mobile), 480px (small mobile)
   ═══════════════════════════════════════════════════ */

/* ─── TABLET (≤1024px) ──────────────────────────── */
@media (max-width: 1024px) {
  /* Globals */
  .section { padding: 72px 0; }
  .container { padding: 0 20px; }

  /* Hero */
  .hero-grid { grid-template-columns: 1fr; gap: 48px; }
  .hero-dash { justify-content: center; }
  .score-report-card { max-width: 100%; }

  /* Sections */
  .system-grid { grid-template-columns: 1fr; gap: 48px; }
  .system-photo-wrap { height: 340px; }
  .krane-grid { grid-template-columns: 1fr; gap: 48px; }
  .krane-mosaic { grid-template-rows: 220px 160px; }
  .krane-stats-inner { flex-direction: row; flex-wrap: wrap; }
  .ks { flex: 1; min-width: 140px; }

  /* ── Who We Are ── */
  .wwa-inner { gap: 40px; }

  /* Cards */
  /* Tablet: 2 cards per row — arrows become vertical between rows */
  .steps-grid {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
  /* On tablet the arrows sit between rows — show vertical, hide horizontal */
  .step-arrow {
    grid-column: 1 / -1;
    flex-direction: row;
    min-height: 0;
    height: 32px;
    justify-content: center;
    gap: 10px;
  }
  .step-arrow__line {
    width: auto;
    flex: none;
    height: 2px;
    width: 60px;
    background: linear-gradient(to right, transparent, rgba(255,205,36,0.35), transparent);
    min-height: 0;
  }
  .step-arrow__icon    { display: none; }
  .step-arrow__icon--v { display: block; font-size: 0.9rem; color: var(--yellow); opacity: 0.85; animation: arrowPulseV 1.8s ease-in-out infinite; }
  @keyframes arrowPulseV {
    0%, 100% { opacity: 0.6; transform: translateY(0); }
    50%       { opacity: 1;   transform: translateY(3px); }
  }
  .pain-cards { grid-template-columns: repeat(2, 1fr); }
  .impact-grid { grid-template-columns: repeat(2, 1fr); }

  /* Photo band collage — tablet */
  .pb-collage { height: 340px; }

  /* ROI */
  .roi-layout { grid-template-columns: 1fr; }
  .roi-inputs-panel { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
  .roi-card { margin-bottom: 0; }
}

/* ─── MOBILE (≤768px) ────────────────────────────── */
@media (max-width: 768px) {
  /* Globals */
  .section { padding: 60px 0; }
  .container { padding: 0 16px; }
  h2 { font-size: clamp(1.7rem, 6vw, 2.4rem); }
  .section-sub { font-size: 0.95rem; margin-bottom: 36px; }

  /* ── Navigation ── */
  .nav-links { display: none; }
  .nav-inner > .btn-yellow { display: none; }
  .hamburger { display: flex; }
  .nav-inner { padding: 0 16px; gap: 0; }

  /* Nav drawer full-width links — large tap targets */
  .nav-drawer { padding: 12px 16px 20px; gap: 4px; }
  .nav-drawer a {
    padding: 12px 8px;
    font-size: 1rem;
    color: var(--g200);
    border-bottom: 1px solid var(--g800);
    display: block;
  }
  .nav-drawer a:last-child { border-bottom: none; margin-top: 8px; }
  .nav-drawer .btn-yellow { padding: 14px; font-size: 0.95rem; }

  /* ── Hero ── */
  .hero { min-height: 100svh; }
  .hero-grid { padding: 80px 16px 60px; }
  .hero-logo-img { height: 44px; }
  .hero-logo-lockup { margin-bottom: 24px; }
  .hero-copy h1 { font-size: clamp(2.2rem, 9vw, 3.4rem); margin-bottom: 20px; }
  .hero-sub { font-size: 1rem; margin-bottom: 32px; }
  .hero-btns { flex-direction: column; gap: 12px; width: 100%; }
  .hero-btns .btn-yellow,
  .hero-btns .btn-ghost { width: 100%; text-align: center; padding: 16px; font-size: 1rem; }
  .hero-stats { gap: 20px; }
  .stat-n { font-size: 1.4rem; }
  .stat-div { width: 1px; height: 28px; }

  /* ── Trust bar ── */
  .trust-bar .container { gap: 10px; justify-content: center; }
  .trust-label { width: 100%; text-align: center; }
  .trust-sep { display: none; }
  .trust-item { font-size: 0.78rem; background: var(--g800); border: 1px solid var(--g700); border-radius: 20px; padding: 4px 12px; }

  /* ── Photo strip ── */
  .photo-strip-inner { height: 160px; }
  .ps-item.ps-wide { flex: 1; }

  /* ── Pain section ── */
  .pain-cards { grid-template-columns: 1fr; gap: 12px; }
  .pain-card { padding: 20px 18px; }
  .pain-stat { font-size: 1.8rem; }
  .pain-quote { padding: 20px; flex-direction: column; gap: 12px; }
  .pq-line { min-height: 3px; width: 40px; }
  .pain-quote p { font-size: 0.92rem; }

  /* ── Who We Are ── */
  .wwa-inner { grid-template-columns: 1fr; gap: 40px; }
  .wwa-definition { padding: 24px 20px; }

  /* ── System section ── */
  .system-grid { gap: 32px; }
  .system-photo-wrap { height: 260px; }
  .compare-table { grid-template-columns: 1fr; gap: 12px; }
  .sys-badge { left: 12px; }

  /* ── Steps / How It Works ── */
  .steps-grid { grid-template-columns: 1fr; gap: 0; }
  .step-card  { margin-bottom: 0; }
  /* Mobile: single column — all arrows vertical, full-width row */
  .step-arrow {
    grid-column: 1;
    flex-direction: row;
    min-height: 0;
    height: 28px;
    padding: 4px 0;
  }
  .step-arrow__line {
    width: 60px;
    height: 2px;
    flex: none;
    background: linear-gradient(to right, transparent, rgba(255,205,36,0.35), transparent);
    min-height: 0;
  }
  .step-arrow__icon    { display: none; }
  .step-arrow__icon--v { display: block; }
  .step-img-wrap { height: 160px; }

  /* ── Impact ── */
  .impact-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .impact-card { padding: 20px 16px; }
  .impact-stat { font-size: 2rem; }

  /* ── Photo band collage — mobile ── */
  .photo-band--collage { padding: 12px 0; }
  .pb-collage {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
    height: auto;
    gap: 4px;
    padding: 0 12px;
  }
  .pb-col-stack--right { display: none; }
  .pb-col--large { height: 320px; }
  .pb-col-stack {
    grid-column: 2;
    display: flex;
    flex-direction: column;
    gap: 4px;
  }
  .pb-col-row {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
  }
  .pb-col--sm { height: 100px; flex-shrink: 0; }
  .pb-col--wide { flex: 1; min-height: 100px; }
  .pb-col-label { font-size: 0.6rem; padding: 20px 8px 7px; gap: 4px; }
  .pb-col-label i { font-size: 0.58rem; }

  /* ── Dashboard KPI strip ── */
  .dash-kpi-strip { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .dkc-val { font-size: 1.3rem; }
  .dkc-label { font-size: 0.65rem; }

  /* ── Dashboard UI header ── */
  .dash-ui-header { flex-direction: column; align-items: flex-start; gap: 10px; padding: 12px 16px; }
  .dash-ui-tabs { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 2px; }
  .dash-tab { white-space: nowrap; padding: 8px 12px; font-size: 0.8rem; }
  .dash-ui-meta { font-size: 0.7rem; }

  /* ── Dashboard Pipeline layout ── */
  .dash-pipeline-layout { grid-template-columns: 1fr; }
  .dash-funnel-col { border-right: none; border-bottom: 1px solid var(--g800); padding: 16px; }
  .dash-table-col { padding: 16px; overflow-x: hidden; }
  .dash-panel-title { font-size: 0.72rem; flex-wrap: wrap; gap: 8px; }
  .dash-search { width: 130px; }
  .dash-search-wrap { gap: 4px; }

  /* ── Candidate table — collapse columns on mobile ── */
  .dt-head { grid-template-columns: 1fr 1fr 1fr; padding: 10px 12px; }
  .dt-row  { grid-template-columns: 1fr 1fr 1fr; padding: 12px 12px; font-size: 0.8rem; }
  /* Hide Exp. and Score columns — keep Candidate, Role, Status */
  .dt-head span:nth-child(3),
  .dt-row  span:nth-child(3),
  .dt-head span:nth-child(4),
  .dt-row  span:nth-child(4) { display: none; }
  .dt-cand img { width: 28px; height: 28px; }
  .dt-cand { gap: 7px; font-size: 0.78rem; }
  .status-chip { font-size: 0.65rem; padding: 3px 8px; }
  .score { width: 28px; height: 28px; font-size: 0.75rem; }

  /* ── Dashboard Analytics ── */
  .dash-analytics-layout { grid-template-columns: 1fr; }
  .dash-chart-card { padding: 14px; }
  .dash-chart-card[style*="span 2"] { grid-column: span 1; }

  /* ── Dashboard Alerts ── */
  .dash-alerts-layout { padding: 14px; gap: 10px; }
  .dash-alert { padding: 12px 14px; gap: 10px; }
  .da-title { font-size: 0.78rem; }
  .da-msg { font-size: 0.74rem; }

  /* ── Candidate Score Report (CSR) ── */
  .csr-selector { flex-direction: column; gap: 8px; }
  .csr-tab { min-width: 100%; flex-direction: row; gap: 12px; }
  .csr-tab-score { margin-left: auto; }
  .csr-layout { grid-template-columns: 1fr; }
  .csr-card-header { padding: 18px 16px; }
  .csr-header-top { flex-direction: column; gap: 14px; align-items: flex-start; }
  .csr-score-ring { align-self: flex-start; }
  .csr-cand-name { font-size: 1.2rem; }
  .csr-breakdown-block { padding: 18px 16px; }
  .csr-snapshot-footer { padding: 16px; }
  .csr-snapshot-grid { grid-template-columns: 1fr 1fr; gap: 0; }
  .csr-snap-pill { border-right: none; border-bottom: 1px solid var(--g800); padding: 10px 12px; }
  .csr-snap-pill:nth-child(odd) { border-right: 1px solid var(--g800); }
  .csr-snap-pill:last-child { border-bottom: none; }
  .csr-snap-pill:nth-last-child(2):nth-child(odd) { border-bottom: none; }
  .csr-tier-strip { flex-wrap: wrap; gap: 8px; padding: 12px 14px; }
  .csr-legend-item { font-size: 0.65rem; }
  .csr-footnote { font-size: 0.75rem; padding: 12px 14px; }

  /* ── Who We Are ── */
  .wwa-inner { grid-template-columns: 1fr; gap: 40px; }
  .wwa-definition { flex-direction: column; gap: 16px; padding: 24px 20px; }
  .wwa-def-bar { width: 40px; height: 3px; min-height: unset; align-self: auto; }

  /* ── Krane section ── */
  .krane-grid { gap: 32px; padding: 0 16px; }
  .krane-mosaic { grid-template-columns: 1fr 1fr; grid-template-rows: 180px 140px; }
  .km-badge { top: 196px; font-size: 0.65rem; padding: 8px 10px; max-width: 160px; }
  .krane-stats-strip { padding: 0 16px; }
  .krane-stats-inner { flex-direction: column; gap: 0; }
  .ks { padding: 18px 20px; }
  .ks-divider { width: 80%; height: 1px; }
  .ks-num { font-size: 2rem; }

  /* ── ROI Calculator ── */
  .roi-scenarios { gap: 8px; }
  .roi-scenarios-label { width: 100%; }
  .roi-scenario-btn { font-size: 0.74rem; padding: 6px 12px; }
  .roi-layout { grid-template-columns: 1fr; gap: 0; }
  .roi-inputs-panel { display: flex; flex-direction: column; gap: 0; }
  .roi-card { padding: 16px; margin-bottom: 12px; border-radius: var(--radius); }
  .roi-card-head { margin-bottom: 12px; }
  .roi-kpi-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .roi-kpi-val { font-size: 1.2rem; }
  .roi-bt-row { grid-template-columns: 1.4fr 0.8fr 1fr; font-size: 0.76rem; gap: 4px; }
  .roi-bt-head { font-size: 0.62rem; }
  .roi-charts-wrap { gap: 16px; }
  .roi-summary-actions { flex-wrap: wrap; gap: 8px; }
  
  .roi-share-url { flex-direction: column; }

  /* ── Final CTA ── */
  .cta-section .btn-xl { padding: 16px 32px; font-size: 1rem; width: 100%; text-align: center; }
  .cta-assurances { flex-direction: column; align-items: center; gap: 10px; }

  /* ── Modals ── */
  .modal-overlay { padding: 12px; align-items: flex-end; }
  .modal-box { padding: 24px 20px; border-radius: 16px 16px 0 0; max-height: 92vh; }
  .modal-box h2 { font-size: 1.2rem; }
  .modal-box p { font-size: 0.83rem; margin-bottom: 16px; }
  .form-row { grid-template-columns: 1fr; gap: 10px; }
  .modal-form { gap: 10px; }

  /* ── Sticky CTA ── */
  .sticky-cta {
    bottom: 16px;
    right: 16px;
    font-size: 0.82rem;
    padding: 11px 20px;
    /* Don't cover full width — keep it a floating button */
  }

  /* ── Sidebar (dashboard legacy) ── */
  .dash-ui-body { flex-direction: column; }
  .dash-sidebar { width: 100%; border-right: none; border-bottom: 1px solid var(--g800); flex-direction: row; flex-wrap: wrap; gap: 16px; }
}

/* ─── SMALL MOBILE (≤480px) ─────────────────────── */
@media (max-width: 480px) {
  /* Globals */
  .section { padding: 48px 0; }

  /* Hero */
  .hero-grid { padding: 72px 16px 48px; }
  .hero-copy h1 { font-size: clamp(2rem, 10vw, 2.8rem); letter-spacing: -0.02em; }
  .hero-logo-img { height: 36px; }
  .hero-stats { flex-direction: column; align-items: center; gap: 16px; }
  .stat-div { width: 40px; height: 1px; }
  .hero-pills { flex-direction: column; align-items: center; }
  .hero-pill { width: 100%; justify-content: center; }

  /* Trust bar */
  .trust-bar .container { flex-wrap: wrap; }
  .trust-item { font-size: 0.72rem; }

  /* Photo strip — hide the wide items on very small screens */
  .photo-strip-inner { height: 140px; gap: 2px; }

  /* Pain cards */
  .pain-card { padding: 18px 14px; }
  .pain-stat { font-size: 1.6rem; }

  /* Impact — single column on very small */
  .impact-grid { grid-template-columns: 1fr; }
  .impact-card { padding: 18px 16px; }

  /* Dashboard KPI strip — single column on tiny screens */
  .dash-kpi-strip { grid-template-columns: 1fr 1fr; }
  .dkc-val { font-size: 1.2rem; }
  .dash-kpi-card { padding: 12px 14px; }

  /* Dashboard tabs — scrollable row */
  .dash-ui-tabs { gap: 2px; }
  .dash-tab { padding: 7px 10px; font-size: 0.75rem; }

  /* Candidate table — 2 columns max on tiny screens */
  .dt-head { grid-template-columns: 1fr 1fr; padding: 8px 10px; }
  .dt-row  { grid-template-columns: 1fr 1fr; padding: 10px 10px; }
  /* Hide Role column too — keep Candidate and Status */
  .dt-head span:nth-child(2),
  .dt-row  span:nth-child(2) { display: none; }

  /* CSR tabs — full row */
  .csr-tab { padding: 10px 12px; }
  .csr-tab-tier { font-size: 1.2rem; }
  .csr-tab-score { font-size: 0.95rem; }
  .csr-tab-role { display: none; }

  /* CSR snapshot — single column */
  .csr-snapshot-grid { grid-template-columns: 1fr; }
  .csr-snap-pill { border-right: none; border-bottom: 1px solid var(--g800); }
  .csr-snap-pill:nth-child(odd) { border-right: none; }

  /* CSR tier strip */
  .csr-tier-strip { display: grid; grid-template-columns: 1fr 1fr; align-items: start; gap: 6px; }
  .csr-tier-strip-label { grid-column: 1 / -1; }

  /* Who We Are — mobile */
  .wwa-identity-grid { grid-template-columns: 1fr; }
  .wwa-identity-item--yes { grid-column: span 1; flex-direction: column; }

  /* ROI */
  .roi-kpi-grid { grid-template-columns: 1fr; gap: 8px; }
  .roi-bt-row { grid-template-columns: 1fr 0.7fr 0.9fr; font-size: 0.72rem; }
  
  .roi-scenario-btn { font-size: 0.72rem; padding: 5px 10px; }

  /* Krane stats */
  .krane-stats { flex-direction: column; }

  /* Modals — full slide-up sheet */
  .modal-overlay { padding: 0; }
  .modal-box { border-radius: 20px 20px 0 0; padding: 24px 16px 32px; max-height: 95vh; }

  /* Sticky CTA — full width on very small */
  .sticky-cta {
    left: 16px;
    right: 16px;
    bottom: 16px;
    text-align: center;
    border-radius: var(--radius);
  }

  /* Footer */
  .footer { padding: 32px 0; }
  .footer-logo-img { height: 32px; }
}
