/* =========================================================================
   GMS Intelligence — enterprise technology theme
   Palette: deep navy · white · slate grey · teal / electric-blue accents
   ========================================================================= */

:root{
  --navy-900:#071A2F;
  --navy-850:#0A2038;
  --navy-800:#0B2140;
  --navy-700:#123055;
  --navy-600:#1B3B5F;

  --accent:#16B7AE;          /* teal (from GMS mark) */
  --accent-600:#0E9C94;
  --accent-2:#5CD0FF;        /* electric blue */
  --accent-soft:rgba(22,183,174,.12);

  --ink:#0E1B2A;             /* headings on light */
  --slate:#475569;           /* body */
  --slate-2:#64748B;
  --muted:#94A3B8;

  --line:#E4E9F0;
  --line-soft:#EEF2F7;
  --bg:#FFFFFF;
  --bg-alt:#F6F9FB;
  --bg-tint:#EAF6F5;

  --radius:14px;
  --radius-sm:10px;
  --shadow-sm:0 1px 2px rgba(11,33,64,.06),0 4px 14px rgba(11,33,64,.05);
  --shadow-md:0 10px 34px rgba(11,33,64,.10);
  --shadow-lg:0 24px 60px rgba(7,26,47,.18);

  --wrap:1200px;
  --gutter:clamp(20px,5vw,48px);
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --display:'Space Grotesk','Inter',sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font);color:var(--slate);
  background:var(--bg);line-height:1.65;font-size:16.5px;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:var(--accent-600);text-decoration:none;transition:color .2s}
a:hover{color:var(--accent)}
h1,h2,h3,h4{color:var(--ink);font-family:var(--display);line-height:1.15;letter-spacing:-.01em;margin:0}
p{margin:0 0 1rem}
ul{margin:0;padding:0;list-style:none}

.container{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gutter)}
.ic{width:18px;height:18px;flex:0 0 auto;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}

.skip-link{position:absolute;left:-999px;top:0;background:var(--navy-900);color:#fff;padding:.6rem 1rem;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.95rem;
  padding:.8rem 1.5rem;border-radius:999px;border:1.5px solid transparent;cursor:pointer;
  transition:transform .18s ease,box-shadow .2s,background .2s,color .2s,border-color .2s;
  white-space:nowrap;line-height:1;
}
.btn:hover{transform:translateY(-2px)}
.btn--accent{background:var(--accent);color:#04231f;box-shadow:0 8px 24px rgba(22,183,174,.35)}
.btn--accent:hover{background:#1ac6bc;color:#04231f}
.btn--dark{background:var(--navy-900);color:#fff}
.btn--dark:hover{background:var(--navy-700);color:#fff}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.08);color:#fff}
.btn--outline{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--outline:hover{border-color:var(--accent);color:var(--accent-600)}

/* ---------- Utility bar ---------- */
.utilitybar{background:var(--navy-900);color:#c6d4e4;font-size:.82rem}
.utilitybar__row{display:flex;justify-content:space-between;align-items:center;gap:1rem;min-height:40px;flex-wrap:wrap}
.utilitybar__item{display:inline-flex;align-items:center;gap:.5rem;color:#c6d4e4}
.utilitybar a.utilitybar__item:hover{color:#fff}
.utilitybar .ic{width:15px;height:15px;color:var(--accent)}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line-soft)}
.header__row{display:flex;align-items:center;gap:1.5rem;min-height:76px}
.brand{display:inline-flex;align-items:center;gap:.7rem;color:var(--ink)}
.brand__mark{font-family:var(--display);font-weight:700;font-size:1.9rem;letter-spacing:.02em;color:var(--navy-900);line-height:1}
.brand__mark::first-letter{color:var(--navy-900)}
.brand__divider{width:2px;height:30px;background:linear-gradient(var(--accent),var(--accent-2));border-radius:2px}
.brand__name{font-size:.62rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--slate-2);line-height:1.25}
.brand--light{color:#fff}
.brand--light .brand__mark{color:#fff}
.brand--light .brand__name{color:#9fb2c6}

.nav{display:flex;gap:1.9rem;margin-left:auto}
.nav a{color:var(--slate);font-weight:500;font-size:.95rem;position:relative;padding:.3rem 0}
.nav a:hover{color:var(--ink)}
.nav a.is-active{color:var(--ink);font-weight:600}
.nav a.is-active::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--accent);border-radius:2px}
.header__cta{margin-left:.4rem}

.nav-toggle{display:none;flex-direction:column;gap:5px;width:44px;height:44px;align-items:center;justify-content:center;background:transparent;border:1px solid var(--line);border-radius:10px;cursor:pointer}
.nav-toggle span{width:20px;height:2px;background:var(--ink);border-radius:2px;transition:.25s}
.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)}

/* ---------- Eyebrow / section heads ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-600);margin-bottom:1rem}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--accent);border-radius:2px}
.eyebrow--onDark{color:var(--accent-2)}
.eyebrow--onDark::before{background:var(--accent-2)}

.section{padding:clamp(64px,8vw,110px) 0}
.section--alt{background:var(--bg-alt);border-block:1px solid var(--line-soft)}
.section--dark{background:linear-gradient(160deg,var(--navy-900),var(--navy-800) 60%,var(--navy-700));color:#c6d4e4}
.section__head{max-width:760px;margin-bottom:3rem}
.section__head--center{margin-inline:auto;text-align:center}
.section__title{font-size:clamp(1.7rem,3.4vw,2.6rem);color:var(--ink)}
.section__title--light{color:#fff}
.section__intro{font-size:1.1rem;color:var(--slate-2);margin-top:1rem}
.section--dark .section__intro{color:#9fb2c6}

/* ---------- HERO (home) ---------- */
.hero{position:relative;background:linear-gradient(155deg,var(--navy-900) 0%,var(--navy-800) 55%,var(--navy-700) 100%);color:#dbe6f2;overflow:hidden}
.hero__bg{position:absolute;inset:0;background:
  radial-gradient(700px 380px at 78% 20%,rgba(92,208,255,.16),transparent 60%),
  radial-gradient(600px 400px at 88% 70%,rgba(22,183,174,.16),transparent 60%);
  pointer-events:none}
.hero__bg::after{content:"";position:absolute;inset:0;opacity:.5;
  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:48px 48px;mask-image:radial-gradient(circle at 70% 40%,#000,transparent 75%)}
.hero__grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:2.5rem;align-items:center;padding:clamp(56px,7vw,96px) var(--gutter)}
.hero__title{font-size:clamp(2.2rem,5vw,3.7rem);color:#fff;letter-spacing:-.02em;margin-bottom:1.4rem}
.hero__lead{font-size:1.18rem;color:#b9c9dc;max-width:44ch;margin-bottom:2rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2.4rem}
.hero__note{display:flex;align-items:flex-start;gap:.7rem;font-size:.95rem;color:#a9bccf;max-width:46ch;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.1)}
.hero__note .ic{color:var(--accent-2);margin-top:2px}
.hero__note strong{color:#fff}
.hero__viz{position:relative}
.viz{width:100%;height:auto;filter:drop-shadow(0 24px 60px rgba(0,0,0,.4))}
.viz__line{stroke-dasharray:900;stroke-dashoffset:900;animation:draw 2.2s ease forwards .3s}
.viz__nodes circle{opacity:0;animation:pop .4s ease forwards}
.viz__nodes circle:nth-child(1){animation-delay:1s}
.viz__nodes circle:nth-child(2){animation-delay:1.4s}
.viz__nodes circle:nth-child(3){animation-delay:1.8s}
.viz__nodes circle:nth-child(4){animation-delay:2.2s}
.viz__bars rect{transform-box:fill-box;transform-origin:bottom;transform:scaleY(0);animation:grow .8s cubic-bezier(.2,.8,.3,1) forwards}
.viz__bars rect:nth-child(1){animation-delay:.2s}.viz__bars rect:nth-child(2){animation-delay:.3s}
.viz__bars rect:nth-child(3){animation-delay:.4s}.viz__bars rect:nth-child(4){animation-delay:.5s}
.viz__bars rect:nth-child(5){animation-delay:.6s}.viz__bars rect:nth-child(6){animation-delay:.7s}
.viz__bars rect:nth-child(7){animation-delay:.8s}.viz__bars rect:nth-child(8){animation-delay:.9s}
.viz__bars rect:nth-child(9){animation-delay:1s}
.viz__donut{stroke-dasharray:0 264;animation:donut 1.6s ease forwards .8s}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes pop{from{opacity:0;transform:scale(.2)}to{opacity:1;transform:scale(1)}}
@keyframes grow{to{transform:scaleY(1)}}
@keyframes donut{to{stroke-dasharray:185 264}}

/* trust strip under hero */
.trustbar{background:var(--navy-850);border-top:1px solid rgba(255,255,255,.07);color:#8ea3ba}
.trustbar__row{display:flex;flex-wrap:wrap;gap:1rem 2.5rem;align-items:center;justify-content:center;padding:1.1rem 0;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase}
.trustbar__row span{display:inline-flex;align-items:center;gap:.55rem}
.trustbar__row .ic{width:16px;height:16px;color:var(--accent)}

/* ---------- Page hero (inner) ---------- */
.pagehero{position:relative;background:linear-gradient(155deg,var(--navy-900),var(--navy-800) 70%,var(--navy-700));color:#dbe6f2;overflow:hidden}
.pagehero__bg{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(600px 300px at 85% 15%,rgba(92,208,255,.14),transparent 60%),radial-gradient(500px 320px at 95% 90%,rgba(22,183,174,.14),transparent 60%)}
.pagehero__bg::after{content:"";position:absolute;inset:0;opacity:.4;
  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:46px 46px;mask-image:radial-gradient(circle at 80% 30%,#000,transparent 70%)}
.pagehero__inner{position:relative;padding:clamp(48px,6vw,84px) var(--gutter);max-width:820px}
.crumbs{display:flex;gap:.55rem;align-items:center;font-size:.82rem;color:#8ea3ba;margin-bottom:1.4rem}
.crumbs a{color:#a9bccf}.crumbs a:hover{color:#fff}
.pagehero__title{font-size:clamp(2rem,4.2vw,3.1rem);color:#fff;margin-bottom:1.1rem}
.pagehero__sub{font-size:1.12rem;color:#b9c9dc;max-width:58ch;margin:0}

/* ---------- Cards (capabilities) ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.card{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:1.9rem;box-shadow:var(--shadow-sm);transition:transform .22s,box-shadow .22s,border-color .22s;position:relative;overflow:hidden}
.card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card__icon{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:13px;background:var(--accent-soft);color:var(--accent-600);margin-bottom:1.2rem}
.card__icon svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.card__title{font-size:1.22rem;margin-bottom:.5rem}
.card__lead{font-size:.95rem;color:var(--slate-2);margin-bottom:1rem}
.card__list li{position:relative;padding-left:1.5rem;font-size:.94rem;color:var(--slate);margin-bottom:.4rem}
.card__list li::before{content:"";position:absolute;left:0;top:.62em;width:7px;height:7px;border-radius:2px;background:var(--accent);transform:rotate(45deg)}

/* ---------- About ---------- */
.about__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:3rem;align-items:start}
.about__text p{color:var(--slate);font-size:1.05rem}
.about__entity{padding:1.1rem 1.3rem;background:var(--bg);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--radius-sm);font-size:.98rem;margin-top:1.4rem}
.expertise{display:flex;flex-wrap:wrap;gap:.7rem;align-content:flex-start}
.expertise li{background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:.55rem 1.1rem;font-size:.92rem;font-weight:500;color:var(--ink);box-shadow:var(--shadow-sm)}
.expertise li::before{content:"";display:inline-block;width:7px;height:7px;background:var(--accent);border-radius:50%;margin-right:.55rem;vertical-align:middle}

/* two-column feature list */
.feature-split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.feature-split .section__title{margin-bottom:1rem}
@media(max-width:860px){.feature-split{grid-template-columns:1fr;gap:1.6rem}}

/* ---------- Pillars / approach ---------- */
.pillars{display:grid;grid-template-columns:repeat(6,1fr);gap:.8rem;counter-reset:p;margin-bottom:3rem}
.pillar{position:relative;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-sm);padding:1.4rem 1rem;text-align:center;box-shadow:var(--shadow-sm)}
.pillar__num{display:block;font-family:var(--display);font-weight:700;font-size:.85rem;color:var(--accent-600);margin-bottom:.5rem}
.pillar__name{font-weight:600;color:var(--ink);font-size:1rem}
.pillar:not(.pillar--end)::after{content:"→";position:absolute;right:-.72rem;top:50%;transform:translateY(-50%);color:var(--accent);font-weight:700;z-index:2}
.philosophy{background:linear-gradient(160deg,var(--navy-900),var(--navy-700));color:#dbe6f2;border-radius:var(--radius);padding:clamp(2rem,5vw,3.2rem);text-align:center}
.philosophy p{font-family:var(--display);font-size:clamp(1.15rem,2.6vw,1.7rem);color:#eaf2fb;margin:.2rem 0;line-height:1.5}
.philosophy strong{color:var(--accent-2)}

/* ---------- Stats ---------- */
.stats{background:var(--bg-tint);border-block:1px solid #d6ece9}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:clamp(48px,6vw,72px) var(--gutter)}
.stat{padding:.5rem 1.2rem;border-left:2px solid rgba(22,183,174,.35)}
.stat:first-child{border-left:none}
.stat__num{font-family:var(--display);font-weight:700;font-size:clamp(2.2rem,4vw,3rem);color:var(--navy-900);line-height:1}
.stat__num span{color:var(--accent-600)}
.stat__label{font-weight:700;color:var(--ink);margin:.4rem 0 .3rem}
.stat__desc{font-size:.9rem;color:var(--slate-2);margin:0}

/* ---------- Technology (dark) ---------- */
.tech__grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.tech__lead{font-size:1.1rem;color:#9fb2c6}
.tech__list{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.tech__list li{display:flex;align-items:center;gap:.8rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:var(--radius-sm);padding:1rem 1.1rem;color:#e3ecf5;font-weight:500}
.tech__list li::before{content:"";width:9px;height:9px;border-radius:2px;background:linear-gradient(var(--accent),var(--accent-2));transform:rotate(45deg);flex:0 0 auto}

/* generic dark cards used on technology page */
.darkcards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.darkcard{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:1.7rem}
.darkcard h3{color:#fff;font-size:1.12rem;margin-bottom:.5rem}
.darkcard p{color:#9fb2c6;font-size:.95rem;margin:0}
.darkcard .card__icon{background:rgba(92,208,255,.12);color:var(--accent-2)}

/* ---------- Industries ---------- */
.industries{display:flex;flex-wrap:wrap;gap:1rem}
.industry{flex:1 1 200px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-sm);padding:1.4rem 1.5rem;font-family:var(--display);font-weight:600;color:var(--ink);box-shadow:var(--shadow-sm);position:relative;padding-left:3rem}
.industry::before{content:"";position:absolute;left:1.3rem;top:50%;transform:translateY(-50%);width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}

/* ---------- Team ---------- */
.team{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.member{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;text-align:center;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}
.member:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.avatar{display:flex;align-items:center;justify-content:center;width:84px;height:84px;margin:0 auto 1.1rem;border-radius:50%;background:linear-gradient(150deg,var(--navy-800),var(--navy-600));color:#fff;font-family:var(--display);font-weight:700;font-size:1.6rem;letter-spacing:.03em;box-shadow:0 8px 22px rgba(11,33,64,.25);position:relative}
.avatar::after{content:attr(data-initials)}
.avatar::before{content:"";position:absolute;inset:-3px;border-radius:50%;background:conic-gradient(from 180deg,var(--accent),var(--accent-2),var(--accent));-webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 3px),#000 calc(100% - 3px));mask:radial-gradient(farthest-side,transparent calc(100% - 3px),#000 calc(100% - 3px))}
.member__name{font-size:1.15rem;margin-bottom:.25rem}
.member__role{color:var(--accent-600);font-weight:600;font-size:.9rem;margin-bottom:.6rem}
.member__bio{font-size:.9rem;color:var(--slate-2);margin-bottom:.8rem}
.member__mail{font-size:.85rem;color:var(--slate-2);word-break:break-word}
.member__mail:hover{color:var(--accent-600)}

/* ---------- Governance ---------- */
.gov{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-bottom:3rem}
.gov__item{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow-sm)}
.gov__item h3{font-size:1.08rem;margin-bottom:.5rem;display:flex;align-items:center;gap:.6rem}
.gov__item h3::before{content:"";width:10px;height:10px;border-radius:3px;background:linear-gradient(var(--accent),var(--accent-2));transform:rotate(45deg)}
.gov__item p{font-size:.94rem;color:var(--slate-2);margin:0}

.bcs{background:linear-gradient(160deg,var(--navy-900),var(--navy-700));color:#dbe6f2;border-radius:var(--radius);padding:clamp(2rem,5vw,3rem)}
.bcs__tag{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2);margin-bottom:1rem}
.bcs p{font-size:1.15rem;color:#e3ecf5;max-width:72ch;margin:0;line-height:1.6}
.bcs strong{color:#fff}

/* ---------- Mission / Vision ---------- */
.mv{background:linear-gradient(160deg,var(--navy-900),var(--navy-800));color:#dbe6f2}
.mv__grid{display:grid;grid-template-columns:1fr auto 1fr;gap:2.5rem;align-items:center;padding:clamp(48px,6vw,80px) var(--gutter)}
.mv__item p{font-family:var(--display);font-size:clamp(1.2rem,2.4vw,1.55rem);color:#fff;line-height:1.45;margin:0}
.mv__divider{width:1px;align-self:stretch;background:linear-gradient(transparent,rgba(255,255,255,.25),transparent)}

/* ---------- Contact ---------- */
.contact__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:start}
.contact__list{margin-top:1.5rem}
.contact__list li{display:flex;align-items:flex-start;gap:.9rem;margin-bottom:1.1rem;color:var(--slate)}
.contact__list .ic{width:20px;height:20px;color:var(--accent-600);margin-top:2px}
.registry{background:var(--navy-900);color:#c6d4e4;border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow-lg)}
.registry__title{color:#fff;font-size:1.15rem;margin-bottom:1.2rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.12)}
.registry__list>div{display:flex;justify-content:space-between;gap:1rem;padding:.55rem 0;border-bottom:1px dashed rgba(255,255,255,.1);font-size:.92rem}
.registry__list>div:last-child{border-bottom:none}
.registry__list dt{color:#8ea3ba}
.registry__list dd{margin:0;color:#fff;font-weight:600;text-align:right}

/* contact form */
.cform{margin-top:2rem;display:grid;gap:1rem}
.cform__row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field label{font-size:.85rem;font-weight:600;color:var(--ink)}
.field input,.field textarea{font-family:inherit;font-size:.95rem;padding:.8rem 1rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg);color:var(--ink);transition:border-color .2s,box-shadow .2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.field textarea{resize:vertical;min-height:130px}
.formnote{font-size:.85rem;color:var(--slate-2)}
.alert{padding:.9rem 1.2rem;border-radius:var(--radius-sm);font-size:.95rem;margin-bottom:1rem}
.alert--ok{background:#e7f7f2;border:1px solid #b6e6d8;color:#0d6b53}
.alert--err{background:#fdecec;border:1px solid #f5c2c2;color:#a12626}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:.8rem;max-width:840px;margin-inline:auto}
.faq__item{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-sm);padding:1.3rem 1.5rem;box-shadow:var(--shadow-sm)}
.faq__item h3{font-size:1.05rem;margin-bottom:.5rem}
.faq__item p{margin:0;color:var(--slate-2);font-size:.96rem}

/* ---------- CTA band ---------- */
.cta{background:linear-gradient(120deg,var(--navy-900),var(--navy-700));color:#fff;text-align:center}
.cta__inner{padding:clamp(56px,7vw,88px) var(--gutter);max-width:720px;margin-inline:auto}
.cta h2{color:#fff;font-size:clamp(1.7rem,3.4vw,2.4rem);margin-bottom:1rem}
.cta p{color:#b9c9dc;font-size:1.1rem;margin-bottom:2rem}

/* ---------- Footer ---------- */
.footer{background:var(--navy-900);color:#9fb2c6;padding-top:clamp(48px,6vw,72px)}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.1)}
.footer__brand p{margin:1.1rem 0;font-size:.92rem;max-width:34ch}
.footer__social{display:flex;gap:.7rem}
.footer__social a{display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.15);border-radius:10px;color:#c6d4e4}
.footer__social a:hover{background:var(--accent);border-color:var(--accent);color:#04231f}
.footer__col h4{color:#fff;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1.1rem}
.footer__col a{display:block;color:#9fb2c6;font-size:.92rem;padding:.28rem 0}
.footer__col a:hover{color:#fff}
.footer__address{font-size:.9rem;line-height:1.7;margin:0}
.footer__bottom{padding:1.4rem 0}
.footer__bottom-row{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:#7f95ac}

/* ---------- Legal / prose ---------- */
.prose{max-width:820px}
.prose h2{font-size:1.4rem;margin:2.2rem 0 .8rem}
.prose h2:first-child{margin-top:0}
.prose p,.prose li{color:var(--slate);font-size:1.02rem}
.prose ul{margin:0 0 1rem;padding-left:0}
.prose ul li{position:relative;padding-left:1.4rem;margin-bottom:.4rem}
.prose ul li::before{content:"";position:absolute;left:0;top:.62em;width:7px;height:7px;background:var(--accent);border-radius:2px;transform:rotate(45deg)}
.prose a{text-decoration:underline}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.is-in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:1000px){
  .cards,.darkcards,.gov{grid-template-columns:repeat(2,1fr)}
  .team{grid-template-columns:repeat(2,1fr)}
  .pillars{grid-template-columns:repeat(3,1fr)}
  .pillar:nth-child(3)::after{display:none}
}
@media(max-width:900px){
  .nav,.header__cta{display:none}
  .nav-toggle{display:flex}
  .nav.is-open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow-md);padding:.5rem var(--gutter) 1rem;margin:0}
  .nav.is-open a{padding:.9rem 0;border-bottom:1px solid var(--line-soft)}
  .nav.is-open a.is-active::after{display:none}
  .header{position:sticky}
  .hero__grid,.about__grid,.tech__grid,.contact__grid{grid-template-columns:1fr;gap:2rem}
  .hero__viz{order:-1;max-width:460px}
  .stats__grid{grid-template-columns:repeat(2,1fr);gap:1.6rem}
  .stat{border-left:none;padding-left:0}
  .mv__grid{grid-template-columns:1fr;gap:1.6rem}
  .mv__divider{height:1px;width:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent)}
  .tech__list{grid-template-columns:1fr}
}
@media(max-width:620px){
  .cards,.darkcards,.gov,.team,.pillars{grid-template-columns:1fr}
  .pillar::after{display:none!important}
  .cform__row{grid-template-columns:1fr}
  .stats__grid{grid-template-columns:1fr}
  .utilitybar__item:last-child{display:none}
  .registry__list>div{flex-direction:column;gap:.1rem}
  .registry__list dd{text-align:left}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  /* show the data-viz in its final state when motion is disabled */
  .viz__line{stroke-dashoffset:0}
  .viz__bars rect{transform:none}
  .viz__nodes circle{opacity:1}
  .viz__donut{stroke-dasharray:185 264}
}
