/* ============================================================
   HALO STAFFING AGENCY — site.css
   "The Halo" — midnight navy · Halo blue · gold halo
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --navy:#06384F;
  --navy-2:#0A4A66;
  --navy-3:#0C5A78;
  --ink:#07344A;
  --slate:#3F5A6B;
  --muted:#5B7D92;
  --paper:#F1F8FC;
  --paper-2:#E1F1FA;
  --white:#ffffff;
  --line:rgba(7,52,74,.10);
  --line-d:rgba(255,255,255,.12);

  --blue:#0CB4F2;        /* Halo wordmark blue */
  --blue-d:#0A93C9;
  --blue-ink:#075A86;
  --gold:#FFE000;        /* the halo */
  --gold-d:#F4CE00;
  --gold-deep:#9C7A00;

  --grad-gold:linear-gradient(135deg,#FFEC57 0%,#FFE000 45%,#F4CE00 100%);
  --grad-blue:linear-gradient(135deg,#4FD0FF 0%,#0CB4F2 50%,#0A93C9 100%);

  --r-sm:10px; --r:16px; --r-lg:26px; --r-xl:34px;
  --sh-1:0 1px 2px rgba(6,56,79,.06), 0 4px 14px rgba(6,56,79,.06);
  --sh-2:0 10px 30px rgba(6,56,79,.10), 0 30px 70px rgba(6,56,79,.10);
  --sh-gold:0 10px 40px rgba(244,206,0,.30);
  --sh-blue:0 10px 40px rgba(12,180,242,.30);

  --ff-disp:"Fraunces", Georgia, "Times New Roman", serif;
  --ff-body:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

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

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%; overflow-x:hidden}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0; font-family:var(--ff-body); color:var(--ink);
  background:var(--paper); line-height:1.6; font-size:17px;
  -webkit-font-smoothing:antialiased; overflow-x:clip;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
h1,h2,h3,h4{font-family:var(--ff-disp); font-weight:600; line-height:1.06; margin:0; letter-spacing:-.01em}
p{margin:0 0 1em}
.wrap{max-width:var(--wrap); margin:0 auto; padding:0 24px}
.eyebrow{
  font-family:var(--ff-body); font-weight:700; font-size:.78rem;
  letter-spacing:.18em; text-transform:uppercase; color:var(--blue-d);
  display:inline-flex; align-items:center; gap:.6em; margin:0 0 .9rem;
}
.eyebrow::before{content:""; width:26px; height:2px; background:var(--gold); border-radius:2px}
.eyebrow.on-dark{color:var(--gold)}
.eyebrow.on-dark::before{background:var(--gold)}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--gold); --fg:#22180a;
  display:inline-flex; align-items:center; justify-content:center; gap:.55em;
  font-family:var(--ff-body); font-weight:700; font-size:.98rem;
  padding:.92em 1.5em; border-radius:999px; border:0; cursor:pointer;
  background:var(--bg); color:var(--fg); position:relative; isolation:isolate; overflow:hidden;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s;
  box-shadow:var(--sh-1); white-space:nowrap; text-align:center;
}
.btn svg{width:1.05em; height:1.05em}
.btn:hover{transform:translateY(-2px)}
.btn--gold{background:var(--grad-gold); color:#231703; box-shadow:var(--sh-gold)}
.btn--blue{background:var(--grad-blue); color:#fff; box-shadow:var(--sh-blue)}
.btn--ghost{background:transparent; color:var(--ink); box-shadow:inset 0 0 0 1.5px var(--line)}
.btn--ghost.on-dark{color:#fff; box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.28)}
.btn--ghost:hover{box-shadow:inset 0 0 0 1.5px var(--blue)}
.btn--lg{padding:1.05em 1.9em; font-size:1.04rem}
.btn--block{display:flex; width:100%}

/* shimmer on gold */
.btn--gold::after{
  content:""; position:absolute; inset:0; border-radius:inherit; z-index:-1;
  background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.55) 50%,transparent 70%);
  transform:translateX(-120%); transition:none;
}
.btn--gold:hover::after{animation:shimmer 1.1s var(--ease)}
@keyframes shimmer{to{transform:translateX(120%)}}

/* ---------- Header ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:90; padding:14px 0;
  transition:background .3s, box-shadow .3s, padding .3s;
}
.site-header.scrolled{
  background:rgba(6,56,79,.82); backdrop-filter:blur(14px) saturate(140%);
  box-shadow:0 1px 0 rgba(255,255,255,.06); padding:9px 0;
}
.nav{display:flex; align-items:center; gap:20px}
.nav-links a{white-space:nowrap}
.brand{display:flex; align-items:center; gap:12px; margin-right:auto}
.nav-links{display:flex; align-items:center; gap:6px; list-style:none; margin:0; padding:0}
.nav-links a{
  color:rgba(255,255,255,.82); font-weight:600; font-size:.93rem;
  padding:.5em .8em; border-radius:999px; transition:color .2s, background .2s;
}
.nav-links a:hover{color:#fff; background:rgba(255,255,255,.08)}
.nav-cta{display:flex; align-items:center; gap:12px}
.nav-phone{
  color:#fff; font-weight:700; font-size:.95rem; display:inline-flex; align-items:center; gap:.5em;
  white-space:nowrap;
}
.nav-phone .ph-ic{color:var(--gold)}
.nav-toggle{display:none; background:none; border:0; cursor:pointer; padding:8px; color:#fff}
.nav-toggle svg{width:26px; height:26px}

/* real logo image */
.brand-logo{height:48px; width:auto; display:block}
.site-header.scrolled .brand-logo{height:40px}
.foot-logo{height:96px; width:auto; margin-bottom:6px}

/* ---------- Hero ---------- */
.hero{
  position:relative; background:var(--navy); color:#fff; overflow:hidden;
  padding:150px 0 90px;
}
.hero__bg{position:absolute; inset:0; z-index:0; overflow:hidden;
  background:#06384F url('../img/hero-bg.jpg') center right / cover no-repeat}
.hero__bg::before{ /* legibility scrim: dark-left for headline, image halo shows right */
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(90deg,#06384F 13%, rgba(6,56,79,.55) 52%, rgba(6,56,79,.10) 100%),
    linear-gradient(0deg,#06384F 0%, transparent 28%);
}
.halo-ring{
  position:absolute; top:-180px; right:-120px; width:620px; height:620px; border-radius:50%;
  background:conic-gradient(from 200deg, rgba(255,224,0,0), rgba(255,224,0,.55), rgba(79,208,255,.4), rgba(255,224,0,0));
  filter:blur(2px); opacity:.5; mask:radial-gradient(circle, transparent 58%, #000 60%, #000 70%, transparent 72%);
  -webkit-mask:radial-gradient(circle, transparent 58%, #000 60%, #000 70%, transparent 72%);
  animation:spin 26s linear infinite;
}
.halo-glow{
  position:absolute; top:-60px; right:60px; width:360px; height:360px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,224,0,.32), transparent 65%); filter:blur(20px);
  animation:pulse 7s var(--ease) infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:.55; transform:scale(1)}50%{opacity:.9; transform:scale(1.06)}}
@media (prefers-reduced-motion:reduce){.halo-ring,.halo-glow{animation:none}}

.hero__grid{position:relative; z-index:2; display:grid; grid-template-columns:1.15fr .85fr; gap:48px; align-items:center}
.hero h1{
  font-size:clamp(2.5rem,5.4vw,4.4rem); line-height:1.0; letter-spacing:-.02em; margin:0 0 .5em;
}
.hero h1 .gold{color:var(--gold)}
.hero h1 .blue{color:#6FD3FF}
.hero__lede{font-size:1.18rem; color:rgba(255,255,255,.82); max-width:38ch; margin:0 0 1.7em}
.hero__cta{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:1.7em}
.hero__assure{display:flex; gap:22px; flex-wrap:wrap; color:rgba(255,255,255,.7); font-size:.92rem}
.hero__assure span{display:inline-flex; align-items:center; gap:.5em}
.hero__assure svg{width:1.05em;height:1.05em;color:var(--gold)}

/* audience toggle */
.aud-toggle{
  display:inline-flex; padding:5px; gap:4px; background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.14); border-radius:999px; margin-bottom:1.5em;
  position:relative;
}
.aud-toggle button{
  position:relative; z-index:2; border:0; background:none; cursor:pointer; color:rgba(255,255,255,.7);
  font-family:var(--ff-body); font-weight:700; font-size:.92rem; padding:.6em 1.25em; border-radius:999px;
  transition:color .3s; display:inline-flex; align-items:center; gap:.5em;
}
.aud-toggle button.is-active{color:#0c1322}
.aud-pill{
  position:absolute; z-index:1; top:5px; bottom:5px; left:5px; width:calc(50% - 5px);
  background:var(--grad-gold); border-radius:999px; transition:transform .38s var(--ease), background .38s;
  box-shadow:0 6px 18px rgba(244,206,0,.4);
}
.aud-toggle[data-aud="talent"] .aud-pill{transform:translateX(100%); background:var(--grad-blue); box-shadow:0 6px 18px rgba(12,180,242,.4)}

/* hero card (right) */
.hero__card{
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.14); border-radius:var(--r-lg); padding:26px;
  backdrop-filter:blur(8px); box-shadow:var(--sh-2);
}
.hero__card h3{color:#fff; font-size:1.35rem; margin-bottom:4px}
.hero__card .sub{color:rgba(255,255,255,.65); font-size:.9rem; margin-bottom:18px}
.statline{display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-bottom:18px}
.statline .s{background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:var(--r-sm); padding:12px 8px; text-align:center}
.statline .n{font-family:var(--ff-disp); font-size:1.5rem; color:var(--gold); font-weight:600; line-height:1}
.statline .l{font-size:.72rem; color:rgba(255,255,255,.62); margin-top:5px; letter-spacing:.02em}
.hero__card .types{display:flex; flex-wrap:wrap; gap:6px}
.chip{font-size:.78rem; font-weight:600; padding:.4em .75em; border-radius:999px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); color:rgba(255,255,255,.85)}

/* marquee */
.marquee{position:relative; z-index:2; margin-top:64px; border-top:1px solid rgba(255,255,255,.1); border-bottom:1px solid rgba(255,255,255,.1); padding:16px 0; overflow:hidden; -webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__track{display:flex; gap:42px; width:max-content; animation:marq 36s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee span{color:rgba(255,255,255,.6); font-weight:600; font-size:.95rem; display:inline-flex; align-items:center; gap:.55em; white-space:nowrap}
.marquee span::before{content:"\2726"; color:var(--gold); font-size:.7em}
@keyframes marq{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none}}

/* ---------- Sections ---------- */
section{position:relative}
.sec{padding:96px 0}
.sec--paper{background:var(--paper)}
.sec--white{background:#fff}
.sec--navy{background:var(--navy); color:#fff}
.sec--tint{background:linear-gradient(180deg,#fff,var(--paper-2))}
.sec-head{max-width:680px; margin:0 0 52px}
.sec-head.center{margin:0 auto 56px; text-align:center}
.sec-head h2{font-size:clamp(2rem,3.6vw,3rem)}
.sec-head p{font-size:1.12rem; color:var(--muted); margin-top:.7rem}
.sec--navy .sec-head p{color:rgba(255,255,255,.72)}

/* dual audience cards */
.duo{display:grid; grid-template-columns:1fr 1fr; gap:26px}
.duo__card{
  position:relative; border-radius:var(--r-lg); padding:38px 34px; overflow:hidden;
  background:#fff; box-shadow:var(--sh-1); border:1px solid var(--line);
  transition:transform .4s var(--ease), box-shadow .4s;
}
.duo__card:hover{transform:translateY(-6px); box-shadow:var(--sh-2)}
.duo__card .tag{font-weight:700; font-size:.8rem; letter-spacing:.14em; text-transform:uppercase}
.duo__card.emp{border-top:5px solid var(--gold)}
.duo__card.tal{border-top:5px solid var(--blue)}
.duo__card.emp .tag{color:var(--gold-deep)}
.duo__card.tal .tag{color:var(--blue-d)}
.duo__card h3{font-size:1.7rem; margin:.4rem 0 .6rem}
.duo__card p{color:var(--slate)}
.duo__list{list-style:none; padding:0; margin:1.2rem 0 1.7rem; display:grid; gap:.6rem}
.duo__list li{display:flex; gap:.7em; align-items:flex-start; font-size:.97rem; color:var(--slate)}
.duo__list svg{width:1.15em; height:1.15em; flex:0 0 auto; margin-top:.18em}
.emp .duo__list svg{color:var(--gold-deep)}
.tal .duo__list svg{color:var(--blue-d)}
.duo__ic{width:54px; height:54px; border-radius:14px; display:grid; place-items:center; margin-bottom:14px}
.emp .duo__ic{background:rgba(255,224,0,.16); color:var(--gold-deep)}
.tal .duo__ic{background:rgba(12,180,242,.14); color:var(--blue-d)}
.duo__ic svg{width:26px;height:26px}

/* ---------- Specialty Explorer ---------- */
.spec-wrap{display:grid; grid-template-columns:1fr; gap:24px}
.spec-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:16px}
.spec-card{
  text-align:left; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r); padding:22px 20px; cursor:pointer; color:#fff; font-family:inherit;
  transition:transform .3s var(--ease), border-color .3s, background .3s; position:relative; overflow:hidden;
}
.spec-card::after{content:""; position:absolute; inset:auto -40% -60% auto; width:160px; height:160px; border-radius:50%; background:radial-gradient(circle,rgba(255,224,0,.25),transparent 70%); opacity:0; transition:opacity .35s}
.spec-card:hover,.spec-card.is-active{transform:translateY(-4px); border-color:var(--gold); background:rgba(255,224,0,.06)}
.spec-card:hover::after,.spec-card.is-active::after{opacity:1}
.spec-card .ic{width:46px;height:46px;border-radius:12px; background:rgba(12,180,242,.18); color:#6FD3FF; display:grid; place-items:center; margin-bottom:14px}
.spec-card.is-active .ic{background:var(--grad-gold); color:#231703}
.spec-card .ic svg{width:24px;height:24px}
.spec-card h3{font-size:1.18rem; color:#fff; margin-bottom:4px}
.spec-card p{font-size:.85rem; color:rgba(255,255,255,.6); margin:0}
.spec-card .cnt{position:absolute; top:16px; right:18px; font-size:.78rem; font-weight:700; color:var(--gold)}

.spec-detail{
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.14); border-radius:var(--r-lg); padding:30px; min-height:220px;
}
.spec-detail__head{display:flex; align-items:center; gap:16px; margin-bottom:18px; flex-wrap:wrap}
.spec-detail__head .ic{width:56px;height:56px;border-radius:14px; background:var(--grad-blue); display:grid; place-items:center; color:#fff}
.spec-detail__head .ic svg{width:28px;height:28px}
.spec-detail h3{font-size:1.6rem; color:#fff}
.spec-detail__head p{margin:.2rem 0 0; color:rgba(255,255,255,.65); font-size:.92rem}
.role-tags{display:flex; flex-wrap:wrap; gap:8px; margin:18px 0}
.role-tags .rt{
  font-size:.86rem; font-weight:600; padding:.5em .9em; border-radius:999px;
  background:rgba(12,180,242,.12); border:1px solid rgba(12,180,242,.3); color:#BDE9FF;
  opacity:0; transform:translateY(6px); animation:rtin .4s var(--ease) forwards;
}
@keyframes rtin{to{opacity:1; transform:none}}
.spec-detail__foot{display:flex; gap:12px; flex-wrap:wrap; align-items:center; margin-top:8px; padding-top:18px; border-top:1px solid rgba(255,255,255,.1)}
.spec-detail__foot .settings{color:rgba(255,255,255,.6); font-size:.88rem; flex:1; min-width:200px}

/* ---------- Process / steps ---------- */
.steps{display:grid; grid-template-columns:repeat(4,1fr); gap:20px; counter-reset:step}
.step{position:relative; padding-top:8px}
.step .num{
  font-family:var(--ff-disp); font-size:2.6rem; font-weight:600; line-height:1;
  color:var(--gold); -webkit-text-stroke:0; margin-bottom:10px; display:flex; align-items:center; gap:10px;
}
.step .num::after{content:""; flex:1; height:2px; background:linear-gradient(90deg,var(--gold),transparent)}
.sec--paper .step .num{color:var(--blue-d)}
.sec--paper .step .num::after{background:linear-gradient(90deg,rgba(12,180,242,.4),transparent)}
.step h3{font-size:1.2rem; margin-bottom:.4rem}
.step p{font-size:.95rem; color:var(--muted)}
.proc-tabs{display:inline-flex; gap:6px; padding:5px; background:#fff; border:1px solid var(--line); border-radius:999px; margin-bottom:38px; box-shadow:var(--sh-1)}
.proc-tabs button{border:0; background:none; cursor:pointer; font-family:var(--ff-body); font-weight:700; font-size:.92rem; padding:.6em 1.3em; border-radius:999px; color:var(--muted); transition:.25s}
.proc-tabs button.is-active{background:var(--ink); color:#fff}

/* ---------- HHA spotlight ---------- */
.spot{display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center}
.spot__media{
  position:relative; border-radius:var(--r-xl); overflow:hidden; min-height:440px;
  background:#0A93C9 url('../img/hha-home.jpg') center / cover no-repeat;
  box-shadow:var(--sh-2);
}
.spot__media::after{content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(0deg, rgba(6,56,79,.55), transparent 42%)}
.spot__media .floatcard{z-index:2;
  position:absolute; left:24px; bottom:24px; background:rgba(255,255,255,.95); color:var(--ink);
  border-radius:var(--r); padding:14px 18px; box-shadow:var(--sh-2); display:flex; gap:12px; align-items:center; max-width:78%;
}
.spot__media .floatcard .ic{width:42px;height:42px;border-radius:11px;background:var(--grad-gold);display:grid;place-items:center;flex:0 0 auto}
.spot__media .floatcard b{display:block; font-size:.98rem}
.spot__media .floatcard small{color:var(--muted)}
.feat-list{list-style:none; padding:0; margin:1.4rem 0 0; display:grid; gap:14px}
.feat-list li{display:flex; gap:14px; align-items:flex-start}
.feat-list .ic{width:42px;height:42px;border-radius:11px; flex:0 0 auto; display:grid; place-items:center; background:rgba(12,180,242,.12); color:var(--blue-d)}
.feat-list .ic svg{width:22px;height:22px}
.feat-list b{display:block; margin-bottom:2px}
.feat-list p{margin:0; color:var(--muted); font-size:.95rem}

/* ---------- Stats band ---------- */
.band{background:var(--grad-blue); color:#fff}
.band .wrap{display:grid; grid-template-columns:repeat(4,1fr); gap:24px; padding-top:54px; padding-bottom:54px}
.band .b{text-align:center}
.band .bn{font-family:var(--ff-disp); font-size:clamp(2rem,4vw,3rem); font-weight:600; line-height:1}
.band .bl{font-weight:600; font-size:.95rem; opacity:.78; margin-top:6px}

/* ---------- About ---------- */
.about{display:grid; grid-template-columns:.95fr 1.05fr; gap:50px; align-items:center}
.values{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:8px}
.value{background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:22px; box-shadow:var(--sh-1)}
.value .ic{width:44px;height:44px;border-radius:11px;display:grid;place-items:center;background:rgba(255,224,0,.18);color:var(--gold-deep);margin-bottom:12px}
.value .ic svg{width:22px;height:22px}
.value h4{font-size:1.08rem; margin-bottom:.3rem}
.value p{font-size:.9rem; color:var(--muted); margin:0}

/* ---------- Map / service area ---------- */
.area{display:grid; grid-template-columns:1fr 1.3fr; gap:40px; align-items:stretch}
.area__info{align-self:center}
.area__info ul{list-style:none; padding:0; margin:1.2rem 0 0; display:grid; gap:14px}
.area__info li{display:flex; gap:13px; align-items:flex-start}
.area__info .ic{width:44px;height:44px;border-radius:11px;flex:0 0 auto;display:grid;place-items:center;background:rgba(12,180,242,.12);color:var(--blue-d)}
.area__info .ic svg{width:22px;height:22px}
.area__info b{display:block}
.area__info small{color:var(--muted)}
#map{min-height:440px; height:100%; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--sh-2); border:1px solid var(--line); z-index:1}
.leaflet-container{background:#073A52}
.leaflet-popup-content-wrapper{border-radius:12px}
.leaflet-popup-content{font-family:var(--ff-body)}

/* ---------- Contact ---------- */
.contact{display:grid; grid-template-columns:1fr 1.05fr; gap:48px}
.contact__aside h2{color:#fff}
.contact__aside p{color:rgba(255,255,255,.72)}
.contact__cards{display:grid; gap:14px; margin-top:24px}
.cc{display:flex; gap:14px; align-items:center; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:var(--r); padding:16px 18px}
.cc .ic{width:46px;height:46px;border-radius:12px;flex:0 0 auto;display:grid;place-items:center;background:var(--grad-gold);color:#231703}
.cc .ic svg{width:23px;height:23px}
.cc b{display:block; color:#fff}
.cc a,.cc span{color:rgba(255,255,255,.72); font-size:.95rem}
.cc a:hover{color:var(--gold)}

form.lead{background:#fff; border-radius:var(--r-lg); padding:30px; box-shadow:var(--sh-2)}
.field{margin-bottom:16px}
.field label{display:block; font-weight:600; font-size:.88rem; margin-bottom:6px; color:var(--ink)}
.field input,.field select,.field textarea{
  width:100%; padding:.85em 1em; border:1.5px solid var(--line); border-radius:var(--r-sm);
  font-family:inherit; font-size:1rem; color:var(--ink); background:#fcfdff; transition:border-color .2s, box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:0; border-color:var(--blue); box-shadow:0 0 0 4px rgba(12,180,242,.12)}
.field textarea{resize:vertical; min-height:96px}
.field-row{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.seg{display:flex; gap:8px; margin-bottom:18px}
.seg label{flex:1; cursor:pointer}
.seg input{position:absolute; opacity:0; pointer-events:none}
.seg span{display:flex; align-items:center; justify-content:center; gap:.5em; padding:.8em; border:1.5px solid var(--line); border-radius:var(--r-sm); font-weight:600; font-size:.92rem; transition:.2s; color:var(--slate)}
.seg input:checked + span{border-color:var(--blue); background:rgba(12,180,242,.08); color:var(--blue-d)}
.form-note{font-size:.8rem; color:var(--muted); margin-top:6px; text-align:center}
.form-ok{display:none; text-align:center; padding:30px 10px}
.form-ok.show{display:block}
.form-ok .ic{width:64px;height:64px;border-radius:50%;background:rgba(34,180,90,.14);color:#1f9d55;display:grid;place-items:center;margin:0 auto 16px}
.form-ok .ic svg{width:32px;height:32px}

/* ---------- FAQ ---------- */
.faq{max-width:820px; margin:0 auto; display:grid; gap:12px}
.faq details{background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:0; overflow:hidden; box-shadow:var(--sh-1)}
.faq summary{cursor:pointer; list-style:none; padding:20px 24px; font-weight:700; font-size:1.05rem; display:flex; justify-content:space-between; align-items:center; gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pl{flex:0 0 auto; width:24px; height:24px; position:relative; transition:transform .3s}
.faq summary .pl::before,.faq summary .pl::after{content:""; position:absolute; background:var(--blue-d); border-radius:2px; top:50%; left:50%; transform:translate(-50%,-50%)}
.faq summary .pl::before{width:14px; height:2px}
.faq summary .pl::after{width:2px; height:14px; transition:transform .3s}
.faq details[open] summary .pl::after{transform:translate(-50%,-50%) scaleY(0)}
.faq details .ans{padding:0 24px 22px; color:var(--slate)}

/* ---------- CTA band ---------- */
.cta-band{position:relative; background:#06384F; color:#fff; overflow:hidden; text-align:center; padding:96px 0}
.cta-band::before{content:""; position:absolute; inset:0; z-index:0;
  background:linear-gradient(0deg,#06384F 33%, rgba(6,56,79,.58) 100%), url('../img/philly.jpg') center 80% / cover no-repeat}
.cta-band .halo-glow{top:42%; left:50%; transform:translate(-50%,-50%); right:auto; width:520px; height:520px; opacity:.5}
.cta-band h2{font-size:clamp(2rem,4vw,3.2rem); position:relative; z-index:2; max-width:18ch; margin:0 auto .6rem}
.cta-band p{position:relative; z-index:2; color:rgba(255,255,255,.78); max-width:50ch; margin:0 auto 1.8rem}
.cta-band .hero__cta{justify-content:center; position:relative; z-index:2}

/* ---------- Footer ---------- */
.site-footer{background:#04222F; color:rgba(255,255,255,.62); padding:64px 0 28px}
.foot-grid{display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:36px; margin-bottom:40px}
.foot-grid h4{color:#fff; font-family:var(--ff-body); font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:16px}
.foot-grid ul{list-style:none; padding:0; margin:0; display:grid; gap:10px}
.foot-grid a:hover{color:var(--gold)}
.foot-grid p{font-size:.92rem; line-height:1.7}
.foot-soc{display:flex; gap:10px; margin-top:16px}
.foot-soc a{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:rgba(255,255,255,.07);transition:.2s}
.foot-soc a:hover{background:var(--gold); color:#231703}
.foot-soc svg{width:18px;height:18px}
.foot-bot{border-top:1px solid rgba(255,255,255,.1); padding-top:22px; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:.84rem}
.foot-bot a:hover{color:#fff}

/* ---------- Reveal ---------- */
.reveal{opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.in{opacity:1; transform:none}
.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}.reveal[data-d="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1; transform:none}}

/* ---------- Modal ---------- */
.modal{position:fixed; inset:0; z-index:200; display:none; align-items:center; justify-content:center; padding:20px}
.modal.open{display:flex}
.modal__scrim{position:absolute; inset:0; background:rgba(4,34,47,.6); backdrop-filter:blur(4px); animation:fade .3s}
.modal__box{position:relative; background:#fff; border-radius:var(--r-lg); max-width:520px; width:100%; padding:34px; box-shadow:var(--sh-2); animation:pop .35s var(--ease)}
.modal__box h3{font-size:1.6rem; margin-bottom:.4rem}
.modal__close{position:absolute; top:14px; right:14px; width:38px;height:38px;border-radius:50%;border:0;background:var(--paper-2); cursor:pointer; display:grid; place-items:center}
@keyframes fade{from{opacity:0}}
@keyframes pop{from{opacity:0; transform:translateY(20px) scale(.97)}}

/* ---------- Page hero (interior) ---------- */
.phero{background:var(--navy); color:#fff; padding:140px 0 70px; position:relative; overflow:hidden}
.phero .halo-glow{top:-40px; right:8%}
.phero .crumbs{position:relative; z-index:2; font-size:.85rem; color:rgba(255,255,255,.55); margin-bottom:14px}
.phero .crumbs a:hover{color:var(--gold)}
.phero h1{position:relative; z-index:2; font-size:clamp(2.2rem,4.6vw,3.6rem); max-width:18ch}
.phero p{position:relative; z-index:2; color:rgba(255,255,255,.78); font-size:1.15rem; max-width:54ch; margin-top:.8rem}

.prose{max-width:760px; margin:0 auto}
.prose h2{font-size:1.9rem; margin:1.8em 0 .5em}
.prose h3{font-size:1.3rem; margin:1.4em 0 .4em}
.prose p{color:var(--slate); margin-bottom:1.1em}
.prose ul{color:var(--slate); padding-left:1.2em; margin-bottom:1.1em}
.prose li{margin-bottom:.5em}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero__grid,.spot,.about,.area,.contact{grid-template-columns:1fr}
  .area__info{order:-1}
  .spec-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .band .wrap{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
}
/* nav collapses to hamburger before it can crowd */
@media (max-width:1100px){
  .nav-links,.nav-phone{display:none}
  .nav-toggle{display:block}
  .nav.mobile-open{position:relative}
  .nav.mobile-open .nav-links{
    display:flex; position:absolute; top:100%; left:12px; right:12px; flex-direction:column; align-items:stretch;
    background:rgba(6,56,79,.97); backdrop-filter:blur(14px); border:1px solid rgba(255,255,255,.12);
    border-radius:var(--r); padding:12px; gap:4px; margin-top:10px; z-index:5;
  }
  .nav.mobile-open .nav-links a{padding:.8em 1em}
}
@media (max-width:760px){
  body{font-size:16px}
  .sec{padding:68px 0}
  .duo{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .hero{padding-top:120px}
  .hero__cta .btn{flex:1}
}
@media (max-width:520px){
  .spec-grid{grid-template-columns:1fr}
  .band .wrap,.values,.foot-grid{grid-template-columns:1fr}
  .statline{grid-template-columns:repeat(3,1fr)}
}

/* ============================================================
   FLAGSHIP POLISH — motion layer (themed FP partial + bespoke)
   namespaced .fp-* / .mote / .spark so it never clashes with
   the existing .reveal / .marquee / [data-count] systems.
   ============================================================ */
:root{
  --fp-accent:var(--gold);
  --fp-accent-lt:#FFEC57;
  --fp-cursor-size:30px;
  --fp-dot-size:6px;
  --fp-aura-1:rgba(12,180,242,.42);
  --fp-aura-2:rgba(255,224,0,.24);
}
html.fp-veil-lock{overflow:hidden}
html.fp-cursor-on,html.fp-cursor-on *{cursor:none !important}

/* 1 · grain ----------------------------------------------------- */
.fp-grain{position:fixed; inset:0; z-index:9990; pointer-events:none; opacity:.22; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* 2 · scroll progress + scrollspy ------------------------------- */
#fp-progress{position:fixed; top:0; left:0; height:3px; width:0; z-index:9991;
  background:linear-gradient(90deg,var(--blue),var(--gold)); box-shadow:0 0 12px rgba(12,180,242,.5)}
.nav-links a[data-fp-spy]{position:relative}
.nav-links a[data-fp-spy].fp-active{color:#fff}
.nav-links a[data-fp-spy].fp-active::after{content:""; position:absolute; left:.8em; right:.8em; bottom:.28em; height:2px; background:var(--gold); border-radius:2px}

/* 3 · intro veil — branded halo --------------------------------- */
#fp-veil{position:fixed; inset:0; z-index:9999; background:radial-gradient(circle at 50% 42%,#0A4A66,#06384F 72%);
  display:flex; align-items:center; justify-content:center; flex-direction:column; gap:16px; transition:opacity .7s ease,visibility .7s}
#fp-veil.fp-gone{opacity:0; visibility:hidden}
#fp-veil .fp-v-mark{width:96px; height:96px; overflow:visible}
#fp-veil .fp-v-ring{fill:none; stroke:var(--gold); stroke-width:3; stroke-dasharray:251; stroke-dashoffset:251; animation:fp-vdraw 1s var(--ease) forwards .12s}
#fp-veil .fp-v-core,#fp-veil .fp-v-orb{opacity:0; transform-box:fill-box; transform-origin:center; animation:fp-vpop .55s var(--ease) forwards}
#fp-veil .fp-v-core{animation-delay:.62s}
#fp-veil .fp-v-orb{animation-delay:.88s}
#fp-veil .fp-v-word{font-family:var(--ff-disp); font-weight:600; color:#fff; font-size:30px; letter-spacing:.005em; opacity:0; animation:fp-vfade .6s ease forwards 1s}
#fp-veil .fp-v-sub{font-family:var(--ff-body); font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--gold); font-weight:700; opacity:0; animation:fp-vfade .6s ease forwards 1.2s}
@keyframes fp-vdraw{to{stroke-dashoffset:0}}
@keyframes fp-vpop{from{opacity:0; transform:scale(.3)}to{opacity:1; transform:scale(1)}}
@keyframes fp-vfade{to{opacity:1}}

/* 4 · custom cursor (ring + dot) -------------------------------- */
#fp-cursor,#fp-cursor-dot{position:fixed; top:0; left:0; z-index:9997; pointer-events:none; border-radius:50%; opacity:0; will-change:transform}
#fp-cursor.fp-show,#fp-cursor-dot.fp-show{opacity:1}
#fp-cursor{width:var(--fp-cursor-size); height:var(--fp-cursor-size); margin-left:calc(var(--fp-cursor-size)/-2); margin-top:calc(var(--fp-cursor-size)/-2); border:1.6px solid var(--gold); transition:width .22s,height .22s,margin .22s,background .22s,opacity .3s}
#fp-cursor-dot{width:var(--fp-dot-size); height:var(--fp-dot-size); margin-left:calc(var(--fp-dot-size)/-2); margin-top:calc(var(--fp-dot-size)/-2); background:var(--gold); transition:opacity .3s}
#fp-cursor.fp-big{width:calc(var(--fp-cursor-size)*1.85); height:calc(var(--fp-cursor-size)*1.85); margin-left:calc(var(--fp-cursor-size)*-0.925); margin-top:calc(var(--fp-cursor-size)*-0.925); background:rgba(255,224,0,.14)}

/* 6 · heading clip / mask reveal -------------------------------- */
.fp-clip{display:inline-block; clip-path:inset(0 0 102% 0); transform:translateY(14px); transition:clip-path .85s var(--ease),transform .85s var(--ease); will-change:clip-path,transform}
.fp-clip.fp-in{clip-path:inset(0 0 -18% 0); transform:none}

/* 7 · 3D tilt + mouse-tracking sheen ---------------------------- */
.fp-tilt{will-change:transform; transition:transform .3s var(--ease)}
.fp-tilt .fp-sheen{position:absolute; inset:0; border-radius:inherit; opacity:0; transition:opacity .35s; pointer-events:none; z-index:1;
  background:radial-gradient(circle at var(--fp-mx,50%) var(--fp-my,50%),rgba(255,236,87,.30),transparent 46%)}
.fp-tilt:hover .fp-sheen{opacity:1}
.fp-tilt>*:not(.fp-sheen){position:relative; z-index:2}

/* 8 · magnetic buttons (JS adds transform) ---------------------- */
.fp-magnetic{transition:transform .25s var(--ease)}

/* 10 · aurora drift on dark sections (standalone; sits above bg, below .wrap) */
.fp-dark{position:relative; overflow:hidden}
.fp-aura{position:absolute; border-radius:50%; filter:blur(80px); pointer-events:none; z-index:1}
.fp-aura.fp-a1{width:440px; height:440px; background:radial-gradient(circle,var(--fp-aura-1),transparent 68%); top:-160px; right:-110px; animation:fp-drift1 28s ease-in-out infinite}
.fp-aura.fp-a2{width:380px; height:380px; background:radial-gradient(circle,var(--fp-aura-2),transparent 66%); bottom:-170px; left:-100px; animation:fp-drift2 33s ease-in-out infinite}
@keyframes fp-drift1{0%,100%{transform:translate(0,0)}50%{transform:translate(-40px,30px)}}
@keyframes fp-drift2{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,-30px)}}

/* bespoke · hero light-motes ------------------------------------ */
.hero__motes{position:absolute; inset:0; z-index:1; pointer-events:none; overflow:hidden}
.hero__motes .mote{position:absolute; bottom:-12px; border-radius:50%; opacity:0;
  background:radial-gradient(circle,rgba(255,236,87,.95),rgba(255,224,0,0) 70%); animation:moteRise linear infinite}
@keyframes moteRise{
  0%{opacity:0; transform:translateY(0) translateX(0) scale(.6)}
  12%{opacity:.85}
  85%{opacity:.5}
  100%{opacity:0; transform:translateY(-86vh) translateX(var(--mx,14px)) scale(1)}
}

/* bespoke · gold click-spark ------------------------------------ */
.fp-spark{position:fixed; z-index:9996; pointer-events:none; color:var(--gold); transform:translate(-50%,-50%); will-change:transform,opacity; animation:fpSpark .62s var(--ease) forwards}
.fp-spark svg{display:block; width:100%; height:100%; filter:drop-shadow(0 0 4px rgba(255,224,0,.6))}
@keyframes fpSpark{0%{opacity:0; transform:translate(-50%,-50%) scale(.2) rotate(0deg)}25%{opacity:1}100%{opacity:0; transform:translate(-50%,-50%) scale(1.5) rotate(40deg)}}

/* GUARDRAILS — touch + reduced-motion --------------------------- */
@media (max-width:760px){
  .fp-aura,.hero__motes{display:none}
}
@media (prefers-reduced-motion:reduce){
  #fp-veil{display:none !important}
  #fp-cursor,#fp-cursor-dot{display:none !important}
  html.fp-cursor-on,html.fp-cursor-on *{cursor:auto !important}
  .fp-clip{clip-path:none !important; transform:none !important}
  .fp-tilt{transition:none !important}
  .fp-aura,.hero__motes,.fp-spark{display:none !important}
  #fp-progress{display:none !important}
}
