:root{
  --bg:#ffffff;
  --bg-subtle:#f8fafc;
  --panel:#f1f5f9;
  --text:#000000;
  --muted:#000000;
  --line:rgba(15,23,42,.10);
  --line-strong:rgba(15,23,42,.14);
  /* Brand blues (pulled from the logo) */
  --accent:#0c1c3c;
  --accent2:#2f74c8;
  --accent-soft:rgba(12,28,60,.12);
  --warn:#d97706;
  --shadow: 0 1px 3px rgba(15,23,42,.06), 0 12px 40px rgba(15,23,42,.08);
  --radius:18px;
  --max:1120px;
  --safe-bottom: env(safe-area-inset-bottom, 0px);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  background:
    radial-gradient(1000px 500px at 15% -5%, rgba(13,148,136,.08), transparent 55%),
    radial-gradient(800px 480px at 95% 0%, rgba(14,165,233,.07), transparent 50%),
    linear-gradient(180deg, var(--bg-subtle) 0%, var(--bg) 35%);
  color:var(--text);
  line-height:1.55;
}

a{color:inherit}
.container{max-width:var(--max); margin:0 auto; padding:0 20px}
.topbar{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.88);
  backdrop-filter: blur(12px);
  border-bottom:0;
  box-shadow:none;
}
.topbar-inner{display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:14px}
.brand{display:flex; align-items:center; gap:10px; text-decoration:none}
.logo{
  display:block;
  height:52px;
  width:auto;
  max-width:min(320px, 72vw);
  object-fit:contain;
  object-position:left center;
  flex-shrink:0;
}

.nav{display:flex; align-items:center; gap:10px}
.nav a{
  font-size:13px; color:var(--muted);
  text-decoration:none;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid transparent;
}
.nav a:hover{color:var(--text); border-color:var(--line); background:var(--bg-subtle)}
.nav .cta{
  color:#fff;
  background: var(--accent);
  border:0;
  font-weight:650;
  box-shadow: 0 4px 14px rgba(13,148,136,.35);
}
.nav .cta:hover{filter:brightness(1.03)}
.nav .nav-link{
  font-family:inherit;
  font-size:13px;
  color:var(--muted);
  padding:8px 10px;
  border-radius:999px;
  border:1px solid transparent;
  background:transparent;
  cursor:pointer;
}
.nav .nav-link:hover{
  color:var(--text);
  border-color:var(--line);
  background:var(--bg-subtle);
}
.nav-dropdown{position:relative}
.nav-dropdown-panel{
  display:none;
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  min-width:min(280px, 92vw);
  max-width:min(320px, 94vw);
  padding:12px 12px 10px;
  border-radius:14px;
  border:1px solid var(--line);
  background:var(--bg);
  box-shadow:var(--shadow);
  z-index:60;
  text-align:left;
}
.nav-dropdown:hover .nav-dropdown-panel,
.nav-dropdown:focus-within .nav-dropdown-panel{
  display:block;
}
.nav-dropdown-item{
  display:block;
  padding:10px 12px;
  border-radius:10px;
  font-size:13px;
  line-height:1.35;
  color:var(--text);
  text-decoration:none;
  font-weight:600;
}
.nav-dropdown-item:hover{background:var(--bg-subtle)}
.nav-dropdown-item--primary{
  font-size:14px;
  font-weight:700;
  padding:12px 12px;
}
.nav-dropdown-seo{
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid var(--line);
  display:flex;
  flex-direction:column;
  gap:2px;
}
.nav-dropdown-seo-label{
  font-size:10px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--muted);
  margin:0 0 6px;
  font-weight:650;
}
.nav-dropdown-seo-link{
  display:block;
  padding:8px 4px;
  font-size:12px;
  font-weight:600;
  color:var(--accent2);
  text-decoration:none;
  border-radius:8px;
}
.nav-dropdown-seo-link:hover{
  background:var(--bg-subtle);
  color:var(--text);
  text-decoration:underline;
  text-underline-offset:3px;
}

/* Immersive hero: full-viewport image + left frosted panel + overlay copy */
.hero--immersive{
  position:relative;
  isolation:isolate;
  padding:0;
  margin:0;
  overflow:hidden;
  min-height:88vh;
  min-height:min(92svh, 900px);
  max-height:92vh;
  max-height:92svh;
}
.hero-visual{
  position:absolute;
  inset:0;
  z-index:0;
  /* Fallback if image hasn’t painted yet (keep light so it never reads as a “black bar”) */
  background:#dbe4ec;
}
.hero-slider{
  position:absolute;
  inset:0;
  overflow:hidden;
  background:#dbe4ec;
}
.hero-slide{
  position:absolute;
  inset:0;
  opacity:0;
  transition:opacity 0.75s ease;
  pointer-events:none;
  overflow:hidden;
}
.hero-slide.is-active{
  opacity:1;
  z-index:1;
}
.hero-slide-img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  display:block;
}
@media (prefers-reduced-motion: reduce){
  .hero-slide{transition-duration:0.01ms}
}
.hero-slider-chrome{
  position:absolute;
  z-index:3;
  left:50%;
  bottom:max(18px, env(safe-area-inset-bottom));
  transform:translateX(-50%);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  pointer-events:none;
}
.hero-slider-chrome button{
  pointer-events:auto;
}
.hero-slider-chrome:focus{
  outline:none;
}
.hero-slider-chrome:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:4px;
  border-radius:12px;
}
.hero-slider-dots{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:8px;
  max-width:min(92vw, 360px);
  pointer-events:auto;
}
.hero-slider-dot{
  width:9px;
  height:9px;
  padding:0;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.65);
  background:rgba(255,255,255,.35);
  cursor:pointer;
  transition:background .2s ease, transform .2s ease;
}
.hero-slider-dot.is-active{
  background:#fff;
  border-color:#fff;
  transform:scale(1.15);
}
.hero-slider-dot:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:2px;
}
.visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
.hero-blur-layer{
  position:absolute;
  inset:0;
  z-index:1;
  width:100%;
  height:100%;
  pointer-events:none;
  /* Frosted wash — wide soft fade (no hard edge) */
  background:linear-gradient(
    90deg,
    rgba(248,250,252,.98) 0%,
    rgba(255,255,255,.82) 14%,
    rgba(255,255,255,.55) 32%,
    rgba(255,255,255,.28) 48%,
    rgba(255,255,255,.1) 62%,
    rgba(255,255,255,.02) 76%,
    transparent 88%
  );
  backdrop-filter:blur(18px) saturate(1.1);
  -webkit-backdrop-filter:blur(18px) saturate(1.1);
  /* Feather the whole layer so blur + tint flow into the photo */
  mask-image:linear-gradient(
    90deg,
    #000 0%,
    #000 8%,
    rgba(0,0,0,.92) 28%,
    rgba(0,0,0,.65) 44%,
    rgba(0,0,0,.35) 58%,
    rgba(0,0,0,.15) 72%,
    rgba(0,0,0,.04) 84%,
    transparent 96%
  );
  -webkit-mask-image:linear-gradient(
    90deg,
    #000 0%,
    #000 8%,
    rgba(0,0,0,.92) 28%,
    rgba(0,0,0,.65) 44%,
    rgba(0,0,0,.35) 58%,
    rgba(0,0,0,.15) 72%,
    rgba(0,0,0,.04) 84%,
    transparent 96%
  );
  mask-size:100% 100%;
  mask-repeat:no-repeat;
  -webkit-mask-size:100% 100%;
  -webkit-mask-repeat:no-repeat;
}
.hero-content{
  position:relative;
  z-index:4;
  min-height:min(92svh, 900px);
  display:flex;
  align-items:center;
  padding-top:calc(12px + env(safe-area-inset-top, 0px));
  padding-bottom:calc(20px + env(safe-area-inset-bottom, 0px));
  box-sizing:border-box;
}
.hero-copy{
  max-width:min(520px, 94vw);
}
.hero-kicker{
  background:rgba(255,255,255,.78);
  border-color:rgba(15,23,42,.12);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
.hero-lead{
  color:var(--text);
}
.hero-caption{
  margin:10px 0 0;
  font-size:13px;
  line-height:1.45;
  color:var(--muted);
  max-width:48ch;
}
.hero-badges{
  margin-top:14px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.hero-badge{
  background:rgba(255,255,255,.72);
  border-color:rgba(15,23,42,.1);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
}
.hero-btn-ghost{
  background:rgba(255,255,255,.82);
  border-color:rgba(15,23,42,.14);
}
.hero-jobs-wrap{
  padding:10px 0 6px;
}
.hero-jobs{
  margin-top:0;
  padding:18px 20px;
}
.hero-jobs-title{
  margin:0 0 12px;
  font-size:15px;
  letter-spacing:.01em;
  color:var(--text);
}
.hero-jobs-list{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
  grid-template-columns:1fr;
}
@media (min-width: 860px){
  .hero-jobs-list{
    grid-template-columns:repeat(3, minmax(0, 1fr));
    align-items:stretch;
  }
}
@media (max-width: 768px){
  :root{
    --topbar-h: 80px;
  }
  body{
    padding-top: var(--topbar-h);
  }
  .topbar .container{
    padding-left:max(10px, env(safe-area-inset-left, 0px));
    padding-right:max(26px, env(safe-area-inset-right, 0px));
  }
  .topbar{
    position:fixed;
    left:0;
    right:0;
    top:0;
    z-index:80;
    background:transparent;
    -webkit-backdrop-filter:none;
    backdrop-filter:none;
  }
  /* Mobile: hero text hidden; keep header CTA */
  .hero-blur-layer{
    display:none;
  }
  /* Mobile: taper the hero image into white at the bottom */
  .hero--immersive::after{
    content:"";
    position:absolute;
    left:0;
    right:0;
    bottom:0;
    height:160px;
    z-index:2;
    pointer-events:none;
    background:linear-gradient(
      180deg,
      rgba(255,255,255,0) 0%,
      rgba(255,255,255,.36) 34%,
      rgba(255,255,255,.78) 64%,
      rgba(255,255,255,1) 100%
    );
  }
  /* Let the hero image sit behind the fixed header */
  .hero--immersive{
    margin-top: calc(-1 * var(--topbar-h));
  }
  /* Mobile: slight top blur/fade over the hero image */
  .hero--immersive::before{
    content:"";
    position:absolute;
    left:0;
    right:0;
    top:0;
    height:118px;
    z-index:2;
    pointer-events:none;
    background:linear-gradient(
      180deg,
      rgba(255,255,255,.72) 0%,
      rgba(255,255,255,.34) 50%,
      rgba(255,255,255,0) 100%
    );
    -webkit-backdrop-filter:blur(14px) saturate(1.08);
    backdrop-filter:blur(14px) saturate(1.08);
    mask-image:linear-gradient(180deg, #000 0%, rgba(0,0,0,.9) 35%, rgba(0,0,0,.3) 70%, transparent 100%);
    -webkit-mask-image:linear-gradient(180deg, #000 0%, rgba(0,0,0,.9) 35%, rgba(0,0,0,.3) 70%, transparent 100%);
  }
  .hero-slider-chrome{
    left:50%;
    right:auto;
    top:auto;
    bottom:calc(14px + env(safe-area-inset-bottom, 0px));
    transform:translateX(-50%);
    flex-direction:row;
    flex-wrap:wrap;
    justify-content:center;
    gap:8px;
    max-width:min(100%, 100vw - 24px);
    padding:0 12px;
    pointer-events:none;
  }
  .hero-slider-dots{
    max-width:min(92vw, 280px);
    gap:6px;
  }
  .hero-slider-dot{
    width:7px;
    height:7px;
  }
  /* Shorter hero = less extreme vertical crop on mixed-aspect slides */
  .hero--immersive{
    min-height:min(76svh, 640px);
    max-height:none;
  }
  .hero-blur-layer{
    width:100%;
    max-width:none;
    top:auto;
    bottom:0;
    left:0;
    right:0;
    height:min(68%, 460px);
    background:linear-gradient(
      180deg,
      transparent 0%,
      rgba(255,255,255,.12) 22%,
      rgba(255,255,255,.55) 45%,
      rgba(255,255,255,.88) 72%,
      rgba(255,255,255,.96) 100%
    );
    backdrop-filter:blur(16px) saturate(1.06);
    -webkit-backdrop-filter:blur(16px) saturate(1.06);
    /* Soft top edge on mobile bottom sheet */
    mask-image:linear-gradient(
      180deg,
      transparent 0%,
      rgba(0,0,0,.12) 8%,
      rgba(0,0,0,.45) 22%,
      rgba(0,0,0,.82) 38%,
      #000 52%,
      #000 100%
    );
    -webkit-mask-image:linear-gradient(
      180deg,
      transparent 0%,
      rgba(0,0,0,.12) 8%,
      rgba(0,0,0,.45) 22%,
      rgba(0,0,0,.82) 38%,
      #000 52%,
      #000 100%
    );
    mask-size:100% 100%;
    -webkit-mask-size:100% 100%;
  }
  .hero-content{
    display:none;
    position:relative;
    z-index:4;
    min-height:min(76svh, 640px);
    align-items:flex-start;
    padding:calc(var(--topbar-h) + 14px) 16px calc(28px + env(safe-area-inset-bottom, 0px));
  }
  .hero-copy{
    margin-bottom:0;
  }
  /* Bias crop toward the subject (no scale — scale + overflow clip caused a dark band at the top) */
  .hero--immersive .hero-slide-img{
    object-position:50% 42%;
  }
  .hero--immersive .h1{
    font-size:clamp(16px, 4.8vw, 24px);
    letter-spacing:-.45px;
    margin-top:12px;
    margin-bottom:12px;
  }
  /* Mobile: show just the headline over the image */
  .hero--immersive .hero-kicker,
  .hero--immersive .hero-lead,
  .hero--immersive .hero-caption,
  .hero--immersive .hero-actions,
  .hero--immersive .hero-badges{
    display:none;
  }
  .hero--immersive .hero-lead{
    font-size:15px;
    line-height:1.5;
    margin:0;
  }
  .hero--immersive .hero-caption{
    margin-top:12px;
    font-size:12.5px;
    max-width:none;
  }
  .hero--immersive .hero-actions{
    flex-direction:column;
    align-items:stretch;
    gap:10px;
    margin-top:16px;
  }
  .hero--immersive .hero-actions .btn{
    width:100%;
    min-height:48px;
    padding:14px 16px;
    font-size:15px;
    justify-content:center;
  }
  .hero--immersive .hero-badges{
    margin-top:12px;
    gap:6px;
  }
  .hero--immersive .hero-badge{
    font-size:10.5px;
    padding:6px 9px;
    border-radius:999px;
  }
  .hero--immersive .hero-kicker{
    font-size:11px;
    padding:7px 11px;
    line-height:1.35;
  }
}
.kicker{
  display:inline-flex; gap:10px; align-items:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--bg);
  color:var(--muted);
  font-size:12px;
}
.kicker b{color:var(--accent)}
.h1{
  font-size: clamp(28px, 3.2vw, 44px);
  line-height:1.08;
  margin:14px 0 10px;
  letter-spacing:-.6px;
  color:var(--text);
}
.h2{
  font-size: clamp(20px, 2.2vw, 26px);
  line-height:1.15;
  margin:0 0 10px;
  letter-spacing:-.35px;
  color:var(--text);
}
.h3{
  font-size:16px;
  line-height:1.25;
  margin:0 0 8px;
  color:var(--text);
}
.areas-map-wrap{
  margin-top:4px;
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
#areas-map{
  height:min(62vh,520px);
  min-height:320px;
  width:100%;
  background:var(--panel);
  z-index:1;
}
.areas-filter-bar{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:12px;
}
.areas-filter-btn{
  font-size:13px;
  padding:10px 12px;
  border-radius:999px;
  cursor:pointer;
  border:1px solid var(--line-strong);
  background:var(--bg);
  color:var(--text);
  font-weight:600;
}
.areas-filter-btn:hover{border-color:var(--accent2); color:var(--accent)}
.areas-filter-btn.is-active{
  background:var(--accent);
  color:#fff;
  border-color:var(--accent);
}
.areas-nation-block{margin-bottom:14px}
.areas-nation-summary{
  cursor:pointer;
  list-style:none;
  margin:0 0 0;
  padding:0 0 0 1.1em;
  position:relative;
  font-weight:640;
  color:var(--text);
}
.areas-nation-summary::-webkit-details-marker{display:none}
.areas-nation-summary::marker{content:""}
.areas-nation-summary::before{
  content:"";
  position:absolute;
  left:0;
  top:.35em;
  width:0;
  height:0;
  border-left:6px solid var(--muted);
  border-top:4px solid transparent;
  border-bottom:4px solid transparent;
  transition:transform .15s ease;
}
.areas-nation-details[open] .areas-nation-summary::before{
  transform:rotate(90deg);
}
.areas-nation-details .areas-county-list{margin-top:12px}
.areas-county-list{
  list-style:none;
  padding:0;
  margin:0;
  columns:1 200px;
  column-gap:20px;
}
.areas-county-list li{
  break-inside:avoid;
  margin:0 0 8px;
}
.areas-county-list a{
  color:var(--accent);
  text-decoration:underline;
  text-underline-offset:3px;
}
.areas-county-list a:hover{color:var(--text)}
.leaflet-container{font-family:inherit}
.lead{color:var(--muted); margin:0; max-width:60ch}
.hero-actions{display:flex; flex-wrap:wrap; gap:10px; margin-top:18px}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--line-strong);
  background:var(--bg);
  color:var(--text);
  text-decoration:none;
  font-weight:640;
  font-size:14px;
  box-shadow: 0 1px 2px rgba(15,23,42,.04);
}
.btn.primary{
  color:#fff;
  border:0;
  background: var(--accent);
  box-shadow: 0 4px 16px rgba(13,148,136,.35);
}
.btn:hover{filter:brightness(1.02)}
.btn small{font-weight:600; color:var(--muted)}

.card{
  border-radius:var(--radius);
  border:1px solid var(--line);
  background: var(--bg);
  box-shadow: var(--shadow);
}
.hero-card{padding:18px}
.hero-card h3{margin:0 0 10px; font-size:14px; letter-spacing:.2px; color:var(--text)}
.hero-card ul{margin:0; padding:0; list-style:none; display:grid; gap:10px}
.pill{
  display:flex; gap:10px; align-items:flex-start;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:var(--bg-subtle);
}
.pill b{display:block; font-size:13px; color:var(--text)}
.pill span{display:block; color:var(--muted); font-size:12px; margin-top:1px}
.dot{
  width:10px; height:10px; border-radius:50%;
  background: var(--accent);
  box-shadow: 0 0 0 6px var(--accent-soft);
  margin-top:4px;
}

.section{padding:26px 0}
.section h2{margin:0 0 10px; font-size:18px; color:var(--text)}
.home-about{
  padding-top:20px;
  padding-bottom:8px;
  background: linear-gradient(180deg, var(--bg-subtle) 0%, var(--bg) 55%);
  border-top: 1px solid var(--line);
  text-align:center;
}
.home-about .container > .h2{margin-left:auto; margin-right:auto; max-width:48rem}
.home-about .home-about-inner{
  max-width:72ch;
  margin:14px auto 0;
  text-align:center;
  /* One size for all copy in the card (overrides body vs .feature p mismatch) */
  font-size:15px;
  line-height:1.6;
}
.home-about .home-about-inner p,
.home-about .home-about-inner li,
.home-about .home-about-inner .lead{
  font-size:inherit;
  line-height:inherit;
}
.home-about .feature p{font-size:inherit}
.home-about .home-about-inner .lead{max-width:none}
.home-about .home-about-inner strong{font-weight:700}
.home-about .list{
  list-style:none;
  padding-left:0;
  margin-left:auto;
  margin-right:auto;
  max-width:60ch;
}
.home-about .list li{font-size:inherit; font-weight:400}
.home-about .hero-actions{justify-content:center}
.home-about .home-about-inner .btn{font-size:inherit}

@media (min-width:960px){
  .home-about .container{
    max-width:none;
    width:100%;
    padding-left:max(24px, env(safe-area-inset-left, 0px));
    padding-right:max(24px, env(safe-area-inset-right, 0px));
  }
  .home-about .container > .h2{max-width:none}
  .home-about .home-about-inner{max-width:none; width:100%}
  .home-about .list{max-width:none}
}
.grid-3{
  display:grid; gap:14px;
  grid-template-columns: repeat(3, minmax(0,1fr));
}
.feature{padding:16px}
.feature h3{margin:0 0 6px; font-size:14px; color:var(--text)}
.feature p{margin:0; color:var(--muted); font-size:13px}
.feature .tag{
  display:inline-flex; align-items:center; gap:8px;
  font-size:12px; color:#fff;
  background: var(--accent);
  padding:6px 10px;
  border-radius:999px;
  margin-bottom:10px;
}

.two-col{display:grid; grid-template-columns: 1fr 1fr; gap:14px}
.list{margin:0; padding-left:18px; color:var(--muted)}
.list li{margin:8px 0}

.footer{
  padding:36px 0 96px;
  margin-top:8px;
  border-top:1px solid var(--line-strong);
  color:var(--muted);
  background:
    radial-gradient(900px 280px at 10% 0%, rgba(47,116,200,.06), transparent 55%),
    linear-gradient(180deg, #f1f5f9 0%, var(--bg) 42%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7);
}
.footer .container{
  max-width:var(--max);
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:clamp(20px, 4vw, 40px);
  align-items:start;
}
.footer-grid > div:first-child{
  padding-right:clamp(0px, 2vw, 12px);
}
.footer-grid > div:first-child .badge{
  box-shadow: 0 1px 2px rgba(15,23,42,.04);
}
.footer-grid > div:first-child .fine{
  max-width:52ch;
  line-height:1.55;
}
.footer-grid > div:last-child{
  padding:16px 18px;
  border-radius:var(--radius);
  border:1px solid var(--line);
  background:rgba(255,255,255,.72);
  box-shadow: 0 8px 30px rgba(15,23,42,.05);
}
.footer-grid > div:last-child > p.fine:first-of-type{
  margin:0 0 12px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--text);
  opacity:.55;
}
.footer-grid > div:last-child > div{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(108px, 1fr));
  gap:6px 14px;
}
.footer a{
  color:var(--text);
  text-decoration:none;
  font-size:13px;
  font-weight:600;
  padding:6px 2px;
  border-radius:8px;
  opacity:.88;
  transition: color .15s ease, opacity .15s ease, background .15s ease;
}
.footer a:hover{
  color:var(--accent2);
  opacity:1;
  background:rgba(47,116,200,.08);
}
.footer-grid > div:first-child a{
  color:var(--accent2);
  text-decoration:underline;
  text-underline-offset:3px;
  font-weight:600;
  padding:0;
  background:none;
}
.footer-grid > div:first-child a:hover{
  color:var(--accent);
  background:none;
}
.fine{font-size:12px; opacity:.95}

/* Sticky contact bar (mobile-first) */
.sticky-bar{
  position:fixed;
  left:0; right:0; bottom:0;
  z-index:60;
  padding:10px 12px calc(10px + var(--safe-bottom));
  background:rgba(255,255,255,.94);
  backdrop-filter: blur(12px);
  border-top:1px solid var(--line);
  box-shadow: 0 -4px 24px rgba(15,23,42,.06);
}
.sticky-inner{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap:10px;
}
.sticky-btn{
  display:flex;
  flex-direction:row;
  align-items:center;
  justify-content:center;
  gap:0;
  padding:12px 8px;
  border-radius:16px;
  border:1px solid var(--line);
  background:var(--bg);
  text-decoration:none;
  min-height:52px;
  box-shadow: 0 1px 2px rgba(15,23,42,.04);
}
.sticky-icon{
  width:26px;
  height:26px;
  flex-shrink:0;
  display:block;
}
.sticky-btn:not(.primary) .sticky-icon{
  color:var(--text);
}
.sticky-btn.primary{
  border:0;
  background: var(--accent);
  color:#fff;
  box-shadow: 0 4px 14px rgba(13,148,136,.35);
}
.sticky-btn.primary .sticky-icon{
  color:#fff;
}
/* WhatsApp brand colour on the icon */
.sticky-btn[data-whatsapp] .sticky-icon--wa{
  color:#25D366;
}
.sticky-btn:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:2px;
}

.badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--bg-subtle);
  color:var(--muted);
  font-size:12px;
}

/* Responsive */
@media (max-width: 920px){
  .footer-grid{grid-template-columns: 1fr}
  .two-col{grid-template-columns: 1fr}
}
@media (max-width: 860px){
  .grid-3{grid-template-columns: 1fr}
  .nav a.hide-sm{display:none}
  .nav .nav-dropdown.hide-sm{display:none}

  .mobile-menu-root{
    position:fixed;
    inset:0;
    z-index:85;
    pointer-events:none;
  }
  .mobile-menu-root .mobile-menu-toggle,
  .mobile-menu-root .mobile-menu-backdrop,
  .mobile-menu-root .mobile-menu-panel{
    pointer-events:auto;
  }
  .mobile-menu-panel:not(.is-open){
    visibility:hidden;
  }

  .mobile-menu-toggle{
    position:fixed;
    top:calc(50vh - 26px);
    right:8px;
    z-index:90;
    width:40px;
    height:52px;
    border-radius:999px;
    border:1px solid rgba(15,23,42,.12);
    background:rgba(255,255,255,.18);
    display:inline-flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    box-shadow: 0 10px 28px rgba(15,23,42,.10);
    -webkit-backdrop-filter:blur(10px) saturate(1.05);
    backdrop-filter:blur(10px) saturate(1.05);
  }
  .mobile-menu-toggle:focus-visible{
    outline:2px solid var(--accent);
    outline-offset:3px;
  }
  .mobile-menu-caret{
    width:22px;
    height:22px;
    display:inline-flex;
    color:var(--text);
    transition:transform .18s ease;
  }
  .mobile-menu-toggle.is-open .mobile-menu-caret{
    transform:rotate(180deg);
  }
  .mobile-menu-toggle.is-open{
    right:calc(min(86vw, 320px) + 12px);
  }
  .mobile-menu-backdrop{
    position:fixed;
    inset:0;
    z-index:85;
    display:none;
    background:rgba(0,0,0,.18);
    -webkit-backdrop-filter:blur(2px);
    backdrop-filter:blur(2px);
  }
  .mobile-menu-backdrop.is-open{
    display:block;
  }
  .mobile-menu-panel{
    position:fixed;
    top:0;
    right:0;
    height:100vh;
    height:100svh;
    width:min(86vw, 320px);
    z-index:88;
    display:block;
    padding:14px 12px 12px;
    transform:translateX(105%);
    transition:transform .22s ease;
  }
  .mobile-menu-panel.is-open{
    transform:translateX(0);
    visibility:visible;
  }
  .mobile-menu-list{
    display:grid;
    gap:8px;
    padding:12px;
    border-radius:18px;
    border:1px solid rgba(15,23,42,.14);
    background:rgba(255,255,255,.34);
    box-shadow: 0 18px 50px rgba(15,23,42,.16);
    -webkit-backdrop-filter:blur(16px) saturate(1.05);
    backdrop-filter:blur(16px) saturate(1.05);
  }
  .mobile-menu-link{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:12px 12px;
    border-radius:14px;
    text-decoration:none;
    border:1px solid rgba(15,23,42,.10);
    background:rgba(255,255,255,.22);
    color:var(--text);
    font-weight:650;
    font-size:14px;
    -webkit-backdrop-filter:blur(10px) saturate(1.05);
    backdrop-filter:blur(10px) saturate(1.05);
  }
  .mobile-menu-link:hover{
    filter:brightness(0.99);
  }
  .mobile-menu-link.cta{
    background:var(--accent);
    border-color:transparent;
    color:#fff;
  }
}
@media (min-width: 861px){
  .sticky-bar{display:none}
  .footer{padding-bottom:28px}
  .mobile-menu-root{display:none !important}
}

/* Accessibility */
.skip-link{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{
  position:fixed; left:12px; top:12px; width:auto; height:auto; padding:10px 12px;
  background:#fff; color:#000; border-radius:10px; z-index:999;
  box-shadow: var(--shadow);
}
