/* ==========================================================================
   Synergy Business Solutions — Design System
   Modern healthcare-tech / revenue cycle management
   Hand-built, dependency-free. (c) Synergy Business Solutions
   ========================================================================== */

/* ----- Self-hosted variable fonts ----- */
@font-face{
  font-family:"Inter var";
  font-style:normal;
  font-weight:100 900;
  font-display:swap;
  src:url("/assets/fonts/inter-var.woff2") format("woff2");
}
@font-face{
  font-family:"Manrope var";
  font-style:normal;
  font-weight:200 800;
  font-display:swap;
  src:url("/assets/fonts/manrope-var.woff2") format("woff2");
}

/* ----- Design tokens ----- */
:root{
  --brand-950:#072142;
  --brand-900:#0a2540;
  --brand-800:#0c3b6e;
  --brand-700:#0e4ea8;
  --brand-600:#1763cf;   /* primary */
  --brand-500:#2f86e8;
  --brand-400:#5aa6f0;
  --brand-200:#bcd8f7;
  --brand-100:#e6f0fc;
  --brand-50:#f3f8fe;

  --teal-700:#0a857d;
  --teal-600:#0e9c93;
  --teal-500:#13b3a8;    /* accent */
  --teal-400:#39c6bc;
  --teal-100:#d8f5f1;

  --ink:#0f1b2d;
  --body:#46566b;
  --muted:#6b7c93;
  --line:#e4ebf3;
  --line-2:#eef3f9;

  --surface:#ffffff;
  --surface-2:#f5f9fd;
  --surface-3:#eaf2fb;
  --dark:#0a2540;
  --dark-2:#0c2c50;

  --success:#15a34a;
  --warn:#e3953a;
  --danger:#d6453f;

  --r-xs:8px; --r-sm:10px; --r:16px; --r-lg:22px; --r-xl:28px; --r-pill:999px;

  --sh-xs:0 1px 2px rgba(13,38,73,.06);
  --sh-sm:0 2px 6px rgba(13,38,73,.07),0 1px 2px rgba(13,38,73,.06);
  --sh:0 10px 26px -10px rgba(13,38,73,.18);
  --sh-lg:0 28px 64px -22px rgba(10,40,80,.32);
  --sh-teal:0 16px 40px -16px rgba(14,156,147,.45);

  --container:1200px;
  --gutter:clamp(20px,5vw,40px);

  --t:.28s cubic-bezier(.4,0,.2,1);

  --ff-body:"Inter var",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --ff-head:"Manrope var","Inter var",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}

/* ----- Reset / base ----- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:96px}
body{
  font-family:var(--ff-body);
  color:var(--body);
  background:var(--surface);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,video{display:block;max-width:100%;height:auto}
/* default inline icon size (component rules below override where needed) */
svg{display:inline-block;vertical-align:middle;width:1.1em;height:1.1em;flex:none}
a{color:var(--brand-700);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--brand-600)}
ul,ol{padding:0;list-style:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,textarea,select{font:inherit;color:inherit}
h1,h2,h3,h4,h5{font-family:var(--ff-head);color:var(--ink);line-height:1.12;font-weight:700;letter-spacing:-.02em}
strong{color:var(--ink);font-weight:650}
:focus-visible{outline:3px solid var(--brand-400);outline-offset:2px;border-radius:4px}

/* ----- Layout ----- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.container-tight{max-width:920px}
.section{padding-block:clamp(64px,8vw,108px)}
.section-sm{padding-block:clamp(48px,6vw,72px)}
.bg-soft{background:var(--surface-2)}
.bg-mesh{background:
  radial-gradient(1100px 480px at 12% -8%,var(--brand-50),transparent 60%),
  radial-gradient(900px 420px at 98% 0%,var(--teal-100),transparent 55%),
  var(--surface);}
.bg-dark{background:
  radial-gradient(900px 500px at 85% -20%,rgba(19,179,168,.20),transparent 60%),
  radial-gradient(700px 460px at 5% 110%,rgba(47,134,232,.22),transparent 60%),
  linear-gradient(160deg,var(--brand-950),var(--brand-900));
  color:#cfe0f1;}
.bg-dark h1,.bg-dark h2,.bg-dark h3,.bg-dark h4{color:#fff}

.grid{display:grid;gap:clamp(18px,2.4vw,30px)}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}

/* ----- Typography helpers ----- */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--ff-head);font-weight:700;font-size:.78rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--teal-700);
}
.eyebrow::before{content:"";width:26px;height:2px;background:linear-gradient(90deg,var(--teal-500),var(--brand-500));border-radius:2px}
.bg-dark .eyebrow{color:var(--teal-400)}
.bg-dark .eyebrow::before{background:linear-gradient(90deg,var(--teal-400),var(--brand-400))}
.h-xxl{font-size:clamp(2.3rem,5.2vw,3.9rem);letter-spacing:-.03em;line-height:1.04}
.h-xl{font-size:clamp(1.95rem,3.6vw,2.85rem)}
.h-lg{font-size:clamp(1.5rem,2.4vw,2rem)}
.lead{font-size:clamp(1.07rem,1.5vw,1.27rem);color:var(--body);line-height:1.6}
.bg-dark .lead{color:#bcd0e6}
.muted{color:var(--muted)}
.measure{max-width:62ch}
.center{text-align:center}
.center .eyebrow{justify-content:center}
.center .measure{margin-inline:auto}
.text-grad{background:linear-gradient(100deg,var(--brand-500),var(--teal-500));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ----- Buttons ----- */
.btn{
  --bg:var(--brand-600);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  padding:.92em 1.5em;border-radius:var(--r-sm);
  font-family:var(--ff-head);font-weight:700;font-size:.98rem;letter-spacing:-.01em;
  background:var(--bg);color:var(--fg);
  box-shadow:var(--sh-sm);transition:transform var(--t),box-shadow var(--t),background var(--t),color var(--t);
  white-space:nowrap;text-align:center;line-height:1.1;
}
.btn svg{width:1.05em;height:1.05em;transition:transform var(--t)}
.btn:hover{transform:translateY(-2px);box-shadow:var(--sh);color:#fff}
.btn:hover svg{transform:translateX(3px)}
.btn-primary{background:linear-gradient(135deg,var(--brand-600),var(--brand-700));color:#fff}
.btn-accent{background:linear-gradient(135deg,var(--teal-500),var(--teal-600));color:#fff;box-shadow:var(--sh-teal)}
.btn-accent:hover{color:#fff}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.28);box-shadow:none}
.btn-ghost:hover{background:rgba(255,255,255,.16);color:#fff}
.btn-outline{background:#fff;color:var(--brand-700);border:1.5px solid var(--brand-200);box-shadow:var(--sh-xs)}
.btn-outline:hover{border-color:var(--brand-500);color:var(--brand-700)}
.btn-lg{padding:1.05em 1.85em;font-size:1.05rem}
.btn-sm{padding:.6em 1em;font-size:.9rem}
.btn-block{display:flex;width:100%}
.btn-row{display:flex;flex-wrap:wrap;gap:14px}

.link-arrow{display:inline-flex;align-items:center;gap:.4em;font-family:var(--ff-head);font-weight:700;font-size:.96rem;color:var(--brand-700)}
.link-arrow svg{width:1em;height:1em;transition:transform var(--t)}
.link-arrow:hover svg{transform:translateX(4px)}

/* ----- Chips / badges ----- */
.chip{display:inline-flex;align-items:center;gap:.5em;padding:.45em .85em;border-radius:var(--r-pill);
  background:var(--brand-50);color:var(--brand-700);border:1px solid var(--brand-100);
  font-family:var(--ff-head);font-weight:650;font-size:.82rem}
.chip svg{width:1.05em;height:1.05em}
.chip-teal{background:var(--teal-100);color:var(--teal-700);border-color:#bfeee8}
.chip-light{background:rgba(255,255,255,.1);color:#dbe9fb;border-color:rgba(255,255,255,.2)}

/* ==========================================================================
   Announcement bar + Header
   ========================================================================== */
.announce{background:linear-gradient(90deg,var(--brand-900),var(--brand-800));color:#dbe9fb;font-size:.86rem}
.announce .container{display:flex;align-items:center;justify-content:center;gap:18px;padding-block:9px;flex-wrap:wrap;text-align:center}
.announce strong{color:#fff}
.announce .sep{width:5px;height:5px;border-radius:50%;background:var(--teal-400);opacity:.8}
.announce a{color:#fff;font-weight:650;border-bottom:1px solid rgba(255,255,255,.4)}
.announce a:hover{color:var(--teal-400)}

.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.86);backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;transition:box-shadow var(--t),border-color var(--t),background var(--t)}
.site-header.scrolled{box-shadow:0 8px 30px -16px rgba(13,38,73,.28);border-bottom-color:var(--line);background:rgba(255,255,255,.95)}
.nav{display:flex;align-items:center;gap:24px;height:74px}
.brand{display:flex;align-items:center;gap:11px;flex-shrink:0}
.brand .logo{height:38px;width:auto}
.brand-txt{display:flex;flex-direction:column;line-height:1}
.brand-txt b{font-family:var(--ff-head);font-weight:800;font-size:1.16rem;color:var(--ink);letter-spacing:-.02em}
.brand-txt span{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:3px}

.nav-menu{display:flex;align-items:center;gap:2px;margin-left:8px}
.nav-menu>li{position:relative}
.nav-link{display:inline-flex;align-items:center;gap:.35em;padding:.7em .85em;border-radius:var(--r-sm);
  font-family:var(--ff-head);font-weight:650;font-size:.96rem;color:#2c3a4d;transition:color var(--t),background var(--t)}
.nav-link:hover{color:var(--brand-700);background:var(--brand-50)}
.nav-link>svg,.nav-link .caret svg{width:.7em;height:.7em;opacity:.6;flex:none;transition:transform var(--t);position:relative;top:1px}
.nav-link .caret{display:inline-flex;align-items:center}
.has-mega:hover .nav-link svg,.has-mega:focus-within .nav-link svg,
.has-dd:hover .nav-link svg,.has-dd:focus-within .nav-link svg{transform:rotate(180deg)}
.nav-spacer{flex:1}
.nav-cta{display:flex;align-items:center;gap:12px}
.nav-phone{display:inline-flex;align-items:center;gap:.5em;font-family:var(--ff-head);font-weight:700;color:var(--ink);font-size:.96rem}
.nav-phone svg{width:1.1em;height:1.1em;color:var(--brand-600)}
.nav-phone small{display:block;font-size:.66rem;font-weight:600;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}

/* Mega / dropdown menus */
.mega,.dropdown{
  position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(10px);
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-lg);
  padding:14px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity var(--t),transform var(--t);z-index:70;
}
.has-mega:hover .mega,.has-mega:focus-within .mega,
.has-dd:hover .dropdown,.has-dd:focus-within .dropdown{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.dropdown{left:0;transform:translateX(0) translateY(10px);min-width:250px}
.has-dd:hover .dropdown,.has-dd:focus-within .dropdown{transform:translateX(0) translateY(0)}
.mega{width:min(760px,90vw)}
.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.mega-foot{margin-top:8px;padding:14px 14px 6px;border-top:1px solid var(--line-2);display:flex;align-items:center;justify-content:space-between;gap:12px}
.menu-item{display:flex;gap:12px;padding:11px 12px;border-radius:var(--r-sm);transition:background var(--t)}
.menu-item:hover{background:var(--brand-50)}
.menu-item .mi-ic{flex-shrink:0;width:38px;height:38px;border-radius:10px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--brand-50),var(--teal-100));color:var(--brand-700)}
.menu-item .mi-ic svg{width:19px;height:19px}
.menu-item b{display:block;font-family:var(--ff-head);font-size:.95rem;color:var(--ink);font-weight:700;line-height:1.2}
.menu-item span{display:block;font-size:.82rem;color:var(--muted);margin-top:2px;line-height:1.4}

/* Mobile */
.nav-toggle{display:none;width:46px;height:46px;border-radius:var(--r-sm);border:1px solid var(--line);
  background:#fff;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.nav-toggle span{display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:transform var(--t),opacity var(--t)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-drawer{position:fixed;inset:0 0 0 auto;width:min(420px,100%);background:#fff;z-index:90;
  transform:translateX(100%);transition:transform .36s cubic-bezier(.4,0,.2,1);overflow-y:auto;box-shadow:var(--sh-lg);
  padding:22px 22px 40px;display:flex;flex-direction:column;gap:6px}
.mobile-drawer.open{transform:translateX(0)}
.scrim{position:fixed;inset:0;background:rgba(8,24,48,.5);opacity:0;visibility:hidden;transition:opacity var(--t);z-index:80;backdrop-filter:blur(2px)}
.scrim.open{opacity:1;visibility:visible}
.md-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.md-close{width:44px;height:44px;border-radius:var(--r-sm);border:1px solid var(--line);display:grid;place-items:center}
.md-sec{border-top:1px solid var(--line-2);padding-top:6px;margin-top:6px}
.md-acc>button{display:flex;width:100%;align-items:center;justify-content:space-between;padding:13px 8px;
  font-family:var(--ff-head);font-weight:700;color:var(--ink);font-size:1.02rem}
.md-acc>button svg{width:1.1em;height:1.1em;transition:transform var(--t);color:var(--muted)}
.md-acc[open]>button svg{transform:rotate(180deg)}
.md-panel{display:flex;flex-direction:column;padding:2px 8px 12px}
.md-panel a{padding:10px 10px;border-radius:8px;color:var(--body);font-weight:550}
.md-panel a:hover{background:var(--brand-50);color:var(--brand-700)}
.md-link{padding:13px 8px;font-family:var(--ff-head);font-weight:700;color:var(--ink);font-size:1.02rem;border-radius:8px}
.md-link:hover{background:var(--brand-50);color:var(--brand-700)}

/* ==========================================================================
   Hero
   ========================================================================== */
.hero{position:relative;overflow:hidden;color:#dbe9fb;
  background:
    radial-gradient(820px 520px at 88% -10%,rgba(19,179,168,.28),transparent 58%),
    radial-gradient(700px 500px at -5% 18%,rgba(47,134,232,.30),transparent 55%),
    linear-gradient(155deg,var(--brand-950) 8%,var(--brand-800) 60%,#0f4a8c);
}
.hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:30px 30px;mask-image:linear-gradient(180deg,#000,transparent 78%);opacity:.7}
.hero .container{position:relative;z-index:2}
.hero-grid{display:grid;grid-template-columns:1.06fr .94fr;gap:clamp(34px,5vw,70px);align-items:center;
  padding-block:clamp(56px,7vw,96px)}
.hero h1{color:#fff;font-size:clamp(2.4rem,5vw,4rem);letter-spacing:-.035em;line-height:1.02}
.hero h1 em{font-style:normal;color:var(--teal-400)}
.hero .lead{color:#bcd4ee;margin-top:20px;max-width:54ch}
.hero-cta{margin-top:30px}
.hero-trust{margin-top:30px;display:flex;flex-wrap:wrap;gap:10px 18px;align-items:center;color:#a9c4e2;font-size:.9rem}
.hero-trust .tg{display:inline-flex;align-items:center;gap:.5em;font-weight:600}
.hero-trust svg{width:1.15em;height:1.15em;color:var(--teal-400)}

/* Hero visual: floating dashboard card */
.hero-visual{position:relative}
.dash{background:linear-gradient(180deg,#ffffff,#f4f9ff);border-radius:var(--r-lg);box-shadow:var(--sh-lg);
  border:1px solid rgba(255,255,255,.6);overflow:hidden}
.dash-top{display:flex;align-items:center;gap:8px;padding:13px 16px;background:#fff;border-bottom:1px solid var(--line)}
.dash-dot{width:10px;height:10px;border-radius:50%;background:#dbe3ec}
.dash-dot:nth-child(1){background:#ff6058}.dash-dot:nth-child(2){background:#ffbd2e}.dash-dot:nth-child(3){background:#28c840}
.dash-title{margin-left:8px;font-family:var(--ff-head);font-weight:700;font-size:.86rem;color:var(--ink)}
.dash-body{padding:18px}
.dash-kpis{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.kpi{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:13px 14px}
.kpi .lab{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700}
.kpi .val{font-family:var(--ff-head);font-weight:800;font-size:1.5rem;color:var(--ink);line-height:1.1;margin-top:5px}
.kpi .val small{font-size:.8rem;color:var(--success);font-weight:700}
.kpi.accent{background:linear-gradient(135deg,var(--brand-700),var(--brand-600));border:0}
.kpi.accent .lab{color:#bcd8f7}.kpi.accent .val{color:#fff}.kpi.accent .val small{color:var(--teal-400)}
.dash-chart{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:14px 14px 8px}
.dash-chart .ct{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.dash-chart .ct b{font-family:var(--ff-head);font-size:.86rem;color:var(--ink)}
.dash-chart .ct span{font-size:.74rem;color:var(--success);font-weight:700}
.bars{display:flex;align-items:flex-end;gap:9px;height:84px}
.bars i{flex:1;border-radius:5px 5px 0 0;background:linear-gradient(180deg,var(--brand-400),var(--brand-600));opacity:.85}
.bars i:last-child{background:linear-gradient(180deg,var(--teal-400),var(--teal-600));opacity:1}
.float-badge{position:absolute;background:#fff;border-radius:14px;box-shadow:var(--sh-lg);padding:12px 15px;
  display:flex;align-items:center;gap:11px;border:1px solid var(--line)}
.float-badge .fb-ic{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;color:#fff;
  background:linear-gradient(135deg,var(--teal-500),var(--teal-600))}
.float-badge .fb-ic svg{width:20px;height:20px}
.float-badge b{font-family:var(--ff-head);font-size:1.05rem;color:var(--ink);line-height:1}
.float-badge span{font-size:.74rem;color:var(--muted)}
.float-badge.one{top:-22px;right:-14px}
.float-badge.two{bottom:-22px;left:-18px}

/* Hero wave divider */
.hero-wave{position:relative;z-index:2;line-height:0}
.hero-wave svg{width:100%;height:auto;display:block}

/* ==========================================================================
   Logo / trust strip
   ========================================================================== */
.trust-strip{padding-block:30px;border-bottom:1px solid var(--line)}
.trust-strip p{text-align:center;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:18px}
.logo-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:18px 38px}
.logo-row .lg{display:inline-flex;align-items:center;gap:.5em;color:#7c8ba0;font-family:var(--ff-head);font-weight:800;font-size:1.05rem;
  opacity:.8;filter:grayscale(1);transition:opacity var(--t),filter var(--t)}
.logo-row .lg:hover{opacity:1;filter:grayscale(0);color:var(--brand-700)}
.logo-row .lg svg{width:1.3em;height:1.3em}

/* ==========================================================================
   Stat band
   ========================================================================== */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,26px)}
.stat{position:relative;padding:6px 4px}
.stat .num{font-family:var(--ff-head);font-weight:800;font-size:clamp(2.1rem,3.6vw,3rem);line-height:1;letter-spacing:-.03em;
  background:linear-gradient(120deg,var(--brand-600),var(--teal-500));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .lab{margin-top:10px;font-weight:600;color:var(--body);font-size:.98rem;line-height:1.4}
.bg-dark .stat .num{background:linear-gradient(120deg,#7fc4ff,var(--teal-400));-webkit-background-clip:text;background-clip:text;color:transparent}
.bg-dark .stat .lab{color:#bcd0e6}
.statband.bordered .stat{border-left:1px solid var(--line);padding-left:24px}
.bg-dark .statband.bordered .stat{border-left-color:rgba(255,255,255,.14)}

/* ==========================================================================
   Section header
   ========================================================================== */
.sec-head{max-width:720px;margin-bottom:clamp(34px,4vw,52px)}
.sec-head.center{margin-inline:auto}
.sec-head h2{margin-top:14px}
.sec-head p{margin-top:16px}

/* ==========================================================================
   Cards: service / feature
   ========================================================================== */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);height:100%;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh);border-color:var(--brand-200)}
.card .ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;margin-bottom:18px;
  background:linear-gradient(135deg,var(--brand-50),var(--teal-100));color:var(--brand-700);transition:background var(--t),color var(--t)}
.card .ic svg{width:25px;height:25px}
.card:hover .ic{background:linear-gradient(135deg,var(--brand-600),var(--brand-700));color:#fff}
.card h3{font-size:1.16rem;margin-bottom:8px}
.card p{font-size:.96rem;margin-bottom:16px;flex:1}
.card .link-arrow{margin-top:auto}
.card-flat{box-shadow:none}
.card-link{cursor:pointer}

/* Feature row (icon + text) */
.feature{display:flex;gap:16px}
.feature .ic{flex-shrink:0;width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--brand-50),var(--teal-100));color:var(--brand-700)}
.feature .ic svg{width:22px;height:22px}
.feature h3{font-size:1.08rem;margin-bottom:5px}
.feature p{font-size:.95rem}
.bg-dark .feature .ic{background:rgba(255,255,255,.08);color:var(--teal-400)}
.bg-dark .feature p{color:#aebfd4}

/* Checklist */
.checks{display:grid;gap:13px}
.checks li{display:flex;gap:12px;align-items:flex-start;font-size:1rem}
.checks li svg{flex-shrink:0;width:22px;height:22px;color:var(--teal-600);margin-top:2px}
.bg-dark .checks li svg{color:var(--teal-400)}
.checks.two{grid-template-columns:1fr 1fr}
.checks strong{color:inherit}

/* ==========================================================================
   Process / steps
   ========================================================================== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.4vw,28px);counter-reset:step}
.step{position:relative;padding-top:8px}
.step .sn{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;margin-bottom:16px;
  font-family:var(--ff-head);font-weight:800;font-size:1.2rem;color:#fff;
  background:linear-gradient(135deg,var(--brand-600),var(--brand-700));box-shadow:var(--sh-sm)}
.step:nth-child(2) .sn{background:linear-gradient(135deg,var(--brand-500),var(--brand-600))}
.step:nth-child(3) .sn{background:linear-gradient(135deg,var(--teal-600),var(--brand-600))}
.step:nth-child(4) .sn{background:linear-gradient(135deg,var(--teal-500),var(--teal-600))}
.step h3{font-size:1.1rem;margin-bottom:7px}
.step p{font-size:.95rem}
.step:not(:last-child)::after{content:"";position:absolute;top:24px;left:60px;right:-14px;height:2px;
  background:linear-gradient(90deg,var(--brand-200),transparent);border-radius:2px}

/* ==========================================================================
   Split media panel
   ========================================================================== */
.panel{background:linear-gradient(160deg,var(--brand-900),var(--brand-800));border-radius:var(--r-lg);
  padding:clamp(26px,3vw,40px);color:#cfe0f1;box-shadow:var(--sh-lg);position:relative;overflow:hidden}
.panel::after{content:"";position:absolute;width:280px;height:280px;border-radius:50%;right:-90px;top:-90px;
  background:radial-gradient(circle,rgba(19,179,168,.4),transparent 70%)}
.panel h3{color:#fff}
.media-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;box-shadow:var(--sh)}

/* Reports/mini chart visual */
.report{display:grid;gap:14px}
.report .row{display:flex;align-items:center;gap:14px}
.report .row .nm{width:120px;font-size:.86rem;font-weight:650;color:var(--ink);font-family:var(--ff-head)}
.report .track{flex:1;height:11px;border-radius:6px;background:var(--surface-3);overflow:hidden}
.report .track i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--brand-500),var(--teal-500))}
.report .pc{width:46px;text-align:right;font-weight:700;color:var(--brand-700);font-size:.86rem}

/* ==========================================================================
   Specialties
   ========================================================================== */
.spec-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.spec{display:flex;align-items:center;gap:12px;padding:16px 16px;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-sm);transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.spec:hover{transform:translateY(-3px);box-shadow:var(--sh-sm);border-color:var(--brand-200)}
.spec .si{width:40px;height:40px;border-radius:10px;flex-shrink:0;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--brand-50),var(--teal-100));color:var(--brand-700)}
.spec .si svg{width:20px;height:20px}
.spec b{font-family:var(--ff-head);font-size:.98rem;color:var(--ink);font-weight:700}

/* ==========================================================================
   Testimonials
   ========================================================================== */
.tst{position:relative}
.tst-track{display:flex;transition:transform .55s cubic-bezier(.45,0,.15,1)}
.tst-slide{min-width:100%;padding:4px}
.tst-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(28px,4vw,48px);
  box-shadow:var(--sh-sm);max-width:880px;margin-inline:auto;text-align:center;position:relative}
.tst-card .quote{font-size:4rem;line-height:.5;color:var(--brand-200);font-family:Georgia,serif;height:34px}
.tst-stars{display:flex;gap:4px;justify-content:center;color:#f2b13c;margin-bottom:18px}
.tst-stars svg{width:20px;height:20px}
.tst-card blockquote{font-size:clamp(1.1rem,1.8vw,1.4rem);color:var(--ink);font-family:var(--ff-head);font-weight:500;
  line-height:1.5;letter-spacing:-.01em}
.tst-meta{margin-top:22px;font-size:.95rem;color:var(--muted)}
.tst-meta b{display:block;color:var(--ink);font-family:var(--ff-head);font-size:1rem}
.tst-dots{display:flex;gap:9px;justify-content:center;margin-top:26px}
.tst-dots button{width:9px;height:9px;border-radius:50%;background:var(--brand-200);transition:width var(--t),background var(--t)}
.tst-dots button[aria-current="true"]{width:30px;border-radius:6px;background:var(--brand-600)}
.tst-nav{display:flex;gap:10px;justify-content:center;margin-top:14px}
.tst-nav button{width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:#fff;display:grid;place-items:center;
  color:var(--ink);transition:border-color var(--t),color var(--t),transform var(--t)}
.tst-nav button:hover{border-color:var(--brand-500);color:var(--brand-700);transform:translateY(-2px)}
.tst-nav svg{width:20px;height:20px}

/* ==========================================================================
   CTA band
   ========================================================================== */
.cta{position:relative;overflow:hidden;border-radius:clamp(20px,3vw,32px);
  background:
   radial-gradient(620px 360px at 88% -30%,rgba(19,179,168,.35),transparent 60%),
   radial-gradient(560px 360px at 0% 130%,rgba(47,134,232,.30),transparent 60%),
   linear-gradient(150deg,var(--brand-900),var(--brand-800));
  color:#cfe0f1;padding:clamp(34px,5vw,64px);text-align:center}
.cta::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:26px 26px;opacity:.6}
.cta>*{position:relative}
.cta h2{color:#fff;margin-bottom:14px}
.cta .lead{color:#c2d6ee;max-width:60ch;margin-inline:auto}
.cta .btn-row{justify-content:center;margin-top:30px}
.cta-fine{margin-top:18px;font-size:.86rem;color:#9fbbdb}

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer{background:linear-gradient(180deg,var(--brand-950),#061a34);color:#a7bdd6;padding-top:clamp(54px,6vw,80px)}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:clamp(28px,4vw,48px);padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand .brand-txt b{color:#fff}.footer-brand .brand-txt span{color:#7f9bbd}
.footer-brand p{margin-top:16px;font-size:.94rem;color:#9fb6d2;max-width:38ch}
.foot-social{display:flex;gap:10px;margin-top:18px}
.foot-social a{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:rgba(255,255,255,.07);
  color:#cfe0f1;border:1px solid rgba(255,255,255,.1);transition:background var(--t),transform var(--t)}
.foot-social a:hover{background:var(--brand-600);color:#fff;transform:translateY(-2px)}
.foot-social svg{width:18px;height:18px}
.footer-col h4{color:#fff;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px;font-weight:700}
.footer-col li{margin-bottom:11px}
.footer-col a{color:#a7bdd6;font-size:.95rem}
.footer-col a:hover{color:#fff}
.foot-contact li{display:flex;gap:11px;align-items:flex-start;margin-bottom:14px;font-size:.95rem;color:#bcd0e6}
.foot-contact svg{flex-shrink:0;width:19px;height:19px;color:var(--teal-400);margin-top:2px}
.foot-contact a{color:#bcd0e6}.foot-contact a:hover{color:#fff}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-block:24px;font-size:.86rem;color:#7f9bbd}
.footer-bottom .fb-links{display:flex;gap:20px;flex-wrap:wrap}
.footer-bottom a{color:#7f9bbd}.footer-bottom a:hover{color:#cfe0f1}

/* ==========================================================================
   Page hero (interior)
   ========================================================================== */
.page-hero{position:relative;overflow:hidden;color:#dbe9fb;padding-block:clamp(48px,6vw,86px);
  background:
   radial-gradient(700px 380px at 92% -30%,rgba(19,179,168,.26),transparent 60%),
   radial-gradient(620px 420px at -5% 10%,rgba(47,134,232,.26),transparent 58%),
   linear-gradient(155deg,var(--brand-950),var(--brand-800))}
.page-hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:28px 28px;mask-image:linear-gradient(180deg,#000,transparent 85%);opacity:.6}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{color:#fff;font-size:clamp(2.1rem,4vw,3.2rem);max-width:18ch}
.page-hero .lead{color:#bcd4ee;margin-top:16px;max-width:60ch}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.86rem;color:#9fbbdb;margin-bottom:18px;flex-wrap:wrap}
.breadcrumb a{color:#bcd4ee}.breadcrumb a:hover{color:#fff}
.breadcrumb svg{width:14px;height:14px;opacity:.6}
.breadcrumb [aria-current]{color:#fff;font-weight:600}

/* prose for content pages */
.prose{max-width:760px}
.prose h2{font-size:clamp(1.5rem,2.4vw,2rem);margin:40px 0 14px}
.prose h3{font-size:1.25rem;margin:30px 0 10px}
.prose p{margin-bottom:16px}
.prose ul{margin:0 0 18px;display:grid;gap:11px}
.prose ul li{position:relative;padding-left:30px}
.prose ul li::before{content:"";position:absolute;left:0;top:7px;width:18px;height:18px;border-radius:50%;
  background:var(--teal-100);box-shadow:inset 0 0 0 1px #b7ebe4}
.prose ul li::after{content:"";position:absolute;left:6px;top:11px;width:6px;height:6px;border-radius:50%;background:var(--teal-600)}
.prose strong{color:var(--ink)}
.prose .lead{margin-bottom:20px}

/* sidebar layout for service pages */
.with-aside{display:grid;grid-template-columns:1fr 340px;gap:clamp(32px,4vw,60px);align-items:start}
.aside{position:sticky;top:96px;display:grid;gap:18px}
.aside-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px;box-shadow:var(--sh-sm)}
.aside-card.dark{background:linear-gradient(160deg,var(--brand-900),var(--brand-800));color:#cfe0f1;border:0}
.aside-card.dark h3{color:#fff}
.aside-card h3{font-size:1.1rem;margin-bottom:8px}
.aside-card p{font-size:.92rem;margin-bottom:16px}
.aside-nav a{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:11px 13px;border-radius:10px;
  font-family:var(--ff-head);font-weight:600;font-size:.92rem;color:var(--body);transition:background var(--t),color var(--t)}
.aside-nav a:hover,.aside-nav a.active{background:var(--brand-50);color:var(--brand-700)}
.aside-nav a svg{width:1em;height:1em;opacity:.5}

/* ==========================================================================
   Pricing table
   ========================================================================== */
.ptable-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm);background:#fff;-webkit-overflow-scrolling:touch}
.ptable{width:100%;border-collapse:collapse;min-width:780px}
.ptable th,.ptable td{padding:16px 18px;text-align:left;border-bottom:1px solid var(--line-2);font-size:.94rem}
.ptable thead th{position:sticky;top:0;background:var(--surface-2);font-family:var(--ff-head);color:var(--ink);font-weight:700;font-size:.9rem;z-index:1}
.ptable tbody th{font-weight:600;color:var(--ink);font-family:var(--ff-head)}
.ptable .col-syn{background:linear-gradient(180deg,var(--brand-50),#fff);position:relative}
.ptable thead .col-syn{background:linear-gradient(135deg,var(--brand-700),var(--brand-600));color:#fff}
.ptable thead .col-syn small{display:block;font-weight:600;font-size:.72rem;color:var(--teal-400);margin-top:3px;letter-spacing:.04em}
.ptable td.col-syn{font-weight:700;color:var(--brand-800)}
.ptable .yes{color:var(--success);font-weight:700}
.ptable .no{color:var(--muted)}
.ptable tbody tr:hover td{background:var(--surface-2)}
.ptable tbody tr:hover td.col-syn{background:var(--brand-100)}
.pill-rec{display:inline-block;margin-left:6px;padding:.15em .6em;border-radius:var(--r-pill);background:var(--teal-500);color:#fff;font-size:.66rem;font-weight:700;letter-spacing:.04em;vertical-align:middle}

.price-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.price-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;display:flex;flex-direction:column;transition:transform var(--t),box-shadow var(--t)}
.price-card:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.price-card.featured{border:2px solid var(--brand-500);box-shadow:var(--sh);position:relative}
.price-card.featured::before{content:"Most popular";position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,var(--teal-500),var(--teal-600));color:#fff;font-family:var(--ff-head);font-weight:700;
  font-size:.74rem;padding:.35em 1em;border-radius:var(--r-pill);box-shadow:var(--sh-sm)}
.price-card h3{font-size:1.25rem}
.price-card .pdesc{font-size:.92rem;color:var(--muted);margin:6px 0 18px}
.price-card .amt{font-family:var(--ff-head);font-weight:800;font-size:2.4rem;color:var(--ink);line-height:1}
.price-card .amt small{font-size:.9rem;color:var(--muted);font-weight:600}
.price-card .checks{margin:22px 0 26px}
.price-card .btn{margin-top:auto}

/* ==========================================================================
   FAQ accordion
   ========================================================================== */
.faq{max-width:840px;margin-inline:auto;display:grid;gap:12px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:box-shadow var(--t),border-color var(--t)}
.faq-item[open]{box-shadow:var(--sh-sm);border-color:var(--brand-200)}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:18px;cursor:pointer;
  padding:20px 22px;font-family:var(--ff-head);font-weight:700;color:var(--ink);font-size:1.06rem;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .ico{flex-shrink:0;width:30px;height:30px;border-radius:9px;display:grid;place-items:center;
  background:var(--brand-50);color:var(--brand-700);transition:transform var(--t),background var(--t),color var(--t)}
.faq-item summary .ico svg{width:16px;height:16px}
.faq-item[open] summary .ico{background:var(--brand-600);color:#fff;transform:rotate(45deg)}
.faq-answer{padding:0 22px 22px;color:var(--body);font-size:.98rem}
.faq-answer p{margin-bottom:12px}

/* ==========================================================================
   Contact
   ========================================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(30px,4vw,56px);align-items:start}
.info-card{display:flex;gap:16px;padding:22px;background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-xs);margin-bottom:16px;transition:box-shadow var(--t),border-color var(--t)}
.info-card:hover{box-shadow:var(--sh-sm);border-color:var(--brand-200)}
.info-card .ic{flex-shrink:0;width:50px;height:50px;border-radius:13px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--brand-600),var(--brand-700));color:#fff}
.info-card .ic svg{width:23px;height:23px}
.info-card h3{font-size:1.02rem;margin-bottom:3px}
.info-card a,.info-card p{font-size:1.02rem;color:var(--body)}
.info-card a:hover{color:var(--brand-700)}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(24px,3vw,38px);box-shadow:var(--sh)}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--ff-head);font-weight:650;font-size:.9rem;color:var(--ink);margin-bottom:7px}
.field label .req{color:var(--danger)}
.field input,.field select,.field textarea{width:100%;padding:.85em 1em;border:1.5px solid var(--line);border-radius:var(--r-sm);
  background:var(--surface-2);transition:border-color var(--t),background var(--t),box-shadow var(--t);font-size:1rem}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand-500);background:#fff;box-shadow:0 0 0 4px var(--brand-100)}
.field textarea{resize:vertical;min-height:130px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.form-note{font-size:.84rem;color:var(--muted);margin-top:6px}
.form-status{padding:14px 16px;border-radius:var(--r-sm);font-size:.94rem;margin-bottom:18px;display:none}
.form-status.ok{display:block;background:#e9f8ef;color:#0c7a39;border:1px solid #bce6cd}
.form-status.err{display:block;background:#fdecec;color:#b3322c;border:1px solid #f4c4c1}
.map-embed{border:0;width:100%;height:340px;border-radius:var(--r);box-shadow:var(--sh-sm)}

/* ==========================================================================
   Misc utilities + reveal animation
   ========================================================================== */
.mt-0{margin-top:0}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}
.mb-0{margin-bottom:0}.divider{height:1px;background:var(--line);border:0;margin-block:clamp(40px,5vw,64px)}
.kicker-strip{display:flex;flex-wrap:wrap;gap:10px}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.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){*{animation:none!important;transition:none!important;scroll-behavior:auto}.reveal{opacity:1;transform:none}}

.skip{position:absolute;left:-9999px;top:0;background:var(--brand-700);color:#fff;padding:12px 18px;border-radius:0 0 10px 0;z-index:200;font-weight:700}
.skip:focus{left:0;color:#fff}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width:1080px){
  .footer-top{grid-template-columns:1fr 1fr}
  .statband{grid-template-columns:repeat(2,1fr);gap:30px 20px}
  .steps{grid-template-columns:repeat(2,1fr);gap:30px}
  .step:not(:last-child)::after{display:none}
  .spec-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:920px){
  .nav-menu,.nav-phone span,.nav-cta .btn{display:none}
  .nav-toggle{display:inline-flex}
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .hero-visual{max-width:480px;margin-inline:auto;width:100%}
  .split,.contact-grid,.with-aside{grid-template-columns:1fr;gap:40px}
  .with-aside .aside{position:static}
  .g-3,.g-4,.price-cards{grid-template-columns:1fr 1fr}
  .mega,.dropdown{display:none}
}
@media (max-width:640px){
  body{font-size:16px}
  .g-2,.g-3,.g-4,.price-cards,.spec-grid,.checks.two,.statband,.footer-top,.form-row,.contact-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .btn-row .btn{width:100%}
}

/* Fail-safe: never leave .reveal content hidden if JS fails to run */
.reveal{animation:revealFailsafe 0s linear 2.5s forwards}
.reveal.in{animation:none}
@keyframes revealFailsafe{to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.reveal{animation:none}}

/* Fix: invisible "bridge" over the 10px gap so the dropdown stays open when
   moving the cursor from the nav item down into the menu (applies at all widths) */
.has-mega>.mega::before,.has-dd>.dropdown::before{content:"";position:absolute;left:0;right:0;top:-14px;height:16px;background:transparent}

/* ==========================================================================
   Floating conversion CTA (FAB)
   ========================================================================== */
.fab{position:fixed;right:18px;bottom:18px;z-index:75;display:flex;flex-direction:column;gap:10px;align-items:flex-end;opacity:0;transform:translateY(12px);pointer-events:none;transition:opacity .3s ease,transform .3s ease}
.fab.show{opacity:1;transform:none;pointer-events:auto}
.fab-btn{display:inline-flex;align-items:center;gap:.5em;padding:.72em 1.05em;border-radius:var(--r-pill);font-family:var(--ff-head);font-weight:700;font-size:.92rem;box-shadow:var(--sh-lg);transition:transform var(--t),box-shadow var(--t)}
.fab-btn svg{width:1.1em;height:1.1em;flex:none}
.fab-btn:hover{transform:translateY(-2px)}
.fab-call{background:#fff;color:var(--brand-700);border:1px solid var(--line)}
.fab-call:hover{color:var(--brand-700)}
.fab-audit{background:linear-gradient(135deg,var(--teal-500),var(--teal-600));color:#fff}
.fab-audit:hover{color:#fff}
@media (max-width:520px){.fab{right:10px;bottom:10px;gap:8px}.fab-btn{font-size:.85rem;padding:.66em .9em}}

/* ==========================================================================
   Revenue-Leak Calculator
   ========================================================================== */
.calc{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh);padding:clamp(22px,3vw,34px)}
.calc-inputs{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}
.calc-field label{display:block;font-family:var(--ff-head);font-weight:650;font-size:.9rem;color:var(--ink);margin-bottom:6px}
.calc-field input{width:100%;padding:.8em 1em;border:1.5px solid var(--line);border-radius:var(--r-sm);background:var(--surface-2);font-size:1.05rem;transition:border-color var(--t),background var(--t),box-shadow var(--t)}
.calc-field input:focus{outline:none;border-color:var(--brand-500);background:#fff;box-shadow:0 0 0 4px var(--brand-100)}
.calc-out{background:linear-gradient(160deg,var(--brand-900),var(--brand-800));color:#cfe0f1;border-radius:var(--r);padding:24px;margin-bottom:22px}
.calc-big{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:18px}
.calc-big .calc-lab{font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:#9fc2e8;font-weight:700}
.calc-big strong{font-family:var(--ff-head);font-weight:800;font-size:clamp(2.4rem,6vw,3.4rem);color:#fff;line-height:1.05;margin:6px 0}
.calc-big .calc-per{font-size:.9rem;color:#bcd4ee}
.calc-break{display:grid;gap:10px;max-width:520px;margin:0 auto}
.calc-break li{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:10px 14px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-sm);font-size:.95rem}
.calc-break li b{font-family:var(--ff-head);color:#fff;white-space:nowrap}
.calc-emaillab{display:block;font-family:var(--ff-head);font-weight:700;color:var(--ink);margin-bottom:8px}
.calc-emailrow{display:flex;gap:10px;flex-wrap:wrap}
.calc-emailrow input{flex:1;min-width:200px;padding:.85em 1em;border:1.5px solid var(--line);border-radius:var(--r-sm);background:var(--surface-2);font-size:1rem}
.calc-emailrow input:focus{outline:none;border-color:var(--brand-500);background:#fff;box-shadow:0 0 0 4px var(--brand-100)}
.calc-note{font-size:.82rem;color:var(--muted);margin-top:14px;line-height:1.55}
@media (max-width:640px){.calc-inputs{grid-template-columns:1fr}}

/* ==========================================================================
   Results / case-study cards
   ========================================================================== */
.result-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px;box-shadow:var(--sh-xs);height:100%;display:flex;flex-direction:column}
.result-card h3{font-size:1.12rem;margin-bottom:2px}
.result-who{font-size:.85rem;color:var(--teal-700);font-weight:700;font-family:var(--ff-head);margin-bottom:12px}
.result-card p{font-size:.95rem;margin-bottom:10px}
.result-metrics{margin-top:auto;display:grid;gap:8px;padding-top:14px;border-top:1px solid var(--line-2)}
.result-metrics li{display:flex;justify-content:space-between;gap:12px;font-size:.9rem}
.result-metrics li span{color:var(--muted)}
.result-metrics li b{font-family:var(--ff-head);color:var(--brand-700);white-space:nowrap}

/* ==========================================================================
   Header nav fit (prevents the phone number from wrapping / crowding)
   ========================================================================== */
.nav-phone{white-space:nowrap}
.nav-phone span{white-space:nowrap}
/* Hide the (redundant) phone block before the bar gets crowded */
@media (max-width:1240px){.nav-phone{display:none}}
/* Collapse the menu to the hamburger before the 7 items crowd the bar */
@media (max-width:1080px){.nav-menu,.nav-cta .btn{display:none}.nav-toggle{display:inline-flex}}

/* ==========================================================================
   Message-us launcher (floating contact menu)
   ========================================================================== */
.msgme{position:fixed;right:18px;bottom:18px;z-index:80;display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.msgme-btn{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--brand-600),var(--brand-700));color:#fff;box-shadow:var(--sh-lg);display:grid;place-items:center;transition:transform var(--t)}
.msgme-btn:hover{transform:translateY(-2px)}
.msgme-btn svg{width:26px;height:26px}
.msgme-btn .msgme-x{display:none}
.msgme.open .msgme-btn .msgme-open{display:none}
.msgme.open .msgme-btn .msgme-x{display:block}
.msgme-panel{width:300px;max-width:calc(100vw - 36px);background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-lg);padding:10px;opacity:0;visibility:hidden;transform:translateY(12px) scale(.98);transform-origin:bottom right;transition:opacity var(--t),transform var(--t),visibility var(--t)}
.msgme.open .msgme-panel{opacity:1;visibility:visible;transform:none}
.msgme-head{padding:10px 12px 12px}
.msgme-head b{display:block;font-family:var(--ff-head);color:var(--ink);font-size:1rem}
.msgme-head span{font-size:.82rem;color:var(--muted)}
.msgme-row{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:var(--r-sm);transition:background var(--t)}
.msgme-row:hover{background:var(--brand-50)}
.msgme-ic{flex:none;width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand-50),var(--teal-100));color:var(--brand-700)}
.msgme-ic svg{width:19px;height:19px}
.msgme-tx b{display:block;font-family:var(--ff-head);font-size:.95rem;color:var(--ink)}
.msgme-tx small{display:block;font-size:.8rem;color:var(--muted)}
.msgme-cta .msgme-ic{background:linear-gradient(135deg,var(--teal-500),var(--teal-600));color:#fff}
@media (max-width:520px){.msgme{right:12px;bottom:12px}.msgme-btn{width:54px;height:54px}.msgme-panel{width:280px}}
