:root {
  --ink: #161514;
  --muted: #6f6a63;
  --paper: #f4f0e7;
  --paper-deep: #e8e0d2;
  --white: #fffdf8;
  --line: rgba(22, 21, 20, .14);
  --red: #9f2f24;
  --gold: #9b7b4f;
  --shadow: 0 24px 80px rgba(36, 28, 18, .12);
  --serif: "Noto Serif SC", Georgia, serif;
  --sans: "Manrope", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background:
    radial-gradient(circle at top right, rgba(159, 47, 36, .06), transparent 34rem),
    var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }

.page-shell { overflow: hidden; }

.site-header {
  width: min(1240px, calc(100% - 40px));
  margin: 0 auto;
  min-height: 86px;
  display: grid;
  grid-template-columns: minmax(250px, 1fr) auto minmax(180px, 1fr);
  align-items: center;
  border-bottom: 1px solid var(--line);
}
.brand { display: flex; align-items: center; gap: 14px; }
.brand-mark { font-size: .86rem; font-weight: 800; letter-spacing: .14em; white-space: nowrap; }
.brand-sub { font-size: .72rem; color: var(--muted); letter-spacing: .12em; text-transform: uppercase; }
.nav-links { display: flex; align-items: center; gap: 30px; font-size: .8rem; }
.nav-links a { color: var(--muted); transition: color .2s ease; }
.nav-links a:hover { color: var(--ink); }
.nav-cta {
  justify-self: end;
  padding: 11px 17px;
  border: 1px solid var(--ink);
  font-size: .76rem;
  font-weight: 700;
  letter-spacing: .02em;
}

.hero {
  width: min(1240px, calc(100% - 40px));
  min-height: 760px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.03fr .97fr;
  align-items: center;
  gap: 56px;
  padding: 80px 0 90px;
}
.eyebrow, .kicker {
  display: inline-block;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .17em;
  color: var(--red);
}
.hero h1 {
  margin: 22px 0 24px;
  font-size: clamp(3.6rem, 7vw, 7.4rem);
  line-height: .97;
  letter-spacing: -.055em;
  font-weight: 500;
}
.hero h1 span {
  display: inline-block;
  font-family: var(--serif);
  font-size: .58em;
  font-weight: 500;
  letter-spacing: -.035em;
  margin-top: 15px;
}
.hero-lead {
  max-width: 690px;
  font-size: 1.05rem;
  color: var(--muted);
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 34px; }
.button {
  display: inline-flex;
  min-height: 50px;
  align-items: center;
  justify-content: center;
  padding: 0 22px;
  border: 1px solid var(--ink);
  font-size: .84rem;
  font-weight: 700;
  cursor: pointer;
  transition: transform .2s ease, background .2s ease, color .2s ease;
}
.button:hover { transform: translateY(-2px); }
.button-primary { background: var(--ink); color: var(--white); }
.button-secondary { background: transparent; color: var(--ink); }
.full-width { width: 100%; }
.hero-proof {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 28px;
  margin-top: 28px;
  color: var(--muted);
  font-size: .75rem;
}
.hero-proof span::before { content: "— "; color: var(--red); }

.hero-visual {
  position: relative;
  min-height: 590px;
  display: grid;
  place-items: center;
}
.orbit {
  position: absolute;
  border: 1px solid rgba(159, 47, 36, .16);
  border-radius: 50%;
}
.orbit-one { width: 510px; height: 510px; }
.orbit-two { width: 380px; height: 380px; transform: rotate(36deg); border-style: dashed; }
.pillar-grid {
  position: relative;
  z-index: 2;
  width: min(100%, 470px);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: rgba(255, 253, 248, .86);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}
.pillar {
  min-height: 250px;
  padding: 28px 16px;
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  align-items: center;
}
.pillar:last-child { border-right: 0; }
.pillar span { font-size: .58rem; color: var(--muted); letter-spacing: .14em; }
.pillar strong {
  font-family: var(--serif);
  writing-mode: vertical-rl;
  font-size: 2.25rem;
  letter-spacing: .24em;
  margin: 25px 0;
  font-weight: 600;
}
.pillar small { font-size: .68rem; color: var(--muted); margin-top: auto; }
.pillar.active { background: var(--ink); color: var(--white); transform: translateY(-14px); }
.pillar.active span, .pillar.active small { color: rgba(255,255,255,.64); }
.chart-caption {
  position: absolute;
  z-index: 3;
  left: 10px;
  bottom: 54px;
  width: 205px;
  padding: 15px 17px;
  background: rgba(255, 253, 248, .94);
  border: 1px solid var(--line);
  box-shadow: 0 12px 30px rgba(23, 22, 20, .10);
  backdrop-filter: blur(8px);
}
.chart-caption span { display: block; color: var(--red); font-size: .53rem; font-weight: 700; letter-spacing: .14em; }
.chart-caption strong { display: block; margin-top: 6px; font-size: .74rem; letter-spacing: .08em; }
.chart-caption small { display: block; margin-top: 4px; color: var(--muted); font-size: .58rem; }
.signal-card {
  position: absolute;
  z-index: 3;
  right: 0;
  bottom: 42px;
  width: 292px;
  padding: 22px;
  background: var(--red);
  color: #fff;
  box-shadow: 0 18px 44px rgba(94, 24, 18, .28);
}
.signal-label { font-size: .58rem; letter-spacing: .14em; opacity: .74; }
.signal-card strong { display: block; margin: 8px 0 4px; font-size: 1.55rem; }
.signal-card p { margin: 0; font-size: .76rem; opacity: .85; }

.decision-strip {
  background: var(--ink);
  color: var(--white);
  padding: 26px max(20px, calc((100vw - 1240px)/2));
}
.decision-strip p {
  margin: 0 0 14px;
  font-family: var(--serif);
  font-size: 1.15rem;
}
.decision-items {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 25px;
  font-size: .72rem;
  color: rgba(255,255,255,.58);
  text-transform: uppercase;
  letter-spacing: .08em;
}

.section {
  width: min(1240px, calc(100% - 40px));
  margin: 0 auto;
  padding: 120px 0;
}
.section-heading {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  align-items: end;
  gap: 70px;
  margin-bottom: 66px;
}
.section-heading h2, .method-intro h2, .fit-card h2, .intake-copy h2, .faq-heading h2, .closing-cta h2 {
  margin: 12px 0 0;
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(2.4rem, 5vw, 4.8rem);
  line-height: 1.08;
  letter-spacing: -.04em;
}
.section-heading p, .method-intro p, .intake-copy p {
  margin: 0;
  color: var(--muted);
}

.report-layout {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 72px;
  align-items: start;
}
.report-preview {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 560px;
  box-shadow: var(--shadow);
  transform: rotate(-1deg);
}
.report-cover {
  background: var(--ink);
  color: var(--white);
  padding: 35px;
  display: flex;
  flex-direction: column;
}
.report-cover p { margin: 50px 0 18px; font-size: .58rem; letter-spacing: .18em; color: rgba(255,255,255,.55); }
.report-cover h3 { margin: 0; font-family: var(--serif); font-size: 2.1rem; font-weight: 500; line-height: 1.15; }
.cover-meta { margin-top: auto; display: flex; justify-content: space-between; font-size: .58rem; color: rgba(255,255,255,.5); }
.mini-logo { font-size: .68rem; font-weight: 800; letter-spacing: .14em; white-space: nowrap; }
.report-page {
  position: relative;
  background: var(--white);
  padding: 48px 36px;
}
.page-number { position: absolute; top: 22px; right: 24px; color: var(--muted); font-size: .65rem; }
.chapter { color: var(--red); font-size: .6rem; letter-spacing: .16em; }
.report-page h4 { margin: 40px 0 24px; font-family: var(--serif); font-size: 1.65rem; line-height: 1.2; font-weight: 500; }
.report-page p { font-size: .78rem; color: var(--muted); }
.redline { width: 74px; height: 3px; background: var(--red); margin-top: 36px; }

.report-index { border-top: 1px solid var(--line); }
.report-index article {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 22px;
  padding: 22px 0;
  border-bottom: 1px solid var(--line);
}
.report-index article > span { color: var(--red); font-size: .72rem; font-weight: 700; }
.report-index h3 { margin: 0 0 6px; font-size: 1rem; }
.report-index p { margin: 0; color: var(--muted); font-size: .82rem; }

.method-section {
  display: grid;
  grid-template-columns: .75fr 1.25fr;
  gap: 90px;
}
.method-intro { position: sticky; top: 40px; align-self: start; }
.method-intro p { margin-top: 30px; }
.method-steps { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--line); }
.method-steps article {
  min-height: 250px;
  padding: 26px 28px;
  border-bottom: 1px solid var(--line);
  border-right: 1px solid var(--line);
}
.method-steps article:nth-child(even) { border-right: 0; }
.step-num { color: var(--red); font-size: .65rem; font-weight: 700; }
.method-steps h3 { margin: 42px 0 12px; font-family: var(--serif); font-size: 1.35rem; font-weight: 500; }
.method-steps p { color: var(--muted); font-size: .82rem; }

.fit-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}
.fit-card {
  min-height: 510px;
  padding: 48px;
  background: var(--white);
  border: 1px solid var(--line);
}
.fit-card-dark { background: var(--ink); color: var(--white); }
.fit-card h2 { font-size: clamp(2.1rem, 4vw, 3.4rem); }
.fit-card ul { margin: 44px 0 0; padding: 0; list-style: none; }
.fit-card li { padding: 14px 0; border-bottom: 1px solid currentColor; border-color: rgba(127,127,127,.25); font-size: .86rem; }

.pricing-section { padding-top: 70px; }
.pricing-grid {
  max-width: 980px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.price-card {
  position: relative;
  min-height: 620px;
  padding: 42px;
  display: flex;
  flex-direction: column;
  border: 1px solid var(--line);
  background: var(--white);
}
.price-card.featured { background: var(--ink); color: var(--white); transform: translateY(-18px); }
.recommended {
  position: absolute;
  top: 0;
  right: 0;
  background: var(--red);
  color: #fff;
  padding: 9px 12px;
  font-size: .58rem;
  font-weight: 700;
  letter-spacing: .12em;
}
.plan { font-size: .68rem; letter-spacing: .15em; color: var(--red); font-weight: 700; }
.price { margin-top: 24px; font-size: 5rem; line-height: 1; letter-spacing: -.06em; }
.price sup { font-size: 1rem; vertical-align: top; margin-right: 7px; }
.price-note { color: var(--muted); font-size: .72rem; }
.featured .price-note { color: rgba(255,255,255,.5); }
.price-card ul { margin: 42px 0; padding: 0; list-style: none; flex: 1; }
.price-card li { padding: 13px 0; border-bottom: 1px solid var(--line); font-size: .84rem; }
.featured .price-card li { border-color: rgba(255,255,255,.12); }
.featured .button-primary { background: var(--white); color: var(--ink); border-color: var(--white); }
.pricing-footnote {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 14px 28px;
  margin-top: 44px;
  font-size: .68rem;
  color: var(--muted);
}

.intake-section {
  display: grid;
  grid-template-columns: .78fr 1.22fr;
  gap: 80px;
  align-items: start;
}
.intake-copy { position: sticky; top: 40px; }
.intake-copy p { margin-top: 28px; }
.intake-form {
  padding: 42px;
  background: var(--white);
  border: 1px solid var(--line);
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
label { display: block; margin-bottom: 18px; font-size: .74rem; font-weight: 700; }
input, textarea, select {
  width: 100%;
  margin-top: 8px;
  padding: 14px;
  border: 1px solid var(--line);
  background: #fbf8f1;
  color: var(--ink);
  outline: none;
}
input:focus, textarea:focus, select:focus { border-color: var(--red); }
.consent { display: flex; gap: 12px; align-items: flex-start; font-weight: 500; color: var(--muted); }
.consent input { width: auto; margin-top: 5px; }
.form-status { min-height: 22px; margin: 12px 0 0; font-size: .75rem; color: var(--red); }

.faq-section {
  display: grid;
  grid-template-columns: .6fr 1.4fr;
  gap: 90px;
}
.faq-list { border-top: 1px solid var(--line); }
details { border-bottom: 1px solid var(--line); padding: 22px 0; }
summary { cursor: pointer; font-weight: 700; list-style: none; }
summary::-webkit-details-marker { display: none; }
summary::after { content: "+"; float: right; color: var(--red); }
details[open] summary::after { content: "–"; }
details p { max-width: 740px; color: var(--muted); font-size: .84rem; }

.closing-cta {
  width: 100%;
  padding: 110px 20px;
  text-align: center;
  background: var(--red);
  color: #fff;
}
.closing-cta .kicker { color: rgba(255,255,255,.66); }
.closing-cta h2 { max-width: 1000px; margin: 24px auto 38px; font-size: clamp(2.4rem, 5vw, 4.6rem); }
.closing-cta .button-primary { background: var(--white); color: var(--ink); border-color: var(--white); }

footer {
  width: min(1240px, calc(100% - 40px));
  margin: 0 auto;
  padding: 44px 0;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  border-top: 1px solid var(--line);
}
footer p { color: var(--muted); font-size: .72rem; }
.footer-links { display: flex; gap: 22px; font-size: .72rem; }
.copyright { grid-column: 1 / -1; margin: 0; }

@media (max-width: 980px) {
  .site-header { grid-template-columns: 1fr auto; }
  .nav-links { display: none; }
  .hero { grid-template-columns: 1fr; padding-top: 70px; }
  .hero-visual { min-height: 520px; }
  .section-heading, .report-layout, .method-section, .intake-section, .faq-section { grid-template-columns: 1fr; }
  .method-intro, .intake-copy { position: static; }
  .fit-section { grid-template-columns: 1fr; }
  .section-heading { gap: 24px; }
}
@media (max-width: 720px) {
  .brand-sub, .nav-cta { display: none; }
  .site-header { min-height: 70px; }
  .hero { width: min(100% - 28px, 1240px); min-height: 0; padding: 52px 0 70px; }
  .hero h1 { font-size: 3.35rem; }
  .hero-proof { display: grid; gap: 9px; }
  .hero-visual { min-height: 440px; }
  .orbit-one { width: 360px; height: 360px; }
  .orbit-two { width: 260px; height: 260px; }
  .pillar-grid { width: 100%; }
  .pillar { min-height: 205px; padding: 22px 8px; }
  .pillar strong { font-size: 1.65rem; }
  .signal-card { width: 230px; right: 0; bottom: 16px; }
  .section { width: min(100% - 28px, 1240px); padding: 82px 0; }
  .section-heading { margin-bottom: 42px; }
  .report-preview { grid-template-columns: 1fr; transform: none; }
  .report-page { min-height: 380px; }
  .method-steps, .pricing-grid, .form-row { grid-template-columns: 1fr; }
  .method-steps article { border-right: 0; }
  .fit-card, .price-card, .intake-form { padding: 30px 24px; }
  .price-card.featured { transform: none; }
  .faq-section { gap: 32px; }
  footer { grid-template-columns: 1fr; }
  .footer-links { flex-wrap: wrap; }
}


/* Pillar Folio brand and historical chart refinements */
@media (max-width: 760px) {
  .brand { gap: 8px; }
  .brand-mark { font-size: .76rem; letter-spacing: .1em; }
  .brand-sub { display: none; }
  .hero-visual {
    display: block;
    min-height: 0;
    padding-top: 92px;
  }
  .pillar-grid { margin: 0 auto; }
  .chart-caption,
  .signal-card {
    position: relative;
    left: auto;
    right: auto;
    bottom: auto;
    width: 100%;
  }
  .chart-caption { margin-top: 14px; }
  .signal-card { margin-top: 12px; }
}

/* Production-readiness additions */
.skip-link {
  position: fixed;
  top: 10px;
  left: 10px;
  z-index: 1000;
  transform: translateY(-160%);
  padding: 10px 14px;
  background: var(--ink);
  color: var(--white);
  font-size: .76rem;
  font-weight: 700;
}
.skip-link:focus { transform: translateY(0); }

:focus-visible {
  outline: 3px solid rgba(159, 47, 36, .42);
  outline-offset: 3px;
}

.inline-link,
.text-link {
  color: var(--red);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
}
.text-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .8rem;
  font-weight: 700;
}
.preview-action {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 18px;
  margin-top: 22px;
}
.preview-action small { color: var(--muted); font-size: .66rem; text-align: right; }

.closing-actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
}
.button-ghost {
  color: #fff;
  border-color: rgba(255,255,255,.66);
  background: transparent;
}
.button-ghost:hover { background: rgba(255,255,255,.08); }

.intake-panel {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  min-height: 430px;
}
.intake-panel h3 {
  margin: 16px 0 18px;
  font-family: var(--serif);
  font-size: clamp(1.8rem, 3vw, 2.8rem);
  line-height: 1.15;
  font-weight: 500;
}
.intake-panel p { margin: 0 0 28px; color: var(--muted); }
.intake-panel .text-link { margin-top: 22px; }
.price-card.featured li { border-color: rgba(255,255,255,.12); }
.optional { color: var(--muted); font-weight: 500; }

.subpage-body { background: var(--paper); }
.subpage-header { position: relative; z-index: 10; }

/* Request page */
.request-page {
  width: min(1120px, calc(100% - 40px));
  margin: 0 auto;
  padding: 90px 0 110px;
}
.request-intro {
  max-width: 880px;
  margin-bottom: 58px;
}
.request-intro h1,
.sample-intro h1,
.legal-hero h1,
.error-card h1 {
  margin: 18px 0 24px;
  font-size: clamp(3rem, 7vw, 6.7rem);
  line-height: .98;
  letter-spacing: -.055em;
  font-weight: 500;
}
.request-intro h1 span {
  display: block;
  margin-top: 14px;
  font-family: var(--serif);
  font-size: .47em;
  line-height: 1.13;
  letter-spacing: -.03em;
}
.request-intro > p,
.sample-intro > p {
  max-width: 760px;
  color: var(--muted);
  font-size: 1rem;
}
.request-notes {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 22px;
  margin-top: 28px;
  color: var(--muted);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .07em;
}
.request-notes span::before { content: "— "; color: var(--red); }
.request-card {
  display: grid;
  grid-template-columns: .75fr 1.25fr;
  gap: 70px;
  padding: 54px;
  background: var(--white);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.request-card-heading h2 {
  margin: 16px 0 18px;
  font-family: var(--serif);
  font-size: clamp(2rem, 4vw, 3.5rem);
  line-height: 1.08;
  font-weight: 500;
}
.request-card-heading p { color: var(--muted); }
.request-card form { min-width: 0; }
.prepared-request {
  grid-column: 2;
  margin-top: 18px;
  padding-top: 34px;
  border-top: 1px solid var(--line);
}
.prepared-request[hidden] { display: none; }
.prepared-request > p { color: var(--muted); font-size: .82rem; }
.prepared-request textarea { font-family: ui-monospace, SFMono-Regular, Consolas, monospace; font-size: .74rem; line-height: 1.55; }
.prepared-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.email-fallback { margin-top: 16px; color: var(--muted); font-size: .72rem; }
.request-bottom {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 30px;
  margin-top: 70px;
  padding-top: 44px;
  border-top: 1px solid var(--line);
}
.request-bottom h2 { margin: 10px 0 0; font-family: var(--serif); font-size: 2.3rem; font-weight: 500; }

/* Sample folio */
.sample-page {
  width: min(1180px, calc(100% - 40px));
  margin: 0 auto;
  padding: 88px 0 120px;
}
.sample-intro { max-width: 900px; margin-bottom: 64px; }
.sample-intro h1 { font-family: var(--serif); font-size: clamp(3rem, 6vw, 5.8rem); line-height: 1.02; }
.sample-disclosure {
  display: flex;
  align-items: baseline;
  gap: 18px;
  margin-top: 30px;
  padding: 18px 20px;
  border-left: 3px solid var(--red);
  background: rgba(255,253,248,.72);
}
.sample-disclosure strong { white-space: nowrap; font-size: .78rem; }
.sample-disclosure span { color: var(--muted); font-size: .78rem; }
.folio-stage { display: grid; gap: 42px; }
.folio-sheet {
  position: relative;
  width: min(100%, 940px);
  min-height: 610px;
  margin: 0 auto;
  padding: 58px 64px;
  background: var(--white);
  border: 1px solid rgba(22,21,20,.12);
  box-shadow: 0 26px 80px rgba(36,28,18,.12);
  overflow: hidden;
}
.folio-sheet:nth-child(even) { transform: translateX(26px); }
.folio-sheet:nth-child(odd) { transform: translateX(-26px); }
.folio-cover-sheet { background: var(--ink); color: var(--white); min-height: 720px; display: flex; flex-direction: column; }
.folio-brandline { font-size: .66rem; letter-spacing: .14em; color: rgba(255,255,255,.64); }
.folio-brandline span { color: var(--red); margin: 0 8px; }
.folio-cover-title { margin: auto 0; max-width: 660px; }
.folio-cover-title > span,
.folio-verdict > span,
.timeline-heading > span,
.folio-close-copy > span {
  color: #d7685d;
  font-size: .64rem;
  font-weight: 700;
  letter-spacing: .15em;
}
.folio-cover-title h2,
.folio-verdict h2,
.folio-contents-sheet > h2,
.timeline-heading h2,
.folio-close-copy h2 {
  margin: 18px 0 24px;
  font-family: var(--serif);
  font-size: clamp(2.8rem, 6vw, 5.6rem);
  line-height: 1.02;
  font-weight: 500;
  letter-spacing: -.045em;
}
.folio-cover-title p { max-width: 560px; color: rgba(255,255,255,.62); }
.folio-cover-bottom { display: flex; justify-content: space-between; gap: 20px; color: rgba(255,255,255,.45); font-size: .6rem; letter-spacing: .1em; }
.folio-running-head { display: flex; align-items: center; gap: 18px; padding-bottom: 20px; border-bottom: 1px solid var(--line); font-size: .62rem; letter-spacing: .14em; }
.folio-running-head span { color: var(--red); }
.sample-pillar-grid { display: grid; grid-template-columns: repeat(4, 1fr); margin: 70px auto 54px; border: 1px solid var(--line); }
.sample-pillar-grid > div { min-height: 300px; padding: 26px 12px; display: flex; flex-direction: column; align-items: center; border-right: 1px solid var(--line); }
.sample-pillar-grid > div:last-child { border-right: 0; }
.sample-pillar-grid span { font-size: .56rem; letter-spacing: .14em; color: var(--muted); }
.sample-pillar-grid strong { margin: 30px 0; writing-mode: vertical-rl; font-family: var(--serif); font-size: 2.5rem; letter-spacing: .24em; }
.sample-pillar-grid small { margin-top: auto; color: var(--muted); font-size: .65rem; }
.sample-pillar-grid .active { background: var(--ink); color: var(--white); transform: translateY(-12px); }
.sample-pillar-grid .active span,
.sample-pillar-grid .active small { color: rgba(255,255,255,.58); }
.folio-note { max-width: 700px; margin-left: auto; padding-left: 22px; border-left: 2px solid var(--red); }
.folio-note span,
.folio-columns span { color: var(--red); font-size: .58rem; font-weight: 700; letter-spacing: .13em; }
.folio-note p { margin-bottom: 0; color: var(--muted); font-size: .78rem; }
.folio-verdict { max-width: 790px; margin: 74px 0 44px; }
.folio-verdict h2 { font-size: clamp(2.7rem, 5vw, 4.8rem); }
.folio-verdict p { max-width: 720px; color: var(--muted); }
.folio-rule { width: 100px; height: 4px; background: var(--red); margin: 50px 0; }
.folio-columns { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; }
.folio-columns p { color: var(--muted); font-size: .82rem; }
.folio-contents-sheet > h2 { max-width: 640px; font-size: clamp(2.6rem, 5vw, 4.6rem); margin: 60px 0 44px; }
.folio-index-list { border-top: 1px solid var(--line); }
.folio-index-list > div { display: grid; grid-template-columns: 45px 220px 1fr; gap: 22px; align-items: baseline; padding: 19px 0; border-bottom: 1px solid var(--line); }
.folio-index-list span { color: var(--red); font-size: .65rem; font-weight: 700; }
.folio-index-list strong { font-size: .86rem; }
.folio-index-list small { color: var(--muted); font-size: .74rem; }
.timeline-heading { margin: 62px 0 50px; max-width: 760px; }
.timeline-heading h2 { font-size: clamp(4rem, 10vw, 8rem); line-height: .9; }
.timeline-heading p { color: var(--muted); }
.sample-timeline { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); }
.sample-timeline > div { position: relative; min-height: 190px; padding: 28px 28px 20px 0; border-right: 1px solid var(--line); }
.sample-timeline > div:not(:first-child) { padding-left: 28px; }
.sample-timeline > div:last-child { border-right: 0; }
.sample-timeline strong { display: block; color: var(--red); font-size: 1.7rem; }
.sample-timeline span { display: block; margin-top: 18px; font-weight: 700; }
.sample-timeline p { color: var(--muted); font-size: .76rem; }
.folio-close-sheet { min-height: 660px; display: flex; flex-direction: column; }
.folio-close-copy { max-width: 760px; margin: auto 0; }
.folio-close-copy h2 { font-size: clamp(3rem, 6vw, 5.4rem); }
.folio-close-copy p { max-width: 680px; margin-bottom: 34px; color: var(--muted); }

/* Legal pages */
.legal-page {
  width: min(960px, calc(100% - 40px));
  margin: 0 auto;
  padding: 88px 0 120px;
}
.legal-hero { padding-bottom: 50px; border-bottom: 1px solid var(--line); }
.legal-hero h1 { font-family: var(--serif); font-size: clamp(3.3rem, 7vw, 6.2rem); }
.legal-hero p { color: var(--muted); }
.legal-content { max-width: 800px; margin: 58px 0 0 auto; }
.legal-content section { padding: 0 0 34px; margin-bottom: 34px; border-bottom: 1px solid var(--line); }
.legal-content h2 { margin: 0 0 14px; font-family: var(--serif); font-size: 1.55rem; font-weight: 500; }
.legal-content p { color: #4f4c46; font-size: .92rem; }

/* Error page */
.error-page { min-height: 100vh; display: grid; place-items: center; padding: 24px; }
.error-card { width: min(760px, 100%); padding: 64px; background: var(--white); border: 1px solid var(--line); box-shadow: var(--shadow); }
.error-card h1 { font-family: var(--serif); font-size: clamp(2.8rem, 7vw, 5.5rem); }
.error-card p { margin-bottom: 28px; color: var(--muted); }

@media (max-width: 980px) {
  .request-card { grid-template-columns: 1fr; gap: 34px; }
  .prepared-request { grid-column: 1; }
  .folio-sheet:nth-child(n) { transform: none; }
}

@media (max-width: 720px) {
  .preview-action { align-items: flex-start; flex-direction: column; }
  .preview-action small { text-align: left; }
  .request-page,
  .sample-page,
  .legal-page { width: min(100% - 28px, 1240px); padding-top: 62px; }
  .request-card { padding: 30px 24px; }
  .request-intro h1 { font-size: 3.4rem; }
  .request-bottom { align-items: flex-start; flex-direction: column; }
  .prepared-actions { display: grid; }
  .sample-disclosure { align-items: flex-start; flex-direction: column; gap: 6px; }
  .folio-stage { gap: 24px; }
  .folio-sheet { min-height: 0; padding: 34px 24px; }
  .folio-cover-sheet { min-height: 610px; }
  .folio-cover-bottom { flex-direction: column; }
  .sample-pillar-grid { margin: 46px 0 34px; }
  .sample-pillar-grid > div { min-height: 235px; padding: 20px 5px; }
  .sample-pillar-grid strong { font-size: 1.72rem; }
  .folio-columns,
  .sample-timeline { grid-template-columns: 1fr; }
  .folio-columns { gap: 18px; }
  .sample-timeline > div,
  .sample-timeline > div:not(:first-child) { min-height: 0; padding: 22px 0; border-right: 0; border-bottom: 1px solid var(--line); }
  .folio-index-list > div { grid-template-columns: 36px 1fr; }
  .folio-index-list small { grid-column: 2; }
  .legal-content { margin-left: 0; }
  .error-card { padding: 40px 26px; }
}
