/* ============ RESET & BASE ============ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Montserrat',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:17px;line-height:1.6;color:#111111;background:#fff;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}

:root{
  --bg:#ffffff;
  --bg-2:#f5f6fa;
  --ink:#111111;
  --ink-2:#333333;
  --ink-3:#808080;
  --line:#e5e7eb;
  --dark:#0a0a0c;
  --dark-2:#16181d;
  --dark-3:#222630;
  --accent:#0066ff;        /* brand blue */
  --accent-2:#3385ff;
  --accent-3:#0052cc;      /* darker blue for hover */
  --accent-soft:rgba(0,102,255,.10);
  --radius:14px;
  --radius-sm:8px;
  --shadow-sm:0 2px 8px rgba(0,0,0,.04);
  --shadow:0 18px 50px -20px rgba(0,0,0,.25);
  --max:1200px;
}

.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 24px}
.eyebrow{
  display:inline-block;font-size:12px;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--accent);margin-bottom:14px;
}
.eyebrow.light{color:var(--accent-2)}
.section-title{
  font-family:'Montserrat',system-ui,sans-serif;font-weight:800;
  font-size:clamp(1.9rem,4vw,3rem);line-height:1.1;letter-spacing:-.02em;
  color:var(--ink);margin-bottom:18px;
}
.section-title.light{color:#fff}
.section-sub{font-size:1.05rem;color:var(--ink-3);max-width:640px}
.section-head{text-align:center;max-width:760px;margin:0 auto 56px}
.section-head .section-sub{margin-left:auto;margin-right:auto}
.lead{font-size:1.15rem;color:var(--ink-2);margin-bottom:18px}
.light{color:#cfcfd4}
.link-arrow{
  display:inline-flex;align-items:center;gap:6px;font-weight:600;
  color:var(--accent);border-bottom:1.5px solid transparent;
  padding-bottom:2px;transition:.2s;
}
.link-arrow:hover{border-bottom-color:var(--accent)}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 22px;border-radius:999px;font-weight:600;font-size:15px;
  letter-spacing:.01em;transition:.2s ease;cursor:pointer;
  white-space:nowrap;
}
.btn-lg{padding:16px 28px;font-size:16px}
.btn-full{width:100%}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-3);transform:translateY(-1px);box-shadow:0 10px 22px -8px rgba(0,102,255,.5)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35)}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:#fff}

/* ============ HEADER ============ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;transition:.25s;
}
.site-header.scrolled{border-bottom-color:var(--line);box-shadow:0 1px 0 rgba(0,0,0,.02)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:84px;gap:24px}
.logo img{height:46px;width:auto}
.nav{display:flex;gap:30px;align-items:center}
.nav a,.nav .nav-trigger{
  font-size:15px;font-weight:500;color:var(--ink-2);transition:.2s;
  font-family:inherit;cursor:pointer;display:inline-flex;align-items:center;gap:6px;
}
.nav a:hover,.nav .nav-trigger:hover{color:var(--accent)}
.nav .nav-trigger{padding:0;background:transparent;border:0}
.nav .nav-caret{transition:.2s;flex-shrink:0;margin-top:2px}
.nav-has-sub{position:relative}
.nav-has-sub.open .nav-caret{transform:rotate(180deg)}
.nav-has-sub.open .nav-trigger{color:var(--accent)}
.nav-submenu{
  position:absolute;top:calc(100% + 18px);left:50%;transform:translateX(-50%) translateY(8px);
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:0 18px 50px -20px rgba(0,0,0,.25);
  min-width:220px;padding:10px;display:flex;flex-direction:column;
  opacity:0;pointer-events:none;transition:.2s;z-index:120;
}
.nav-has-sub.open .nav-submenu{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nav-submenu::before{
  content:"";position:absolute;top:-6px;left:50%;transform:translateX(-50%) rotate(45deg);
  width:12px;height:12px;background:#fff;border-left:1px solid var(--line);border-top:1px solid var(--line);
}
.nav-submenu a{
  padding:10px 14px;border-radius:8px;font-size:14.5px;color:var(--ink-2);
}
.nav-submenu a:hover{background:var(--bg-2);color:var(--accent)}
.header-cta{display:flex;align-items:center;gap:18px}
.phone-link{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:var(--ink)}
.phone-link:hover{color:var(--accent)}

.nav-toggle{
  display:none;flex-direction:column;gap:5px;width:36px;height:36px;
  align-items:center;justify-content:center;
}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--ink);transition:.25s;border-radius:2px}
.nav-toggle[aria-expanded=true] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded=true] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded=true] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============ HERO ============ */
.hero{
  position:relative;min-height:100vh;color:#fff;
  display:flex;align-items:center;overflow:hidden;padding:130px 0 80px;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;filter:saturate(.9)}
.hero-overlay{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 70% at 30% 20%, rgba(0,0,0,.35), transparent 60%),
    linear-gradient(180deg, rgba(10,10,12,.55) 0%, rgba(10,10,12,.7) 60%, rgba(10,10,12,.95) 100%);
}
.hero-inner{position:relative;z-index:1;max-width:880px}
.hero-title{
  font-family:'Montserrat',system-ui,sans-serif;font-weight:800;
  font-size:clamp(2.4rem,6vw,4.6rem);line-height:1.05;letter-spacing:-.02em;
  margin:18px 0 22px;
}
.hero-title .accent{color:#fff;background:linear-gradient(90deg,#0066ff,#3385ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{font-size:1.15rem;line-height:1.6;color:#d8d8de;max-width:620px;margin-bottom:34px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:60px}
.hero-meta{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;
  max-width:640px;padding-top:30px;border-top:1px solid rgba(255,255,255,.15);
}
.hero-meta strong{display:block;font-family:'Montserrat',system-ui,sans-serif;font-size:1.7rem;font-weight:800;color:#fff;line-height:1}
.hero-meta span{display:block;margin-top:6px;font-size:13px;color:#a8a8b0;letter-spacing:.02em}

.live-chip{
  display:inline-flex;align-items:center;gap:8px;padding:7px 14px;margin:0;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);
  border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;color:#fff;backdrop-filter:blur(10px);
}
/* LIVE/REC dot stays broadcast-red regardless of brand colour — universal signal */
.live-dot{
  display:inline-block;width:8px;height:8px;border-radius:50%;
  background:#ff3030;box-shadow:0 0 0 0 rgba(255,48,48,.7);
  animation:pulse 1.6s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(255,48,48,.7)}
  70%{box-shadow:0 0 0 10px rgba(255,48,48,0)}
  100%{box-shadow:0 0 0 0 rgba(255,48,48,0)}
}

/* ============ INTRO ============ */
.intro{padding:110px 0}
.intro-grid{
  display:grid;grid-template-columns:1fr 1.3fr;gap:80px;align-items:start;
}
.intro-eyebrow .section-title{margin-bottom:0}
.intro-body p{margin-bottom:18px;color:var(--ink-2)}

/* ============ SERVICES ============ */
.services{padding:90px 0;background:var(--bg-2)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.service-card{
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:.3s;border:1px solid var(--line);
}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.service-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:#222}
.service-img img{width:100%;height:100%;object-fit:cover;transition:.6s}
.service-card:hover .service-img img{transform:scale(1.05)}
.card-tag{
  position:absolute;top:14px;left:14px;display:inline-flex;align-items:center;gap:6px;
  background:var(--accent);color:#fff;padding:5px 11px;border-radius:999px;
  font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
}
.card-tag.tag-dark{background:rgba(0,0,0,.85);backdrop-filter:blur(8px)}
.card-tag .live-dot{background:#fff;box-shadow:0 0 0 0 rgba(255,255,255,.7)}
.service-body{padding:28px 26px 30px}
.service-body h3{font-family:'Montserrat',system-ui,sans-serif;font-size:1.5rem;font-weight:800;margin-bottom:10px}
.service-body p{color:var(--ink-3);margin-bottom:18px;font-size:.97rem}
.tick-list li{
  position:relative;padding-left:22px;font-size:.92rem;color:var(--ink-2);margin-bottom:6px;
}
.tick-list li::before{
  content:"";position:absolute;left:0;top:9px;width:12px;height:12px;
  background:var(--accent-soft);border-radius:50%;
}
.tick-list li::after{
  content:"";position:absolute;left:3px;top:11px;width:6px;height:3px;
  border-left:2px solid var(--accent);border-bottom:2px solid var(--accent);
  transform:rotate(-45deg);
}

/* ============ WHY (DARK) ============ */
.why{background:var(--dark);color:#fff;padding:110px 0;position:relative;overflow:hidden}
.why::before{
  content:"";position:absolute;top:-200px;right:-200px;width:600px;height:600px;
  background:radial-gradient(circle,rgba(0,102,255,.16),transparent 60%);
  pointer-events:none;
}
.why-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center;position:relative}
.why-copy p{margin-bottom:18px;font-size:1.02rem;line-height:1.7}
.why-stats{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.stat{
  background:var(--dark-2);border:1px solid var(--dark-3);border-radius:var(--radius);
  padding:28px 24px;
}
.stat-num{
  font-family:'Montserrat',system-ui,sans-serif;font-size:3rem;font-weight:800;line-height:1;
  color:var(--accent-2);margin-bottom:10px;
}
.stat-label{font-size:.92rem;color:#a8a8b0;line-height:1.5}

/* ============ SECTORS ============ */
.sectors{padding:120px 0}
.sector-grid{display:flex;flex-direction:column;gap:60px}
.sector-card{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.sector-card.reverse .sector-img{order:2}
.sector-img{
  border-radius:var(--radius);overflow:hidden;aspect-ratio:16/10;
  box-shadow:var(--shadow);
}
.sector-img img{width:100%;height:100%;object-fit:cover;transition:.6s}
.sector-card:hover .sector-img img{transform:scale(1.04)}
.sector-tag{
  display:inline-block;font-size:11px;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--accent);background:var(--accent-soft);
  padding:6px 12px;border-radius:999px;margin-bottom:18px;
}
.sector-body h3{font-family:'Montserrat',system-ui,sans-serif;font-size:2rem;font-weight:800;line-height:1.15;margin-bottom:16px}
.sector-body p{color:var(--ink-2);margin-bottom:20px}

/* ============ PROCESS ============ */
.process{padding:110px 0;background:var(--bg-2)}
.process-list{
  display:grid;grid-template-columns:repeat(4,1fr);gap:28px;counter-reset:step;
}
.process-list li{
  background:#fff;padding:36px 26px;border-radius:var(--radius);position:relative;
  border:1px solid var(--line);
}
.process-num{
  display:inline-block;font-family:'Montserrat',system-ui,sans-serif;font-size:1.1rem;font-weight:800;
  color:var(--accent);margin-bottom:18px;
}
.process-list h3{font-family:'Montserrat',system-ui,sans-serif;font-size:1.3rem;font-weight:800;margin-bottom:10px}
.process-list p{color:var(--ink-3);font-size:.95rem}

/* ============ TEAM ============ */
.team{padding:120px 0}
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.team-list{margin-top:24px}
.team-list li{padding:20px 0;border-top:1px solid var(--line)}
.team-list li:last-child{border-bottom:1px solid var(--line)}
.team-list strong{display:block;font-family:'Montserrat',system-ui,sans-serif;font-size:1.2rem;font-weight:800;margin-bottom:4px}
.team-list span{color:var(--ink-3);font-size:.95rem}
.team-images{position:relative;aspect-ratio:1;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:18px}
.team-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.team-img-large{grid-column:1/3;grid-row:1/3;background:#000}
.team-img-large img{width:100%;height:100%;object-fit:cover;object-position:center}
.team-img-small{display:none}

/* ============ WHY US 4-UP ============ */
.why-us{padding:100px 0;background:var(--bg-2)}
.whyus-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.whyus-card{
  background:#fff;border-radius:var(--radius);padding:32px 28px;
  border:1px solid var(--line);transition:.25s;
}
.whyus-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.whyus-icon{
  width:48px;height:48px;border-radius:12px;background:var(--accent-soft);
  display:flex;align-items:center;justify-content:center;color:var(--accent);
  margin-bottom:20px;
}
.whyus-card h3{font-family:'Montserrat',system-ui,sans-serif;font-size:1.2rem;font-weight:800;margin-bottom:8px}
.whyus-card p{color:var(--ink-3);font-size:.94rem;line-height:1.55}

/* ============ CLIENTS ============ */
.clients{padding:70px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.clients-label{
  text-align:center;font-size:12px;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-3);margin-bottom:30px;
}
.clients-strip{max-width:1100px;margin:0 auto;opacity:.85}
.clients-strip img{width:100%;height:auto;filter:grayscale(100%)}

/* ============ FAQ ============ */
.faq{padding:110px 0}
.faq-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:80px;align-items:start}
.faq-head p{color:var(--ink-3);margin-top:14px}
.faq-head a{color:var(--accent);font-weight:600}
.faq-list{display:flex;flex-direction:column;gap:4px}
.faq-item{
  border:1px solid var(--line);border-radius:var(--radius-sm);
  background:#fff;transition:.2s;overflow:hidden;
}
.faq-item[open]{border-color:var(--ink-2)}
.faq-item summary{
  list-style:none;cursor:pointer;padding:12px 22px;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  font-weight:600;font-size:.93rem;color:var(--ink);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";font-size:1.4rem;font-weight:300;color:var(--accent);
  transition:.25s;flex-shrink:0;
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-body{padding:0 22px 18px;color:var(--ink-2);font-size:.95rem;line-height:1.6}

/* ============ CTA / CONTACT ============ */
.cta{background:var(--dark);color:#fff;padding:110px 0;position:relative;overflow:hidden}
.cta::before{
  content:"";position:absolute;bottom:-200px;left:-200px;width:600px;height:600px;
  background:radial-gradient(circle,rgba(0,102,255,.16),transparent 60%);
}
.cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;position:relative}
.cta-copy p{margin-bottom:32px}
.cta-contact{display:flex;flex-direction:column;gap:24px}
.cta-phone{
  display:inline-flex;align-items:center;gap:14px;color:#fff;
  padding:18px 22px;background:var(--dark-2);border:1px solid var(--dark-3);
  border-radius:var(--radius);width:max-content;transition:.2s;
}
.cta-phone:hover{border-color:var(--accent);background:var(--dark-3)}
.cta-phone svg{color:var(--accent-2)}
.cta-phone small{display:block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#9a9aa0;margin-bottom:2px}
.cta-phone strong{font-family:'Montserrat',system-ui,sans-serif;font-size:1.4rem;font-weight:800}
.cta-meta p{margin:0 0 4px;color:#cfcfd4;font-size:.95rem}
.cta-meta strong{color:#fff;display:inline-block;min-width:70px}

.quote-form{
  background:#fff;color:var(--ink);border-radius:var(--radius);
  padding:36px 32px;box-shadow:var(--shadow);
}
.quote-form h3{font-family:'Montserrat',system-ui,sans-serif;font-size:1.5rem;font-weight:800;margin-bottom:20px}
.field{margin-bottom:16px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink-2);margin-bottom:6px}
.field input,.field select,.field textarea{
  width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:var(--radius-sm);
  font:inherit;font-size:15px;color:var(--ink);background:#fafafa;transition:.2s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--accent);background:#fff;
}
.field textarea{resize:vertical;min-height:90px}
.form-success{
  margin-top:14px;padding:10px 14px;background:#e8f7ee;color:#0a7c2c;
  border-radius:var(--radius-sm);font-size:14px;font-weight:600;text-align:center;
}

/* ============ FOOTER ============ */
.site-footer{background:#06060a;color:#9a9aa0;padding:70px 0 30px;font-size:.92rem}

/* GMB embeds strip */
.footer-maps{padding-bottom:50px;border-bottom:1px solid #1c1c22;margin-bottom:50px}
.footer-maps-title{
  color:#fff;font-family:'Montserrat',system-ui,sans-serif;font-size:1.5rem;font-weight:800;
  margin-bottom:24px;
}
.footer-maps-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
}
.footer-map{
  background:var(--dark-2);border:1px solid var(--dark-3);
  border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;
}
.footer-map iframe{
  width:100%;height:170px;border:0;display:block;filter:invert(.92) hue-rotate(180deg) saturate(.4) brightness(1);
}
.footer-map-label{
  display:block;padding:12px 14px;font-size:.85rem;font-weight:600;color:#fff;
  border-top:1px solid var(--dark-3);transition:.2s;
}
.footer-map-label:hover{color:var(--accent-2);background:var(--dark-3)}

.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:50px;padding-bottom:50px;border-bottom:1px solid #1c1c22}
.footer-logo{height:54px;margin-bottom:20px;filter:brightness(0) invert(1)}
.footer-brand p{margin-bottom:22px;line-height:1.6;max-width:320px}
.footer-social{display:flex;gap:10px}
.footer-social a{
  width:38px;height:38px;border-radius:50%;border:1px solid #2a2a32;
  display:inline-flex;align-items:center;justify-content:center;color:#cfcfd4;
  transition:.2s;
}
.footer-social a:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.footer-col h4{color:#fff;font-size:14px;font-weight:700;letter-spacing:.04em;margin-bottom:18px;text-transform:uppercase}
.footer-col ul li{margin-bottom:10px}
.footer-col a:hover{color:#fff}

/* Popular search terms block */
.footer-tags-block{padding:30px 0;border-bottom:1px solid #1c1c22;margin-bottom:0}
.footer-tags-block h4{color:#fff;font-size:13px;font-weight:700;letter-spacing:.06em;margin-bottom:14px;text-transform:uppercase}
.footer-tag-list{display:flex;flex-wrap:wrap;gap:8px;list-style:none;padding:0;margin:0}
.footer-tag-list li{display:inline-block}
.footer-tag-list a{
  display:inline-block;padding:5px 12px;background:var(--dark-2);border:1px solid var(--dark-3);
  border-radius:999px;font-size:12px;color:#a8a8b0;transition:.2s;
}
.footer-tag-list a:hover{background:var(--accent);border-color:var(--accent);color:#fff}

.footer-bottom{
  padding-top:28px;display:flex;justify-content:space-between;gap:30px;
  flex-wrap:wrap;font-size:.82rem;color:#6a6a72;
}
.footer-copyright-tags{max-width:660px;text-align:right}

/* ============ PAGE HERO (interior pages) ============ */
.page-hero{
  position:relative;color:#fff;padding:170px 0 100px;overflow:hidden;
  display:flex;align-items:center;
}
.page-hero-compact{padding:150px 0 80px}
.page-hero-bg{position:absolute;inset:0;z-index:0}
.page-hero-bg img{width:100%;height:100%;object-fit:cover}
.page-hero-overlay{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 70% at 30% 20%, rgba(0,0,0,.35), transparent 60%),
    linear-gradient(180deg, rgba(10,10,12,.55) 0%, rgba(10,10,12,.78) 60%, rgba(10,10,12,.92) 100%);
}
.page-hero-inner{position:relative;z-index:1;max-width:880px}
.page-hero-title{
  font-family:'Montserrat',system-ui,sans-serif;font-weight:800;
  font-size:clamp(2.2rem,5.5vw,4rem);line-height:1.05;letter-spacing:-.02em;
  margin:18px 0 22px;
}
.page-hero-title .accent{
  background:linear-gradient(90deg,#0066ff,#3385ff);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.page-hero-sub{font-size:1.1rem;line-height:1.65;color:#d8d8de;max-width:640px;margin-bottom:30px}
.page-hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:30px}
.page-hero-pills{display:flex;flex-wrap:wrap;gap:10px}
.pill{
  display:inline-block;padding:6px 14px;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);border-radius:999px;
  font-size:12px;font-weight:600;letter-spacing:.04em;color:#fff;
  backdrop-filter:blur(10px);
}

/* ============ STORY (about) ============ */
.story{padding:110px 0}
.story-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:80px;align-items:start}
.story-eyebrow .section-title{margin-bottom:0}
.story-body p{margin-bottom:18px;color:var(--ink-2)}

/* ============ STRIP DARK (split copy on dark) ============ */
.strip-dark{background:var(--dark);color:#fff;padding:100px 0;position:relative;overflow:hidden}
.strip-dark::before{
  content:"";position:absolute;top:-200px;right:-200px;width:600px;height:600px;
  background:radial-gradient(circle,rgba(0,102,255,.14),transparent 60%);
}
.strip-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;position:relative}
.strip-list p{margin-bottom:18px;font-size:1rem}
.check-list-light li{
  position:relative;padding-left:26px;margin-bottom:10px;font-size:1rem;color:#cfcfd4;
}
.check-list-light li::before{
  content:"";position:absolute;left:0;top:8px;width:14px;height:14px;
  border-radius:50%;background:rgba(51,133,255,.16);
}
.check-list-light li::after{
  content:"";position:absolute;left:3px;top:11px;width:8px;height:4px;
  border-left:2px solid var(--accent-2);border-bottom:2px solid var(--accent-2);
  transform:rotate(-45deg);
}
.cover-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-top:30px}
.cover-h{
  font-family:'Montserrat',system-ui,sans-serif;font-size:1.4rem;font-weight:800;
  color:#fff;margin-bottom:18px;
}
.link-light{color:var(--accent-2)}
.link-light:hover{text-decoration:underline}

/* ============ TEAM PAGE (people cards) ============ */
.team-page{padding:110px 0}
.team-people{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.person-card{
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:.25s;
}
.person-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.person-photo{aspect-ratio:1;background:#222;overflow:hidden}
.person-photo img{width:100%;height:100%;object-fit:cover}
.person-body{padding:30px 28px}
.person-tag{
  display:inline-block;font-size:11px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent);background:var(--accent-soft);
  padding:5px 11px;border-radius:999px;margin-bottom:14px;
}
.person-card h3{font-family:'Montserrat',system-ui,sans-serif;font-size:1.7rem;font-weight:800;margin-bottom:12px}
.person-card p{color:var(--ink-3);font-size:.97rem}

/* ============ TESTIMONIAL ============ */
.testimonial-section{padding:80px 0}
.testimonial-card{
  max-width:780px;margin:0 auto;text-align:center;padding:50px 30px;
  border-radius:var(--radius);background:var(--bg-2);position:relative;
}
.quote-mark{color:var(--accent);opacity:.3;margin-bottom:14px}
.testimonial-quote{
  font-family:'Montserrat',system-ui,sans-serif;font-size:clamp(1.4rem,2.8vw,1.9rem);
  font-weight:500;line-height:1.4;color:var(--ink);margin-bottom:20px;letter-spacing:-.01em;
}
.testimonial-attr{color:var(--ink-3);font-size:.92rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.testimonial-section [class*="elfsight-app-"]{margin-top:50px}

/* ============ FEATURE GRID (services rows) ============ */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feature-grid-3{grid-template-columns:repeat(3,1fr)}
.feature-card{
  background:#fff;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);transition:.25s;display:flex;flex-direction:column;
}
.feature-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.feature-img{aspect-ratio:16/10;overflow:hidden;background:#222}
.feature-img img{width:100%;height:100%;object-fit:cover;transition:.5s}
.feature-card:hover .feature-img img{transform:scale(1.05)}
.feature-card h3{
  font-family:'Montserrat',system-ui,sans-serif;font-size:1.25rem;font-weight:800;
  padding:24px 24px 0;margin-bottom:8px;
}
.feature-card p{padding:0 24px 24px;color:var(--ink-3);font-size:.95rem;flex:1}
.feature-icon{
  width:48px;height:48px;border-radius:12px;background:var(--accent-soft);
  color:var(--accent);display:flex;align-items:center;justify-content:center;
  margin:28px 24px 0;
}
.feature-cta{
  background:var(--ink);color:#fff;justify-content:center;align-items:flex-start;
  padding:32px 28px;
}
.feature-cta h3{color:#fff;padding:0;margin-bottom:10px}
.feature-cta p{color:#cfcfd4;padding:0;margin-bottom:20px}
.feature-cta .btn{align-self:flex-start}

/* Long copy section */
.long-copy{padding:90px 0;background:var(--bg-2)}
.long-copy-inner{max-width:740px;margin:0 auto}
.long-copy-inner p{margin-bottom:18px;color:var(--ink-2);font-size:1.02rem;line-height:1.75}

/* whyus 3up override */
.whyus-grid-3{grid-template-columns:repeat(3,1fr)}

/* ============ PARTNERS (home page) ============ */
.partners{padding:100px 0;background:var(--bg-2)}
.partners-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.partner-card{
  display:flex;flex-direction:column;background:#fff;border-radius:var(--radius);
  padding:32px 28px;border:1px solid var(--line);transition:.25s;
}
.partner-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--accent)}
.partner-region{
  display:inline-block;font-size:11px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent);margin-bottom:14px;
}
.partner-card h3{font-family:'Montserrat',system-ui,sans-serif;font-size:1.3rem;font-weight:800;margin-bottom:10px}
.partner-card p{color:var(--ink-3);font-size:.95rem;flex:1;margin-bottom:18px}

/* ============ SERVICE CARD AS LINK (home) ============ */
.service-link{display:block;color:inherit}
.service-link:hover{color:inherit}

/* ============ PACKAGES ============ */
.packages{padding:110px 0;background:var(--bg-2)}
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:24px}
.pkg-card{
  position:relative;background:#fff;border-radius:var(--radius);padding:36px 30px;
  border:1px solid var(--line);display:flex;flex-direction:column;transition:.25s;
}
.pkg-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.pkg-card-feature{
  border:2px solid var(--accent);transform:translateY(-4px);
  box-shadow:0 18px 50px -20px rgba(0,102,255,.32);
}
.pkg-card-feature:hover{transform:translateY(-7px)}
.pkg-tag{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:#fff;padding:5px 14px;border-radius:999px;
  font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
}
.pkg-card h3{font-family:'Montserrat',system-ui,sans-serif;font-size:1.6rem;font-weight:800;margin-bottom:6px}
.pkg-meta{color:var(--ink-3);font-size:.9rem;margin-bottom:22px;font-weight:500}
.pkg-card .tick-list{flex:1;margin-bottom:24px}
.pkg-card .tick-list li{font-size:.95rem;margin-bottom:10px}
.packages-note{text-align:center;color:var(--ink-3);font-size:.9rem;margin-top:14px}

/* ============ CONTACT PAGE ============ */
.contact-section{padding:90px 0}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:70px;align-items:start}
.contact-info .section-title{margin-bottom:34px}
.contact-row{
  display:flex;gap:18px;margin-bottom:24px;padding-bottom:24px;
  border-bottom:1px solid var(--line);
}
.contact-row:last-of-type{border-bottom:none}
.contact-icon{
  flex-shrink:0;width:46px;height:46px;border-radius:12px;
  background:var(--accent-soft);color:var(--accent);
  display:flex;align-items:center;justify-content:center;
}
.contact-row strong{display:block;font-size:13px;font-weight:700;letter-spacing:.06em;color:var(--ink-3);text-transform:uppercase;margin-bottom:4px}
.contact-link{display:block;font-family:'Montserrat',system-ui,sans-serif;font-size:1.4rem;font-weight:800;color:var(--ink)}
.contact-link:hover{color:var(--accent)}
.contact-link-static{display:block;font-family:'Montserrat',system-ui,sans-serif;font-size:1.15rem;font-weight:700;color:var(--ink)}
.contact-note{margin-top:14px;color:var(--ink-3);font-size:.95rem;line-height:1.6}

/* ============ LOCATIONS (contact page) ============ */
.locations{padding:90px 0 110px;background:var(--bg-2)}
.locations-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.location-card{
  background:#fff;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);transition:.25s;
}
.location-card:hover{box-shadow:var(--shadow)}
.location-map{aspect-ratio:16/10;background:#eee}
.location-map iframe{width:100%;height:100%;border:0;display:block}
.location-body{padding:26px 28px}
.location-body h3{font-family:'Montserrat',system-ui,sans-serif;font-size:1.4rem;font-weight:800;margin:8px 0 10px}
.location-body p{color:var(--ink-3);margin-bottom:14px;font-size:.95rem}

/* ============ CTA BAND (page bottoms) ============ */
.cta-band{
  padding:80px 0;background:var(--ink);color:#fff;text-align:center;
  position:relative;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 70% 30%, rgba(0,102,255,.18), transparent 60%);
}
.cta-band-inner{position:relative;max-width:680px;margin:0 auto}
.cta-band h2{
  font-family:'Montserrat',system-ui,sans-serif;font-size:clamp(1.7rem,3.5vw,2.4rem);
  font-weight:600;margin-bottom:14px;line-height:1.15;
}
.cta-band p{color:#cfcfd4;margin-bottom:26px;font-size:1.05rem}
.cta-band-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.btn-ghost-dark{
  background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35);
}
.btn-ghost-dark:hover{background:rgba(255,255,255,.1);border-color:#fff}

/* nav active state */
.nav a.active,.nav .nav-trigger.active{color:var(--accent)}

/* ============ FOOTER REVIEWS BLOCK ============ */
.footer-reviews{
  padding:50px 0;border-bottom:1px solid #1c1c22;margin-bottom:50px;
}
.footer-reviews-title{
  color:#fff;font-family:'Montserrat',system-ui,sans-serif;font-size:1.5rem;font-weight:800;
  margin-bottom:24px;
}
.footer-reviews .elfsight-app-8f330059-f0b0-4070-8bb3-de66c5d4f5e9{
  background:var(--dark-2);border:1px solid var(--dark-3);border-radius:var(--radius);
  padding:18px;min-height:180px;
}

/* ============ FOOTER PARTNERS / SIMPLE PARTNERS LIST ============ */
.partners-simple{padding:80px 0;background:var(--bg-2);border-top:1px solid var(--line)}
.partners-simple-inner{max-width:820px;margin:0 auto}
.partners-simple h2{
  font-family:'Montserrat',system-ui,sans-serif;font-size:clamp(1.5rem,3vw,2rem);
  font-weight:600;margin-bottom:8px;color:var(--ink);
}
.partners-simple p.partners-intro{color:var(--ink-3);font-size:.95rem;margin-bottom:24px}
.partners-simple .partners-text p{
  color:var(--ink-2);font-size:.97rem;line-height:1.7;margin-bottom:14px;
}
.partners-simple a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.partners-simple a:hover{color:#0052cc}

/* ============ THANKS PAGE ============ */
.thanks-body{
  background:
    radial-gradient(80% 60% at 50% 0%, rgba(0,102,255,.07), transparent 70%),
    linear-gradient(180deg, #fff 0%, #fafaf8 100%);
  min-height:100vh;
}
#confetti-canvas{
  position:fixed;inset:0;width:100%;height:100%;
  pointer-events:none;z-index:1000;
}
.thanks-main{
  padding:170px 0 100px;text-align:center;position:relative;
}
.thanks-inner{max-width:780px;margin:0 auto;padding:0 24px;position:relative;z-index:2}
.thanks-badge{
  width:84px;height:84px;border-radius:50%;
  background:linear-gradient(135deg,#22c55e,#15803d);
  color:#fff;display:inline-flex;align-items:center;justify-content:center;
  margin:0 auto 26px;
  box-shadow:0 18px 40px -10px rgba(34,197,94,.45);
  animation:badgePop .6s cubic-bezier(.18,.89,.32,1.28) both;
}
@keyframes badgePop{
  0%{transform:scale(0);opacity:0}
  60%{transform:scale(1.15)}
  100%{transform:scale(1);opacity:1}
}
.thanks-title{
  font-family:'Montserrat',system-ui,sans-serif;font-weight:800;
  font-size:clamp(2.4rem,6vw,4.4rem);line-height:1.05;letter-spacing:-.02em;
  margin:8px 0 22px;color:var(--ink);
}
.thanks-title .accent{
  background:linear-gradient(90deg,#0066ff,#3385ff);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.thanks-sub{
  font-size:1.15rem;line-height:1.65;color:var(--ink-2);
  max-width:560px;margin:0 auto 36px;
}
.thanks-actions{
  display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:90px;
}
.thanks-actions .btn-ghost-dark{
  color:var(--ink);border-color:var(--line);
}
.thanks-actions .btn-ghost-dark:hover{
  background:#fff;border-color:var(--ink);
}

.thanks-next{margin-top:60px;padding-top:60px;border-top:1px solid var(--line)}
.thanks-next-title{
  font-family:'Montserrat',system-ui,sans-serif;font-weight:800;font-size:1.3rem;
  color:var(--ink-2);margin-bottom:24px;
}
.thanks-next-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;text-align:left;
}
.thanks-link-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 22px;transition:.25s;color:inherit;display:block;
}
.thanks-link-card:hover{
  transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--accent);
}
.thanks-link-eyebrow{
  display:block;font-size:11px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent);margin-bottom:10px;
}
.thanks-link-card h3{
  font-family:'Montserrat',system-ui,sans-serif;font-size:1.15rem;font-weight:800;margin-bottom:6px;
}
.thanks-link-card p{font-size:.9rem;color:var(--ink-3);line-height:1.5}

@media (max-width:900px){
  .thanks-next-grid{grid-template-columns:1fr;gap:12px}
  .thanks-main{padding:140px 0 70px}
  .thanks-actions{margin-bottom:60px}
}

/* ============ REVIEWS SECTION (home page) ============ */
.reviews-section{padding:90px 0;background:var(--bg-2);border-top:1px solid var(--line)}

/* ============ FAMILY SERVICES (funeral page) ============ */
.family-services{padding:110px 0;background:var(--bg-2)}
.family-services-grid{
  display:grid;grid-template-columns:1fr 1.2fr;gap:70px;align-items:center;
}
.family-services-copy .section-title{margin-bottom:18px}
.family-services-copy p{color:var(--ink-2);margin-bottom:14px}
.family-services-times{display:grid;grid-template-columns:1fr;gap:18px}
.time-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:28px 26px;transition:.25s;
}
.time-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.time-icon{
  width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;
}
.time-icon-day{background:rgba(255,176,46,.14);color:#e08a00}
.time-icon-night{background:rgba(60,80,160,.14);color:#3a52a3}
.time-card h3{font-family:'Montserrat',system-ui,sans-serif;font-size:1.3rem;font-weight:800;margin-bottom:8px}
.time-card > p{color:var(--ink-3);font-size:.95rem;margin-bottom:16px}
.time-card .tick-list li{font-size:.9rem;margin-bottom:6px}

@media (max-width:1024px){
  .family-services-grid{grid-template-columns:1fr;gap:40px}
}

/* ============ MOBILE NAV — DROPDOWN ============ */
@media (max-width:1024px){
  .nav-submenu{
    position:static;transform:none;opacity:1;pointer-events:auto;
    box-shadow:none;border:0;background:transparent;padding:0 0 0 14px;min-width:0;
    display:none;
  }
  .nav-has-sub.open .nav-submenu{display:flex;transform:none}
  .nav-submenu::before{display:none}
  .nav-submenu a{padding:10px 0;font-size:15px;border-bottom:1px solid var(--line)}
  .nav-submenu a:last-child{border-bottom:none}
  .nav-has-sub{padding:14px 0;border-bottom:1px solid var(--line)}
  .nav-has-sub .nav-trigger{width:100%;justify-content:space-between;font-size:16px}
}

/* ============ RESPONSIVE ============ */
@media (max-width:1024px){
  .nav{
    position:absolute;top:84px;left:0;right:0;background:#fff;
    flex-direction:column;gap:0;padding:10px 24px 20px;
    border-bottom:1px solid var(--line);
    transform:translateY(-10px);opacity:0;pointer-events:none;transition:.25s;
  }
  .nav.open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav a{padding:14px 0;border-bottom:1px solid var(--line);font-size:16px}
  .nav a:last-child{border-bottom:none}
  .nav-toggle{display:flex}
  .header-cta .phone-link{display:none}

  .intro-grid,.why-grid,.team-grid,.cta-grid,.faq-grid,.story-grid,.strip-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .process-list{grid-template-columns:repeat(2,1fr)}
  .whyus-grid,.whyus-grid-3{grid-template-columns:repeat(2,1fr)}
  .sector-card,.sector-card.reverse{grid-template-columns:1fr;gap:30px}
  .sector-card.reverse .sector-img{order:0}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .footer-maps-grid{grid-template-columns:repeat(2,1fr)}
  .feature-grid,.feature-grid-3{grid-template-columns:repeat(2,1fr)}
  .partners-grid{grid-template-columns:repeat(2,1fr)}
  .pkg-grid{grid-template-columns:1fr;gap:18px}
  .pkg-card-feature{transform:none}
  .team-people{grid-template-columns:1fr}
  .locations-grid{grid-template-columns:1fr}
  .cover-grid{grid-template-columns:1fr;gap:30px}
}

@media (max-width:640px){
  .container{padding:0 18px}
  .header-inner{height:72px}
  .logo img{height:38px}
  .nav{top:72px}
  .header-cta .btn{padding:10px 16px;font-size:13px}
  .hero{padding:110px 0 60px;min-height:auto}
  .hero-meta{grid-template-columns:1fr;gap:16px;padding-top:24px}
  .hero-meta strong{font-size:1.4rem}
  .hero-actions .btn{flex:1}
  .intro,.services,.why,.sectors,.process,.team,.why-us,.faq,.cta{padding:70px 0}
  .services-grid{grid-template-columns:1fr}
  .process-list{grid-template-columns:1fr}
  .whyus-grid{grid-template-columns:1fr}
  .why-stats{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-maps-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column}
  .footer-copyright-tags{text-align:left}
  .feature-grid,.feature-grid-3,.partners-grid{grid-template-columns:1fr}
  .page-hero{padding:130px 0 70px}
  .page-hero-actions .btn{flex:1}
  .field-row{grid-template-columns:1fr}
  .quote-form{padding:28px 22px}
  .section-head{margin-bottom:42px}
}

/* ============ REVEAL ============ */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
