/* ============================================
   Design tokens
   ============================================ */
:root{
  --ink:        #0A1628;
  --ink-2:      #0F2340;
  --ink-3:      #17325C;
  --paper:      #FFFFFF;
  --paper-2:    #F6F8FB;
  --paper-3:    #ECF0F6;
  --amber:      #F5B014;
  --amber-hot:  #F97316;
  --amber-soft: #FFF3D1;
  --cyan:       #22D3EE;
  --text:       #0A1628;
  --text-muted: #55647D;
  --line:       rgba(10,22,40,.08);
  --line-dark:  rgba(255,255,255,.09);
  --radius:     14px;
  --radius-lg:  22px;
  --shadow-sm:  0 1px 2px rgba(10,22,40,.06), 0 1px 1px rgba(10,22,40,.04);
  --shadow-md:  0 10px 30px -12px rgba(10,22,40,.18), 0 2px 6px rgba(10,22,40,.06);
  --shadow-lg:  0 30px 70px -20px rgba(10,22,40,.28), 0 10px 20px -8px rgba(10,22,40,.1);
  --max:        1200px;
  --ease:       cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Geist',system-ui,-apple-system,Segoe UI,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:var(--paper);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  padding-bottom:env(safe-area-inset-bottom);
  font-feature-settings:"ss01","cv11";
}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
::selection{background:var(--amber);color:var(--ink)}

/* Typography */
h1,h2,h3,h4,.display{
  font-family:'Geist',system-ui,sans-serif;
  font-weight:700;
  letter-spacing:-.035em;
  line-height:1.02;
  margin:0;
}
h1{font-size:clamp(2.5rem, 6.2vw, 5rem); font-weight:800; letter-spacing:-.04em}
h2{font-size:clamp(2rem, 4.2vw, 3.25rem); font-weight:700; letter-spacing:-.035em}
h3{font-size:clamp(1.2rem, 1.9vw, 1.5rem); font-weight:600; letter-spacing:-.02em}
p{margin:0}

.container{width:min(100% - 2.5rem, var(--max)); margin-inline:auto}
.eyebrow{
  display:inline-flex; align-items:center; gap:.55rem;
  font-size:.78rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  color:var(--amber);
}
.eyebrow::before{
  content:""; width:8px; height:8px; border-radius:50%;
  background:var(--amber); box-shadow:0 0 0 0 rgba(245,176,20,.7);
  animation:pulse 2s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(245,176,20,.6)}
  70%{box-shadow:0 0 0 10px rgba(245,176,20,0)}
  100%{box-shadow:0 0 0 0 rgba(245,176,20,0)}
}

/* ============================================
   Emergency bar
   ============================================ */
.ebar{
  background:linear-gradient(90deg,#0A1628,#102744 55%,#0A1628);
  color:#EAF0FA;
  font-size:.82rem;
  border-bottom:1px solid var(--line-dark);
}
.ebar__inner{
  display:flex; align-items:center; justify-content:center; gap:.6rem;
  min-height:38px; padding:.4rem 1rem; flex-wrap:wrap;
  font-size:.82rem;
}
@media (max-width:520px){
  .ebar__inner{gap:.4rem; font-size:.76rem}
  .ebar__inner .ebar__hide-sm{display:none}
}
.ebar__dot{
  width:8px;height:8px;border-radius:50%;background:var(--amber);
  box-shadow:0 0 12px rgba(245,176,20,.9);
}
.ebar strong{color:var(--amber);font-weight:700}
.ebar a{color:#fff;font-weight:600;white-space:nowrap}
.ebar a:hover{color:var(--amber)}

/* ============================================
   Header
   ============================================ */
.hdr{
  position:sticky; top:0; z-index:40;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(1.4) blur(14px);
  -webkit-backdrop-filter:saturate(1.4) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .2s var(--ease), background .2s var(--ease);
}
.hdr--scrolled{border-bottom-color:var(--line); background:rgba(255,255,255,.92)}
.hdr__inner{
  display:flex; align-items:center; justify-content:space-between;
  height:64px; gap:.75rem;
}
@media (min-width: 900px){ .hdr__inner{height:72px; gap:1rem} }
.logo{display:flex; align-items:center; gap:.65rem; font-family:'Geist';
  font-weight:800; font-size:1.25rem; letter-spacing:-.02em; color:var(--ink)}
.logo__mark{
  width:36px; height:36px; border-radius:10px;
  background:linear-gradient(145deg, var(--ink) 20%, var(--ink-3));
  display:grid; place-items:center;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12), 0 4px 14px rgba(10,22,40,.18);
}
.logo__mark svg{width:20px;height:20px}
.logo__dot{color:var(--amber)}

.nav{display:none; gap:2rem}
.nav a{
  font-size:.92rem; font-weight:500; color:var(--text);
  position:relative; transition:color .15s var(--ease);
}
.nav a:hover{color:var(--ink)}
.nav a::after{
  content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px;
  background:var(--amber); transform:scaleX(0); transform-origin:left;
  transition:transform .2s var(--ease);
}
.nav a:hover::after{transform:scaleX(1)}

.hdr__right{display:flex; align-items:center; gap:.5rem}

.langbtn{
  display:inline-flex; align-items:center; gap:.2rem;
  background:var(--paper-2); border:1px solid var(--line);
  padding:.38rem .6rem; border-radius:999px;
  font-size:.78rem; font-weight:600; color:var(--text-muted);
  transition:all .15s var(--ease);
}
.langbtn:hover{color:var(--ink); border-color:rgba(10,22,40,.18)}
.langbtn .sep{opacity:.35;margin-inline:.1rem}
.langbtn [data-lang-active="true"]{color:var(--ink)}

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  font-weight:600; font-size:.95rem;
  padding:.85rem 1.35rem; border-radius:999px;
  transition:transform .15s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease), color .2s var(--ease);
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn--amber{
  background:var(--amber); color:var(--ink);
  box-shadow:0 8px 20px -8px rgba(245,176,20,.6), inset 0 -2px 0 rgba(10,22,40,.08);
}
.btn--amber:hover{background:#FFC534; box-shadow:0 10px 28px -8px rgba(245,176,20,.8)}
.btn--ghost{background:transparent; color:var(--ink); border:1px solid var(--line)}
.btn--ghost:hover{background:var(--paper-2); border-color:rgba(10,22,40,.2)}
.btn--dark{background:var(--ink); color:#fff}
.btn--dark:hover{background:var(--ink-2)}
.btn--lg{padding:1.1rem 1.75rem; font-size:1.02rem}
.btn svg{width:18px;height:18px}

.hdr__callpill{display:inline-flex}
.hdr__callicon{
  display:none; width:40px; height:40px; border-radius:50%;
  background:var(--amber); color:var(--ink);
  align-items:center; justify-content:center;
  box-shadow:0 6px 16px -6px rgba(245,176,20,.6), inset 0 -2px 0 rgba(10,22,40,.08);
  transition:transform .15s var(--ease);
}
.hdr__callicon svg{width:18px; height:18px}
.hdr__callicon:active{transform:scale(.94)}
@media (max-width: 899px){
  .hdr__callpill{display:none}
  .hdr__callicon{display:inline-flex}
}

/* ============================================
   Section
   ============================================ */
section{padding:5rem 0; position:relative}
.sec-head{max-width:720px; margin-bottom:3rem}
.sec-head > .eyebrow{margin-bottom:.85rem}
.sec-head p{margin-top:1rem; color:var(--text-muted); font-size:1.05rem; max-width:640px}

/* ============================================
   Service page hero
   ============================================ */
.svc-hero{
  position:relative;
  padding:3rem 0 4rem;
  overflow:hidden;
  background:
    radial-gradient(1200px 600px at 110% -20%, rgba(245,176,20,.14), transparent 60%),
    radial-gradient(800px 500px at -10% 30%, rgba(34,211,238,.08), transparent 60%),
    linear-gradient(180deg, #fff, var(--paper-2));
}
.svc-hero__grid{
  display:grid; grid-template-columns:1fr; gap:2.5rem; align-items:center;
}
.svc-hero .eyebrow{margin-bottom:1.1rem}
.svc-hero h1{font-size:clamp(2.2rem, 5.4vw, 4.25rem)}
.svc-hero h1 em{
  font-style:normal; position:relative; white-space:nowrap;
  background:linear-gradient(180deg, transparent 62%, rgba(245,176,20,.45) 62%, rgba(245,176,20,.45) 92%, transparent 92%);
  padding:0 .15em;
}
.svc-hero__sub{
  margin-top:1.25rem; max-width:560px;
  font-size:clamp(1.02rem, 1.3vw, 1.15rem);
  color:var(--text-muted);
}
.svc-hero__ctas{display:flex; flex-wrap:wrap; gap:.75rem; margin-top:1.75rem; align-items:stretch}
.btn-stack{
  display:inline-flex; flex-direction:column; align-items:center;
  gap:.15rem; padding:1rem 1.75rem;
  background:var(--amber); color:var(--ink);
  border-radius:18px; white-space:nowrap;
  box-shadow:0 14px 32px -10px rgba(245,176,20,.55), inset 0 -2px 0 rgba(10,22,40,.08);
  transition:transform .15s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
}
.btn-stack:hover{background:#FFC534; transform:translateY(-1px); box-shadow:0 18px 40px -10px rgba(245,176,20,.75)}
.btn-stack:active{transform:translateY(0)}
.btn-stack__top{display:inline-flex; align-items:center; gap:.55rem; font-weight:700; font-size:1.05rem; letter-spacing:-.01em}
.btn-stack__top svg{width:20px;height:20px}
.btn-stack__sub{font-family:'Geist'; font-weight:800; font-size:1.35rem; letter-spacing:-.02em; line-height:1}

.svc-hero__micro{margin-top:.85rem; font-size:.86rem; color:var(--text-muted); font-weight:500}
.svc-hero__bullets{
  list-style:none; padding:0; margin:1.75rem 0 0;
  display:grid; gap:.6rem;
}
.svc-hero__bullets li{
  display:flex; align-items:flex-start; gap:.65rem;
  color:var(--ink); font-weight:500; font-size:.98rem;
}
.svc-hero__bullets svg{
  flex:0 0 20px; width:20px; height:20px; margin-top:2px;
  color:var(--amber);
}

.svc-hero__right{position:relative}
.svc-hero__frame{
  position:relative; aspect-ratio:4/5;
  border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:var(--shadow-lg);
  background:linear-gradient(135deg, var(--ink-2), var(--ink));
  isolation:isolate;
}
.svc-hero__frame img{
  width:100%; height:100%; object-fit:cover; object-position:center;
  transition:transform 8s var(--ease);
}
.svc-hero__frame:hover img{transform:scale(1.04)}
.svc-hero__frame::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 55%, rgba(10,22,40,.55));
  pointer-events:none;
}
.svc-hero__badge{
  position:absolute; z-index:2;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(12px);
  border-radius:14px; padding:.75rem .9rem;
  box-shadow:var(--shadow-md);
  display:flex; align-items:center; gap:.65rem;
  max-width:240px;
}
.svc-hero__badge--tl{top:1rem; left:1rem}
.svc-hero__badge--br{bottom:1rem; right:1rem; flex-direction:column; align-items:flex-start; gap:.15rem}
.badge__icon{
  width:34px; height:34px; border-radius:9px;
  background:var(--amber); display:grid; place-items:center;
  box-shadow:inset 0 -2px 0 rgba(10,22,40,.08); flex:0 0 34px;
}
.badge__icon svg{width:18px;height:18px;color:var(--ink)}
.badge__txt{font-size:.72rem; color:var(--text-muted); font-weight:500; line-height:1.2}
.badge__big{font-size:.92rem; font-weight:700; color:var(--ink); line-height:1.2}
.badge__stars{color:var(--amber); font-size:.85rem; letter-spacing:-.1em}

/* ============================================
   Breadcrumbs
   ============================================ */
.crumbs{
  padding:1rem 0 0; font-size:.82rem; color:var(--text-muted);
  display:flex; gap:.45rem; align-items:center; flex-wrap:wrap;
}
.crumbs a{color:var(--text-muted); transition:color .15s var(--ease)}
.crumbs a:hover{color:var(--ink)}
.crumbs__sep{opacity:.4}
.crumbs [aria-current="page"]{color:var(--ink); font-weight:500}

/* ============================================
   Pain points (symptoms)
   ============================================ */
.pain{background:var(--paper)}
.pain-grid{
  display:grid; grid-template-columns:1fr; gap:.75rem;
  margin-top:2.5rem;
}
.pain-item{
  display:flex; align-items:flex-start; gap:1rem;
  padding:1.25rem 1.35rem;
  background:var(--paper-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  transition:all .2s var(--ease);
}
.pain-item:hover{background:#fff; box-shadow:var(--shadow-md); transform:translateY(-2px)}
.pain-item__dot{
  flex:0 0 12px; width:12px; height:12px; border-radius:50%;
  background:var(--amber-hot);
  box-shadow:0 0 0 5px rgba(249,115,22,.12);
  margin-top:8px;
}
.pain-item strong{display:block; color:var(--ink); font-weight:600; margin-bottom:.1rem}
.pain-item span{color:var(--text-muted); font-size:.93rem; line-height:1.5}

/* ============================================
   Process (service-specific)
   ============================================ */
.svc-process{background:var(--ink); color:#fff; position:relative; overflow:hidden}
.svc-process::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(700px 400px at 10% 10%, rgba(34,211,238,.07), transparent 60%),
    radial-gradient(700px 400px at 90% 90%, rgba(245,176,20,.1), transparent 60%);
  pointer-events:none;
}
.svc-process .sec-head p{color:rgba(255,255,255,.7)}
.svc-process h2{color:#fff}
.svc-steps{
  display:grid; grid-template-columns:1fr; gap:1rem; position:relative;
}
.svc-step{
  padding:2rem; border-radius:var(--radius-lg);
  background:rgba(255,255,255,.04);
  border:1px solid var(--line-dark);
  backdrop-filter:blur(10px);
  position:relative;
}
.svc-step__num{
  font-family:'Geist'; font-weight:800;
  font-size:3rem; color:var(--amber); letter-spacing:-.04em; line-height:1;
}
.svc-step h3{color:#fff; margin:.75rem 0 .5rem}
.svc-step p{color:rgba(255,255,255,.72); font-size:.97rem}

/* ============================================
   Included / features
   ============================================ */
.included{background:var(--paper-2)}
.included-grid{
  display:grid; grid-template-columns:1fr; gap:1rem;
}
.feat{
  display:flex; align-items:flex-start; gap:1rem;
  padding:1.5rem; border-radius:var(--radius);
  background:#fff; border:1px solid var(--line);
  transition:all .2s var(--ease);
}
.feat:hover{transform:translateY(-2px); box-shadow:var(--shadow-md); border-color:transparent}
.feat__icon{
  width:44px; height:44px; flex:0 0 44px; border-radius:12px;
  background:var(--amber-soft); color:var(--amber-hot);
  display:grid; place-items:center;
}
.feat__icon svg{width:22px;height:22px}
.feat h3{color:var(--ink); font-size:1.05rem; font-weight:600; margin-bottom:.35rem}
.feat p{color:var(--text-muted); font-size:.93rem}

/* ============================================
   Pricing card
   ============================================ */
.pricing{background:var(--paper)}
.price-wrap{
  display:grid; grid-template-columns:minmax(0, 560px); justify-content:center;
  gap:2rem; margin-top:2.5rem;
}
.price-card{
  padding:2.25rem; border-radius:var(--radius-lg);
  background:linear-gradient(160deg, #fff, var(--paper-2));
  border:1px solid var(--line);
  box-shadow:var(--shadow-md);
  position:relative; overflow:hidden;
}
.price-card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:5px;
  background:linear-gradient(90deg, var(--amber), var(--amber-hot));
}
.price-card__lbl{
  display:inline-flex; padding:.3rem .75rem; border-radius:999px;
  background:var(--amber-soft); color:#92590E;
  font-size:.72rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  margin-bottom:1rem;
}
.price-card__num{
  font-family:'Geist'; font-size:clamp(2.5rem, 5vw, 3.75rem); font-weight:800;
  color:var(--ink); letter-spacing:-.035em; line-height:1;
  display:flex; align-items:baseline; gap:.25rem;
}
.price-card__num small{font-size:.4em; font-weight:500; color:var(--text-muted); letter-spacing:0}
.price-card__foot{color:var(--text-muted); font-size:.95rem; margin-top:.5rem}
.price-card ul{
  list-style:none; padding:0; margin:1.5rem 0 0;
  display:grid; gap:.55rem;
}
.price-card ul li{
  display:flex; align-items:flex-start; gap:.6rem;
  color:var(--ink); font-size:.96rem; font-weight:500;
}
.price-card ul svg{flex:0 0 18px; width:18px; height:18px; color:var(--amber); margin-top:3px}

/* ============================================
   Quote form
   ============================================ */
.quote-card{
  padding:2rem 1.75rem; border-radius:var(--radius-lg);
  background:var(--ink); color:#fff;
  border:1px solid var(--line-dark);
  box-shadow:var(--shadow-lg);
  position:relative; overflow:hidden;
}
.quote-card::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(400px 300px at 100% 0%, rgba(245,176,20,.2), transparent 60%);
  pointer-events:none;
}
.quote-card__head{margin-bottom:1.25rem; position:relative}
.quote-card h3{color:#fff; font-size:1.35rem; margin-bottom:.35rem}
.quote-card__sub{color:rgba(255,255,255,.65); font-size:.93rem}
.quote-form{display:grid; gap:.8rem; position:relative}
.field{display:grid; gap:.35rem}
.field label{
  font-size:.78rem; font-weight:600; color:rgba(255,255,255,.75);
  letter-spacing:.04em; text-transform:uppercase;
}
.field input, .field select, .field textarea{
  font-family:inherit; font-size:1rem; color:#fff;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px; padding:.75rem .85rem;
  transition:all .15s var(--ease);
  width:100%;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--amber);
  box-shadow:0 0 0 3px rgba(245,176,20,.2);
  background:rgba(255,255,255,.08);
}
.field input::placeholder, .field textarea::placeholder{color:rgba(255,255,255,.4)}
.field textarea{resize:vertical; min-height:80px}
.field select{appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%23ffffff' stroke-width='2' fill='none' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat; background-position:right 1rem center;
  padding-right:2.5rem;
}
.field-row{display:grid; grid-template-columns:1fr 1fr; gap:.8rem}
.quote-form button{
  margin-top:.5rem; padding:1rem 1.5rem; border-radius:12px;
  background:var(--amber); color:var(--ink);
  font-weight:700; font-size:1.02rem;
  box-shadow:0 12px 28px -10px rgba(245,176,20,.6), inset 0 -2px 0 rgba(10,22,40,.08);
  transition:transform .15s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  width:100%;
}
.quote-form button svg{flex:0 0 auto; width:18px; height:18px}
.quote-form button:hover{background:#FFC534; transform:translateY(-1px)}
.quote-form__foot{
  margin-top:.75rem; font-size:.78rem; color:rgba(255,255,255,.55);
  text-align:center;
}
.quote-form__or{
  margin:.75rem 0; text-align:center;
  color:rgba(255,255,255,.45); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase;
  position:relative;
}
.quote-form__or::before, .quote-form__or::after{
  content:""; position:absolute; top:50%; width:30%; height:1px;
  background:rgba(255,255,255,.12);
}
.quote-form__or::before{left:0}
.quote-form__or::after{right:0}
.quote-card .callbtn{
  display:flex; align-items:center; justify-content:center; gap:.6rem;
  padding:.9rem; border-radius:12px;
  background:rgba(255,255,255,.06); color:#fff;
  border:1px solid rgba(255,255,255,.12);
  font-weight:600; font-size:.98rem;
  transition:all .15s var(--ease);
}
.quote-card .callbtn:hover{background:rgba(255,255,255,.1); border-color:var(--amber); color:var(--amber)}
.quote-card .callbtn svg{width:18px; height:18px}
.quote-card__trust{
  display:flex; flex-wrap:wrap; gap:.5rem .9rem; margin-top:1rem;
  font-size:.78rem; color:rgba(255,255,255,.55);
}
.quote-card__trust span{display:inline-flex; align-items:center; gap:.3rem}
.quote-card__trust svg{width:12px;height:12px;color:var(--amber)}

/* ============================================
   Why us on service pages
   ============================================ */
.svc-why{background:var(--paper-2)}
.svc-why-grid{
  display:grid; grid-template-columns:1fr; gap:.75rem;
}
.svc-why-card{
  display:flex; align-items:flex-start; gap:1rem;
  padding:1.4rem 1.5rem; border-radius:var(--radius);
  background:#fff; border:1px solid var(--line);
  transition:all .2s var(--ease);
}
.svc-why-card:hover{transform:translateY(-2px); box-shadow:var(--shadow-md); border-color:transparent}
.svc-why-card__icon{
  width:42px; height:42px; flex:0 0 42px; border-radius:11px;
  background:var(--amber-soft); color:var(--amber-hot);
  display:grid; place-items:center;
}
.svc-why-card__icon svg{width:22px;height:22px}
.svc-why-card strong{display:block; color:var(--ink); font-weight:600; margin-bottom:.15rem}
.svc-why-card span{color:var(--text-muted); font-size:.92rem}

/* ============================================
   Related services
   ============================================ */
.related{background:var(--paper)}
.rel-grid{
  display:grid; grid-template-columns:1fr; gap:1rem;
}
.rel{
  position:relative; display:block;
  padding:1.75rem; border-radius:var(--radius-lg);
  background:var(--paper-2); border:1px solid var(--line);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
  overflow:hidden; isolation:isolate;
  color:inherit;
}
.rel:hover{transform:translateY(-4px); box-shadow:var(--shadow-md); background:#fff}
.rel__icon{
  width:52px; height:52px; border-radius:14px;
  display:grid; place-items:center; margin-bottom:1.25rem;
  background:var(--ink); color:var(--amber);
  transition:background .25s var(--ease), color .25s var(--ease);
}
.rel:hover .rel__icon{background:var(--amber); color:var(--ink)}
.rel__icon svg{width:24px;height:24px}
.rel h3{margin-bottom:.55rem; color:var(--ink)}
.rel p{color:var(--text-muted); font-size:.97rem}
.rel__arrow{
  position:absolute; top:1.75rem; right:1.75rem;
  width:34px; height:34px; border-radius:50%;
  background:var(--paper); border:1px solid var(--line);
  display:grid; place-items:center; color:var(--text-muted);
  transition:all .25s var(--ease);
}
.rel:hover .rel__arrow{background:var(--amber); border-color:var(--amber); color:var(--ink); transform:rotate(-45deg)}
.rel__arrow svg{width:16px;height:16px}

/* ============================================
   FAQ
   ============================================ */
.faq{background:var(--paper)}
.faq__list{max-width:820px; margin:0 auto}
details.faq__item{
  border-bottom:1px solid var(--line);
  padding:1.25rem 0;
}
details.faq__item summary{
  list-style:none; cursor:pointer;
  display:flex; justify-content:space-between; align-items:center;
  gap:1rem; font-weight:600; color:var(--ink); font-size:1.05rem;
}
details.faq__item summary::-webkit-details-marker{display:none}
details.faq__item summary .plus{
  width:32px; height:32px; flex:0 0 32px; border-radius:50%;
  background:var(--paper-2); border:1px solid var(--line);
  display:grid; place-items:center; color:var(--ink);
  transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
}
details.faq__item[open] summary .plus{background:var(--amber); border-color:var(--amber); transform:rotate(45deg)}
details.faq__item p{padding-top:.75rem; color:var(--text-muted); font-size:.98rem; max-width:720px}

/* ============================================
   CTA band
   ============================================ */
.cta{
  background:
    radial-gradient(600px 400px at 20% 0%, rgba(245,176,20,.18), transparent 60%),
    radial-gradient(600px 400px at 100% 100%, rgba(34,211,238,.1), transparent 60%),
    linear-gradient(135deg, var(--ink), var(--ink-2));
  color:#fff; text-align:center; overflow:hidden; position:relative;
}
.cta::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    repeating-linear-gradient(45deg, transparent 0, transparent 18px, rgba(255,255,255,.018) 18px, rgba(255,255,255,.018) 19px);
}
.cta h2{color:#fff; max-width:720px; margin:0 auto}
.cta p{color:rgba(255,255,255,.72); margin:1rem auto 2rem; max-width:560px; font-size:1.05rem}
.cta__phone{
  display:inline-flex; align-items:center; gap:1rem;
  background:var(--amber); color:var(--ink);
  padding:1.15rem 2rem; border-radius:999px;
  font-size:clamp(1.2rem,2.5vw,1.65rem);
  font-family:'Geist'; font-weight:700; letter-spacing:-.01em;
  box-shadow:0 15px 50px -10px rgba(245,176,20,.55);
  transition:transform .15s var(--ease), box-shadow .2s var(--ease);
}
.cta__phone:hover{transform:translateY(-2px); box-shadow:0 20px 60px -10px rgba(245,176,20,.75)}
.cta__phone svg{width:26px;height:26px}
.cta__sub{margin-top:1rem; font-size:.92rem; color:rgba(255,255,255,.6); position:relative}

/* ============================================
   Footer
   ============================================ */
.ftr{background:var(--ink); color:rgba(255,255,255,.7); padding:4rem 0 6rem}
.ftr__grid{display:grid; grid-template-columns:1fr; gap:2.5rem}
.ftr h4{
  font-family:'Geist'; font-size:.78rem; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; color:#fff; margin-bottom:1rem;
}
.ftr ul{list-style:none; padding:0; margin:0; display:grid; gap:.65rem}
.ftr a:hover{color:var(--amber)}
.ftr__brand p{margin-top:1rem; font-size:.95rem; max-width:340px}
.ftr__brand .logo{color:#fff}
.ftr__brand .logo__mark{background:linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.02)); border:1px solid var(--line-dark)}
.ftr__contact a{display:flex; align-items:center; gap:.6rem; color:#fff; font-weight:500}
.ftr__contact svg{width:16px; height:16px; color:var(--amber)}
.ftr__legal{
  border-top:1px solid var(--line-dark); margin-top:3rem; padding-top:1.5rem;
  display:flex; flex-wrap:wrap; gap:1rem; justify-content:space-between;
  font-size:.82rem; color:rgba(255,255,255,.45);
}

/* Mobile sticky call */
.mobile-cta{
  position:fixed; left:0; right:0; bottom:0; z-index:50;
  padding:.75rem 1rem calc(.75rem + env(safe-area-inset-bottom));
  background:rgba(10,22,40,.96);
  backdrop-filter:blur(14px);
  border-top:1px solid var(--line-dark);
  display:flex; gap:.5rem;
}
.mobile-cta__btn{flex:1; font-size:1rem; font-weight:700}

/* On-scroll reveal */
.reveal{opacity:0; transform:translateY(16px); transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.in{opacity:1; transform:none}

/* ============================================
   Thank-you screen (post-submit)
   ============================================ */
.quote-card[data-submitted="true"] .quote-form{display:none}
.quote-card[data-submitted="true"] .thankyou{display:flex}
.thankyou{
  display:none; flex-direction:column; align-items:center; text-align:center;
  padding:1rem 0; color:#fff; gap:.5rem;
}
.thankyou__icon{
  width:64px; height:64px; border-radius:50%;
  background:var(--amber); color:var(--ink);
  display:grid; place-items:center; margin-bottom:.5rem;
  box-shadow:0 10px 28px -8px rgba(245,176,20,.55);
}
.thankyou__icon svg{width:32px; height:32px}
.thankyou h3{color:#fff; font-size:1.35rem; margin-bottom:.25rem}
.thankyou p{color:rgba(255,255,255,.7); font-size:.95rem; max-width:320px; margin-bottom:.75rem}
.thankyou__call{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.75rem 1.25rem; border-radius:999px;
  background:var(--amber); color:var(--ink); font-weight:700;
}

/* ============================================
   Breakpoints
   ============================================ */
@media (min-width: 640px){
  .pain-grid{grid-template-columns:repeat(2,1fr)}
  .included-grid{grid-template-columns:repeat(2,1fr)}
  .svc-why-grid{grid-template-columns:repeat(2,1fr)}
  .rel-grid{grid-template-columns:repeat(3,1fr)}
  .ftr__grid{grid-template-columns:2fr 1fr 1fr 1fr}
}
@media (min-width: 900px){
  .nav{display:flex}
  .mobile-cta{display:none}
  body{padding-bottom:0}
  .svc-hero{padding:4.5rem 0 6rem}
  .svc-hero__grid{grid-template-columns:1.05fr .95fr; gap:4rem}
  .svc-steps{grid-template-columns:repeat(3,1fr)}
  section{padding:6rem 0}
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important; transition-duration:.01ms !important}
  .reveal{opacity:1;transform:none}
}

/* ============================================
   Logo — image variant (used on homepage + area pages)
   ============================================ */
.logo__full{display:block; height:44px; width:auto}
@media (min-width: 900px){ .logo__full{height:52px} }

/* ============================================
   Language pill — alternate class name used on area pages
   (aliases .langbtn behavior to .lang for consistency)
   ============================================ */
.lang{
  display:inline-flex; align-items:center; gap:.15rem;
  font-family:'Geist'; font-weight:600; font-size:.85rem;
  color:var(--text-muted); background:var(--paper-2);
  border:1px solid var(--line); border-radius:999px;
  padding:.35rem .7rem; cursor:pointer; transition:color .15s, border-color .15s;
}
.lang:hover{color:var(--ink); border-color:rgba(10,22,40,.18)}
.lang .lang__sep{opacity:.35;margin-inline:.1rem}
.lang [data-lang-active="true"]{color:var(--ink)}

/* ============================================
   Neighborhoods section (area pages)
   ============================================ */
.neighborhoods{background:var(--paper-2)}
.neigh-list{
  list-style:none; padding:0; margin:2rem 0 0;
  display:grid; grid-template-columns:repeat(2,1fr); gap:.6rem 1.5rem;
}
.neigh-list li{
  padding:.65rem 0 .65rem 1.5rem; position:relative;
  border-bottom:1px solid var(--line); font-weight:500; color:var(--ink);
}
.neigh-list li::before{
  content:""; position:absolute; left:0; top:50%; transform:translateY(-50%);
  width:8px; height:8px; border-radius:50%; background:var(--amber);
}
@media (min-width: 640px){ .neigh-list{grid-template-columns:repeat(3,1fr)} }
@media (min-width: 900px){ .neigh-list{grid-template-columns:repeat(4,1fr)} }

/* ============================================
   Final CTA section (area pages)
   ============================================ */
.final-cta{background:linear-gradient(135deg, var(--ink), var(--ink-2))}
.final-cta__box{
  padding:3.5rem 2rem; border-radius:var(--radius-lg);
  text-align:center; color:#fff;
}
.final-cta__box h2{color:#fff; margin:0 0 .75rem}
.final-cta__box p{color:rgba(255,255,255,.75); margin:0 0 2rem}
.final-cta__btns{display:flex; justify-content:center; flex-wrap:wrap; gap:.75rem}
