/* ============================================
   TACHLES AI — v3
   Hebrew RTL · premium boutique · founder-led
   ============================================ */

:root {
  /* PALETTE — Editorial Crimson (locked 2026-05-16)
     White bg + sharp crimson accent. Clean B2B premium feel.
     Replaced earlier warm-ochre palette after Or's review of 3 options. */
  --bg: #FFFFFF;
  --bg-alt: #F5F6F8;
  --bg-warm: #FAFAFA;
  --bg-dark: #0D0F14;
  --bg-darker: #06080C;

  --ink: #0D0F14;
  --ink-2: #2A2E36;
  --ink-muted: #5A5F6B;
  --ink-faint: #8A8F99;

  --rule: #E5E7EB;
  --rule-soft: rgba(13, 15, 20, 0.05);
  --rule-dark: rgba(255, 255, 255, 0.08);

  --accent: #E11D48;
  --accent-strong: #BE123C;
  --accent-soft: rgba(225, 29, 72, 0.10);

  --good: #16A34A;
  --warn: #EA580C;
  --info: #4F46E5;

  --btn-primary-bg: var(--ink);
  --btn-primary-text: #fff;

  --font-sans: 'Heebo', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: 'JetBrains Mono', 'SF Mono', Menlo, monospace;

  --container-max: 1180px;
  --gutter: clamp(1rem, 4vw, 2.5rem);

  --section-pad-y: clamp(6rem, 14vh, 11rem);

  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out-soft: cubic-bezier(0.16, 1, 0.3, 1);
  --t-fast: 180ms var(--ease-out);
  --t: 320ms var(--ease-out);
  --t-slow: 700ms var(--ease-out-soft);
}

/* Palette switcher UI removed 2026-05-16 — Or chose palette C as canonical.
   ============================================ */

/* ============================================
   MOTION LIBRARY — Tier 1 upgrades
   ============================================ */

/* Stagger reveals — children get progressive delay */
.is-visible .stagger-child {
  animation: revealUp 700ms var(--ease-out-soft) backwards;
  animation-delay: calc(var(--si, 0) * 90ms);
}
@keyframes revealUp {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Smooth scroll snap clearance for sticky nav */
section[id] { scroll-margin-top: 88px; }

/* Tile hover lift — clean, no 3D tilt */
.tile {
  transition: transform 360ms var(--ease-out-soft), box-shadow 360ms var(--ease-out-soft);
}
.tile:hover {
  transform: translateY(-4px);
  box-shadow: 0 30px 60px -30px rgba(14,14,14,0.18);
}

/* Card hover — gentle, no horizontal shift on RTL */
.project-card, .delivery-item, .faq-item {
  transition: transform 320ms var(--ease-out-soft), border-color 320ms var(--ease-out-soft), background 320ms var(--ease-out-soft);
}
.project-card:hover { transform: translateY(-3px); border-color: var(--rule); }

/* Reduced motion guard */
@media (prefers-reduced-motion: reduce) {
  .tile:hover { transform: none; }
  .is-visible .stagger-child { animation: none; }
}

/* === Reset === */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 17px;
  line-height: 1.65;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: 0;
  overscroll-behavior: none;
}
[dir="ltr"] { unicode-bidi: isolate; direction: ltr; }
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; border: 0; background: none; }
a { color: inherit; text-decoration: none; }
h1, h2, h3, h4, h5 { margin: 0; font-weight: 700; line-height: 1.1; letter-spacing: -0.02em; }
p { margin: 0; }
ul, ol { margin: 0; padding: 0; list-style: none; }
::selection { background: var(--ink); color: var(--bg); }
.container { width: 100%; max-width: var(--container-max); margin: 0 auto; padding-inline: var(--gutter); }
section { padding-block: var(--section-pad-y); position: relative; }

/* === Chapter marker (Linear-style) === */
.chapter {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  color: var(--ink-faint);
  letter-spacing: 0.06em;
  margin-bottom: 1.25rem;
  display: inline-block;
  padding-inline-start: 1.5rem;
  position: relative;
  direction: ltr;
  unicode-bidi: isolate;
}
.chapter::before {
  content: "";
  position: absolute;
  inset-inline-start: 0;
  top: 50%;
  width: 1rem;
  height: 1px;
  background: var(--ink-faint);
}
.chapter-dark { color: rgba(255,255,255,0.5); }
.chapter-dark::before { background: rgba(255,255,255,0.5); }

/* === Section heads === */
.section-head { max-width: 760px; margin-bottom: 3.5rem; }
.section-title {
  font-size: clamp(1.75rem, 4.2vw, 3.25rem);
  font-weight: 900;
  letter-spacing: -0.035em;
  line-height: 1.05;
  color: var(--ink);
  margin-bottom: 1rem;
}
.section-title-dark { color: #fff; }
.section-sub {
  font-size: clamp(1.05rem, 1.4vw, 1.18rem);
  color: var(--ink-muted);
  line-height: 1.55;
  max-width: 60ch;
}
.section-head-dark .section-sub { color: rgba(255,255,255,0.7); }
.eyebrow {
  display: inline-block;
  font-size: 13px;
  font-weight: 600;
  color: var(--accent-strong);
  letter-spacing: 0.04em;
  text-transform: none;
  margin-bottom: 1rem;
}

/* === Buttons === */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 14px 26px;
  font-size: 15px;
  font-weight: 600;
  border-radius: 999px;
  border: 1px solid transparent;
  transition: background var(--t-fast), color var(--t-fast), transform var(--t-fast), border-color var(--t-fast);
  white-space: nowrap;
  cursor: pointer;
}
.btn-primary { background: var(--ink); color: #fff; }
.btn-primary:hover { background: var(--ink-2); transform: translateY(-1px); }
.btn-link { background: transparent; color: var(--ink); border: 0; padding-inline: 0.5rem; }
.btn-link:hover { color: var(--accent-strong); }
.btn-submit { padding: 16px 28px; }
.btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}
a:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 4px;
}

/* === RIBBON === */
.ribbon {
  display: block;
  background: var(--ink);
  color: #fff;
  text-align: center;
  font-size: 13px;
  font-weight: 500;
  padding: 9px 16px;
  transition: background var(--t-fast);
}
.ribbon:hover { background: var(--accent-strong); }
.ribbon-inner {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
}
.ribbon-dot {
  width: 7px; height: 7px; border-radius: 9999px;
  background: #6BCF8F;
  animation: dotPulse 2s ease-in-out infinite;
}
.ribbon-arrow {
  display: inline-block;
  transition: transform var(--t-fast);
}
.ribbon:hover .ribbon-arrow { transform: translateX(-3px); }

@keyframes dotPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.5; transform: scale(1.4); }
}

/* === HEADER / NAV === */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--rule-soft);
}
.nav {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: 14px;
}
.brand { display: inline-flex; align-items: center; gap: 0.5rem; font-weight: 700; font-size: 17px; }
.brand-mark {
  width: 9px; height: 9px;
  border-radius: 9999px;
  background: var(--ink);
  display: inline-block;
}
.brand-name { direction: ltr; unicode-bidi: isolate; letter-spacing: -0.01em; }

.nav-links { display: flex; align-items: center; gap: 1.75rem; }
.nav-links a {
  font-size: 14.5px;
  font-weight: 500;
  color: var(--ink-2);
  transition: color var(--t-fast);
}
.nav-links a:hover { color: var(--ink); }
.nav-links a[aria-current="location"] { color: var(--accent-strong); }
.nav-cta {
  background: var(--ink);
  color: #fff !important;
  padding: 8px 16px;
  border-radius: 9999px;
}
.nav-cta:hover { background: #2A2A2A; }

.nav-toggle {
  display: none;
  position: relative;
  width: 40px;
  height: 40px;
  border: 1px solid var(--rule);
  border-radius: 10px;
  background: transparent;
}
.nav-toggle span {
  position: absolute;
  inset-inline-start: 10px;
  width: 18px;
  height: 1.5px;
  background: var(--ink);
  transition: transform var(--t), top var(--t), opacity var(--t-fast);
}
.nav-toggle span:nth-child(1) { top: 13px; }
.nav-toggle span:nth-child(2) { top: 19px; }
.nav-toggle span:nth-child(3) { top: 25px; }
.nav-toggle[aria-expanded="true"] span:nth-child(1) { top: 19px; transform: rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { top: 19px; transform: rotate(-45deg); }

@media (max-width: 880px) {
  .nav-toggle { display: block; }
  .nav-links {
    position: absolute;
    top: 100%;
    inset-inline: 0;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 14px var(--gutter) 22px;
    background: rgba(255,255,255,0.98);
    border-bottom: 1px solid var(--rule);
    backdrop-filter: blur(14px);
    transform: translateY(-12px);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: transform var(--t), opacity var(--t), visibility 0s linear var(--t);
  }
  .nav-links.nav-open {
    transform: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transition: transform var(--t), opacity var(--t), visibility 0s;
  }
  .nav-links a {
    padding: 14px 0;
    border-bottom: 1px solid var(--rule);
  }
  .nav-links a:last-child { border-bottom: 0; }
  .nav-cta { background: var(--ink); color: #fff !important; padding: 12px 16px; margin-top: 10px; text-align: center; }
}

/* === HERO === */
.hero {
  padding-block: clamp(4rem, 9vh, 7rem) clamp(4rem, 8vh, 7rem);
  position: relative;
  overflow: hidden;
}
/* Hero radial blob removed for clean Apple-feel — pure white background */

.hero-grid {
  display: grid;
  grid-template-columns: 1fr 1.05fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: center;
  position: relative;
  z-index: 1;
}
@media (max-width: 880px) {
  .hero-grid { grid-template-columns: 1fr; gap: 2.5rem; }
}

.hero-copy { max-width: 600px; }
.hero-title {
  font-size: clamp(2.4rem, 6vw, 4.8rem);
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 0.98;
  margin-bottom: 1.5rem;
}
.accent-underline {
  position: relative;
  display: inline-block;
  isolation: isolate;
}
.accent-underline::before {
  content: "";
  position: absolute;
  inset-inline-start: -0.08em;
  inset-inline-end: -0.08em;
  bottom: 0.05em;
  height: 0.34em;
  background: var(--accent);
  opacity: 0.92;
  z-index: -1;
  transform: skewX(-3deg);
  border-radius: 2px;
}
.hero-sub {
  font-size: clamp(1.05rem, 1.4vw, 1.18rem);
  color: var(--ink-muted);
  line-height: 1.55;
  max-width: 52ch;
  margin-bottom: 2rem;
}
.hero-cta { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; margin-bottom: 2.25rem; }
.hero-trust {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 13.5px;
  color: var(--ink-faint);
}
.hero-trust-mark { color: var(--accent); }
.hero-trust-photo {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  border: 1px solid var(--rule);
}

/* === LIVE CONSOLE (the hero artifact) === */
.console {
  background: var(--bg-dark);
  color: #fff;
  border-radius: 18px;
  padding: 22px 22px 18px;
  font-family: var(--font-mono);
  box-shadow:
    0 30px 60px -20px rgba(14,14,14,0.18),
    0 12px 24px -12px rgba(14,14,14,0.10);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
/* Console interior ochre tint removed — clean dark surface only */
.console-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11px;
  letter-spacing: 0.12em;
  color: rgba(255,255,255,0.55);
  padding-bottom: 14px;
  border-bottom: 1px solid var(--rule-dark);
  margin-bottom: 16px;
}
.console-brand { display: inline-flex; align-items: center; gap: 8px; }
.console-brand-mark {
  width: 7px; height: 7px;
  border-radius: 9999px;
  background: #6BCF8F;
  animation: dotPulse 2s ease-in-out infinite;
}
.console-clock { font-variant-numeric: tabular-nums; }

.console-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-bottom: 22px;
}
@media (max-width: 520px) {
  .console-grid { grid-template-columns: 1fr 1fr; }
}
.console-metric {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.console-metric-label {
  font-family: var(--font-sans);
  font-size: 11.5px;
  color: rgba(255,255,255,0.55);
  letter-spacing: 0;
}
.console-metric-value {
  font-family: var(--font-mono);
  font-size: clamp(1.6rem, 2.8vw, 2.2rem);
  font-weight: 700;
  color: #fff;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  line-height: 1;
}
.console-metric-bar {
  display: block;
  height: 3px;
  background: rgba(255,255,255,0.12);
  border-radius: 999px;
  overflow: hidden;
}
.console-metric-bar > span {
  display: block;
  height: 100%;
  width: var(--w);
  background: linear-gradient(90deg, var(--accent), #E5A95F);
  border-radius: 999px;
  animation: barGrow 1.2s var(--ease-out-soft) forwards;
  transform-origin: 0 0;
}
@keyframes barGrow {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}
.console-metric-trend {
  font-family: var(--font-sans);
  font-size: 11px;
  color: rgba(255,255,255,0.45);
  letter-spacing: 0;
}

.console-feed {
  border-top: 1px solid var(--rule-dark);
  padding-top: 14px;
  margin-bottom: 14px;
}
.console-feed-head {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-sans);
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: rgba(255,255,255,0.45);
  margin-bottom: 10px;
}
.console-feed-dot {
  width: 6px; height: 6px;
  border-radius: 9999px;
  background: var(--accent);
  animation: dotPulse 2.4s ease-in-out infinite;
}
.console-feed-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.console-feed-list li {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 14px;
  font-family: var(--font-sans);
  font-size: 12.5px;
  color: rgba(255,255,255,0.78);
  line-height: 1.45;
  padding: 4px 0;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.console-feed-list li:last-child { border-bottom: 0; }
.feed-time {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: rgba(255,255,255,0.4);
  letter-spacing: 0.04em;
}
.feed-msg { color: rgba(255,255,255,0.85); }

.console-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 12px;
  border-top: 1px solid var(--rule-dark);
  font-family: var(--font-mono);
  font-size: 11px;
  color: rgba(255,255,255,0.45);
  letter-spacing: 0.06em;
}
.console-status { display: inline-flex; align-items: center; gap: 8px; }
.console-status-dot {
  width: 6px; height: 6px;
  border-radius: 9999px;
  background: #6BCF8F;
  animation: dotPulse 2s ease-in-out infinite;
}

/* === STATS === */
.stats {
  background: var(--bg-alt);
  padding-block: clamp(3rem, 6vh, 5rem);
  border-block: 1px solid var(--rule);
}
.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  margin-top: 1rem;
}
@media (max-width: 760px) {
  .stats-grid { grid-template-columns: 1fr 1fr; }
}
.stat {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center;
  text-align: center;
}
.stat-num {
  font-size: clamp(2.4rem, 4vw, 3.4rem);
  font-weight: 900;
  letter-spacing: -0.04em;
  color: var(--ink);
  line-height: 1;
  direction: ltr;
  unicode-bidi: isolate;
}
.stat-num small { font-size: 0.5em; font-weight: 700; color: var(--ink-muted); margin-inline-start: 2px; }
.stat-label { font-size: 14px; color: var(--ink-muted); line-height: 1.4; max-width: 200px; }

/* ============================================
   INLINE CTAs — scattered scroll triggers
   ============================================ */
.inline-cta {
  background: var(--bg);
  padding-block: clamp(2rem, 4vh, 3rem);
  border-block: 1px solid var(--rule);
}
.inline-cta-strong {
  background: var(--bg-warm);
  border-color: var(--accent-soft);
}
.inline-cta-quiet {
  background: var(--bg);
  border-color: transparent;
  padding-block: clamp(1.5rem, 3vh, 2.25rem);
}
.inline-cta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  flex-wrap: wrap;
}
.inline-cta-text {
  flex: 1;
  min-width: 280px;
  margin: 0;
  font-size: clamp(15px, 1.4vw, 17.5px);
  line-height: 1.55;
  color: var(--ink);
  font-weight: 500;
}
.inline-cta-strong .inline-cta-text { font-weight: 600; font-size: clamp(16.5px, 1.5vw, 19px); }
.inline-cta-quiet .inline-cta-text { color: var(--ink-muted); font-size: 14.5px; }
.inline-cta-quote {
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 1.5em;
  margin-inline-end: 6px;
  vertical-align: -0.2em;
  font-weight: 900;
}
.inline-cta-btn {
  flex-shrink: 0;
  white-space: nowrap;
}
.inline-cta-link {
  flex-shrink: 0;
  color: var(--accent-strong);
  font-weight: 700;
  border-bottom: 1.5px solid currentColor;
  padding-bottom: 2px;
}
.inline-cta-link:hover { color: var(--ink); }
@media (max-width: 640px) {
  .inline-cta-row { gap: 1rem; }
  .inline-cta-btn { width: 100%; text-align: center; }
}

/* === LOGO MARQUEE === */
.logos {
  background: var(--bg);
  padding-block: clamp(3rem, 5vh, 4rem);
  border-bottom: 1px solid var(--rule);
  overflow: hidden;
  position: relative;
}
.logos-head {
  margin-bottom: 1.5rem;
}
.logos-eyebrow {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--ink-faint);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-align: center;
}
.logos-marquee {
  position: relative;
  width: 100%;
}
.logos-track {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: clamp(12px, 1.4vw, 24px);
  align-items: center;
}
/* Hide the duplicated set — first 6 only on the static layout */
.logos-track > .logo-chip:nth-child(n+7) { display: none; }
@media (max-width: 720px) {
  .logos-track { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
.logo-chip {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px 20px;
  border-radius: 12px;
  border: 1px solid var(--rule);
  background: var(--bg);
  width: 100%;
  height: 88px;
  transition: transform 280ms var(--ease-out-soft), border-color 280ms var(--ease-out), background 280ms var(--ease-out), box-shadow 280ms var(--ease-out);
}
.logo-chip img {
  max-width: 130px;
  max-height: 44px;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: grayscale(40%) brightness(0.95);
  opacity: 0.85;
  transition: filter 280ms var(--ease-out), opacity 280ms var(--ease-out);
}
.logo-chip:hover {
  transform: translateY(-3px);
  border-color: var(--ink);
  box-shadow: 0 12px 28px -16px rgba(14,14,14,0.18);
}
.logo-chip:hover img {
  filter: grayscale(0%) brightness(1);
  opacity: 1;
}
.logo-chip-dark {
  background: var(--bg-dark);
  border-color: var(--bg-dark);
}
.logo-chip-dark img {
  filter: none;
  opacity: 1;
}
.logo-chip-dark:hover {
  background: #1a1a1a;
}
.logo-chip-coming {
  background: transparent;
  border-style: dashed;
  border-color: var(--ink-faint);
}
.logo-chip-coming span {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--ink-faint);
  white-space: nowrap;
}
.logo-chip-coming:hover {
  border-color: var(--ink-muted);
  background: transparent;
  transform: translateY(-2px);
}
.logos-disclaimer {
  margin-top: 1.5rem;
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--ink-faint);
  text-align: center;
  letter-spacing: 0.02em;
}
@media (prefers-reduced-motion: reduce) {
  .logos-track { animation: none; }
}

/* === CASE STUDY === */
.case { background: var(--bg); }
.case-disclaimer {
  margin-top: 0.5rem;
  font-size: 13px;
  color: var(--ink-faint);
  font-style: italic;
}

.case-stages {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}
.case-stage {
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: 18px;
  padding: clamp(1.5rem, 3vw, 2.5rem);
  position: relative;
  transition: border-color var(--t), transform var(--t);
}
.case-stage:hover { border-color: var(--ink); transform: translateY(-2px); }

.case-stage-head {
  display: flex;
  align-items: baseline;
  gap: 1rem;
  margin-bottom: 1.25rem;
}
.case-stage-num {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
  color: var(--accent-strong);
  background: var(--accent-soft);
  padding: 4px 12px;
  border-radius: 999px;
  letter-spacing: 0.06em;
}
.case-stage-head h3 {
  font-size: clamp(1.3rem, 2.4vw, 1.85rem);
  font-weight: 900;
  letter-spacing: -0.025em;
}
.case-quote {
  font-family: 'Heebo', serif;
  font-style: italic;
  font-size: clamp(1.05rem, 1.5vw, 1.25rem);
  color: var(--ink-2);
  line-height: 1.5;
  margin: 0 0 1.25rem;
  padding-inline-start: 1rem;
  border-inline-start: 3px solid var(--accent);
}
.case-quote-after {
  border-inline-start-color: var(--good);
  color: var(--ink);
  font-style: normal;
  font-weight: 500;
}

.case-pains, .case-wins {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.case-wins { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 720px) {
  .case-pains, .case-wins { grid-template-columns: 1fr 1fr; }
}
.case-pains li, .case-wins li {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 14px;
  background: var(--bg-alt);
  border-radius: 12px;
}
.case-wins li { background: rgba(45,122,74,0.06); }
.case-pain-num, .case-win-num {
  font-size: clamp(1.4rem, 2.4vw, 1.85rem);
  font-weight: 900;
  letter-spacing: -0.03em;
  color: var(--ink);
  direction: ltr;
  unicode-bidi: isolate;
}
.case-pain-num small, .case-win-num small {
  font-size: 0.5em;
  font-weight: 700;
  color: var(--ink-muted);
  margin-inline-start: 2px;
}
.case-win-num { color: var(--good); }
.case-pains span:last-child, .case-wins span:last-child {
  font-size: 13px;
  color: var(--ink-muted);
}

.case-body {
  font-size: 1.05rem;
  color: var(--ink-2);
  line-height: 1.65;
  margin-bottom: 1.5rem;
  max-width: 70ch;
}
.case-arch {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  background: var(--bg-warm);
  border: 1px solid var(--rule);
  border-radius: 14px;
  padding: 18px 20px;
  margin-bottom: 1rem;
}
.case-node {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  background: #fff;
  border: 1px solid var(--rule);
  padding: 8px 14px;
  border-radius: 999px;
  white-space: nowrap;
}
.case-node-mid { background: var(--ink); color: #fff; border-color: var(--ink); }
.case-node-out { background: var(--accent); color: #fff; border-color: var(--accent); }
.case-arrow {
  font-family: var(--font-mono);
  font-size: 1.2rem;
  color: var(--ink-faint);
  transform: scaleX(-1); /* RTL flip directional arrow */
}
.case-meta {
  font-size: 13px;
  color: var(--ink-faint);
}

/* === DELIVERY (numbered chapters of work types) === */
.delivery { background: var(--bg-alt); border-block: 1px solid var(--rule); }
.delivery-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-top: 1px solid var(--rule);
}
.delivery-item {
  display: grid;
  grid-template-columns: 60px 1fr auto;
  gap: 1.5rem;
  align-items: center;
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--rule);
  transition: padding var(--t);
  cursor: pointer;
}
.delivery-item:hover { padding-inline-start: 1rem; }
.delivery-num {
  font-family: var(--font-mono);
  font-size: 22px;
  font-weight: 700;
  color: var(--accent-strong);
  letter-spacing: -0.02em;
}
.delivery-body h3 {
  font-size: clamp(1.15rem, 1.8vw, 1.4rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: 4px;
}
.delivery-body p {
  font-size: 14.5px;
  color: var(--ink-muted);
  line-height: 1.5;
}
.delivery-tag {
  font-family: var(--font-mono);
  font-size: 11.5px;
  font-weight: 600;
  color: var(--ink-2);
  background: rgba(255,255,255,0.6);
  border: 1px solid var(--rule);
  padding: 5px 10px;
  border-radius: 999px;
  white-space: nowrap;
}
@media (max-width: 600px) {
  .delivery-item { grid-template-columns: 50px 1fr; }
  .delivery-tag { display: none; }
}

/* === PROOF tiles (carried from v2 with polish) === */
.proof { background: var(--bg); }
.tiles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-bottom: 3rem;
}
@media (max-width: 920px) { .tiles { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .tiles { grid-template-columns: 1fr; } }
.tile {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: 22px;
  overflow: hidden;
  transition: border-color var(--t), transform var(--t), box-shadow var(--t);
}
.tile:hover {
  border-color: var(--ink);
  transform: translateY(-4px);
  box-shadow: 0 24px 48px -20px rgba(14,14,14,0.18), 0 8px 16px -10px rgba(14,14,14,0.10);
}
.tile-frame {
  background: var(--bg-warm);
  padding: 22px 20px 0;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  min-height: 320px;
  position: relative;
  overflow: hidden;
}
.tile-caption {
  padding: 22px;
  border-top: 1px solid var(--rule);
}
.tile-tag {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 11.5px;
  font-weight: 700;
  color: var(--accent-strong);
  letter-spacing: 0.04em;
  margin-bottom: 8px;
}
.tile-caption h4 {
  font-size: 1.18rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: 4px;
}
.tile-caption p {
  font-size: 14px;
  color: var(--ink-muted);
  line-height: 1.5;
}

/* PDF mockup */
.pdf-page {
  background: #fff;
  border: 1px solid var(--rule);
  width: 100%;
  max-width: 280px;
  font-size: 11px;
  line-height: 1.45;
  color: var(--ink-2);
  border-radius: 6px;
  box-shadow: 0 16px 32px -16px rgba(14,14,14,0.15);
  overflow: hidden;
  font-family: var(--font-sans);
}
.pdf-head {
  padding: 14px 16px;
  border-bottom: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
}
.pdf-logo {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-weight: 800;
  font-size: 11px;
}
.pdf-mark {
  width: 7px; height: 7px;
  background: var(--ink);
  border-radius: 9999px;
  display: inline-block;
}
.pdf-meta {
  display: flex;
  flex-direction: column;
  gap: 1px;
  font-size: 9.5px;
  color: var(--ink-faint);
  text-align: end;
}
.pdf-body { padding: 14px 16px 16px; }
.pdf-eyebrow {
  font-size: 9.5px;
  font-weight: 700;
  color: var(--accent-strong);
  letter-spacing: 0.06em;
  margin-bottom: 6px;
}
.pdf-h {
  font-size: 14px;
  font-weight: 800;
  letter-spacing: -0.015em;
  margin-bottom: 6px;
}
.pdf-lead {
  font-size: 10.5px;
  color: var(--ink-muted);
  margin-bottom: 10px;
  line-height: 1.5;
}
.pdf-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 10px;
  margin-bottom: 10px;
}
.pdf-table th {
  text-align: end;
  font-weight: 700;
  font-size: 9.5px;
  color: var(--ink-faint);
  border-bottom: 1px solid var(--rule);
  padding: 6px 4px;
}
.pdf-table th:first-child, .pdf-table td:first-child { text-align: start; }
.pdf-table td {
  padding: 6px 4px;
  border-bottom: 1px solid var(--rule-soft);
  font-size: 10.5px;
}
.pdf-table strong { font-weight: 700; color: var(--ink); }
.pdf-bar {
  display: inline-block;
  width: var(--w);
  height: 6px;
  background: var(--accent);
  border-radius: 9999px;
  vertical-align: middle;
}
.pdf-callout {
  background: var(--bg-warm);
  border-radius: 8px;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.pdf-callout-num {
  font-size: 22px;
  font-weight: 900;
  letter-spacing: -0.03em;
  color: var(--accent-strong);
  direction: ltr;
  unicode-bidi: isolate;
}
.pdf-callout-label { font-size: 10px; color: var(--ink-muted); line-height: 1.4; }
.pdf-foot {
  padding: 10px 16px;
  border-top: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
  font-size: 9px;
  color: var(--ink-faint);
}

/* Chat mockup */
.chat-window {
  background: #E5DDD5;
  width: 100%;
  max-width: 280px;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 16px 32px -16px rgba(14,14,14,0.18);
  display: flex;
  flex-direction: column;
  height: 380px;
}
.chat-head {
  background: #075E54;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.chat-avatar { width: 32px; height: 32px; flex-shrink: 0; }
.chat-avatar svg { width: 100%; height: 100%; border-radius: 9999px; }
.chat-titles { display: flex; flex-direction: column; gap: 2px; }
.chat-name { font-size: 12px; font-weight: 700; color: #fff; }
.chat-status { font-size: 10px; color: rgba(255,255,255,0.7); display: inline-flex; align-items: center; gap: 5px; }
.chat-dot {
  width: 6px; height: 6px;
  border-radius: 9999px;
  background: #6BCF8F;
  animation: dotPulse 2.5s ease-in-out infinite;
}
.chat-body {
  flex: 1;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 12px, transparent 12px 24px),
    #E5DDD5;
  padding: 12px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.msg {
  display: flex;
  flex-direction: column;
  max-width: 80%;
  padding: 8px 10px;
  border-radius: 8px;
  font-size: 11.5px;
  line-height: 1.45;
  position: relative;
}
.msg p { margin: 0; }
.msg-time {
  align-self: flex-start;
  margin-top: 2px;
  font-size: 9px;
  color: var(--ink-faint);
  unicode-bidi: plaintext;
}
.msg-out .msg-time { color: rgba(0,0,0,0.45); align-self: flex-end; }
.msg-check { color: #4FC3F7; }
.msg-in {
  align-self: flex-start;
  background: #fff;
  border-bottom-inline-start-radius: 2px;
}
.msg-out {
  align-self: flex-end;
  background: #DCF8C6;
  border-bottom-inline-end-radius: 2px;
}
.msg-system {
  align-self: center;
  background: rgba(255,255,255,0.6);
  font-size: 10px;
  color: var(--ink-muted);
  padding: 5px 10px;
  border-radius: 999px;
  text-align: center;
  max-width: 90%;
}
.chat-foot {
  background: #F0F0F0;
  padding: 8px 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.chat-input {
  flex: 1;
  font-size: 11px;
  color: var(--ink-faint);
  padding: 6px 10px;
  background: #fff;
  border-radius: 999px;
}
.chat-send {
  width: 28px;
  height: 28px;
  background: #075E54;
  color: #fff;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
}

/* === Credit Alert mockup === */
.alert-window {
  background: #FFFFFF;
  width: 100%;
  max-width: 320px;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 20px 40px -20px rgba(14,14,14,0.22);
  display: flex;
  flex-direction: column;
  height: 380px;
  border: 1px solid var(--rule);
}
.alert-head {
  background: var(--bg-dark);
  padding: 10px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: #fff;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.04em;
}
.alert-brand { display: inline-flex; align-items: center; gap: 8px; }
.alert-brand-mark {
  width: 7px; height: 7px;
  border-radius: 9999px;
  background: var(--accent);
  box-shadow: 0 0 8px var(--accent);
  animation: alertPulse 2.4s ease-in-out infinite;
}
@keyframes alertPulse {
  0%, 100% { opacity: 0.7; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.15); }
}
.alert-clock { opacity: 0.7; }

.alert-body { padding: 18px 18px 14px; flex: 1; display: flex; flex-direction: column; gap: 14px; }

.alert-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  align-self: flex-start;
  padding: 6px 12px;
  border-radius: 9999px;
  font-size: 12px;
  font-weight: 700;
}
.alert-tag-warn {
  background: rgba(229, 122, 30, 0.12);
  color: #B5400A;
}
.alert-dot {
  width: 7px; height: 7px;
  border-radius: 9999px;
  background: #E57A1E;
  box-shadow: 0 0 6px rgba(229,122,30,0.6);
}

.alert-customer {
  font-size: 15px;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -0.015em;
  margin: 0;
}

.alert-rating {
  display: flex;
  align-items: stretch;
  gap: 8px;
  margin-top: 2px;
}
.alert-rating-block {
  flex: 1;
  background: var(--bg);
  border-radius: 10px;
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  border: 1px solid var(--rule);
}
.alert-rating-block-bad {
  background: rgba(181, 64, 10, 0.06);
  border-color: rgba(181, 64, 10, 0.2);
}
.alert-rating-label {
  font-size: 10.5px;
  color: var(--ink-muted);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.alert-rating-num {
  font-size: 26px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--ink);
}
.alert-rating-block-bad .alert-rating-num { color: #B5400A; }
.alert-rating-arrow {
  align-self: center;
  font-size: 18px;
  color: var(--ink-muted);
}

.alert-signals {
  list-style: none;
  margin: 0;
  padding: 12px 0 0;
  border-top: 1px dashed var(--rule);
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.alert-signals li {
  font-size: 12.5px;
  color: var(--ink-2);
  display: flex;
  align-items: flex-start;
  gap: 8px;
  line-height: 1.4;
}
.alert-sig-dot {
  width: 5px; height: 5px;
  margin-top: 6px;
  background: var(--ink-muted);
  border-radius: 9999px;
  flex-shrink: 0;
}

.alert-actions {
  display: flex;
  gap: 8px;
  margin-top: auto;
  padding-top: 6px;
}
.alert-cta {
  flex: 1;
  padding: 9px 12px;
  background: var(--ink);
  color: var(--bg);
  border-radius: 9999px;
  font-size: 12px;
  font-weight: 700;
  text-align: center;
  letter-spacing: -0.005em;
}
.alert-cta-alt {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--ink);
}

.alert-foot {
  background: var(--bg-alt);
  padding: 8px 14px;
  font-size: 10.5px;
  color: var(--ink-muted);
  display: flex;
  align-items: center;
  gap: 8px;
}
.alert-foot-dot {
  width: 6px; height: 6px;
  border-radius: 9999px;
  background: var(--good);
  box-shadow: 0 0 5px rgba(45, 122, 74, 0.5);
}

/* Dashboard mockup */
.dash-window {
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: 10px;
  width: 100%;
  max-width: 280px;
  font-size: 10.5px;
  line-height: 1.4;
  color: var(--ink-2);
  box-shadow: 0 16px 32px -16px rgba(14,14,14,0.15);
  overflow: hidden;
}
.dash-head {
  padding: 12px 14px;
  border-bottom: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
}
.dash-titles { display: flex; flex-direction: column; gap: 2px; }
.dash-eyebrow {
  font-size: 9.5px;
  font-weight: 700;
  color: var(--accent-strong);
  letter-spacing: 0.06em;
}
.dash-titles h5 { font-size: 13px; font-weight: 800; letter-spacing: -0.015em; }
.dash-range {
  display: inline-flex;
  background: var(--bg-alt);
  border-radius: 999px;
  padding: 2px;
  font-size: 9.5px;
  font-weight: 600;
}
.dash-range span {
  padding: 4px 8px;
  border-radius: 999px;
  color: var(--ink-faint);
}
.dash-range-active { background: #fff; color: var(--ink) !important; box-shadow: 0 1px 2px rgba(0,0,0,0.06); }

.dash-kpis {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--rule);
}
.kpi { display: flex; flex-direction: column; gap: 2px; }
.kpi-label { font-size: 9.5px; color: var(--ink-faint); }
.kpi-value {
  font-size: 17px;
  font-weight: 900;
  letter-spacing: -0.03em;
  color: var(--ink);
  direction: ltr;
  unicode-bidi: isolate;
}
.kpi-value small { font-size: 0.55em; font-weight: 600; color: var(--ink-muted); margin-inline-start: 2px; }
.kpi-delta { font-size: 9.5px; font-weight: 600; }
.kpi-good { color: var(--good); }
.kpi-bad { color: #B53A3A; }
.kpi-warn { color: var(--warn); }

.dash-chart {
  position: relative;
  padding: 14px;
  height: 100px;
  border-bottom: 1px solid var(--rule);
}
.chart-grid {
  position: absolute;
  inset: 14px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  pointer-events: none;
}
.chart-grid span {
  display: block;
  height: 1px;
  background: var(--rule-soft);
}
.chart-bars {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  height: 100%;
  align-items: end;
  position: relative;
}
.chart-bars span {
  display: block;
  height: var(--h);
  background: linear-gradient(180deg, var(--accent), var(--accent-strong));
  border-radius: 3px;
  transition: opacity var(--t-fast);
  position: relative;
}
.chart-bars span::after {
  content: attr(data-day);
  position: absolute;
  top: 100%;
  inset-inline-start: 50%;
  transform: translateX(50%);
  margin-top: 4px;
  font-size: 8.5px;
  color: var(--ink-faint);
  font-family: var(--font-sans);
}

.dash-alerts {
  padding: 8px 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.alert {
  display: grid;
  grid-template-columns: 8px 1fr auto;
  gap: 8px;
  align-items: center;
  font-size: 10px;
}
.alert-dot {
  width: 7px; height: 7px;
  border-radius: 9999px;
}
.alert-warn { background: var(--warn); }
.alert-info { background: var(--info); }
.alert-text strong { font-weight: 700; }
.alert-time { font-size: 9px; color: var(--ink-faint); white-space: nowrap; }

/* Proof video placeholder */
.proof-video {
  margin-top: 2.5rem;
  background: var(--bg-dark);
  border-radius: 18px;
  overflow: hidden;
  position: relative;
  text-align: center;
  padding: 0;
}
.proof-video-frame {
  aspect-ratio: 16 / 9;
  background:
    radial-gradient(circle at 30% 30%, rgba(184,136,79,0.15), transparent 50%),
    var(--bg-dark);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.7);
}
.video-poster {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}
.video-play {
  width: 64px; height: 64px;
  border-radius: 9999px;
  background: rgba(255,255,255,0.1);
  border: 2px solid rgba(255,255,255,0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  color: #fff;
  transition: background var(--t-fast), transform var(--t-fast);
}
.proof-video:hover .video-play { background: var(--accent); transform: scale(1.05); }
.video-label {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.6);
}
.proof-video-caption {
  background: var(--bg-darker);
  color: rgba(255,255,255,0.55);
  padding: 14px 24px;
  font-size: 13px;
}

/* === PROCESS (dark) === */
.process { background: var(--bg-dark); color: #fff; padding-block: clamp(5rem, 12vh, 9rem); }
.process .section-head { margin-bottom: 2rem; }
.process-pullquote {
  font-size: clamp(1.5rem, 3.4vw, 2.4rem);
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1.15;
  color: #fff;
  margin: 1.5rem 0 3.5rem;
  max-width: 780px;
  position: relative;
}
.process-pullquote-mark {
  font-size: 2.5em;
  line-height: 0.5;
  color: var(--accent);
  margin-inline-end: 0.1em;
  vertical-align: -0.4em;
  font-weight: 400;
}
.process-pullquote-soft { color: rgba(255,255,255,0.55); display: block; margin-top: 0.4rem; }

.steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  margin-bottom: 2.25rem;
}
@media (max-width: 920px) { .steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .steps { grid-template-columns: 1fr; } }
.step {
  border-top: 1px solid rgba(255,255,255,0.12);
  padding-top: 1.25rem;
  transition: border-color var(--t);
}
.step:hover { border-top-color: var(--accent); }
.step-num {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: 0.06em;
  margin-bottom: 0.875rem;
}
.step h3 {
  font-size: clamp(1.15rem, 1.8vw, 1.4rem);
  font-weight: 800;
  margin-bottom: 0.5rem;
  color: #fff;
}
.step p {
  font-size: 14.5px;
  color: rgba(255,255,255,0.7);
  line-height: 1.55;
}
.process-foot {
  font-size: 14px;
  color: rgba(255,255,255,0.55);
  border-top: 1px solid var(--rule-dark);
  padding-top: 1.5rem;
}

/* === MANIFESTO === */
.manifesto {
  background: var(--bg-warm);
  border-block: 1px solid var(--rule);
}
.manifesto-grid {
  max-width: 720px;
  text-align: start;
}
.manifesto-title {
  font-size: clamp(2rem, 4.8vw, 3.4rem);
  margin-bottom: 2rem;
}
.manifesto-body {
  font-size: clamp(1.05rem, 1.4vw, 1.18rem);
  line-height: 1.75;
  color: var(--ink-2);
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.manifesto-body em { font-style: italic; color: var(--ink); }
.manifesto-body strong { font-weight: 800; color: var(--accent-strong); }
.manifesto-sig {
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--rule);
  display: flex;
  align-items: center;
  gap: 16px;
}
.manifesto-sig-photo {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  flex-shrink: 0;
  border: 1px solid var(--rule);
}
.manifesto-sig-text { display: flex; flex-direction: column; gap: 4px; }
.manifesto-sig-name { font-size: 18px; font-weight: 800; }
.manifesto-sig-role { font-size: 14px; color: var(--ink-muted); }

/* === PROJECTS === */
.projects { background: var(--bg); }
.projects-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}
@media (max-width: 920px) { .projects-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .projects-grid { grid-template-columns: 1fr; } }
.project-card {
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: 18px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color var(--t), transform var(--t), box-shadow var(--t);
  position: relative;
}
.project-card:hover {
  border-color: var(--ink);
  transform: translateY(-3px);
  box-shadow: 0 18px 36px -18px rgba(14,14,14,0.12);
}
.project-art {
  aspect-ratio: 16 / 10;
  background-size: 14px 14px;
  background-image:
    linear-gradient(rgba(14,14,14,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(14,14,14,0.05) 1px, transparent 1px);
  position: relative;
  overflow: hidden;
}
.project-art::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 70% 30%, var(--art-color, var(--accent-soft)), transparent 60%);
  opacity: 0.7;
}
.project-art-1 { --art-color: rgba(184,136,79,0.4); }
.project-art-2 { --art-color: rgba(45,122,74,0.3); }
.project-art-3 { --art-color: rgba(37,99,176,0.3); }
.project-art-4 { --art-color: rgba(181,58,58,0.25); }
.project-art-5 { --art-color: rgba(181,115,27,0.3); }
.project-art-6 { --art-color: rgba(108,90,164,0.3); }

.project-body { padding: 22px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.project-tag {
  font-family: var(--font-mono);
  font-size: 11.5px;
  font-weight: 700;
  color: var(--accent-strong);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.project-body h4 {
  font-size: 1.12rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.3;
}
.project-body p {
  font-size: 14px;
  color: var(--ink-muted);
  line-height: 1.5;
  margin-top: 4px;
}
.project-status {
  position: absolute;
  top: 14px;
  inset-inline-end: 14px;
  background: var(--ink);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  padding: 5px 10px;
  border-radius: 999px;
  letter-spacing: 0.02em;
}

/* === TESTIMONIALS === */
.testimonials {
  background: var(--bg-alt);
  border-block: 1px solid var(--rule);
}
.testimonial-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}
@media (max-width: 880px) { .testimonial-grid { grid-template-columns: 1fr; } }
.testimonial {
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: 18px;
  padding: 28px 24px;
  position: relative;
  transition: border-color var(--t);
}
.testimonial:hover { border-color: var(--ink); }
.testimonial::before {
  content: "״";
  position: absolute;
  top: 16px;
  inset-inline-start: 24px;
  font-size: 60px;
  color: var(--accent);
  line-height: 0.5;
  font-family: 'Heebo', serif;
  opacity: 0.4;
}
.testimonial-quote {
  font-size: 1.05rem;
  line-height: 1.55;
  color: var(--ink-2);
  margin-bottom: 1.5rem;
  font-style: italic;
  position: relative;
  padding-top: 18px;
}
.testimonial-foot { display: flex; align-items: center; gap: 12px; padding-top: 1rem; border-top: 1px solid var(--rule); }
.testimonial-avatar {
  width: 42px; height: 42px;
  border-radius: 9999px;
  background: linear-gradient(135deg, var(--bg-warm), var(--rule));
  border: 1px solid var(--rule);
  flex-shrink: 0;
}
.testimonial-meta { display: flex; flex-direction: column; gap: 2px; }
.testimonial-name { font-size: 14.5px; font-weight: 700; color: var(--ink-faint); font-style: italic; }
.testimonial-role { font-size: 12.5px; color: var(--ink-faint); }

/* === FAQ === */
.faq { background: var(--bg); }
.faq-list { max-width: 880px; }
.faq-item {
  border-top: 1px solid var(--rule);
  padding: 0;
}
.faq-item:last-child { border-bottom: 1px solid var(--rule); }
.faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 22px 0;
  font-size: clamp(1.05rem, 1.5vw, 1.25rem);
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--ink);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  transition: color var(--t-fast);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "+";
  font-size: 24px;
  font-weight: 400;
  color: var(--ink-muted);
  flex-shrink: 0;
  transition: transform var(--t), color var(--t-fast);
}
.faq-item[open] summary::after { content: "−"; transform: rotate(0); color: var(--accent-strong); }
.faq-item summary:hover { color: var(--accent-strong); }
.faq-answer {
  padding: 0 0 24px;
  font-size: 15.5px;
  color: var(--ink-muted);
  line-height: 1.65;
  max-width: 70ch;
}

/* === FOUNDER === */
.founder {
  background: #fff;
  border-block: 1px solid var(--rule);
}
.founder-grid {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: start;
}
@media (max-width: 880px) { .founder-grid { grid-template-columns: 1fr; gap: 2.5rem; } }

.founder-large {
  position: sticky;
  top: 100px;
}
.founder-large-photo {
  aspect-ratio: 1;
  background: var(--bg-alt);
  border-radius: 22px;
  overflow: hidden;
  margin-bottom: 1.25rem;
  max-width: 360px;
}
@media (max-width: 880px) { .founder-large-photo { max-width: 320px; margin-inline: auto; } }
.founder-large-photo img { width: 100%; height: 100%; display: block; object-fit: cover; }
.founder-large-meta { display: flex; flex-direction: column; gap: 4px; margin-bottom: 1.25rem; }
.founder-large-name { font-size: 1.4rem; font-weight: 900; letter-spacing: -0.025em; }
.founder-large-role { font-size: 14.5px; color: var(--ink-muted); }
.founder-large-loc { font-size: 13px; color: var(--ink-faint); margin-top: 4px; }

.founder-credentials { display: flex; flex-direction: column; gap: 8px; padding-top: 1rem; border-top: 1px solid var(--rule); }
.founder-credentials li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 14px;
  color: var(--ink-2);
  line-height: 1.5;
}
.cred-icon { color: var(--accent); flex-shrink: 0; font-weight: 700; }

.founder-copy { max-width: 640px; }
.founder-copy p {
  font-size: clamp(1.02rem, 1.35vw, 1.15rem);
  color: var(--ink-2);
  line-height: 1.7;
  margin-bottom: 1.25rem;
}
.founder-copy p strong { font-weight: 800; color: var(--accent-strong); }
.founder-copy .btn { margin-top: 1rem; }

/* === CONTACT === */
.contact {
  background: var(--bg-alt);
  border-block: 1px solid var(--rule);
}
.contact-grid { max-width: 720px; }

.contact-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem 1.25rem;
  margin-bottom: 2rem;
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: 22px;
  padding: clamp(1.5rem, 3vw, 2.5rem);
}
@media (max-width: 600px) { .contact-form { grid-template-columns: 1fr; } }

.field { display: flex; flex-direction: column; gap: 8px; }
.field-full { grid-column: 1 / -1; }
.field label { font-size: 14px; font-weight: 600; color: var(--ink-2); }
.field input, .field textarea, .field select {
  width: 100%;
  padding: 12px 14px;
  background: var(--bg);
  border: 1px solid var(--rule);
  border-radius: 12px;
  color: var(--ink);
  font-family: inherit;
  font-size: 15.5px;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.field select {
  appearance: none;
  -webkit-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 fill='%235A5A5A' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: left 14px center;
  padding-left: 36px;
  cursor: pointer;
}
.field input:focus-visible, .field textarea:focus-visible, .field select:focus-visible {
  outline: none;
  border-color: var(--ink);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.field textarea { resize: vertical; min-height: 90px; }

.btn-submit { grid-column: 1 / -1; justify-self: start; }
.form-status { grid-column: 1 / -1; font-size: 14px; min-height: 1em; }
.form-status.is-success { color: var(--good); font-weight: 600; }
.form-status.is-error { color: #B53A3A; font-weight: 600; }

.contact-alt-block {
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.contact-alt, .contact-alt-direct { font-size: 14.5px; color: var(--ink-muted); margin: 0; }
.contact-alt a, .contact-alt-link {
  color: var(--accent-strong);
  font-weight: 600;
  border-bottom: 1px solid currentColor;
  transition: color var(--t-fast);
}
.contact-alt a:hover, .contact-alt-link:hover { color: var(--ink); }
.contact-alt-direct { font-weight: 500; color: var(--ink); }
.contact-alt-direct .contact-alt-link { font-weight: 700; }
.form-status a { color: var(--accent-strong); font-weight: 700; border-bottom: 1px solid currentColor; }

/* === FOOTER === */
.site-footer {
  background: var(--bg-dark);
  color: #fff;
  padding-block: clamp(3rem, 6vh, 5rem) clamp(1.5rem, 3vh, 2.5rem);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: 2.5rem;
  align-items: start;
}
@media (max-width: 720px) { .footer-grid { grid-template-columns: 1fr; gap: 2rem; } }
.footer-brand { display: flex; flex-direction: column; gap: 0.5rem; }
.footer-brand .brand-name { font-size: 1.2rem; font-weight: 900; }
.footer-brand p { font-size: 14px; color: rgba(255,255,255,0.6); }
.footer-links { display: flex; flex-direction: column; gap: 8px; }
.footer-links a { font-size: 14px; color: rgba(255,255,255,0.7); transition: color var(--t-fast); }
.footer-links a:hover { color: var(--accent); }
.footer-meta { font-size: 13px; color: rgba(255,255,255,0.4); }
.footer-meta p { direction: ltr; unicode-bidi: isolate; }

/* === Scroll-reveal === */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 700ms var(--ease-out-soft), transform 700ms var(--ease-out-soft);
  will-change: opacity, transform;
}
.reveal.is-visible { opacity: 1; transform: none; }
.reveal.delay-100 { transition-delay: 100ms; }
.reveal.delay-200 { transition-delay: 200ms; }
.reveal.delay-300 { transition-delay: 300ms; }

/* === Reduced motion === */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0ms !important;
    scroll-behavior: auto !important;
  }
  .reveal { opacity: 1; transform: none; }
}

/* ============================================
   ONE-PER-VIEWPORT LAYOUT
   Each .view section fills (close to) one screen height.
   Apple / Linear / leftclick.ai rhythm — scroll = next idea.
   ============================================ */

.page-one-per-view .view {
  min-height: 100dvh;
  min-height: 100vh; /* fallback */
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-block: clamp(5rem, 9vh, 7rem);
  position: relative;
  scroll-margin-top: 0;
}

.page-one-per-view section[id] { scroll-margin-top: 0; }

.view-inner { width: 100%; }
.view-inner-narrow { max-width: 820px; margin-inline: auto; }

.view-eyebrow {
  font-family: var(--font-mono);
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: 1.75rem;
  display: block;
}
.view-process .view-eyebrow,
.view-console .view-eyebrow { color: rgba(255,255,255,0.5); }

.view-head { max-width: 880px; margin-bottom: 3.5rem; }

/* — Viewport 1 — hero copy alone — */
.view-hero-copy { background: var(--bg); }
.view-hero-copy .view-inner {
  max-width: 1100px;
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.view-hero-copy .hero-title {
  font-size: clamp(2.8rem, 7vw, 5.6rem);
  letter-spacing: -0.04em;
  line-height: 0.98;
  font-weight: 900;
  margin-bottom: 1.75rem;
  text-align: center !important;
  width: 100%;
}
.view-hero-copy .hero-sub {
  font-size: clamp(1.15rem, 1.6vw, 1.4rem);
  line-height: 1.5;
  max-width: 56ch;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: 2.5rem;
  color: var(--ink-muted);
  text-align: center !important;
}
.view-hero-copy .hero-cta {
  margin-bottom: 0;
  justify-content: center;
}
.view-hero-copy .eyebrow { color: var(--accent-strong); }

/* Hero stats row — leftclick.ai pattern */
.hero-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(1rem, 3vw, 3rem);
  max-width: 980px;
  margin: 0 auto 3rem;
  padding-block: 2rem;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
@media (max-width: 720px) {
  .hero-stats { grid-template-columns: repeat(2, 1fr); gap: 1.5rem 1rem; padding-block: 1.5rem; }
}
.hero-stat {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: center;
  text-align: center;
}
.hero-stat-num {
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 900;
  letter-spacing: -0.035em;
  line-height: 1;
  color: var(--ink);
  direction: ltr;
  unicode-bidi: isolate;
}
.hero-stat-num small {
  font-size: 0.55em;
  font-weight: 700;
  color: var(--ink-muted);
}
.hero-stat-label {
  font-size: clamp(11.5px, 1vw, 13.5px);
  color: var(--ink-muted);
  line-height: 1.35;
  letter-spacing: 0;
  max-width: 18ch;
}

/* ============================================
   BIG HERO CTA — animated, prominent
   ============================================ */
.btn-hero-cta {
  position: relative;
  padding: 22px 44px;
  font-size: 17.5px;
  font-weight: 700;
  gap: 0.9rem;
  letter-spacing: -0.005em;
  isolation: isolate;
  overflow: hidden;
  box-shadow:
    0 18px 40px -16px rgba(225, 29, 72, 0.42),
    0 8px 20px -10px rgba(14, 15, 20, 0.32);
  animation: heroCtaPulse 2.6s ease-in-out infinite;
}
.btn-hero-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.18) 50%, transparent 100%);
  transform: translateX(-120%);
  transition: transform 700ms var(--ease-out-soft);
  z-index: -1;
}
.btn-hero-cta:hover::before { transform: translateX(120%); }
.btn-hero-cta .btn-arrow {
  display: inline-block;
  font-size: 1.15em;
  transition: transform 280ms var(--ease-out-soft);
}
.btn-hero-cta:hover {
  transform: translateY(-2px);
  background: var(--accent);
  animation-play-state: paused;
}
.btn-hero-cta:hover .btn-arrow { transform: translateX(-6px); }
@keyframes heroCtaPulse {
  0%, 100% {
    box-shadow:
      0 18px 40px -16px rgba(225, 29, 72, 0.42),
      0 8px 20px -10px rgba(14, 15, 20, 0.32),
      0 0 0 0 rgba(225, 29, 72, 0.45);
  }
  50% {
    box-shadow:
      0 22px 48px -16px rgba(225, 29, 72, 0.55),
      0 10px 24px -10px rgba(14, 15, 20, 0.4),
      0 0 0 14px rgba(225, 29, 72, 0);
  }
}
@media (prefers-reduced-motion: reduce) {
  .btn-hero-cta { animation: none; }
}

/* ============================================
   GLOBAL CENTERING — every viewport content centered
   Aggressive: flexbox column + !important so RTL/cascade can't drift right
   ============================================ */
.page-one-per-view .view-inner {
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.page-one-per-view .view-head,
.page-one-per-view .section-title,
.page-one-per-view .section-sub,
.page-one-per-view .view-eyebrow {
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.page-one-per-view .view-head { display: block; }

/* Delivery list — center the column itself */
.page-one-per-view .delivery-list {
  max-width: 880px;
  margin-inline: auto;
}
/* Keep delivery row internal layout (num + body) but center the row content */
.page-one-per-view .delivery-item { text-align: right; }

/* Tiles row — center the grid */
.page-one-per-view .tiles {
  justify-content: center;
  margin-inline: auto;
}
.page-one-per-view .tile { text-align: right; }

/* Process steps — center the row */
.page-one-per-view .steps { justify-content: center; }
.page-one-per-view .step { text-align: center; }

/* FAQ — center the list */
.page-one-per-view .faq-list {
  max-width: 880px;
  margin-inline: auto;
  text-align: right;
}

/* Founder — center the grid */
.page-one-per-view .view-founder .founder-grid {
  justify-content: center;
  max-width: 1100px;
  margin-inline: auto;
}
.page-one-per-view .founder-copy { text-align: right; }

/* Manifesto — center the column, body stays right-aligned for reading */
.page-one-per-view .manifesto-grid {
  margin-inline: auto;
  text-align: center;
}
.page-one-per-view .manifesto-body { text-align: right; }
.page-one-per-view .manifesto-sig { justify-content: center; }

/* Contact — center form */
.page-one-per-view .view-contact .view-head { margin-inline: auto; }
.page-one-per-view .contact-form,
.page-one-per-view .contact-alt-block { margin-inline: auto; }
.page-one-per-view .contact-form { text-align: right; }

/* Cases — center the grid */
.page-one-per-view .cases-grid {
  justify-content: center;
  max-width: 1100px;
  margin-inline: auto;
}
.page-one-per-view .case-card { text-align: right; }

.scroll-hint {
  position: absolute;
  bottom: 2.5rem;
  inset-inline-start: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 0.45rem;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-faint);
  transition: color var(--t-fast), transform var(--t-fast);
}
.scroll-hint:hover { color: var(--ink); }
.scroll-hint-arrow {
  display: inline-block;
  font-size: 18px;
  animation: scrollHint 1.8s ease-in-out infinite;
}
@keyframes scrollHint {
  0%, 100% { transform: translateY(0); opacity: 0.6; }
  50%      { transform: translateY(6px); opacity: 1; }
}

/* — Viewport 2 — Live Console (alive: ambient crimson glow, rotating feed, ticking metrics) — */
.view-console {
  background: var(--bg-dark);
  color: #fff;
  overflow: hidden;
  position: relative;
}
.view-console::before {
  content: "";
  position: absolute;
  inset: -10%;
  background:
    radial-gradient(ellipse 60% 50% at 22% 28%, rgba(225,29,72,0.13) 0%, transparent 55%),
    radial-gradient(ellipse 55% 45% at 78% 72%, rgba(225,29,72,0.10) 0%, transparent 55%),
    radial-gradient(ellipse 40% 35% at 50% 100%, rgba(225,29,72,0.08) 0%, transparent 60%);
  pointer-events: none;
  animation: consoleAmbient 14s ease-in-out infinite alternate;
  z-index: 0;
}
@keyframes consoleAmbient {
  0%   { transform: translate3d(0, 0, 0) scale(1);     opacity: 0.85; }
  50%  { transform: translate3d(2%, -1%, 0) scale(1.04); opacity: 1; }
  100% { transform: translate3d(-2%, 1%, 0) scale(0.98); opacity: 0.9; }
}
.view-console .view-inner-narrow { max-width: 760px; position: relative; z-index: 1; }
.view-console .console {
  box-shadow:
    0 50px 100px -20px rgba(0,0,0,0.55),
    0 30px 60px -30px rgba(0,0,0,0.4),
    0 0 0 1px rgba(225,29,72,0.18);
  border: 1px solid rgba(255,255,255,0.10);
  background: linear-gradient(180deg, rgba(255,255,255,0.02) 0%, transparent 100%), var(--bg-dark);
}

/* Feed: new item slide-in with crimson flash, oldest fade-out */
.console-feed-list li.feed-new {
  animation: feedSlideIn 800ms var(--ease-out-soft);
}
.console-feed-list li.feed-out {
  animation: feedSlideOut 420ms ease-in forwards;
}
@keyframes feedSlideIn {
  0%   { opacity: 0; transform: translateY(-10px); background: rgba(225,29,72,0.18); }
  60%  { background: rgba(225,29,72,0.10); }
  100% { opacity: 1; transform: translateY(0); background: transparent; }
}
@keyframes feedSlideOut {
  0%   { opacity: 1; transform: translateY(0); max-height: 60px; }
  100% { opacity: 0; transform: translateY(10px); max-height: 0; padding-block: 0; margin-block: 0; }
}

/* Number tick pulse */
.console-metric-value.tick {
  animation: metricTick 700ms var(--ease-out-soft);
}
@keyframes metricTick {
  0%   { transform: scale(1);    color: #fff; }
  35%  { transform: scale(1.12); color: #fff; text-shadow: 0 0 18px rgba(225,29,72,0.7); }
  100% { transform: scale(1);    color: #fff; text-shadow: none; }
}

/* Metric bar shimmer — subtle moving highlight */
.console-metric-bar { position: relative; overflow: hidden; }
.console-metric-bar > span::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.18) 50%, transparent 100%);
  transform: translateX(-100%);
  animation: barShimmer 3.4s ease-in-out infinite;
}
@keyframes barShimmer {
  0%, 70% { transform: translateX(-100%); }
  100%    { transform: translateX(100%); }
}

/* Section CTAs — small contextual conversion prompts at the bottom of each viewport */
.section-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  margin-top: clamp(2rem, 4vh, 3rem);
  font-size: 15.5px;
  color: var(--ink-muted);
  flex-wrap: wrap;
}
.section-cta-on-dark { color: rgba(255,255,255,0.7); }
.section-cta-link {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  font-weight: 700;
  color: var(--ink);
  padding: 10px 22px;
  border-radius: 9999px;
  background: rgba(225,29,72,0.08);
  border: 1px solid rgba(225,29,72,0.25);
  transition: background var(--t-fast), border-color var(--t-fast), transform var(--t-fast), gap var(--t-fast);
}
.section-cta-link:hover {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
  transform: translateY(-1px);
  gap: 0.65rem;
}
.section-cta-on-dark .section-cta-link {
  color: #fff;
  background: rgba(225,29,72,0.18);
  border-color: rgba(225,29,72,0.45);
}
.section-cta-on-dark .section-cta-link:hover {
  background: var(--accent);
  border-color: var(--accent);
}

/* Headline on dark backgrounds */
.view-head-on-dark { margin-bottom: 2.5rem; }
.section-sub-on-dark { color: rgba(255,255,255,0.72); }
.view-console .section-title { font-size: clamp(1.6rem, 3.5vw, 2.6rem); margin-bottom: 0.9rem; }
.view-console .view-eyebrow { color: rgba(225,29,72,0.85); margin-bottom: 0.85rem; }

/* "Now processing" indicator below the feed */
.console-now {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px dashed rgba(255,255,255,0.08);
  font-size: 11px;
  color: rgba(255,255,255,0.6);
}
.console-now-dot {
  width: 6px; height: 6px; border-radius: 9999px;
  background: #E11D48;
  box-shadow: 0 0 10px rgba(225,29,72,0.7);
  animation: nowPulse 1.2s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes nowPulse {
  0%, 100% { opacity: 0.5; transform: scale(0.85); }
  50%      { opacity: 1;   transform: scale(1.2); }
}
.console-now-label {
  font-family: var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(225,29,72,0.85);
  font-size: 10px;
}
.console-now-text {
  color: rgba(255,255,255,0.78);
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: opacity 250ms ease-out;
}

/* — Viewport 3 — logos — */
.view-logos {
  background: var(--bg);
  border-block: 1px solid var(--rule-soft);
}
.view-logos .view-inner { text-align: center; }
.view-logos .view-eyebrow { margin-bottom: 3rem; }

/* — Viewport 4 — cases — */
.view-cases { background: var(--bg); }

.cases-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 1.5rem;
}
.cases-grid-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}
.cases-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
  max-width: 1100px;
  margin-inline: auto;
}
@media (max-width: 1180px) {
  .cases-grid-4, .cases-grid-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 720px) {
  .cases-grid, .cases-grid-4, .cases-grid-3 { grid-template-columns: 1fr; }
}

/* SVG hero art inside each case card */
.case-art-svg {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  max-height: 160px;
  object-fit: contain;
}
.case-card-art {
  aspect-ratio: 16 / 7;
  padding: 1.5rem;
}
.cases-grid-4 .case-card-art {
  aspect-ratio: 5 / 3;
  padding: 1rem;
}
.cases-grid-4 .case-card-body {
  padding: 1.1rem 1.25rem 1.25rem;
  gap: 0.55rem;
}
.cases-grid-4 .case-card-tag { font-size: 10.5px; }
.cases-grid-4 .case-card-body h3 {
  font-size: clamp(1.02rem, 1.25vw, 1.2rem);
  line-height: 1.18;
}
.cases-grid-4 .case-card-body p {
  font-size: 13.5px;
  line-height: 1.45;
}
.cases-grid-4 .case-card-link { font-size: 13px; }

/* 3-column grid: more breathing room per card */
.cases-grid-3 .case-card-art {
  aspect-ratio: 5 / 3;
  padding: 1.25rem;
}
.cases-grid-3 .case-card-body {
  padding: 1.3rem 1.5rem 1.5rem;
  gap: 0.65rem;
}
.cases-grid-3 .case-card-tag { font-size: 11px; }
.cases-grid-3 .case-card-body h3 {
  font-size: clamp(1.15rem, 1.5vw, 1.35rem);
  line-height: 1.18;
}
.cases-grid-3 .case-card-body p {
  font-size: 14.5px;
  line-height: 1.5;
}
.cases-grid-3 .case-card-link { font-size: 14px; }
.case-art-supplier { background: linear-gradient(135deg, #0D0F14 0%, #1a1d28 100%); }
.case-art-barcode  { background: linear-gradient(135deg, #0D0F14 0%, #1c1820 100%); }
.case-art-room     { background: linear-gradient(135deg, #0D0F14 0%, #1d1925 100%); }
/* Legacy variants — kept for any old cached links */
.case-art-builder  { background: linear-gradient(135deg, #0D0F14 0%, #181b25 100%); }
.case-art-garage   { background: linear-gradient(135deg, #0D0F14 0%, #1f1822 100%); }
.case-art-dnb      { background: linear-gradient(135deg, #0D0F14 0%, #1a1820 100%); }

.case-card {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--rule);
  border-radius: 24px;
  overflow: hidden;
  background: var(--bg);
  text-decoration: none;
  color: inherit;
  transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.case-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 30px 60px -30px rgba(14,15,20,0.18);
  border-color: var(--ink);
}

.case-card-art {
  background: var(--bg-dark);
  color: #fff;
  aspect-ratio: 16 / 9;
  padding: 2.5rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  position: relative;
  overflow: hidden;
}
.case-card-art::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 80% 20%, var(--accent-soft) 0%, transparent 60%);
  pointer-events: none;
}
.case-card-stat {
  font-size: clamp(2.5rem, 5vw, 4.2rem);
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1;
  color: #fff;
  direction: ltr;
  unicode-bidi: isolate;
  position: relative;
  z-index: 1;
}
.case-card-stat-label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  margin-top: 0.5rem;
  position: relative;
  z-index: 1;
}

.case-card-body {
  padding: 2rem 2rem 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  flex: 1;
}
.case-card-tag {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent-strong);
}
.case-card-body h3 {
  font-size: clamp(1.4rem, 2vw, 1.75rem);
  letter-spacing: -0.02em;
  font-weight: 800;
}
.case-card-body p {
  color: var(--ink-muted);
  font-size: 15.5px;
  line-height: 1.55;
  margin-bottom: 0.5rem;
}
.case-card-link {
  font-weight: 600;
  color: var(--ink);
  font-size: 15px;
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  transition: gap var(--t-fast);
}
.case-card:hover .case-card-link { gap: 0.7rem; }

.case-card-coming {
  border-style: dashed;
  background: var(--bg-warm);
  align-items: center;
  justify-content: center;
  text-align: center;
  cursor: default;
  pointer-events: none;
  opacity: 0.7;
}
.case-card-coming:hover { transform: none; box-shadow: none; border-color: var(--rule); }
.case-card-coming .case-card-body {
  align-items: center;
  padding: 3rem 2rem;
}

/* — Viewport 5 — delivery — */
.view-delivery { background: var(--bg-alt); border-block: 1px solid var(--rule); }

/* — Viewport 6 — proof tiles — */
.view-proof { background: var(--bg); }

/* — Viewport 7 — process — */
.view-process {
  background: var(--bg-dark);
  color: #fff;
}
.view-process .section-title { color: #fff; }
.view-process .step h3 { color: #fff; }
.view-process .step p { color: rgba(255,255,255,0.72); }

/* — Viewport 8 — manifesto — */
.view-manifesto {
  background: var(--bg-warm);
  border-block: 1px solid var(--rule-soft);
}
.view-manifesto .view-inner-narrow { text-align: right; }

/* — Viewport 9 — faq — */
.view-faq { background: var(--bg); }
.view-faq .faq-list { max-width: 100%; }

/* — Viewport 10 — founder — */
.view-founder { background: var(--bg); }
.view-founder .founder-grid {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 4rem;
  align-items: center;
}
@media (max-width: 880px) {
  .view-founder .founder-grid { grid-template-columns: 1fr; gap: 2rem; }
}

/* — Viewport 11 — contact — */
.view-contact {
  background: var(--bg-alt);
  border-block: 1px solid var(--rule);
}
.view-contact .view-head { margin-bottom: 2.5rem; }

/* ============================================
   CASE DETAIL PAGE — /case/{slug}/
   ============================================ */

.page-case-detail .site-header { border-bottom: 1px solid var(--rule); }
.case-detail-main { padding-top: 1.5rem; padding-bottom: 4rem; }

.case-back {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding-block: 1.25rem;
  padding-inline: var(--gutter);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-muted);
  max-width: var(--container-max);
  margin-inline: auto;
  transition: color var(--t-fast), gap var(--t-fast);
}
.case-back:hover { color: var(--ink); gap: 0.75rem; }

.case-detail-hero {
  padding-block: clamp(3rem, 8vh, 6rem) clamp(3rem, 6vh, 4.5rem);
  border-bottom: 1px solid var(--rule-soft);
}
.case-detail-hero .eyebrow { color: var(--accent-strong); margin-bottom: 1rem; display: inline-block; }
.case-detail-title {
  font-size: clamp(2.2rem, 5vw, 4rem);
  letter-spacing: -0.035em;
  line-height: 1.02;
  font-weight: 900;
  margin-bottom: 1.25rem;
  max-width: 14ch;
}
.case-detail-sub {
  font-size: clamp(1.1rem, 1.5vw, 1.25rem);
  color: var(--ink-muted);
  line-height: 1.5;
  max-width: 62ch;
  margin-bottom: 0.5rem;
}
.case-detail-hero .case-disclaimer {
  font-size: 13px;
  color: var(--ink-faint);
  margin-bottom: 2.5rem;
}

.case-detail-headline-stats {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: max-content;
  justify-content: center;
  gap: clamp(2rem, 6vw, 4.5rem);
  padding-top: 2rem;
  border-top: 1px solid var(--rule-soft);
  margin-inline: auto;
  max-width: 100%;
}
@media (max-width: 720px) {
  .case-detail-headline-stats {
    grid-auto-flow: row;
    grid-auto-columns: auto;
    grid-template-columns: repeat(2, max-content);
    justify-content: center;
    gap: 1.5rem 2.5rem;
  }
}
.case-detail-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 6px;
}
.case-detail-stat-num {
  font-size: clamp(1.6rem, 2.6vw, 2.2rem);
  font-weight: 900;
  letter-spacing: -0.025em;
  color: var(--ink);
  direction: ltr;
  unicode-bidi: isolate;
}
.case-detail-stat-label {
  font-size: 13px;
  color: var(--ink-muted);
}

.case-stage-section {
  padding-block: clamp(4rem, 8vh, 6rem);
  border-bottom: 1px solid var(--rule-soft);
}
.case-stage-section .container { max-width: 880px; }
.case-stage-section-head {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}
.case-stage-section-head h2 {
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1.05;
}
.case-stage-section .case-quote {
  font-size: clamp(1.1rem, 1.5vw, 1.3rem);
  line-height: 1.5;
  margin-block: 1.5rem 2rem;
}
.case-stage-section .case-pains,
.case-stage-section .case-wins {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-top: 1.5rem;
}
.case-stage-section .case-wins { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 720px) {
  .case-stage-section .case-pains,
  .case-stage-section .case-wins { grid-template-columns: 1fr 1fr; }
}
.case-stage-section .case-body {
  font-size: 17px;
  line-height: 1.65;
  color: var(--ink-2);
  max-width: 62ch;
  margin-bottom: 2rem;
}
.case-stage-section .case-arch {
  background: var(--bg-warm);
  border: 1px solid var(--rule);
}
.case-stage-section .case-meta {
  margin-top: 1.25rem;
  font-size: 13.5px;
  color: var(--ink-faint);
}
.case-stage-section .case-quote-after {
  margin-top: 2rem;
  background: var(--bg-warm);
  border-inline-start: 3px solid var(--accent);
  padding: 1.25rem 1.5rem;
  border-radius: 0 12px 12px 0;
}

.case-detail-cta {
  padding-block: clamp(4rem, 9vh, 7rem);
  background: var(--bg-alt);
  text-align: right;
}
.case-detail-cta .container { max-width: 880px; }
.case-detail-cta .section-sub { margin-bottom: 2rem; }
.case-detail-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: center;
}

/* ============================================
   Disable old hero/section padding when inside .page-one-per-view
   ============================================ */
.page-one-per-view section { padding-block: 0; }
.page-one-per-view .view { padding-block: clamp(5rem, 9vh, 7rem); }
.page-one-per-view .container { max-width: var(--container-max); }

