/* ============================================================
   Christine Countywide Mobile Notary — Site Design System
   Brand: Navy #06183d · Red #c1121f · Gold #e5a900 · Cream
   Type:  Archivo (display + body) · Instrument Serif (accent)
   ============================================================ */

:root{
  --navy:#06183d;
  --navy-2:#0a2150;
  --navy-3:#10306e;
  --ink:#15203a;
  --body:#3c4663;
  --red:#c1121f;
  --red-dark:#9b0e18;
  --green:#11823b;
  --green-dark:#0c6b30;
  --blue:#0b4eb3;
  --blue-dark:#093f90;
  --gold:#e5a900;
  --gold-soft:#ffd66b;
  --cream:#fffdf5;
  --cream-2:#fdf8e9;
  --soft:#f7fbff;
  --mint:#f4fbf6;
  --line:#d7dce8;
  --line-soft:#e7ebf4;
  --white:#ffffff;

  --font-sans:"Archivo","Helvetica Neue",Helvetica,sans-serif;
  --font-serif:"Instrument Serif",Georgia,serif;

  --shadow-sm:0 1px 2px rgba(6,24,61,.06),0 2px 8px rgba(6,24,61,.06);
  --shadow-md:0 2px 6px rgba(6,24,61,.07),0 14px 34px rgba(6,24,61,.12);
  --shadow-lg:0 6px 16px rgba(6,24,61,.12),0 30px 60px rgba(6,24,61,.18);

  --r-sm:10px;
  --r-md:16px;
  --r-lg:24px;

  --wrap:1180px;
  --ease:cubic-bezier(.22,.8,.3,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}

body{
  font-family:var(--font-sans);
  font-size:17px;
  line-height:1.65;
  color:var(--body);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
strong{color:var(--ink);}

::selection{background:var(--gold-soft);color:var(--navy);}

h1,h2,h3,h4{
  font-family:var(--font-sans);
  color:var(--navy);
  line-height:1.06;
  letter-spacing:-.015em;
  font-weight:800;
  text-wrap:balance;
}
p{text-wrap:pretty;}

.serif-accent{
  font-family:var(--font-serif);
  font-style:italic;
  font-weight:400;
  letter-spacing:0;
  color:var(--red);
}
.dark .serif-accent{color:var(--gold-soft);}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px;}

/* ---------- Kicker / eyebrow ---------- */
.kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:12.5px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--red);
}
.kicker::before{
  content:"";
  width:26px;height:2px;
  background:var(--gold);
  flex:none;
}
.dark .kicker{color:var(--gold-soft);}
.dark .kicker::before{background:var(--red);}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-family:var(--font-sans);
  font-size:15px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  padding:16px 28px;
  border-radius:999px;
  border:2px solid transparent;
  cursor:pointer;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease),color .25s var(--ease);
  white-space:nowrap;
}
.btn svg{width:18px;height:18px;flex:none;}
.btn:hover{transform:translateY(-2px);}
.btn:active{transform:translateY(0);}
.btn-red{background:var(--red);color:#fff;box-shadow:0 10px 24px rgba(193,18,31,.32);}
.btn-red:hover{background:var(--red-dark);box-shadow:0 14px 30px rgba(193,18,31,.4);}
.btn-green{background:var(--green);color:#fff;box-shadow:0 10px 24px rgba(17,130,59,.3);}
.btn-green:hover{background:var(--green-dark);}
.btn-blue{background:var(--blue);color:#fff;box-shadow:0 10px 24px rgba(11,78,179,.3);}
.btn-blue:hover{background:var(--blue-dark);}
.btn-outline{border-color:var(--navy);color:var(--navy);background:transparent;}
.btn-outline:hover{background:var(--navy);color:#fff;}
.btn-outline-light{border-color:rgba(255,255,255,.45);color:#fff;background:transparent;}
.btn-outline-light:hover{background:#fff;color:var(--navy);border-color:#fff;}

/* ---------- Announcement bar ---------- */
.topbar{
  background:var(--navy);
  color:#fff;
  font-size:13.5px;
  font-weight:600;
  letter-spacing:.04em;
  border-bottom:3px solid var(--red);
  position:relative;
  z-index:60;
}
.topbar .wrap{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:26px;
  min-height:42px;
  flex-wrap:wrap;
  padding-top:6px;padding-bottom:6px;
}
.topbar .stars{color:var(--gold-soft);letter-spacing:.12em;}
.topbar a{color:var(--gold-soft);font-weight:700;}
.topbar a:hover{text-decoration:underline;}
.topbar .tb-sep{opacity:.35;}
@media (max-width:760px){
  .topbar .tb-hide{display:none;}
}

/* ---------- Header ---------- */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,253,245,.92);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft);
  transition:box-shadow .3s var(--ease);
}
.site-header.scrolled{box-shadow:var(--shadow-sm);}
.site-header .wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  min-height:78px;
}
.brand{display:flex;align-items:center;gap:12px;}
.brand-seal{
  width:46px;height:46px;flex:none;
  border-radius:50%;
  background:var(--navy);
  color:var(--gold-soft);
  display:grid;place-items:center;
  font-weight:900;
  font-size:15px;
  letter-spacing:.02em;
  border:2px solid var(--gold);
  box-shadow:0 0 0 3px rgba(229,169,0,.18);
}
.brand-name{display:flex;flex-direction:column;line-height:1.12;}
.brand-name b{font-size:16.5px;font-weight:800;color:var(--navy);letter-spacing:-.01em;}
.brand-name span{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--red);}

.nav-desktop{display:flex;align-items:center;gap:4px;}
.nav-desktop > li{position:relative;}
.nav-link{
  display:inline-flex;align-items:center;gap:6px;
  font-size:14.5px;font-weight:600;color:var(--ink);
  padding:10px 13px;border-radius:8px;
  transition:color .2s;
  position:relative;
}
.nav-link::after{
  content:"";position:absolute;left:13px;right:13px;bottom:4px;height:2px;
  background:var(--red);transform:scaleX(0);transform-origin:left;
  transition:transform .28s var(--ease);
}
.nav-link:hover{color:var(--red);}
.nav-link:hover::after,.nav-link[aria-current="page"]::after{transform:scaleX(1);}
.nav-link .caret{width:9px;height:9px;border-right:1.8px solid currentColor;border-bottom:1.8px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform .2s;}

.dropdown{
  position:absolute;top:calc(100% + 8px);left:0;
  min-width:264px;
  background:#fff;
  border:1px solid var(--line-soft);
  border-radius:var(--r-md);
  box-shadow:var(--shadow-lg);
  padding:10px;
  opacity:0;visibility:hidden;
  transform:translateY(8px);
  transition:opacity .22s var(--ease),transform .22s var(--ease),visibility .22s;
  display:grid;
}
.nav-desktop li:hover > .dropdown,
.nav-desktop li:focus-within > .dropdown{opacity:1;visibility:visible;transform:translateY(0);}
.dropdown a{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:10px;
  font-size:14.5px;font-weight:600;color:var(--ink);
  transition:background .18s,color .18s;
}
.dropdown a:hover{background:var(--cream-2);color:var(--red);}
.dropdown a .dot{width:6px;height:6px;border-radius:50%;background:var(--gold);flex:none;}
.dropdown a:nth-child(4n+1) .dot{background:var(--red);}
.dropdown a:nth-child(4n+2) .dot{background:var(--green);}
.dropdown a:nth-child(4n+3) .dot{background:var(--blue);}
.dropdown a:nth-child(4n+4) .dot{background:var(--gold);}
.dropdown .dd-all{border-top:1px solid var(--line-soft);margin-top:6px;padding-top:12px;color:var(--blue);}

.header-cta{display:flex;align-items:center;gap:10px;}
.header-cta .btn{padding:12px 22px;font-size:13.5px;}

.nav-burger{
  display:none;
  width:46px;height:46px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  flex-direction:column;
  align-items:center;justify-content:center;gap:5px;
}
.nav-burger span{width:20px;height:2px;background:var(--navy);transition:transform .3s var(--ease),opacity .2s;}
.nav-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-burger[aria-expanded="true"] span:nth-child(2){opacity:0;}
.nav-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* Mobile nav overlay */
.nav-mobile{
  position:fixed;inset:0;z-index:49;
  background:var(--navy);
  color:#fff;
  padding:120px 28px 120px;
  overflow-y:auto;
  opacity:0;visibility:hidden;
  transition:opacity .3s var(--ease),visibility .3s;
}
.nav-mobile.open{opacity:1;visibility:visible;}
.nav-mobile h5{
  font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold-soft);margin:26px 0 10px;font-weight:700;
}
.nav-mobile a{
  display:block;padding:9px 0;
  font-size:19px;font-weight:700;color:#fff;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.nav-mobile a:active{color:var(--gold-soft);}
@media (max-width:1080px){
  .nav-desktop{display:none;}
  .site-header .wrap > nav[aria-label="Primary"]{display:none;}
  .header-cta .btn-outline{display:none;}
  .nav-burger{display:flex;}
}

/* Small phones — brand + call CTA + burger must fit a 320-430px row */
@media (max-width:520px){
  .site-header .wrap{gap:10px;padding-left:16px;padding-right:16px;min-height:64px;}
  .brand{gap:8px;}
  .brand-seal{width:38px;height:38px;font-size:12px;}
  .brand-name b{font-size:13.5px;}
  .brand-name span{font-size:9px;letter-spacing:.14em;}
  .header-cta{gap:8px;}
  .header-cta .btn{padding:10px 12px;font-size:12.5px;}
  .header-cta .btn svg{width:15px;height:15px;}
  .nav-burger{width:40px;height:40px;}
}

/* Grids whose track minimums exceed narrow viewports collapse to one column
   (!important needed: index.html sets grid-template-columns inline) */
@media (max-width:560px){
  .check-grid{grid-template-columns:1fr !important;}
  /* icon + link + trailing text are separate flex items; without wrap their
     min-content widths sum and force the grid track past narrow viewports */
  .check-card{flex-wrap:wrap;}
}

/* 320px-class devices */
@media (max-width:360px){
  .site-header .wrap{gap:8px;padding-left:12px;padding-right:12px;}
  .mobile-bar .btn{font-size:12px;padding:12px 4px;}
}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{
  background:
    radial-gradient(900px 420px at 88% -10%, rgba(11,78,179,.35), transparent 64%),
    radial-gradient(700px 380px at -6% 110%, rgba(193,18,31,.28), transparent 60%),
    var(--navy);
  color:#fff;
  padding:84px 0 76px;
  position:relative;
  overflow:hidden;
}
.page-hero::after{
  content:"";
  position:absolute;inset:auto 0 0 0;height:3px;
  background:linear-gradient(90deg,var(--red),var(--gold),var(--green),var(--blue));
}
.page-hero .crumbs{
  display:flex;flex-wrap:wrap;gap:8px;align-items:center;
  font-size:13px;font-weight:600;letter-spacing:.05em;
  color:rgba(255,255,255,.65);
  margin-bottom:26px;
}
.page-hero .crumbs a:hover{color:var(--gold-soft);}
.page-hero .crumbs .sep{opacity:.4;}
.page-hero h1{
  color:#fff;
  font-size:clamp(36px,5vw,60px);
  font-weight:900;
  max-width:880px;
  margin:16px 0 18px;
}
.page-hero .lead{
  font-size:clamp(17px,1.7vw,20px);
  color:rgba(255,255,255,.82);
  max-width:760px;
  margin-bottom:34px;
}
.page-hero .hero-actions{display:flex;flex-wrap:wrap;gap:14px;}
.page-hero .hero-facts{
  display:flex;flex-wrap:wrap;gap:10px 26px;
  margin-top:34px;
  font-size:14px;font-weight:600;color:rgba(255,255,255,.85);
}
.page-hero .hero-facts span{display:inline-flex;align-items:center;gap:8px;}
.page-hero .hero-facts .tick{color:var(--gold-soft);font-weight:900;}

/* ---------- Sections ---------- */
.section{padding:92px 0;}
.section-soft{background:var(--soft);}
.section-cream{background:var(--cream-2);}
.section-mint{background:var(--mint);}
.section-white{background:#fff;}
.section.dark{
  background:
    radial-gradient(820px 400px at 100% 0%, rgba(11,78,179,.3), transparent 60%),
    var(--navy);
  color:#fff;
}
.section.dark h2,.section.dark h3{color:#fff;}
.section.dark p{color:rgba(255,255,255,.8);}

.section-head{max-width:780px;margin-bottom:52px;}
.section-head h2{font-size:clamp(30px,3.6vw,46px);margin:14px 0 14px;}
.section-head p{font-size:18px;}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.section-head.center .kicker{justify-content:center;}

/* ---------- Check cards ---------- */
.check-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(255px,100%),1fr));
  gap:16px;
}
.check-card{
  display:flex;align-items:flex-start;gap:14px;
  background:#fff;
  border:1px solid var(--line-soft);
  border-top:3px solid var(--blue);
  border-radius:var(--r-md);
  padding:20px 20px 19px;
  font-weight:600;
  font-size:15.5px;
  color:var(--ink);
  box-shadow:var(--shadow-sm);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.check-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.check-grid .check-card:nth-child(4n+1){border-top-color:var(--red);}
.check-grid .check-card:nth-child(4n+2){border-top-color:var(--green);}
.check-grid .check-card:nth-child(4n+3){border-top-color:var(--blue);}
.check-grid .check-card:nth-child(4n+4){border-top-color:var(--gold);}
.check-card .ck{
  flex:none;width:24px;height:24px;border-radius:50%;
  display:grid;place-items:center;
  background:var(--mint);color:var(--green);
  font-size:13px;font-weight:900;
  margin-top:1px;
}
.dark .check-card{background:rgba(255,255,255,.045);border-color:rgba(255,255,255,.12);color:#fff;box-shadow:none;}
.dark .check-card .ck{background:rgba(255,214,107,.14);color:var(--gold-soft);}

/* ---------- Split layout ---------- */
.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
}
.split .split-media img{
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);
  width:100%;
  aspect-ratio:4/3.4;
  object-fit:cover;
}
.split h2{font-size:clamp(28px,3.2vw,42px);margin:14px 0 16px;}
.split p + p{margin-top:14px;}
@media (max-width:920px){
  .split{grid-template-columns:1fr;gap:38px;}
}

/* ---------- CTA trio band ---------- */
.cta-band{
  background:
    radial-gradient(700px 360px at 12% 0%, rgba(193,18,31,.4), transparent 62%),
    radial-gradient(600px 340px at 95% 100%, rgba(11,78,179,.4), transparent 62%),
    var(--navy);
  color:#fff;
  padding:84px 0;
  position:relative;
  overflow:hidden;
}
.cta-band h2{color:#fff;font-size:clamp(30px,3.6vw,46px);margin:14px 0 12px;}
.cta-band .cta-sub{color:rgba(255,255,255,.8);max-width:640px;font-size:17.5px;}
.cta-trio{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:44px;
}
.cta-tile{
  display:flex;flex-direction:column;gap:8px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.14);
  border-radius:var(--r-lg);
  padding:30px 28px;
  position:relative;
  overflow:hidden;
  transition:transform .3s var(--ease),background .3s var(--ease),border-color .3s;
}
.cta-tile::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:var(--tile,#fff);
}
.cta-tile.call{--tile:var(--red);}
.cta-tile.text{--tile:var(--green);}
.cta-tile.email{--tile:var(--blue);}
.cta-tile:hover{transform:translateY(-5px);background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.3);}
.cta-tile .tile-kicker{
  font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.6);
}
.cta-tile .tile-main{
  font-size:clamp(20px,2vw,26px);
  font-weight:800;color:#fff;letter-spacing:-.01em;
  display:flex;align-items:center;gap:12px;
}
.cta-tile .tile-main svg{width:24px;height:24px;color:var(--tile,#fff);}
.cta-tile .tile-note{font-size:13.5px;color:rgba(255,255,255,.62);}
@media (max-width:880px){.cta-trio{grid-template-columns:1fr;}}

/* ---------- Quote / review cards ---------- */
.quote-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));
  gap:18px;
}
.quote-card{
  background:#fff;
  border:1px solid var(--line-soft);
  border-radius:var(--r-lg);
  padding:30px 28px 26px;
  box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;gap:14px;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.quote-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.quote-card .q-stars{color:var(--gold);font-size:15px;letter-spacing:.16em;}
.quote-card .q-text{
  font-family:var(--font-serif);
  font-style:italic;
  font-size:21px;
  line-height:1.4;
  color:var(--navy);
}
.quote-card .q-meta{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--body);}

/* ---------- FAQ accordion ---------- */
.faq-list{max-width:840px;margin:0 auto;display:grid;gap:12px;}
.faq-item{
  background:#fff;
  border:1px solid var(--line-soft);
  border-radius:var(--r-md);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:22px 26px;
  font-weight:700;font-size:17px;color:var(--navy);
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary .fx{
  flex:none;width:28px;height:28px;border-radius:50%;
  border:2px solid var(--line);
  display:grid;place-items:center;
  color:var(--red);font-weight:800;font-size:16px;
  transition:transform .3s var(--ease),background .3s,color .3s,border-color .3s;
}
.faq-item[open] summary .fx{transform:rotate(45deg);background:var(--red);color:#fff;border-color:var(--red);}
.faq-item .faq-a{padding:0 26px 24px;font-size:16px;}
.faq-item .faq-a p + p{margin-top:10px;}

/* ---------- City chips ---------- */
.city-grid{
  display:flex;flex-wrap:wrap;gap:10px;
}
.city-chip{
  display:inline-flex;align-items:center;gap:8px;
  border:1.5px solid var(--line);
  background:#fff;
  border-radius:999px;
  padding:10px 18px;
  font-size:14.5px;font-weight:600;color:var(--ink);
  transition:border-color .2s,transform .25s var(--ease),box-shadow .25s var(--ease);
}
.city-chip .pin{color:var(--red);font-size:13px;}
a.city-chip:hover{border-color:var(--red);transform:translateY(-2px);box-shadow:var(--shadow-sm);color:var(--red);}

/* ---------- Photo gallery ---------- */
.gallery{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.gallery a{
  display:block;border-radius:var(--r-md);overflow:hidden;
  position:relative;
  box-shadow:var(--shadow-sm);
}
.gallery img{
  width:100%;height:100%;object-fit:cover;aspect-ratio:1/1.15;
  transition:transform .6s var(--ease);
}
.gallery a:hover img{transform:scale(1.05);}
.gallery a:nth-child(5n+1){grid-row:span 2;}
.gallery a:nth-child(5n+1) img{aspect-ratio:auto;height:100%;}
@media (max-width:880px){.gallery{grid-template-columns:repeat(2,1fr);}}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px;counter-reset:step;}
.step-card{
  background:#fff;border:1px solid var(--line-soft);
  border-radius:var(--r-lg);
  padding:30px 26px;
  box-shadow:var(--shadow-sm);
  counter-increment:step;
}
.step-card::before{
  content:"0" counter(step);
  font-size:13px;font-weight:800;letter-spacing:.18em;
  color:var(--red);
  display:block;margin-bottom:14px;
}
.step-card h3{font-size:19px;margin-bottom:8px;}
.step-card p{font-size:15px;}
.dark .step-card{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.13);box-shadow:none;}
.dark .step-card h3{color:#fff;}
.dark .step-card::before{color:var(--gold-soft);}

/* ---------- Related links ---------- */
.related{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px;
}
.related a{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:#fff;border:1px solid var(--line-soft);
  border-radius:var(--r-md);
  padding:18px 22px;
  font-weight:700;font-size:15px;color:var(--navy);
  box-shadow:var(--shadow-sm);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),color .2s;
}
.related a .arr{color:var(--red);font-weight:900;transition:transform .25s var(--ease);}
.related a:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);color:var(--red);}
.related a:hover .arr{transform:translateX(4px);}

/* ---------- Footer ---------- */
.site-footer{
  background:var(--navy);
  color:rgba(255,255,255,.78);
  padding:80px 0 0;
  border-top:4px solid var(--red);
  font-size:14.5px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1.1fr;
  gap:48px;
  padding-bottom:56px;
}
.site-footer h4{
  color:#fff;font-size:13px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  margin-bottom:18px;
}
.site-footer h4::after{content:"";display:block;width:24px;height:2px;background:var(--gold);margin-top:8px;}
.site-footer ul{display:grid;gap:9px;}
.site-footer a{transition:color .2s;}
.site-footer a:hover{color:var(--gold-soft);}
.footer-brand .brand-seal{margin-bottom:16px;}
.footer-brand p{max-width:320px;margin-bottom:18px;}
.footer-brand .f-phone{
  display:block;font-size:24px;font-weight:800;color:#fff;letter-spacing:-.01em;margin-bottom:4px;
}
.footer-brand .f-phone:hover{color:var(--gold-soft);}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);
  padding:22px 0;
  display:flex;flex-wrap:wrap;gap:10px 28px;align-items:center;justify-content:space-between;
  font-size:13px;color:rgba(255,255,255,.55);
}
@media (max-width:980px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr;gap:36px;}}

/* ---------- Mobile sticky action bar ---------- */
.mobile-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:48;
  display:none;
  grid-template-columns:1fr 1fr;
  background:var(--navy);
  border-top:2px solid var(--gold);
  padding:10px 12px calc(10px + env(safe-area-inset-bottom));
  gap:10px;
}
.mobile-bar .btn{width:100%;padding:14px 10px;font-size:14px;}
@media (max-width:760px){
  .mobile-bar{display:grid;}
  body{padding-bottom:78px;}
}

/* ---------- Reveal animations ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .55s var(--ease),transform .55s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal-d1{transition-delay:.08s;}
.reveal-d2{transition-delay:.16s;}
.reveal-d3{transition-delay:.24s;}
.reveal-d4{transition-delay:.32s;}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  *{animation-duration:.01ms !important;animation-iteration-count:1 !important;}
}

/* ---------- Ticker ---------- */
.ticker{
  background:var(--cream-2);
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
  overflow:hidden;
  padding:16px 0;
}
.ticker-track{
  display:flex;gap:44px;width:max-content;
  animation:tick 46s linear infinite;
}
.ticker span{
  display:inline-flex;align-items:center;gap:12px;
  font-size:13.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--navy);white-space:nowrap;
}
.ticker span i{font-style:normal;color:var(--red);}
@keyframes tick{to{transform:translateX(-50%);}}
@media (prefers-reduced-motion:reduce){.ticker-track{animation:none;}}

/* ---------- Misc ---------- */
.note-card{
  border:1px solid var(--line-soft);
  border-left:4px solid var(--gold);
  background:#fff;
  border-radius:0 var(--r-md) var(--r-md) 0;
  padding:22px 26px;
  font-size:15.5px;
  box-shadow:var(--shadow-sm);
}
.dark .note-card{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.14);border-left-color:var(--gold);color:rgba(255,255,255,.85);}

.stat-row{display:flex;flex-wrap:wrap;gap:14px 56px;margin-top:40px;}
.stat .stat-num{
  font-size:clamp(34px,3.4vw,48px);font-weight:900;color:var(--navy);
  letter-spacing:-.02em;line-height:1;display:flex;align-items:baseline;gap:2px;
}
.dark .stat .stat-num{color:#fff;}
.stat .stat-num .unit{font-size:.55em;color:var(--red);}
.dark .stat .stat-num .unit{color:var(--gold-soft);}
.stat .stat-label{font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--body);margin-top:8px;}
.dark .stat .stat-label{color:rgba(255,255,255,.6);}

@media (max-width:640px){
  .section{padding:64px 0;}
  .page-hero{padding:58px 0 54px;}
  .hero-actions .btn{width:100%;}
}
