/* ===== Page-specific styles for homepage ===== */

body.home-page {
  --home-fluid-max: 1880px;
  --home-fluid-gutter: clamp(24px, 2.4vw, 48px);
  --home-section-pad: clamp(56px, 7vw, 128px);
  --home-section-gap: clamp(28px, 3.8vw, 72px);
  --home-card-pad: clamp(24px, 2.5vw, 44px);
}

body.home-page main > section.band:not(.home-product-band) {
  padding-block: var(--home-section-pad);
}

body.home-page main > section.band:not(.home-product-band) > .container,
body.home-page .site-footer > .container {
  width: min(var(--home-fluid-max), calc(100% - (var(--home-fluid-gutter) * 2)));
  max-width: none;
  padding-inline: 0;
  gap: var(--home-section-gap);
}

body.home-page main > section.band:not(.home-product-band) > .container[style] {
  max-width: none !important;
}

body.home-page .section-head {
  padding-bottom: clamp(22px, 2.8vw, 48px);
}

body.home-page .section-head h2 {
  max-width: min(22ch, 100%);
  font-size: clamp(40px, 4vw, 76px);
  line-height: 0.99;
  letter-spacing: 0;
}

body.home-page .arch-split,
body.home-page .next-block {
  gap: clamp(32px, 4.6vw, 92px);
}

@media (min-width: 1000px) {
  body.home-page .arch-split {
    grid-template-columns: minmax(0, 0.92fr) minmax(420px, 1.08fr);
  }
  body.home-page .arch-split.arch-split-balanced {
    grid-template-columns: minmax(0, 1fr) minmax(420px, 1fr);
  }
  body.home-page .arch-split.arch-split-wide-copy {
    grid-template-columns: minmax(500px, 1.12fr) minmax(380px, 0.88fr);
  }
  body.home-page .next-block {
    grid-template-columns: minmax(0, 1.05fr) minmax(420px, 0.95fr);
  }
}

body.home-page .triad,
body.home-page .audience-grid,
body.home-page .diff-grid,
body.home-page .vcc-grid,
body.home-page .first-person-row {
  gap: clamp(18px, 1.8vw, 34px);
  margin-top: clamp(30px, 3.6vw, 68px);
}

body.home-page .triad-card,
body.home-page .aud-card,
body.home-page .diff-card,
body.home-page .vcc-card,
body.home-page .structure-panel,
body.home-page .next-illus {
  padding: var(--home-card-pad);
}

body.home-page .editorial,
body.home-page .arch-copy,
body.home-page .next-prose,
body.home-page .prose[style] {
  max-width: min(76ch, 100%) !important;
}

body.home-page .editorial p,
body.home-page .arch-copy p,
body.home-page .next-prose p,
body.home-page .prose[style] p,
body.home-page p[style*="font-size: 19px"] {
  font-size: clamp(19px, 1.42vw, 27px) !important;
  line-height: 1.44 !important;
}

body.home-page .arch-copy p.muted,
body.home-page .next-prose p[style*="font-size: 17px"] {
  font-size: clamp(17px, 1.12vw, 21px) !important;
  line-height: 1.55 !important;
}

body.home-page .triad-card h3,
body.home-page .vcc-card h4,
body.home-page .structure-title,
body.home-page .next-illus h3 {
  font-size: clamp(23px, 2.1vw, 36px);
}

body.home-page .triad-card ul,
body.home-page .triad-card .triad-foot,
body.home-page .structure-note,
body.home-page .tertiary-list li,
body.home-page .chip {
  font-size: clamp(13.5px, 0.9vw, 16px);
}

body.home-page .aud-card p,
body.home-page .diff-card p,
body.home-page .vcc-card .v-claim,
body.home-page .before-after .side p,
body.home-page .axis-item .axis-copy {
  font-size: clamp(17px, 1.16vw, 22px);
  line-height: 1.46;
}

body.home-page .band-ink .arch-copy p { color: rgba(255, 255, 255, 0.9); }
body.home-page .band-ink .arch-copy p.muted { color: rgba(255, 255, 255, 0.78); }
body.home-page .band-ink .vcc-card--on-ink {
  background: transparent;
  border-color: rgba(255, 255, 255, 0.18);
}
body.home-page .band-ink .vcc-card--on-ink h4,
body.home-page .band-ink .vcc-card--on-ink .vcc-tagline { color: rgba(255, 255, 255, 0.9); }
body.home-page .band-ink .vcc-card--on-ink .v-claim { color: rgba(255, 255, 255, 0.78); }

body.home-page .callout[style],
body.home-page .refused[style] {
  max-width: min(90ch, 100%) !important;
}

@media (min-width: 1000px) {
  body.home-page section[data-screen-label="02 What Lucy Is"] > .container {
    grid-template-columns: minmax(0, 0.96fr) minmax(420px, 1.04fr);
    column-gap: clamp(48px, 6vw, 112px);
    align-items: end;
  }

  body.home-page section[data-screen-label="02 What Lucy Is"] > .container > .section-head {
    grid-column: 1;
  }

  body.home-page section[data-screen-label="02 What Lucy Is"] > .container > .prose {
    grid-column: 2;
    margin-top: 0 !important;
    align-self: end;
  }

  body.home-page section[data-screen-label="02 What Lucy Is"] > .container > :not(.section-head):not(.prose) {
    grid-column: 1 / -1;
  }

  body.home-page section[data-screen-label="FAQ"] .faq {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: clamp(40px, 5vw, 96px);
    border-top: 0;
  }

  body.home-page section[data-screen-label="FAQ"] .faq details {
    border-top: 1px solid rgba(11,15,42,0.16);
  }
}

@media (max-width: 760px) {
  body.home-page {
    --home-fluid-gutter: clamp(18px, 5vw, 28px);
    --home-section-pad: clamp(44px, 12vw, 72px);
  }
  body.home-page .section-head h2 {
    font-size: clamp(34px, 10vw, 46px);
    line-height: 1.03;
  }
}

/* ----- Beat 2: triad diagram ----- */
.triad {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-5);
  margin-top: var(--s-6);
}
@media (min-width: 880px) { .triad { grid-template-columns: repeat(3, 1fr); } }
.triad-card {
  border: 1px solid var(--ink-faint);
  background: #fff;
  border-radius: var(--r-card);
  padding: var(--s-6);
  display: grid; gap: var(--s-3);
  align-content: start;
  position: relative;
}
.triad-card .role {
  font-family: var(--face-ui);
  font-weight: 600;
  font-size: 11.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.triad-card.lucy { background: var(--lucy-blue); color: #fff; border-color: var(--lucy-blue-deep); }
.triad-card.lucy .role { color: rgba(255,255,255,0.8); }
.triad-card.lucy h3 { color: #fff; }
.triad-card.lucy ul li { color: rgba(255,255,255,0.92); }
.triad-card.lucy .triad-foot { color: rgba(255,255,255,0.7); border-top-color: rgba(255,255,255,0.2); }

.triad-card.human .role { color: var(--ink-soft); }
.triad-card.artifact { background: var(--paper-deep); border-color: var(--ink-faint); }
.triad-card.artifact .role { color: var(--ink-soft); }

.triad-card h3 { font-size: 22px; line-height: 1.2; }
.triad-card ul {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 6px;
  font-family: var(--face-ui);
  font-size: 14px;
  color: var(--ink);
}
.triad-card ul li::before {
  content: "—"; color: var(--ink-soft); margin-right: 8px;
}
.triad-card .triad-foot {
  margin-top: var(--s-3);
  padding-top: var(--s-3);
  border-top: 1px solid var(--ink-faint);
  font-family: var(--face-ui);
  font-size: 12.5px;
  color: var(--ink-soft);
}

/* ----- Editorial column (Beat 3) ----- */
.editorial {
  max-width: 64ch;
  display: grid; gap: var(--s-4);
}
.editorial p {
  font-family: var(--face-display);
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink);
  margin: 0;
  text-wrap: pretty;
}
.editorial p strong {
  font-weight: 600;
  background: linear-gradient(180deg, transparent 60%, rgba(232,215,184,0.55) 60%);
  padding: 0 2px;
}
.editorial .pull {
  font-family: var(--face-display);
  font-size: clamp(22px, 2.4vw, 28px);
  line-height: 1.3;
  color: var(--ink);
  font-weight: 500;
  border-left: 2px solid var(--sand-deep);
  padding: var(--s-3) var(--s-5);
  margin: var(--s-3) 0;
}

/* ----- Beat 4 audience cuts ----- */
.audience-grid {
  display: grid; grid-template-columns: 1fr; gap: var(--s-5);
  margin-top: var(--s-6);
}
@media (min-width: 880px) { .audience-grid { grid-template-columns: repeat(3, 1fr); } }
.aud-card {
  border: 1px solid var(--ink-faint);
  border-radius: var(--r-card);
  padding: var(--s-6);
  background: #fff;
  display: grid; gap: var(--s-3);
}
.aud-card .who {
  font-family: var(--face-ui);
  font-weight: 600;
  font-size: 11.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--lucy-blue);
}
.aud-card p {
  font-family: var(--face-display);
  font-size: 17px;
  line-height: 1.5;
  color: var(--ink);
  margin: 0;
  text-wrap: pretty;
}
.chip-row { display: flex; flex-wrap: wrap; gap: var(--s-3); margin-top: var(--s-6); }
.chip {
  font-family: var(--face-ui); font-size: 13.5px; font-weight: 500;
  padding: 8px 16px; border-radius: var(--r-pill);
  background: #fff; border: 1px solid var(--ink-faint);
  color: var(--ink); text-decoration: none;
  display: inline-flex; align-items: center; gap: 6px;
  transition: border-color var(--t-hover) var(--ease), color var(--t-hover) var(--ease);
}
.chip:hover { border-color: var(--lucy-blue); color: var(--lucy-blue); }

/* ----- Beat 5 differentiator panel ----- */
.diff-grid {
  display: grid; grid-template-columns: 1fr; gap: var(--s-3);
  margin-top: var(--s-6);
  counter-reset: dnum;
}
@media (min-width: 720px) { .diff-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .diff-grid { grid-template-columns: repeat(3, 1fr); } }
.diff-card {
  border: 1px solid var(--ink-faint);
  background: #fff;
  border-radius: var(--r-card);
  padding: var(--s-5) var(--s-6);
  display: grid; gap: var(--s-3); align-content: start;
  counter-increment: dnum;
  position: relative;
}
.diff-card::before {
  content: counter(dnum, decimal-leading-zero);
  font-family: var(--face-mono);
  font-size: 12px;
  color: var(--ink-soft);
  letter-spacing: 0.06em;
}
.diff-card p {
  font-family: var(--face-display);
  font-size: 17px;
  line-height: 1.45;
  color: var(--ink);
  margin: 0;
  text-wrap: pretty;
}
.diff-card.feature { background: var(--ink); border-color: var(--ink); }
.diff-card.feature::before { color: rgba(255,255,255,0.5); }
.diff-card.feature p { color: #fff; }
.diff-card.feature p strong { color: var(--lucy-blue-soft); font-weight: 500; }

/* ----- Beat 6 trust ----- */
.vcc-grid {
  display: grid; grid-template-columns: 1fr; gap: var(--s-4);
  margin-top: var(--s-6);
}
@media (min-width: 880px) { .vcc-grid { grid-template-columns: repeat(3, 1fr); } }
.vcc-card {
  border: 1px solid var(--ink-faint);
  border-radius: var(--r-card);
  background: #fff;
  padding: var(--s-6);
  display: grid; gap: var(--s-3); align-content: start;
}
.vcc-card .v-num {
  font-family: var(--face-mono); font-size: 12px; color: var(--lucy-blue);
  letter-spacing: 0.08em;
}
.vcc-card h4 { font-family: var(--face-display); font-size: 22px; font-weight: 600; color: var(--ink); }
.vcc-card .v-claim {
  font-family: var(--face-display); font-style: italic;
  font-size: 16px; color: var(--ink-muted);
}

.first-person-row {
  display: grid; grid-template-columns: 1fr; gap: var(--s-4);
  margin-top: var(--s-6);
}
@media (min-width: 880px) { .first-person-row { grid-template-columns: repeat(3, 1fr); } }

/* ----- Beat 7 next ----- */
.next-block {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-7);
  align-items: center;
}
@media (min-width: 1000px) { .next-block { grid-template-columns: 1.1fr 0.9fr; } }
.next-prose p {
  font-family: var(--face-display);
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink);
  margin: 0 0 1em;
  max-width: 56ch;
}
.tertiary-list {
  list-style: none; padding: 0; margin: var(--s-6) 0 0;
  display: grid; gap: var(--s-3);
}
.tertiary-list li {
  font-family: var(--face-ui); font-size: 14px; color: var(--ink-muted);
  display: grid; grid-template-columns: 1fr auto; gap: var(--s-3); align-items: baseline;
  padding: var(--s-3) 0;
  border-bottom: 1px solid var(--ink-faint);
}
.tertiary-list li:first-child { border-top: 1px solid var(--ink-faint); }
.tertiary-list a { color: var(--ink); text-decoration: none; font-weight: 500; }
.tertiary-list a::after { content: " →"; color: var(--ink-soft); }
.tertiary-list a:hover { color: var(--lucy-blue); }

.next-illus {
  position: relative;
  background: var(--ink);
  color: #fff;
  border-radius: var(--r-card);
  padding: var(--s-7);
  display: grid; gap: var(--s-4);
  overflow: hidden;
}
.next-illus::before {
  content: "";
  position: absolute; right: -80px; bottom: -80px;
  width: 280px; height: 280px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--lucy-blue), transparent 70%);
  opacity: 0.7; filter: blur(8px);
}
.next-illus .ni-eyebrow {
  font-family: var(--face-ui); font-weight: 600;
  font-size: 11.5px; letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  position: relative;
}
.next-illus h3 { color: #fff; font-size: 28px; line-height: 1.15; max-width: 16ch; position: relative; }
.next-illus .ni-arrow {
  position: relative;
  display: inline-flex; align-items: center; gap: 10px;
  margin-top: var(--s-4);
  font-family: var(--face-ui); font-weight: 500; font-size: 14px;
  color: var(--lucy-blue-soft);
}
.next-illus .ni-arrow span {
  display: inline-grid; place-items: center;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--lucy-blue); color: #fff;
}

/* ----- Homepage hero head + balanced grid + product-fact band (mirror EN) ----- */
.ll-home-hero-head {
  margin-bottom: clamp(10px, 1vw, 18px);
  padding-top: 12px;
}
.ll-home-hero-head .eyebrow {
  margin-bottom: 6px;
}
.ll-home-hero-head h1 {
  max-width: none;
  margin: 0;
  font-size: clamp(48px, 4.4vw, 86px);
  line-height: 0.99;
  letter-spacing: 0;
  text-wrap: pretty;
}
.ll-hero > .container {
  width: min(1880px, calc(100% - 48px));
  max-width: none;
  padding-inline: 0;
}
.ll-home-hero-grid--centered {
  align-items: center !important;
}
.ll-home-hero-grid--centered > div:first-child {
  padding-top: 0;
}
.ll-home-hero-text {
  align-self: center;
  display: grid;
  gap: clamp(34px, 4.2vw, 76px);
  max-width: 42ch;
  min-height: calc(var(--hero-demo-height) * 0.88);
  align-content: center;
}
.ll-home-hero-text p {
  margin: 0;
  font-family: var(--font-serif, var(--face-display));
  font-size: clamp(22px, 1.55vw, 31px);
  line-height: 1.31;
  color: var(--ink);
  max-width: none;
}
.ll-home-hero-text p:last-child {
  margin-bottom: 0;
}
.ll-hero.v22-hero {
  --hero-demo-height: clamp(420px, min(42vw, calc(100vh - 255px)), 800px);
  display: block;
  min-height: auto !important;
  padding-top: 0 !important;
  padding-bottom: clamp(16px, 1.7vw, 24px) !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.ll-hero-demo .ll-hero-prototype-frame {
  height: auto !important;
  aspect-ratio: 1.62 / 1;
  width: 100%;
  max-height: var(--hero-demo-height);
}
.ll-hero-demo {
  justify-self: end;
  width: min(100%, calc(var(--hero-demo-height) * 1.62));
}
.ll-home-hero-grid--centered.ll-hero-grid {
  grid-template-columns: minmax(340px, 0.38fr) minmax(0, 1fr);
  gap: clamp(16px, 1.4vw, 24px) !important;
}
@media (min-width: 1600px) {
  .ll-home-hero-text {
    margin-left: clamp(24px, 2.4vw, 48px);
  }
  .ll-home-hero-grid--centered.ll-hero-grid {
    grid-template-columns: minmax(440px, 0.38fr) minmax(0, 1fr);
    gap: clamp(24px, 2.2vw, 46px) !important;
  }
}
@media (max-width: 1240px) {
  .ll-home-hero-grid--centered.ll-hero-grid {
    grid-template-columns: 1fr;
    gap: clamp(18px, 5vw, 32px) !important;
  }
  .ll-home-hero-text {
    width: 100%;
    max-width: 100%;
    min-height: auto;
  }
  .ll-hero-demo {
    width: 100%;
    justify-self: stretch;
  }
}
section.band.home-product-band {
  background: var(--lucy-blue-soft);
  border-top: 1px solid rgba(53, 89, 242, 0.18);
  border-bottom: 1px solid rgba(53, 89, 242, 0.18);
  padding-top: clamp(10px, 1vw, 14px);
  padding-bottom: clamp(10px, 1vw, 14px);
}
.home-product-band .container {
  display: block;
  width: min(1880px, calc(100% - 48px));
  max-width: none;
  padding-inline: 0;
}
.home-product-band p {
  margin: 0;
  max-width: min(1120px, calc(100% - 300px));
  font-family: var(--face-display);
  font-size: clamp(17px, 1.15vw, 22px);
  line-height: 1.28;
  color: var(--ink);
  text-align: left;
  text-wrap: balance;
}
@media (max-width: 780px) {
  .home-product-band p { max-width: none; }
}
