/* ============================================================
   HATZOLAH EMS — MODERN DESIGN SYSTEM (2026-06-04)
   New flagship template. Sora + Inter, navy/red, depth + motion.
   ============================================================ */

:root{
  /* Surfaces */
  --bg:        #ffffff;
  --bg-soft:   #f4f7fb;     /* cool light band */
  --bg-tint:   #eef3f9;
  --card:      #ffffff;

  /* Ink */
  --ink:       #0a1726;     /* near-black navy */
  --ink-2:     #0d2238;     /* brand navy */
  --ink-soft:  #4d6175;
  --ink-mute:  #8194a6;

  /* Brand */
  --navy:      #0d2238;
  --navy-700:  #163a5f;
  --navy-900:  #081827;
  --red:       #e11d34;     /* brighter modern signal */
  --red-600:   #c2152a;
  --red-soft:  #ff5e72;

  /* Lines + glow */
  --line:      #e4eaf1;
  --line-soft: #eef2f7;
  --glow-red:  rgba(225,29,52,0.55);
  --glow-blue: rgba(40,110,210,0.45);

  /* Radius */
  --r-sm: 12px;
  --r:    18px;
  --r-lg: 26px;
  --r-xl: 34px;
  --pill: 9999px;

  /* Shadows (soft, layered, slightly colored) */
  --sh-1: 0 1px 2px rgba(13,34,56,.06), 0 10px 26px -14px rgba(13,34,56,.20);
  --sh-2: 0 2px 6px rgba(13,34,56,.07), 0 24px 60px -24px rgba(13,34,56,.30);
  --sh-3: 0 40px 90px -30px rgba(8,24,39,.45);
  --sh-red: 0 14px 40px -12px rgba(225,29,52,.45);

  /* Type */
  --display: 'Sora', 'Inter', system-ui, sans-serif;
  --sans:    'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --maxw: 1200px;
  --gut: clamp(20px, 5vw, 56px);
  --ease: cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--display);color:var(--ink);margin:0;line-height:1.08;letter-spacing:-.02em;font-weight:700;}
p{margin:0;}
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut);}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;cursor:pointer;border:0;
  font-family:var(--sans);font-weight:650;font-size:.98rem;letter-spacing:.005em;
  padding:14px 24px;border-radius:var(--pill);transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease);
  white-space:nowrap;
}
.btn .arrow{transition:transform .2s var(--ease);}
.btn:hover .arrow{transform:translateX(4px);}
.btn-primary{background:linear-gradient(135deg,var(--red) 0%,var(--red-600) 100%);color:#fff;box-shadow:var(--sh-red);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 48px -12px rgba(225,29,52,.55);}
.btn-dark{background:var(--navy);color:#fff;box-shadow:var(--sh-1);}
.btn-dark:hover{transform:translateY(-2px);background:var(--navy-700);}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line);}
.btn-ghost:hover{border-color:var(--navy);transform:translateY(-2px);}
.btn-light{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.28);backdrop-filter:blur(6px);}
.btn-light:hover{background:rgba(255,255,255,.2);transform:translateY(-2px);}
.btn-block{width:100%;justify-content:center;}

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--sans);font-weight:700;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--red);
}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--red);border-radius:2px;}
.eyebrow.on-dark{color:#fff;}
.eyebrow.on-dark::before{background:var(--red-soft);}

/* ---------- Section rhythm ---------- */
.section{padding:clamp(64px,8vw,118px) 0;}
.section.tight{padding:clamp(44px,5vw,72px) 0;}
.band-soft{background:var(--bg-soft);}
.sec-head{max-width:760px;margin:0 auto clamp(40px,5vw,60px);text-align:center;}
.sec-head h2{font-size:clamp(2rem,4.4vw,3.25rem);margin:14px 0 0;}
.sec-head p{margin:18px auto 0;color:var(--ink-soft);font-size:1.08rem;max-width:60ch;}
.sec-foot{text-align:center;margin-top:clamp(36px,4vw,52px);}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.topbar{background:var(--navy-900);color:rgba(255,255,255,.82);font-size:.84rem;}
.topbar .container{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-block:9px;}
.topbar strong{color:#fff;}
.topbar a{color:#fff;font-weight:650;display:inline-flex;align-items:center;gap:7px;}
.topbar a svg{width:15px;height:15px;}

.nav{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.72);backdrop-filter:blur(16px) saturate(150%);
  border-bottom:1px solid transparent;transition:border-color .3s var(--ease),box-shadow .3s var(--ease),background .3s var(--ease);}
.nav.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 24px -18px rgba(13,34,56,.5);}
.nav .container{display:flex;align-items:center;justify-content:space-between;gap:18px;height:74px;}
.nav-logo img{height:42px;width:auto;}
.nav-links{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0;}
.nav-links a{font-weight:600;font-size:.96rem;color:var(--ink-2);padding:10px 14px;border-radius:var(--pill);transition:background .15s,color .15s;}
.nav-links a:hover,.nav-links a.is-active{background:var(--bg-tint);color:var(--navy);}
.nav-cta{display:flex;align-items:center;gap:12px;}
.nav-phone{font-weight:700;color:var(--navy);display:inline-flex;align-items:center;gap:8px;font-size:.96rem;}
.nav-phone svg{width:18px;height:18px;color:var(--red);}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:transparent;border:0;cursor:pointer;padding:8px;}
.nav-toggle span{width:24px;height:2px;background:var(--navy);border-radius:2px;transition:.25s var(--ease);}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.mnav{position:fixed;inset:0 0 0 auto;width:min(86vw,360px);background:#fff;z-index:80;
  transform:translateX(100%);transition:transform .32s var(--ease);box-shadow:var(--sh-3);padding:84px 26px 26px;display:flex;flex-direction:column;gap:6px;}
.mnav.open{transform:translateX(0);}
.mnav a{font-weight:600;font-size:1.05rem;color:var(--ink-2);padding:13px 12px;border-radius:12px;}
.mnav a:hover{background:var(--bg-tint);}
.mnav .btn{margin-top:14px;}
.mnav-scrim{position:fixed;inset:0;background:rgba(8,24,39,.5);z-index:70;opacity:0;visibility:hidden;transition:.3s;}
.mnav-scrim.open{opacity:1;visibility:visible;}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;background:radial-gradient(120% 120% at 85% 0%,#16385c 0%,#0d2238 45%,#081827 100%);color:#fff;overflow:hidden;}
.hero::before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:54px 54px;mask-image:radial-gradient(80% 70% at 70% 10%,#000 0%,transparent 75%);opacity:.5;}
.hero::after{content:"";position:absolute;top:-15%;right:-5%;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,var(--glow-red) 0%,transparent 70%);filter:blur(20px);opacity:.55;pointer-events:none;}
.hero .container{position:relative;display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(30px,4vw,64px);
  align-items:center;padding-top:clamp(56px,7vw,96px);padding-bottom:clamp(120px,12vw,160px);}
.hero-badge{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  border-radius:var(--pill);padding:7px 15px 7px 9px;font-size:.8rem;font-weight:650;color:#fff;backdrop-filter:blur(6px);margin-bottom:22px;}
.hero-badge .dot{width:9px;height:9px;border-radius:50%;background:#21d07a;box-shadow:0 0 0 4px rgba(33,208,122,.25);animation:pulse 2.4s infinite;}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(33,208,122,.25);}50%{box-shadow:0 0 0 7px rgba(33,208,122,0);}}
.hero h1{font-size:clamp(2.5rem,5.6vw,4.2rem);font-weight:800;letter-spacing:-.03em;color:#fff;}
.hero h1 .grad{background:linear-gradient(100deg,#ff5e72,#ff97a3);-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero-lede{margin-top:22px;font-size:1.16rem;line-height:1.6;color:rgba(255,255,255,.8);max-width:46ch;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px;}
.hero-trust{display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:34px;}
.hero-trust span{display:inline-flex;align-items:center;gap:8px;font-size:.9rem;font-weight:550;color:rgba(255,255,255,.78);}
.hero-trust svg{width:18px;height:18px;color:#21d07a;flex:0 0 18px;}

/* Hero visual: framed image + floating stat chip */
.hero-visual{position:relative;}
.hero-frame{position:relative;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-3);border:1px solid rgba(255,255,255,.12);aspect-ratio:4/5;}
.hero-frame img{width:100%;height:100%;object-fit:cover;}
.hero-chip{position:absolute;left:-26px;bottom:34px;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  border-radius:var(--r);padding:16px 20px;box-shadow:var(--sh-2);display:flex;align-items:center;gap:14px;min-width:230px;}
.hero-chip .ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,var(--red),var(--red-600));color:#fff;flex:0 0 42px;}
.hero-chip .ic svg{width:22px;height:22px;}
.hero-chip .k{font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-mute);}
.hero-chip .v{font-family:var(--display);font-weight:700;font-size:1.1rem;color:var(--navy);}

/* Floating booking card overlapping hero bottom */
.hero-book{position:relative;margin-top:-96px;z-index:5;}
.hero-book .container{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-2);}
.hb-item{background:#fff;padding:24px 22px;display:flex;align-items:center;gap:14px;}
.hb-item .ic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:var(--bg-tint);color:var(--navy);flex:0 0 44px;}
.hb-item .ic svg{width:23px;height:23px;}
.hb-item .k{font-family:var(--display);font-weight:700;font-size:1.02rem;color:var(--ink);line-height:1.15;}
.hb-item .s{font-size:.84rem;color:var(--ink-soft);margin-top:2px;}

/* ============================================================
   INSURER / LOGO STRIP
   ============================================================ */
.insurers{padding:38px 0;}
.insurers .lab{text-align:center;font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:20px;}
.insurer-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:14px 30px;}
.insurer-row span{font-family:var(--display);font-weight:700;font-size:1.05rem;color:var(--ink-mute);opacity:.85;}

/* ============================================================
   SERVICE CARDS (bento)
   ============================================================ */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.svc-card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:28px 24px;display:flex;flex-direction:column;transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s;overflow:hidden;}
.svc-card::after{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--red),var(--red-soft));transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--sh-2);border-color:transparent;}
.svc-card:hover::after{transform:scaleX(1);}
.svc-ic{width:52px;height:52px;border-radius:15px;display:grid;place-items:center;margin-bottom:18px;
  background:linear-gradient(135deg,var(--navy),var(--navy-700));color:#fff;box-shadow:var(--sh-1);}
.svc-ic svg{width:26px;height:26px;}
.svc-card h3{font-size:1.16rem;margin-bottom:9px;}
.svc-card p{color:var(--ink-soft);font-size:.96rem;line-height:1.55;flex:1;}
.svc-link{margin-top:16px;font-weight:700;font-size:.9rem;color:var(--red);display:inline-flex;align-items:center;gap:7px;}
.svc-link svg{width:16px;height:16px;transition:transform .2s var(--ease);}
.svc-card:hover .svc-link svg{transform:translateX(4px);}

/* ============================================================
   STAT BAND
   ============================================================ */
.statband{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-900) 100%);color:#fff;position:relative;overflow:hidden;}
.statband::before{content:"";position:absolute;top:-40%;left:60%;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,var(--glow-blue),transparent 70%);opacity:.4;}
.stat-grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center;}
.stat .num{font-family:var(--display);font-weight:800;font-size:clamp(2.4rem,5vw,3.6rem);letter-spacing:-.03em;
  background:linear-gradient(120deg,#fff,#9fc4ef);-webkit-background-clip:text;background-clip:text;color:transparent;}
.stat .lab{margin-top:8px;color:rgba(255,255,255,.72);font-size:.96rem;font-weight:550;}
.stat .sub{color:rgba(255,255,255,.45);font-size:.8rem;margin-top:2px;}

/* ============================================================
   BOOKING SECTION
   ============================================================ */
.book-inner{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(30px,4vw,64px);align-items:center;}
.book-intro h2{font-size:clamp(2rem,4vw,3rem);margin-top:14px;}
.book-intro .lede{margin-top:18px;color:var(--ink-soft);font-size:1.08rem;}
.book-points{list-style:none;padding:0;margin:26px 0 0;display:grid;gap:14px;}
.book-points li{display:flex;align-items:center;gap:12px;font-weight:550;color:var(--ink-2);}
.book-points .tick{width:26px;height:26px;border-radius:50%;background:rgba(33,208,122,.14);color:#12a45a;display:grid;place-items:center;flex:0 0 26px;}
.book-points .tick svg{width:15px;height:15px;}
.book-callnote{margin-top:24px;font-size:.92rem;color:var(--ink-soft);border-left:3px solid var(--red);padding:6px 0 6px 15px;}

.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(24px,3vw,38px);box-shadow:var(--sh-2);}
.form-card h3{font-size:1.35rem;margin-bottom:6px;}
.form-card .fc-sub{color:var(--ink-soft);font-size:.95rem;margin-bottom:22px;}
.field{margin-bottom:16px;}
.field label{display:block;font-size:.82rem;font-weight:650;color:var(--ink-2);margin-bottom:7px;}
.field .opt{font-weight:400;color:var(--ink-mute);}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--sans);font-size:1rem;color:var(--ink);background:#fff;
  border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;transition:border-color .15s,box-shadow .15s;}
.field textarea{min-height:92px;resize:vertical;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 4px rgba(13,34,56,.08);}
.field select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238194a6' stroke-width='2.4'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 14px center;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-note{margin-top:14px;font-size:.82rem;color:var(--ink-mute);text-align:center;}
.form-error{margin:12px 0 0;color:var(--red);font-size:.88rem;font-weight:650;}

/* ============================================================
   COVERAGE SILO
   ============================================================ */
.silo-wrap{display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(26px,3vw,46px);align-items:stretch;}
.silo-cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(22px,2.5vw,34px);}
.silo-col h3{font-size:1rem;font-family:var(--display);margin-bottom:14px;padding-bottom:11px;border-bottom:1px solid var(--line);color:var(--navy);}
.chip-row{display:flex;flex-wrap:wrap;gap:9px;}
.chip{display:inline-flex;align-items:center;gap:7px;font-size:.9rem;font-weight:550;color:var(--ink-2);
  background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--pill);padding:8px 14px;transition:.18s var(--ease);}
.chip:hover{background:var(--navy);color:#fff;border-color:var(--navy);transform:translateY(-2px);}
.silo-map{min-height:360px;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--sh-1);}
.silo-map iframe{display:block;width:100%;height:100%;min-height:360px;}

/* ============================================================
   WHY-US (bento)
   ============================================================ */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.why-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 26px;transition:transform .25s var(--ease),box-shadow .25s var(--ease);}
.why-card:hover{transform:translateY(-5px);box-shadow:var(--sh-2);}
.why-ic{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;margin-bottom:18px;
  background:radial-gradient(circle at 30% 30%,#16385c,#0d2238);color:var(--red-soft);box-shadow:var(--sh-1);}
.why-ic svg{width:26px;height:26px;}
.why-card h3{font-size:1.14rem;margin-bottom:9px;}
.why-card p{color:var(--ink-soft);font-size:.96rem;line-height:1.55;}

/* ============================================================
   COMMUNITY CARDS
   ============================================================ */
.comm-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.comm-card{position:relative;border-radius:var(--r-xl);padding:clamp(30px,4vw,48px);overflow:hidden;color:#fff;box-shadow:var(--sh-2);}
.comm-card.donate{background:linear-gradient(135deg,var(--red) 0%,var(--red-600) 100%);}
.comm-card.volunteer{background:linear-gradient(135deg,var(--navy-700) 0%,var(--navy-900) 100%);}
.comm-card::after{content:"";position:absolute;top:-30%;right:-10%;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.1);}
.comm-card h3{color:#fff;font-size:1.7rem;margin-bottom:12px;position:relative;}
.comm-card p{color:rgba(255,255,255,.85);position:relative;margin-bottom:24px;max-width:42ch;}
.comm-card .btn{position:relative;}

/* ============================================================
   MISSION QUOTE
   ============================================================ */
.mission{background:var(--bg-soft);text-align:center;}
.mission blockquote{max-width:880px;margin:0 auto;font-family:var(--display);font-weight:600;
  font-size:clamp(1.6rem,3.4vw,2.5rem);line-height:1.3;letter-spacing:-.02em;color:var(--ink);}
.mission blockquote .accent{color:var(--red);}
.mission .sig{margin-top:24px;font-size:.86rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);}

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px;}
.faq-item{border:1px solid var(--line);border-radius:var(--r);background:#fff;overflow:hidden;transition:box-shadow .2s,border-color .2s;}
.faq-item.open{box-shadow:var(--sh-1);border-color:transparent;}
.faq-q{width:100%;text-align:left;background:transparent;border:0;cursor:pointer;padding:20px 24px;
  font-family:var(--display);font-weight:600;font-size:1.06rem;color:var(--ink);display:flex;align-items:center;justify-content:space-between;gap:16px;}
.faq-q .pm{flex:0 0 24px;width:24px;height:24px;position:relative;}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--red);border-radius:2px;transition:transform .25s var(--ease);}
.faq-q .pm::before{top:11px;left:3px;width:18px;height:2px;}
.faq-q .pm::after{top:3px;left:11px;width:2px;height:18px;}
.faq-item.open .pm::after{transform:rotate(90deg);opacity:0;}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s var(--ease);}
.faq-a-inner{padding:0 24px 22px;color:var(--ink-soft);line-height:1.65;}

/* ============================================================
   CTA BAND
   ============================================================ */
.cta{background:radial-gradient(120% 140% at 20% 0%,#16385c,#0d2238 55%,#081827);color:#fff;text-align:center;position:relative;overflow:hidden;}
.cta::after{content:"";position:absolute;bottom:-40%;right:10%;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,var(--glow-red),transparent 70%);opacity:.5;}
.cta h2{position:relative;font-size:clamp(2rem,4.4vw,3.2rem);color:#fff;}
.cta p{position:relative;margin:18px auto 30px;color:rgba(255,255,255,.78);max-width:52ch;font-size:1.08rem;}
.cta .hero-cta{position:relative;justify-content:center;}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--navy-900);color:rgba(255,255,255,.7);padding:clamp(56px,7vw,84px) 0 32px;}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:36px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1);}
.footer-brand img{height:44px;margin-bottom:18px;}
.footer-brand p{font-size:.95rem;line-height:1.65;max-width:38ch;}
.footer-legal{margin-top:16px;font-size:.82rem;color:rgba(255,255,255,.45);}
.footer h4{color:#fff;font-size:.84rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px;font-family:var(--sans);font-weight:700;}
.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:11px;}
.footer ul a{font-size:.95rem;color:rgba(255,255,255,.7);transition:color .15s;}
.footer ul a:hover{color:#fff;}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;padding-top:26px;font-size:.85rem;color:rgba(255,255,255,.45);}

/* ============================================================
   MOTION
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s 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;}
.reveal.d5{transition-delay:.4s;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}*{scroll-behavior:auto;}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .hero .container{grid-template-columns:1fr;padding-bottom:clamp(96px,12vw,130px);}
  .hero-visual{max-width:440px;}
  .hero-book .container{grid-template-columns:1fr 1fr;}
  .svc-grid{grid-template-columns:repeat(2,1fr);}
  .why-grid{grid-template-columns:repeat(2,1fr);}
  .stat-grid{grid-template-columns:repeat(2,1fr);gap:34px;}
  .silo-wrap{grid-template-columns:1fr;}
  .book-inner{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr 1fr;gap:30px;}
}
@media (max-width:860px){
  .nav-links,.nav-phone{display:none;}
  .nav-toggle{display:flex;}
}
@media (max-width:620px){
  body{font-size:16px;}
  .hero-book .container{grid-template-columns:1fr;}
  .svc-grid,.why-grid,.comm-grid,.silo-cols{grid-template-columns:1fr;}
  .stat-grid{grid-template-columns:1fr 1fr;}
  .field-row{grid-template-columns:1fr;}
  .hero-chip{left:0;}
  .footer-top{grid-template-columns:1fr;}
}

/* ============================================================
   INTERIOR / SILO PAGE COMPONENTS
   ============================================================ */
.page-hero{position:relative;background:radial-gradient(120% 130% at 85% 0%,#16385c,#0d2238 50%,#081827);color:#fff;overflow:hidden;padding:clamp(40px,5vw,64px) 0 clamp(48px,6vw,76px);}
.page-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:54px 54px;mask-image:radial-gradient(80% 80% at 75% 0%,#000,transparent 75%);opacity:.5;}
.page-hero::after{content:"";position:absolute;top:-20%;right:-5%;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,var(--glow-red),transparent 70%);opacity:.5;}
.page-hero .container{position:relative;}
.breadcrumb{display:flex;flex-wrap:wrap;gap:8px;font-size:.84rem;color:rgba(255,255,255,.62);margin-bottom:18px;}
.breadcrumb a{color:rgba(255,255,255,.82);font-weight:600;}
.breadcrumb a:hover{color:#fff;}
.breadcrumb .sep{opacity:.4;}
.page-hero h1{font-size:clamp(2.1rem,4.6vw,3.4rem);font-weight:800;letter-spacing:-.03em;color:#fff;max-width:18ch;}
.page-hero .ph-sub{margin-top:18px;font-size:1.1rem;color:rgba(255,255,255,.8);max-width:60ch;}
.page-hero .hero-cta{margin-top:28px;}

.layout{display:grid;grid-template-columns:1fr 320px;gap:clamp(30px,4vw,56px);align-items:start;}
.prose{max-width:760px;}
.prose h2{font-size:clamp(1.5rem,2.8vw,2rem);margin:clamp(34px,4vw,48px) 0 14px;letter-spacing:-.02em;}
.prose h3{font-size:1.2rem;margin:26px 0 10px;}
.prose p{margin:0 0 16px;color:var(--ink-soft);}
.prose ul{margin:0 0 18px;padding-left:0;list-style:none;display:grid;gap:10px;}
.prose ul li{position:relative;padding-left:30px;color:var(--ink-soft);}
.prose ul li::before{content:"";position:absolute;left:0;top:9px;width:16px;height:16px;border-radius:50%;background:rgba(225,29,52,.12);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23e11d34' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");background-repeat:no-repeat;background-position:center;}
.prose strong{color:var(--ink-2);font-weight:700;}
.prose .lead{font-size:1.14rem;color:var(--ink);}

.takeaways{background:var(--bg-soft);border:1px solid var(--line);border-left:4px solid var(--red);border-radius:var(--r);padding:22px 24px;margin:26px 0;}
.takeaways h2{font-size:1.05rem;margin:0 0 12px;font-family:var(--display);}
.takeaways ul{margin:0;}

.localfac{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(22px,3vw,32px);margin:32px 0;box-shadow:var(--sh-1);}
.localfac h2{font-size:1.3rem;margin:0 0 6px;}
.localfac .lf-sub{color:var(--ink-soft);font-size:.95rem;margin-bottom:20px;}
.lf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.lf-col h3{font-size:.96rem;color:var(--navy);margin:0 0 12px;padding-bottom:9px;border-bottom:1px solid var(--line);font-family:var(--display);}
.lf-col ul{list-style:none;margin:0;padding:0;display:grid;gap:8px;}
.lf-col li{font-size:.92rem;color:var(--ink-soft);display:flex;gap:8px;}
.lf-col li::before{content:"";flex:0 0 6px;width:6px;height:6px;border-radius:50%;background:var(--red);margin-top:8px;}

/* Sidebar */
.side{position:sticky;top:96px;display:grid;gap:20px;}
.side-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;box-shadow:var(--sh-1);}
.side-card.book{background:linear-gradient(135deg,var(--navy-700),var(--navy-900));color:#fff;}
.side-card.book h3{color:#fff;font-size:1.2rem;margin-bottom:8px;}
.side-card.book p{color:rgba(255,255,255,.8);font-size:.92rem;margin-bottom:16px;}
.side-card h3{font-size:1.05rem;margin-bottom:14px;}
.side-links{list-style:none;margin:0;padding:0;display:grid;gap:9px;}
.side-links a{font-size:.93rem;color:var(--ink-2);font-weight:550;display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:10px;transition:.15s;}
.side-links a:hover{background:var(--bg-tint);color:var(--navy);}
.side-links a svg{width:15px;height:15px;color:var(--red);flex:0 0 15px;}

.related{margin:36px 0;}
.related h2{font-size:1.3rem;margin-bottom:16px;}
.rel-grid{display:flex;flex-wrap:wrap;gap:10px;}
.page-map{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--sh-1);height:260px;margin:8px 0 0;}
.page-map iframe{width:100%;height:100%;border:0;display:block;}

@media (max-width:980px){.layout{grid-template-columns:1fr;}.side{position:static;grid-template-columns:1fr 1fr;}.lf-grid{grid-template-columns:1fr;}}
@media (max-width:620px){.side{grid-template-columns:1fr;}}
