:root{
  --base:#0E1726;        /* deep slate */
  --panel:#16223A;       /* panel */
  --panel-2:#1C2C49;     /* lighter panel */
  --line:#24344f;        /* hairline on dark */
  --green:#21D19F;       /* operational */
  --green-soft:#16604c;  /* operational dim */
  --amber:#F5A524;       /* warning */
  --red:#F2545B;         /* danger */
  --light:#F5F7FB;       /* light section bg */
  --card:#FFFFFF;
  --ink:#0E1726;         /* text on light */
  --ink-soft:#54637A;    /* muted on light */
  --line-light:#E4E9F1;  /* hairline on light */
  --cloud:#A9B7CC;       /* muted on dark */
  --white:#F4F7FB;
  --display:'Space Grotesk',sans-serif;
  --body:'IBM Plex Sans',sans-serif;
  --mono:'IBM Plex Mono',monospace;
  --maxw:1180px;
  --radius:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--base);color:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.08;letter-spacing:-0.02em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.mono{font-family:var(--mono)}
.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--green);display:inline-flex;align-items:center;gap:.5rem}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(33,209,159,.18)}
:focus-visible{outline:2px solid var(--green);outline-offset:3px;border-radius:4px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--body);font-weight:600;font-size:.95rem;padding:.85rem 1.4rem;border-radius:10px;border:1px solid transparent;cursor:pointer;transition:transform .15s ease,background .2s ease,box-shadow .2s ease;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--green);color:#06251c;box-shadow:0 8px 24px -8px rgba(33,209,159,.55)}
.btn-primary:hover{box-shadow:0 14px 32px -8px rgba(33,209,159,.7)}
.btn-ghost{background:transparent;color:var(--white);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--green);color:var(--green)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#1d2c46}
.btn svg{width:17px;height:17px}

/* header */
header{position:sticky;top:0;z-index:60;background:rgba(14,23,38,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
/* header bar runs wider than the 1180 content so the menu has room to breathe */
.nav{display:flex;align-items:center;justify-content:space-between;height:68px;max-width:1400px;padding:0 32px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-weight:700;font-size:1.15rem;letter-spacing:-.02em}
.brand .dot{width:30px;height:30px;border-radius:8px;background:linear-gradient(140deg,var(--green),#0e8f6e);display:grid;place-items:center;color:#06251c;font-weight:700;font-size:.95rem}
.brand small{display:block;font-family:var(--mono);font-size:.55rem;letter-spacing:.16em;color:var(--cloud);font-weight:400;margin-top:-2px}
.nav-links{display:flex;align-items:center;gap:2rem;font-size:.92rem;color:var(--cloud)}
.nav-links a{transition:color .2s}
.nav-links a:hover{color:var(--green)}
.nav-cta{display:flex;align-items:center;gap:1rem}
.callnum{font-family:var(--mono);font-size:.92rem;color:var(--white);display:flex;align-items:center;gap:.45rem}
.callnum svg{width:15px;height:15px;color:var(--green)}
.burger{display:none;background:none;border:1px solid var(--line);border-radius:8px;padding:.5rem;cursor:pointer}
.burger span{display:block;width:18px;height:2px;background:var(--white);margin:3px 0;border-radius:2px}

/* hero */
.hero{position:relative;padding:74px 0 86px;overflow:hidden}
.hero::before{content:"";position:absolute;top:-30%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(33,209,159,.16),transparent 62%);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;position:relative}
.hero h1{font-size:clamp(2.3rem,4.6vw,3.5rem);margin:1.1rem 0 1.2rem}
.hero h1 em{font-style:normal;color:var(--green)}
.hero p.lead{font-size:1.12rem;color:var(--cloud);max-width:30rem;margin-bottom:1.9rem}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:1.7rem}
.trust-row{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;font-size:.85rem;color:var(--cloud)}
.stars{color:var(--amber);letter-spacing:1px}
.trust-row b{color:var(--white)}
.trust-sep{width:1px;height:18px;background:var(--line)}

/* status board widget */
.board{background:linear-gradient(165deg,var(--panel),#101b30);border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:0 40px 80px -40px rgba(0,0,0,.7)}
.board-top{display:flex;align-items:center;justify-content:space-between;padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:6px}
.board-top .t{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--cloud)}
.live{display:flex;align-items:center;gap:.4rem;font-family:var(--mono);font-size:.68rem;color:var(--green)}
.live i{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(33,209,159,.5)}50%{opacity:.6;box-shadow:0 0 0 5px rgba(33,209,159,0)}}
.brow{display:flex;align-items:center;justify-content:space-between;padding:13px 4px;border-bottom:1px solid rgba(36,52,79,.55)}
.brow:last-child{border-bottom:none}
.brow .lbl{display:flex;align-items:center;gap:.7rem;font-size:.92rem}
.brow .ico{width:30px;height:30px;border-radius:8px;background:rgba(33,209,159,.1);display:grid;place-items:center;color:var(--green)}
.brow .ico svg{width:16px;height:16px}
.pill{font-family:var(--mono);font-size:.7rem;letter-spacing:.05em;padding:.28rem .6rem;border-radius:6px;background:rgba(33,209,159,.13);color:var(--green);display:flex;align-items:center;gap:.4rem}
.pill i{width:6px;height:6px;border-radius:50%;background:var(--green)}
.board-foot{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.uptime{font-family:var(--mono)}
.uptime b{font-size:1.5rem;color:var(--green);font-weight:600}
.uptime span{font-size:.7rem;color:var(--cloud);display:block;letter-spacing:.1em}

/* generic section */
section{position:relative}
.s-pad{padding:90px 0}
.light{background:var(--light);color:var(--ink)}
.light .eyebrow{color:#0e8f6e}
.light .eyebrow::before{background:#0e8f6e}
.sec-head{max-width:42rem;margin-bottom:52px}
.sec-head h2{font-size:clamp(1.9rem,3.4vw,2.65rem);margin:1rem 0 .9rem}
.sec-head p{font-size:1.08rem;color:var(--ink-soft)}
.dark .sec-head p{color:var(--cloud)}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* pain -> fix */
.flip-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.flip{background:var(--card);border:1px solid var(--line-light);border-radius:var(--radius);padding:24px;transition:transform .2s,box-shadow .2s}
.flip:hover{transform:translateY(-4px);box-shadow:0 24px 48px -28px rgba(14,23,38,.28)}
.flip .pain{display:flex;gap:.7rem;align-items:flex-start;color:var(--ink);font-weight:600;font-size:1.05rem;margin-bottom:.7rem}
.flip .x{flex:0 0 auto;width:24px;height:24px;border-radius:6px;background:rgba(242,84,91,.12);color:var(--red);display:grid;place-items:center;margin-top:1px}
.flip .x svg{width:14px;height:14px}
.flip .fix{display:flex;gap:.7rem;align-items:flex-start;color:var(--ink-soft);font-size:.96rem;padding-top:.7rem;border-top:1px dashed var(--line-light)}
.flip .c{flex:0 0 auto;width:24px;height:24px;border-radius:6px;background:rgba(33,209,159,.12);color:#0e8f6e;display:grid;place-items:center;margin-top:1px}
.flip .c svg{width:14px;height:14px}

/* services */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:26px;transition:transform .2s,border-color .2s}
.svc:hover{transform:translateY(-4px);border-color:var(--green)}
.svc .ico{width:46px;height:46px;border-radius:11px;background:rgba(33,209,159,.1);color:var(--green);display:grid;place-items:center;margin-bottom:16px}
.svc .ico svg{width:23px;height:23px}
.svc h3{font-size:1.15rem;margin-bottom:.5rem}
.svc p{font-size:.92rem;color:var(--cloud)}

/* tool shells */
.tool{background:linear-gradient(165deg,var(--panel),#101b30);border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:0 40px 90px -50px rgba(0,0,0,.8)}
.tool-head{display:flex;align-items:center;justify-content:space-between;padding:18px 26px;border-bottom:1px solid var(--line);background:rgba(0,0,0,.12)}
.tool-head .dots{display:flex;gap:7px}
.tool-head .dots i{width:11px;height:11px;border-radius:50%;background:var(--line)}
.tool-head .dots i:first-child{background:var(--red)}
.tool-head .dots i:nth-child(2){background:var(--amber)}
.tool-head .dots i:nth-child(3){background:var(--green)}
.tool-head .name{font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;color:var(--cloud)}
.tool-body{padding:34px}

/* scorecard */
.sc-progress{display:flex;align-items:center;gap:.7rem;margin-bottom:24px;font-family:var(--mono);font-size:.74rem;color:var(--cloud)}
.sc-bar{flex:1;height:6px;background:var(--line);border-radius:4px;overflow:hidden}
.sc-bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--amber),var(--green));border-radius:4px;transition:width .4s ease}
.sc-q{font-family:var(--display);font-size:1.5rem;font-weight:600;letter-spacing:-.02em;margin-bottom:22px;min-height:2.4em}
.sc-opts{display:grid;gap:11px}
.sc-opt{text-align:left;background:var(--panel-2);border:1px solid var(--line);color:var(--white);padding:16px 18px;border-radius:11px;cursor:pointer;font-size:1rem;font-family:var(--body);display:flex;align-items:center;gap:.85rem;transition:border-color .15s,background .15s,transform .12s}
.sc-opt:hover{border-color:var(--green);background:#21314f;transform:translateX(3px)}
.sc-opt .key{font-family:var(--mono);font-size:.78rem;width:26px;height:26px;border-radius:7px;border:1px solid var(--line);display:grid;place-items:center;color:var(--cloud);flex:0 0 auto}
.sc-opt:hover .key{border-color:var(--green);color:var(--green)}

/* scorecard result */
.sc-result{text-align:center;animation:fade .5s ease}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.gauge{position:relative;width:200px;height:200px;margin:0 auto 18px}
.gauge svg{transform:rotate(-90deg)}
.gauge .num{position:absolute;inset:0;display:grid;place-items:center;flex-direction:column}
.gauge .num b{font-family:var(--display);font-size:3rem;font-weight:600;line-height:1}
.gauge .num span{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;color:var(--cloud);text-transform:uppercase}
.sc-verdict{font-family:var(--display);font-size:1.6rem;font-weight:600;margin-bottom:.6rem}
.sc-msg{color:var(--cloud);max-width:30rem;margin:0 auto 26px;font-size:1rem}
.sc-result .btn{margin:0 .4rem .6rem}
.restart{background:none;border:none;color:var(--cloud);font-family:var(--mono);font-size:.78rem;cursor:pointer;text-decoration:underline;margin-top:6px}
.restart:hover{color:var(--green)}

/* calculator */
.calc-grid{display:grid;grid-template-columns:1fr .9fr;gap:40px;align-items:center}
.calc-controls{display:grid;gap:26px}
.calc-field label{display:flex;justify-content:space-between;align-items:baseline;font-size:.95rem;margin-bottom:10px;color:var(--white)}
.calc-field label .val{font-family:var(--mono);color:var(--green);font-size:1.05rem;font-weight:600}
input[type=range]{-webkit-appearance:none;width:100%;height:6px;border-radius:4px;background:var(--line);outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--green);cursor:pointer;border:4px solid var(--panel);box-shadow:0 0 0 1px var(--green)}
input[type=range]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--green);cursor:pointer;border:4px solid var(--panel);box-shadow:0 0 0 1px var(--green)}
.calc-out{background:rgba(242,84,91,.07);border:1px solid rgba(242,84,91,.3);border-radius:16px;padding:30px;text-align:center}
.calc-out .cap{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cloud);margin-bottom:10px}
.calc-out .big{font-family:var(--display);font-size:clamp(2.4rem,5vw,3.4rem);font-weight:700;color:var(--red);line-height:1;letter-spacing:-.02em}
.calc-out .sub{color:var(--cloud);font-size:.9rem;margin-top:10px}
.calc-out .mo{font-family:var(--mono);color:var(--white);margin-top:18px;padding-top:16px;border-top:1px solid var(--line);font-size:.86rem}
.calc-out .mo b{color:var(--amber)}

/* proof / stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:54px}
.stat{background:var(--card);border:1px solid var(--line-light);border-radius:var(--radius);padding:26px 22px;text-align:center}
.stat b{font-family:var(--display);font-size:2.5rem;font-weight:700;color:var(--ink);display:block;letter-spacing:-.02em}
.stat b em{font-style:normal;color:#0e8f6e}
.stat span{font-size:.84rem;color:var(--ink-soft);font-family:var(--mono);letter-spacing:.04em}
.certs{display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:center}
.cert{font-family:var(--mono);font-size:.8rem;letter-spacing:.1em;color:var(--ink-soft);border:1px solid var(--line-light);background:var(--card);padding:.6rem 1rem;border-radius:8px;display:flex;align-items:center;gap:.5rem}
.cert::before{content:"";width:8px;height:8px;border-radius:2px;background:#0e8f6e}

/* testimonials */
.quote-wrap{position:relative;max-width:46rem;margin:0 auto}
.quote{text-align:center}
.quote .stars{font-size:1.3rem;margin-bottom:18px;display:block}
.quote p{font-family:var(--display);font-size:clamp(1.25rem,2.6vw,1.7rem);font-weight:500;line-height:1.4;letter-spacing:-.01em;color:var(--white);min-height:3em}
.quote .who{margin-top:22px;font-family:var(--mono);font-size:.82rem;color:var(--green);letter-spacing:.06em}
.quote .who span{color:var(--cloud);display:block;letter-spacing:.04em;margin-top:2px}
.q-nav{display:flex;justify-content:center;gap:9px;margin-top:30px}
.q-nav button{width:9px;height:9px;border-radius:50%;background:var(--line);border:none;cursor:pointer;transition:background .2s,width .2s}
.q-nav button.on{background:var(--green);width:26px;border-radius:5px}

/* guide block */
.guide{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center;background:linear-gradient(160deg,var(--panel),#101b30);border:1px solid var(--line);border-radius:22px;padding:48px}
.guide .gbadge{aspect-ratio:1;background:linear-gradient(150deg,#16604c,#0c2c24);border:1px solid var(--green-soft);border-radius:16px;display:grid;place-items:center;position:relative;overflow:hidden}
.guide .gbadge .doc{width:62%;background:var(--white);border-radius:8px;aspect-ratio:.77;box-shadow:0 30px 60px -20px rgba(0,0,0,.6);padding:16px;transform:rotate(-3deg)}
.guide .gbadge .doc .ln{height:7px;border-radius:3px;background:var(--line-light);margin-bottom:7px}
.guide .gbadge .doc .ln.t{background:#0e8f6e;width:55%;height:11px;margin-bottom:12px}
.guide .gbadge .doc .ln.s{width:80%}
.guide .gbadge .doc .ln.s2{width:65%}
.guide h2{font-size:clamp(1.7rem,3vw,2.2rem);margin-bottom:.5rem}
.guide ul{list-style:none;margin:18px 0 24px;display:grid;gap:11px}
.guide li{display:flex;gap:.7rem;align-items:flex-start;color:var(--cloud);font-size:.96rem}
.guide li svg{width:18px;height:18px;color:var(--green);flex:0 0 auto;margin-top:3px}

/* final cta */
.final{background:radial-gradient(circle at 30% 0%,rgba(33,209,159,.18),transparent 55%),var(--base);text-align:center;border-top:1px solid var(--line)}
.final h2{font-size:clamp(2rem,4.2vw,3rem);max-width:18ch;margin:1rem auto 1rem}
.final p{color:var(--cloud);max-width:34rem;margin:0 auto 2rem;font-size:1.08rem}
.final-cta{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap}
.final .addr{margin-top:2.4rem;font-family:var(--mono);font-size:.82rem;color:var(--cloud);display:flex;gap:1.4rem;justify-content:center;flex-wrap:wrap}
.final .addr a:hover{color:var(--green)}

/* footer */
footer{background:#0a1119;border-top:1px solid var(--line);padding:50px 0 30px}
.foot-grid{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;align-items:flex-start}
.foot-links{display:flex;gap:46px;flex-wrap:wrap}
.foot-col h4{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cloud);margin-bottom:14px;font-weight:500}
.foot-col a{display:block;font-size:.9rem;color:var(--white);margin-bottom:9px;opacity:.85;transition:opacity .2s,color .2s}
.foot-col a:hover{opacity:1;color:var(--green)}
.foot-bottom{margin-top:40px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:.8rem;color:var(--cloud);font-family:var(--mono)}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* responsive */
@media(max-width:1024px){
  .hero-grid,.calc-grid,.guide{grid-template-columns:1fr;gap:38px}
  .svc-grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
  .flip-grid{grid-template-columns:1fr}
  .nav-links,.callnum{display:none}
  .burger{display:block}
  .nav-links.open{display:flex;position:absolute;top:68px;left:0;right:0;background:var(--base);flex-direction:column;padding:20px 24px;gap:1rem;border-bottom:1px solid var(--line)}
}
@media(max-width:560px){
  .svc-grid,.stats{grid-template-columns:1fr}
  .s-pad{padding:62px 0}
  .tool-body{padding:22px}
  .guide{padding:30px}
  .calc-out .big{font-size:2.6rem}
  .hero{padding:48px 0 60px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   SUB-PAGES (contact, services, buyersguide, about)
   ============================================================ */

/* sub-page hero */
.subhero{position:relative;padding:72px 0 56px;overflow:hidden;border-bottom:1px solid var(--line)}
.subhero::before{content:"";position:absolute;top:-40%;left:-8%;width:520px;height:520px;background:radial-gradient(circle,rgba(33,209,159,.14),transparent 62%);pointer-events:none}
.subhero .wrap{position:relative}
.subhero h1{font-size:clamp(2.1rem,4.4vw,3.1rem);margin:1rem 0 1rem;max-width:20ch}
.subhero p{font-size:1.12rem;color:var(--cloud);max-width:42rem}
.crumbs{font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;color:var(--cloud)}
.crumbs a:hover{color:var(--green)}
.crumbs span{color:var(--green)}

/* generic prose / lead on dark */
.lead-2{font-size:1.08rem;color:var(--cloud);max-width:46rem}
.dark .lead-2{color:var(--cloud)}

/* two-column split (contact) */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:start}
.split.rev{grid-template-columns:.95fr 1.05fr}

/* info cards list */
.info-list{display:grid;gap:14px;margin-top:6px}
.info-row{display:flex;gap:.9rem;align-items:flex-start;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px 20px}
.info-row .ico{flex:0 0 auto;width:42px;height:42px;border-radius:10px;background:rgba(33,209,159,.1);color:var(--green);display:grid;place-items:center}
.info-row .ico svg{width:20px;height:20px}
.info-row h4{font-family:var(--display);font-size:1.02rem;margin-bottom:2px}
.info-row p,.info-row a{font-size:.92rem;color:var(--cloud)}
.info-row a:hover{color:var(--green)}

/* reassurance bullets */
.reassure{display:grid;gap:11px;margin:22px 0}
.reassure li{list-style:none;display:flex;gap:.7rem;align-items:flex-start;color:var(--cloud);font-size:.98rem}
.reassure svg{width:18px;height:18px;color:var(--green);flex:0 0 auto;margin-top:3px}

/* form */
.form-card{background:linear-gradient(165deg,var(--panel),#101b30);border:1px solid var(--line);border-radius:18px;padding:30px;box-shadow:0 40px 90px -55px rgba(0,0,0,.8)}
.form-card h3{font-size:1.3rem;margin-bottom:.4rem}
.form-card .sub{color:var(--cloud);font-size:.92rem;margin-bottom:22px}
.field{margin-bottom:16px}
.field label{display:block;font-size:.84rem;font-family:var(--mono);letter-spacing:.04em;color:var(--cloud);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;background:var(--base);border:1px solid var(--line);border-radius:10px;color:var(--white);font-family:var(--body);font-size:.98rem;padding:13px 14px;transition:border-color .15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green)}
.field textarea{min-height:120px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-note{font-size:.78rem;color:var(--cloud);font-family:var(--mono);margin-top:6px}
.form-status{margin-top:14px;font-size:.92rem;display:none}
.form-status.ok{display:block;color:var(--green)}
.form-status.err{display:block;color:var(--red)}

/* booking embed slot */
.booking{background:var(--panel);border:1px dashed var(--line);border-radius:16px;padding:40px 30px;text-align:center}
.booking .cap{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cloud);margin-bottom:12px}
.booking iframe{width:100%;min-height:640px;border:0;border-radius:12px}

/* services detail rows */
.svc-detail{display:grid;gap:20px}
.svc-row{display:grid;grid-template-columns:64px 1fr;gap:22px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:28px;scroll-margin-top:90px;transition:border-color .2s}
.svc-row:hover{border-color:var(--green)}
.svc-row .badge{width:64px;height:64px;border-radius:14px;background:rgba(33,209,159,.1);color:var(--green);display:grid;place-items:center}
.svc-row .badge svg{width:30px;height:30px}
.svc-row h3{font-size:1.3rem;margin-bottom:.5rem}
.svc-row p{color:var(--cloud);font-size:.98rem;margin-bottom:14px;max-width:54rem}
.svc-row ul{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:9px}
.svc-row li{display:flex;gap:.6rem;align-items:flex-start;font-size:.92rem;color:var(--cloud)}
.svc-row li svg{width:16px;height:16px;color:var(--green);flex:0 0 auto;margin-top:3px}

/* process steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:step}
.step{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:24px}
.step .n{font-family:var(--mono);font-size:.8rem;color:var(--green);display:inline-grid;place-items:center;width:34px;height:34px;border-radius:9px;border:1px solid var(--green-soft);background:rgba(33,209,159,.08);margin-bottom:14px}
.step h4{font-family:var(--display);font-size:1.05rem;margin-bottom:.4rem;color:var(--green)}
.step p{font-size:.9rem;color:var(--cloud)}

/* about portrait/value */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:46px;align-items:center}
.portrait{aspect-ratio:.92;background:linear-gradient(150deg,#16604c,#0c2c24);border:1px solid var(--green-soft);border-radius:20px;display:grid;place-items:center;position:relative;overflow:hidden}
.portrait .mono-badge{font-family:var(--display);font-size:5rem;font-weight:700;color:rgba(244,247,251,.92)}
.portrait .tag{position:absolute;bottom:18px;left:18px;right:18px;background:rgba(14,23,38,.7);backdrop-filter:blur(6px);border:1px solid var(--line);border-radius:10px;padding:12px 14px;font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;color:var(--cloud)}
.values{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:8px}
.value{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:20px}
.value .ico{width:40px;height:40px;border-radius:10px;background:rgba(33,209,159,.1);color:var(--green);display:grid;place-items:center;margin-bottom:12px}
.value .ico svg{width:20px;height:20px}
.value h4{font-family:var(--display);font-size:1.05rem;margin-bottom:.35rem}
.value p{font-size:.9rem;color:var(--cloud)}

/* faq */
.faq{display:grid;gap:12px;max-width:48rem;margin:0 auto}
.faq details{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:0 22px;overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:20px 0;font-family:var(--display);font-weight:500;font-size:1.08rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--mono);color:var(--green);font-size:1.4rem;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--cloud);font-size:.96rem;padding:0 0 20px;margin:0}

/* download card */
.dl-card{background:linear-gradient(160deg,var(--panel),#101b30);border:1px solid var(--line);border-radius:20px;padding:40px;display:grid;grid-template-columns:1fr auto;gap:30px;align-items:center}
.dl-card h3{font-size:1.4rem;margin-bottom:.5rem}
.dl-card p{color:var(--cloud);font-size:.96rem;max-width:34rem}
.dl-cover{width:150px;aspect-ratio:.77;background:var(--white);border-radius:10px;box-shadow:0 30px 60px -20px rgba(0,0,0,.6);padding:20px;transform:rotate(-3deg)}
.dl-cover .ln{height:8px;border-radius:3px;background:var(--line-light);margin-bottom:9px}
.dl-cover .ln.t{background:#0e8f6e;width:60%;height:13px;margin-bottom:14px}
.dl-cover .ln.s{width:80%}

/* mid-page cta band */
.cta-band{background:radial-gradient(circle at 50% 0%,rgba(33,209,159,.14),transparent 60%);border:1px solid var(--line);border-radius:22px;padding:48px;text-align:center}
.cta-band h2{font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:.7rem}
.cta-band p{color:var(--cloud);max-width:36rem;margin:0 auto 1.6rem}

@media(max-width:1024px){
  .split,.split.rev,.about-grid{grid-template-columns:1fr;gap:34px}
  .steps{grid-template-columns:1fr 1fr}
  .values{grid-template-columns:1fr 1fr}
  .dl-card{grid-template-columns:1fr;text-align:center;justify-items:center}
  .dl-cover{transform:none}
}
@media(max-width:560px){
  .field-row{grid-template-columns:1fr}
  .steps,.values{grid-template-columns:1fr}
  .svc-row{grid-template-columns:1fr}
  .svc-row ul{grid-template-columns:1fr}
  .form-card,.cta-band,.dl-card{padding:26px}
}

/* ============================================================
   SERVICE-AREA NAV DROPDOWN
   ============================================================ */
.nav-links a.active{color:var(--green)}
.nav-links .dropdown{position:relative}
.nav-links .dropdown > a{display:inline-flex;align-items:center;gap:.3rem;cursor:pointer}
.nav-links .dropdown .caret{width:13px;height:13px;transition:transform .2s}
.nav-links .dropdown:hover .caret,.nav-links .dropdown:focus-within .caret{transform:rotate(180deg)}
.nav-links .dropdown-menu{position:absolute;top:calc(100% + 16px);left:50%;transform:translateX(-50%) translateY(8px);min-width:300px;background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:9px;opacity:0;visibility:hidden;transition:opacity .18s ease,transform .18s ease;box-shadow:0 28px 56px -28px rgba(0,0,0,.7);display:grid;grid-template-columns:1fr 1fr;gap:2px;z-index:70}
.nav-links .dropdown:hover .dropdown-menu,.nav-links .dropdown:focus-within .dropdown-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-links .dropdown-menu::before{content:"";position:absolute;bottom:100%;left:0;right:0;height:18px}
.nav-links .dropdown-menu a{padding:9px 12px;border-radius:8px;font-size:.9rem;color:var(--cloud);white-space:nowrap}
.nav-links .dropdown-menu a:hover,.nav-links .dropdown-menu a[aria-current=page]{background:var(--panel-2);color:var(--green)}
.nav-links .dropdown-menu .all{grid-column:1/-1;border-top:1px solid var(--line);margin-top:5px;padding-top:11px;color:var(--green);font-weight:600}

@media(max-width:1024px){
  .nav-links .dropdown-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;background:transparent;border:0;padding:6px 0 6px 14px;min-width:0;grid-template-columns:1fr 1fr}
  .nav-links .dropdown > a{justify-content:flex-start}
  .nav-links .dropdown .caret{display:none}
}
@media(max-width:560px){
  .nav-links .dropdown-menu{grid-template-columns:1fr}
}

/* ============================================================
   LEGAL PROSE, 404, FLOATING MOBILE CTA
   ============================================================ */
.prose{max-width:50rem}
.prose h2{font-size:1.3rem;margin:2rem 0 .6rem;color:var(--ink)}
.prose h2:first-child{margin-top:0}
.prose p,.prose li{color:var(--ink-soft);font-size:1rem;line-height:1.7}
.prose ul{margin:.4rem 0 1rem 1.2rem;display:grid;gap:.35rem}
.prose a{color:#0e8f6e;text-decoration:underline}
.prose .updated{font-family:var(--mono);font-size:.82rem;color:var(--ink-soft);margin-bottom:1.6rem}

/* floating mobile call/book bar */
.mobile-cta{display:none}
@media(max-width:720px){
  .mobile-cta{display:grid;grid-template-columns:1fr 1fr;position:fixed;left:0;right:0;bottom:0;z-index:80;box-shadow:0 -10px 28px -14px rgba(0,0,0,.6)}
  .mobile-cta a{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:15px 10px;font-family:var(--body);font-weight:600;font-size:1rem;text-decoration:none}
  .mobile-cta a svg{width:18px;height:18px}
  .mcta-call{background:var(--panel-2);color:var(--white);border-top:1px solid var(--line)}
  .mcta-book{background:var(--green);color:#06251c}
  body{padding-bottom:58px}
}
