/* ============================================================
   webMonx Solutions LLP - shared design system
   "Measured Signal": cool precision-instrument light theme.
   Steel blue structure, orange (#F26522) live-signal accent,
   deep navy dark sections. Token names kept from the prior
   build so page-level inline styles re-theme automatically
   (--ink* are backgrounds, --bone* are text).
   Fonts: Bricolage Grotesque / Hanken Grotesque / JetBrains Mono
   ============================================================ */

:root{
  /* backgrounds */
  --ink:#F3F6FA;        /* page canvas (cool precise paper) */
  --ink-2:#EAEFF5;      /* soft surface (strips, principles) */
  --ink-3:#FFFFFF;      /* cards, panels */
  --ink-4:#E6ECF3;      /* hover surface */
  --line:rgba(13,28,45,.13);
  --line-2:rgba(13,28,45,.055);
  /* text */
  --bone:#0E1B2B;       /* primary text (deep cool ink) */
  --bone-dim:#46586D;   /* muted text, >= 5:1 on white */
  --bone-faint:#5B6D82; /* faint labels, >= 4.5:1 on white */
  /* brand */
  --orange:#F26522;     /* live signal accent, fills, large text */
  --orange-soft:#FF7A45;
  --orange-deep:#BD4E12;/* orange for small text on light, >= 6:1 */
  --blue:#1C6B97;       /* steel blue structure, links, labels */
  --blue-soft:#2E86C0;
  --blue-deep:#0B2940;  /* deep navy stat band */
  --dark:#0A1A28;       /* dark sections (footer, cta) */
  --drip:#1FAE5A;       /* dripBot accent (text-safe green) */
  --drip-bright:#25D366;
  /* effects */
  --shadow:0 22px 56px rgba(13,28,45,.12);
  --shadow-sm:0 10px 26px rgba(13,28,45,.08);
  --ease:cubic-bezier(.16,1,.3,1);
  --display:"Bricolage Grotesque",sans-serif;
  --body:"Hanken Grotesque",sans-serif;
  --mono:"JetBrains Mono",monospace;
  --maxw:1240px;
  --r:16px;
  /* semantic z-index scale */
  --z-base:2;
  --z-sticky:60;
  --z-drawer:55;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--ink);color:var(--bone);
  font-family:var(--body);font-size:17px;line-height:1.62;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
}
::selection{background:var(--orange);color:#fff}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative;z-index:var(--z-base)}

/* visible focus for keyboard users */
a:focus-visible,button:focus-visible,.btn:focus-visible,
input:focus-visible,textarea:focus-visible,select:focus-visible,
.acc-q:focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:6px}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.05;letter-spacing:-.025em;color:var(--bone);text-wrap:balance}
p{text-wrap:pretty}
.eyebrow{font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--orange-deep);display:inline-flex;align-items:center;gap:11px}
.eyebrow::before{content:"";width:16px;height:2px;border-radius:2px;background:var(--orange);flex-shrink:0}
.eyebrow.blue{color:var(--blue)}
.eyebrow.blue::before{background:var(--blue)}
.eyebrow.de{color:#0F7A38} /* deep WhatsApp green, >= 4.5:1 on white */
.eyebrow.de::before{background:var(--drip-bright);box-shadow:0 0 10px rgba(37,211,102,.7)}

/* ---------- buttons ---------- */
.btn{font-family:var(--body);font-weight:600;font-size:15px;padding:13px 24px;border-radius:100px;cursor:pointer;border:none;display:inline-flex;align-items:center;gap:9px;transition:transform .25s var(--ease),background .2s,box-shadow .3s,border-color .2s,color .2s;white-space:nowrap}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 8px 22px rgba(242,101,34,.26)}
.btn-primary:hover{transform:translateY(-2px);background:#ff6f2e;box-shadow:0 14px 32px rgba(242,101,34,.36)}
.btn-ghost{background:transparent;color:var(--bone);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--bone);background:rgba(13,28,45,.04)}
.btn-blue{background:var(--blue);color:#fff;box-shadow:0 8px 22px rgba(28,107,151,.24)}
.btn-blue:hover{transform:translateY(-2px);background:#1f76a6;box-shadow:0 14px 32px rgba(28,107,151,.34)}
.btn .arr{transition:transform .25s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}

/* ---------- header ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:var(--z-sticky);border-bottom:1px solid transparent;transition:background .35s,border-color .35s,backdrop-filter .35s}
header.scrolled{background:rgba(243,246,250,.82);backdrop-filter:blur(16px) saturate(1.4);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand img,.foot-logo{height:30px;width:auto}
.brand{display:inline-flex;align-items:center}
.foot-logo{height:34px;margin-bottom:18px}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links>a,.menu-top{font-size:14.5px;color:var(--bone-dim);transition:color .2s;cursor:pointer;display:inline-flex;align-items:center;gap:5px}
.nav-links>a:hover,.menu-top:hover{color:var(--bone)}
.caret{font-size:10px;opacity:.6}
.has-menu{position:relative}
.submenu{position:absolute;top:140%;left:-14px;min-width:236px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .22s,transform .22s var(--ease),visibility .22s;box-shadow:var(--shadow)}
.has-menu:hover .submenu,.has-menu:focus-within .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu a{display:block;padding:11px 14px;border-radius:9px;font-size:14px;color:var(--bone-dim);transition:background .18s,color .18s}
.submenu a:hover{background:var(--ink-4);color:var(--bone)}
.nav-cta{padding:11px 20px;color:#fff !important}
.nav-toggle{display:none;background:none;border:none;color:var(--bone);cursor:pointer;font-size:24px;line-height:1}

/* ---------- sections ---------- */
section.block{padding:clamp(72px,9vw,112px) 0;position:relative;z-index:var(--z-base)}
section.block.tight{padding:clamp(56px,7vw,82px) 0}
.sec-head{max-width:760px;margin-bottom:56px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center;display:inline-flex}
.sec-head h2{font-size:clamp(31px,4.6vw,52px);margin-top:18px;letter-spacing:-.03em}
.sec-head p{color:var(--bone-dim);font-size:18px;margin-top:18px;max-width:62ch}
.sec-head.center p{margin-left:auto;margin-right:auto}

/* ---------- page hero ---------- */
.page-hero{position:relative;padding:160px 0 66px;border-bottom:1px solid var(--line);overflow:hidden}
.page-hero .glow{position:absolute;width:520px;height:520px;border-radius:50%;filter:blur(110px);opacity:.55;top:-160px;right:-60px;background:radial-gradient(circle,rgba(242,101,34,.22),transparent 70%);pointer-events:none}
.page-hero.blue .glow{background:radial-gradient(circle,rgba(28,107,151,.24),transparent 70%)}
.page-hero .grid-lines{position:absolute;inset:0;background-image:linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px);background-size:60px 60px;-webkit-mask-image:radial-gradient(ellipse 70% 80% at 70% 0%,#000,transparent 70%);mask-image:radial-gradient(ellipse 70% 80% at 70% 0%,#000,transparent 70%)}
.breadcrumb{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--bone-faint);margin-bottom:22px}
.breadcrumb a{color:var(--bone-dim)}
.breadcrumb a:hover{color:var(--orange-deep)}
.page-hero h1{font-size:clamp(38px,6vw,72px);font-weight:800;max-width:15ch;margin-top:8px;letter-spacing:-.035em}
.page-hero p.lead{font-size:clamp(18px,2vw,21px);color:var(--bone-dim);max-width:58ch;margin-top:24px;line-height:1.5}
.page-hero .hero-cta{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}

/* ---------- card grid (control matrix) ---------- */
.card-grid{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.card-grid.c2{grid-template-columns:repeat(2,1fr)}
.card-grid.c3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--ink-3);padding:38px 34px;transition:background .3s,transform .3s var(--ease);position:relative}
.card:hover{background:var(--ink-4)}
.card .ix{font-family:var(--mono);font-size:12px;color:var(--orange-deep);letter-spacing:.1em;font-weight:500}
.card .ix.blue{color:var(--blue)}
.card h3{font-size:23px;margin:16px 0 11px}
.card p{color:var(--bone-dim);font-size:15px;line-height:1.6}
.card .tags{list-style:none;margin-top:18px;display:flex;flex-wrap:wrap;gap:8px}
.card .tags li{font-family:var(--mono);font-size:11px;letter-spacing:.03em;color:var(--bone-faint);border:1px solid var(--line);padding:4px 10px;border-radius:6px}
.card .more{display:inline-flex;align-items:center;gap:7px;margin-top:20px;font-size:14px;font-weight:600;color:var(--orange-deep)}
.card .more .arr{transition:transform .25s var(--ease)}
.card:hover .more .arr{transform:translateX(4px)}

.cards{display:grid;gap:22px}
.cards.c2{grid-template-columns:repeat(2,1fr)}
.cards.c3{grid-template-columns:repeat(3,1fr)}
.fcard{background:var(--ink-3);border:1px solid var(--line);border-radius:var(--r);padding:32px 30px;transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;box-shadow:var(--shadow-sm)}
.fcard:hover{transform:translateY(-5px);border-color:rgba(28,107,151,.42);box-shadow:var(--shadow)}
.fcard h3{font-size:21px;margin:6px 0 10px}
.fcard h4{font-size:18px;font-weight:600;margin:4px 0 9px}
.fcard p{color:var(--bone-dim);font-size:15px}
.fcard .ic{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(242,101,34,.12);margin-bottom:18px}
.fcard .ic.blue{background:rgba(28,107,151,.12)}

/* ---------- product cards (shared) ---------- */
.prod-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.prod{position:relative;border:1px solid var(--line);border-radius:22px;padding:38px 36px 32px;background:var(--ink-3);overflow:hidden;transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;display:flex;flex-direction:column;min-height:440px;box-shadow:var(--shadow-sm)}
.prod:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.prod::after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;filter:blur(80px);top:-140px;right:-110px;opacity:.18;transition:opacity .35s}
.prod:hover::after{opacity:.32}
.prod.drip::after{background:var(--drip-bright)}.prod.cro::after{background:var(--blue)}
.prod.drip:hover{border-color:rgba(31,174,90,.5)}.prod.cro:hover{border-color:rgba(28,107,151,.5)}
.prod-top{display:flex;align-items:center;justify-content:space-between;position:relative;z-index:var(--z-base)}
.prod-name{font-family:var(--display);font-weight:800;font-size:30px;letter-spacing:-.03em;display:flex;align-items:center;gap:9px}
.prod-name .pd{width:10px;height:10px;border-radius:50%}
.prod.drip .pd{background:var(--drip-bright);box-shadow:0 0 14px var(--drip-bright)}.prod.cro .pd{background:var(--blue);box-shadow:0 0 14px var(--blue-soft)}
.prod-tag{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--bone-faint);border:1px solid var(--line);padding:5px 11px;border-radius:100px}
.prod h3.head{font-size:23px;font-weight:600;margin:24px 0 0;position:relative;z-index:var(--z-base);line-height:1.22}
.prod p.desc{color:var(--bone-dim);font-size:15px;margin-top:13px;position:relative;z-index:var(--z-base)}
.prod-feats{list-style:none;margin:20px 0 0;position:relative;z-index:var(--z-base);display:flex;flex-direction:column;gap:10px}
.prod-feats li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px}
.prod-feats li svg{flex-shrink:0;margin-top:3px}
.prod-foot{margin-top:auto;padding-top:26px;position:relative;z-index:var(--z-base);display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.prod-link{font-weight:600;font-size:15px;display:inline-flex;align-items:center;gap:8px;color:var(--bone)}
.prod-link .arr{transition:transform .25s var(--ease)}.prod-link:hover .arr{transform:translateX(5px)}

/* ---------- feature rows ---------- */
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;padding:64px 0;border-bottom:1px solid var(--line-2)}
.feature-row:last-child{border-bottom:none}
.feature-row.flip .fr-copy{order:2}
.fr-copy .eyebrow{margin-bottom:18px}
.fr-copy h3{font-size:clamp(25px,3.2vw,37px);margin-bottom:16px;letter-spacing:-.03em}
.fr-copy p{color:var(--bone-dim);font-size:16.5px;margin-bottom:20px;max-width:54ch}
.check{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:12px 22px}
.check li{display:flex;gap:10px;align-items:flex-start;font-size:14.5px;color:var(--bone)}
.check li svg{flex-shrink:0;margin-top:3px}

/* instrument readout panel */
.panel{position:relative;border:1px solid var(--line);border-radius:var(--r);min-height:330px;overflow:hidden;background:linear-gradient(160deg,#fff,var(--ink-2));box-shadow:var(--shadow-sm)}
.panel .pgrid{position:absolute;inset:0;background-image:linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px);background-size:38px 38px}
.panel .pglow{position:absolute;width:300px;height:300px;border-radius:50%;filter:blur(70px);opacity:.42;top:-80px;right:-60px;background:radial-gradient(circle,rgba(242,101,34,.4),transparent 70%)}
.panel.blue .pglow{background:radial-gradient(circle,rgba(28,107,151,.38),transparent 70%)}
/* corner crop ticks: frame the panel like a measured viewport */
.panel::after{content:"";position:absolute;inset:14px;pointer-events:none;z-index:3;
  background-image:
    linear-gradient(var(--blue),var(--blue)),linear-gradient(var(--blue),var(--blue)),
    linear-gradient(var(--blue),var(--blue)),linear-gradient(var(--blue),var(--blue)),
    linear-gradient(var(--blue),var(--blue)),linear-gradient(var(--blue),var(--blue)),
    linear-gradient(var(--blue),var(--blue)),linear-gradient(var(--blue),var(--blue));
  background-repeat:no-repeat;
  background-size:13px 1.5px,1.5px 13px,13px 1.5px,1.5px 13px,13px 1.5px,1.5px 13px,13px 1.5px,1.5px 13px;
  background-position:left top,left top,right top,right top,left bottom,left bottom,right bottom,right bottom;
  opacity:.34}
.panel .pcontent{position:relative;z-index:var(--z-base);padding:30px;height:100%;display:flex;flex-direction:column;justify-content:center;gap:14px}
.mini-row{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px;box-shadow:var(--shadow-sm)}
.mini-row .l{font-size:14px}
.mini-row .v{font-family:var(--mono);font-size:13px;color:var(--orange-deep)}
.mini-row .v.blue{color:var(--blue)}
.mini-row .v.ok{color:var(--drip)}
.flowline{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-family:var(--mono);font-size:12.5px;color:var(--bone-dim)}
.flowline .node{background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px 12px;color:var(--bone);box-shadow:var(--shadow-sm)}
.flowline .ar{color:var(--orange)}
.bigstat{font-family:var(--display);font-weight:700;font-size:54px;letter-spacing:-.02em}
.bigstat .u{font-size:24px;color:var(--bone-dim)}

/* ---------- stat band (deep navy) ---------- */
.band{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--blue-deep);position:relative;overflow:hidden}
.band::before{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:60px 60px;pointer-events:none}
.band-grid{display:grid;grid-template-columns:repeat(4,1fr);position:relative;z-index:var(--z-base)}
.bstat{padding:52px 26px;border-right:1px solid rgba(255,255,255,.14);text-align:center}
.bstat:last-child{border-right:none}
.bstat .n{font-family:var(--display);font-weight:700;font-size:clamp(30px,4vw,46px);letter-spacing:-.02em;color:var(--orange-soft)}
.bstat .n.blue{color:#fff}
.bstat .l{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:rgba(226,236,245,.72);margin-top:10px}

/* ---------- logo strip (connected stack) ---------- */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:24px 0;background:var(--ink-2)}
.strip-label{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--bone-faint);margin-bottom:14px}
.chips{display:flex;gap:12px;flex-wrap:wrap}
.chip{font-family:var(--mono);font-size:13px;color:var(--bone-dim);border:1px solid var(--line);border-radius:100px;padding:7px 15px;background:#fff;transition:border-color .2s,color .2s,transform .2s var(--ease)}
.chip:hover{border-color:var(--orange);color:var(--bone);transform:translateY(-2px)}

/* ---------- steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{border:1px solid var(--line);border-radius:var(--r);padding:30px 28px;background:#fff;position:relative;box-shadow:var(--shadow-sm);transition:transform .35s var(--ease),box-shadow .35s}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.step .sn{font-family:var(--mono);font-size:13px;color:var(--orange-deep);letter-spacing:.08em}
.step h4{font-size:20px;margin:14px 0 9px}
.step p{color:var(--bone-dim);font-size:14.5px}

/* ---------- cta band (dark) ---------- */
.cta-band{position:relative;overflow:hidden;text-align:center;padding:clamp(76px,10vw,108px) 0;background:var(--dark);color:#EAF1F8}
.cta-band::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:64px 64px;-webkit-mask-image:radial-gradient(ellipse 60% 80% at 50% 0%,#000,transparent 72%);mask-image:radial-gradient(ellipse 60% 80% at 50% 0%,#000,transparent 72%)}
.cta-band .cglow{position:absolute;width:640px;height:640px;border-radius:50%;filter:blur(90px);background:radial-gradient(circle,rgba(242,101,34,.22),transparent 70%);top:-220px;left:50%;transform:translateX(-50%);z-index:1}
.cta-inner{position:relative;z-index:var(--z-base);max-width:740px;margin:0 auto}
.cta-inner h2{font-size:clamp(33px,5vw,60px);font-weight:800;color:#fff;letter-spacing:-.03em}
.cta-inner p{color:rgba(234,241,248,.72);font-size:19px;margin-top:18px}
.cta-row{display:flex;gap:14px;justify-content:center;margin-top:34px;flex-wrap:wrap}
.cta-band .btn-ghost{color:#EAF1F8;border-color:rgba(234,241,248,.3)}
.cta-band .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.07)}

/* ---------- accordion ---------- */
.acc{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff}
.acc-item{border-bottom:1px solid var(--line)}
.acc-item:last-child{border-bottom:none}
.acc-q{width:100%;text-align:left;background:none;border:none;color:var(--bone);font-family:var(--display);font-weight:600;font-size:18px;padding:24px 26px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px}
.acc-q .pm{color:var(--orange);font-size:22px;transition:transform .25s var(--ease);flex-shrink:0}
.acc-item.open .pm{transform:rotate(45deg)}
.acc-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.acc-a p{color:var(--bone-dim);font-size:15.5px;padding:0 26px 24px}

/* ---------- contact form ---------- */
.form-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:start}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--bone-faint);margin-bottom:8px}
.field input,.field textarea,.field select{width:100%;background:#fff;border:1px solid var(--line);border-radius:11px;padding:13px 15px;color:var(--bone);font-family:var(--body);font-size:15.5px;transition:border-color .2s,box-shadow .2s}
.field input::placeholder,.field textarea::placeholder{color:var(--bone-faint)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(242,101,34,.14)}
.field textarea{resize:vertical;min-height:130px}
.contact-side .cbox{border:1px solid var(--line);border-radius:var(--r);padding:26px 28px;background:#fff;margin-bottom:18px;box-shadow:var(--shadow-sm)}
.contact-side .cbox .k{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--bone-faint);margin-bottom:10px}
.contact-side .cbox .v{font-size:15px;color:var(--bone-dim);line-height:1.6}
.contact-side .cbox .v a{color:var(--blue)}
.contact-side .cbox .v a:hover{color:var(--orange-deep)}

/* ---------- legal doc ---------- */
.doc{padding:54px 0 100px}
.doc .wrap{max-width:760px}
.doc .intro{font-size:18px;color:var(--bone-dim);margin-bottom:38px;line-height:1.65}
.doc h2{font-size:25px;margin:46px 0 13px;scroll-margin-top:96px;letter-spacing:-.02em}
.doc h3{font-size:18px;font-weight:600;margin:26px 0 9px}
.doc p{color:var(--bone-dim);margin-bottom:15px;line-height:1.7}
.doc ul{list-style:none;margin:0 0 17px}
.doc ul li{color:var(--bone-dim);padding-left:23px;position:relative;margin-bottom:10px;line-height:1.65}
.doc ul li::before{content:"";position:absolute;left:4px;top:11px;width:6px;height:6px;border-radius:2px;background:var(--orange)}
.doc strong{color:var(--bone);font-weight:600}
.doc a{color:var(--blue)}
.doc a:hover{text-decoration:underline}
/* callout: full hairline border, faint accent tint, leading mark (no side-stripe) */
.callout{position:relative;background:var(--ink-3);border:1px solid var(--line);border-radius:14px;padding:22px 26px 22px 46px;margin:24px 0;box-shadow:var(--shadow-sm)}
.callout::before{content:"";position:absolute;left:24px;top:28px;width:10px;height:10px;border-radius:3px;background:var(--callout-accent,var(--orange))}
.callout p:last-child{margin-bottom:0}
.toc{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px 28px;margin-bottom:40px;box-shadow:var(--shadow-sm)}
.toc h4{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--bone-faint);margin-bottom:14px}
.toc ol{margin:0;padding-left:20px;columns:2;column-gap:30px}
.toc ol li{margin-bottom:8px}
.toc ol li a{color:var(--blue);font-size:14px}
.toc ol li a:hover{color:var(--orange-deep);text-decoration:none}

/* ---------- footer (dark) ---------- */
footer{border-top:1px solid var(--line);padding:62px 0 36px;background:var(--dark);position:relative;z-index:var(--z-base);overflow:hidden}
footer::before{content:"";position:absolute;width:560px;height:560px;border-radius:50%;filter:blur(110px);background:radial-gradient(circle,rgba(28,107,151,.16),transparent 70%);top:-280px;right:-120px;pointer-events:none}
.foot-brand p{color:rgba(226,236,245,.62);font-size:14.5px;max-width:320px;line-height:1.6}
.foot-contact{margin-top:16px}
.foot-contact a{color:var(--orange-soft);font-size:14.5px}
.foot-col h5{font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:rgba(226,236,245,.46);margin-bottom:17px}
.foot-col a{display:block;color:rgba(226,236,245,.64);font-size:14px;margin-bottom:11px;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:52px;padding-top:26px;border-top:1px solid rgba(226,236,245,.13);flex-wrap:wrap;gap:12px}
.foot-bottom p,.foot-bottom a{font-size:13px;color:rgba(226,236,245,.5)}
.foot-bottom .legal{display:flex;gap:22px}
.foot-bottom .legal a:hover{color:#fff}

/* ---------- reveal (gated on .js so content shows without JS) ---------- */
.js .reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}.d5{transition-delay:.4s}

/* footer grid (shared) */
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:40px}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .nav-links{position:fixed;top:76px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);flex-direction:column;align-items:flex-start;gap:0;padding:10px 28px 24px;transform:translateY(-140%);transition:transform .38s var(--ease);max-height:calc(100vh - 76px);overflow-y:auto;box-shadow:var(--shadow);z-index:var(--z-drawer)}
  .nav-links.open{transform:translateY(0)}
  .nav-links>a,.menu-top{padding:14px 0;width:100%;border-bottom:1px solid var(--line-2)}
  .has-menu{width:100%}
  .submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;background:transparent;padding:0 0 10px 14px;min-width:0}
  .submenu a{padding:9px 0}
  .nav-cta{margin-top:14px;width:100%;justify-content:center}
  .nav-toggle{display:block}
  .feature-row,.feature-row.flip .fr-copy{grid-template-columns:1fr;order:0}
  .feature-row{gap:34px}
  .form-grid{grid-template-columns:1fr;gap:36px}
  .prod-grid{grid-template-columns:1fr}
}
@media(max-width:820px){
  .card-grid.c2,.card-grid.c3,.cards.c2,.cards.c3{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .band-grid{grid-template-columns:repeat(2,1fr)}
  .bstat:nth-child(2){border-right:none}
  .bstat:nth-child(1),.bstat:nth-child(2){border-bottom:1px solid rgba(255,255,255,.14)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .toc ol{columns:1}
  .check{grid-template-columns:1fr}
}
@media(max-width:540px){
  .wrap{padding:0 20px}
  .band-grid{grid-template-columns:1fr}
  .bstat{border-right:none;border-bottom:1px solid rgba(255,255,255,.14)}
  .bstat:last-child{border-bottom:none}
  .foot-grid{grid-template-columns:1fr}
  .card,.fcard{padding:28px 24px}
  .callout{padding-left:26px}
  .callout::before{display:none}
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .js .reveal{opacity:1 !important;transform:none !important}
}
