/* ============================================================
   Your Internet Options — Global Stylesheet
   Used by ALL city pages. Header, footer, and section styles.
   ============================================================ */

/* ============================================================
   Mobile, AL — AT&T Fiber  ·  v3
   World-class · LeadConnector iframe · Generic fiber imagery
   Brand: #029CD7 / #0B1A2B  ·  Space Grotesk + Inter
   ============================================================ */

:root{
  --blue:#029CD7;
  --blue-deep:#0287BC;
  --blue-bright:#3DB7E0;
  --blue-soft:#E6F5FC;
  --blue-glow:rgba(2,156,215,.18);
  --navy:#0B1A2B;
  --navy-2:#0F2235;
  --navy-3:#152C45;
  --ink:#0B1A2B;
  --text:#3F4D5E;
  --muted:#7B8597;
  --quiet:#A8B0BE;
  --line:#E5EAF0;
  --line-soft:#EFF2F6;
  --line-mute:#D9DEE6;
  --bg:#FFFFFF;
  --off:#F6F8FB;
  --cream:#FBF6EA;
  --cream-deep:#F5EDD8;
  --shadow-1:0 1px 2px rgba(11,26,43,.05);
  --shadow-2:0 12px 32px rgba(11,26,43,.10);
  --shadow-3:0 30px 60px -18px rgba(11,26,43,.22);
  --shadow-blue:0 24px 60px -16px rgba(2,156,215,.34);
  --r-sm:8px; --r:14px; --r-lg:22px; --r-xl:28px;
  --container:1240px;
  --gut:clamp(20px, 4vw, 32px);
  --pad-section:clamp(80px, 9vw, 136px);
  --ease:cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;font-family:'Inter',system-ui,sans-serif;
  font-size:17px;line-height:1.65;color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--blue-deep)}
button{font-family:inherit;cursor:pointer}

h1,h2,h3,h4,.display{
  font-family:'Space Grotesk',system-ui,sans-serif;
  color:var(--ink);line-height:1.05;
  letter-spacing:-.025em;font-weight:600;
  margin:0 0 .4em;
}
h1{font-size:clamp(2.5rem, 5.5vw, 4.25rem);font-weight:700;letter-spacing:-.04em;line-height:1.02}
h2{font-size:clamp(1.625rem, 3vw, 2.5rem);letter-spacing:-.03em;line-height:1.1}
h3{font-size:1.4rem;font-weight:600;line-height:1.2;letter-spacing:-.018em}
h4{font-size:1.0625rem;font-weight:600}
p{margin:0 0 1em}

.skip{position:absolute;left:-9999px;background:var(--ink);color:#fff;padding:10px 16px;z-index:1000}
.skip:focus{left:8px;top:8px}

.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:var(--pad-section);position:relative}
.section--off{background:var(--off)}
.section--cream{background:var(--cream)}

/* ============= SCROLL PROGRESS ============= */
.scroll-progress{
  position:fixed;top:0;left:0;height:2px;width:0%;
  background:linear-gradient(90deg, var(--blue), var(--blue-bright));
  z-index:60;transition:width .05s linear;
  box-shadow:0 0 10px var(--blue);
}

/* ============= SECTION MARKER ============= */
.sec-mark{
  display:flex;align-items:baseline;gap:18px;margin-bottom:32px;
  font-family:'Space Grotesk',sans-serif;
}
.sec-mark .num{
  font-size:.95rem;font-weight:600;color:var(--blue);letter-spacing:.18em;
}
.sec-mark .label{
  font-size:.78rem;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;color:var(--muted);
}
.sec-mark .rule{
  flex:1;height:1px;
  background:linear-gradient(to right, var(--line), transparent);
  margin-left:6px;
}

/* ============= HEADER ============= */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line-soft);
}
.nav{display:flex;align-items:center;gap:28px;height:74px}
.brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.brand img{height:36px;width:auto}
.primary-nav{margin-left:auto;display:flex;align-items:center;gap:4px}
.primary-nav a, .primary-nav button{
  display:inline-flex;align-items:center;gap:6px;
  padding:9px 14px;border-radius:8px;
  font-size:.93rem;font-weight:500;color:var(--ink);
  background:transparent;border:none;
  transition:background .2s var(--ease),color .2s var(--ease);
}
.primary-nav a:hover, .primary-nav button:hover{background:var(--blue-soft);color:var(--blue)}

.cities{position:relative}
.cities-trigger::after{
  content:"";display:inline-block;width:7px;height:7px;
  border-right:2px solid currentColor;border-bottom:2px solid currentColor;
  transform:rotate(45deg) translateY(-2px);
  margin-left:4px;transition:transform .2s var(--ease);
}
.cities[aria-expanded="true"] .cities-trigger::after{transform:rotate(-135deg) translateY(2px)}
.cities-menu{
  position:absolute;top:calc(100% + 8px);right:0;
  min-width:580px;background:#fff;border:1px solid var(--line);
  border-radius:16px;box-shadow:var(--shadow-3);
  padding:24px;display:none;
  grid-template-columns:repeat(2,1fr);gap:20px 32px;
}
.cities[aria-expanded="true"] .cities-menu{display:grid}
.cities-state{
  font-size:.7rem;text-transform:uppercase;letter-spacing:.18em;
  color:var(--muted);font-weight:600;margin-bottom:10px;
  padding-bottom:8px;border-bottom:1px solid var(--line-soft);
}
.cities-menu ul{list-style:none;margin:0;padding:0}
.cities-menu li a{
  display:block;padding:7px 8px;border-radius:6px;
  font-size:.93rem;color:var(--ink);font-weight:500;
}
.cities-menu li a:hover{background:var(--blue-soft);color:var(--blue)}

.btn-cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 18px;border-radius:999px;
  background:var(--blue);color:#fff !important;
  font-weight:600;font-size:.93rem;letter-spacing:-.005em;
  box-shadow:0 4px 14px var(--blue-glow);
  border:none;cursor:pointer;
  transition:transform .15s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease);
}
.btn-cta:hover{background:var(--blue-deep);transform:translateY(-1px);box-shadow:0 8px 22px rgba(2,156,215,.36)}
.btn-cta svg{transition:transform .2s var(--ease)}
.btn-cta:hover svg{transform:translateX(2px)}
.nav-cta{margin-left:6px}

.hamburger{display:none;background:none;border:none;width:42px;height:42px;border-radius:8px;align-items:center;justify-content:center}
.hamburger span,.hamburger span::before,.hamburger span::after{
  display:block;width:22px;height:2px;background:var(--ink);
}
.hamburger span{position:relative;transition:.2s}
.hamburger span::before,.hamburger span::after{content:"";position:absolute;left:0}
.hamburger span::before{top:-7px}
.hamburger span::after{top:7px}

/* ============= HERO ============= */
.hero{
  position:relative;overflow:hidden;
  padding-block:clamp(64px, 9vw, 132px) clamp(56px, 8vw, 112px);
  background:
    radial-gradient(1100px 540px at 88% 0%, rgba(2,156,215,.16), transparent 60%),
    radial-gradient(800px 420px at -8% 80%, rgba(2,156,215,.08), transparent 65%),
    var(--bg);
}
.hero::before{
  /* fine grid */
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(to right, rgba(11,26,43,.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(11,26,43,.05) 1px, transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 90% 70% at 50% 30%, #000 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 90% 70% at 50% 30%, #000 30%, transparent 80%);
  opacity:.55;
}
.hero-fiber{
  position:absolute;right:-50px;top:80px;width:520px;height:520px;
  pointer-events:none;opacity:.35;z-index:0;
  filter:blur(.5px);
}

.hero-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:start;
}

.live-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:7px 14px;border:1px solid var(--line);border-radius:999px;
  background:rgba(255,255,255,.7);backdrop-filter:blur(8px);
  font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink);margin-bottom:28px;
}
.live-dot{
  width:7px;height:7px;border-radius:50%;background:var(--blue);
  box-shadow:0 0 0 0 var(--blue);
  animation:pulse 2s var(--ease) infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(2,156,215,.5)}
  100%{box-shadow:0 0 0 12px rgba(2,156,215,0)}
}

.hero h1{margin-bottom:22px}
.hero h1 .l1{display:block;color:var(--ink)}
.hero h1 .l2{display:block;font-style:italic;font-weight:500}
.hero h1 .l2 em{
  font-style:normal;font-weight:700;letter-spacing:-.05em;
  background:linear-gradient(180deg, var(--blue) 0%, var(--blue-deep) 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}

.hero-sub{
  font-size:1.0625rem;line-height:1.6;color:var(--text);
  max-width:46ch;margin-bottom:36px;
}
.hero-sub strong{color:var(--ink);font-weight:600}

.hero-meta{
  display:flex;flex-wrap:wrap;gap:14px 28px;
  padding-top:24px;border-top:1px dashed var(--line-mute);
  font-size:.92rem;
}
.hero-meta span{display:inline-flex;align-items:center;gap:8px;color:var(--ink);font-weight:500}
.hero-meta svg{color:var(--blue);flex-shrink:0}

/* ============= LEADCONNECTOR FORM CARD ============= */
.form-card{
  position:relative;background:#fff;
  border:1px solid var(--line);border-radius:var(--r-xl);
  box-shadow:var(--shadow-3);
  padding:0;
  isolation:isolate;
}
.form-card::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;
  padding:1px;background:linear-gradient(180deg, var(--blue) 0%, transparent 60%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  pointer-events:none;
}
.form-tag{
  position:absolute;top:18px;left:30px;z-index:2;
  display:inline-flex;align-items:center;gap:6px;
  background:var(--blue-soft);color:var(--blue);
  padding:5px 12px;border-radius:999px;
  font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;
}
.form-tag::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--blue);
  box-shadow:0 0 0 0 rgba(2,156,215,.6);
  animation:pulse 2s var(--ease) infinite;
}
.form-head{padding:54px 30px 4px}
.form-head h2{font-size:1.45rem;letter-spacing:-.025em;margin:0 0 4px}
.form-help{font-size:.92rem;color:var(--muted);margin:0 0 4px}
.form-iframe-wrap{
  position:relative;padding:0 0 18px;
}
.form-iframe-wrap iframe{
  width:100%;
  height:380px;        /* initial height — LeadConnector script resizes after load */
  display:block;
  border:0;
}

/* ============= SHOWCASE STRIP ============= */
.showcase{
  position:relative;overflow:hidden;
  background:var(--ink);color:#fff;
  padding-block:clamp(72px, 9vw, 120px);
}
.showcase-bg{
  position:absolute;inset:0;
  background-image:url('https://images.unsplash.com/photo-1742774101928-f7e92a471c1b?fm=jpg&q=80&w=2000&auto=format&fit=crop');
  background-size:cover;background-position:center;
  opacity:.5;
}
.showcase::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(700px 400px at 30% 50%, rgba(11,26,43,.7), rgba(11,26,43,.92)),
    linear-gradient(180deg, var(--ink) 0%, rgba(11,26,43,.85) 100%);
}
.showcase-inner{position:relative;z-index:2}
.showcase h2{
  color:#fff;font-size:clamp(2.25rem, 4.5vw, 3.75rem);
  letter-spacing:-.04em;line-height:1.05;margin:0 0 18px;
  max-width:18ch;
}
.showcase h2 em{font-style:italic;font-weight:500;color:var(--blue-bright)}
.showcase-lede{
  font-size:1.0625rem;color:#B8C5D6;line-height:1.65;
  max-width:50ch;margin:0 0 48px;
}
.showcase-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid rgba(255,255,255,.12);
  padding-top:36px;
}
.showcase-stat{padding:0 28px;border-right:1px solid rgba(255,255,255,.1)}
.showcase-stat:first-child{padding-left:0}
.showcase-stat:last-child{border-right:none;padding-right:0}
.showcase-stat strong{
  display:block;font-family:'Space Grotesk',sans-serif;
  font-size:clamp(2rem, 3.6vw, 2.85rem);font-weight:700;color:#fff;
  letter-spacing:-.04em;line-height:1;margin-bottom:8px;
}
.showcase-stat strong .unit{font-size:.55em;color:var(--blue-bright);font-weight:600;margin-left:2px}
.showcase-stat span{
  font-size:.78rem;color:#8FA0B6;letter-spacing:.06em;
  text-transform:uppercase;font-weight:500;
}

/* ============= INTRO ============= */
.intro-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:72px;align-items:center}
.intro-copy h2{margin-bottom:24px;max-width:18ch}
.intro-copy p{font-size:1.0625rem;line-height:1.7;color:var(--text);max-width:54ch}
.pull-quote{
  position:relative;margin:36px 0 0;padding:0 0 0 28px;
  border-left:3px solid var(--blue);
  font-family:'Space Grotesk',sans-serif;font-style:italic;
  font-size:1.25rem;line-height:1.45;color:var(--ink);
  font-weight:500;letter-spacing:-.012em;
  max-width:42ch;
}
.intro-visual{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  aspect-ratio:4/5;background:var(--off);
  box-shadow:var(--shadow-2);
}
.intro-visual img{width:100%;height:100%;object-fit:cover}
.intro-visual::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(11,26,43,.45) 100%);
}
.intro-tag{
  position:absolute;left:20px;bottom:20px;z-index:2;
  background:rgba(255,255,255,.95);backdrop-filter:blur(8px);
  padding:10px 14px;border-radius:10px;
  font-size:.82rem;font-weight:600;color:var(--ink);
  display:flex;align-items:center;gap:8px;
}
.intro-tag .pin{
  width:8px;height:8px;border-radius:50%;background:var(--blue);
  box-shadow:0 0 0 4px rgba(2,156,215,.2);
}

/* ============= FEATURES ============= */
.features-head{margin-bottom:64px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end}
.features-head h2{margin:0;max-width:16ch}
.features-head p{margin:0;color:var(--text);max-width:48ch;font-size:1.0625rem;line-height:1.65}

.fct-list{display:grid;gap:0}
.fct{
  display:grid;grid-template-columns:80px 1.4fr 1fr;gap:32px;
  padding:36px 0;border-top:1px solid var(--line);
  align-items:start;
  transition:background .25s var(--ease);
  position:relative;
}
.fct:last-child{border-bottom:1px solid var(--line)}
.fct::before{
  content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);
  width:3px;height:60%;background:var(--blue);
  transition:transform .3s var(--ease);
  transform-origin:center;
}
.fct:hover::before{transform:translateY(-50%) scaleY(1)}
.fct:hover{padding-left:18px}
.fct-num{
  font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:1.05rem;color:var(--blue);letter-spacing:.08em;
}
.fct-title{
  font-family:'Space Grotesk',sans-serif;font-weight:600;
  font-size:1.55rem;color:var(--ink);line-height:1.15;letter-spacing:-.025em;
  margin:0;
}
.fct-body{font-size:1rem;color:var(--text);line-height:1.65;margin:0}
.fct-body a{color:var(--blue);font-weight:500;border-bottom:1px solid currentColor}

/* ============= PLANS ============= */
.plans-head{display:grid;grid-template-columns:1fr 1fr 240px;align-items:end;gap:32px;margin-bottom:48px}
.plans-head h2{margin:0;max-width:18ch}
.plans-head p{margin:0;color:var(--text);max-width:46ch}
.plans-head-visual{
  width:100%;height:140px;border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow-1);position:relative;
}
.plans-head-visual img{width:100%;height:100%;object-fit:cover}
.plans-head-visual::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, transparent 30%, rgba(2,156,215,.18) 100%);
}

.plans-rail{
  display:grid;grid-template-columns:repeat(5,1fr);gap:14px;
}
.plan{
  position:relative;background:#fff;
  border:1px solid var(--line);border-radius:var(--r-lg);
  padding:26px 22px;
  display:flex;flex-direction:column;gap:16px;
  transition:transform .2s var(--ease),box-shadow .25s var(--ease),border-color .2s var(--ease);
}
.plan:hover{transform:translateY(-4px);box-shadow:var(--shadow-2);border-color:var(--blue)}
.plan-name{
  font-family:'Space Grotesk',sans-serif;font-weight:600;
  font-size:1.05rem;color:var(--ink);letter-spacing:-.015em;
}
.plan-mbps{
  font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:2.1rem;color:var(--ink);letter-spacing:-.04em;line-height:1;
}
.plan-mbps .u{font-size:.5em;color:var(--muted);font-weight:500;letter-spacing:.04em;margin-left:3px}
.plan-meter{
  width:100%;height:5px;background:var(--line-soft);border-radius:99px;overflow:hidden;
}
.plan-meter > i{
  display:block;height:100%;background:linear-gradient(90deg, var(--blue), var(--blue-deep));
  border-radius:inherit;
  transform-origin:left;
  transform:scaleX(0);
  transition:transform 1.4s var(--ease);
}
.plan.in .plan-meter > i{transform:scaleX(var(--w,.5))}
.plan-symm{
  font-size:.82rem;color:var(--muted);font-weight:500;
  display:flex;align-items:center;gap:6px;
}
.plan-price{
  font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:1.5rem;color:var(--blue);letter-spacing:-.025em;
  border-top:1px solid var(--line-soft);padding-top:16px;
}
.plan-price .per{font-size:.7em;color:var(--muted);font-weight:500;letter-spacing:0}

.plans-note{margin-top:24px;font-size:.85rem;color:var(--muted);max-width:80ch}

/* ============= COMPARISON ============= */
.vs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px;align-items:start}
.vs-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:32px 28px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);
}
.vs-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}
.vs-card.is-att{
  background:linear-gradient(180deg, var(--ink) 0%, #15293F 100%);
  color:#C5CFDC;border-color:transparent;
  box-shadow:var(--shadow-3);
  position:relative;overflow:hidden;
}
.vs-card.is-att::before{
  content:"";position:absolute;top:-50%;right:-30%;width:300px;height:300px;
  background:radial-gradient(circle, rgba(2,156,215,.32) 0%, transparent 65%);
  pointer-events:none;
}
.vs-card.is-att .vs-name,.vs-card.is-att .vs-title{color:#fff}
.vs-card.is-att .vs-tag{background:var(--blue);color:#fff}
.vs-card.is-att li{border-color:rgba(255,255,255,.1)}
.vs-card.is-att .vs-yes{color:var(--blue);background:rgba(2,156,215,.16)}
.vs-name{
  font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:1.6rem;color:var(--ink);letter-spacing:-.03em;line-height:1;
  margin-bottom:6px;
}
.vs-tag{
  display:inline-block;padding:4px 10px;border-radius:999px;
  font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  background:var(--off);color:var(--muted);margin-bottom:22px;
}
.vs-card ul{list-style:none;margin:0;padding:0}
.vs-card li{
  display:flex;align-items:flex-start;gap:14px;
  padding:14px 0;border-top:1px solid var(--line-soft);
  font-size:.95rem;
}
.vs-card li:first-child{border-top:none;padding-top:0}
.vs-feat-name{flex:1;color:inherit;font-weight:500;font-size:.85rem;letter-spacing:.04em;text-transform:uppercase}
.vs-card.is-att .vs-feat-name{color:#9AAAC0}
.vs-feat-val{font-family:'Space Grotesk',sans-serif;font-weight:600;color:var(--ink);text-align:right;font-size:1rem;letter-spacing:-.01em}
.vs-card.is-att .vs-feat-val{color:#fff}
.vs-yes,.vs-no{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 10px;border-radius:999px;
  font-size:.78rem;font-weight:600;
}
.vs-yes{background:rgba(2,156,215,.12);color:var(--blue)}
.vs-no{background:rgba(122,134,153,.1);color:#7A8699}
.vs-foot{margin-top:36px;font-size:1rem;color:var(--text);max-width:72ch;line-height:1.65}

/* ============= NEIGHBORHOODS ============= */
.hood-head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:48px}
.hood-head h2{margin:0;max-width:18ch}
.hood-head p{margin:0;color:var(--text);max-width:48ch;font-size:1.0625rem;line-height:1.65}

.hood-layout{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start}
.hood-list{margin:0;padding:0;list-style:none}
.hood-row{
  display:grid;grid-template-columns:36px 1fr;column-gap:24px;row-gap:6px;
  padding:24px 8px;border-top:1px solid var(--line);
  transition:background .25s var(--ease),padding .25s var(--ease);
}
.hood-row:last-child{border-bottom:1px solid var(--line)}
.hood-row:hover{background:rgba(2,156,215,.04);padding-left:18px;padding-right:18px}
.hood-idx{
  font-family:'Space Grotesk',sans-serif;font-weight:600;
  font-size:.92rem;color:var(--blue);letter-spacing:.05em;
  align-self:start;padding-top:4px;
}
.hood-name{
  font-family:'Space Grotesk',sans-serif;font-weight:600;
  font-size:1.35rem;color:var(--ink);letter-spacing:-.025em;line-height:1.15;
}
.hood-desc{
  grid-column:2;font-size:.95rem;color:var(--text);line-height:1.55;
}

.hood-visual{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  aspect-ratio:4/5;background:var(--off);box-shadow:var(--shadow-2);
  position:sticky;top:96px;
}
.hood-visual img{width:100%;height:100%;object-fit:cover}
.hood-visual::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(11,26,43,.55) 100%);
}
.hood-visual-meta{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:24px;color:#fff;
}
.hood-visual-meta strong{
  display:block;font-family:'Space Grotesk',sans-serif;
  font-size:1.6rem;font-weight:700;letter-spacing:-.03em;line-height:1.1;margin-bottom:6px;
}
.hood-visual-meta span{font-size:.88rem;color:#C5CFDC;letter-spacing:.04em}

.hood-foot{margin-top:36px;font-size:.97rem;color:var(--text)}
.hood-foot a{font-weight:600;border-bottom:1px solid currentColor}

/* ============= FAQ ============= */
.faq-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:start}
.faq-aside h2{margin:0 0 16px}
.faq-aside p{color:var(--text);font-size:1rem;line-height:1.7;max-width:34ch}
.faq-aside-visual{
  margin-top:32px;border-radius:var(--r);overflow:hidden;
  aspect-ratio:4/3;box-shadow:var(--shadow-1);
  position:relative;max-width:340px;
}
.faq-aside-visual img{width:100%;height:100%;object-fit:cover}
.faq-aside-visual::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(11,26,43,.45) 100%);
}
.faq-aside-visual span{
  position:absolute;left:14px;bottom:14px;z-index:2;
  font-family:'Space Grotesk',sans-serif;font-weight:600;
  color:#fff;font-size:.9rem;letter-spacing:-.01em;
}
.faq-list{display:flex;flex-direction:column;gap:10px}
.qa{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;
  transition:border-color .2s var(--ease),box-shadow .25s var(--ease);
}
.qa[open]{border-color:#C9D7E2;box-shadow:var(--shadow-1)}
.qa summary{
  list-style:none;cursor:pointer;
  padding:22px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  font-family:'Space Grotesk',sans-serif;font-weight:600;
  color:var(--ink);font-size:1.05rem;letter-spacing:-.012em;
  transition:color .2s var(--ease);
}
.qa summary::-webkit-details-marker{display:none}
.qa summary:hover{color:var(--blue)}
.qa-icon{
  flex-shrink:0;width:30px;height:30px;border-radius:50%;
  background:var(--blue-soft);color:var(--blue);
  display:flex;align-items:center;justify-content:center;
  position:relative;
  transition:transform .25s var(--ease),background .2s var(--ease);
}
.qa[open] .qa-icon{transform:rotate(45deg);background:var(--blue);color:#fff}
.qa-icon::before{content:"";position:absolute;width:12px;height:2px;background:currentColor}
.qa-icon::after{content:"";position:absolute;width:2px;height:12px;background:currentColor}
.qa-body{padding:0 24px 22px;color:var(--text);font-size:.97rem;line-height:1.7}

/* ============= CTA ============= */
.cta-band{
  position:relative;overflow:hidden;
  background:var(--ink);color:#C5CFDC;
  padding-block:clamp(80px,9vw,128px);
}
.cta-bg{
  position:absolute;inset:0;
  background-image:url('https://images.unsplash.com/photo-1606778303077-3780ea8d5420?fm=jpg&q=80&w=2000&auto=format&fit=crop');
  background-size:cover;background-position:center;
  opacity:.25;
  filter:saturate(1.2);
}
.cta-band::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(900px 500px at 80% 40%, rgba(2,156,215,.22), transparent 60%),
    linear-gradient(180deg, rgba(11,26,43,.92) 0%, rgba(11,26,43,.95) 100%);
}
.cta-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr;gap:48px;align-items:center;text-align:center;max-width:780px;margin-inline:auto}
.cta-inner h2{
  color:#fff;margin-bottom:18px;
  letter-spacing:-.04em;font-size:clamp(2.25rem, 4vw, 3.5rem);line-height:1.05;
}
.cta-inner p{color:#9DAAC0;font-size:1.125rem;margin:0 auto 36px;max-width:48ch;line-height:1.6}
.cta-actions{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;align-items:center}
.cta-band .btn-cta{padding:14px 28px;font-size:1rem}
.cta-secondary{
  display:inline-flex;align-items:center;gap:8px;
  color:#fff;font-weight:500;font-size:.97rem;
  border-bottom:1px solid rgba(255,255,255,.18);padding-bottom:2px;
  transition:border-color .2s var(--ease);
}
.cta-secondary:hover{color:#fff;border-color:#fff}

/* ============= FOOTER ============= */
.footer{background:#070F1A;color:#8B96AA;padding-block:56px 28px}
.footer-grid{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.08);
}
.footer h4{color:#fff;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px;font-weight:600}
.footer ul{list-style:none;padding:0;margin:0}
.footer li{margin-bottom:10px}
.footer a{color:#8B96AA;font-size:.93rem}
.footer a:hover{color:#fff}
.footer-brand p{font-size:.93rem;line-height:1.7;max-width:36ch;margin-bottom:0}
.copyright{padding-top:24px;font-size:.85rem;color:#5C6679;display:flex;justify-content:flex-start}

/* ============= REVEAL ============= */
@media (prefers-reduced-motion: no-preference){
  .reveal{opacity:0;transform:translateY(14px);animation:reveal .8s var(--ease) forwards}
  .reveal.d1{animation-delay:.05s}
  .reveal.d2{animation-delay:.15s}
  .reveal.d3{animation-delay:.25s}
  .reveal.d4{animation-delay:.35s}
  @keyframes reveal{to{opacity:1;transform:translateY(0)}}
}

/* ============= RESPONSIVE ============= */
@media (max-width: 1080px){
  .showcase-stats{grid-template-columns:repeat(2,1fr);row-gap:32px}
  .showcase-stat:nth-child(2){border-right:none}
  .showcase-stat:nth-child(3){padding-left:0}
  .plans-rail{grid-template-columns:repeat(3,1fr)}
}
@media (max-width: 960px){
  .hero-grid,.intro-grid,.faq-grid,.features-head,.hood-head,.plans-head,.hood-layout{
    grid-template-columns:1fr;gap:40px;
  }
  .plans-head-visual{height:160px;max-width:380px}
  .vs-grid{grid-template-columns:1fr;gap:14px}
  .vs-card.is-att{order:-1}
  .footer-grid{grid-template-columns:1.5fr 1fr 1fr;gap:32px}
  .fct{grid-template-columns:64px 1fr;gap:18px}
  .fct-body{grid-column:2}
  .hood-visual{position:relative;top:auto;aspect-ratio:16/10}
  .hero-fiber{display:none}
}
@media (max-width: 720px){
  .primary-nav{
    position:fixed;top:74px;left:0;right:0;bottom:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:#fff;padding:20px;
    transform:translateY(-100%);visibility:hidden;
    transition:transform .3s var(--ease),visibility .3s;
    border-top:1px solid var(--line-soft);overflow-y:auto;
  }
  .primary-nav.open{transform:translateY(0);visibility:visible}
  .primary-nav a,.primary-nav button{padding:14px 12px;border-radius:8px;justify-content:flex-start;font-size:1rem}
  .nav-cta{margin:8px 0 0}
  .hamburger{display:inline-flex}
  .cities-menu{position:static;display:grid;box-shadow:none;border:1px solid var(--line);min-width:auto;margin-top:6px}
  .cities[aria-expanded="false"] .cities-menu{display:none}

  .form-head{padding:48px 24px 4px}
  .form-iframe-wrap{padding:0 0 14px}
  .showcase-stats{grid-template-columns:1fr;row-gap:24px}
  .showcase-stat{padding:0;border-right:none;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:16px}
  .showcase-stat:last-child{border-bottom:none;padding-bottom:0}
  .plans-rail{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 480px){
  .footer-grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
  html{scroll-behavior:auto}
}

/* ============================================================
   v3.1 ADDITIONS — Pensacola benefits list & pill-grid neighborhoods
   ============================================================ */

/* ============= BENEFITS BLOCK (intro inline benefits list) ============= */
.benefits-block{
  margin-top:64px;
  padding-top:56px;
  border-top:1px solid var(--line);
}
.benefits-title{
  font-family:'Space Grotesk',sans-serif;font-weight:600;
  font-size:1.5rem;color:var(--ink);letter-spacing:-.02em;
  margin:0 0 32px;
}
.benefits-list{
  list-style:none;margin:0;padding:0;
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:24px 40px;
}
.benefits-list > li{
  display:grid;grid-template-columns:44px 1fr;gap:18px;align-items:start;
  padding:8px 0;
}
.benefit-icon{
  width:44px;height:44px;border-radius:10px;
  background:var(--blue-soft);color:var(--blue);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.benefits-list > li > div{display:flex;flex-direction:column;gap:4px}
.benefits-list strong{
  font-family:'Space Grotesk',sans-serif;font-weight:600;
  font-size:1.05rem;color:var(--ink);letter-spacing:-.015em;
}
.benefits-list span{font-size:.95rem;color:var(--text);line-height:1.55}

/* ============= NEIGHBORHOOD PILL GRID ============= */
.hood-pill-grid{
  display:flex;flex-wrap:wrap;gap:12px;
  margin-top:8px;
}
.hood-pill{
  display:inline-flex;align-items:center;
  padding:11px 18px;border-radius:999px;
  background:#fff;border:1px solid var(--line);
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:.97rem;color:var(--ink);letter-spacing:-.005em;
  transition:transform .15s var(--ease),background .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease);
  cursor:default;
}
.hood-pill:hover{
  background:var(--blue);border-color:var(--blue);color:#fff;
  transform:translateY(-1px);
}

/* ============= CTA TERTIARY LINK ROW ============= */
.cta-tertiary{
  margin-top:24px !important;
  font-size:.93rem !important;color:#9DAAC0 !important;
}
.cta-tertiary a{
  color:#fff !important;
  border-bottom:1px solid rgba(255,255,255,.18);
  padding-bottom:1px;
  margin:0 4px;
  transition:border-color .2s var(--ease);
}
.cta-tertiary a:hover{border-color:#fff}

/* ============= RESPONSIVE — benefits + pills ============= */
@media (max-width: 720px){
  .benefits-list{grid-template-columns:1fr;gap:18px}
  .hood-pill-grid{gap:8px}
  .hood-pill{padding:9px 14px;font-size:.92rem}
}


/* ============================================================
   v3.2 ADDITIONS — Directory page styles (states index, cities-list)
   ============================================================ */

/* ============= DIRECTORY HERO ============= */
.dir-hero{
  position:relative;overflow:hidden;
  padding-block:clamp(72px,9vw,128px) clamp(56px,8vw,96px);
  background:
    radial-gradient(1100px 540px at 88% 0%, rgba(2,156,215,.16), transparent 60%),
    radial-gradient(800px 420px at -8% 80%, rgba(2,156,215,.08), transparent 65%),
    var(--bg);
}
.dir-hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(to right, rgba(11,26,43,.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(11,26,43,.05) 1px, transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 90% 70% at 50% 30%, #000 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 90% 70% at 50% 30%, #000 30%, transparent 80%);
  opacity:.55;
}
.dir-hero-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:center;
}
.dir-hero h1{
  font-size:clamp(2.5rem, 5.5vw, 4.5rem);
  letter-spacing:-.04em;line-height:1.02;margin-bottom:24px;
}
.dir-hero h1 em{
  font-style:normal;font-weight:700;
  background:linear-gradient(180deg, var(--blue) 0%, var(--blue-deep) 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.dir-hero-sub{
  font-size:1.1875rem;line-height:1.55;color:var(--text);
  max-width:50ch;margin-bottom:36px;
}
.dir-hero-meta{
  display:flex;flex-wrap:wrap;gap:16px 28px;
  padding-top:24px;border-top:1px dashed var(--line-mute);
  font-size:.92rem;
}
.dir-hero-meta div{display:inline-flex;align-items:center;gap:8px;color:var(--ink);font-weight:500}
.dir-hero-meta strong{
  font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:1.05rem;color:var(--blue);letter-spacing:-.02em;
}

.dir-hero-visual{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  aspect-ratio:1/1;background:var(--off);
  box-shadow:var(--shadow-2);
}
.dir-hero-visual img{width:100%;height:100%;object-fit:cover}
.dir-hero-visual::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, transparent 50%, rgba(11,26,43,.45) 100%);
}
.dir-hero-tag{
  position:absolute;left:20px;bottom:20px;z-index:2;
  background:rgba(255,255,255,.95);backdrop-filter:blur(8px);
  padding:10px 14px;border-radius:10px;
  font-size:.82rem;font-weight:600;color:var(--ink);
  display:flex;align-items:center;gap:8px;
}
.dir-hero-tag .pin{
  width:8px;height:8px;border-radius:50%;background:var(--blue);
  box-shadow:0 0 0 4px rgba(2,156,215,.2);
}

/* ============= STATE/CITY CARD GRID ============= */
.dir-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));
  gap:20px;
  margin-top:48px;
}

.dir-card{
  position:relative;display:flex;flex-direction:column;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;
  text-decoration:none;color:inherit;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .2s var(--ease);
}
.dir-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-2);
  border-color:var(--blue);
  color:inherit;
}
.dir-card:hover .dir-card-arrow{
  background:var(--blue);color:#fff;border-color:var(--blue);
  transform:translate(2px,-2px);
}

.dir-card-thumb{
  position:relative;width:100%;
  aspect-ratio:16/9;
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-3) 100%);
  overflow:hidden;
}
.dir-card-thumb img{width:100%;height:100%;object-fit:cover;opacity:.65}
.dir-card-thumb::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(400px 200px at 50% 100%, rgba(2,156,215,.4) 0%, transparent 65%);
}
.dir-card-stat{
  position:absolute;left:18px;bottom:18px;z-index:2;
  display:inline-flex;align-items:baseline;gap:6px;
  font-family:'Space Grotesk',sans-serif;color:#fff;
}
.dir-card-stat strong{font-size:1.6rem;font-weight:700;letter-spacing:-.02em;line-height:1}
.dir-card-stat span{font-size:.78rem;color:rgba(255,255,255,.8);letter-spacing:.06em;text-transform:uppercase;font-weight:500}

.dir-card-body{padding:26px 26px 22px;flex:1;display:flex;flex-direction:column;gap:10px}
.dir-card-region{
  font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--blue);
}
.dir-card-name{
  font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:1.6rem;color:var(--ink);letter-spacing:-.025em;line-height:1.1;
  margin:0;
}
.dir-card-desc{font-size:.95rem;color:var(--text);line-height:1.55;margin:0}

.dir-card-foot{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 26px;border-top:1px solid var(--line-soft);
  font-size:.88rem;color:var(--muted);
}
.dir-card-foot strong{
  font-family:'Space Grotesk',sans-serif;font-weight:600;
  color:var(--ink);font-size:.95rem;letter-spacing:-.005em;
}
.dir-card-arrow{
  width:34px;height:34px;border-radius:50%;
  border:1px solid var(--line);color:var(--muted);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease),transform .2s var(--ease);
}

/* ============= TRUST STRIP ============= */
.trust-strip{
  background:var(--off);
  padding-block:36px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.trust-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;align-items:center;
}
.trust-item{
  display:flex;align-items:center;gap:14px;
  font-size:.95rem;color:var(--ink);font-weight:500;
}
.trust-item-icon{
  width:42px;height:42px;border-radius:10px;
  background:rgba(2,156,215,.1);color:var(--blue);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.trust-item span{display:block;font-size:.78rem;color:var(--muted);font-weight:400;letter-spacing:.04em;text-transform:uppercase;margin-bottom:2px}
.trust-item strong{display:block;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.0625rem;letter-spacing:-.015em;line-height:1.15}

/* ============= LEAD-IN COPY ============= */
.dir-leadin{
  max-width:780px;margin:0 auto;text-align:center;
  padding-block:clamp(60px,7vw,96px);
}
.dir-leadin h2{
  font-size:clamp(1.75rem,3.5vw,2.5rem);
  margin:0 auto 20px;max-width:24ch;line-height:1.1;
}
.dir-leadin p{
  font-size:1.0625rem;line-height:1.7;color:var(--text);
  max-width:62ch;margin:0 auto 16px;
}
.dir-leadin p:last-child{margin-bottom:0}

/* ============= RESPONSIVE — directory pages ============= */
@media (max-width: 960px){
  .dir-hero-grid{grid-template-columns:1fr;gap:40px}
  .dir-hero-visual{max-width:520px;margin-inline:auto}
  .trust-grid{grid-template-columns:repeat(2,1fr);gap:24px}
}
@media (max-width: 720px){
  .dir-grid{grid-template-columns:1fr;gap:16px}
  .trust-grid{grid-template-columns:1fr;gap:18px}
  .dir-card-name{font-size:1.4rem}
}


/* ============================================================
   v3.3 — MEGA MENU (header dropdown, 3-pane city directory)
   ============================================================ */

.yio-mega-wrap{position:relative}
.yio-mega-radio{position:absolute;width:0;height:0;opacity:0;pointer-events:none}

.yio-mega-trigger{
  appearance:none;background:none;border:0;
  font-family:inherit;font-size:.95rem;font-weight:500;color:var(--ink);
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 0;cursor:pointer;
  transition:color .15s var(--ease);
}
.yio-mega-trigger svg{transition:transform .2s var(--ease);opacity:.6}
.yio-mega-trigger:hover{color:var(--blue)}
.yio-mega-trigger[aria-expanded="true"] svg{transform:rotate(180deg)}

.yio-mega{
  position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(-8px);
  width:min(960px, calc(100vw - 32px));
  background:#fff;
  border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:0 24px 60px -12px rgba(11,26,43,.18), 0 0 0 1px rgba(11,26,43,.04);
  opacity:0;pointer-events:none;visibility:hidden;
  transition:opacity .2s var(--ease),transform .2s var(--ease),visibility 0s .2s;
  z-index:9999;
  overflow:hidden;
}
.yio-mega.is-open{
  opacity:1;pointer-events:auto;visibility:visible;
  transform:translateX(-50%) translateY(0);
  transition:opacity .25s var(--ease),transform .25s var(--ease),visibility 0s 0s;
}

.yio-mega-inner{
  display:grid;grid-template-columns:280px 1fr;
  min-height:420px;
}

/* ============= LEFT PANE — STATES + CITIES ============= */
.yio-mega-states{
  background:var(--off);
  border-right:1px solid var(--line);
  padding:24px 8px 24px 24px;
  overflow-y:auto;max-height:520px;
}
.yio-mega-state{margin-bottom:24px}
.yio-mega-state:last-child{margin-bottom:0}
.yio-mega-state-name{
  display:block;
  font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);
  margin-bottom:8px;padding:0 14px;
}
.yio-mega-state ul{list-style:none;margin:0;padding:0}

.yio-mega-city-link{
  display:flex;align-items:center;justify-content:space-between;
  padding:9px 14px;border-radius:8px;
  font-size:.95rem;font-weight:500;color:var(--ink);
  cursor:pointer;
  transition:background .15s var(--ease),color .15s var(--ease);
}
.yio-mega-city-link svg{opacity:0;transition:opacity .15s var(--ease),transform .15s var(--ease)}
.yio-mega-city-link:hover{background:rgba(2,156,215,.08);color:var(--blue)}
.yio-mega-city-link:hover svg{opacity:.5}

/* ============= RIGHT PANE — CITY CONTENT ============= */
.yio-mega-content{
  position:relative;
  padding:36px 36px 32px;
}
.yio-mega-city-pane{display:none;animation:yio-mega-fade .2s var(--ease)}
.yio-mega-city-pane.is-active{display:block}
@keyframes yio-mega-fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* CSS-driven city selection: when a radio is checked, show the matching pane */

.yio-mega-city-head{
  display:flex;flex-direction:column-reverse;gap:2px;
  padding-bottom:20px;margin-bottom:24px;
  border-bottom:1px solid var(--line);
}
.yio-mega-city-name{
  font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:1.6rem;color:var(--blue);letter-spacing:-.02em;line-height:1;
  margin:0;
}
.yio-mega-city-state{
  font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);
}

.yio-mega-services{
  display:grid;grid-template-columns:repeat(2, 1fr);
  gap:6px 32px;
}
.yio-mega-service{
  display:flex;align-items:center;
  padding:10px 12px;border-radius:8px;
  font-size:.95rem;font-weight:500;color:var(--ink);
  text-decoration:none;
  transition:background .15s var(--ease),color .15s var(--ease),padding-left .15s var(--ease);
}
a.yio-mega-service:hover{
  background:rgba(2,156,215,.08);
  color:var(--blue);
  padding-left:16px;
}
.yio-mega-service.is-disabled{
  color:#B5BFCC;cursor:not-allowed;
}
.yio-mega-service.is-disabled::after{
  content:"Soon";
  margin-left:auto;
  font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);
  background:#fff;border:1px solid var(--line);
  padding:2px 7px;border-radius:999px;
}

/* ============= RESPONSIVE — mega menu ============= */
@media (max-width: 760px){
  .yio-mega{
    position:fixed;top:auto;bottom:0;left:0;right:0;transform:translateY(100%);
    width:100%;max-height:80vh;
    border-radius:var(--r-lg) var(--r-lg) 0 0;
  }
  .yio-mega.is-open{transform:translateY(0)}
  .yio-mega-inner{grid-template-columns:1fr;min-height:0;max-height:80vh;overflow-y:auto}
  .yio-mega-states{border-right:0;border-bottom:1px solid var(--line);padding:16px;max-height:none}
  .yio-mega-content{padding:24px}
  .yio-mega-services{grid-template-columns:1fr}
}


/* ============================================================
   v3.3 — MEGA MENU (Cities & services)
   ============================================================ */

.yio-mm{
  position:relative;
  display:inline-block;
  font-family:'Inter',sans-serif;
}

/* Trigger button — sits inline in the header nav */
.yio-mm-trigger{
  display:inline-flex;align-items:center;gap:6px;
  padding:0;background:none;border:0;cursor:pointer;
  font:inherit;color:var(--ink);font-size:.95rem;font-weight:500;
  letter-spacing:-.005em;
  transition:color .15s var(--ease);
}
.yio-mm-trigger:hover,
.yio-mm.is-open .yio-mm-trigger{color:var(--blue)}
.yio-mm-trigger svg{
  transition:transform .2s var(--ease);
  opacity:.7;
}
.yio-mm.is-open .yio-mm-trigger svg{transform:rotate(180deg)}

/* Panel — drops down from the trigger */
.yio-mm-panel{
  position:absolute;
  top:calc(100% + 18px);
  right:0;            /* aligns to right edge of trigger; tweak if your nav needs left-align */
  width:min(900px, calc(100vw - 32px));
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  box-shadow:0 24px 64px -12px rgba(11,26,43,.18), 0 8px 24px -8px rgba(11,26,43,.08);
  opacity:0;visibility:hidden;
  transform:translateY(-8px);
  transition:opacity .2s var(--ease), transform .2s var(--ease), visibility 0s .2s;
  z-index:1000;
}
.yio-mm.is-open .yio-mm-panel{
  opacity:1;visibility:visible;
  transform:translateY(0);
  transition:opacity .2s var(--ease), transform .2s var(--ease), visibility 0s 0s;
}

/* Inner grid */
.yio-mm-inner{
  display:grid;
  grid-template-columns:280px 1fr;
  min-height:380px;
}

/* LEFT — sidebar of cities grouped by state */
.yio-mm-sidebar{
  padding:20px 16px;
  border-right:1px solid var(--line-soft);
  background:var(--off);
  border-radius:14px 0 0 14px;
  max-height:520px;overflow-y:auto;
}
.yio-mm-state-group{margin-bottom:18px}
.yio-mm-state-group:last-child{margin-bottom:0}
.yio-mm-state-label{
  font-family:'Inter',sans-serif;
  font-size:.68rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);
  margin:0 0 6px;padding:0 12px;
}
.yio-mm-city-list{list-style:none;margin:0;padding:0}
.yio-mm-city-list li{margin:0}
.yio-mm-city{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;
  padding:9px 12px;
  background:none;border:0;cursor:pointer;
  font-family:'Inter',sans-serif;
  font-size:.92rem;font-weight:500;
  color:var(--ink);
  text-align:left;
  border-radius:6px;
  transition:background .15s var(--ease), color .15s var(--ease);
}
.yio-mm-city svg{opacity:.4;transition:opacity .15s var(--ease), transform .15s var(--ease)}
.yio-mm-city:hover{background:rgba(2,156,215,.08);color:var(--blue)}
.yio-mm-city:hover svg{opacity:.7;transform:translateX(2px)}
.yio-mm-city.is-active{
  background:var(--blue);color:#fff;
  font-weight:500;
}
.yio-mm-city.is-active svg{opacity:.9}

/* RIGHT — service grid for active city */
.yio-mm-detail{
  position:relative;
  padding:28px 32px;
}
.yio-mm-pane{display:none}
.yio-mm-pane.is-active{display:block}

.yio-mm-pane-head{
  display:flex;align-items:baseline;gap:14px;
  padding-bottom:18px;
  border-bottom:1px solid var(--line-soft);
  margin-bottom:20px;
}
.yio-mm-pane-head h3{
  font-family:'Space Grotesk',sans-serif;
  font-size:1.5rem;font-weight:700;
  color:var(--blue);
  letter-spacing:-.025em;line-height:1;
  margin:0;
}
.yio-mm-pane-state{
  font-size:.7rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);
}

.yio-mm-svc-grid{
  list-style:none;
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:2px 24px;
  margin:0 0 22px;padding:0;
}
.yio-mm-svc-grid li{margin:0}
.yio-mm-svc-grid a{
  display:block;
  padding:10px 0;
  font-size:.95rem;font-weight:500;
  color:var(--ink);text-decoration:none;
  border-bottom:1px solid transparent;
  transition:color .15s var(--ease), border-color .15s var(--ease);
}
.yio-mm-svc-grid a:hover{
  color:var(--blue);
  border-bottom-color:rgba(2,156,215,.4);
}

.yio-mm-pane-foot{
  margin:0;padding-top:16px;
  border-top:1px solid var(--line-soft);
  font-size:.88rem;
}
.yio-mm-pane-foot a{
  color:var(--blue);font-weight:500;text-decoration:none;
}
.yio-mm-pane-foot a:hover{text-decoration:underline}

/* Empty fallback (no states/cities yet) */
.yio-mm-empty .yio-mm-trigger{
  display:inline-flex;align-items:center;gap:6px;
  padding:0;text-decoration:none;
  font:inherit;color:var(--ink);font-size:.95rem;font-weight:500;
}

/* ============= RESPONSIVE — mega menu ============= */
@media (max-width: 760px){
  .yio-mm-panel{
    position:fixed;top:auto;bottom:0;left:0;right:0;
    width:100%;
    max-height:80vh;
    border-radius:14px 14px 0 0;
    transform:translateY(100%);
  }
  .yio-mm.is-open .yio-mm-panel{transform:translateY(0)}
  .yio-mm-inner{
    grid-template-columns:1fr;
    min-height:0;max-height:80vh;
    overflow-y:auto;
  }
  .yio-mm-sidebar{
    border-right:0;border-bottom:1px solid var(--line-soft);
    border-radius:14px 14px 0 0;
    max-height:none;
  }
  .yio-mm-svc-grid{grid-template-columns:1fr}
  .yio-mm-detail{padding:20px 24px}
}


/* ============================================================
   v3.4 — CITY HUB: services grid (svc-card)
   ============================================================ */
.svc-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:16px;
  margin-top:48px;
}
.svc-card{
  position:relative;display:flex;flex-direction:column;gap:8px;
  padding:24px 22px 22px;
  background:#fff;border:1px solid var(--line);border-radius:12px;
  text-decoration:none;color:inherit;
  transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease);
}
.svc-card:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 24px -8px rgba(11,26,43,.1);
  border-color:var(--blue);
  color:inherit;
}
.svc-card:hover .svc-card-arrow{
  background:var(--blue);color:#fff;border-color:var(--blue);
  transform:translate(2px,-2px);
}
.svc-card--soon{
  opacity:.55;cursor:default;
  background:var(--off);border-style:dashed;
}
.svc-card-tag{
  display:inline-flex;align-items:center;
  align-self:flex-start;
  padding:3px 10px;border-radius:999px;
  font-size:.66rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:4px;
}
.svc-card-tag--live{background:rgba(2,156,215,.1);color:var(--blue)}
.svc-card-tag--soon{background:rgba(11,26,43,.06);color:var(--muted)}
.svc-card-name{
  font-family:'Space Grotesk',sans-serif;font-weight:600;
  font-size:1.12rem;color:var(--ink);letter-spacing:-.02em;
  margin:0;line-height:1.2;
}
.svc-card-desc{
  font-size:.91rem;color:var(--text);line-height:1.5;
  margin:0;
}
.svc-card-arrow{
  position:absolute;top:22px;right:22px;
  width:30px;height:30px;border-radius:50%;
  border:1px solid var(--line);color:var(--muted);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease),transform .2s var(--ease);
}

@media (max-width: 720px){
  .svc-grid{grid-template-columns:1fr;gap:12px}
}

/* ============================================================
   v4 POLISH PATCHES (delivery-10) — appended for clean override
   ============================================================ */

/* 1. Intro grids: top-align text with images (no more giant gaps when
   image is taller than text content) */
.intro-grid { align-items: start; }
.intro-copy h2 { margin-bottom: 16px; }

/* 2. SVGs inside icon containers must be block to defeat
   inline/baseline rendering — fixes visual off-center bug */
.trust-item-icon svg,
.benefit-icon svg,
.svc-card-arrow svg,
.qa-icon svg { display: block; }

/* 3. Bigger, more confident trust strip icons */
.trust-item-icon {
  width: 48px; height: 48px; border-radius: 12px;
  background: linear-gradient(135deg, rgba(2,156,215,.12), rgba(2,156,215,.06));
}
.trust-item { gap: 16px; }
.trust-item span { font-size: .72rem; letter-spacing: .08em; }
.trust-item strong { font-size: 1.05rem; }

/* 4. Service card refinements */
.svc-card { padding: 26px 24px 24px; gap: 10px; }
.svc-card-name { font-size: 1.15rem; }
.svc-card-desc { font-size: .94rem; line-height: 1.55; color: #475569; }
.svc-card-tag { font-size: .68rem; letter-spacing: .12em; }

/* 5. Tighter sec-mark to next-element spacing */
.sec-mark { margin-bottom: 40px; }

/* 6. Hood pill polish (used only when relevant) */
.hood-pill { padding: 10px 18px; font-size: .92rem; }

/* 7. FAQ accordion polish — softer borders, smoother type */
.qa { border-radius: 14px; }
.qa summary { padding: 22px 26px; font-size: 1.02rem; }
.qa-body { padding: 0 26px 22px; font-size: .96rem; line-height: 1.7; }

/* 8. CTA tertiary line gets a touch more breathing room */
.cta-tertiary { line-height: 1.7 !important; }

/* ============================================================
   v4.2 POLISH PATCHES — bigger icons, refined card depth,
   image strip support, FAQ open-state styling
   ============================================================ */

/* Trust strip — icons fill more confidently, container has depth */
.trust-item-icon {
  display: grid !important;
  place-items: center !important;
  width: 52px !important; height: 52px !important;
  border-radius: 14px !important;
  background: linear-gradient(180deg, rgba(2,156,215,.16) 0%, rgba(2,156,215,.06) 100%) !important;
  border: 1px solid rgba(2,156,215,.18) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7), 0 1px 2px rgba(11,26,43,.04) !important;
  color: #0277A8 !important;
  line-height: 1 !important;
  padding: 0 !important;
}
.trust-item-icon svg {
  width: 24px !important; height: 24px !important;
  display: block !important;
  stroke-width: 1.85 !important;
  grid-area: 1 / 1 !important;
  margin: 0 !important;
}
.trust-item { gap: 18px !important; }
.trust-grid { gap: 28px !important; }

/* Service card — subtle accent + softer interaction */
.svc-card {
  border-radius: 16px;
  border: 1px solid rgba(11,26,43,.07);
  box-shadow: 0 1px 2px rgba(11,26,43,.02), 0 0 0 1px rgba(255,255,255,.5) inset;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.svc-card:hover {
  transform: translateY(-3px);
  border-color: rgba(2,156,215,.25);
  box-shadow: 0 12px 32px rgba(11,26,43,.08), 0 0 0 1px rgba(255,255,255,.5) inset;
}
.svc-card-tag--live {
  background: rgba(2,156,215,.1) !important;
  color: #0277A8 !important;
}

/* FAQ accordion — refined open state */
.qa {
  background: #fff;
  border: 1px solid rgba(11,26,43,.07);
  box-shadow: 0 1px 2px rgba(11,26,43,.02);
  transition: box-shadow .25s ease, border-color .25s ease;
}
.qa[open] {
  border-color: rgba(2,156,215,.22);
  box-shadow: 0 10px 28px rgba(11,26,43,.08);
}

/* Hood pill — slight border for definition */
.hood-pill {
  background: #fff !important;
  border: 1px solid rgba(11,26,43,.08) !important;
  box-shadow: 0 1px 2px rgba(11,26,43,.02);
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
}
.hood-pill:hover {
  border-color: rgba(2,156,215,.35) !important;
  background: rgba(2,156,215,.04) !important;
  transform: translateY(-1px);
}

/* Image strip — clean 3-up photo band */
.img-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin: 0 0 56px;
}
.img-strip > figure {
  margin: 0;
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-radius: 16px;
}
.img-strip img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .6s ease;
}
.img-strip figure:hover img { transform: scale(1.04); }
.img-strip figcaption {
  position: absolute; left: 14px; bottom: 14px;
  background: rgba(11,26,43,.78);
  color: #fff;
  padding: 6px 12px;
  border-radius: 8px;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  backdrop-filter: blur(6px);
}
@media (max-width: 720px) {
  .img-strip { grid-template-columns: 1fr; gap: 10px; }
}

/* Showcase tweaks — softer dark overlay so background image shows more */
.showcase-bg { opacity: .55 !important; }
.showcase::before {
  background:
    radial-gradient(800px 500px at 30% 50%, rgba(11,26,43,.55), rgba(11,26,43,.88)) !important;
}

/* ============================================================
   v4.3 PATCHES — sub-block subsection styling
   v4.4 PATCHES — tightened sub-block spacing for better visual flow
   ============================================================ */

/* Sub-block: H3 sub-heading + content (bullets, cards, tables) inside a section.
   Used when an ### subsection contains bullets or tables (mixed content)
   rather than prose-only (which renders as a svc-card). */
.sub-block {
  margin-block: 36px 0;
}
.sub-block + .sub-block { margin-top: 44px; }

.sub-head {
  font-size: 1.3rem !important;
  font-weight: 600 !important;
  line-height: 1.25 !important;
  letter-spacing: -.012em;
  margin: 0 0 20px !important;
  color: var(--ink);
  max-width: 38ch;
  position: relative;
  padding-left: 18px;
}
.sub-head::before {
  content: '';
  position: absolute;
  left: 0;
  top: .4em;
  bottom: .4em;
  width: 3px;
  border-radius: 2px;
  background: linear-gradient(180deg, var(--blue), var(--blue-deep));
}

/* When a sub-block immediately wraps a svc-grid, tighten the spacing.
   This is the common case: bullet list with bold-name items → grid of cards. */
.sub-block > .svc-grid:first-of-type {
  margin-top: 0;
}

/* When a sub-block wraps doc-list (plain bullets), make them look intentional. */
.sub-block .doc-list {
  margin-top: 0;
  padding-left: 0;
  list-style: none;
}
.sub-block .doc-list li {
  position: relative;
  padding-left: 22px;
  margin-bottom: 12px;
  font-size: 1rem;
  line-height: 1.62;
  color: var(--text);
}
.sub-block .doc-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: .65em;
  width: 12px;
  height: 2px;
  background: var(--blue);
  border-radius: 2px;
}

/* Sub-block paragraphs (when subsection has para then bullets) */
.sub-block .sec-para {
  margin-bottom: 20px;
  max-width: 64ch;
}

/* Sub-block tables — tighten spacing */
.sub-block .table-wrap { margin-top: 4px; }

/* When a section starts with a sub-block (no intro paragraph), pull it up to
   reduce the dead space between sec-mark / heading and the sub-block. */
.features-head + .sub-block,
.intro-grid + .sub-block {
  margin-top: 32px;
}

@media (max-width: 720px) {
  .sub-head { font-size: 1.15rem !important; padding-left: 14px; margin-bottom: 16px !important; }
  .sub-head::before { width: 2px; }
  .sub-block { margin-top: 28px; }
  .sub-block + .sub-block { margin-top: 32px; }
}
