/* ===========================================================================
   ATELIER CHAUFFEUR — design system
   Concept: high-fashion LOOKBOOK / editorial spread.
   Stark gallery-white, oversized Archivo display, one saturated crimson accent,
   asymmetric grid, oversized folio numerals, full-bleed color-field plates.
   No raster imagery — type + color blocks do the "lookbook" work.
   =========================================================================== */

:root {
  --paper: #fbfbf9;        /* gallery off-white */
  --paper-2: #f3f2ed;      /* faint warm panel */
  --ink: #141414;          /* charcoal-black */
  --ink-2: #6b6b64;        /* muted caption ink */
  --ink-3: #a4a39b;        /* faint */
  --line: #e4e3dc;         /* hairline */
  --line-ink: #1f1f1f;     /* dark hairline */
  --crimson: #c1121f;      /* the one accent */
  --crimson-deep: #8b0d17; /* hover / depth */
  --crimson-tint: #f7e3e3; /* faint wash */

  --display: "Archivo", "Inter Tight", system-ui, sans-serif;
  --body: "Inter Tight", system-ui, -apple-system, sans-serif;

  --maxw: 1320px;
  --gut: clamp(20px, 5vw, 64px);
}

/* ---- reset ---- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--body);
  font-size: 17px;
  line-height: 1.6;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  letter-spacing: -0.005em;
}
img, svg { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
h1, h2, h3, h4 { font-family: var(--display); font-weight: 800; line-height: 0.98; margin: 0; letter-spacing: -0.02em; }
p { margin: 0 0 1.1em; }

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

/* ---- shared atoms ---- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gut); }
.kicker {
  font-family: var(--body);
  font-weight: 600;
  font-size: 0.72rem;
  letter-spacing: 0.34em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.kicker--crimson { color: var(--crimson); }
.rule { height: 1px; background: var(--ink); border: 0; margin: 0; }
.rule--faint { background: var(--line); }
.rule--crimson { background: var(--crimson); height: 2px; }

.folio-num {
  font-family: var(--display);
  font-weight: 800;
  line-height: 0.8;
  letter-spacing: -0.04em;
  font-size: clamp(3.4rem, 12vw, 9.5rem);
  color: var(--ink);
}
.folio-num--out {
  color: transparent;
  -webkit-text-stroke: 1.4px var(--ink);
}
.folio-num--crimson { color: var(--crimson); }

.btn {
  display: inline-flex; align-items: center; gap: 0.6em;
  font-family: var(--body); font-weight: 600;
  font-size: 0.86rem; letter-spacing: 0.04em;
  padding: 0.95em 1.5em;
  background: var(--ink); color: var(--paper);
  border: 1px solid var(--ink);
  transition: background .18s, color .18s;
}
.btn:hover { background: var(--crimson); border-color: var(--crimson); color: #fff; }
.btn--ghost { background: transparent; color: var(--ink); }
.btn--ghost:hover { background: var(--ink); color: var(--paper); }
.btn--crimson { background: var(--crimson); border-color: var(--crimson); color: #fff; }
.btn--crimson:hover { background: var(--crimson-deep); border-color: var(--crimson-deep); }
.btn--lg { padding: 1.15em 2em; font-size: 0.95rem; }

.tel-link { white-space: nowrap; }

/* =====================================================================
   MASTHEAD — folio bar (not a button nav)
   ===================================================================== */
.masthead {
  position: sticky; top: 0; z-index: 60;
  background: var(--paper);
  border-bottom: 1px solid var(--ink);
}
.masthead__top {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 1rem; padding: 0.85rem var(--gut) 0.7rem;
}
.brandmark {
  font-family: var(--display); font-weight: 800;
  font-size: clamp(1.05rem, 2.4vw, 1.5rem);
  letter-spacing: -0.02em; line-height: 1;
  text-transform: uppercase;
}
.brandmark .amp { color: var(--crimson); }
.masthead__meta {
  display: flex; gap: 1.6rem; align-items: baseline;
  font-family: var(--body); font-size: 0.68rem; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--ink-2);
}
.masthead__meta a { color: var(--ink); font-weight: 600; }
.masthead__meta a:hover { color: var(--crimson); }
.masthead__meta .sep { color: var(--line); }

.contents {
  border-top: 1px solid var(--line);
  display: flex; flex-wrap: wrap; align-items: stretch;
  padding-inline: var(--gut);
}
.contents a {
  display: inline-flex; align-items: baseline; gap: 0.5em;
  padding: 0.6rem 0; margin-right: 2.1rem;
  font-family: var(--body); font-size: 0.82rem; font-weight: 500;
  letter-spacing: 0.02em; color: var(--ink);
  border-bottom: 2px solid transparent;
  transition: color .15s, border-color .15s;
}
.contents a .c-folio { font-size: 0.62rem; color: var(--ink-3); font-weight: 600; letter-spacing: 0.1em; }
.contents a:hover { color: var(--crimson); }
.contents a.is-here { border-bottom-color: var(--crimson); color: var(--crimson); }
.contents a.is-flag .c-folio { color: var(--crimson); }

.nav-toggle { display: none; }

/* =====================================================================
   COVER (home hero) — full-bleed editorial cover
   ===================================================================== */
.cover {
  position: relative;
  border-bottom: 1px solid var(--ink);
  padding: clamp(2.2rem, 6vw, 5rem) 0 clamp(2.4rem, 6vw, 5.5rem);
  overflow: hidden;
}
.cover__season {
  display: flex; gap: 1.4rem; align-items: baseline; margin-bottom: 1.4rem; flex-wrap: wrap;
}
.cover h1 {
  font-size: clamp(2.2rem, 9.4vw, 7.8rem);
  letter-spacing: -0.025em;
  text-transform: uppercase;
  white-space: nowrap;
}
.cover h1 .ln { display: block; }
.cover h1 .ln--crimson { color: var(--crimson); }
.cover__lede {
  max-width: 40ch;
  font-size: clamp(1.05rem, 1.6vw, 1.3rem); line-height: 1.45; color: var(--ink);
}
/* foot row under the title — never overlaps the headline */
.cover__foot {
  display: grid; grid-template-columns: 1fr auto; gap: clamp(1.2rem, 4vw, 3.5rem);
  align-items: end; margin-top: clamp(1.6rem, 4vw, 3rem);
}
.cover__issue {
  font-family: var(--display); font-weight: 800;
  font-size: clamp(3rem, 8vw, 6rem); line-height: 0.78; letter-spacing: -0.04em;
  color: transparent; -webkit-text-stroke: 1.5px var(--ink); display: block;
}
.cover__right { text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: 1.1rem; }
.cover__cta { display: flex; flex-direction: column; align-items: flex-end; gap: 0.8rem; }

/* =====================================================================
   SECTION scaffolding
   ===================================================================== */
.section { padding: clamp(3rem, 8vw, 7rem) 0; border-bottom: 1px solid var(--line); }
.section--tight { padding: clamp(2.2rem, 5vw, 4rem) 0; }
.section-head {
  display: grid; grid-template-columns: auto 1fr; gap: 1.2rem 2rem;
  align-items: end; margin-bottom: clamp(2rem, 5vw, 3.5rem);
}
.section-head__num {
  font-family: var(--display); font-weight: 800; font-size: clamp(2rem, 5vw, 3.6rem);
  line-height: 0.8; letter-spacing: -0.04em; color: var(--crimson);
}
.section-head h2 {
  font-size: clamp(1.9rem, 5vw, 3.4rem); text-transform: uppercase; letter-spacing: -0.025em;
}
.section-head__aside { grid-column: 1 / -1; max-width: 56ch; color: var(--ink-2); font-size: 1.02rem; }

/* ---- manifesto / editorial intro (asymmetric) ---- */
.manifesto {
  display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(1.5rem, 5vw, 4rem);
  align-items: start;
}
.manifesto__quote {
  font-family: var(--display); font-weight: 700;
  font-size: clamp(1.6rem, 3.4vw, 2.9rem); line-height: 1.04; letter-spacing: -0.02em;
}
.manifesto__quote .hl { color: var(--crimson); }
.manifesto__body { color: var(--ink); font-size: 1.05rem; }
.manifesto__body .lead-cap::first-letter {
  font-family: var(--display); font-weight: 800; float: left;
  font-size: 3.4em; line-height: 0.72; padding: 0.04em 0.12em 0 0; color: var(--crimson);
}

/* =====================================================================
   GALLERY — asymmetric occasion spreads (color-field plates)
   ===================================================================== */
.gallery { display: grid; grid-template-columns: repeat(12, 1fr); gap: clamp(14px, 1.6vw, 26px); }
.plate {
  position: relative; overflow: hidden;
  display: flex; flex-direction: column; justify-content: flex-end;
  min-height: 340px; padding: 1.5rem;
  border: 1px solid var(--ink);
  background: var(--paper-2); color: var(--ink);
  transition: transform .35s cubic-bezier(.2,.7,.2,1);
}
.plate:hover { transform: translateY(-4px); }
.plate__num {
  position: absolute; top: 0.7rem; left: 1.1rem;
  font-family: var(--display); font-weight: 800; line-height: 0.8;
  font-size: clamp(3rem, 7vw, 6rem); letter-spacing: -0.04em;
  color: transparent; -webkit-text-stroke: 1.3px currentColor; opacity: 0.5;
}
.plate__name {
  font-family: var(--display); font-weight: 800; text-transform: uppercase;
  font-size: clamp(1.5rem, 2.6vw, 2.4rem); line-height: 0.96; letter-spacing: -0.02em;
}
.plate__meta { margin-top: 0.5rem; font-size: 0.78rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-2); }
.plate__arrow { position: absolute; top: 1.2rem; right: 1.2rem; font-size: 1.1rem; color: var(--crimson); opacity: 0; transition: opacity .25s; }
.plate:hover .plate__arrow { opacity: 1; }

/* color-field variants for the lookbook plates */
.plate--ink { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.plate--ink .plate__meta { color: var(--ink-3); }
.plate--crimson { background: var(--crimson); color: #fff; border-color: var(--crimson); }
.plate--crimson .plate__meta { color: #f6cdd0; }
.plate--crimson .plate__arrow { color: #fff; }
.plate--paper { background: var(--paper); }

/* asymmetric spans (desktop) */
.span-7 { grid-column: span 7; }
.span-5 { grid-column: span 5; }
.span-6 { grid-column: span 6; }
.span-4 { grid-column: span 4; }
.span-8 { grid-column: span 8; }
.span-12 { grid-column: span 12; }
.tall { min-height: 520px; }
.short { min-height: 300px; }

/* =====================================================================
   ASSET TEASER (Package Builder promo)
   ===================================================================== */
.teaser {
  display: grid; grid-template-columns: 1fr 0.85fr; gap: clamp(1.5rem, 4vw, 3.5rem);
  align-items: center; background: var(--ink); color: var(--paper);
  padding: clamp(2rem, 5vw, 4rem); border: 1px solid var(--ink);
}
.teaser h2 { font-size: clamp(2rem, 5vw, 3.6rem); text-transform: uppercase; letter-spacing: -0.025em; }
.teaser h2 .hl { color: var(--crimson); }
.teaser p { color: #d9d8d2; max-width: 42ch; }
.teaser__art {
  border: 1px solid #34332f; padding: 1.4rem; min-height: 230px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.teaser__art .row { display: flex; justify-content: space-between; align-items: baseline; border-bottom: 1px solid #34332f; padding: 0.55rem 0; font-size: 0.84rem; }
.teaser__art .row:last-child { border-bottom: 0; }
.teaser__art .row .v { font-family: var(--display); font-weight: 700; color: #fff; }
.teaser__art .row .v.cr { color: var(--crimson); }

/* =====================================================================
   FLEET plates
   ===================================================================== */
.fleet-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: clamp(14px, 1.6vw, 24px); }
.veh {
  border: 1px solid var(--ink); padding: 1.5rem; background: var(--paper);
  display: flex; flex-direction: column; min-height: 300px;
}
.veh__num { font-family: var(--display); font-weight: 800; color: var(--crimson); font-size: 1.1rem; letter-spacing: 0.1em; }
.veh h3 { font-size: 1.45rem; text-transform: uppercase; margin-top: 0.4rem; line-height: 1; }
.veh__class { font-size: 0.74rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-2); margin-top: 0.4rem; }
.veh__spec { margin-top: auto; padding-top: 1rem; display: grid; grid-template-columns: 1fr 1fr; gap: 0.5rem 1rem; border-top: 1px solid var(--line); }
.veh__spec dt { font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-2); }
.veh__spec dd { margin: 0 0 0.3rem; font-family: var(--display); font-weight: 700; font-size: 1.05rem; }

/* =====================================================================
   JOURNAL teaser + index
   ===================================================================== */
.dispatch-list { display: grid; gap: 0; }
.dispatch {
  display: grid; grid-template-columns: auto 1fr auto; gap: 1.2rem 2rem; align-items: baseline;
  padding: 1.5rem 0; border-top: 1px solid var(--line);
}
.dispatch:last-child { border-bottom: 1px solid var(--line); }
.dispatch__folio { font-family: var(--display); font-weight: 800; color: var(--crimson); font-size: 1.1rem; }
.dispatch__title { font-family: var(--display); font-weight: 700; font-size: clamp(1.2rem, 2.4vw, 1.7rem); line-height: 1.05; letter-spacing: -0.015em; }
.dispatch:hover .dispatch__title { color: var(--crimson); }
.dispatch__cat { font-size: 0.68rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-2); white-space: nowrap; }
.dispatch__dek { grid-column: 2 / 3; color: var(--ink-2); font-size: 0.96rem; max-width: 60ch; margin-top: -0.6rem; }

/* =====================================================================
   ARTICLE
   ===================================================================== */
.article { max-width: 720px; margin-inline: auto; }
.article__head { border-bottom: 1px solid var(--ink); padding-bottom: 1.6rem; margin-bottom: 2.2rem; }
.article__cat { color: var(--crimson); }
.article h1 { font-size: clamp(2rem, 5.5vw, 3.4rem); text-transform: none; letter-spacing: -0.025em; margin: 1rem 0; line-height: 1.02; }
.article__meta { display: flex; gap: 1.2rem; flex-wrap: wrap; font-size: 0.78rem; letter-spacing: 0.06em; color: var(--ink-2); text-transform: uppercase; }
.prose { font-size: 1.08rem; line-height: 1.72; }
.prose h2 { font-size: 1.7rem; margin: 2.4rem 0 0.9rem; text-transform: none; letter-spacing: -0.015em; }
.prose h3 { font-size: 1.25rem; margin: 1.8rem 0 0.6rem; font-weight: 700; text-transform: none; }
.prose p > strong { font-weight: 600; }
.prose a { color: var(--crimson); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
.prose ul, .prose ol { padding-left: 1.2rem; margin: 0 0 1.3rem; }
.prose li { margin-bottom: 0.5rem; }
.prose blockquote {
  margin: 1.8rem 0; padding: 0.4rem 0 0.4rem 1.4rem; border-left: 2px solid var(--crimson);
  font-family: var(--display); font-weight: 700; font-size: 1.3rem; line-height: 1.2; letter-spacing: -0.01em;
}
.prose hr { border: 0; border-top: 1px solid var(--line); margin: 2.4rem 0; }
.rank {
  border: 1px solid var(--ink); padding: 1.3rem 1.5rem; margin: 1.4rem 0;
  display: grid; grid-template-columns: auto 1fr; gap: 0.4rem 1.2rem; align-items: baseline;
}
.rank__n { font-family: var(--display); font-weight: 800; font-size: 2rem; color: var(--crimson); line-height: 0.8; grid-row: span 2; }
.rank__name { font-family: var(--display); font-weight: 700; font-size: 1.25rem; }
.rank__body { grid-column: 2; margin: 0; color: var(--ink); }
.rank--lead { border-width: 2px; border-color: var(--crimson); background: var(--crimson-tint); }

/* =====================================================================
   FAQ
   ===================================================================== */
.faq { border-top: 1px solid var(--ink); margin-top: 2.5rem; }
.faq details { border-bottom: 1px solid var(--line); padding: 1.1rem 0; }
.faq summary { font-family: var(--display); font-weight: 700; font-size: 1.12rem; list-style: none; cursor: pointer; display: flex; justify-content: space-between; gap: 1rem; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; color: var(--crimson); font-weight: 800; }
.faq details[open] summary::after { content: "–"; }
.faq details p { margin: 0.8rem 0 0; color: var(--ink-2); }

/* =====================================================================
   BACK-COVER CTA — full-bleed crimson editorial spread (distinct CTA shape)
   ===================================================================== */
.backcover {
  background: var(--crimson); color: #fff;
  padding: clamp(3rem, 9vw, 7rem) 0; position: relative; overflow: hidden;
}
.backcover__inner { position: relative; z-index: 2; }
.backcover .kicker { color: #f6cdd0; }
.backcover h2 {
  font-size: clamp(2.4rem, 8vw, 6.5rem); text-transform: uppercase; letter-spacing: -0.03em;
  line-height: 0.92; margin: 1rem 0 1.6rem; color: #fff;
}
.backcover__phone {
  font-family: var(--display); font-weight: 800; letter-spacing: -0.03em;
  font-size: clamp(2.6rem, 9vw, 7rem); line-height: 0.85; color: #fff; display: inline-block;
}
.backcover__phone:hover { color: var(--ink); }
.backcover__row { display: flex; flex-wrap: wrap; gap: 1.4rem 2.6rem; align-items: baseline; justify-content: space-between; margin-top: 2rem; }
.backcover__note { max-width: 40ch; color: #fbe2e3; font-size: 0.98rem; }
.backcover__folio { font-family: var(--display); font-weight: 800; font-size: clamp(4rem, 14vw, 12rem); line-height: 0.7; color: transparent; -webkit-text-stroke: 1.6px rgba(255,255,255,0.5); position: absolute; right: var(--gut); bottom: -0.1em; z-index: 1; pointer-events: none; }

/* =====================================================================
   FOOTER / colophon
   ===================================================================== */
.colophon { background: var(--ink); color: var(--paper); padding: clamp(2.5rem, 6vw, 4.5rem) 0 2rem; }
.colophon__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 2rem; align-items: start; }
.colophon__brand { font-family: var(--display); font-weight: 800; font-size: 1.6rem; text-transform: uppercase; letter-spacing: -0.02em; }
.colophon__brand .amp { color: var(--crimson); }
.colophon p { color: #b8b7b0; font-size: 0.92rem; max-width: 40ch; }
.colophon h4 { font-family: var(--body); font-weight: 600; font-size: 0.7rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 0.9rem; }
.colophon ul { list-style: none; margin: 0; padding: 0; }
.colophon li { margin-bottom: 0.5rem; }
.colophon a:hover { color: var(--crimson); }
.colophon__phone { font-family: var(--display); font-weight: 800; font-size: 1.5rem; color: #fff; }
.colophon__phone:hover { color: var(--crimson); }
.colophon__legal { display: flex; flex-wrap: wrap; gap: 0.5rem 1.4rem; justify-content: space-between; margin-top: 2.6rem; padding-top: 1.4rem; border-top: 1px solid #2c2b27; font-size: 0.74rem; letter-spacing: 0.04em; color: var(--ink-3); }

/* =====================================================================
   PACKAGE BUILDER
   ===================================================================== */
.builder { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: start; }
.builder__panel { border: 1px solid var(--ink); padding: clamp(1.4rem, 3vw, 2.2rem); background: var(--paper); }
.field { margin-bottom: 1.9rem; }
.field:last-child { margin-bottom: 0; }
.field > .lbl { display: flex; align-items: baseline; gap: 0.6rem; margin-bottom: 0.8rem; }
.field > .lbl .n { font-family: var(--display); font-weight: 800; color: var(--crimson); font-size: 0.95rem; }
.field > .lbl .t { font-family: var(--display); font-weight: 700; font-size: 1.05rem; text-transform: uppercase; letter-spacing: 0.01em; }

.chip-row { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.chip {
  border: 1px solid var(--ink); background: var(--paper); color: var(--ink);
  padding: 0.55em 0.95em; font-size: 0.84rem; font-weight: 500; letter-spacing: 0.01em;
  transition: background .14s, color .14s;
}
.chip[aria-pressed="true"], .chip.is-on { background: var(--ink); color: var(--paper); }
.chip[aria-pressed="true"].chip--accent, .chip.is-on.chip--accent { background: var(--crimson); border-color: var(--crimson); color: #fff; }
.chip:hover { border-color: var(--crimson); }

.stepper { display: inline-flex; align-items: stretch; border: 1px solid var(--ink); }
.stepper button { width: 3rem; background: var(--paper); border: 0; font-family: var(--display); font-weight: 800; font-size: 1.3rem; color: var(--ink); }
.stepper button:hover { background: var(--crimson); color: #fff; }
.stepper .val { min-width: 5.5rem; display: flex; align-items: center; justify-content: center; gap: 0.4rem; border-inline: 1px solid var(--ink); font-family: var(--display); font-weight: 800; font-size: 1.3rem; }
.stepper .val small { font-family: var(--body); font-weight: 500; font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-2); }

.veh-pick { display: grid; grid-template-columns: 1fr 1fr; gap: 0.6rem; }
.veh-pick button {
  text-align: left; border: 1px solid var(--ink); background: var(--paper); padding: 0.85rem;
  display: flex; flex-direction: column; gap: 0.2rem; transition: background .14s, color .14s;
}
.veh-pick button .vn { font-family: var(--display); font-weight: 700; font-size: 1rem; }
.veh-pick button .vc { font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-2); }
.veh-pick button.is-on { background: var(--ink); color: var(--paper); }
.veh-pick button.is-on .vc { color: var(--ink-3); }
.veh-pick button:hover { border-color: var(--crimson); }

/* the composed package "spread" output */
.package {
  border: 1px solid var(--ink); background: var(--paper); position: sticky; top: 96px;
}
.package__head { background: var(--ink); color: var(--paper); padding: 1.3rem 1.5rem; display: flex; justify-content: space-between; align-items: baseline; }
.package__head .ttl { font-family: var(--display); font-weight: 800; text-transform: uppercase; font-size: 1.2rem; letter-spacing: 0.01em; }
.package__head .num { font-family: var(--display); font-weight: 800; color: var(--crimson); }
.package__body { padding: 1.5rem; }
.package__line { display: grid; grid-template-columns: auto 1fr; gap: 0.3rem 1rem; padding: 0.9rem 0; border-bottom: 1px solid var(--line); }
.package__line .k { font-size: 0.66rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--crimson); font-weight: 600; padding-top: 0.25rem; }
.package__line .v { font-family: var(--display); font-weight: 700; font-size: 1.12rem; line-height: 1.1; }
.package__line .sub { grid-column: 2; color: var(--ink-2); font-size: 0.9rem; font-family: var(--body); font-weight: 400; }
.itinerary { grid-column: 1 / -1; margin: 0.4rem 0 0; padding: 0; list-style: none; }
.itinerary li { display: grid; grid-template-columns: auto 1fr; gap: 0.9rem; padding: 0.45rem 0; border-top: 1px dotted var(--line); font-size: 0.92rem; }
.itinerary li .hr { font-family: var(--display); font-weight: 800; color: var(--crimson); font-size: 0.82rem; letter-spacing: 0.04em; white-space: nowrap; padding-top: 0.1rem; }
.addon-tags { display: flex; flex-wrap: wrap; gap: 0.4rem; grid-column: 2; }
.addon-tags span { border: 1px solid var(--crimson); color: var(--crimson); font-size: 0.72rem; letter-spacing: 0.08em; text-transform: uppercase; padding: 0.25em 0.6em; }
.package__foot { padding: 1.3rem 1.5rem; border-top: 1px solid var(--ink); display: flex; flex-direction: column; gap: 0.8rem; }
.package__reserve { font-family: var(--display); font-weight: 800; font-size: 1.4rem; }
.package__reserve a { color: var(--crimson); }
.package__actions { display: flex; gap: 0.6rem; flex-wrap: wrap; }
.btn--mini { padding: 0.6em 1em; font-size: 0.78rem; }

/* embed copy-code box */
.magnet { border: 1px solid var(--ink); margin-top: clamp(2rem, 5vw, 3.5rem); }
.magnet__head { background: var(--paper-2); padding: 1rem 1.4rem; border-bottom: 1px solid var(--ink); display: flex; justify-content: space-between; align-items: center; gap: 1rem; flex-wrap: wrap; }
.magnet__head h3 { font-size: 1.1rem; text-transform: uppercase; }
.magnet pre { margin: 0; padding: 1.2rem 1.4rem; overflow-x: auto; background: var(--ink); color: #e8e7e1; font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: 0.78rem; line-height: 1.6; }

/* =====================================================================
   reveal animation
   ===================================================================== */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } html { scroll-behavior: auto; } }

/* =====================================================================
   embed (chromeless) body
   ===================================================================== */
.embed-body { padding: clamp(1rem, 3vw, 1.6rem); }
.embed-credit { text-align: right; font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-2); padding: 0.7rem var(--gut); border-top: 1px solid var(--line); }
.embed-credit a { color: var(--crimson); font-weight: 600; }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 1000px) {
  .builder { grid-template-columns: 1fr; }
  .package { position: static; }
  .teaser { grid-template-columns: 1fr; }
  .manifesto { grid-template-columns: 1fr; }
  .colophon__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  body { font-size: 16px; }
  .cover h1 { white-space: normal; }
  .masthead__meta { display: none; }
  .nav-toggle {
    display: inline-flex; background: transparent; border: 1px solid var(--ink);
    font-family: var(--body); font-weight: 600; font-size: 0.72rem; letter-spacing: 0.16em;
    text-transform: uppercase; padding: 0.4em 0.8em; color: var(--ink);
  }
  .contents { display: none; flex-direction: column; padding-bottom: 0.6rem; }
  .contents.is-open { display: flex; }
  .contents a { margin-right: 0; border-bottom: 1px solid var(--line); }
  .cover__grid { grid-template-columns: 1fr; }
  .cover__right { text-align: left; flex-direction: row; justify-content: space-between; align-items: flex-end; }
  .cover__cta { align-items: flex-start; }
  .gallery { grid-template-columns: repeat(6, 1fr); }
  .span-7, .span-5, .span-6, .span-4, .span-8, .span-12 { grid-column: span 6; }
  .tall, .short { min-height: 320px; }
  .section-head { grid-template-columns: 1fr; }
  .colophon__grid { grid-template-columns: 1fr; }
  .veh-pick { grid-template-columns: 1fr; }
  .dispatch { grid-template-columns: auto 1fr; }
  .dispatch__cat { grid-column: 2; }
  .dispatch__dek { grid-column: 1 / -1; margin-top: 0; }
}
