/* ======================================================================
   BILL TERMINATOR — shared stylesheet
   A bright funnel brand, part of the Unified Array family.
   Type: Barlow Condensed (display) · Barlow (body) · DM Mono (labels)
   ====================================================================== */

:root{
  /* surfaces */
  --bg:        #F6F8FC;
  --bg-soft:   #ECF1F8;
  --panel:     #FFFFFF;
  --ink:       #0B1018;   /* UA near-black */
  --ink-2:     #233246;
  --muted:     #5C6B82;
  --line:      #E2E8F2;
  --line-2:    #D3DCEA;

  /* brand */
  --accent:    #1B6EF3;   /* UA electric blue */
  --accent-2:  #4DABF7;
  --accent-ink:#FFFFFF;
  --accent-wash:#E9F1FE;
  --accent-deep:#0B1018;

  --kill:      #E5484D;   /* terminate red */
  --kill-wash: #FDECEC;
  --save:      #16A36A;   /* savings green */
  --save-wash: #E6F6EE;

  --maxw: 1180px;
  --radius: 16px;
  --radius-lg: 24px;
  --ease: cubic-bezier(.2,.7,.2,1);
  --shadow-sm: 0 1px 2px rgba(15,22,40,.05), 0 8px 24px -18px rgba(15,22,40,.3);
  --shadow: 0 1px 2px rgba(15,22,40,.05), 0 24px 50px -30px rgba(20,30,70,.4);
  --shadow-blue: 0 18px 40px -20px rgba(27,110,243,.55);
}

*,*::before,*::after{ box-sizing:border-box; }
html{
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
  overflow-x:hidden;
}
body{
  margin:0;
  overflow-x:hidden;
  background:var(--bg);
  color:var(--ink);
  font-family:"Barlow", system-ui, sans-serif;
  font-weight:400;
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }
::selection{ background:var(--accent); color:#fff; }

h1,h2,h3,h4{
  font-family:"Barlow Condensed", system-ui, sans-serif;
  font-weight:700;
  line-height:.98;
  margin:0;
  letter-spacing:-.005em;
  text-wrap:balance;
}
p{ margin:0; text-wrap:pretty; }

.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }

/* labels / eyebrows ---------------------------------------------------- */
.eyebrow{
  font-family:"DM Mono", monospace;
  font-weight:500;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--accent);
  display:inline-flex;
  align-items:center;
  gap:9px;
}
.eyebrow::before{
  content:"";
  width:22px; height:1px; background:var(--accent); opacity:.6;
}
.eyebrow.no-rule::before{ display:none; }
.eyebrow.kill{ color:var(--kill); }
.eyebrow.kill::before{ background:var(--kill); }

/* buttons -------------------------------------------------------------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55em;
  border-radius:999px; padding:14px 26px;
  font-family:"Barlow", sans-serif; font-weight:600; font-size:16px;
  letter-spacing:.01em; border:1.5px solid transparent;
  transition:.22s var(--ease); white-space:nowrap;
}
.btn svg{ width:18px; height:18px; }
.btn-primary{ background:var(--accent); color:var(--accent-ink); box-shadow:var(--shadow-blue); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 24px 48px -18px rgba(27,110,243,.7); }
.btn-dark{ background:var(--ink); color:#fff; }
.btn-dark:hover{ transform:translateY(-2px); background:#161E2B; }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn-ghost:hover{ border-color:var(--accent); color:var(--accent); }
.btn-kill{ background:var(--kill); color:#fff; box-shadow:0 18px 40px -20px var(--kill); }
.btn-kill:hover{ transform:translateY(-2px); }
.btn-lg{ padding:17px 32px; font-size:17px; }
.btn-block{ width:100%; }

/* reveal animation ----------------------------------------------------- */
[data-reveal]{
  opacity:0; transform:translateY(20px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
  will-change:opacity, transform;
}
[data-reveal].is-in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
}
@media print{ [data-reveal]{ opacity:1 !important; transform:none !important; } }

/* ============================ HEADER ================================== */
.announce{
  background:var(--ink); color:#fff; font-family:"DM Mono",monospace;
  font-size:12.5px; letter-spacing:.04em; text-align:center; padding:9px 20px;
}
.announce b{ color:var(--accent-2); font-weight:500; }

.site-header{ position:sticky; top:0; z-index:60; transition:.3s var(--ease); }
.site-header.is-scrolled{
  background:rgba(246,248,252,.82); backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);
}
.bar{ display:flex; align-items:center; gap:26px; height:72px; }

.brand{ display:flex; align-items:center; gap:12px; flex:none; }
.mark{ width:34px; height:34px; flex:none; }
.mark rect{ fill:var(--accent); }
.mark rect.k{ fill:var(--kill); }
.brand-text{ display:flex; flex-direction:column; line-height:1; }
.brand-name{
  font-family:"Barlow Condensed",sans-serif; font-weight:700; font-size:21px;
  letter-spacing:.02em; text-transform:uppercase;
}
.brand-sub{
  font-family:"DM Mono",monospace; font-size:8.5px; letter-spacing:.18em;
  color:var(--muted); text-transform:uppercase; margin-top:3px; white-space:nowrap;
}

nav.main{ margin-left:auto; display:flex; gap:28px; align-items:center; }
nav.main a{
  font-weight:500; font-size:15px; color:var(--muted); transition:.2s;
  position:relative; padding:4px 0;
}
nav.main a:hover, nav.main a.active{ color:var(--ink); }
nav.main a.active::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px;
  background:var(--accent); border-radius:2px;
}
.header-cta{ display:flex; align-items:center; gap:13px; margin-left:auto; }
.nav-toggle{ display:none; width:44px; height:44px; padding:0; border-radius:50%; }

/* mobile nav */
.mobile-nav{
  display:none; position:fixed; inset:0; z-index:100;
  background:rgba(246,248,252,.98); backdrop-filter:blur(8px);
  flex-direction:column; overflow-y:auto;
}
.mobile-nav-inner{
  padding:88px 28px 28px;
  display:flex; flex-direction:column; flex:1;
}
.mobile-nav-close{
  position:fixed; top:14px; right:16px; z-index:101;
  width:44px; height:44px; font-size:20px; padding:0;
  border-radius:50%; display:grid; place-items:center;
  background:var(--bg); border:1.5px solid var(--line-2);
  cursor:pointer; transition:.2s;
}
.mobile-nav-close:hover{ border-color:var(--accent); color:var(--accent); }
body.nav-open{ overflow:hidden; }
body.nav-open .mobile-nav{ display:flex; }
.mobile-nav a{ font-family:"Barlow Condensed",sans-serif; font-weight:600;
  font-size:30px; padding:14px 0; border-bottom:1px solid var(--line); text-transform:uppercase; }
.mobile-nav .btn{ margin-top:24px; }

/* ============================ HERO ==================================== */
.hero{ position:relative; overflow:hidden; }
.hero-visual{ min-width:0; max-width:100%; }
.hero-grid-bg{
  position:absolute; inset:0; z-index:0;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:54px 54px; opacity:.6;
  mask-image:radial-gradient(ellipse 78% 64% at 72% 8%, #000 22%, transparent 72%);
}
.hero-inner{
  position:relative; z-index:1; display:grid;
  grid-template-columns:1.06fr .94fr; gap:54px; align-items:center;
  padding:74px 0 92px;
}
.hero h1{ font-size:clamp(46px,6.4vw,84px); letter-spacing:-.015em; margin:20px 0 0; }
.hero h1 .kill{ position:relative; white-space:nowrap; color:var(--kill); }
.hero h1 .kill::after{
  content:""; position:absolute; left:-3px; right:-3px; top:52%; height:6px;
  background:var(--kill); border-radius:4px; transform:scaleX(0); transform-origin:left;
  animation:strike 1s var(--ease) .7s forwards;
}
@keyframes strike{ to{ transform:scaleX(1); } }
@media (prefers-reduced-motion: reduce){ .hero h1 .kill::after{ transform:scaleX(1); animation:none; } }
.hero .lead{ font-size:20px; color:var(--ink-2); margin-top:24px; max-width:34ch; }
.hero-actions{ display:flex; gap:14px; margin-top:34px; flex-wrap:wrap; }
.hero-note{
  margin-top:20px; font-family:"DM Mono",monospace; font-size:13px;
  color:var(--muted); display:flex; align-items:center; gap:9px; letter-spacing:.02em;
}
.dot{ width:8px; height:8px; border-radius:50%; background:var(--save);
  box-shadow:0 0 0 4px rgba(22,163,106,.18); flex:none; }

/* hero bill card */
.billcard{
  background:var(--panel); border:1px solid var(--line); border-radius:var(--radius-lg);
  box-shadow:var(--shadow); padding:26px; position:relative;
}
.bc-top{ display:flex; justify-content:space-between; align-items:center;
  padding-bottom:16px; border-bottom:1px solid var(--line); }
.bc-provider{ font-family:"Barlow Condensed",sans-serif; font-weight:700; font-size:21px; text-transform:uppercase; letter-spacing:.01em; }
.bc-tag{ font-family:"DM Mono",monospace; font-size:10.5px; color:var(--muted); letter-spacing:.08em; text-transform:uppercase; }
.bc-line{ display:flex; justify-content:space-between; align-items:center;
  padding:13px 0; border-bottom:1px dashed var(--line); font-size:15.5px; }
.bc-line .lbl{ color:var(--muted); }
.bc-line .old{ text-decoration:line-through; color:var(--muted); margin-right:10px; }
.bc-line .new{ font-weight:700; color:var(--save); font-family:"DM Mono",monospace; }
.bc-total{ display:flex; justify-content:space-between; align-items:flex-end; padding-top:18px; }
.bc-total .sm{ font-family:"DM Mono",monospace; font-size:11px; color:var(--muted); letter-spacing:.06em; text-transform:uppercase; }
.bc-total .big{ font-family:"Barlow Condensed",sans-serif; font-size:42px; font-weight:700; color:var(--accent); line-height:.9; margin-top:4px; }
.bc-was{ text-decoration:line-through; color:var(--muted); font-weight:600; font-family:"DM Mono",monospace; }
.bc-badge{
  position:absolute; top:-16px; right:24px; background:var(--save); color:#fff;
  font-family:"Barlow Condensed",sans-serif; font-weight:700; font-size:16px;
  padding:8px 16px; border-radius:999px; box-shadow:0 12px 24px -8px var(--save);
  animation:floaty 4s ease-in-out infinite; letter-spacing:.02em;
}
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-7px); } }
.float-chip{
  position:absolute; background:var(--panel); border:1px solid var(--line);
  border-radius:13px; box-shadow:var(--shadow-sm); padding:11px 15px;
  font-size:13.5px; font-weight:600; display:flex; gap:9px; align-items:center;
}
.float-chip .ic{ width:26px; height:26px; border-radius:8px; display:grid; place-items:center; font-size:14px; flex:none; }
.float-chip .ic.b{ background:var(--accent-wash); color:var(--accent); }
.float-chip .ic.g{ background:var(--save-wash); color:var(--save); }
.float-chip.c1{ left:-30px; top:34%; animation:floaty 5s ease-in-out infinite; }
.float-chip.c2{ right:-22px; bottom:6%; animation:floaty 4.4s ease-in-out .6s infinite; }
@media (prefers-reduced-motion: reduce){ .bc-badge,.float-chip{ animation:none; } }
@media (max-width: 1100px){ .float-chip{ display:none; } }

/* ======================= TRUST STRIP ================================== */
.trust{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--bg-soft); }
.trust .container{ display:flex; align-items:center; gap:30px; padding:20px 28px; flex-wrap:wrap; }
.trust .lbl{ font-family:"DM Mono",monospace; font-size:11px; color:var(--muted); letter-spacing:.1em; text-transform:uppercase; }
.logos{ display:flex; gap:26px; flex-wrap:wrap; align-items:center; margin-left:auto; }
.logo-slot{
  font-family:"Barlow Condensed",sans-serif; font-weight:700; font-size:17px;
  letter-spacing:.04em; text-transform:uppercase; color:var(--ink-2); opacity:.62;
}

/* ======================= SECTIONS ===================================== */
section.block{ padding:96px 0; }
.sec-head{ max-width:64ch; }
.sec-head h2{ font-size:clamp(34px,4.4vw,58px); margin-top:14px; }
.sec-head p{ color:var(--muted); font-size:18px; margin-top:16px; max-width:56ch; }
.sec-head.center{ margin:0 auto; text-align:center; }
.sec-head.center .eyebrow{ justify-content:center; }

/* dual value cards */
.dual{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:50px; }
.dcard{ border-radius:var(--radius-lg); padding:38px; border:1px solid var(--line); background:var(--panel); position:relative; overflow:hidden; }
.dcard.kill{ background:linear-gradient(180deg,var(--kill-wash),var(--panel) 60%); border-color:#F6D5D5; }
.dcard.run{ background:linear-gradient(180deg,var(--accent-wash),var(--panel) 60%); border-color:#CFE2FD; }
.dcard .num{ font-family:"DM Mono",monospace; font-weight:500; font-size:12px; letter-spacing:.14em; color:var(--muted); }
.dcard.kill .num{ color:var(--kill); }
.dcard.run .num{ color:var(--accent); }
.dcard h3{ font-size:30px; margin:14px 0 12px; text-transform:uppercase; }
.dcard > p{ color:var(--muted); }
.dcard ul{ list-style:none; padding:0; margin:22px 0 0; display:grid; gap:12px; }
.dcard li{ display:flex; gap:12px; align-items:flex-start; font-size:15.5px; }
.dcard li .ck{ flex:none; width:22px; height:22px; border-radius:50%; display:grid; place-items:center; font-size:12px; color:#fff; margin-top:2px; }
.dcard.kill .ck{ background:var(--kill); }
.dcard.run .ck{ background:var(--accent); }

/* services grid */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:50px; }
.svc{ background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); padding:30px; transition:.3s var(--ease); }
.svc:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:transparent; }
.svc .ic{ width:48px; height:48px; border-radius:13px; background:var(--accent-wash); color:var(--accent); display:grid; place-items:center; margin-bottom:18px; }
.svc .ic svg{ width:24px; height:24px; }
.svc h3{ font-size:22px; margin-bottom:8px; text-transform:uppercase; }
.svc p{ color:var(--muted); font-size:15px; }

/* steps */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; margin-top:54px; counter-reset:s; }
.step{ position:relative; padding-top:30px; }
.step::before{ counter-increment:s; content:counter(s,decimal-leading-zero);
  font-family:"DM Mono",monospace; font-weight:500; font-size:14px; color:var(--accent); letter-spacing:.08em; }
.step h3{ font-size:24px; margin:10px 0 8px; text-transform:uppercase; }
.step p{ color:var(--muted); font-size:15px; }
.step .ln{ position:absolute; top:36px; left:58px; right:-12px; height:1px; background:var(--line-2); }
.step:last-child .ln{ display:none; }

/* stats */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.stat{ text-align:center; }
.stat .v{ font-family:"Barlow Condensed",sans-serif; font-weight:700; font-size:clamp(46px,5.4vw,66px); line-height:.9; letter-spacing:-.01em; }
.stat .v span{ color:var(--accent); }
.stat .k{ font-family:"DM Mono",monospace; color:var(--muted); margin-top:12px; font-size:12px; letter-spacing:.06em; text-transform:uppercase; }

/* ===================== SAVINGS CALCULATOR ============================= */
.calc-wrap{
  display:grid; grid-template-columns:1fr 1fr; gap:0; border:1px solid var(--line);
  border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); background:var(--panel);
}
.calc-left{ padding:50px; background:linear-gradient(160deg,var(--ink),#141E2E); color:#fff; position:relative; overflow:hidden; }
.calc-left::after{ content:""; position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:34px 34px; mask-image:radial-gradient(circle at 80% 0%, #000, transparent 70%); pointer-events:none; }
.calc-left > *{ position:relative; }
.calc-left h2{ font-size:38px; color:#fff; }
.calc-left p{ color:rgba(220,228,240,.8); margin-top:14px; }
.calc{ margin-top:30px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.13); border-radius:var(--radius); padding:24px; }
.calc label{ font-family:"DM Mono",monospace; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:rgba(220,228,240,.75); }
.calc .inp{ display:flex; align-items:center; gap:8px; margin-top:12px; background:rgba(0,0,0,.28); border-radius:12px; padding:0 16px; border:1px solid rgba(255,255,255,.08); }
.calc .inp span{ color:rgba(220,228,240,.7); font-size:22px; font-family:"Barlow Condensed",sans-serif; font-weight:700; }
.calc .inp input{ background:transparent; border:0; outline:0; color:#fff; font-size:26px; font-family:"Barlow Condensed",sans-serif; font-weight:700; padding:14px 0; width:100%; }
.est{ margin-top:22px; opacity:.35; transition:.4s var(--ease); }
.est.is-active{ opacity:1; }
.est .k{ font-family:"DM Mono",monospace; font-size:11px; color:rgba(220,228,240,.7); letter-spacing:.08em; text-transform:uppercase; }
.est .v{ font-family:"Barlow Condensed",sans-serif; font-weight:700; font-size:52px; color:#4ED99B; line-height:1; margin-top:4px; }
.est .fine{ font-size:12.5px; color:rgba(180,192,210,.7); margin-top:8px; font-family:"DM Mono",monospace; letter-spacing:.02em; }
.calc-right{ padding:50px; display:flex; flex-direction:column; justify-content:center; }
.calc-right h3{ font-size:30px; text-transform:uppercase; }
.calc-right .sub{ color:var(--muted); margin:10px 0 26px; }
.calc-list{ list-style:none; padding:0; margin:0 0 28px; display:grid; gap:14px; }
.calc-list li{ display:flex; gap:13px; align-items:flex-start; font-size:16px; }
.calc-list .ck{ flex:none; width:24px; height:24px; border-radius:7px; background:var(--save-wash); color:var(--save); display:grid; place-items:center; font-size:13px; margin-top:1px; }
.calc-actions{ display:flex; gap:12px; flex-wrap:wrap; }

/* ===================== TESTIMONIALS =================================== */
.reviews-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.google-pill{ display:inline-flex; align-items:center; gap:10px; background:var(--panel); border:1px solid var(--line); border-radius:999px; padding:10px 18px; box-shadow:var(--shadow-sm); }
.google-pill .stars{ color:#F5A623; letter-spacing:1px; }
.google-pill b{ font-family:"Barlow Condensed",sans-serif; font-size:18px; }
.google-pill .sub{ font-family:"DM Mono",monospace; font-size:11px; color:var(--muted); letter-spacing:.04em; }
.reviews-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:46px; }
.review{ background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); padding:28px; display:flex; flex-direction:column; }
.review .stars{ color:#F5A623; letter-spacing:1px; font-size:15px; }
.review p{ margin:14px 0 20px; font-size:15.5px; color:var(--ink-2); }
.review .who{ display:flex; align-items:center; gap:12px; margin-top:auto; }
.review .av{ width:42px; height:42px; border-radius:50%; display:grid; place-items:center; color:#fff; font-family:"Barlow Condensed",sans-serif; font-weight:700; font-size:18px; flex:none; }
.review .nm{ font-weight:600; font-size:15px; }
.review .dt{ font-family:"DM Mono",monospace; font-size:11px; color:var(--muted); }

/* ===================== CTA BAND ======================================= */
.cta-band{
  background:linear-gradient(135deg,var(--accent),#2C57E0); color:#fff;
  border-radius:var(--radius-lg); padding:68px; text-align:center; position:relative; overflow:hidden;
}
.cta-band::before{ content:""; position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.1) 1px,transparent 1px);
  background-size:40px 40px; mask-image:radial-gradient(circle at 50% 0%, #000, transparent 72%); }
.cta-band > *{ position:relative; }
.cta-band h2{ font-size:clamp(36px,5vw,60px); color:#fff; text-transform:uppercase; }
.cta-band p{ color:rgba(255,255,255,.92); font-size:19px; margin:18px auto 0; max-width:48ch; }
.cta-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:34px; }
.cta-band .btn-primary{ background:#fff; color:var(--accent); box-shadow:0 20px 40px -16px rgba(0,0,0,.4); }
.cta-band .btn-primary:hover{ background:#fff; }
.cta-band .btn-ghost{ color:#fff; border-color:rgba(255,255,255,.5); }
.cta-band .btn-ghost:hover{ border-color:#fff; color:#fff; background:rgba(255,255,255,.08); }

/* ===================== PAGE HERO (inner pages) ======================== */
.page-hero{ position:relative; overflow:hidden; border-bottom:1px solid var(--line); }
.page-hero .container{ position:relative; z-index:1; padding:72px 28px 64px; }
.page-hero h1{ font-size:clamp(44px,6vw,80px); margin-top:18px; letter-spacing:-.015em; }
.page-hero p{ font-size:20px; color:var(--ink-2); margin-top:20px; max-width:52ch; }

/* ===================== CONTACT ======================================== */
.contact-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:24px; }
.contact-card{ background:var(--panel); border:1px solid var(--line); border-radius:var(--radius-lg); padding:42px; }
.contact-methods{ display:grid; gap:14px; margin-top:8px; }
.cmethod{ display:flex; align-items:center; gap:18px; padding:20px 22px; border:1px solid var(--line); border-radius:var(--radius); transition:.22s var(--ease); background:var(--bg); min-width:0; }
.cmethod:hover{ border-color:var(--accent); transform:translateX(4px); box-shadow:var(--shadow-sm); }
.cmethod .ic{ width:48px; height:48px; border-radius:13px; display:grid; place-items:center; flex:none; }
.cmethod .ic svg{ width:22px; height:22px; }
.cmethod .ic.blue{ background:var(--accent-wash); color:var(--accent); }
.cmethod .ic.green{ background:var(--save-wash); color:var(--save); }
.cmethod .ic.dark{ background:var(--ink); color:#fff; }
.cmethod .txt{ display:flex; flex-direction:column; gap:2px; min-width:0; flex:1; }
.cmethod .label{ font-family:"DM Mono",monospace; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); display:block; }
.cmethod .val{ font-family:"Barlow Condensed",sans-serif; font-weight:700; font-size:22px; text-transform:uppercase; line-height:1.1; display:block; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cmethod .arr{ margin-left:auto; color:var(--muted); transition:.2s; flex:none; }
.cmethod:hover .arr{ color:var(--accent); transform:translateX(3px); }
.info-row{ display:flex; justify-content:space-between; gap:16px; padding:16px 0; border-bottom:1px dashed var(--line); }
.info-row:last-child{ border-bottom:0; }
.info-row .k{ font-family:"DM Mono",monospace; font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); }
.info-row .vv{ font-weight:600; text-align:right; }

/* checklist (shared) */
.checklist{ list-style:none; padding:0; margin:0; display:grid; gap:13px; }
.checklist li{ display:flex; gap:13px; align-items:flex-start; font-size:16px; }
.checklist .ck{ flex:none; width:24px; height:24px; border-radius:7px; background:var(--accent-wash); color:var(--accent); display:grid; place-items:center; font-size:13px; margin-top:1px; }

/* ===================== FOOTER ========================================= */
footer.site{ background:var(--ink); color:#fff; padding:72px 0 36px; }
footer.site a{ color:rgba(220,228,240,.7); transition:.2s; }
footer.site a:hover{ color:#fff; }
.foot-top{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:34px; padding-bottom:44px; border-bottom:1px solid rgba(255,255,255,.1); }
.foot-brand .mark rect{ fill:var(--accent-2); }
.foot-brand .mark rect.k{ fill:var(--kill); }
.foot-brand .brand-name{ color:#fff; }
.foot-brand .brand-sub{ color:rgba(220,228,240,.55); }
.foot-brand p{ color:rgba(220,228,240,.6); font-size:15px; margin-top:18px; max-width:32ch; }
.foot-col h4{ font-family:"DM Mono",monospace; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:rgba(220,228,240,.5); margin-bottom:16px; font-weight:500; }
.foot-col a{ display:block; padding:6px 0; font-size:15px; }
.foot-socials{ display:flex; gap:10px; margin-top:20px; }
.foot-socials a{ width:38px; height:38px; border-radius:10px; border:1px solid rgba(255,255,255,.14); display:grid; place-items:center; }
.foot-socials a:hover{ background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.3); }
.foot-socials svg{ width:15px; height:15px; fill:currentColor; }
.foot-bottom{ display:flex; justify-content:space-between; align-items:center; padding-top:26px; color:rgba(220,228,240,.5); font-size:13.5px; flex-wrap:wrap; gap:12px; font-family:"DM Mono",monospace; letter-spacing:.02em; }
.foot-bottom a{ color:rgba(220,228,240,.6); }
.foot-end{ display:flex; gap:20px; align-items:center; flex-wrap:wrap; justify-content:flex-end; }
.foot-end .credit a{ color:rgba(220,228,240,.85); border-bottom:1px solid rgba(220,228,240,.25); padding-bottom:1px; transition:.2s; }
.foot-end .credit a:hover{ color:var(--accent-2); border-color:var(--accent-2); }

/* ===================== RESPONSIVE ===================================== */
@media (max-width: 940px){
  nav.main, .header-cta a.btn-ghost, .header-cta a.btn-primary{ display:none; }
  .header-cta .nav-toggle{ display:inline-flex; margin-left:auto; }
  .hero-inner{ grid-template-columns:1fr; gap:50px; padding:48px 0 64px; }
  .hero-visual{ order:2; }
  .dual, .calc-wrap, .contact-grid{ grid-template-columns:1fr; }
  .svc-grid, .reviews-grid{ grid-template-columns:1fr 1fr; }
  .steps{ grid-template-columns:1fr 1fr; }
  .step .ln{ display:none; }
  .stats{ grid-template-columns:1fr 1fr; gap:40px 24px; }
  .foot-top{ grid-template-columns:1fr 1fr; gap:30px; }
  .cta-band, .calc-left, .calc-right, .contact-card{ padding:38px 28px; }
}
@media (max-width: 700px){
  .bar{ gap:14px; }
  .header-cta{ gap:8px; }
  .hero-inner{ padding:40px 0 54px; }
  .float-chip.c1{ left:-10px; }
  .float-chip.c2{ right:-8px; }
  .cmethod .val{ font-size:18px; }
  .calc-wrap{ border-radius:var(--radius); }
}
@media (max-width: 560px){
  body{ font-size:16px; }
  .svc-grid, .reviews-grid{ grid-template-columns:1fr; }
  section.block{ padding:62px 0; }
  .float-chip{ display:none; }
  .foot-top{ grid-template-columns:1fr; }
  .reviews-head{ flex-direction:column; align-items:flex-start; }
  .container{ padding:0 18px; }
  .cmethod{ padding:16px 16px; gap:13px; }
  .cmethod .ic{ width:42px; height:42px; }
  .cmethod .val{ font-size:17px; }
  .contact-card{ padding:28px 20px; }
  .send-card{ padding:28px 20px; }
  .cta-band{ padding:42px 22px; }
  .bc-total .big{ font-size:34px; }
  .billcard{ padding:18px; }
  .hero h1{ letter-spacing:-.01em; }
  .steps{ grid-template-columns:1fr; }
}
