/* ============================================================
   MERIDIAN RESTORATIONS — landing page system
   Cormorant Garamond (display) · Jost (UI) · Space Mono (spec)
   Heritage-garage. Warm near-black, paper, taupe-gold.
   Theme + accent + font-pairing + hero-layout are data-attr driven.
   ============================================================ */

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

:root{
  /* accent (overridden by [data-accent]) */
  --accent:#8b7355;
  --err:#c15f4a;
  --accent-soft:color-mix(in oklab, var(--accent) 60%, transparent);

  /* font stacks (overridden by [data-font]) */
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Jost', system-ui, sans-serif;
  --mono:'Space Mono', ui-monospace, monospace;

  --ease:cubic-bezier(.22,.65,.3,1);
  --maxw:1240px;
  --bezel:clamp(20px,5vw,90px);
}

/* ---------- THEMES ---------- */
:root,[data-theme="dark"]{
  --bg:      #221E1A;
  --bg-2:    oklch(0.262 0.010 60);
  --bg-3:    oklch(0.306 0.011 58);
  --ink:     oklch(0.952 0.013 80);
  --ink-soft:oklch(0.790 0.013 74);
  --ink-faint:oklch(0.628 0.012 68);
  --hair:    rgba(247,238,226,0.14);
  --hair-2:  rgba(247,238,226,0.07);
  --scrim:   rgba(15,12,9,0.55);
  --grain-op:0.04;
  --grain-blend:overlay;
  --slot-bg: rgba(247,238,226,0.05);
}
[data-theme="light"]{
  --bg:      #F7F2EA;
  --bg-2:    #EFE8DB;
  --bg-3:    #E7DECF;
  --ink:     #26231E;
  --ink-soft:#574F44;
  --ink-faint:#8a8072;
  --hair:    rgba(38,35,30,0.14);
  --hair-2:  rgba(38,35,30,0.07);
  --scrim:   rgba(20,16,12,0.30);
  --grain-op:0.04;
  --grain-blend:multiply;
  --slot-bg: rgba(38,35,30,0.04);
}

/* ---------- ACCENTS ---------- */
[data-accent="terra"] { --accent:oklch(0.648 0.112 44); }
[data-accent="taupe"] { --accent:#8b7355; }
[data-accent="olive"] { --accent:oklch(0.598 0.060 124); }
[data-accent="steel"] { --accent:oklch(0.610 0.046 238); }

/* ---------- FONT PAIRINGS ---------- */
[data-font="heritage"]{ --serif:'Cormorant Garamond',Georgia,serif; --sans:'Jost',system-ui,sans-serif; }
[data-font="editorial"]{ --serif:'Spectral',Georgia,serif;        --sans:'Archivo',system-ui,sans-serif; }
[data-font="classic"]  { --serif:'Libre Caslon Display',Georgia,serif; --sans:'Jost',system-ui,sans-serif; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans); font-weight:300; line-height:1.7;
  background:var(--bg); color:var(--ink); overflow-x:hidden;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  transition:background .5s var(--ease), color .5s var(--ease);
}

/* film grain */
body::before{
  content:""; position:fixed; inset:0; z-index:3; pointer-events:none;
  opacity:var(--grain-op); mix-blend-mode:var(--grain-blend);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

::selection{ background:var(--accent); color:var(--bg); }

/* ---------- shared type ---------- */
.kicker{
  font-family:var(--mono); font-size:11px; font-weight:400;
  letter-spacing:0.22em; text-transform:uppercase; color:var(--accent);
  display:inline-flex; align-items:center; gap:11px;
}
.kicker .ln{ width:26px; height:1px; background:var(--accent); opacity:.65; display:inline-block; }

.display{
  font-family:var(--serif); font-weight:500; color:var(--ink);
  line-height:0.98; letter-spacing:-0.012em; text-wrap:pretty;
  font-size:clamp(42px,7.4vw,104px);
}
.display em{ font-style:italic; color:var(--accent); }

h2.title{
  font-family:var(--serif); font-weight:500; color:var(--ink);
  font-size:clamp(32px,4.6vw,58px); line-height:1.08; letter-spacing:-0.008em;
  text-wrap:pretty;
}
h2.title em{ font-style:italic; color:var(--accent); }

.lede{
  font-family:var(--serif); font-style:italic; font-weight:400;
  font-size:clamp(20px,2.3vw,30px); line-height:1.42; color:var(--ink);
  max-width:30ch; text-wrap:pretty;
}
.body{
  font-size:clamp(15px,1.05vw,16.5px); font-weight:300; line-height:1.85;
  color:var(--ink-soft); max-width:60ch;
}
.body strong{ color:var(--ink); font-weight:400; }
.eyebrow{
  font-family:var(--mono); font-size:11px; letter-spacing:0.2em;
  text-transform:uppercase; color:var(--ink-faint);
}

/* ---------- layout primitives ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-left:var(--bezel); padding-right:var(--bezel); }
.section{ padding:clamp(78px,8.5vw,132px) 0; position:relative; }
.section + .section{ border-top:1px solid var(--hair-2); }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:40;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--bezel);
  transition:background .4s var(--ease), border-color .4s var(--ease), backdrop-filter .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:color-mix(in oklab, var(--bg) 82%, transparent);
  -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px);
  border-bottom:1px solid var(--hair);
}
.brand{ display:flex; align-items:baseline; gap:19px; text-decoration:none; color:var(--ink); }
.brand .mk{ font-family:var(--serif); font-size:20px; font-weight:600; letter-spacing:0.14em; text-transform:uppercase; line-height:1; padding-left:0.14em; }
.brand .sub{ font-family:var(--mono); font-size:9.5px; letter-spacing:0.24em; text-transform:uppercase; color:var(--ink-faint); }
.nav-links{ display:flex; align-items:center; gap:34px; }
.nav-links a{
  font-family:var(--sans); font-size:12px; font-weight:400; letter-spacing:0.04em;
  text-transform:uppercase; color:var(--ink-soft); text-decoration:none;
  transition:color .25s var(--ease); position:relative;
}
.nav-links a:not(.pill)::after{
  content:""; position:absolute; left:0; right:100%; bottom:-5px; height:1px;
  background:var(--accent); transition:right .3s var(--ease);
}
.nav-links a:not(.pill):hover{ color:var(--ink); }
.nav-links a:not(.pill):hover::after{ right:0; }
.pill{
  border:1px solid var(--accent); border-radius:999px; padding:8px 16px !important;
  color:var(--accent) !important; transition:background .25s,color .25s;
}
.pill:hover{ background:var(--accent); color:var(--bg) !important; }
@media(max-width:760px){ .nav-links a:not(.pill){ display:none; } }

/* ============================================================
   HERO — three layouts toggled by [data-hero]
   ============================================================ */
.hero{ display:none; }
[data-hero="a"] #hero-a,
[data-hero="b"] #hero-b{ display:block; }
[data-hero="c"] #hero-c{ display:flex; }

.hero-cta{ display:flex; gap:16px; flex-wrap:wrap; align-items:center; }
.btn{
  font-family:var(--sans); font-size:13px; font-weight:500; letter-spacing:0.05em;
  text-transform:uppercase; text-decoration:none; cursor:pointer;
  padding:15px 30px; border-radius:2px; border:1px solid var(--accent);
  background:var(--accent); color:var(--bg);
  transition:transform .25s var(--ease), background .25s, color .25s, border-color .25s;
}
.btn:hover{ transform:translateY(-2px); }
.btn{ white-space:nowrap; }
.btn.ghost{ background:transparent; color:var(--ink); border-color:var(--hair); }
.btn.ghost:hover{ border-color:var(--accent); color:var(--accent); }

.spec-row{ display:flex; flex-wrap:wrap; gap:0; border-top:1px solid var(--hair); }
.spec-row .spec{ padding:18px 28px 18px 0; margin-right:28px; border-right:1px solid var(--hair); }
.spec-row .spec:last-child{ border-right:0; }
.spec .v{ font-family:var(--serif); font-size:clamp(22px,2.4vw,30px); color:var(--ink); line-height:1; }
.spec .l{ font-family:var(--mono); font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ink-faint); margin-top:8px; }

/* ---- HERO A — statement ---- */
#hero-a .ha-inner{ max-width:var(--maxw); margin:0 auto; padding:clamp(116px,15vh,164px) var(--bezel) clamp(40px,6vh,76px); }
#hero-a .display{ margin:26px 0 30px; max-width:16ch; }
#hero-a .lede{ max-width:42ch; margin-bottom:38px; }
.hc-cta, #hero-a .hero-cta{ align-self:flex-start; }

/* ---- HERO B — split type ---- */
#hero-b{ padding-top:120px; }
#hero-b .hb-grid{ display:grid; grid-template-columns:1.1fr 0.9fr; gap:clamp(40px,6vw,92px); align-items:center; min-height:calc(100vh - 120px); padding-bottom:60px; }
#hero-b .display{ margin:24px 0 0; }
#hero-b .hb-side{ border-left:1px solid var(--hair); padding-left:clamp(28px,3vw,52px); }
#hero-b .hb-side .lede{ margin-bottom:34px; max-width:34ch; }
#hero-b .spec-row{ margin-top:40px; }
@media(max-width:900px){
  #hero-b .hb-grid{ grid-template-columns:1fr; gap:42px; min-height:0; }
  #hero-b .hb-side{ border-left:0; border-top:1px solid var(--hair); padding-left:0; padding-top:36px; }
}

/* ---- HERO C — editorial centered ---- */
#hero-c{ min-height:100vh; flex-direction:column; justify-content:center; padding-top:128px; padding-bottom:clamp(48px,7vw,90px); text-align:center; }
#hero-c .hc-head{ display:flex; flex-direction:column; align-items:center; gap:26px; }
#hero-c .display{ max-width:17ch; }
#hero-c .lede{ max-width:46ch; }
#hero-c .meta{ display:flex; gap:0; justify-content:center; flex-wrap:wrap; }
#hero-c .meta span{ font-family:var(--mono); font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--ink-faint); padding:0 22px; border-right:1px solid var(--hair); }
#hero-c .meta span:last-child{ border-right:0; }
#hero-c .hc-cta{ margin-top:6px; }

/* ============================================================
   WHAT WE RESTORE
   ============================================================ */
.sec-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:40px; margin-bottom:clamp(40px,5vw,68px); flex-wrap:wrap; }
.sec-head .title{ margin-top:18px; }
.sec-head .body{ max-width:34ch; }

.fleet{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,34px); }
@media(max-width:880px){ .fleet{ grid-template-columns:1fr; max-width:480px; margin:0 auto; } }
.marque{ display:flex; flex-direction:column; padding-top:26px; border-top:1px solid var(--hair); }
.marque .yr{ font-family:var(--mono); font-size:11px; letter-spacing:0.16em; color:var(--ink-faint); }
.marque .nm{ font-family:var(--serif); font-size:clamp(28px,3.2vw,40px); color:var(--ink); line-height:1.02; margin:14px 0 16px; }
.marque .tx{ font-size:14.5px; line-height:1.75; color:var(--ink-soft); font-weight:300; }
.marque .ft{ margin-top:auto; padding-top:20px; font-family:var(--mono); font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-faint); }

/* ============================================================
   THE CRAFT
   ============================================================ */
#craft{ background:var(--bg-2); }
.craft-grid{ display:grid; grid-template-columns:0.85fr 1.15fr; gap:clamp(40px,6vw,96px); align-items:start; }
@media(max-width:900px){ .craft-grid{ grid-template-columns:1fr; gap:48px; } }
.craft-grid .lede{ margin-top:22px; }
.principles{ display:flex; flex-direction:column; }
.principle{ display:grid; grid-template-columns:auto 1fr; gap:28px; padding:26px 0; border-top:1px solid var(--hair); }
.principle:last-child{ border-bottom:1px solid var(--hair); }
.principle .no{ font-family:var(--mono); font-size:12px; color:var(--accent); letter-spacing:0.1em; padding-top:6px; }
.principle h3{ font-family:var(--serif); font-weight:500; font-size:clamp(20px,2.1vw,26px); color:var(--ink); line-height:1.1; }
.principle p{ font-size:14.5px; line-height:1.7; color:var(--ink-soft); font-weight:300; margin-top:8px; max-width:48ch; }

/* ============================================================
   THE VISION
   ============================================================ */
#vision{ background:var(--bg-2); }
.vision-inner{ max-width:860px; margin:0 auto; text-align:center; }
#vision .kicker{ margin-bottom:clamp(26px,3vw,38px); }
.vision-lede{ font-family:var(--serif); font-style:italic; font-weight:400; font-size:clamp(26px,3.7vw,46px); line-height:1.24; color:var(--ink); text-wrap:pretty; }
.vision-lede .vl-line{ display:block; }
.vision-lede .vl-line + .vl-line{ margin-top:0.18em; }
.vision-lede em{ font-style:italic; color:var(--accent); }
.vision-body{ max-width:58ch; margin:clamp(32px,4vw,48px) auto 0; }
.vision-body p{ font-size:clamp(15px,1.05vw,16.5px); line-height:1.92; color:var(--ink-soft); font-weight:300; text-wrap:pretty; }
.vision-body p + p{ margin-top:18px; }

/* ============================================================
   INQUIRE / COMING SOON
   ============================================================ */
#inquire{ }
.inq-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(44px,6vw,100px); align-items:start; }
@media(max-width:880px){ .inq-grid{ grid-template-columns:1fr; gap:48px; } }
.inq-grid .body{ margin-top:28px; }
.inq-contact{ margin-top:34px; display:flex; flex-direction:column; gap:6px; }
.inq-contact a{ font-family:var(--serif); font-size:clamp(22px,2.4vw,30px); color:var(--ink); text-decoration:none; transition:color .25s; }
.inq-contact a:hover{ color:var(--accent); }
.inq-contact .l{ font-family:var(--mono); font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ink-faint); }

form.inq{ display:flex; flex-direction:column; gap:20px; }
.field{ display:flex; flex-direction:column; gap:9px; }
.field label{ font-family:var(--mono); font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ink-faint); }
.field input,.field select,.field textarea{
  font-family:var(--sans); font-size:15px; font-weight:300; color:var(--ink);
  background:transparent; border:0; border-bottom:1px solid var(--hair);
  padding:9px 2px; outline:none; transition:border-color .25s; width:100%;
}
.field select{
  -webkit-appearance:none; -moz-appearance:none; appearance:none;
  border-radius:0; cursor:pointer; padding-right:26px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23a8997f' stroke-width='1.4'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 2px center; background-size:11px;
}
.field textarea{ resize:vertical; min-height:74px; line-height:1.6; }
.field input:focus,.field select:focus,.field textarea:focus{ border-color:var(--accent); }
/* live email validation feedback (toggled by JS once the user types) */
.field input.is-valid{ border-color:var(--accent); }
.field input.is-invalid,
.field input.is-invalid:focus{ border-color:var(--err); }
/* branded inline validation message */
.field-err{
  font-family:var(--mono); font-size:10px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--err); margin-top:1px; display:none;
}
.field-err.show{ display:block; }
.field select option{ background:var(--bg-2); color:var(--ink); }
.field input::placeholder,.field textarea::placeholder{ color:var(--ink-faint); }
.inq .row2{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
@media(max-width:520px){ .inq .row2{ grid-template-columns:1fr; } }
.inq .btn{ align-self:flex-start; margin-top:6px; border:0; }
.inq-done{ display:none; padding:28px 0; }
.inq-done.show{ display:block; }
.inq-done .display{ font-size:clamp(28px,4vw,46px); }
.inq-done p{ color:var(--ink-soft); margin-top:14px; font-weight:300; }
form.inq.hide{ display:none; }

/* ============================================================
   FOOTER — closing statement
   ============================================================ */
.footer{ background:var(--bg-2); padding:clamp(96px,13vw,168px) 0 clamp(40px,5vw,60px); border-top:1px solid var(--hair); text-align:center; }
.foot-eyebrow{ font-family:var(--mono); font-size:11px; letter-spacing:0.28em; text-transform:uppercase; color:var(--accent); }
.foot-statement{ font-family:var(--serif); font-weight:500; color:var(--ink); font-size:clamp(34px,5.4vw,68px); line-height:1.08; letter-spacing:-0.01em; text-wrap:pretty; margin:clamp(22px,3vw,36px) auto 0; max-width:15ch; }
.foot-statement em{ font-style:italic; color:var(--accent); }
.foot-rule{ width:46px; height:1px; background:var(--accent); opacity:.7; margin:clamp(28px,4vw,44px) auto; }
.foot-note{ font-size:clamp(14px,1.05vw,16px); line-height:1.85; color:var(--ink-soft); font-weight:300; max-width:50ch; margin:0 auto; text-wrap:pretty; }
.foot-base{ margin-top:clamp(60px,8vw,100px); }
.foot-base p{ font-family:var(--mono); font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color:var(--ink-faint); }

/* reveal-on-scroll */
.rv{ opacity:0; transform:translateY(22px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.rv.in{ opacity:1; transform:none; }
@media(prefers-reduced-motion:reduce){ .rv{ opacity:1; transform:none; transition:none; } html{ scroll-behavior:auto; } }

/* ============================================================
   MOBILE / TABLET REFINEMENTS
   ============================================================ */
@media(max-width:640px){
  /* nav: keep the wordmark from crowding out the Inquire pill */
  .nav{ padding-top:15px; padding-bottom:15px; }
  .brand{ gap:13px; }
  .brand .mk{ font-size:21px !important; }
  .brand .sub{ font-size:10px !important; }
  .nav-links{ gap:0; }
  .pill{ padding:7px 14px !important; font-size:12px; }

  /* hero: tighter top gap under the fixed nav, calmer rhythm */
  #hero-c{ padding-top:96px !important; }
  #hero-c .hc-head{ gap:20px; }
  /* meta: stack cleanly without the floating divider when it wraps */
  #hero-c .meta{ flex-direction:column; gap:7px; }
  #hero-c .meta span{ border-right:0; padding:0; }
  #hero-a .ha-inner{ padding-top:104px; }
  #hero-b{ padding-top:96px; }

  /* sections: trim the very large vertical padding on small screens */
  .section{ padding:clamp(56px,14vw,78px) 0; }
  .footer{ padding-top:64px !important; padding-bottom:48px !important; }

  /* center the section name + summary blocks on mobile */
  .sec-head{ flex-direction:column; align-items:center; text-align:center; gap:18px; }
  .sec-head .body{ max-width:42ch; }
  /* "Three marques." / "Restored to drive." on separate lines (mobile only) */
  #restore .title em{ display:block; }
  .craft-grid > div:first-child{ text-align:center; }
  .craft-grid .lede, .craft-grid .body{ margin-left:auto; margin-right:auto; }
  #inquire .inq-grid > div:first-child{ text-align:center; }
  #inquire .inq-grid .body{ margin-left:auto; margin-right:auto; }
  .kicker{ justify-content:center; }
  /* keep the principle list and form fields left-aligned for readability */
  .principle, .field, .inq-contact{ text-align:left; }
  .principle .kicker, .inq-contact .kicker{ justify-content:flex-start; }

  /* avoid iOS focus-zoom on form fields */
  .field input, .field select, .field textarea{ font-size:16px; }
}

@media(max-width:430px){
  /* keep "Restorations" beside the wordmark, just tighter, so the
     header reads the same on iPhone Pro and Pro Max */
  .brand{ gap:9px; }
  .brand .mk{ font-size:19px !important; letter-spacing:0.1em; }
  .brand .sub{ font-size:9px !important; letter-spacing:0.18em; }
  .nav{ padding-left:16px; padding-right:16px; }
  .pill{ padding:7px 13px !important; }
}

