/* La Traverse — BOLD direction.
   Same tokens as v1 but used differently: cream-dominant, editorial,
   bracket-systematic, oversized type. */

@font-face {
  font-family: 'Clash Display';
  src: url('fonts/ClashDisplay-Variable.woff2') format('woff2-variations'),
       url('fonts/ClashDisplay-Variable.woff') format('woff-variations'),
       url('fonts/ClashDisplay-Variable.ttf') format('truetype-variations');
  font-weight: 200 700;
  font-style: normal;
  font-display: swap;
}
@import url('https://api.fontshare.com/v2/css?f[]=satoshi@300,400,500,600,700,900&f[]=zodiak@400i,500i,600,700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;700&display=swap');

:root {
  /* surfaces — cream dominant */
  --cream:    #f5f0e8;
  --cream-2:  #ebe4d6;   /* slightly toasted, for inset blocks */
  --ink:      #0f1117;
  --ink-2:    #181b24;
  --paper:    #fbf9f4;   /* warm white for cards on cream */

  /* type */
  --fg:       #1a1a1a;
  --fg-2:     #55586a;
  --fg-3:     #8b8ea0;
  --fg-inv:   #f5f0e8;
  --fg-inv-2: rgba(245,240,232,0.55);
  --fg-inv-3: rgba(245,240,232,0.35);

  /* accents */
  --terra:        #c4622a;
  --terra-hover:  #a84e33;
  --amber:        #f59e0b;
  --amber-hover:  #d97706;

  /* borders */
  --border-c:    rgba(26,26,26,0.10);
  --border-c2:   rgba(26,26,26,0.18);
  --border-ink:  rgba(245,240,232,0.10);

  /* fonts */
  --display: 'Clash Display','Helvetica Neue',Arial,sans-serif;
  --serif:   'Zodiak',Georgia,serif;
  --sans:    'Satoshi','Helvetica Neue',Arial,sans-serif;
  --mono:    'JetBrains Mono','Courier New',monospace;

  /* layout */
  --pad:     clamp(24px, 5vw, 80px);
  --max:     1380px;
  --section: clamp(96px, 14vw, 200px);
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; scroll-behavior: smooth; }
body { background: var(--cream); color: var(--fg); font-family: var(--sans); line-height: 1.6; overflow-x: hidden; }

/* Reveal animation — applied to sections via [data-reveal]. Falls back gracefully when reduced motion. */
@media (prefers-reduced-motion: no-preference) {
  [data-reveal] { opacity: 0; transform: translateY(28px); transition: opacity .9s cubic-bezier(.22,.8,.32,1), transform .9s cubic-bezier(.22,.8,.32,1); }
  [data-reveal].is-revealed { opacity: 1; transform: none; }
}
a { color: inherit; text-decoration: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; color: inherit; }
img { display: block; max-width: 100%; height: auto; }

::selection { background: var(--terra); color: #fff; }

/* shared "grain" — applied to dark and warm surfaces alike */
.grain { position: relative; }
.grain::after {
  content: ''; position: absolute; inset: 0; pointer-events: none; opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 256px 256px;
}
.grain--dark::after { opacity: 0.06; }

/* shared bracket marker — used as section labels everywhere */
.b-marker { display: inline-flex; align-items: baseline; gap: 6px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-2); }
.b-marker__br { color: var(--terra); }
.b-marker--inv { color: var(--fg-inv-2); }
.b-marker--inv .b-marker__br { color: var(--amber); }
.b-marker--amber .b-marker__br { color: var(--amber); }

/* shared container */
.wrap { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }

/* ============== STATUS BAR ============== */
.statusbar {
  position: sticky; top: 0; z-index: 50;
  background: rgba(15,17,23,0.96); color: var(--fg-inv);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.06em;
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
}
.statusbar__inner { display: flex; align-items: center; gap: 20px; max-width: var(--max); margin: 0 auto; padding: 9px var(--pad); }
.statusbar__live { display: inline-flex; align-items: center; gap: 8px; color: var(--amber); font-weight: 500; text-transform: uppercase; flex-shrink: 0; }
.statusbar__dot { width: 6px; height: 6px; border-radius: 50%; background: var(--amber); animation: pulse 1.6s ease-in-out infinite; }
.statusbar__msg { color: rgba(245,240,232,0.85); flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.statusbar__msg b { color: var(--fg-inv); font-weight: 500; }
.statusbar__meta { color: var(--fg-inv-3); flex-shrink: 0; }
@keyframes pulse { 0%,100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.4; transform: scale(0.75); } }

/* ============== SHARED PAGE LAYOUTS (subpages) ============== */
.page-hero {
  padding: 96px var(--pad) 64px; max-width: var(--max); margin: 0 auto;
  position: relative;
}
.page-hero__crumb {
  display: inline-flex; gap: 8px; align-items: baseline;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--fg-3); margin-bottom: 24px;
}
.page-hero__crumb a { color: var(--fg-3); transition: color .2s; }
.page-hero__crumb a:hover { color: var(--terra); }
.page-hero__crumb b { color: var(--fg); font-weight: 500; }
.page-hero__crumb-sep { color: var(--border-c2); }

.page-hero__title {
  font-family: var(--display); font-weight: 300;
  font-size: clamp(40px, 6.4vw, 96px);
  line-height: 1.0; letter-spacing: -0.035em; color: var(--fg);
  max-width: 1100px;
}
.page-hero__title em {
  font-style: normal; font-family: var(--display); font-weight: 400;
  color: var(--terra);
}
.page-hero__title em.amber { color: var(--amber-hover); }
.page-hero__lead {
  font-family: var(--serif); font-style: italic;
  font-size: clamp(16px, 1.7vw, 19px); line-height: 1.55; color: var(--fg-2);
  max-width: 720px; margin-top: 24px;
}
.page-hero__meta {
  display: flex; flex-wrap: wrap; gap: 28px;
  padding-top: 28px; margin-top: 32px;
  border-top: 1px solid var(--border-c);
}
.page-hero__meta-item {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em;
  color: var(--fg-2); display: inline-flex; align-items: baseline; gap: 8px;
}
.page-hero__meta-item b { color: var(--terra); font-weight: 500; }
.page-hero__cta-row {
  display: flex; gap: 14px; align-items: center; flex-wrap: wrap;
  margin-top: 32px;
}

.page-section { padding: 80px var(--pad); max-width: var(--max); margin: 0 auto; }
.page-section--dark { background: var(--ink); color: var(--fg-inv); max-width: none; padding-left: 0; padding-right: 0; }
.page-section--dark .page-section__wrap { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }
.page-section--cream { background: var(--cream-2); max-width: none; padding-left: 0; padding-right: 0; }
.page-section--cream .page-section__wrap { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }

.page-section__head { display: flex; flex-direction: column; gap: 14px; margin-bottom: 48px; max-width: 720px; }
.page-section__title {
  font-family: var(--display); font-weight: 400;
  font-size: clamp(28px, 4vw, 52px); line-height: 1.1; letter-spacing: -0.025em;
  color: var(--fg);
}
.page-section--dark .page-section__title { color: var(--fg-inv); }
.page-section__title em { font-style: normal; font-family: var(--serif); font-weight: 500; color: var(--terra); }
.page-section--dark .page-section__title em { color: var(--amber); }
.page-section__lead {
  font-family: var(--serif); font-style: italic; font-size: 16px; line-height: 1.55;
  color: var(--fg-2);
}
.page-section--dark .page-section__lead { color: var(--fg-inv-2); }

/* shared dense-card grid for feature lists */
.feat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.feat-grid--2 { grid-template-columns: repeat(2, 1fr); }
.feat-grid--4 { grid-template-columns: repeat(4, 1fr); }
.feat-card {
  background: var(--paper); border: 1px solid var(--border-c); border-radius: 16px;
  padding: 26px 24px; transition: transform .3s, box-shadow .3s, border-color .3s;
}
.feat-card:hover { transform: translateY(-3px); border-color: rgba(196,98,42,0.35); box-shadow: 0 14px 32px -12px rgba(0,0,0,0.08); }
.feat-card--dark { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); }
.feat-card--dark:hover { background: rgba(245,158,11,0.04); border-color: rgba(245,158,11,0.25); }
.feat-card__num {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 28px; height: 28px; padding: 0 8px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; font-weight: 500;
  color: var(--terra); background: rgba(196,98,42,0.10); border-radius: 100px;
  margin-bottom: 16px;
}
.feat-card--dark .feat-card__num { color: var(--amber); background: rgba(245,158,11,0.12); }
.feat-card__title {
  font-family: var(--display); font-weight: 500; font-size: 19px; line-height: 1.2;
  letter-spacing: -0.015em; color: var(--fg); margin-bottom: 8px;
}
.feat-card--dark .feat-card__title { color: var(--fg-inv); }
.feat-card__desc {
  font-family: var(--sans); font-size: 14px; line-height: 1.55; color: var(--fg-2);
}
.feat-card--dark .feat-card__desc { color: var(--fg-inv-2); }

@media (max-width: 1024px) { .feat-grid, .feat-grid--4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .feat-grid, .feat-grid--2, .feat-grid--4 { grid-template-columns: 1fr; } }

/* ============== PROCESS TIMELINE (reused on multiple pages) ============== */
.timeline { max-width: 900px; margin: 0 auto; display: flex; flex-direction: column; }
.timeline__step {
  display: grid; grid-template-columns: 90px 1fr; gap: 32px;
  padding: 28px 0; border-top: 1px solid var(--border-c);
}
.timeline__step:last-child { border-bottom: 1px solid var(--border-c); }
.timeline__step-num {
  font-family: var(--display); font-weight: 200; font-size: 64px;
  line-height: 1; letter-spacing: -0.04em; color: var(--terra);
}
.timeline__step-week {
  display: inline-block;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--fg-3); margin-bottom: 10px;
}
.timeline__step-title {
  font-family: var(--display); font-weight: 500; font-size: 24px;
  line-height: 1.15; letter-spacing: -0.015em; color: var(--fg);
  margin-bottom: 10px;
}
.timeline__step-desc {
  font-family: var(--sans); font-size: 15px; line-height: 1.6; color: var(--fg-2);
}
@media (max-width: 640px) {
  .timeline__step { grid-template-columns: 60px 1fr; gap: 18px; }
  .timeline__step-num { font-size: 48px; }
}

/* ============== PRICING (3 tiers, reusable) ============== */
.pricing { max-width: 1080px; margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.pricing__card {
  position: relative;
  background: var(--paper); border: 1px solid var(--border-c); border-radius: 18px;
  padding: 32px 28px; display: flex; flex-direction: column;
  transition: transform .3s, box-shadow .3s, border-color .3s;
}
.pricing__card--popular { border-color: var(--amber); box-shadow: 0 16px 48px -20px rgba(245,158,11,0.35); }
.pricing__card:hover { transform: translateY(-3px); box-shadow: 0 18px 40px -16px rgba(0,0,0,0.08); }
.pricing__badge {
  position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase;
  background: var(--amber); color: var(--ink); padding: 5px 14px; border-radius: 100px;
}
.pricing__name {
  font-family: var(--display); font-weight: 500; font-size: 22px;
  letter-spacing: -0.015em; color: var(--fg); margin-bottom: 14px;
}
.pricing__price { display: flex; align-items: baseline; gap: 6px; margin-bottom: 24px; }
.pricing__amount {
  font-family: var(--display); font-weight: 300; font-size: 56px; line-height: 1;
  letter-spacing: -0.035em; color: var(--fg);
}
.pricing__currency { font-family: var(--sans); font-size: 15px; color: var(--fg-2); }
.pricing__features { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.pricing__features li {
  font-family: var(--sans); font-size: 14.5px; line-height: 1.4; color: var(--fg);
  padding-left: 22px; position: relative;
}
.pricing__features li::before {
  content: ''; position: absolute; left: 0; top: 8px;
  width: 8px; height: 8px; border-radius: 50%; background: rgba(245,158,11,0.35);
}
.pricing__card--popular .pricing__features li::before { background: var(--amber); }
.pricing__cta {
  margin-top: 22px; width: 100%; justify-content: center;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 14px 22px; border-radius: 12px; cursor: pointer; border: 0;
  transition: background .2s, transform .2s;
}
.pricing__cta--primary { background: var(--amber); color: var(--ink); }
.pricing__cta--primary:hover { background: var(--amber-hover); transform: translateY(-1px); }
.pricing__cta--ghost { background: transparent; color: var(--fg); border: 1px solid var(--border-c2); }
.pricing__cta--ghost:hover { background: var(--cream-2); }

@media (max-width: 900px) { .pricing { grid-template-columns: 1fr; max-width: 460px; } }

/* ============== COMPARE TABLE (2 columns) ============== */
.compare {
  max-width: 1000px; margin: 0 auto; border: 1px solid var(--border-c);
  border-radius: 18px; overflow: hidden; background: var(--paper);
}
.compare__head, .compare__row { display: grid; grid-template-columns: 1fr 1fr; }
.compare__head-cell {
  padding: 16px 20px; font-family: var(--display); font-weight: 500;
  font-size: 15px; letter-spacing: -0.005em;
}
.compare__head-cell--old { background: var(--ink); color: rgba(255,255,255,0.72); }
.compare__head-cell--new { background: var(--terra); color: #fff; }
.compare__row { border-top: 1px solid var(--border-c); }
.compare__cell {
  padding: 13px 20px; font-family: var(--sans); font-size: 14px; line-height: 1.5;
  display: flex; gap: 10px; align-items: center;
}
.compare__cell--old { color: #b94740; }
.compare__cell--new { color: #2d8a6e; font-weight: 500; background: rgba(245,158,11,0.02); }
.compare__icon { flex-shrink: 0; font-family: var(--sans); font-weight: 600; }

@media (max-width: 640px) {
  .compare__head, .compare__row { grid-template-columns: 1fr; }
  .compare__cell--old { padding-bottom: 4px; }
  .compare__cell--new { padding-top: 4px; }
}

/* ============== FAQ / ACCORDION ============== */
.faq { max-width: 800px; margin: 0 auto; }
.faq__item { border-bottom: 1px solid var(--border-c); padding: 22px 0; cursor: pointer; }
.faq__item:first-child { border-top: 1px solid var(--border-c); }
.faq__q {
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  font-family: var(--display); font-weight: 500; font-size: 19px;
  letter-spacing: -0.01em; color: var(--fg); line-height: 1.3;
}
.faq__icon {
  flex-shrink: 0; width: 24px; height: 24px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--cream-2); color: var(--terra);
  font-family: var(--sans); font-weight: 500;
  transition: transform .3s, background .25s;
}
.faq__item.is-open .faq__icon { background: var(--terra); color: var(--cream); transform: rotate(45deg); }
.faq__a {
  max-height: 0; overflow: hidden;
  transition: max-height .35s cubic-bezier(.2,.8,.2,1);
}
.faq__item.is-open .faq__a { max-height: 400px; }
.faq__a p {
  font-family: var(--sans); font-size: 15px; line-height: 1.7; color: var(--fg-2);
  padding-top: 16px;
}

/* ============== CONTACT FORM ============== */
.contact-form {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
  max-width: 740px; margin: 0 auto;
}
.contact-form__field { display: flex; flex-direction: column; gap: 6px; }
.contact-form__field--wide { grid-column: 1 / -1; }
.contact-form__label {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--fg-3);
}
.contact-form__input, .contact-form__textarea {
  font-family: var(--sans); font-size: 15px; color: var(--fg);
  background: var(--paper); border: 1px solid var(--border-c2); border-radius: 12px;
  padding: 14px 16px; outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.contact-form__input:focus, .contact-form__textarea:focus {
  border-color: var(--terra); box-shadow: 0 0 0 3px rgba(196,98,42,0.12);
}
.contact-form__textarea { min-height: 140px; resize: vertical; }
.contact-form__submit {
  grid-column: 1 / -1;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
  background: var(--fg); color: var(--cream);
  padding: 16px 28px; border-radius: 100px; cursor: pointer; border: 0;
  transition: background .2s, transform .2s, box-shadow .25s;
  justify-self: start;
}
.contact-form__submit:hover { background: var(--terra); transform: translateY(-2px); box-shadow: 0 12px 28px -10px rgba(196,98,42,0.4); }

@media (max-width: 640px) {
  .contact-form { grid-template-columns: 1fr; }
}

/* ============== PROJECT GRID (projets page) ============== */
.proj-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px;
  max-width: var(--max); margin: 0 auto;
}
.proj-tile {
  background: var(--paper); border: 1px solid var(--border-c); border-radius: 22px;
  padding: 28px; cursor: pointer;
  transition: transform .3s, box-shadow .3s, border-color .3s;
  display: flex; flex-direction: column; gap: 16px;
}
.proj-tile:hover { transform: translateY(-4px); border-color: rgba(196,98,42,0.35); box-shadow: 0 18px 44px -18px rgba(0,0,0,0.1); }
.proj-tile__industry {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--terra);
}
.proj-tile__name {
  font-family: var(--display); font-weight: 500; font-size: clamp(28px, 3vw, 40px);
  line-height: 1; letter-spacing: -0.02em; color: var(--fg);
}
.proj-tile__desc {
  font-family: var(--serif); font-style: italic; font-size: 16px; line-height: 1.55;
  color: var(--fg-2); max-width: 480px;
}
.proj-tile__tags { display: flex; gap: 8px; flex-wrap: wrap; }
.proj-tile__tag {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.06em;
  padding: 5px 10px; background: var(--cream-2); border-radius: 100px; color: var(--fg-2);
}
.proj-tile__cta {
  margin-top: auto; font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--terra);
}

@media (max-width: 720px) { .proj-grid { grid-template-columns: 1fr; } }

/* ============== LEGAL / TEXT-HEAVY ============== */
.legal { max-width: 760px; margin: 0 auto; padding: 0 var(--pad); }
.legal h2 {
  font-family: var(--display); font-weight: 500; font-size: 26px;
  letter-spacing: -0.015em; color: var(--fg);
  margin: 48px 0 16px;
}
.legal h3 {
  font-family: var(--display); font-weight: 500; font-size: 19px;
  color: var(--fg); margin: 28px 0 10px;
}
.legal p, .legal li {
  font-family: var(--sans); font-size: 15px; line-height: 1.75; color: var(--fg-2);
  margin-bottom: 14px;
}
.legal ul { padding-left: 22px; margin-bottom: 14px; }
.legal a { color: var(--terra); text-decoration: underline; text-underline-offset: 3px; }
.legal a:hover { color: var(--terra-hover); }
.legal__meta {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--fg-3); padding-bottom: 28px; border-bottom: 1px solid var(--border-c); margin-bottom: 32px;
}
.bnav {
  position: sticky; top: 0; z-index: 60;
  background: rgba(245, 240, 232, 0.0);
  backdrop-filter: blur(0px); -webkit-backdrop-filter: blur(0px);
  transition: background-color .3s, backdrop-filter .3s, border-color .3s, box-shadow .3s;
  border-bottom: 1px solid transparent;
}
.bnav.is-scrolled {
  background: rgba(245, 240, 232, 0.86);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-bottom-color: var(--border-c);
}
.bnav__inner {
  max-width: var(--max); margin: 0 auto;
  padding: 18px var(--pad);
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
}
.bnav__logo {
  display: inline-flex; align-items: center; padding: 0;
  background: none; border: 0; cursor: pointer;
}
.bnav__links { display: flex; gap: 30px; align-items: center; }
.bnav__link {
  font-family: var(--mono); font-size: 13.5px; letter-spacing: 0.07em; text-transform: uppercase;
  color: var(--fg-2); transition: color .2s; cursor: pointer; position: relative;
  padding: 8px 2px; background: none; border: 0;
}
.bnav__link::after {
  content: ''; position: absolute; bottom: 2px; left: 2px; right: 2px;
  height: 1.5px; background: var(--terra); border-radius: 2px;
  transform: scaleX(0); transform-origin: left; transition: transform .3s cubic-bezier(.2,.8,.2,1);
}
.bnav__link:hover { color: var(--fg); }
.bnav__link:hover::after { transform: scaleX(0.5); }
.bnav__link.is-active { color: var(--fg); }
.bnav__link.is-active::after { transform: scaleX(1); }

.bnav__actions { display: flex; gap: 12px; align-items: center; }
.bnav__cta {
  font-family: var(--mono); font-size: 13.5px; letter-spacing: 0.07em; text-transform: uppercase;
  padding: 11px 20px; border: 1px solid var(--fg); border-radius: 100px;
  display: inline-flex; align-items: center; gap: 8px;
  cursor: pointer; transition: background .2s, color .2s, transform .2s, box-shadow .25s;
  background: transparent; color: var(--fg);
}
.bnav__cta > span { display: inline-flex; align-items: center; line-height: 1; }
.bnav__cta svg, .bnav__cta__arrow { display: block; flex-shrink: 0; }
.bnav__cta:hover {
  background: var(--fg); color: var(--cream);
  transform: translateY(-1px); box-shadow: 0 8px 24px -10px rgba(15,17,23,0.4);
}

.bnav__burger {
  display: none;
  width: 36px; height: 36px; padding: 0;
  background: transparent; border: 1px solid var(--border-c2); border-radius: 50%;
  flex-direction: column; align-items: center; justify-content: center; gap: 4px;
  cursor: pointer;
}
.bnav__burger span {
  display: block; width: 14px; height: 1.5px; background: var(--fg);
  transition: transform .3s, opacity .3s;
}
.bnav__burger.is-open span:nth-child(1) { transform: translateY(5.5px) rotate(45deg); }
.bnav__burger.is-open span:nth-child(2) { opacity: 0; }
.bnav__burger.is-open span:nth-child(3) { transform: translateY(-5.5px) rotate(-45deg); }

.bnav-drawer {
  position: fixed; top: 0; right: 0; bottom: 0; width: min(86vw, 360px);
  background: var(--ink); color: var(--fg-inv); z-index: 55;
  transform: translateX(100%); transition: transform .35s cubic-bezier(.2,.8,.2,1);
  padding: 88px 32px 32px;
}
.bnav-drawer.is-open { transform: translateX(0); }
.bnav-drawer__nav { display: flex; flex-direction: column; gap: 6px; }
.bnav-drawer__link {
  text-align: left; padding: 14px 0; background: none; border: 0;
  font-family: var(--display); font-weight: 400; font-size: 24px;
  color: var(--cream); cursor: pointer; border-bottom: 1px solid rgba(245,240,232,0.08);
  transition: color .2s, padding-left .25s;
}
.bnav-drawer__link:hover { color: var(--amber); padding-left: 6px; }
.bnav-drawer__link.is-active { color: var(--amber); }
.bnav-drawer__cta {
  margin-top: 24px;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 14px 22px; background: var(--amber); color: var(--ink);
  border-radius: 100px; cursor: pointer; border: 0;
  transition: background .2s, transform .2s;
}
.bnav-drawer__cta:hover { background: var(--amber-hover); transform: translateY(-1px); }

@media (max-width: 880px) {
  .bnav__links { display: none; }
  .bnav__cta   { display: none; }
  .bnav__burger { display: inline-flex; }
}

/* Back-to-top floating button */
.totop {
  position: fixed; right: 22px; bottom: 22px; z-index: 40;
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--fg); color: var(--cream);
  display: flex; align-items: center; justify-content: center;
  border: 0; cursor: pointer; opacity: 0; pointer-events: none;
  transform: translateY(8px);
  transition: opacity .3s, transform .3s, background .2s;
  box-shadow: 0 12px 32px -10px rgba(15,17,23,0.45);
}
.totop.is-shown { opacity: 1; pointer-events: auto; transform: translateY(0); }
.totop:hover { background: var(--terra); }

/* ============== HERO ============== */
.hero { padding: 40px var(--pad) 80px; max-width: var(--max); margin: 0 auto; position: relative; }
.hero__index { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-3); display: flex; gap: 18px; align-items: baseline; flex-wrap: wrap; padding-bottom: 22px; border-bottom: 1px solid var(--border-c); margin-bottom: 36px; }
.hero__index span:first-child { color: var(--terra); font-weight: 500; }

.hero__title { font-family: var(--display); font-weight: 300; font-size: clamp(40px, 6.4vw, 96px); line-height: 1.0; letter-spacing: -0.035em; color: var(--fg); max-width: 1100px; }
.hero__title-line { display: block; }
.hero__title-line + .hero__title-line { margin-top: 4px; }
.hero__title .accent { font-weight: 400; position: relative; display: inline-block; }
.hero__title .accent::after { display: none; }
.hero__title .accent--terra { color: var(--terra); }
.hero__title .accent--amber { color: var(--amber-hover); }
.hero__title .bracketed { color: var(--terra); display: inline-block; font-weight: 200; font-family: var(--mono); }
.hero__title .bracketed--amber { color: var(--amber-hover); }

.hero__sub { font-family: var(--serif); font-style: italic; font-size: clamp(16px, 1.7vw, 19px); line-height: 1.5; color: var(--fg-2); max-width: 720px; margin-top: 28px; }

/* split, two cards under the title showing both services */
.hero__split { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 44px; }
.hero-card-wrap { display: flex; flex-direction: column; gap: 12px; }
.hero-card-overlabel {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--terra);
}
.hero-card-overlabel--amber { color: var(--amber-hover); }
.hero-card {
  background: var(--paper); border: 1px solid var(--border-c); border-radius: 18px;
  overflow: hidden; display: flex; flex-direction: column;
  transition: transform .3s, box-shadow .3s, border-color .3s;
}
.hero-card:hover { transform: translateY(-2px); box-shadow: 0 18px 50px -16px rgba(0,0,0,0.10); }
.hero-card--tool:hover  { border-color: rgba(196,98,42,0.35); }
.hero-card--agent:hover { border-color: rgba(245,158,11,0.40); }

.hero-card__head {
  display: flex; align-items: center; gap: 12px; padding: 14px 18px;
  border-bottom: 1px solid var(--border-c); background: var(--cream-2);
}
.hero-card__dots { display: inline-flex; gap: 6px; flex-shrink: 0; }
.hero-card__dots span { width: 9px; height: 9px; border-radius: 50%; background: rgba(0,0,0,0.18); }
.hero-card__dots span:nth-child(1) { background: rgba(196,98,42,0.55); }
.hero-card__dots span:nth-child(2) { background: rgba(245,158,11,0.55); }
.hero-card__dots span:nth-child(3) { background: rgba(45,138,110,0.55); }
.hero-card__file { font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.04em; color: var(--fg-2); flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.hero-card__avatar { width: 32px; height: 32px; border-radius: 50%; background: var(--amber); color: var(--ink); display: flex; align-items: center; justify-content: center; font-family: var(--display); font-weight: 600; font-size: 14px; flex-shrink: 0; overflow: hidden; box-shadow: 0 0 0 2px rgba(245,158,11,0.4), 0 4px 10px -2px rgba(245,158,11,0.3); }
.hero-card__avatar img { width: 100%; height: 100%; display: block; }
/* SaaS product preview v2 (browser chrome + sidebar + dashboard) */
.hero-card--tool { background: #fbf9f4; }
.saas2__chrome { display: flex; align-items: center; gap: 12px; padding: 11px 14px; background: linear-gradient(to bottom, #ebe4d6, #e2dac8); border-bottom: 1px solid var(--border-c); }
.saas2__chrome-dots { display: inline-flex; gap: 6px; flex-shrink: 0; }
.saas2__chrome-dots span { width: 10px; height: 10px; border-radius: 50%; background: rgba(0,0,0,0.18); }
.saas2__chrome-dots span:nth-child(1) { background: #e06c5d; }
.saas2__chrome-dots span:nth-child(2) { background: #e8b04e; }
.saas2__chrome-dots span:nth-child(3) { background: #6abf6a; }
.saas2__chrome-url { display: inline-flex; align-items: center; gap: 6px; flex: 1; min-width: 0; background: rgba(255,255,255,0.85); border: 1px solid var(--border-c); border-radius: 100px; padding: 4px 14px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.03em; color: var(--fg-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.saas2__chrome-url svg { color: #2d8a6e; flex-shrink: 0; }

.saas2__body { display: grid; grid-template-columns: 48px 1fr; min-height: 320px; }

.saas2__sidebar { background: var(--ink); padding: 14px 0; display: flex; flex-direction: column; gap: 14px; align-items: center; border-right: 1px solid var(--border-c); }
.saas2__sidebar-logo { width: 28px; height: 28px; border-radius: 8px; background: var(--terra); color: #fff; font-family: var(--display); font-weight: 600; font-size: 11px; letter-spacing: -0.02em; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 10px -3px rgba(196,98,42,0.6); }
.saas2__nav { display: flex; flex-direction: column; gap: 4px; padding-top: 6px; border-top: 1px solid rgba(255,255,255,0.08); width: 32px; align-items: center; padding-top: 14px; }
.saas2__nav-item { width: 28px; height: 28px; border-radius: 7px; display: flex; align-items: center; justify-content: center; color: rgba(245,240,232,0.45); cursor: pointer; transition: background .2s, color .2s; }
.saas2__nav-item:hover { background: rgba(255,255,255,0.05); color: var(--cream); }
.saas2__nav-item--active { background: rgba(245,158,11,0.18); color: var(--amber); box-shadow: inset 0 0 0 1px rgba(245,158,11,0.3); }

.saas2__main { padding: 14px 16px 16px; display: flex; flex-direction: column; gap: 12px; background: #fbf9f4; }
.saas2__main-head { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.saas2__crumb { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.04em; color: var(--fg-3); }
.saas2__crumb--strong { color: var(--fg); font-weight: 500; }
.saas2__main-pills { display: inline-flex; gap: 4px; background: var(--cream-2); padding: 3px; border-radius: 100px; }
.saas2__pill { font-family: var(--mono); font-size: 10px; letter-spacing: 0.04em; padding: 4px 10px; border-radius: 100px; color: var(--fg-3); cursor: pointer; }
.saas2__pill--active { background: var(--fg); color: var(--cream); }

.saas2__kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.saas2__kpi { background: #fff; border: 1px solid var(--border-c); border-radius: 10px; padding: 9px 11px; display: flex; flex-direction: column; gap: 2px; }
.saas2__kpi-lbl { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-3); }
.saas2__kpi-val { font-family: var(--display); font-weight: 500; font-size: 17px; letter-spacing: -0.015em; line-height: 1.05; color: var(--fg); }
.saas2__kpi-trend { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.04em; }
.saas2__kpi-trend--up { color: #2d8a6e; }

.saas2__chart { background: #fff; border: 1px solid var(--border-c); border-radius: 10px; padding: 10px 12px; display: flex; flex-direction: column; gap: 6px; }
.saas2__chart-head { display: flex; justify-content: space-between; align-items: baseline; font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.04em; color: var(--fg); }
.saas2__chart-meta { color: var(--fg-3); font-size: 9.5px; }
.saas2__chart svg { width: 100%; height: 72px; display: block; }

.saas2__rows { background: #fff; border: 1px solid var(--border-c); border-radius: 10px; padding: 10px 12px; }
.saas2__rows-head { display: flex; justify-content: space-between; align-items: baseline; font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.04em; color: var(--fg); padding-bottom: 6px; border-bottom: 1px dashed var(--border-c); margin-bottom: 4px; }
.saas2__rows-meta { color: var(--fg-3); font-size: 9.5px; }
.saas2__rows ul { list-style: none; padding: 0; margin: 0; }
.saas2__row { display: grid; grid-template-columns: 8px 1fr auto auto; gap: 8px; align-items: center; padding: 6px 0; font-family: var(--sans); font-size: 11.5px; border-bottom: 1px dashed var(--border-c); }
.saas2__row:last-child { border-bottom: 0; }
.saas2__row-dot { width: 6px; height: 6px; border-radius: 50%; }
.saas2__row-name { color: var(--fg); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.saas2__row-meta { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.04em; color: var(--fg-2); }
.saas2__row-time { font-family: var(--mono); font-size: 9.5px; color: var(--fg-3); }

/* ═══════ CRM Dashboard preview inside hero card ═══════ */
.crm__body { display: grid; grid-template-columns: 160px 1fr; min-height: 380px; position: relative; }

/* -- Sidebar -- */
.crm__sidebar { background: #1a2332; display: flex; flex-direction: column; justify-content: space-between; border-right: 1px solid rgba(255,255,255,0.06); overflow: hidden; }
.crm__sidebar-inner { padding: 10px 0; display: flex; flex-direction: column; gap: 2px; overflow-y: auto; }
.crm__section { padding: 0 8px; }
.crm__section-head { display: flex; align-items: center; justify-content: space-between; padding: 6px 8px; font-family: var(--mono); font-size: 8.5px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.35); margin-top: 4px; }
.crm__section-head svg { opacity: 0.4; }
.crm__nav { display: flex; flex-direction: column; gap: 1px; }
.crm__nav-item { display: flex; align-items: center; gap: 7px; padding: 5px 8px; border-radius: 6px; font-family: var(--sans); font-size: 10.5px; color: rgba(255,255,255,0.6); cursor: pointer; text-decoration: none; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; transition: background .15s, color .15s; }
.crm__nav-item:hover { background: rgba(255,255,255,0.05); color: rgba(255,255,255,0.85); }
.crm__nav-item--active { background: #2563eb; color: #fff; font-weight: 500; }
.crm__nav-item svg { flex-shrink: 0; opacity: 0.7; }
.crm__nav-item--active svg { opacity: 1; }
.crm__badge { margin-left: auto; background: rgba(255,255,255,0.12); color: rgba(255,255,255,0.7); font-family: var(--mono); font-size: 9px; padding: 1px 6px; border-radius: 100px; font-weight: 500; }
.crm__sidebar-footer { padding: 6px 8px; border-top: 1px solid rgba(255,255,255,0.06); }
.crm__user { display: flex; align-items: center; gap: 6px; padding: 4px; }
.crm__user-avatar { width: 24px; height: 24px; border-radius: 6px; background: #374151; color: rgba(255,255,255,0.6); font-family: var(--mono); font-size: 9px; font-weight: 600; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.crm__user-info { display: flex; flex-direction: column; min-width: 0; flex: 1; }
.crm__user-name { font-family: var(--sans); font-size: 10px; font-weight: 500; color: rgba(255,255,255,0.75); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.crm__user-email { font-family: var(--mono); font-size: 8.5px; color: rgba(255,255,255,0.35); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* -- Main content -- */
.crm__main { padding: 16px 18px; display: flex; flex-direction: column; gap: 14px; background: #f8f9fb; overflow: hidden; }
.crm__main-header { display: flex; flex-direction: column; gap: 2px; }
.crm__title { font-family: var(--display); font-weight: 600; font-size: 16px; letter-spacing: -0.01em; color: #111827; margin: 0; }
.crm__subtitle { font-family: var(--sans); font-size: 10.5px; color: #6b7280; margin: 0; }

/* KPI cards */
.crm__kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.crm__kpi-card { background: #fff; border: 1px solid #e5e7eb; border-radius: 10px; padding: 12px 10px; display: flex; align-items: flex-start; gap: 8px; }
.crm__kpi-icon { width: 28px; height: 28px; border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.crm__kpi-icon--blue { background: #eff6ff; color: #3b82f6; }
.crm__kpi-icon--teal { background: #ecfdf5; color: #10b981; }
.crm__kpi-icon--amber { background: #fffbeb; color: #f59e0b; }
.crm__kpi-icon svg { width: 15px; height: 15px; }
.crm__kpi-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.crm__kpi-label { font-family: var(--sans); font-size: 9.5px; color: #6b7280; white-space: nowrap; }
.crm__kpi-value { font-family: var(--display); font-weight: 600; font-size: 18px; letter-spacing: -0.02em; color: #111827; line-height: 1.1; }
.crm__kpi-sub { font-size: 11px; font-weight: 400; color: #9ca3af; }

/* Funnel */
.crm__funnel { background: #fff; border: 1px solid #e5e7eb; border-radius: 10px; padding: 12px 14px; }
.crm__funnel-title { font-family: var(--display); font-weight: 600; font-size: 13px; color: #111827; margin: 0 0 10px; }
.crm__funnel-rows { display: flex; flex-direction: column; gap: 6px; }
.crm__funnel-row { display: grid; grid-template-columns: 80px 1fr; gap: 8px; align-items: center; }
.crm__funnel-label { font-family: var(--sans); font-size: 10px; color: #6b7280; text-align: right; white-space: nowrap; }
.crm__funnel-bar-wrap { position: relative; height: 22px; background: #f3f4f6; border-radius: 6px; overflow: hidden; }
.crm__funnel-bar { height: 100%; border-radius: 6px; display: flex; align-items: center; padding-left: 8px; min-width: 28px; }
.crm__funnel-bar--teal { background: linear-gradient(90deg, #06b6d4, #22d3ee); }
.crm__funnel-bar--green { background: linear-gradient(90deg, #10b981, #34d399); }
.crm__funnel-count { font-family: var(--mono); font-size: 10px; font-weight: 600; color: #fff; }
.crm__funnel-count--empty { color: #9ca3af; font-family: var(--mono); font-size: 10px; font-weight: 600; background: #e5e7eb; width: 22px; height: 22px; border-radius: 6px; display: inline-flex; align-items: center; justify-content: center; }
.crm__funnel-count--red { background: #fecaca; color: #ef4444; }
.crm__funnel-count--green { background: #d1fae5; color: #059669; }

/* -- Chat widget overlay -- */
.crm__chat-widget { position: absolute; bottom: 8px; right: 8px; width: 200px; background: #fff; border-radius: 12px; box-shadow: 0 8px 30px -6px rgba(0,0,0,0.2), 0 0 0 1px rgba(0,0,0,0.06); display: flex; flex-direction: column; overflow: hidden; z-index: 5; }
.crm__chat-header { display: flex; align-items: center; gap: 6px; padding: 7px 10px; background: #f59e0b; color: #fff; }
.crm__chat-icon { display: flex; align-items: center; }
.crm__chat-label { font-family: var(--display); font-weight: 600; font-size: 12px; flex: 1; }
.crm__chat-actions { display: flex; align-items: center; gap: 6px; opacity: 0.7; }
.crm__chat-body { padding: 8px 10px; max-height: 140px; overflow: hidden; font-family: var(--sans); font-size: 9px; line-height: 1.4; color: #374151; }
.crm__chat-msg-title { font-weight: 600; color: #111827; margin: 0 0 2px; font-size: 9.5px; }
.crm__chat-msg p { margin: 2px 0; }
.crm__chat-quote { font-style: italic; color: #6b7280; border-left: 2px solid #d1d5db; padding-left: 6px; margin: 4px 0; }
.crm__chat-list { margin: 3px 0; padding-left: 14px; }
.crm__chat-list li { margin: 1px 0; }
.crm__chat-input { display: flex; align-items: center; gap: 6px; padding: 6px 8px; border-top: 1px solid #e5e7eb; }
.crm__chat-placeholder { font-family: var(--sans); font-size: 9px; color: #9ca3af; flex: 1; }
.crm__chat-send { width: 22px; height: 22px; border-radius: 6px; background: #f59e0b; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.crm__chat-powered { font-family: var(--mono); font-size: 7.5px; color: #9ca3af; text-align: center; padding: 3px 0 5px; letter-spacing: 0.04em; }

/* Responsive: hide sidebar on small screens */
@media (max-width: 600px) {
  .crm__body { grid-template-columns: 1fr; }
  .crm__sidebar { display: none; }
  .crm__chat-widget { width: 170px; }
  .crm__kpis { grid-template-columns: 1fr; }
}

/* SaaS dashboard preview inside hero card */
.hero-card__body--saas { padding: 16px 18px; display: flex; flex-direction: column; gap: 14px; background: var(--paper); }
.saas__kpis { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.saas__kpi { background: var(--cream-2); border-radius: 12px; padding: 10px 12px; display: flex; flex-direction: column; gap: 2px; }
.saas__kpi-lbl { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-3); }
.saas__kpi-val { font-family: var(--display); font-weight: 500; font-size: 18px; letter-spacing: -0.015em; color: var(--fg); line-height: 1.1; }
.saas__kpi-trend { font-family: var(--mono); font-size: 10px; letter-spacing: 0.04em; color: #2d8a6e; }
.saas__kpi-trend--up { color: #2d8a6e; }
.saas__chart { height: 64px; background: var(--cream-2); border-radius: 12px; padding: 8px; }
.saas__chart svg { width: 100%; height: 100%; display: block; }
.saas__rows { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 2px; }
.saas__row { display: grid; grid-template-columns: 10px 1fr auto auto; gap: 10px; align-items: center; padding: 7px 4px; font-family: var(--sans); font-size: 12.5px; border-bottom: 1px dashed var(--border-c); }
.saas__row:last-child { border-bottom: 0; }
.saas__row-dot { width: 6px; height: 6px; border-radius: 50%; }
.saas__row-name { color: var(--fg); }
.saas__row-meta { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.04em; color: var(--fg-2); }
.saas__row-time { font-family: var(--mono); font-size: 10.5px; color: var(--fg-3); }
.hero-card__name { font-family: var(--display); font-weight: 500; font-size: 14px; letter-spacing: -0.01em; line-height: 1; }
.hero-card__role { font-family: var(--mono); font-size: 10px; letter-spacing: 0.06em; color: var(--fg-3); text-transform: uppercase; margin-top: 3px; }
.hero-card__head > div { flex: 1; min-width: 0; }
.hero-card__badge { font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; padding: 4px 10px; border-radius: 100px; flex-shrink: 0; }
.hero-card__badge--terra { color: var(--terra); background: rgba(196,98,42,0.10); }
.hero-card__badge--amber { color: var(--amber-hover); background: rgba(245,158,11,0.12); }

.hero-card__body { padding: 18px 20px; flex: 1; min-height: 200px; position: relative; }
.hero-card__body--code { background: #fbf9f4; font-family: var(--mono); font-size: 12.5px; line-height: 1.7; color: var(--fg); overflow: hidden; }
.hero-card__body--code pre { white-space: pre-wrap; word-break: break-word; margin: 0; font-family: inherit; }
.hero-card__body--code .ln { display: inline-block; width: 22px; color: var(--fg-3); user-select: none; margin-right: 6px; }
.hero-card__body--code .c-key  { color: #c4622a; font-weight: 500; }
.hero-card__body--code .c-str  { color: #2d8a6e; }
.hero-card__body--code .c-tag  { color: #3b6cf5; }
.hero-card__body--code .c-attr { color: #a84e33; }
.hero-card__body--code .c-fn   { color: #1a1a1a; font-weight: 600; }
.hero-card__body--code .c-id   { color: #1a1a1a; }
.hero-card__caret {
  position: absolute; width: 7px; height: 16px; background: var(--terra);
  /* place right after the closing brace on line 10 */
  bottom: 22px; left: 64px;
  animation: caret-blink 1s steps(2) infinite;
}
@keyframes caret-blink { 0%,50% { opacity: 1; } 50.01%,100% { opacity: 0; } }

.hero-card__body--chat { background: var(--paper); display: flex; flex-direction: column; gap: 10px; padding: 16px 18px; }
.hero-card__bubble { padding: 12px 16px; border-radius: 14px; font-family: var(--sans); font-size: 14px; line-height: 1.5; max-width: 92%; position: relative; }
.hero-card__bubble--client { background: var(--cream-2); color: var(--fg); align-self: flex-end; border-bottom-right-radius: 6px; }
.hero-card__bubble--agent  { background: var(--ink); color: var(--cream); align-self: flex-start; border-bottom-left-radius: 6px; }
.hero-card__bubble-from { display: block; font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-3); margin-bottom: 5px; }
.hero-card__bubble--agent .hero-card__bubble-from { color: rgba(245,240,232,0.55); }
.hero-card__typing { display: inline-flex; gap: 3px; margin-left: 6px; vertical-align: middle; }
.hero-card__typing span { width: 4px; height: 4px; border-radius: 50%; background: var(--amber); animation: typing 1.3s ease-in-out infinite; }
.hero-card__typing span:nth-child(2) { animation-delay: .2s; }
.hero-card__typing span:nth-child(3) { animation-delay: .4s; }

.hero-card__foot {
  padding: 10px 18px; border-top: 1px solid var(--border-c); display: flex; gap: 18px; align-items: center;
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.06em; color: var(--fg-3); text-transform: uppercase;
  background: var(--cream-2);
}
.hero-card__live { display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: #16a34a; margin-right: 6px; vertical-align: middle; animation: pulse 1.6s ease-in-out infinite; }
.hero-card__live--amber { background: var(--amber); }
.hero-card__foot span:first-child { color: var(--fg); font-weight: 500; display: inline-flex; align-items: center; }
.hero-card__foot span:last-child { margin-left: auto; }

.hero__cta-row {
  display: flex; gap: 18px; align-items: center; margin-top: 44px;
  flex-wrap: wrap;
  padding-top: 36px; border-top: 1px solid var(--border-c);
}
.hero__reassure { margin-left: auto; display: flex; flex-wrap: wrap; gap: 28px; }
.hero__reassure-item { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; color: var(--fg-2); display: inline-flex; align-items: baseline; gap: 8px; }
.hero__reassure-item__br { color: var(--terra); }

@media (max-width: 900px) {
  .hero__split { grid-template-columns: 1fr; }
  .hero__reassure { margin-left: 0; }
}
.btn-primary {
  display: inline-flex; align-items: center; gap: 10px; font-family: var(--mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
  background: var(--fg); color: var(--cream); padding: 18px 28px; border-radius: 100px; transition: transform .2s, background .2s, box-shadow .25s;
}
.btn-primary:hover { background: var(--terra); transform: translateY(-2px); box-shadow: 0 12px 32px rgba(196,98,42,0.30); }
.btn-primary svg { transition: transform .2s; }
.btn-primary:hover svg { transform: translateX(4px); }
.btn-ghost { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg); padding: 18px 6px; position: relative; }
.btn-ghost::after { content: ''; position: absolute; left: 6px; right: 6px; bottom: 12px; height: 1px; background: currentColor; transform-origin: left; transition: transform .25s; }
.btn-ghost:hover::after { transform: scaleX(0.6); }
@keyframes stroke-in { from { transform: scaleX(0); } to { transform: scaleX(1); } }

/* hero right panel — live status card */
.hero__status { background: var(--paper); border: 1px solid var(--border-c); border-radius: 20px; padding: 28px; position: relative; overflow: hidden; }
.hero__status__lbl { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-3); display: flex; align-items: center; gap: 8px; }
.hero__status__lbl::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--amber); animation: pulse 1.6s ease-in-out infinite; }
.hero__status__title { font-family: var(--display); font-weight: 500; font-size: 22px; line-height: 1.2; margin-top: 14px; }
.hero__status__title em { font-style: normal; color: var(--terra); font-weight: 600; }
.hero__status__meta { display: flex; gap: 18px; font-family: var(--mono); font-size: 11px; color: var(--fg-3); margin-top: 6px; letter-spacing: 0.05em; }
.hero__status__bubble { margin-top: 18px; background: var(--cream-2); border-radius: 14px; padding: 14px 16px; font-family: var(--sans); font-size: 14px; line-height: 1.55; color: var(--fg); position: relative; }
.hero__status__bubble::before { content: ''; position: absolute; top: -6px; left: 24px; width: 12px; height: 12px; background: var(--cream-2); transform: rotate(45deg); }
.hero__status__bubble-from { display: block; font-family: var(--mono); font-size: 10px; color: var(--fg-3); letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 6px; }
.hero__status__typing { margin-top: 14px; display: flex; align-items: center; gap: 10px; font-family: var(--mono); font-size: 11px; color: var(--fg-3); letter-spacing: 0.08em; text-transform: uppercase; }
.hero__status__dots { display: inline-flex; gap: 3px; }
.hero__status__dots span { width: 4px; height: 4px; background: var(--terra); border-radius: 50%; animation: typing 1.4s infinite ease-in-out; }
.hero__status__dots span:nth-child(2) { animation-delay: .2s; }
.hero__status__dots span:nth-child(3) { animation-delay: .4s; }
@keyframes typing { 0%,80%,100% { opacity: 0.2; } 40% { opacity: 1; } }

.hero__reassure { margin-top: 80px; padding-top: 30px; border-top: 1px solid var(--border-c); display: flex; flex-wrap: wrap; gap: 36px; }
.hero__reassure-item { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; color: var(--fg-2); display: inline-flex; align-items: baseline; gap: 8px; }
.hero__reassure-item__br { color: var(--terra); }

/* ============== MANIFESTO TAPE ============== */
.manifesto { background: var(--ink); color: var(--fg-inv); padding: 64px 0; overflow: hidden; position: relative; }
.manifesto__track-wrap { overflow: hidden; }
.manifesto__track { display: inline-flex; gap: 48px; align-items: center; width: max-content; animation: tape 38s linear infinite; }
.manifesto__item { font-family: var(--display); font-weight: 300; font-size: clamp(48px, 9vw, 128px); line-height: 1; letter-spacing: -0.03em; flex-shrink: 0; color: var(--fg-inv); }
.manifesto__sep { font-family: var(--mono); font-weight: 400; font-size: clamp(28px, 5vw, 48px); color: var(--amber); flex-shrink: 0; }
@keyframes tape { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* ============== TWO VOIES ============== */
.voies { padding: 96px var(--pad) 80px; max-width: var(--max); margin: 0 auto; }
.voies__head { display: flex; flex-direction: column; gap: 10px; margin-bottom: 48px; max-width: 640px; }
.voies__title { font-family: var(--display); font-weight: 400; font-size: clamp(26px, 3.6vw, 48px); line-height: 1.1; letter-spacing: -0.025em; }
.voies__title em { font-style: normal; font-family: var(--serif); font-weight: 500; color: var(--terra); }
.voies__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start; position: relative; }
.voies__grid::before { content: ''; position: absolute; top: 0; bottom: 0; left: 50%; width: 1px; background: var(--border-c); transform: translateX(-50%); }
.voie { padding: 0 8px; display: flex; flex-direction: column; }
.voie__head { display: flex; flex-direction: column; gap: 14px; margin-bottom: 22px; }
.voie__index { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-3); }
.voie--right .voie__index { color: var(--terra); }
.voie__numwrap { display: flex; align-items: baseline; gap: 16px; padding-bottom: 18px; border-bottom: 1px solid var(--border-c); }
.voie__num { font-family: var(--display); font-weight: 200; font-size: clamp(72px, 9vw, 124px); line-height: 0.82; letter-spacing: -0.06em; color: var(--fg); flex-shrink: 0; }
.voie--right .voie__num { color: var(--terra); }
.voie__num-rule { flex: 1; height: 1px; background: linear-gradient(to right, var(--border-c2), transparent); margin-bottom: 8px; }
.voie__lbl { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-2); padding-bottom: 8px; flex-shrink: 0; }
.voie__title { font-family: var(--display); font-weight: 500; font-size: clamp(26px, 2.8vw, 36px); line-height: 1.1; letter-spacing: -0.02em; margin-top: 4px; color: var(--fg); }
.voie__desc { font-family: var(--serif); font-style: italic; font-size: 16px; line-height: 1.5; color: var(--fg-2); margin-top: 14px; max-width: 360px; }
.voie__tags { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 20px; }
.voie__tag { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.08em; padding: 5px 11px; border: 1px solid var(--border-c2); border-radius: 100px; color: var(--fg); }
.voie--right .voie__tag { border-color: rgba(196,98,42,0.3); color: var(--terra); }
.voie__cta { display: inline-flex; align-items: center; gap: 10px; margin-top: 28px; font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg); cursor: pointer; }
.voie__cta::after { content: '→'; font-family: var(--sans); font-size: 16px; transition: transform .2s; }
.voie__cta:hover::after { transform: translateX(4px); }
.voie--right .voie__cta { color: var(--terra); }

/* ============== AGENT TEAM ============== */
.team { background: var(--ink); color: var(--fg-inv); padding: 64px var(--pad) 96px; position: relative; overflow: hidden; }
.team__head { max-width: var(--max); margin: 0 auto 48px; display: flex; justify-content: space-between; align-items: flex-end; gap: 40px; flex-wrap: wrap; }
.team__head > div { display: flex; flex-direction: column; gap: 10px; }
.team__title { font-family: var(--display); font-weight: 400; font-size: clamp(26px, 3.6vw, 48px); line-height: 1.1; letter-spacing: -0.025em; color: var(--fg-inv); max-width: 720px; }
.team__title em { font-style: normal; font-family: var(--serif); font-weight: 500; color: var(--amber); }
.team__intro { font-family: var(--serif); font-style: italic; font-size: 16px; line-height: 1.55; color: var(--fg-inv-2); max-width: 380px; }
.team__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; max-width: var(--max); margin: 0 auto; }

.agent-card {
  position: relative; display: flex; flex-direction: column; gap: 18px;
  padding: 22px 22px 20px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.08);
  overflow: hidden;
  transition: transform .35s cubic-bezier(.2,.8,.2,1), border-color .35s, box-shadow .35s;
}
.agent-card:hover {
  transform: translateY(-4px);
  border-color: color-mix(in srgb, var(--agent-color) 50%, rgba(255,255,255,0.08));
  box-shadow: 0 24px 56px -20px color-mix(in srgb, var(--agent-color) 35%, transparent);
}
.agent-card__flood {
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(circle at 20% 0%, color-mix(in srgb, var(--agent-color) 22%, transparent), transparent 65%);
  opacity: 0; transition: opacity .35s; border-radius: inherit;
}
.agent-card:hover .agent-card__flood { opacity: 1; }
.agent-card > *:not(.agent-card__flood) { position: relative; z-index: 1; }

.agent-card__head { display: flex; gap: 14px; align-items: center; }
.agent-card__photo {
  position: relative; flex-shrink: 0;
  width: 64px; height: 64px; border-radius: 50%;
  background: var(--paper); overflow: hidden;
  box-shadow:
    0 0 0 2.5px color-mix(in srgb, var(--agent-color) 80%, transparent),
    0 14px 24px -8px color-mix(in srgb, var(--agent-color) 50%, transparent),
    0 4px 12px -4px rgba(0,0,0,0.3),
    inset 0 -6px 12px -8px rgba(0,0,0,0.12);
  transition: transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .4s;
}
.agent-card:hover .agent-card__photo {
  transform: scale(1.06) translateY(-2px);
  box-shadow:
    0 0 0 2.5px color-mix(in srgb, var(--agent-color) 100%, transparent),
    0 22px 36px -10px color-mix(in srgb, var(--agent-color) 65%, transparent),
    0 6px 16px -4px rgba(0,0,0,0.4),
    inset 0 -6px 12px -8px rgba(0,0,0,0.15);
}
.agent-card__photo img { width: 100%; height: 100%; display: block; }
.agent-card__info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.agent-card__live {
  font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(245,240,232,0.5);
  display: inline-flex; align-items: center; gap: 6px;
  margin-bottom: 2px;
}
.agent-card__live > span {
  width: 6px; height: 6px; border-radius: 50%; background: #16a34a;
  animation: pulse 1.8s ease-in-out infinite;
  box-shadow: 0 0 8px rgba(22,163,74,0.5);
}
.agent-card__name {
  font-family: var(--display); font-weight: 500; font-size: 21px; letter-spacing: -0.015em;
  color: var(--fg-inv); line-height: 1;
}
.agent-card__role {
  font-family: var(--serif); font-style: italic; font-size: 13.5px; line-height: 1.4;
  color: var(--fg-inv-2); margin-top: 2px;
}

.agent-card__meta {
  padding-top: 16px; border-top: 1px solid rgba(255,255,255,0.08);
  display: flex; flex-direction: column; gap: 9px;
}
.agent-card__meta-row {
  display: grid; grid-template-columns: 70px 1fr; gap: 12px; align-items: baseline;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.04em;
}
.agent-card__meta-lbl { color: rgba(245,240,232,0.4); text-transform: uppercase; letter-spacing: 0.12em; font-size: 10px; }
.agent-card__meta-val { color: var(--fg-inv); }
.agent-card__chips { display: inline-flex; gap: 5px; flex-wrap: wrap; }
.agent-card__chip {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.06em;
  padding: 2px 9px; border-radius: 100px;
  background: color-mix(in srgb, var(--agent-color) 15%, transparent);
  color: var(--agent-color);
  border: 1px solid color-mix(in srgb, var(--agent-color) 30%, transparent);
}

.agent-card__quote {
  padding-top: 14px; border-top: 1px solid rgba(255,255,255,0.06);
  font-family: var(--serif); font-style: italic; font-size: 13.5px; line-height: 1.55;
  color: var(--fg-inv-2);
}
.agent-card__quote::before {
  content: '"'; color: var(--amber); margin-right: 4px;
  font-size: 28px; line-height: 0; vertical-align: -10px; font-family: var(--serif);
}

/* ============== DAY CAROUSEL ============== */
.day__carousel { position: relative; max-width: 1200px; margin: 0 auto; }
.day__viewport { overflow: hidden; padding: 8px 0; }
.day__rail { display: flex; gap: 16px; transition: transform .5s cubic-bezier(.2,.8,.2,1); }
.day__slide { flex: 0 0 calc((100% - 32px) / 3); max-width: calc((100% - 32px) / 3); }
.day__controls { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-top: 22px; padding: 0 4px; }
.day__btn { width: 44px; height: 44px; border-radius: 50%; background: var(--paper); border: 1px solid var(--border-c2); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background .2s, border-color .2s, color .2s; color: var(--fg); font-size: 18px; }
.day__btn:hover { background: var(--terra); color: var(--cream); border-color: var(--terra); }
.day__btn:disabled { opacity: 0.3; cursor: not-allowed; }
.day__btn:disabled:hover { background: var(--paper); color: var(--fg); border-color: var(--border-c2); }
.day__dots { display: flex; gap: 6px; align-items: center; }
.day__dot { width: 24px; height: 4px; border-radius: 100px; background: var(--border-c2); border: 0; cursor: pointer; transition: background .2s, width .2s; padding: 0; }
.day__dot.is-active { background: var(--terra); width: 36px; }
.day__progress { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; color: var(--fg-3); }
.day__progress b { color: var(--terra); font-weight: 500; font-style: normal; }

@media (max-width: 980px) { .day__slide { flex: 0 0 calc((100% - 16px) / 2); max-width: calc((100% - 16px) / 2); } }
@media (max-width: 640px) { .day__slide { flex: 0 0 100%; max-width: 100%; } } ============== */
.day { padding: 96px var(--pad); max-width: var(--max); margin: 0 auto; }
.day__head { display: flex; flex-direction: column; gap: 10px; margin-bottom: 48px; max-width: 640px; margin-left: clamp(8px, 3vw, 48px); }
.day__title { font-family: var(--display); font-weight: 400; font-size: clamp(26px, 3.6vw, 48px); line-height: 1.1; letter-spacing: -0.025em; }
.day__title em { font-style: normal; font-family: var(--serif); font-weight: 500; color: var(--terra); }
.day__sub-block { display: flex; flex-direction: column; gap: 18px; max-width: 480px; padding-bottom: 4px; align-self: end; }
.day__sub { font-family: var(--serif); font-style: italic; font-size: 15px; line-height: 1.6; color: var(--fg-2); margin: 0; }
.day__sub-stats { display: flex; gap: 22px; flex-wrap: wrap; }
.day__sub-stats span { display: flex; flex-direction: column; gap: 2px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-3); }
.day__sub-stats b { font-family: var(--display); font-weight: 400; font-size: 26px; line-height: 1; letter-spacing: -0.02em; color: var(--terra); font-style: normal; }

.day__scenes { list-style: none; padding: 0; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 14px; max-width: 1200px; }

@media (max-width: 820px) {
  .day__scenes { grid-template-columns: 1fr; max-width: 940px; }
}

.scene { background: var(--paper); border: 1px solid var(--border-c); border-radius: 18px; padding: 20px 22px; transition: border-color .3s, transform .3s, box-shadow .3s; }
.scene:hover { border-color: rgba(196,98,42,0.35); transform: translateY(-1px); box-shadow: 0 12px 32px -12px rgba(0,0,0,0.08); }
.scene__head { display: grid; grid-template-columns: 76px 32px 1fr auto; gap: 14px; align-items: center; padding-bottom: 14px; border-bottom: 1px dashed var(--border-c); margin-bottom: 14px; }
.scene__time { font-family: var(--mono); font-size: 15px; font-weight: 500; color: var(--terra); letter-spacing: 0.04em; }
.scene__rule { height: 1px; background: var(--border-c2); }
.scene__marker { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-3); }
.scene__channel { font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-3); background: var(--cream-2); padding: 4px 10px; border-radius: 100px; }

.scene__body { display: flex; flex-direction: column; gap: 14px; }
.scene__exchange { display: flex; flex-direction: column; gap: 12px; }
.scene__bubble-row { display: flex; gap: 10px; align-items: flex-end; max-width: 100%; }
.scene__bubble-row--client { justify-content: flex-start; }
.scene__bubble-row--agent  { justify-content: flex-end; flex-direction: row-reverse; }
.scene__bubble-avatar { width: 32px; height: 32px; border-radius: 50%; overflow: hidden; flex-shrink: 0; background: var(--cream-2); box-shadow: 0 0 0 1.5px var(--border-c2), 0 4px 10px -3px rgba(0,0,0,0.15); }
.scene__bubble-avatar--agent { box-shadow: 0 0 0 2px rgba(245,158,11,0.5), 0 4px 12px -3px rgba(245,158,11,0.35); }
.scene__bubble-avatar img { width: 100%; height: 100%; display: block; }
.scene__bubble { padding: 12px 16px; border-radius: 14px; font-family: var(--sans); font-size: 14.5px; line-height: 1.5; max-width: 78%; }
.scene__bubble--client { background: var(--cream-2); color: var(--fg); border-bottom-left-radius: 6px; }
.scene__bubble--agent { background: var(--ink); color: var(--cream); border-bottom-right-radius: 6px; box-shadow: 0 8px 20px -8px rgba(245,158,11,0.35); }
.scene__bubble-from { display: block; font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 5px; color: var(--fg-3); }
.scene__bubble--agent .scene__bubble-from { color: var(--amber); }
.scene__narrative { font-family: var(--serif); font-style: italic; font-size: 15px; line-height: 1.55; color: var(--fg-2); padding: 8px 4px; }

.scene__outcome { display: inline-flex; align-items: center; gap: 8px; padding: 8px 14px; border-radius: 100px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; align-self: flex-start; }
.scene__outcome-mark { font-family: var(--sans); font-size: 14px; font-weight: 600; }
.scene__outcome--ok { background: rgba(45,138,110,0.08); border: 1px solid rgba(45,138,110,0.25); color: #2d8a6e; }
.scene__outcome--system { background: rgba(59,108,245,0.06); border: 1px solid rgba(59,108,245,0.22); color: #3b6cf5; }
.scene__outcome--escalate { background: rgba(196,98,42,0.08); border: 1px solid rgba(196,98,42,0.25); color: var(--terra); }

/* ============== WORK ============== */
.work { padding: 96px var(--pad); max-width: var(--max); margin: 0 auto; }
.work__head { display: grid; grid-template-columns: 1.1fr 1fr; gap: 60px; align-items: end; margin-bottom: 48px; padding-bottom: 36px; border-bottom: 1px solid var(--border-c2); }
.work__head-left { display: flex; flex-direction: column; gap: 10px; }
.work__title { font-family: var(--display); font-weight: 400; font-size: clamp(26px, 3.6vw, 48px); line-height: 1.1; letter-spacing: -0.025em; }
.work__title em { font-style: normal; font-family: var(--serif); font-weight: 500; color: var(--terra); }
.work__head-right { display: flex; flex-direction: column; gap: 28px; align-items: flex-end; padding-bottom: 6px; }
.work__sub { margin: 0; font-family: var(--serif); font-style: italic; font-size: 15.5px; line-height: 1.6; color: var(--fg-2); max-width: 460px; text-align: right; }
.work__head-counter { display: flex; align-items: baseline; gap: 14px; }
.work__head-counter span { font-family: var(--display); font-weight: 300; font-size: clamp(48px, 5vw, 72px); line-height: 0.85; letter-spacing: -0.04em; color: var(--terra); }
.work__head-counter small { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-3); }

/* ----- FEATURED ----- */
.work__featured { display: grid; grid-template-columns: 96px 1fr; gap: 28px; align-items: stretch; margin-bottom: 56px; cursor: pointer; transition: transform .35s; }
.work__featured:hover { transform: translateY(-2px); }
.work__featured-side { display: flex; flex-direction: column; justify-content: space-between; padding: 18px 0; border-right: 1px solid var(--border-c); }
.work__featured-side-num { font-family: var(--display); font-weight: 200; font-size: 72px; line-height: 0.85; letter-spacing: -0.05em; color: var(--terra); }
.work__featured-side-lbl { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--fg-3); writing-mode: vertical-rl; transform: rotate(180deg); align-self: center; padding: 18px 0; }
.work__featured-side-yr { font-family: var(--mono); font-size: 12px; letter-spacing: 0.1em; color: var(--fg-2); }

.work__featured-poster { position: relative; overflow: hidden; padding: 40px 40px 36px; border-radius: 22px; background: linear-gradient(165deg, var(--ink) 0%, var(--ink-2) 100%); color: var(--fg-inv); display: flex; flex-direction: column; gap: 22px; min-height: 440px; transition: box-shadow .35s; }
.work__featured:hover .work__featured-poster { box-shadow: 0 24px 60px -20px rgba(0,0,0,0.4); }
.work__featured-poster::after { content: ''; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(circle at 80% 15%, rgba(245,158,11,0.16), transparent 55%), radial-gradient(circle at 20% 90%, rgba(196,98,42,0.10), transparent 60%); }
.work__featured-poster > * { position: relative; z-index: 1; }
.work__featured-poster-tag { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--amber); display: inline-flex; align-items: center; gap: 10px; align-self: flex-start; }
.work__featured-poster-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--amber); animation: pulse 1.8s ease-in-out infinite; box-shadow: 0 0 12px rgba(245,158,11,0.6); }
.work__featured-poster-name { font-family: var(--display); font-weight: 200; font-size: clamp(64px, 9vw, 128px); line-height: 0.85; letter-spacing: -0.06em; color: var(--fg-inv); }
.work__featured-poster-name .dim { color: rgba(245,240,232,0.45); }
.work__featured-poster-name .dot { color: var(--amber); }
.work__featured-poster-img { width: 100%; margin: 12px 0 16px; border-radius: 10px; overflow: hidden; border: 1px solid rgba(245,240,232,0.12); }
.work__featured-poster-img img { width: 100%; height: auto; display: block; }
.work__featured-poster-desc { font-family: var(--serif); font-style: italic; font-size: clamp(15px, 1.5vw, 17px); line-height: 1.55; color: rgba(245,240,232,0.78); max-width: 580px; margin: 0; }
.work__featured-poster-rule { height: 1px; background: linear-gradient(to right, rgba(245,158,11,0.4) 0%, rgba(245,240,232,0.15) 35%, transparent 100%); width: 100%; }
.work__featured-poster-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }
.work__featured-poster-stats > div { display: flex; flex-direction: column; gap: 4px; }
.work__featured-poster-stats b { font-family: var(--display); font-weight: 400; font-size: clamp(24px, 2.6vw, 32px); letter-spacing: -0.02em; color: var(--amber); line-height: 1; font-style: normal; }
.work__featured-poster-stats small { font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(245,240,232,0.5); }
.work__featured-poster-foot { padding-top: 18px; border-top: 1px solid rgba(245,240,232,0.1); display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; color: rgba(245,240,232,0.5); }
.work__featured-poster-cta { color: var(--amber); }

/* ----- INDEX LIST (other projects) ----- */
.work__index { display: flex; flex-direction: column; }
.work__index-head { display: grid; grid-template-columns: 60px 1.2fr 1.4fr 1.6fr 32px; gap: 18px; padding: 10px 4px; border-bottom: 1px solid var(--border-c2); font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-3); }
.work__row { display: grid; grid-template-columns: 60px 1.2fr 1.4fr 1.6fr 32px; gap: 18px; align-items: center; padding: 22px 4px 0; border-bottom: 1px solid var(--border-c); cursor: pointer; position: relative; transition: padding-left .35s, padding-right .35s; }
.work__row::before { content: ''; position: absolute; left: 0; right: 0; bottom: 0; top: 0; background: linear-gradient(to right, rgba(196,98,42,0.06), transparent 80%); opacity: 0; transition: opacity .3s; pointer-events: none; border-radius: 4px; }
.work__row:hover::before { opacity: 1; }
.work__row:hover { padding-left: 14px; }
.work__row-num { font-family: var(--display); font-weight: 200; font-size: clamp(32px, 3.4vw, 48px); line-height: 1; letter-spacing: -0.03em; color: var(--fg-3); transition: color .3s; }
.work__row:hover .work__row-num { color: var(--terra); }
.work__row-industry { font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--terra); }
.work__row-name { font-family: var(--display); font-weight: 500; font-size: clamp(20px, 2.4vw, 30px); line-height: 1.1; letter-spacing: -0.02em; color: var(--fg); }
.work__row-stack { display: flex; gap: 6px; flex-wrap: wrap; }
.work__row-stack span { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.04em; padding: 4px 10px; background: var(--cream-2); border-radius: 100px; color: var(--fg-2); }
.work__row-cta { font-family: var(--sans); font-size: 22px; color: var(--fg-3); justify-self: end; transition: color .3s, transform .3s; }
.work__row:hover .work__row-cta { color: var(--terra); transform: translateX(6px); }
.work__row-desc { grid-column: 2 / 5; font-family: var(--serif); font-style: italic; font-size: 14.5px; line-height: 1.5; color: var(--fg-2); margin: 4px 0 22px; max-width: 720px; max-height: 0; overflow: hidden; opacity: 0; transition: max-height .4s cubic-bezier(.2,.8,.2,1), opacity .25s, margin .3s; }
.work__row.is-hover .work__row-desc { max-height: 100px; opacity: 1; margin: 6px 0 22px; }

@media (max-width: 900px) {
  .work__head { grid-template-columns: 1fr; gap: 28px; }
  .work__head-right { align-items: flex-start; }
  .work__sub { text-align: left; }
  .work__featured { grid-template-columns: 1fr; gap: 16px; }
  .work__featured-side { flex-direction: row; border-right: 0; border-bottom: 1px solid var(--border-c); padding: 0 0 16px; justify-content: flex-start; align-items: center; gap: 22px; }
  .work__featured-side-lbl { writing-mode: horizontal-tb; transform: none; padding: 0; }
  .work__featured-poster { padding: 28px 24px; min-height: 0; }
  .work__featured-poster-stats { grid-template-columns: repeat(2, 1fr); gap: 18px; }
  .work__index-head, .work__row { grid-template-columns: 40px 1fr 24px; }
  .work__index-head > :nth-child(3), .work__index-head > :nth-child(4) { display: none; }
  .work__row > .work__row-industry { grid-column: 2; grid-row: 1; }
  .work__row > .work__row-name { grid-column: 2; grid-row: 2; }
  .work__row > .work__row-stack { grid-column: 2; grid-row: 3; margin-top: 4px; }
  .work__row-desc { grid-column: 2; }
  .work__row-num { grid-row: 1 / 4; }
}

/* ============== PROJECT MODAL ============== */
.proj-modal { position: fixed; inset: 0; z-index: 1000; background: rgba(15,17,23,0.85); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); display: flex; align-items: center; justify-content: center; padding: 20px; animation: proj-fade-in .2s ease; }
@keyframes proj-fade-in { from { opacity: 0; } to { opacity: 1; } }
.proj-modal__inner { background: var(--paper); border-radius: 22px; max-width: 760px; width: 100%; max-height: 90vh; overflow-y: auto; position: relative; padding: 40px clamp(24px, 4vw, 48px); animation: proj-slide-up .35s cubic-bezier(.2,.8,.2,1); }
@keyframes proj-slide-up { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.proj-modal__close { position: absolute; top: 16px; right: 16px; width: 36px; height: 36px; border-radius: 50%; background: var(--cream-2); border: 0; font-family: var(--sans); font-size: 22px; line-height: 1; color: var(--fg); cursor: pointer; transition: background .2s; display: flex; align-items: center; justify-content: center; }
.proj-modal__close:hover { background: var(--terra); color: var(--cream); }
.proj-modal__head { margin-bottom: 28px; padding-bottom: 22px; border-bottom: 1px solid var(--border-c); }
.proj-modal__meta { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--terra); }
.proj-modal__name { font-family: var(--display); font-weight: 500; font-size: clamp(36px, 5vw, 56px); letter-spacing: -0.025em; line-height: 1; margin: 10px 0 12px; }
.proj-modal__short { font-family: var(--serif); font-style: italic; font-size: 16px; line-height: 1.5; color: var(--fg-2); margin: 0; }
.proj-modal__image { width: 100%; border-radius: 10px; overflow: hidden; border: 1px solid var(--border); }
.proj-modal__image img { width: 100%; height: auto; display: block; }
.proj-modal__body { display: flex; flex-direction: column; gap: 24px; }
.proj-modal__block { display: flex; flex-direction: column; gap: 10px; }
.proj-modal__block-lbl { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-3); }
.proj-modal__block p { font-family: var(--sans); font-size: 15px; line-height: 1.6; color: var(--fg); margin: 0; }
.proj-modal__block ul { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.proj-modal__block li { font-family: var(--sans); font-size: 14.5px; line-height: 1.55; color: var(--fg); display: flex; gap: 10px; }
.proj-modal__block li span { color: var(--terra); font-family: var(--mono); font-weight: 500; flex-shrink: 0; }
.proj-modal__stack { display: flex; gap: 8px; flex-wrap: wrap; }
.proj-modal__stack span { font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; padding: 5px 11px; background: var(--cream-2); border-radius: 100px; color: var(--fg-2); }

/* ============== ATELIER / STUDIO ============== */
.atelier { background: var(--ink); color: var(--fg-inv); padding: 88px var(--pad); position: relative; overflow: hidden; }
.atelier__inner { max-width: var(--max); margin: 0 auto; }
.atelier__head { display: flex; flex-direction: column; gap: 10px; margin-bottom: 48px; max-width: 640px; }
.atelier__title { font-family: var(--display); font-weight: 400; font-size: clamp(26px, 3.6vw, 48px); line-height: 1.1; letter-spacing: -0.025em; color: var(--fg-inv); }
.atelier__title em { font-style: normal; font-family: var(--serif); font-weight: 500; color: var(--amber); }

.atelier__banner { position: relative; height: clamp(220px, 28vw, 360px); border-radius: 18px; overflow: hidden; margin: 0 0 48px; border: 1px solid var(--border-ink); }
.atelier__banner img { width: 100%; height: 100%; object-fit: cover; filter: contrast(1.05) saturate(0.95) brightness(0.92); display: block; }
.atelier__banner-meta { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: space-between; padding: 22px 26px; background: linear-gradient(to top, rgba(15,17,23,0.7) 0%, rgba(15,17,23,0.2) 40%, transparent 100%); pointer-events: none; }
.atelier__banner-meta > div:first-child { display: flex; flex-direction: column; gap: 4px; align-items: flex-end; align-self: flex-end; }
.atelier__banner-coord { font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; color: rgba(245,240,232,0.6); text-transform: uppercase; }
.atelier__banner-place { font-family: var(--display); font-weight: 500; font-size: clamp(18px, 2.2vw, 24px); color: var(--amber); letter-spacing: -0.01em; }
.atelier__banner-tags { display: flex; gap: 14px; flex-wrap: wrap; font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(245,240,232,0.7); }

.atelier__quote { font-family: var(--serif); font-style: italic; font-size: clamp(16px, 1.6vw, 20px); line-height: 1.55; color: var(--fg-inv-2); max-width: 720px; margin: 0 auto 56px; padding: 0 12px; text-align: left; }
.atelier__quote::before { content: '« '; color: var(--amber); }
.atelier__quote::after  { content: ' »'; color: var(--amber); }

.atelier__founders { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; }
.atelier__founder { display: grid; grid-template-columns: 220px 1fr; gap: 28px; align-items: start; }
.atelier__founder-photo { position: relative; aspect-ratio: 3/4; border-radius: 12px; overflow: hidden; background: var(--ink-2); box-shadow: 0 16px 40px -16px rgba(0,0,0,0.5); }
.atelier__founder-photo img { width: 100%; height: 100%; object-fit: cover; filter: contrast(1.05); display: block; }
.atelier__founder-tag { position: absolute; bottom: 12px; left: 12px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--amber); background: rgba(15,17,23,0.85); padding: 4px 10px; border-radius: 100px; backdrop-filter: blur(8px); }
.atelier__founder-meta { padding-top: 8px; }
.atelier__founder-name { font-family: var(--display); font-weight: 500; font-size: 30px; letter-spacing: -0.02em; color: var(--fg-inv); }
.atelier__founder-name::before { content: ''; display: block; width: 36px; height: 2px; background: var(--amber); margin-bottom: 16px; }
.atelier__founder-role { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-inv-2); margin-top: 6px; }
.atelier__founder-bio { font-family: var(--serif); font-style: italic; font-size: 15px; line-height: 1.6; color: var(--fg-inv-2); margin-top: 18px; }
.atelier__founder-skills { display: flex; gap: 6px; margin-top: 18px; flex-wrap: wrap; }
.atelier__founder-skills span { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.06em; padding: 3px 10px; border-radius: 100px; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1); color: var(--fg-inv-2); }

/* ============== CONVERSATION CTA ============== */
.conv { padding: 96px var(--pad); max-width: var(--max); margin: 0 auto; }
.conv__inner {
  background: linear-gradient(160deg, var(--ink) 0%, var(--ink-2) 100%);
  color: var(--fg-inv);
  border-radius: 26px;
  padding: clamp(36px, 5vw, 72px) clamp(28px, 4.5vw, 64px);
  position: relative; overflow: hidden;
}
.conv__inner::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(60% 80% at 70% 0%, rgba(245,158,11,0.16), transparent 60%);
}
.conv__inner > * { position: relative; z-index: 1; }
.conv__marker {
  display: inline-flex; align-items: baseline; gap: 6px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--amber); margin-bottom: 20px;
}
.conv__marker-br { color: var(--amber); opacity: 0.7; }
.conv__title { font-family: var(--display); font-weight: 400; font-size: clamp(26px, 3.6vw, 48px); line-height: 1.1; letter-spacing: -0.025em; color: var(--fg-inv); }
.conv__title em { font-style: normal; font-family: var(--serif); font-weight: 500; color: var(--amber); }
.conv__sub { font-family: var(--serif); font-style: italic; font-size: clamp(15px, 1.4vw, 17px); color: var(--fg-inv-2); margin-top: 18px; max-width: 480px; line-height: 1.55; }

.conv__chips { display: flex; gap: 8px; flex-wrap: wrap; margin: 36px 0 16px; }
.conv__chip {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em;
  padding: 10px 16px; border: 1px solid rgba(245,240,232,0.18); border-radius: 100px;
  cursor: pointer; transition: all .2s;
  background: rgba(245,240,232,0.04); color: var(--fg-inv-2);
}
.conv__chip:hover { border-color: var(--amber); color: var(--amber); background: rgba(245,158,11,0.08); }
.conv__chip.is-selected { background: var(--amber); color: var(--ink); border-color: var(--amber); }

.conv__composer {
  display: flex; gap: 10px; align-items: stretch;
  background: rgba(245,240,232,0.04); border: 1px solid rgba(245,240,232,0.14);
  border-radius: 14px; padding: 6px 6px 6px 18px;
  transition: border-color .25s, background .25s;
}
.conv__composer:focus-within { border-color: rgba(245,158,11,0.5); background: rgba(245,240,232,0.06); }
.conv__input {
  flex: 1; border: 0; background: transparent; outline: none;
  font-family: var(--sans); font-size: 15px; color: var(--fg-inv);
  padding: 14px 0;
}
.conv__input::placeholder { color: rgba(245,240,232,0.35); }
.conv__send {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  background: var(--amber); color: var(--ink); padding: 0 20px; border-radius: 10px;
  transition: background .2s, transform .2s;
}
.conv__send:hover { background: var(--amber-hover); }
.conv__send:active { transform: scale(0.97); }

.conv__toast {
  margin-top: 14px; text-align: left;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; color: var(--amber);
  opacity: 0; transform: translateY(-4px); transition: opacity .3s, transform .3s;
}
.conv__toast.is-shown { opacity: 1; transform: translateY(0); }

.conv__meta {
  display: flex; gap: 24px; margin-top: 36px;
  padding-top: 24px; border-top: 1px solid rgba(245,240,232,0.08);
  flex-wrap: wrap;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em;
  color: var(--fg-inv-3);
}
.conv__meta b { color: var(--fg-inv); font-weight: 500; }

@media (max-width: 640px) {
  .conv__meta { gap: 12px; flex-direction: column; }
  .conv__send { padding: 12px 18px; }
}

/* ============== FOOTER ============== */
.bfooter { background: var(--ink); color: var(--fg-inv); padding: 56px var(--pad) 28px; position: relative; overflow: hidden; }
.bfooter__inner { max-width: var(--max); margin: 0 auto; }
.bfooter__hero { display: flex; justify-content: space-between; align-items: flex-end; gap: 40px; flex-wrap: wrap; padding-bottom: 36px; border-bottom: 1px solid var(--border-ink); margin-bottom: 36px; }
.bfooter__hero-quote { font-family: var(--serif); font-style: italic; font-size: clamp(15px, 1.5vw, 18px); color: var(--fg-inv-2); max-width: 460px; line-height: 1.5; margin: 0; }
.bfooter__cols { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 28px; }
.bfooter__col-title { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-inv-3); margin-bottom: 16px; }
.bfooter__col p { font-family: var(--serif); font-style: italic; font-size: 15px; line-height: 1.55; color: var(--fg-inv-2); max-width: 320px; }
.bfooter__col a { display: block; font-family: var(--sans); font-size: 14px; color: var(--fg-inv-2); padding: 5px 0; transition: color .2s; cursor: pointer; }
.bfooter__col a:hover { color: var(--amber); }
.bfooter__bottom { display: flex; justify-content: space-between; align-items: center; gap: 24px; padding-top: 32px; border-top: 1px solid var(--border-ink); flex-wrap: wrap; }
.bfooter__copy { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; color: var(--fg-inv-3); }
.bfooter__legal { display: flex; gap: 24px; }
.bfooter__legal a { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; color: var(--fg-inv-3); cursor: pointer; }
.bfooter__legal a:hover { color: var(--fg-inv); }
.bfooter__horizon { position: absolute; left: 0; right: 0; bottom: 80px; height: 1px; background: linear-gradient(to right, transparent, var(--amber) 30%, var(--amber) 70%, transparent); opacity: 0.4; }

/* ============== RESPONSIVE ============== */
@media (max-width: 980px) {
  .hero__grid { grid-template-columns: 1fr; gap: 40px; }
  .voies__grid { grid-template-columns: 1fr; gap: 60px; }
  .voies__grid::before { display: none; }
  .team__grid { grid-template-columns: 1fr 1fr; }
  .day__head { gap: 8px; }
  .day__step { grid-template-columns: 80px auto 1fr; gap: 16px; }
  .work__featured { grid-template-columns: 1fr; gap: 32px; padding: 32px; }
  .work__list { grid-template-columns: 1fr 1fr; }
  .atelier__head { grid-template-columns: 1fr; }
  .atelier__founders { grid-template-columns: 1fr; gap: 48px; }
  .bfooter__cols { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .bnav__links { display: none; }
  .team__grid { grid-template-columns: 1fr; }
  .day__step { grid-template-columns: 1fr; gap: 4px; padding: 18px 0; }
  .work__list { grid-template-columns: 1fr; }
  .atelier__founder { grid-template-columns: 1fr; }
  .atelier__founder-photo { max-width: 240px; }
  .bfooter__cols { grid-template-columns: 1fr; gap: 32px; }
  .bfooter__bottom { flex-direction: column; align-items: flex-start; }
}

/* ============== SPOTLIGHT (cursor-follow warm light) ============== */
.spotlight { position: relative; isolation: isolate; }
.spotlight::before {
  content: ''; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: radial-gradient(420px circle at var(--mx, 50%) var(--my, 50%), rgba(245,158,11,0.16), transparent 55%);
  opacity: 0; transition: opacity .35s;
  border-radius: inherit;
}
.spotlight:hover::before { opacity: 1; }
.spotlight > * { position: relative; z-index: 1; }

/* ============== OVERHEARD (replaces Manifesto) ============== */
.overheard { background: var(--ink); color: var(--fg-inv); padding: 44px 0 36px; overflow: hidden; position: relative; }
.overheard__head { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad) 20px; }
.overheard__tracks { display: flex; flex-direction: column; gap: 10px; }
.overheard__tape { overflow: hidden; position: relative; }
.overheard__tape::before, .overheard__tape::after {
  content: ''; position: absolute; top: 0; bottom: 0; width: 100px; z-index: 2; pointer-events: none;
}
.overheard__tape::before { left: 0; background: linear-gradient(to right, var(--ink), transparent); }
.overheard__tape::after  { right: 0; background: linear-gradient(to left,  var(--ink), transparent); }
.overheard__track { display: inline-flex; gap: 10px; width: max-content; align-items: center; padding: 2px 0; }
.overheard__tape--ltr .overheard__track { animation: overheard-ltr 64s linear infinite; }
.overheard__tape--rtl .overheard__track { animation: overheard-rtl 72s linear infinite; }
@keyframes overheard-ltr { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
@keyframes overheard-rtl { 0% { transform: translateX(-50%); } 100% { transform: translateX(0); } }
.overheard__bubble {
  display: inline-flex; align-items: baseline; gap: 8px; flex-shrink: 0;
  padding: 8px 16px; border-radius: 100px;
  font-family: var(--sans); font-size: 13px; line-height: 1.4;
  white-space: nowrap;
}
.overheard__bubble--client { background: rgba(255,255,255,0.05); color: var(--fg-inv); border: 1px solid rgba(255,255,255,0.06); }
.overheard__bubble--agent  { background: rgba(245,158,11,0.10); color: var(--fg-inv); border: 1px solid rgba(245,158,11,0.20); }
.overheard__lang {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.1em;
  color: var(--amber); flex-shrink: 0;
}
.overheard__bubble--client .overheard__lang { color: var(--fg-inv-3); }

/* ============== ARCHITECTURE (constellation) ============== */
.arch { background: var(--ink); color: var(--fg-inv); padding: 96px var(--pad) 64px; position: relative; overflow: hidden; }
.arch__head { display: flex; flex-direction: column; gap: 10px; max-width: 640px; margin: 0 auto 48px; }
.arch__title { font-family: var(--display); font-weight: 400; font-size: clamp(26px, 3.6vw, 48px); line-height: 1.1; letter-spacing: -0.025em; color: var(--fg-inv); }
.arch__title em { font-style: normal; font-family: var(--serif); font-weight: 500; color: var(--amber); }
.arch__sub { font-family: var(--serif); font-style: italic; font-size: 15px; line-height: 1.6; color: var(--fg-inv-2); margin-top: 8px; }
.arch__stage { max-width: 1320px; margin: 0 auto; }
.arch__svg { width: 100%; height: auto; display: block; }
.arch__label { font-family: var(--mono); font-size: 13px; letter-spacing: 0.06em; fill: var(--fg-inv-2); }
.arch__label--agent { fill: var(--fg-inv); font-weight: 500; }
.arch__avatar-letter { font-family: var(--display); font-weight: 600; font-size: 18px; letter-spacing: -0.02em; fill: var(--ink); text-anchor: middle; }
.arch__col-head { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; fill: var(--fg-inv-3); text-transform: uppercase; }
.arch__router-label { font-family: var(--mono); font-size: 12px; letter-spacing: 0.22em; fill: var(--amber); font-weight: 500; }
.arch__router-meta  { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; fill: var(--fg-inv-3); }
.arch__stats {
  max-width: 1100px; margin: 36px auto 0; padding: 16px 28px;
  background: rgba(245,158,11,0.04); border: 1px solid rgba(245,158,11,0.18); border-radius: 100px;
  display: flex; align-items: baseline; justify-content: center; gap: 18px; flex-wrap: wrap;
}
.arch__stat-line { font-family: var(--mono); font-size: 12.5px; letter-spacing: 0.04em; color: rgba(245,240,232,0.55); display: inline-flex; align-items: baseline; gap: 8px; }
.arch__stat-line b { font-family: var(--display); font-weight: 500; font-size: 22px; letter-spacing: -0.015em; color: var(--amber); line-height: 1; }
.arch__stat-line b i { font-family: var(--mono); font-weight: 500; font-style: normal; font-size: 13px; letter-spacing: 0; }
.arch__stat-sep { font-family: var(--mono); font-size: 14px; color: rgba(245,158,11,0.35); }

@media (max-width: 720px) {
  .arch__stats { border-radius: 22px; padding: 16px 20px; gap: 14px 16px; }
  .arch__stat-sep { display: none; }
  .arch__stat-line { flex-basis: 45%; }
}

/* ============== LIVE DEMO ============== */
.demo { padding: var(--section) var(--pad); max-width: var(--max); margin: 0 auto; }
.demo__head { display: flex; flex-direction: column; gap: 10px; margin-bottom: 48px; max-width: 640px; }
.demo__title { font-family: var(--display); font-weight: 400; font-size: clamp(26px, 3.6vw, 48px); line-height: 1.1; letter-spacing: -0.025em; }
.demo__title em { font-style: normal; font-family: var(--serif); font-weight: 500; color: var(--terra); }
.demo__stage {
  display: grid; grid-template-columns: 5fr 7fr; gap: 32px;
  background: var(--paper); border: 1px solid var(--border-c); border-radius: 24px;
  padding: 36px;
  position: relative; overflow: hidden;
}
.demo__stage::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(420px circle at 75% 40%, color-mix(in srgb, var(--agent-color) 18%, transparent), transparent 60%);
  transition: background 0.6s ease;
}
.demo__stage > * { position: relative; z-index: 1; }
.demo__chips { display: flex; flex-direction: column; gap: 10px; }
.demo__chip { text-align: left; padding: 14px 16px 14px 42px; border-radius: 14px; background: var(--cream); border: 1px solid var(--border-c); cursor: pointer; transition: all .2s; display: flex; flex-direction: column; gap: 4px; position: relative; }
.demo__chip::before { content: '▶'; position: absolute; left: 16px; top: 17px; font-size: 11px; color: var(--terra); opacity: 0.5; transition: opacity .2s, transform .2s; }
.demo__chip:hover { border-color: var(--terra); transform: translateY(-1px); box-shadow: 0 8px 18px -8px rgba(196,98,42,0.18); }
.demo__chip:hover::before { opacity: 1; transform: scale(1.15); }
.demo__chip.is-active { background: var(--fg); color: var(--cream); border-color: var(--fg); }
.demo__chip.is-active::before { color: var(--amber); opacity: 1; }
.demo__chip-q { font-family: var(--sans); font-size: 14.5px; line-height: 1.45; }
.demo__chip-tag { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-3); }
.demo__chip.is-active .demo__chip-tag { color: var(--amber); }

.demo__convo { display: flex; flex-direction: column; gap: 14px; min-height: 360px; }
.demo__bubble { padding: 16px 20px; border-radius: 18px; font-family: var(--sans); font-size: 15px; line-height: 1.55; max-width: 88%; position: relative; }
.demo__bubble--user { background: var(--cream-2); color: var(--fg); align-self: flex-end; border-bottom-right-radius: 6px; }
.demo__bubble--agent { background: var(--fg); color: var(--cream); align-self: flex-start; border-bottom-left-radius: 6px; box-shadow: 0 16px 40px -16px color-mix(in srgb, var(--agent-color) 50%, transparent); min-height: 60px; }
.demo__bubble-from { display: block; font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-3); margin-bottom: 6px; }
.demo__caret { display: inline-block; color: var(--agent-color); margin-left: 2px; animation: caret 0.9s steps(2) infinite; }
@keyframes caret { 0%, 50% { opacity: 1; } 50.01%, 100% { opacity: 0; } }
.demo__agent-row { display: flex; align-items: center; gap: 12px; padding: 6px 4px; }
.demo__agent-row > div { flex: 1; }
.demo__agent-avatar { width: 44px; height: 44px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--display); font-weight: 600; font-size: 16px; color: var(--ink); flex-shrink: 0; overflow: hidden; box-shadow: 0 0 0 2px color-mix(in srgb, var(--agent-color) 70%, transparent), 0 6px 14px -4px color-mix(in srgb, var(--agent-color) 40%, transparent); }
.demo__agent-avatar img { width: 100%; height: 100%; display: block; }
.demo__agent-name { font-family: var(--display); font-weight: 500; font-size: 17px; letter-spacing: -0.01em; }
.demo__agent-role { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; color: var(--fg-3); text-transform: uppercase; }
.demo__agent-status { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; color: var(--agent-color); text-transform: uppercase; }
.demo__actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 4px; opacity: 0; transform: translateY(8px); transition: all 0.3s; }
.demo__actions.is-shown { opacity: 1; transform: translateY(0); }
.demo__action { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; padding: 10px 16px; border-radius: 100px; border: 1px solid var(--border-c2); background: var(--cream); cursor: pointer; transition: all .2s; }
.demo__action:hover { background: var(--agent-color, var(--fg)); color: #fff; border-color: var(--agent-color, var(--fg)); }

@media (max-width: 900px) {
  .demo__stage { grid-template-columns: 1fr; padding: 24px; }
}

@media (max-width: 720px) {
  .day__step-side { position: static; max-width: none; margin-top: 8px; opacity: 1; transform: none; grid-column: 1 / -1; }
  .day__step:has(.day__step-side) .day__step-text { padding-right: 0; }
}
