/* Palanca website — extends colors_and_type.css */
@import url("./colors_and_type.css");

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html, body { overflow-x: clip; }
body { background: var(--palanca-warm-white); color: var(--palanca-body); margin: 0; font-family: var(--palanca-font-ui); }
img, svg { max-width: 100%; height: auto; display: block; }

/* ───── Layout primitives ───── */
.container { width: 100%; max-width: 76rem; margin: 0 auto; padding: 0 1.5rem; }
@media (min-width: 720px) { .container { padding: 0 2.5rem; } }
@media (min-width: 1100px) { .container { padding: 0 4rem; } }
.container-narrow { max-width: 56rem; margin: 0 auto; padding: 0 1.5rem; }
@media (min-width: 720px) { .container-narrow { padding: 0 2.5rem; } }

main { padding-bottom: 0; }
section { padding: 4rem 0; }
@media (min-width: 720px) { section { padding: 5.5rem 0; } }
@media (min-width: 1100px) { section { padding: 7rem 0; } }
section.tight { padding: 3rem 0; }
@media (min-width: 720px) { section.tight { padding: 4rem 0; } }

.section-warm { background: var(--palanca-warm-white); color: var(--palanca-body); }
.section-navy { background: var(--palanca-navy); color: var(--palanca-warm-white); }
.section-navy h1, .section-navy h2, .section-navy h3, .section-navy h4 { color: var(--palanca-warm-white); }
.section-navy .eyebrow { color: var(--palanca-copper); }
.section-navy a { color: var(--palanca-warm-white); }
.section-navy a:hover { color: var(--palanca-copper); }

/* ───── Palanca animated wordmark / lift mark ───── */
.palanca-wordmark, .palanca-liftmark { display: block; overflow: visible; }
.pl-letters.pl-anim { animation: pl-letters-fade 2.6s cubic-bezier(.22,.61,.36,1) infinite both; }
.pl-chevron.pl-anim { transform-box: fill-box; transform-origin: 50% 100%; animation: pl-chevron-rise 2.6s cubic-bezier(.22,.61,.36,1) infinite both; }
.pl-fulcrum.pl-anim { transform-box: fill-box; transform-origin: 50% 100%; animation: pl-fulcrum-pop 2.6s cubic-bezier(.22,.61,.36,1) infinite both; }
@keyframes pl-letters-fade { 0%, 8% { opacity: 0; } 58%, 100% { opacity: 1; } }
@keyframes pl-chevron-rise { 0%, 18% { transform: translateY(14px); opacity: 0; } 45% { transform: translateY(0); opacity: 1; } 72% { transform: translateY(-2px); opacity: 1; } 86%, 100% { transform: translateY(0); opacity: 1; } }
@keyframes pl-fulcrum-pop { 0%, 10% { transform: scale(0.55); opacity: 0; } 38%, 100% { transform: scale(1); opacity: 1; } }
@media (prefers-reduced-motion: reduce) { .pl-letters.pl-anim, .pl-chevron.pl-anim, .pl-fulcrum.pl-anim { animation: none !important; opacity: 1 !important; transform: none !important; } }

/* ───── Skip link ───── */
.skip { position: absolute; left: -9999px; }
.skip:focus { position: absolute; left: 1rem; top: 1rem; z-index: 100; background: var(--palanca-navy); color: var(--palanca-warm-white); padding: 0.5rem 1rem; }

/* ───── Header ───── */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(248, 246, 240, 0.92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--palanca-rule);
}
.site-header .container {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 1.1rem; padding-bottom: 1.1rem;
}
.brand-link { display: inline-flex; align-items: center; text-decoration: none; }
.brand-link img, .brand-link .palanca-wordmark { height: 2rem; width: auto; }
.nav { display: none; gap: 2rem; }
@media (min-width: 880px) { .nav { display: flex; } }
.nav a {
  font-family: var(--palanca-font-ui); font-size: 0.875rem; font-weight: 500;
  color: var(--palanca-navy); text-decoration: none;
  letter-spacing: 0.01em; padding: 0.4rem 0;
  border-bottom: 2px solid transparent;
  transition: border-color 150ms var(--ease-standard), color 150ms var(--ease-standard);
  cursor: pointer;
}
.nav a:hover, .nav a.current { border-bottom-color: var(--palanca-copper); }

.site-header .meta-line {
  display: none;
  font-family: var(--palanca-font-ui); font-size: 0.75rem;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--palanca-muted);
}
@media (min-width: 1200px) { .site-header .meta-line { display: block; } }

.mobile-toggle {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: transparent; border: 1px solid var(--palanca-navy);
  font-family: var(--palanca-font-ui); font-size: 0.75rem; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--palanca-navy); padding: 0.5rem 0.85rem; cursor: pointer;
  border-radius: 2px;
}
@media (min-width: 880px) { .mobile-toggle { display: none; } }
.nav-mobile {
  display: none; flex-direction: column; gap: 0;
  padding: 0 1.5rem 1.5rem; border-top: 1px solid var(--palanca-rule);
}
.nav-mobile.open { display: flex; }
.nav-mobile a {
  display: block; padding: 1rem 0;
  border-bottom: 1px solid var(--palanca-rule);
  font-family: var(--palanca-font-ui); font-weight: 500;
  color: var(--palanca-navy); text-decoration: none;
}

/* ───── Hero ───── */
.hero { padding-top: 5rem; padding-bottom: 4rem; }
@media (min-width: 1100px) { .hero { padding-top: 7rem; padding-bottom: 6rem; } }

.eyebrow {
  font-family: var(--palanca-font-ui); font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--palanca-copper);
  margin: 0 0 1.5rem;
}

.hero h1 {
  font-family: var(--palanca-font-editorial); font-weight: 500;
  font-size: clamp(48px, 8vw, 112px); line-height: 0.94;
  letter-spacing: -0.025em; color: var(--palanca-navy);
  margin: 0 0 2rem; max-width: 14ch; text-wrap: balance;
}
.hero h1 .accent { color: var(--palanca-copper); font-style: italic; }
.hero .lede {
  font-family: var(--palanca-font-editorial); font-weight: 400;
  font-size: clamp(20px, 2.2vw, 26px); line-height: 1.45;
  color: var(--palanca-navy); max-width: 38ch; margin: 0 0 2.5rem;
}

.hero-actions { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; }

/* Hero meta strip — datestamp + locator */
.hero-meta {
  display: grid; grid-template-columns: 1fr; gap: 1rem;
  border-top: 1px solid var(--palanca-rule);
  border-bottom: 1px solid var(--palanca-rule);
  padding: 1.25rem 0; margin-top: 4rem;
  font-family: var(--palanca-font-ui); font-size: 0.75rem;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--palanca-muted);
}
@media (min-width: 720px) { .hero-meta { grid-template-columns: repeat(2, 1fr); align-items: center; } }
@media (min-width: 1000px) { .hero-meta { grid-template-columns: repeat(4, 1fr); } }
.hero-meta .label { color: var(--palanca-navy); font-weight: 700; display: block; margin-bottom: 0.35rem; }

/* ───── Buttons ───── */
.btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-family: var(--palanca-font-ui); font-weight: 600; font-size: 0.95rem;
  padding: 0.85rem 1.6rem; text-decoration: none; cursor: pointer;
  border: 2px solid var(--palanca-navy); border-radius: 2px;
  transition: background 150ms var(--ease-standard), color 150ms var(--ease-standard), border-color 150ms var(--ease-standard);
  line-height: 1.2; letter-spacing: 0.01em;
}
.btn-primary { background: var(--palanca-navy); color: var(--palanca-warm-white); }
.btn-primary:hover { background: var(--palanca-copper); border-color: var(--palanca-copper); }
.btn-outline { background: transparent; color: var(--palanca-navy); }
.btn-outline:hover { background: var(--palanca-navy); color: var(--palanca-warm-white); }
.section-navy .btn-outline { border-color: var(--palanca-warm-white); color: var(--palanca-warm-white); }
.section-navy .btn-outline:hover { background: var(--palanca-warm-white); color: var(--palanca-navy); }
.btn .arrow { transition: transform 150ms var(--ease-standard); display: inline-block; }
.btn:hover .arrow { transform: translateX(3px); }

/* Inline link with arrow */
.in-link {
  font-family: var(--palanca-font-ui); font-weight: 600; font-size: 0.95rem;
  color: var(--palanca-navy); text-decoration: none;
  border-bottom: 1px solid var(--palanca-navy);
  padding-bottom: 2px;
  transition: color 150ms var(--ease-standard), border-color 150ms var(--ease-standard);
}
.in-link:hover { color: var(--palanca-copper); border-bottom-color: var(--palanca-copper); }
.section-navy .in-link { color: var(--palanca-warm-white); border-bottom-color: var(--palanca-warm-white); }
.section-navy .in-link:hover { color: var(--palanca-copper); border-bottom-color: var(--palanca-copper); }

/* ───── Editorial section header ───── */
.sec-hd {
  display: grid; grid-template-columns: auto 1fr auto; gap: 1.5rem;
  align-items: baseline;
  border-bottom: 1px solid currentColor; padding-bottom: 0.75rem; margin-bottom: 3.5rem;
  color: var(--palanca-navy);
}
.section-navy .sec-hd { color: var(--palanca-warm-white); }
.sec-hd .num {
  font-family: var(--palanca-font-editorial); font-weight: 500;
  font-size: 1.125rem; color: var(--palanca-copper);
  font-variant-numeric: tabular-nums;
}
.sec-hd .label {
  font-family: var(--palanca-font-ui); font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
}
.sec-hd .meta {
  font-family: var(--palanca-font-editorial); font-style: italic;
  font-size: 0.875rem; color: var(--palanca-muted);
  display: none;
}
.section-navy .sec-hd .meta { color: rgba(248, 246, 240, 0.7); }
@media (min-width: 720px) { .sec-hd .meta { display: block; } }

/* ───── Headlines ───── */
h2.display {
  font-family: var(--palanca-font-editorial); font-weight: 500;
  font-size: clamp(36px, 5.2vw, 68px); line-height: 1.02;
  letter-spacing: -0.02em; color: var(--palanca-navy);
  margin: 0 0 1.5rem; max-width: 18ch; text-wrap: balance;
}
.section-navy h2.display { color: var(--palanca-warm-white); }
h3.eyebrow-h {
  font-family: var(--palanca-font-ui); font-weight: 700; font-size: 0.875rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--palanca-navy); margin: 0 0 1rem;
}
.section-navy h3.eyebrow-h { color: var(--palanca-warm-white); }

p.lede {
  font-family: var(--palanca-font-editorial); font-size: 1.25rem;
  line-height: 1.5; color: var(--palanca-navy);
  max-width: 52ch; margin: 0 0 1rem;
}
.section-navy p.lede { color: var(--palanca-warm-white); }

p.body {
  font-family: var(--palanca-font-ui); font-size: 1.0625rem; line-height: 1.65;
  color: var(--palanca-body); max-width: 62ch; margin: 0 0 1rem;
}
.section-navy p.body { color: rgba(248, 246, 240, 0.92); }

/* ───── Drop cap intro paragraph ───── */
.dropcap-p {
  font-family: var(--palanca-font-editorial); font-size: 1.5rem;
  line-height: 1.45; color: var(--palanca-navy);
  max-width: 44ch; margin: 0;
}
.dropcap {
  float: left; font-family: var(--palanca-font-editorial);
  font-weight: 500; font-size: 96px; line-height: 0.85;
  margin: 8px 12px -4px 0; color: var(--palanca-copper);
}

/* ───── Hero photo collage ───── */
.hero-grid {
  display: grid; gap: 3rem; align-items: end;
}
@media (min-width: 1000px) {
  .hero-grid { grid-template-columns: 1.15fr 0.85fr; gap: 5rem; }
}

.hero-photos {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem;
  height: 100%;
}
.photo-frame {
  position: relative; overflow: hidden;
  background: var(--palanca-warm-white);
  border: 1px solid var(--palanca-rule);
}
.photo-frame img { width: 100%; height: 100%; object-fit: cover; display: block; }
.photo-frame .caption {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 1.5rem 1rem 0.85rem;
  font-family: var(--palanca-font-ui); font-size: 10px; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--palanca-warm-white);
  background: linear-gradient(to top, rgba(29, 53, 87, 0.8), rgba(29, 53, 87, 0));
}
.photo-frame .ph-tag {
  position: absolute; top: 0.75rem; left: 0.75rem;
  padding: 0.3rem 0.5rem;
  font-family: var(--palanca-font-ui); font-size: 9px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--palanca-warm-white); background: rgba(29, 53, 87, 0.85);
}

.photo-tall { aspect-ratio: 3 / 4; }
.photo-square { aspect-ratio: 1 / 1; }
.photo-wide { aspect-ratio: 4 / 3; }
.photo-portrait { aspect-ratio: 1 / 2; grid-row: span 2; }

/* Placeholder photo (gradient-free, just warm panel + label) */
.photo-placeholder {
  width: 100%; height: 100%;
  background-color: var(--palanca-rule);
  background-image:
    linear-gradient(135deg, rgba(180, 106, 60, 0.06) 25%, transparent 25%),
    linear-gradient(225deg, rgba(180, 106, 60, 0.06) 25%, transparent 25%),
    linear-gradient(45deg, rgba(180, 106, 60, 0.06) 25%, transparent 25%),
    linear-gradient(315deg, rgba(180, 106, 60, 0.06) 25%, transparent 25%);
  background-position: 12px 0, 12px 0, 0 0, 0 0;
  background-size: 24px 24px;
  background-repeat: repeat;
  display: flex; align-items: center; justify-content: center;
}
.photo-placeholder .ph-label {
  font-family: var(--palanca-font-ui); font-size: 10px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--palanca-navy); opacity: 0.7;
  background: rgba(248, 246, 240, 0.92); padding: 0.4rem 0.75rem;
  border: 1px solid var(--palanca-rule);
}
.photo-placeholder.placeholder-warm { background-color: #EFE6D7; }

/* Real photography */
img.photo-real {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}

/* Moodboard photo (uses moodboard.png, anchored crops) */
.photo-mood {
  background-image: url('./assets/moodboard.png');
  background-size: 320% auto;
  background-repeat: no-repeat;
  background-color: var(--palanca-rule);
}
.photo-mood.crop-a { background-position: 25% 30%; }
.photo-mood.crop-b { background-position: 75% 25%; }
.photo-mood.crop-c { background-position: 30% 75%; }
.photo-mood.crop-d { background-position: 80% 70%; }
.photo-mood.crop-e { background-position: 50% 50%; background-size: 240% auto; }
.photo-mood.crop-f { background-position: 10% 50%; }

/* ───── Two-column section ───── */
.col-2 { display: grid; gap: 2.5rem; }
@media (min-width: 880px) { .col-2 { grid-template-columns: 1fr 1fr; gap: 4rem; align-items: start; } }
.col-2.align-center { align-items: center; }
.col-2-1 { display: grid; gap: 2.5rem; }
@media (min-width: 880px) { .col-2-1 { grid-template-columns: 1.2fr 0.8fr; gap: 4rem; align-items: start; } }

.col-3 { display: grid; gap: 2rem; }
@media (min-width: 800px) { .col-3 { grid-template-columns: repeat(3, 1fr); gap: 2.5rem; } }

/* ───── Pull quote ───── */
.pull {
  font-family: var(--palanca-font-editorial); font-weight: 400;
  font-size: clamp(28px, 3.8vw, 44px); line-height: 1.18;
  color: var(--palanca-navy); margin: 0;
  border-left: 2px solid var(--palanca-copper);
  padding: 0.25rem 0 0.25rem 1.75rem;
  max-width: 26ch;
}
.section-navy .pull { color: var(--palanca-warm-white); border-left-color: var(--palanca-copper); }
.pull-cite {
  font-family: var(--palanca-font-ui); font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--palanca-copper); margin: 1.25rem 0 0;
}

/* Bleed quote — ceremonial */
.bleed-quote { padding: 6rem 0; text-align: center; }
.bleed-quote blockquote {
  font-family: var(--palanca-font-editorial); font-weight: 500;
  font-size: clamp(32px, 4.5vw, 56px); line-height: 1.15;
  color: var(--palanca-navy); max-width: 22ch; margin: 0 auto;
  letter-spacing: -0.01em;
}
.bleed-quote .cite {
  font-family: var(--palanca-font-ui); font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--palanca-copper); margin-top: 2rem;
}

/* ───── Service / program rows ───── */
.row-list { border-top: 1px solid var(--palanca-rule); }
.row-list-item {
  display: grid; gap: 0.5rem 1.5rem;
  padding: 2rem 0; border-bottom: 1px solid var(--palanca-rule);
  grid-template-columns: 1fr;
  transition: background 200ms var(--ease-standard);
  cursor: pointer; position: relative;
}
.row-list-item:hover { background: rgba(180, 106, 60, 0.04); }
@media (min-width: 800px) {
  .row-list-item {
    grid-template-columns: auto 2.4fr 1fr auto;
    align-items: baseline; padding: 2.25rem 0;
  }
}
.row-num {
  font-family: var(--palanca-font-editorial); font-weight: 500;
  font-size: 1rem; color: var(--palanca-copper);
  font-variant-numeric: tabular-nums; min-width: 2.5rem;
}
.row-name {
  font-family: var(--palanca-font-editorial); font-weight: 500;
  font-size: clamp(22px, 2.5vw, 30px); line-height: 1.15;
  color: var(--palanca-navy); margin: 0;
}
.section-navy .row-list { border-top-color: rgba(248, 246, 240, 0.2); }
.section-navy .row-list-item { border-bottom-color: rgba(248, 246, 240, 0.2); }
.section-navy .row-name { color: var(--palanca-warm-white); }
.row-dek {
  grid-column: 1 / -1;
  font-family: var(--palanca-font-ui); font-size: 0.95rem; line-height: 1.55;
  color: var(--palanca-muted); margin: 0; max-width: 70ch;
}
@media (min-width: 800px) { .row-dek { grid-column: 2 / 3; margin-top: 0.4rem; } }
.row-meta {
  font-family: var(--palanca-font-ui); font-size: 0.75rem; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--palanca-muted);
}
.row-arrow {
  font-family: var(--palanca-font-editorial); font-size: 1.25rem;
  color: var(--palanca-copper); opacity: 0; transition: opacity 200ms var(--ease-standard);
}
.row-list-item:hover .row-arrow { opacity: 1; }
/* Phone: tighten engagement rows — no empty arrow row, smaller padding */
@media (max-width: 799px) {
  .row-list-item { padding: 1.5rem 0; gap: 0.35rem 1rem; grid-template-columns: auto 1fr; align-items: baseline; }
  .row-list-item > div:nth-child(2) { grid-column: 2; }
  .row-dek { grid-column: 2; }
  .row-meta { grid-column: 2; margin-top: 0.35rem; }
  .row-arrow { display: none; }
}

/* ───── Numbered ledger card (case study) ───── */
.ledger {
  padding: 3rem 0; border-top: 1px solid var(--palanca-rule);
}
.ledger:last-child { border-bottom: 1px solid var(--palanca-rule); }
.ledger-head { display: flex; align-items: baseline; gap: 1.5rem; margin-bottom: 2rem; flex-wrap: wrap; }
.ledger-num {
  font-family: var(--palanca-font-editorial); font-weight: 500;
  font-size: 3rem; color: var(--palanca-copper); line-height: 1;
  font-variant-numeric: tabular-nums;
}
.ledger-label {
  font-family: var(--palanca-font-editorial); font-weight: 500;
  font-size: clamp(24px, 2.6vw, 32px); color: var(--palanca-navy); line-height: 1.15;
}
.ledger-meta {
  font-family: var(--palanca-font-ui); font-size: 0.75rem; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--palanca-muted);
  margin-left: auto;
}
@media (max-width: 599px) { .ledger-head { gap: 1rem; } .ledger-meta { margin-left: 0; width: 100%; } }
.ledger-grid { display: grid; gap: 2rem; }
@media (min-width: 880px) { .ledger-grid { grid-template-columns: repeat(3, 1fr); gap: 3rem; } }
.ledger-col-head {
  font-family: var(--palanca-font-ui); font-size: 0.7rem; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--palanca-copper);
  border-top: 1px solid var(--palanca-copper); padding-top: 0.85rem; margin-bottom: 0.85rem;
}
.ledger-col-body {
  font-family: var(--palanca-font-editorial); font-size: 1.0625rem; line-height: 1.55;
  color: var(--palanca-navy);
}

/* ───── Three-meanings rail (navy) ───── */
.meanings { display: grid; gap: 0; counter-reset: meaning; }
@media (min-width: 800px) { .meanings { grid-template-columns: repeat(3, 1fr); } }
.meaning {
  padding: 2.5rem 0;
  border-top: 1px solid rgba(248, 246, 240, 0.2);
  counter-increment: meaning;
}
@media (min-width: 800px) {
  .meaning { padding: 3rem 2rem; border-top: none; }
  .meaning + .meaning { border-left: 1px solid rgba(248, 246, 240, 0.2); }
  .meaning:first-child { padding-left: 0; }
  .meaning:last-child { padding-right: 0; }
}
.meaning::before {
  content: counter(meaning, decimal-leading-zero);
  font-family: var(--palanca-font-editorial); font-weight: 500;
  font-size: 0.875rem; color: var(--palanca-copper);
  letter-spacing: 0.08em; display: block;
}
.meaning-word {
  font-family: var(--palanca-font-editorial); font-style: italic; font-weight: 500;
  font-size: 2.5rem; color: var(--palanca-warm-white);
  line-height: 1; margin: 0.4rem 0 1rem;
  letter-spacing: -0.01em;
}
.meaning-body {
  font-family: var(--palanca-font-editorial); font-size: 1.0625rem;
  line-height: 1.55; color: rgba(248, 246, 240, 0.92);
  max-width: 38ch;
}

/* ───── Lift Report mock ───── */
.lift-section { display: grid; gap: 3rem; align-items: center; }
@media (min-width: 900px) { .lift-section { grid-template-columns: 1fr 1fr; gap: 4rem; } }
.lift-mock {
  aspect-ratio: 8.5 / 11; background: var(--palanca-warm-white);
  border: 1px solid var(--palanca-rule);
  padding: 2.5rem 2rem; display: flex; flex-direction: column;
  box-shadow: 0 25px 60px -28px rgba(29, 53, 87, 0.45);
  position: relative; max-width: 480px; width: 100%;
}
.lift-mock .lm-logo { height: 22px; margin-bottom: 1.75rem; }
.lift-mock .lm-eyebrow {
  font-family: var(--palanca-font-ui); font-size: 9px; font-weight: 700;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--palanca-copper);
}
.lift-mock .lm-title {
  font-family: var(--palanca-font-editorial); font-weight: 500;
  font-size: clamp(26px, 8.5vw, 38px); line-height: 1; color: var(--palanca-navy);
  margin: 0.5rem 0 1.25rem; letter-spacing: -0.01em;
}
@media (max-width: 480px) { .lift-mock { padding: 1.75rem 1.5rem; } .lift-mock .lm-stamp { bottom: 1.5rem; right: 1.5rem; } }
.lift-mock .lm-rule { width: 2.25rem; height: 2px; background: var(--palanca-copper); margin-bottom: 1.25rem; }
.lift-mock .lm-meta {
  font-family: var(--palanca-font-ui); font-size: 9px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--palanca-muted); margin-bottom: 0.25rem;
}
.lift-mock .lm-client {
  font-family: var(--palanca-font-editorial); font-size: 1.25rem;
  color: var(--palanca-navy); margin: 0 0 0.5rem; font-weight: 500;
}
.lift-mock .lm-toc {
  margin-top: 1.5rem; padding: 1rem 0;
  border-top: 1px solid var(--palanca-rule);
  border-bottom: 1px solid var(--palanca-rule);
}
.lift-mock .lm-toc-item {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 0.4rem 0;
  font-family: var(--palanca-font-editorial); font-size: 11px;
  color: var(--palanca-navy);
}
.lift-mock .lm-toc-item .pg {
  font-family: var(--palanca-font-ui); font-size: 9px; letter-spacing: 0.16em;
  color: var(--palanca-copper); font-variant-numeric: tabular-nums;
}
.lift-mock .lm-tagline {
  margin-top: auto; padding-top: 1.5rem;
  font-family: var(--palanca-font-editorial); font-style: italic;
  font-size: 12px; color: var(--palanca-navy);
}
.lift-mock .lm-stamp {
  position: absolute; bottom: 2rem; right: 2rem;
  font-family: var(--palanca-font-ui); font-size: 9px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--palanca-copper);
  border: 1px solid var(--palanca-copper); padding: 0.3rem 0.5rem;
  transform: rotate(-4deg);
}

/* ───── Stat row (navy) ───── */
.stats {
  display: grid; gap: 0;
  border-top: 1px solid rgba(248, 246, 240, 0.2);
  border-bottom: 1px solid rgba(248, 246, 240, 0.2);
}
@media (min-width: 720px) { .stats { grid-template-columns: repeat(3, 1fr); } }
.stat { padding: 2rem 0; }
@media (min-width: 720px) {
  .stat { padding: 2.5rem 2.5rem; }
  .stat:first-child { padding-left: 0; }
  .stat:last-child { padding-right: 0; }
  .stat + .stat { border-left: 1px solid rgba(248, 246, 240, 0.2); }
}
.stat-num {
  font-family: var(--palanca-font-editorial); font-weight: 500;
  font-size: clamp(64px, 9vw, 112px); line-height: 0.85;
  color: var(--palanca-warm-white); letter-spacing: -0.025em;
  display: flex; align-items: baseline; gap: 0.15rem;
}
.stat-num .unit { color: var(--palanca-copper); font-style: italic; font-size: 0.4em; }
.stat-label {
  font-family: var(--palanca-font-ui); font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(248, 246, 240, 0.78); margin-top: 1rem; max-width: 24ch;
}

/* ───── Index list ───── */
.index { list-style: none; padding: 0; margin: 0; border-top: 1px solid var(--palanca-rule); }
.index li {
  display: grid; grid-template-columns: auto 1fr auto; align-items: baseline; gap: 1rem;
  padding: 1.1rem 0; border-bottom: 1px solid var(--palanca-rule);
}
.idx-num {
  font-family: var(--palanca-font-editorial); font-weight: 500;
  font-size: 0.875rem; color: var(--palanca-copper);
  font-variant-numeric: tabular-nums;
}
.idx-title {
  font-family: var(--palanca-font-editorial); font-size: 1.125rem;
  color: var(--palanca-navy); font-weight: 500;
}
.idx-meta {
  font-family: var(--palanca-font-ui); font-size: 0.75rem; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--palanca-muted);
}
/* Phone: let the title breathe, meta drops below it */
@media (max-width: 599px) {
  .index li { grid-template-columns: auto 1fr; gap: 0.25rem 1rem; }
  .idx-meta { grid-column: 2; }
}

/* ───── Editorial duo (oversized italic + prose) ───── */
.editorial-duo { display: grid; gap: 2.5rem; align-items: center; }
@media (min-width: 1000px) { .editorial-duo { grid-template-columns: 1fr 1fr; gap: 5rem; } }
.editorial-word {
  font-family: var(--palanca-font-editorial); font-weight: 500; font-style: italic;
  font-size: clamp(44px, 7vw, 96px); line-height: 0.85;
  color: var(--palanca-navy); letter-spacing: -0.04em; margin: 0;
  max-width: 100%;
}
.editorial-word .period { color: var(--palanca-copper); font-style: normal; }
.section-navy .editorial-word { color: var(--palanca-warm-white); }

/* ───── Logo strip (sponsors/partners) ───── */
.logo-strip {
  display: grid; gap: 1.5rem 2.5rem;
  grid-template-columns: repeat(2, 1fr);
  align-items: center; padding: 2.5rem 0;
}
@media (min-width: 720px) { .logo-strip { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1000px) { .logo-strip { grid-template-columns: repeat(6, 1fr); } }
.logo-cell {
  height: 64px; display: flex; align-items: center; justify-content: center;
  font-family: var(--palanca-font-editorial); font-size: 1.05rem;
  color: var(--palanca-navy); font-weight: 500; letter-spacing: -0.005em;
  border-bottom: 1px solid var(--palanca-rule);
}

/* ───── Lever diagram (engineering plate) ───── */
.lever-plate { margin: 0; max-width: 540px; }
.lever-diagram { width: 100%; height: auto; display: block; }
.lever-caption {
  display: grid; grid-template-columns: auto 1fr; gap: 1.25rem;
  padding-top: 1rem; margin-top: 1rem;
  border-top: 1px solid rgba(248, 246, 240, 0.25);
}
.section-warm .lever-caption { border-top-color: var(--palanca-rule); }
.lc-label {
  font-family: var(--palanca-font-ui); font-size: 0.7rem; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--palanca-copper); padding-top: 2px;
}
.lc-text {
  font-family: var(--palanca-font-editorial); font-size: 0.9375rem;
  line-height: 1.5; color: rgba(248, 246, 240, 0.8);
}
.section-warm .lc-text { color: var(--palanca-muted); }

/* ───── Form ───── */
.form-grid { display: grid; gap: 1.25rem; max-width: 36rem; width: 100%; min-width: 0; }
.form-row { display: flex; flex-direction: column; gap: 0.4rem; min-width: 0; }
.form-row.row-2 { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 600px) { .form-row.row-2 { grid-template-columns: 1fr 1fr; } }
.form-row input, .form-row textarea, .form-row select { width: 100%; min-width: 0; max-width: 100%; }
.form-row label {
  font-family: var(--palanca-font-ui); font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--palanca-navy);
}
.form-row input, .form-row textarea, .form-row select {
  font-family: var(--palanca-font-ui); font-size: 1rem; color: var(--palanca-body);
  background: transparent; border: 0; border-bottom: 1px solid var(--palanca-navy);
  padding: 0.5rem 0; line-height: 1.5;
  border-radius: 0; outline: none;
  transition: border-color 150ms var(--ease-standard);
}
.form-row input:focus, .form-row textarea:focus, .form-row select:focus { border-color: var(--palanca-copper); }
.form-row textarea { min-height: 120px; resize: vertical; }
.form-row .help { font-family: var(--palanca-font-ui); font-size: 0.75rem; color: var(--palanca-muted); }

/* ───── Footer ───── */
.site-footer {
  background: var(--palanca-navy); color: var(--palanca-warm-white);
  padding: 5rem 0 2.5rem; margin-top: 0;
}
.site-footer a { color: var(--palanca-warm-white); text-decoration: none; }
.site-footer a:hover { color: var(--palanca-copper); }
.footer-tagline-block { display: grid; gap: 1.5rem; align-items: end; padding-bottom: 4rem; border-bottom: 1px solid rgba(248, 246, 240, 0.18); margin-bottom: 3rem; }
@media (min-width: 880px) { .footer-tagline-block { grid-template-columns: 2fr 1fr; gap: 3rem; } }
.footer-tag {
  font-family: var(--palanca-font-editorial); font-weight: 500;
  font-size: clamp(36px, 5.5vw, 80px); line-height: 0.95;
  color: var(--palanca-warm-white); letter-spacing: -0.02em; margin: 0;
  max-width: 14ch; text-wrap: balance;
}
.footer-tag .accent { color: var(--palanca-copper); font-style: italic; }
.footer-action {
  font-family: var(--palanca-font-ui); font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase; color: rgba(248, 246, 240, 0.7);
  margin: 0 0 1rem;
}

.footer-grid { display: grid; gap: 2.5rem; }
@media (min-width: 600px) { .footer-grid { grid-template-columns: 1fr 1fr; } .footer-grid > .footer-mark { grid-column: 1 / -1; } }
@media (min-width: 1000px) { .footer-grid { grid-template-columns: 1.5fr 1fr 1fr 1fr; } .footer-grid > .footer-mark { grid-column: auto; } }
.footer-mark img { height: 2.25rem; margin-bottom: 1.5rem; }
.footer-tagline {
  font-family: var(--palanca-font-editorial); font-style: italic;
  font-size: 1rem; color: rgba(248, 246, 240, 0.88); max-width: 26ch;
}
.footer-heading {
  font-family: var(--palanca-font-ui); font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.18em; font-size: 0.7rem;
  color: var(--palanca-copper); margin: 0 0 1rem;
}
.footer-list { list-style: none; padding: 0; margin: 0; }
.footer-list li { margin-bottom: 0.6rem; font-size: 0.95rem; font-family: var(--palanca-font-ui); }
.footer-bottom {
  border-top: 1px solid rgba(248, 246, 240, 0.18);
  margin-top: 3.5rem; padding-top: 1.5rem;
  display: flex; flex-wrap: wrap; gap: 1rem;
  justify-content: space-between;
  font-family: var(--palanca-font-ui); font-size: 0.75rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(248, 246, 240, 0.6);
}

/* ───── Scroll-reveal ───── */
.reveal { opacity: 0; transform: translateY(12px); transition: opacity 600ms var(--ease-standard), transform 600ms var(--ease-standard); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* ───── Page hero ───── */
.page-hero { padding: 5rem 0 3rem; }
@media (min-width: 1100px) { .page-hero { padding: 7rem 0 4rem; } }
.page-hero h1 {
  font-family: var(--palanca-font-editorial); font-weight: 500;
  font-size: clamp(40px, 6.5vw, 88px); line-height: 0.96;
  letter-spacing: -0.025em; color: var(--palanca-navy);
  margin: 0 0 1.5rem; max-width: 16ch; text-wrap: balance;
}
.page-hero .lede {
  font-family: var(--palanca-font-editorial); font-size: clamp(18px, 1.8vw, 22px);
  line-height: 1.5; color: var(--palanca-navy); max-width: 48ch;
}

/* ───── Print badge / chip ───── */
.chip {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-family: var(--palanca-font-ui); font-size: 0.7rem; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--palanca-navy); background: transparent;
  border: 1px solid var(--palanca-navy); padding: 0.35rem 0.6rem;
  border-radius: 2px;
}
.chip.copper { color: var(--palanca-copper); border-color: var(--palanca-copper); }
.section-navy .chip { color: var(--palanca-warm-white); border-color: var(--palanca-warm-white); }
.section-navy .chip.copper { color: var(--palanca-copper); border-color: var(--palanca-copper); }

/* ───── HR ───── */
hr.copper { border: 0; border-top: 2px solid var(--palanca-copper); width: 3rem; margin: 1.5rem 0; }
hr.rule { border: 0; border-top: 1px solid var(--palanca-rule); margin: 3rem 0; }
.section-navy hr.rule { border-top-color: rgba(248, 246, 240, 0.2); }

/* ───── Responsive key/value rows (contact details, founder note) ───── */
.kv-row {
  display: grid; grid-template-columns: 1fr; gap: 0.5rem 1.5rem;
  padding: 1.25rem 0; border-bottom: 1px solid var(--palanca-rule);
  align-items: baseline;
}
@media (min-width: 600px) { .kv-row { grid-template-columns: 10rem 1fr; } }

.founder-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem 2rem; align-items: baseline; }
@media (min-width: 720px) { .founder-grid { grid-template-columns: auto 1fr; } }

/* ───── Tweaks panel — slot ───── */
[data-tweaks-root] { font-family: var(--palanca-font-ui); }
