/* ============================================================
   MISTRESS OLIVIE — shared system
   NOIR · ink #0b0a0a · ivory #ece6da · crimson #c20016
   Type: Jost (wide light caps) + Bodoni Moda (display serif)
   ============================================================ */

:root {
  --ink: #0b0a0a;
  --ink-2: #110f0e;
  --ink-3: #1a1614;
  --ivory: #ece6da;
  --ivory-dim: #a59a8e;
  --ivory-faint: #6f675e;
  --crimson: #c20016;
  --crimson-deep: #8a0014;
  --crimson-glow: rgba(194, 0, 22, 0.5);
  --hair: rgba(255, 255, 255, 0.07);
  --hair-red: rgba(194, 0, 22, 0.32);
  --serif: 'Bodoni Moda', Georgia, serif;
  --sans: 'Jost', system-ui, sans-serif;
  --gut: 64px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--ink);
  color: var(--ivory);
  font-family: var(--sans);
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

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

a { color: inherit; text-decoration: none; }
img { display: block; }

/* ---------- layout ---------- */
.wrap { max-width: 1320px; margin: 0 auto; padding: 0 var(--gut); }

.kicker {
  font-size: 11px; letter-spacing: 0.6em; text-transform: uppercase;
  color: var(--crimson); margin: 0;
}
.kicker--dim { color: var(--ivory-dim); letter-spacing: 0.42em; }

/* ---------- top bar ---------- */
.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 30px var(--gut) 0;
  font-size: 14px; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--ivory-dim);
}
.topbar__loc { white-space: nowrap; }
.topnav { display: flex; gap: 38px; }
.topnav a { position: relative; padding-bottom: 4px; transition: color .25s ease; }
.topnav a:hover { color: var(--ivory); }
.topnav a.is-active { color: var(--ivory); }
.topnav a.is-active::after,
.topnav a:hover::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -2px; height: 1px;
  background: var(--crimson);
}

/* ---------- brand block ---------- */
.brand { text-align: center; padding: 28px 0 6px; }
.brand__kicker {
  font-size: 14px; letter-spacing: 0.62em; text-transform: uppercase;
  color: var(--crimson); margin-bottom: 12px;
}
.brand__name {
  font-family: var(--serif); font-weight: 500;
  font-size: clamp(48px, 8vw, 96px); line-height: 0.9; letter-spacing: 0.02em;
  margin: 0; color: var(--ivory);
}
.brand--small .brand__name { font-size: clamp(34px, 5vw, 52px); }

/* hairline crimson rule */
.rule {
  height: 1px; margin: 26px var(--gut) 0;
  background: linear-gradient(90deg, transparent, var(--crimson) 50%, transparent);
  opacity: 0.7;
}
.rule--tight { margin-top: 0; }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 14px;
  border: 1px solid var(--crimson); color: var(--ivory);
  padding: 16px 32px; font-size: 11px; letter-spacing: 0.34em; text-transform: uppercase;
  background: transparent; cursor: pointer; font-family: var(--sans);
  transition: background .3s ease, color .3s ease, letter-spacing .3s ease;
}
.btn:hover { background: var(--crimson); color: #fff; letter-spacing: 0.4em; }
.btn--solid { background: var(--crimson); color: #fff; }
.btn--solid:hover { background: #fff; color: var(--ink); border-color: #fff; }

/* ---------- generic section ---------- */
.section { padding: 96px 0; }
.section--tight { padding: 64px 0; }
.eyebrow-row { display: flex; align-items: baseline; gap: 20px; margin-bottom: 40px; }
.eyebrow-row .idx { font-family: var(--serif); font-size: 13px; color: var(--crimson); letter-spacing: 0.2em; }
.h-display {
  font-family: var(--serif); font-style: italic; font-weight: 400;
  font-size: clamp(34px, 4.4vw, 58px); line-height: 1.05; margin: 0;
}
.h-display em { color: var(--crimson); font-style: italic; }
.lede {
  font-size: 16px; line-height: 1.9; color: var(--ivory-dim);
  letter-spacing: 0.02em; max-width: 540px;
}

/* ---------- triad cells ---------- */
.triad {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px;
  background: var(--hair-red); border: 1px solid var(--hair-red);
}
.cell { background: var(--ink); padding: 44px 38px; }
.cell__num { font-family: var(--serif); font-size: 13px; color: var(--crimson); letter-spacing: 0.2em; }
.cell__title { font-size: 13px; letter-spacing: 0.34em; text-transform: uppercase; margin: 16px 0 14px; color: var(--ivory); }
.cell__body { font-size: 14px; line-height: 1.8; color: var(--ivory-dim); margin: 0; }

/* ---------- footer ---------- */
.footer {
  border-top: 1px solid var(--hair); margin-top: 0;
  padding: 56px var(--gut) 48px;
}
.footer__top {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 40px; flex-wrap: wrap; margin-bottom: 44px;
}
.footer__name { font-family: var(--serif); font-size: 40px; letter-spacing: 0.06em; margin: 0; }
.footer__cta { font-size: 12px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ivory-dim); }
.footer__links { display: flex; gap: 30px; flex-wrap: wrap; }
.footer__links a { font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ivory-dim); transition: color .25s; }
.footer__links a:hover { color: var(--crimson); }
.footer__base {
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px;
  padding-top: 28px; border-top: 1px solid var(--hair);
  font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ivory-faint);
}

/* ---------- image framing ---------- */
.framed { position: relative; padding: 10px; }
.framed::after { content: ''; position: absolute; inset: 0; border: 1px solid var(--crimson-glow); pointer-events: none; }
.framed img { width: 100%; height: 100%; object-fit: cover; filter: saturate(1.05) contrast(1.02); }

/* ---------- page hero (interior pages) ---------- */
.page-hero { padding: 64px 0 0; }
.page-hero .h-display { max-width: 14ch; }

/* ---------- fade-in ---------- */
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .9s ease, transform .9s ease; }
.reveal.in { opacity: 1; transform: none; }

/* ---------- responsive ---------- */
@media (max-width: 980px) {
  :root { --gut: 28px; }
  .topnav { display: none; }
  .triad { grid-template-columns: 1fr; }
  .footer__top { flex-direction: column; align-items: flex-start; }
}
