/* ============================================================
   OFEX — Sample 2 · Premium / refined (on-brand crimson + dark)
   ============================================================ */
:root {
  --crimson:      #A6243C;   /* brand red */
  --crimson-deep: #7E1A2E;
  --crimson-br:   #C32B47;
  --ink:          #161C21;   /* deep dark */
  --ink-2:        #1E272D;   /* brand dark */
  --ink-3:        #28333A;
  --paper:        #FBFAF8;   /* warm white */
  --paper-2:      #F2EEE9;
  --text:         #1E272D;
  --text-soft:    #5A5F63;
  --muted:        #8E9094;
  --line:         rgba(30,39,45,0.14);
  --line-soft:    rgba(30,39,45,0.08);
  --line-light:   rgba(255,255,255,0.16);

  --sans:  "Hanken Grotesk", system-ui, -apple-system, "Segoe UI", sans-serif;
  --serif: "Instrument Serif", Georgia, "Times New Roman", serif;

  --shell: 1680px;
  --gutter: clamp(1.4rem, 4.5vw, 5rem);
  --sec-y: clamp(5.5rem, 12vh, 10rem);
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--sans);
  background: var(--paper);
  color: var(--text);
  line-height: 1.65;
  font-size: 1.0625rem;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--crimson); color: #fff; }

.shell { width: 100%; max-width: var(--shell); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: var(--sec-y); }

/* ---- Type primitives ---- */
.eyebrow {
  font-size: 0.7rem; font-weight: 600; letter-spacing: 0.26em;
  text-transform: uppercase; color: var(--crimson); margin-bottom: 1.4rem;
}
.eyebrow--light { color: #E08494; }
.eyebrow--center { text-align: center; }

.h2 {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(2rem, 4.6vw, 3.6rem);
  line-height: 1.06; letter-spacing: -0.025em;
}
.h2--light { color: var(--paper); }
.ser-it { font-family: var(--serif); font-style: italic; font-weight: 400; color: var(--crimson); letter-spacing: 0; }
.h2--light .ser-it, .hero__title .ser-it { color: #E08494; }

/* ============================================================ Header */
.hdr {
  position: fixed; inset: 0 0 auto 0; z-index: 60;
  transition: background .5s var(--ease), border-color .5s var(--ease), backdrop-filter .5s var(--ease);
  border-bottom: 1px solid transparent;
}
.hdr.is-stuck { background: rgba(22,28,33,0.82); backdrop-filter: blur(12px); border-bottom-color: var(--line-light); }
.hdr__in { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; padding-block: 1.1rem; }
.brand { display: inline-flex; align-items: center; }
.brand__logo { height: clamp(34px, 3.4vw, 44px); width: auto; display: block; filter: drop-shadow(0 1px 2px rgba(0,0,0,.3)); transition: opacity .3s var(--ease); }
.brand:hover .brand__logo { opacity: 0.82; }
.nav { display: flex; gap: clamp(0.8rem, 1.9vw, 2rem); flex: 1; justify-content: center; }
.nav a { font-size: 0.92rem; font-weight: 500; color: rgba(255,255,255,0.78); position: relative; padding-block: 0.4rem; transition: color .35s var(--ease); }
.nav a::after { content:""; position:absolute; left:0; bottom:0; width:100%; height:1.5px; background: var(--crimson-br); transform: scaleX(0); transform-origin:left; transition: transform .45s var(--ease); }
.nav a:hover { color: #fff; }
.nav a:hover::after { transform: scaleX(1); }
.burger { display: none; }

/* ============================================================ Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--sans); font-size: 0.78rem; font-weight: 600; letter-spacing: 0.1em;
  text-transform: uppercase; padding: 1.05rem 2rem; cursor: pointer;
  border: 1.5px solid transparent; border-radius: 2px;
  transition: background .4s var(--ease), color .4s var(--ease), border-color .4s var(--ease), transform .4s var(--ease);
}
.btn:hover { transform: translateY(-2px); }
.btn--solid { background: var(--crimson); color: #fff; }
.btn--solid:hover { background: var(--crimson-br); }
.btn--ghost { background: transparent; border-color: rgba(255,255,255,0.32); color: #fff; }
.btn--ghost:hover { border-color: #fff; background: rgba(255,255,255,0.06); }
.btn--outline-light { background: transparent; border-color: rgba(255,255,255,0.4); color: #fff; }
.btn--outline-light:hover { background: #fff; color: var(--ink); border-color: #fff; }

/* ============================================================ Hero */
.hero { position: relative; background: var(--ink); color: var(--paper); padding-top: clamp(8rem, 17vh, 12rem); padding-bottom: 0; overflow: hidden; }
.hero__glow {
  position: absolute; top: -20%; right: -10%; width: 70vw; height: 70vw; max-width: 900px; max-height: 900px;
  background: radial-gradient(circle, rgba(166,36,60,0.34), rgba(166,36,60,0) 62%);
  pointer-events: none; z-index: 0;
}
.hero__in { position: relative; z-index: 1; display: grid; grid-template-columns: 1.35fr 0.65fr; gap: clamp(2rem,5vw,5rem); align-items: center; padding-bottom: clamp(3rem,6vw,5rem); }
.hero__title { font-weight: 800; font-size: clamp(3rem, 8.5vw, 6.6rem); line-height: 0.98; letter-spacing: -0.035em; margin-bottom: 1.2rem; }
.hero__sub { font-family: var(--serif); font-size: clamp(1.4rem, 3vw, 2.3rem); font-style: normal; color: rgba(255,255,255,0.92); margin-bottom: 1.8rem; }
.hero__sub em { font-style: italic; color: #E08494; }
.hero__lede { max-width: 44ch; font-size: 1.12rem; color: rgba(255,255,255,0.66); font-weight: 300; margin-bottom: 2.4rem; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 0.9rem; }
.hero__seal { display: flex; flex-direction: column; align-items: center; gap: 1.2rem; }
.seal-stamp { width: min(300px, 60vw); height: auto; filter: drop-shadow(0 18px 40px rgba(0,0,0,0.5)); transform-origin: center; }
.hero__sealcap { font-family: var(--serif); font-style: italic; font-size: 1.15rem; color: rgba(255,255,255,0.6); text-align: center; }
.hero__trust {
  position: relative; z-index: 1; list-style: none;
  display: grid; grid-template-columns: repeat(6,1fr); gap: 1rem;
  border-top: 1px solid var(--line-light); padding-block: 1.8rem; margin-bottom: 0;
}
.hero__trust li { font-size: 0.92rem; color: rgba(255,255,255,0.6); }
.hero__trust strong { display: block; font-size: 1.5rem; font-weight: 700; color: #fff; letter-spacing: -0.02em; }

/* ============================================================ Marquee */
.marquee { background: var(--crimson); color: #fff; overflow: hidden; padding-block: 0.9rem; white-space: nowrap; }
.marquee__track { display: inline-flex; align-items: center; gap: 2rem; animation: scroll 34s linear infinite; }
.marquee span { font-size: 0.8rem; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; }
.marquee i { color: rgba(255,255,255,0.55); font-style: normal; font-size: 0.7rem; }
@keyframes scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ============================================================ How We Can Help */
.help { display: grid; grid-template-columns: 1fr 0.92fr; gap: clamp(2.5rem,6vw,6rem); align-items: center; }
.help .h2 { margin: 0.4rem 0 1.6rem; }
.help__intro { color: var(--text-soft); margin-bottom: 1.3rem; max-width: 52ch; }
.help__intro strong { color: var(--text); font-weight: 600; }
.ticks { list-style: none; display: flex; flex-wrap: wrap; gap: 0.8rem; margin: 1.8rem 0 2.4rem; }
.ticks li { display: inline-flex; align-items: center; gap: 0.55rem; font-size: 0.9rem; font-weight: 500; border: 1px solid var(--line); border-radius: 100px; padding: 0.5rem 1.1rem; }
.ticks li::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--crimson); }

.plate figcaption { font-family: var(--serif); font-style: italic; font-size: 1.05rem; color: var(--text-soft); margin-top: 1rem; text-align: center; }
.plate figcaption span { display: block; font-family: var(--sans); font-style: normal; font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); margin-top: 0.5rem; }
.plate__img {
  width: 100%; aspect-ratio: 4/5; border: 1px solid var(--line); border-radius: 3px; position: relative; overflow: hidden;
  background: linear-gradient(200deg, #2b343b 0%, #1e272d 60%, #161c21 100%);
}
.plate__img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; }
.plate__img::before { /* corner ticks over photo */
  content:""; position:absolute; inset:16px; z-index:2; border:1px solid rgba(255,255,255,0.55); pointer-events:none;
  -webkit-mask: linear-gradient(#000 0 0) top left/24px 1px no-repeat, linear-gradient(#000 0 0) top left/1px 24px no-repeat,
    linear-gradient(#000 0 0) top right/24px 1px no-repeat, linear-gradient(#000 0 0) top right/1px 24px no-repeat,
    linear-gradient(#000 0 0) bottom left/24px 1px no-repeat, linear-gradient(#000 0 0) bottom left/1px 24px no-repeat,
    linear-gradient(#000 0 0) bottom right/24px 1px no-repeat, linear-gradient(#000 0 0) bottom right/1px 24px no-repeat;
          mask: linear-gradient(#000 0 0) top left/24px 1px no-repeat, linear-gradient(#000 0 0) top left/1px 24px no-repeat,
    linear-gradient(#000 0 0) top right/24px 1px no-repeat, linear-gradient(#000 0 0) top right/1px 24px no-repeat,
    linear-gradient(#000 0 0) bottom left/24px 1px no-repeat, linear-gradient(#000 0 0) bottom left/1px 24px no-repeat,
    linear-gradient(#000 0 0) bottom right/24px 1px no-repeat, linear-gradient(#000 0 0) bottom right/1px 24px no-repeat;
}
.plate__img::after { /* wax seal stamped in the corner */
  content:""; position:absolute; right:-22px; bottom:-22px; z-index:3; width:104px; height:104px;
  background: url("seal.svg") center/contain no-repeat;
  filter: drop-shadow(0 8px 20px rgba(0,0,0,.5));
}

/* ============================================================ Bands */
.band { background: var(--ink); color: var(--paper); }
.band--quote { background: var(--ink-2); }

.elevate { max-width: 60rem; }
.elevate .h2 { margin: 0.4rem 0 1.6rem; }
.elevate__sub { color: rgba(255,255,255,0.6); max-width: 58ch; font-weight: 300; font-size: 1.08rem; }
.stats { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(1.5rem,4vw,3.5rem); margin-top: clamp(3rem,6vw,5rem); }
.stat { border-top: 2px solid var(--crimson); padding-top: 1.6rem; }
.stat__num { font-weight: 800; font-size: clamp(2.6rem,5.5vw,4.4rem); line-height: 1; letter-spacing: -0.04em; color: #fff; display: flex; align-items: baseline; }
.stat__pre { color: #E08494; }
.stat__num--word { font-family: var(--serif); font-style: italic; font-weight: 400; color: #E08494; letter-spacing: -0.01em; }
.stat__label { color: rgba(255,255,255,0.62); font-weight: 300; margin-top: 1rem; max-width: 34ch; }
.elevate__cta { margin-top: clamp(3rem,6vw,4.5rem); }

/* ============================================================ Why / grid */
.why__head { max-width: 56rem; margin-bottom: clamp(3rem,6vw,4.5rem); }
.why__head .h2 { margin: 0.4rem 0 1.4rem; }
.why__intro { color: var(--text-soft); font-size: 1.1rem; max-width: 56ch; }

/* Themed clusters — 15 items grouped into 4 labelled themes */
.themes { display: flex; flex-direction: column; border-top: 1px solid var(--line); }
.theme {
  display: grid; grid-template-columns: minmax(220px, 0.85fr) 2.6fr;
  gap: clamp(2rem, 4.5vw, 5rem);
  padding-block: clamp(2.6rem, 4.5vw, 4rem);
  border-bottom: 1px solid var(--line);
}
.theme__label { position: sticky; top: 6rem; align-self: start; }
.theme__n { font-family: var(--serif); font-style: italic; font-size: 1.15rem; color: var(--crimson); opacity: .8; display: block; margin-bottom: 0.7rem; }
.theme__name { font-size: clamp(1.5rem, 2.3vw, 2.05rem); font-weight: 700; letter-spacing: -0.02em; line-height: 1.06; margin-bottom: 0.8rem; }
.theme__desc { font-size: 0.95rem; color: var(--text-soft); font-weight: 300; line-height: 1.55; max-width: 28ch; }
.theme__items { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(1.6rem, 2.6vw, 2.6rem) clamp(2rem, 3.2vw, 3.4rem); }
.cell { position: relative; padding-left: 1.1rem; }
.cell::before { content:""; position:absolute; left:0; top:0.42rem; width:5px; height:5px; background: var(--crimson); border-radius:1px; transform: rotate(45deg); }
.cell h4 { font-size: 1.04rem; font-weight: 700; letter-spacing: -0.01em; margin-bottom: 0.4rem; }
.cell p { font-size: 0.9rem; color: var(--text-soft); font-weight: 300; line-height: 1.55; }

/* ============================================================ Testimonials */
.qs { position: relative; min-height: 14rem; max-width: 60rem; margin: 1rem auto 0; }
.q { position: absolute; inset: 0; text-align: center; opacity: 0; visibility: hidden; transform: translateY(12px); transition: opacity .8s var(--ease), transform .8s var(--ease), visibility .8s; }
.q.is-active { opacity: 1; visibility: visible; transform: none; position: relative; }
.q blockquote { font-family: var(--serif); font-style: italic; font-size: clamp(1.5rem,3.4vw,2.5rem); line-height: 1.32; color: var(--paper); max-width: 26ch; margin: 0 auto 2rem; }
.q blockquote::before { content:"“"; color: var(--crimson-br); }
.q blockquote::after { content:"”"; color: var(--crimson-br); }
.q__n { display: block; font-size: 0.82rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: #fff; }
.q__r { display: block; font-size: 0.82rem; color: rgba(255,255,255,0.5); margin-top: 0.4rem; }
.qs__nav { display: flex; align-items: center; justify-content: center; gap: 1.4rem; margin-top: 2.8rem; }
.qs__btn { width: 3rem; height: 3rem; border: 1px solid var(--line-light); background: transparent; color: #fff; cursor: pointer; border-radius: 50%; transition: background .35s var(--ease), border-color .35s var(--ease); }
.qs__btn:hover { background: var(--crimson); border-color: var(--crimson); }
.qs__count { font-size: 0.8rem; letter-spacing: 0.14em; color: rgba(255,255,255,0.55); }

/* ============================================================ Contact */
.contact { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2.5rem,6vw,6rem); align-items: start; }
.contact .h2 { margin: 0.4rem 0 0; }
.colophon { margin-top: 2.6rem; }
.colophon > div { display: grid; grid-template-columns: 5.5rem 1fr; gap: 1.2rem; padding: 1.2rem 0; border-top: 1px solid var(--line-soft); }
.colophon dt { font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); padding-top: 0.2rem; }
.colophon dd { color: var(--text-soft); }
.colophon a { border-bottom: 1px solid var(--line); transition: color .3s var(--ease), border-color .3s var(--ease); }
.colophon a:hover { color: var(--crimson); border-color: var(--crimson); }

.contact__form { display: flex; flex-direction: column; gap: 1.7rem; background: var(--paper-2); border: 1px solid var(--line); border-radius: 5px; padding: clamp(1.6rem,3vw,2.6rem); }
.frow { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.field { display: flex; flex-direction: column; }
.field span { font-size: 0.68rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); margin-bottom: 0.6rem; }
.field input, .field textarea { background: var(--paper); border: 1px solid var(--line); border-radius: 3px; font-family: var(--sans); font-size: 1rem; color: var(--text); padding: 0.8rem 0.9rem; resize: vertical; transition: border-color .4s var(--ease), box-shadow .4s var(--ease); }
.field input:focus, .field textarea:focus { outline: none; border-color: var(--crimson); box-shadow: 0 0 0 3px rgba(166,36,60,0.12); }
.contact__form .btn { align-self: flex-start; }

/* ============================================================ Footer */
.ftr { background: var(--ink); color: var(--paper); padding-top: clamp(4rem,7vw,5.5rem); }
.ftr__in { display: grid; grid-template-columns: 1.1fr 1.5fr 1.4fr; gap: 2.5rem; padding-bottom: 3.5rem; }
.ftr__brand { display: flex; flex-direction: column; gap: 0.9rem; max-width: 22rem; }
.ftr__logo { height: 42px; width: auto; align-self: flex-start; display: block; }
.ftr__tag { font-size: 0.86rem; line-height: 1.55; font-weight: 300; color: rgba(255,255,255,0.5); }
.ftr__nav { display: flex; flex-wrap: wrap; gap: 0.5rem 1.4rem; align-content: start; }
.ftr__nav a { font-size: 0.85rem; color: rgba(255,255,255,0.7); transition: color .3s var(--ease); }
.ftr__nav a:hover { color: #E08494; }
.ftr__contact { display: flex; flex-direction: column; gap: 0.55rem; font-size: 0.88rem; color: rgba(255,255,255,0.65); }
.ftr__contact a:hover { color: #fff; }
.ftr__base { border-top: 1px solid var(--line-light); padding-block: 1.8rem; font-size: 0.74rem; letter-spacing: 0.06em; color: rgba(255,255,255,0.4); }

/* ============================================================ Reveal */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity 1s var(--ease), transform 1s var(--ease); }
.reveal.in { opacity: 1; transform: none; }

/* ============================================================ Responsive */
@media (max-width: 940px) {
  .nav, .hdr__cta { display: none; }
  .burger { display: flex; flex-direction: column; gap: 6px; background: none; border: none; cursor: pointer; padding: 6px; }
  .burger span { width: 26px; height: 2px; background: #fff; display: block; }
  .hero__in { grid-template-columns: 1fr; }
  .hero__seal { order: -1; }
  .seal-stamp { width: 180px; }
  .help, .contact { grid-template-columns: 1fr; }
  .stats { grid-template-columns: 1fr; }
  .theme { grid-template-columns: 1fr; gap: 1.6rem; }
  .theme__label { position: static; }
  .theme__desc { max-width: 48ch; }
  .hero__trust { grid-template-columns: repeat(2,1fr); gap: 1.5rem; }
  .ftr__in { grid-template-columns: 1fr; gap: 2rem; }
}
@media (max-width: 560px) {
  .theme__items { grid-template-columns: 1fr; }
  .frow { grid-template-columns: 1fr; }
  .hero__cta .btn { flex: 1; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
  .marquee__track { animation: none; }
}
