/* ============================================================
   SAYF DETAILING | "The Salt Belt"
   Mobile car detailing, Ottawa
   ============================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Archivo:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900&family=Archivo+Expanded:wght@600;700;800;900&family=Hanken+Grotesk:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

/* ---- Tokens ---- */
:root{
  --ink:        #112a2d;   /* deep petrol-teal base */
  --ink-2:      #163438;   /* raised petrol surface */
  --ink-3:      #214b50;   /* hairline-on-dark / borders */
  --ink-4:      #345e63;   /* lighter divider on dark */
  --bone:       #ecefed;   /* cool frost off-white */
  --bone-2:     #e0e5e2;   /* deeper frost, sunken */
  --paper:      #f6f8f7;   /* lightest frost paper */
  --amber:      #ef6a43;   /* persimmon / coral accent */
  --amber-deep: #cf4a26;   /* pressed / text-on-frost accent */
  --amber-soft: #fbe0d6;   /* accent tint bg */
  --mist:       #93a6a6;   /* cool teal-gray text on dark */
  --mist-2:     #6a8080;   /* dimmer */
  --ink-soft:   #4d5a59;   /* body gray on light */
  --line-light: #d4dad7;   /* hairline on frost */
  --line-light2:#c3ccc8;

  --maxw: 1200px;
  --gut: clamp(20px, 5vw, 64px);
  --radius: 4px;
  --radius-lg: 10px;

  --shadow-pop: 0 18px 50px -16px rgba(10,11,13,.55);
  --shadow-card: 0 1px 0 rgba(0,0,0,.04), 0 14px 36px -22px rgba(20,22,26,.5);

  --ff-disp: 'Archivo Expanded', 'Archivo', sans-serif;
  --ff-arch: 'Archivo', sans-serif;
  --ff-body: 'Hanken Grotesk', system-ui, sans-serif;

  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--ff-body);
  background:var(--bone);
  color:var(--ink);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--amber); color:var(--ink); }

/* ---- Layout helpers ---- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
.section{ padding-block:clamp(64px, 9vw, 128px); }
.eyebrow{
  font-family:var(--ff-arch);
  font-weight:700;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--amber-deep);
}
.eyebrow::before{
  content:"";
  width:26px; height:2px; background:var(--amber); display:inline-block;
}
.eyebrow.on-dark{ color:var(--amber); }
.eyebrow.center{ justify-content:center; }

h1,h2,h3{ margin:0; line-height:1.02; letter-spacing:-.01em; }
.display{
  font-family:var(--ff-disp);
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:-.005em;
  line-height:.95;
}
.h2{
  font-family:var(--ff-disp);
  font-weight:800;
  text-transform:uppercase;
  font-size:clamp(30px, 4.6vw, 56px);
  line-height:.98;
  letter-spacing:-.01em;
}
.lead{ font-size:clamp(17px,1.4vw,20px); color:var(--ink-soft); line-height:1.6; }
.lead.on-dark{ color:var(--mist); }

.amber-text{ color:var(--amber-deep); }
.on-dark .amber-text, .amber-text.on-dark{ color:var(--amber); }

/* ---- Buttons ---- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--ff-arch); font-weight:700;
  font-size:15px; letter-spacing:.01em;
  padding:15px 24px; border-radius:var(--radius);
  border:1.5px solid transparent;
  transition:transform .12s var(--ease), background .15s var(--ease), color .15s var(--ease), border-color .15s var(--ease);
  white-space:nowrap;
}
.btn svg{ width:18px; height:18px; }
.btn-amber{ background:var(--amber); color:var(--ink); }
.btn-amber:hover{ background:#ff8159; }
.btn-amber:active{ transform:translateY(1px); }
.btn-ink{ background:var(--ink); color:var(--bone); }
.btn-ink:hover{ background:#000; }
.btn-ghost{ background:transparent; border-color:var(--ink); color:var(--ink); }
.btn-ghost:hover{ background:var(--ink); color:var(--bone); }
.btn-ghost.on-dark{ border-color:var(--ink-4); color:var(--bone); }
.btn-ghost.on-dark:hover{ background:var(--bone); color:var(--ink); border-color:var(--bone); }
.btn-lg{ padding:18px 30px; font-size:16px; }

/* ============================================================
   HEADER
   ============================================================ */
.nav{
  position:sticky; top:0; z-index:60;
  background:rgba(17,42,45,.82);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--ink-3);
  color:var(--bone);
}
.nav-row{ display:flex; align-items:center; justify-content:space-between; height:68px; gap:24px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand-mark{
  width:38px; height:38px; flex:none; border-radius:7px;
  background:var(--amber); color:var(--ink);
  display:grid; place-items:center;
  font-family:var(--ff-disp); font-weight:900; font-size:19px;
}
.brand-name{ display:block; font-family:var(--ff-disp); font-weight:800; text-transform:uppercase; font-size:16px; letter-spacing:.02em; line-height:1; color:var(--bone); }
.brand-sub{ display:block; font-family:var(--ff-arch); font-weight:600; font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--mist); margin-top:4px; }
.nav-links{ display:flex; align-items:center; gap:30px; margin-left:auto; }
.nav-links a{ font-family:var(--ff-arch); font-weight:600; font-size:14px; color:var(--mist); transition:color .15s; }
.nav-links a:hover{ color:var(--bone); }
.nav-cta{ display:flex; align-items:center; gap:10px; }
.nav-phone{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--ff-arch); font-weight:700; font-size:15px; color:var(--bone);
}
.nav-phone svg{ width:16px; height:16px; color:var(--amber); }
@media(max-width:900px){ .nav-links{ display:none; } }
@media(max-width:560px){ .nav-phone{ display:none; } .brand-name, .brand-sub{ white-space:nowrap; } }

/* ============================================================
   HERO
   ============================================================ */
.hero{ background:var(--ink); color:var(--bone); position:relative; overflow:hidden; }
.hero-inner{ padding-top:clamp(48px,7vw,84px); padding-bottom:clamp(40px,5vw,64px); position:relative; z-index:2; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,4vw,60px); align-items:center; }
.hero-eyebrow{
  font-family:var(--ff-arch); font-weight:700; font-size:12.5px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--mist); display:flex; align-items:center; gap:12px;
  margin-bottom:30px;
}
.hero-eyebrow::before{ content:""; width:30px; height:2px; background:var(--amber); }
.hero h1{
  font-family:var(--ff-disp); font-weight:900; text-transform:uppercase;
  font-size:clamp(38px, 5.4vw, 70px); line-height:.92; letter-spacing:-.02em;
  margin:0;
}
.hero h1 em{ font-style:normal; color:var(--amber); }
.hero-sub{ font-size:clamp(17px,1.45vw,20px); color:var(--mist); max-width:34ch; margin:28px 0 0; line-height:1.55; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:12px; margin-top:34px; }
.hero-facts{ display:flex; flex-direction:column; margin-top:40px; padding-top:10px; border-top:1px solid var(--ink-3); }
.fact{ display:flex; align-items:center; gap:14px; padding:14px 0; border-bottom:1px solid var(--ink-3); }
.fact:last-child{ border-bottom:0; }
.fact svg{ flex:none; width:19px; height:19px; color:var(--amber); stroke-width:2; }
.fact b{ font-family:var(--ff-arch); font-weight:700; font-size:15.5px; color:var(--bone); }
.fact span{ font-size:14.5px; color:var(--mist); }
.fact .sep{ color:var(--ink-4); }

/* hero before/after card */
.hero-ba{ position:relative; }
.hero-ba .ba{ box-shadow:var(--shadow-pop); }
.hero-ba-tag{
  position:absolute; left:-14px; top:-14px; z-index:5;
  background:var(--amber); color:var(--ink);
  font-family:var(--ff-arch); font-weight:700; font-size:12.5px; letter-spacing:.04em;
  padding:9px 14px; border-radius:3px; transform:rotate(-2.5deg);
  box-shadow:0 8px 22px -8px rgba(0,0,0,.6);
}
@media(max-width:860px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-ba{ order:-1; }
}

/* salt grain texture motif (subtle) */
.grain{
  position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.5;
  background-image:radial-gradient(circle at 1px 1px, rgba(255,255,255,.05) 1px, transparent 0);
  background-size:22px 22px;
}

/* ============================================================
   BEFORE / AFTER SLIDER
   ============================================================ */
.ba{
  position:relative; width:100%; aspect-ratio:4/3; overflow:hidden;
  border-radius:var(--radius-lg); user-select:none; touch-action:pan-y;
  background:var(--ink-2); cursor:ew-resize;
  border:1px solid rgba(0,0,0,.25);
}
.ba img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; pointer-events:none; }
.ba .after-wrap{ position:absolute; inset:0; }
.ba .before-wrap{ position:absolute; inset:0; overflow:hidden; will-change:clip-path; clip-path:inset(0 50% 0 0); }
.ba .ba-handle{
  position:absolute; top:0; bottom:0; left:50%; width:2px; background:var(--bone);
  transform:translateX(-1px); z-index:4; will-change:left;
  box-shadow:0 0 0 1px rgba(0,0,0,.25);
}
.ba .ba-knob{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:46px; height:46px; border-radius:50%; background:var(--bone); color:var(--ink);
  display:grid; place-items:center; box-shadow:0 6px 18px -4px rgba(0,0,0,.6);
}
.ba .ba-knob svg{ width:22px; height:22px; }
.ba-label{
  position:absolute; bottom:12px; z-index:3;
  font-family:var(--ff-arch); font-weight:700; font-size:11.5px; letter-spacing:.14em; text-transform:uppercase;
  padding:6px 11px; border-radius:3px; color:var(--bone);
  background:rgba(17,42,45,.7); backdrop-filter:blur(4px);
}
.ba-label.before{ left:12px; }
.ba-label.after{ right:12px; background:rgba(239,106,67,.94); color:var(--ink); }

/* ============================================================
   STEPS (also used for About stats)
   ============================================================ */
.steps{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(28px,4vw,56px); margin-top:56px; max-width:640px; }
.step{ position:relative; padding-top:24px; border-top:2px solid var(--ink); }
.step-n{ font-family:var(--ff-disp); font-weight:800; font-size:clamp(34px,4vw,46px); line-height:1; color:var(--amber-deep); letter-spacing:-.02em; display:block; }
.step h3{ font-family:var(--ff-arch); font-weight:700; font-size:21px; margin:18px 0 10px; letter-spacing:-.01em; }
.step p{ margin:0; color:var(--ink-soft); font-size:15.5px; }
@media(max-width:760px){ .steps{ grid-template-columns:1fr; gap:30px; } }

/* ============================================================
   SALT PROBLEM (dark)
   ============================================================ */
.dark{ background:var(--ink); color:var(--bone); }
.dark .lead{ color:var(--mist); }
.salt-grid{ display:grid; grid-template-columns:.82fr 1.18fr; gap:clamp(30px,5vw,72px); align-items:center; }
.salt-points{ list-style:none; margin:30px 0 0; padding:0; display:grid; gap:2px; }
.salt-points li{ display:flex; gap:16px; align-items:flex-start; padding:18px 0; border-top:1px solid var(--ink-3); }
.salt-points li:last-child{ border-bottom:1px solid var(--ink-3); }
.salt-points .ico{ flex:none; width:26px; height:26px; color:var(--amber); stroke-width:1.6; margin-top:2px; }
.salt-points b{ font-family:var(--ff-arch); font-weight:700; font-size:17px; color:var(--bone); display:block; }
.salt-points span{ color:var(--mist); font-size:15px; }
@media(max-width:820px){ .salt-grid{ grid-template-columns:1fr; } }

/* ============================================================
   GALLERY of sliders
   ============================================================ */
.ba-gallery{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(18px,2.2vw,28px); margin-top:48px; }
.ba-card .cap{ display:flex; align-items:baseline; justify-content:space-between; gap:14px; margin-top:14px; }
.ba-card .cap b{ font-family:var(--ff-arch); font-weight:700; font-size:16px; }
.ba-card .cap span{ font-size:13px; color:var(--ink-soft); }
.on-dark .ba-card .cap span{ color:var(--mist); }
@media(max-width:720px){ .ba-gallery{ grid-template-columns:1fr; } }

/* ============================================================
   SERVICES
   ============================================================ */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2vw,26px); margin-top:48px; }
.svc{ background:var(--paper); border:1px solid var(--line-light); border-radius:var(--radius-lg); padding:30px; }
.svc-head{ display:flex; align-items:baseline; gap:14px; margin-bottom:22px; padding-bottom:18px; border-bottom:1px solid var(--line-light); }
.svc-ix{ font-family:var(--ff-disp); font-weight:800; font-size:17px; color:var(--amber-deep); letter-spacing:.02em; }
.svc-ix.amber{ color:var(--amber); }
.svc h3{ font-family:var(--ff-disp); font-weight:800; text-transform:uppercase; font-size:18px; letter-spacing:-.005em; }
.svc-list{ list-style:none; margin:0; padding:0; display:grid; gap:11px; }
.svc-list li{ display:flex; gap:11px; align-items:flex-start; font-size:15.5px; color:var(--ink-soft); }
.svc-list .chk{ flex:none; width:18px; height:18px; margin-top:2px; color:var(--amber-deep); stroke-width:2.2; }
.svc.premium{ background:var(--ink); border-color:var(--ink); color:var(--bone); }
.svc.premium h3{ color:var(--bone); }
.svc.premium .svc-ico{ background:var(--amber); color:var(--ink); }
.svc.premium .svc-list li{ color:var(--mist); }
.svc.premium .svc-head{ border-color:var(--ink-4); }
.svc.premium .tag{ font-family:var(--ff-arch); font-weight:700; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--amber); margin-bottom:6px; }
@media(max-width:860px){ .svc-grid{ grid-template-columns:1fr; } }

/* ============================================================
   PRICING
   ============================================================ */
.price-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2vw,24px); margin-top:48px; align-items:stretch; }
.plan{
  background:var(--paper); border:1px solid var(--line-light); border-radius:var(--radius-lg);
  padding:32px 30px; display:flex; flex-direction:column; position:relative;
}
.plan.feat{ background:var(--ink); color:var(--bone); border-color:var(--ink); box-shadow:var(--shadow-pop); }
.plan-badge{
  position:absolute; top:-12px; left:30px;
  background:var(--amber); color:var(--ink);
  font-family:var(--ff-arch); font-weight:700; font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  padding:6px 12px; border-radius:3px;
}
.plan-name{ font-family:var(--ff-disp); font-weight:800; text-transform:uppercase; font-size:24px; letter-spacing:-.01em; }
.plan-desc{ font-size:15px; color:var(--ink-soft); margin:10px 0 0; min-height:44px; }
.plan.feat .plan-desc{ color:var(--mist); }
.plan-prices{ display:grid; gap:1px; margin:24px 0; background:var(--line-light); border:1px solid var(--line-light); border-radius:6px; overflow:hidden; }
.plan.feat .plan-prices{ background:var(--ink-3); border-color:var(--ink-3); }
.price-row{ display:flex; align-items:center; justify-content:space-between; background:var(--paper); padding:13px 16px; }
.plan.feat .price-row{ background:var(--ink-2); }
.price-row .veh{ font-size:14px; color:var(--ink-soft); font-weight:500; }
.plan.feat .price-row .veh{ color:var(--mist); }
.price-row .amt{ font-family:var(--ff-disp); font-weight:800; font-size:20px; font-feature-settings:'tnum'; }
.price-row .amt::before{ content:"$"; font-size:13px; vertical-align:top; margin-right:1px; color:var(--amber-deep); }
.plan.feat .price-row .amt::before{ color:var(--amber); }
.plan-incl{ list-style:none; margin:0 0 26px; padding:0; display:grid; gap:10px; }
.plan-incl li{ display:flex; gap:10px; font-size:14.5px; color:var(--ink-soft); align-items:flex-start; }
.plan.feat .plan-incl li{ color:var(--mist); }
.plan-incl .chk{ flex:none; width:16px; height:16px; margin-top:3px; color:var(--amber-deep); stroke-width:2.4; }
.plan.feat .plan-incl .chk{ color:var(--amber); }
.plan .btn{ margin-top:auto; justify-content:center; }
.plan.custom{ background:var(--bone-2); }
.plan.custom .quote{ font-family:var(--ff-disp); font-weight:800; font-size:30px; text-transform:uppercase; letter-spacing:-.01em; margin:22px 0; }
@media(max-width:860px){ .price-grid{ grid-template-columns:1fr; max-width:440px; margin-inline:auto; } }

/* add-ons */
.addons{ margin-top:30px; border:1px solid var(--line-light); border-radius:var(--radius-lg); background:var(--paper); overflow:hidden; }
.addons-head{ padding:20px 26px; border-bottom:1px solid var(--line-light); display:flex; align-items:center; gap:12px; }
.addons-head h3{ font-family:var(--ff-arch); font-weight:700; font-size:17px; }
.addons-grid{ display:grid; grid-template-columns:repeat(4,1fr); }
.addon{ padding:20px 26px; border-right:1px solid var(--line-light); }
.addon:last-child{ border-right:0; }
.addon .ttl{ font-size:14.5px; font-weight:600; color:var(--ink); }
.addon .amt{ font-family:var(--ff-disp); font-weight:800; font-size:18px; margin-top:6px; color:var(--amber-deep); font-feature-settings:'tnum'; }
@media(max-width:760px){ .addons-grid{ grid-template-columns:repeat(2,1fr); } .addon:nth-child(2n){ border-right:0; } .addon{ border-bottom:1px solid var(--line-light); } }
@media(max-width:430px){ .addons-grid{ grid-template-columns:1fr; } .addon{ border-right:0; } }
.disclaimer{ display:flex; gap:12px; align-items:flex-start; margin-top:22px; font-size:14px; color:var(--ink-soft); max-width:62ch; }
.disclaimer svg{ flex:none; width:18px; height:18px; color:var(--amber-deep); margin-top:2px; }

/* ============================================================
   RESULTS GALLERY (masonry-ish)
   ============================================================ */
.results-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(12px,1.4vw,18px); margin-top:48px; }
.result{ position:relative; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:3/4; background:var(--ink-2); }
.result img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.result:hover img{ transform:scale(1.05); }
.result .rl{ position:absolute; left:12px; bottom:11px; font-family:var(--ff-arch); font-weight:600; font-size:12px; color:var(--bone); letter-spacing:.02em; text-shadow:0 1px 6px rgba(0,0,0,.7); z-index:2; }
.result::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(17,42,45,.55), transparent 45%); }
.result.tall{ grid-row:span 1; }
@media(max-width:820px){ .results-grid{ grid-template-columns:repeat(2,1fr); } }

/* ============================================================
   BOOKING / CONTACT
   ============================================================ */
.book-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,72px); align-items:start; }
.contact-card{ display:flex; gap:16px; align-items:flex-start; padding:22px 0; border-top:1px solid var(--ink-3); }
.contact-card:first-of-type{ border-top:0; padding-top:0; }
.contact-ico{ flex:none; width:46px; height:46px; border-radius:9px; background:var(--ink-2); border:1px solid var(--ink-3); color:var(--amber); display:grid; place-items:center; }
.contact-ico svg{ width:21px; height:21px; stroke-width:1.7; }
.contact-card .l{ font-family:var(--ff-arch); font-weight:600; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--mist); }
.contact-card .v{ font-family:var(--ff-arch); font-weight:700; font-size:21px; color:var(--bone); margin-top:3px; }
.contact-card .v.sm{ font-size:17px; }
.contact-card .s{ font-size:14px; color:var(--mist); margin-top:7px; }
.contact-card .l, .contact-card .v, .contact-card .s{ display:block; }

.form{ background:var(--bone); color:var(--ink); border-radius:var(--radius-lg); padding:clamp(24px,3vw,38px); box-shadow:var(--shadow-pop); }
.form h3{ font-family:var(--ff-disp); font-weight:800; text-transform:uppercase; font-size:22px; letter-spacing:-.01em; }
.form p.fs{ font-size:14.5px; color:var(--ink-soft); margin:8px 0 24px; }
.field{ margin-bottom:18px; }
.field label{ display:block; font-family:var(--ff-arch); font-weight:600; font-size:12.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:8px; }
.field input, .field select, .field textarea{
  width:100%; font-family:var(--ff-body); font-size:16px; color:var(--ink);
  background:var(--paper); border:1.5px solid var(--line-light); border-radius:var(--radius);
  padding:13px 15px; transition:border-color .15s, box-shadow .15s;
}
.field textarea{ resize:vertical; min-height:96px; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--ink); box-shadow:0 0 0 3px rgba(239,106,67,.25); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.choice{ display:flex; flex-wrap:wrap; gap:8px; }
.choice label{
  display:inline-flex; align-items:center; gap:0; margin:0;
  font-family:var(--ff-arch); font-weight:600; font-size:14px; letter-spacing:0; text-transform:none;
  padding:10px 15px; border:1.5px solid var(--line-light); border-radius:var(--radius);
  background:var(--paper); cursor:pointer; transition:all .14s; color:var(--ink-soft);
}
.choice input{ position:absolute; opacity:0; width:0; height:0; }
.choice label:hover{ border-color:var(--ink); }
.choice input:checked + span{ }
.choice label:has(input:checked){ background:var(--ink); color:var(--bone); border-color:var(--ink); }
.form .btn{ width:100%; justify-content:center; margin-top:6px; }
.form-note{ font-size:12.5px; color:var(--ink-soft); text-align:center; margin-top:14px; }
.book-cta-row{ display:flex; gap:12px; margin-top:30px; flex-wrap:wrap; }
@media(max-width:860px){ .book-grid{ grid-template-columns:1fr; } .field-row{ grid-template-columns:1fr; } }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:#0c2023; color:var(--mist); border-top:1px solid var(--ink-3); }
.footer-top{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:30px; padding-block:54px; }
.footer .brand-name{ color:var(--bone); }
.footer-tag{ max-width:34ch; font-size:14.5px; margin-top:16px; color:var(--mist); }
.footer-cols{ display:flex; gap:60px; flex-wrap:wrap; }
.footer-col h4{ font-family:var(--ff-arch); font-weight:700; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--mist-2); margin:0 0 14px; }
.footer-col a, .footer-col p{ display:block; font-size:15px; color:var(--mist); margin:0 0 9px; transition:color .15s; }
.footer-col a:hover{ color:var(--bone); }
.footer-bottom{ border-top:1px solid var(--ink-3); padding-block:22px; display:flex; flex-wrap:wrap; gap:10px 24px; justify-content:space-between; font-size:13px; color:var(--mist-2); }
.confirm-note{ font-size:12px; color:var(--mist); }

/* ============================================================
   STICKY MOBILE CALL BAR
   ============================================================ */
.mobar{
  position:fixed; left:0; right:0; bottom:0; z-index:70;
  display:none; gap:10px; padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  background:rgba(17,42,45,.92); backdrop-filter:blur(12px); border-top:1px solid var(--ink-3);
}
.mobar .btn{ flex:1; justify-content:center; padding:14px; }
@media(max-width:760px){
  .mobar{ display:flex; }
  body{ padding-bottom:74px; }
}

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

/* section heading block */
.shead{ max-width:60ch; }
.shead.center{ margin-inline:auto; text-align:center; }
.shead .h2{ margin-top:18px; }
.shead p{ margin-top:18px; }
