/* ============================================================
   Foundation InfoSec — Secure Operations design system
   Shared across all pages.
   ============================================================ */
:root{
  --blue:#2E5BFF;--blue-bright:#5B82FF;--cyan:#34E5DC;
  --bg:#070B16;--bg-2:#0B1122;--panel:#0E1628;--panel-2:#121C33;
  --line:#1C2740;--line-2:#27344F;
  --txt:#E6ECF7;--mut:#8A97B4;--mut-2:#5C6A8A;
  --maxw:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'IBM Plex Sans',system-ui,sans-serif;color:var(--txt);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;line-height:1.06;letter-spacing:-0.02em;font-weight:600}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.mono{font-family:'IBM Plex Mono',monospace}
.eyebrow{font-family:'IBM Plex Mono';font-size:12px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 12px var(--cyan);display:inline-block}
.txt-blue{color:var(--blue-bright)}
.center{text-align:center}

/* ---------- NAV ---------- */
header.nav{position:sticky;top:0;z-index:60;background:rgba(7,11,22,.8);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:13px 32px;display:flex;align-items:center;gap:30px}
.brand{display:flex;align-items:center;gap:11px;font-family:'Space Grotesk';font-weight:600;font-size:18px;white-space:nowrap}
.brand img{width:30px;height:30px;filter:drop-shadow(0 0 10px rgba(46,91,255,.6))}
.brand .sub{display:block;font-family:'IBM Plex Mono';font-size:9px;letter-spacing:.22em;color:var(--mut-2);margin-top:1px;font-weight:400}
.navlinks{display:flex;gap:26px;margin-left:auto;font-size:14.5px;font-weight:500}
.navlinks a{color:var(--mut);transition:color .15s;position:relative;padding:4px 0}
.navlinks a:hover,.navlinks a.active{color:var(--txt)}
.navlinks a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--blue);border-radius:2px}
.nav-cta{display:flex;align-items:center;gap:16px}
.phone{font-family:'IBM Plex Mono';font-size:13px;color:var(--mut);display:flex;align-items:center;gap:7px;white-space:nowrap}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:'IBM Plex Sans';font-weight:600;font-size:14.5px;padding:11px 20px;border-radius:8px;transition:.18s;cursor:pointer;border:1px solid transparent;white-space:nowrap}
.btn svg{width:15px;height:15px}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 0 0 1px rgba(91,130,255,.4),0 8px 30px rgba(46,91,255,.35)}
.btn-primary:hover{background:var(--blue-bright);transform:translateY(-1px)}
.btn-ghost{background:rgba(255,255,255,.03);color:var(--txt);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--blue-bright);background:rgba(46,91,255,.08)}
.btn-lg{padding:14px 26px;font-size:15.5px}
.menu-btn{display:none;background:none;border:1px solid var(--line-2);border-radius:7px;padding:8px;cursor:pointer}
.mobnav{display:none;flex-direction:column;padding:8px 20px 20px;border-bottom:1px solid var(--line);background:var(--bg)}
.mobnav.open{display:flex}
.mobnav a{padding:11px 0;border-bottom:1px solid var(--line);font-weight:500;color:var(--mut)}

/* ---------- HERO (home) ---------- */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero-bg{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:48px 48px;opacity:.6;mask-image:radial-gradient(130% 100% at 75% 0,#000 25%,transparent 70%)}
.hero-glow{position:absolute;top:-10%;right:-5%;width:60%;height:80%;background:radial-gradient(circle,rgba(46,91,255,.28),transparent 62%);filter:blur(30px);pointer-events:none}
.scanline{position:absolute;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);opacity:.4;animation:scanmove 7s linear infinite}
@keyframes scanmove{0%{top:0}100%{top:100%}}
.hero-in{max-width:var(--maxw);margin:0 auto;padding:92px 32px 88px;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;position:relative}
.hero h1{font-size:clamp(40px,5.3vw,70px);font-weight:700;margin:22px 0 0;letter-spacing:-0.03em}
.hero h1 em{font-style:normal;color:var(--blue-bright);text-shadow:0 0 40px rgba(91,130,255,.5)}
.hero p.lead{font-size:18.5px;color:var(--mut);max-width:46ch;margin:24px 0 0}
.console{margin-top:28px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:14px 16px;font-family:'IBM Plex Mono';font-size:13.5px;max-width:480px;box-shadow:0 20px 50px rgba(0,0,0,.5)}
.console .bar{display:flex;gap:6px;margin-bottom:11px}
.console .bar i{width:9px;height:9px;border-radius:50%;background:var(--line-2)}
.console .bar i:first-child{background:#ff5f57}.console .bar i:nth-child(2){background:#febc2e}.console .bar i:nth-child(3){background:#28c840}
.console .ln{color:var(--mut);white-space:nowrap;overflow:hidden}
.console .ln b{color:var(--cyan);font-weight:500}
.console .cur{color:var(--blue-bright)}
.hero-cta{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.stats{display:flex;gap:36px;margin-top:42px;padding-top:28px;border-top:1px solid var(--line)}
.stat .n{font-family:'Space Grotesk';font-weight:700;font-size:32px;color:#fff}
.stat .n span{color:var(--cyan)}
.stat .l{font-size:12.5px;color:var(--mut-2);margin-top:2px}
.hero-vis{position:relative;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center}
.hero-vis .ring{position:absolute;border:1px solid var(--line-2);border-radius:50%}
.r1{inset:2%}.r2{inset:16%}.r3{inset:30%}
.scan{position:absolute;inset:2%;border-radius:50%;border:1.5px solid transparent;border-top-color:var(--blue-bright);animation:spin 9s linear infinite}
.scan.b{inset:16%;border-top-color:transparent;border-right-color:var(--cyan);animation-duration:14s;animation-direction:reverse}
@keyframes spin{to{transform:rotate(360deg)}}
.hero-mark{width:44%;filter:drop-shadow(0 0 50px rgba(46,91,255,.85));z-index:2;animation:pulse 4s ease-in-out infinite}
@keyframes pulse{0%,100%{filter:drop-shadow(0 0 40px rgba(46,91,255,.7))}50%{filter:drop-shadow(0 0 70px rgba(91,130,255,1))}}
.chip-float{position:absolute;background:rgba(14,22,40,.9);border:1px solid var(--line-2);border-radius:8px;padding:8px 12px;font-family:'IBM Plex Mono';font-size:11.5px;backdrop-filter:blur(8px);display:flex;align-items:center;gap:8px;z-index:3}
.chip-float .dot{width:7px;height:7px;border-radius:50%;background:#28c840;box-shadow:0 0 8px #28c840}
.cf1{top:12%;left:-3%}.cf2{bottom:22%;right:-5%}.cf3{bottom:5%;left:10%}

/* ---------- PAGE HEADER (inner pages) ---------- */
.pagehead{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.pagehead-bg{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:46px 46px;opacity:.5;mask-image:radial-gradient(120% 120% at 80% 0,#000 20%,transparent 70%)}
.pagehead-glow{position:absolute;top:-30%;right:5%;width:45%;height:120%;background:radial-gradient(circle,rgba(46,91,255,.22),transparent 62%);filter:blur(30px)}
.pagehead-in{position:relative;max-width:var(--maxw);margin:0 auto;padding:64px 32px 60px}
.crumb{font-family:'IBM Plex Mono';font-size:12px;color:var(--mut-2);letter-spacing:.05em;margin-bottom:18px;display:flex;gap:8px;align-items:center}
.crumb a{color:var(--mut)}.crumb a:hover{color:var(--cyan)}
.pagehead h1{font-size:clamp(34px,4.6vw,58px);font-weight:700;color:#fff;letter-spacing:-0.03em;max-width:20ch}
.pagehead h1 em{font-style:normal;color:var(--blue-bright)}
.pagehead p{color:var(--mut);font-size:18px;max-width:60ch;margin-top:20px}

/* ---------- STANDARDS MARQUEE ---------- */
.standards{background:var(--bg-2);border-bottom:1px solid var(--line);padding:20px 0;overflow:hidden}
.marquee{display:flex;white-space:nowrap;animation:slide 32s linear infinite;width:max-content}
.standards:hover .marquee{animation-play-state:paused}
@keyframes slide{to{transform:translateX(-50%)}}
.mq-item{display:inline-flex;align-items:center;padding:0 28px;font-family:'IBM Plex Mono';font-size:13.5px;color:var(--mut)}
.mq-item::after{content:"";width:4px;height:4px;border-radius:50%;background:var(--blue);margin-left:28px}

/* ---------- SECTION SCAFFOLD ---------- */
section{padding:96px 0}
.sec-head{max-width:680px}
.sec-head.center{margin:0 auto;text-align:center}
.sec-head h2{font-size:clamp(30px,3.7vw,46px);margin:16px 0 0;color:#fff;font-weight:600}
.sec-head h2 em{font-style:normal;color:var(--blue-bright)}
.sec-head p{color:var(--mut);font-size:17px;margin-top:18px}
.alt{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* services grid (home) */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:52px}
.svc{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:24px 22px 26px;position:relative;transition:.22s;min-height:230px;display:flex;flex-direction:column;overflow:hidden}
.svc::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--blue),transparent);opacity:0;transition:.22s}
.svc:hover{border-color:var(--line-2);transform:translateY(-3px);box-shadow:0 18px 44px rgba(0,0,0,.45)}
.svc:hover::before{opacity:1}
.svc .num{font-family:'IBM Plex Mono';font-size:11.5px;color:var(--mut-2)}
.svc .ic{width:38px;height:38px;border-radius:9px;background:var(--panel-2);border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center;color:var(--blue-bright);margin:16px 0 14px}
.svc .ic svg{width:20px;height:20px;stroke-width:1.7}
.svc h3{font-size:17.5px;color:#fff}
.svc p{font-size:13.5px;color:var(--mut);margin-top:8px;line-height:1.55}
.svc .arrow{margin-top:auto;padding-top:14px;color:var(--cyan);opacity:0;transform:translateX(-6px);transition:.2s;font-size:12.5px;font-family:'IBM Plex Mono';display:flex;align-items:center;gap:6px}
.svc:hover .arrow{opacity:1;transform:translateX(0)}
.svc.link{cursor:pointer}

/* why / credo */
.why-in{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.credo{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.credo .it{background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:20px}
.credo .it h4{font-size:14.5px;color:#fff;display:flex;align-items:center;gap:9px;font-family:'Space Grotesk'}
.credo .it h4 svg{width:16px;height:16px;color:var(--cyan);stroke-width:2.2;flex-shrink:0}
.credo .it p{font-size:13px;color:var(--mut);margin-top:6px;line-height:1.5}
.assessor{display:inline-flex;align-items:center;gap:13px;background:var(--panel);border:1px solid var(--line-2);border-radius:11px;padding:14px 18px;margin-top:24px}
.assessor .seal{width:42px;height:42px;border-radius:9px;background:var(--blue);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 0 22px rgba(46,91,255,.6)}
.assessor .seal svg{width:22px;height:22px;stroke-width:2}
.assessor b{font-size:14.5px;color:#fff}
.assessor span{display:block;font-size:12.5px;color:var(--mut)}

/* industries grid (home) */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:50px}
.ind{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:24px;transition:.2s;position:relative;display:block}
.ind:hover{border-color:var(--blue);box-shadow:0 0 0 1px var(--blue),0 16px 40px rgba(46,91,255,.18)}
.ind .ic{width:26px;height:26px;color:var(--cyan);stroke-width:1.6}
.ind h3{font-size:17.5px;margin:14px 0 8px;color:#fff}
.ind p{font-size:13.5px;color:var(--mut)}
.ind .tag{position:absolute;top:20px;right:20px;font-family:'IBM Plex Mono';font-size:10px;color:var(--mut-2);border:1px solid var(--line-2);border-radius:5px;padding:3px 7px}

/* ---------- FEATURE ROWS (detail pages) ---------- */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:30px 0}
.feature + .feature{border-top:1px solid var(--line)}
.feature .fnum{font-family:'IBM Plex Mono';font-size:13px;color:var(--blue-bright);letter-spacing:.08em}
.feature h2{font-size:clamp(26px,3vw,38px);color:#fff;margin:14px 0 0;font-weight:600}
.feature .sub{font-family:'IBM Plex Mono';font-size:13.5px;color:var(--cyan);margin-top:10px;letter-spacing:.02em}
.feature p{color:var(--mut);font-size:16px;margin-top:18px;line-height:1.7}
.feature .blist{list-style:none;margin-top:22px;display:grid;gap:11px}
.feature .blist li{display:flex;gap:12px;font-size:14.5px;color:var(--txt)}
.feature .blist li svg{width:18px;height:18px;color:var(--blue-bright);flex-shrink:0;margin-top:3px;stroke-width:2.2}
.feature .fbtn{margin-top:26px}
.feature .fcard{background:var(--panel);border:1px solid var(--line);border-radius:16px;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.feature .fcard .grid-ov{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:34px 34px;opacity:.5}
.feature .fcard .fmark{width:40%;filter:drop-shadow(0 0 36px rgba(46,91,255,.7));z-index:2;opacity:.95}
.feature .fcard .ic-lg{width:30%;color:var(--blue-bright);z-index:2;stroke-width:1.3;filter:drop-shadow(0 0 30px rgba(46,91,255,.5))}
.feature:nth-child(even) .fmedia{order:-1}
@media(min-width:861px){.feature:nth-child(even) .fcol-text{order:2}}

/* ---------- CONTENT (about / generic) ---------- */
.lede{font-size:21px;color:var(--txt);line-height:1.65;max-width:60ch}
.prose p{color:var(--mut);font-size:16.5px;line-height:1.75;margin-top:18px;max-width:68ch}
.prose a{color:var(--blue-bright);border-bottom:1px solid var(--line-2)}
.prose a:hover{border-color:var(--blue-bright)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.card-soft{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:28px}
.card-soft h3{color:#fff;font-size:20px;margin-bottom:12px}
.card-soft p{color:var(--mut);font-size:15px;line-height:1.65}

/* credo full list (about) */
.credo-list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:14px}
.credo-list .it{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:22px;transition:.2s}
.credo-list .it:hover{border-color:var(--line-2)}
.credo-list .it .h{display:flex;align-items:center;gap:11px}
.credo-list .it .h svg{width:18px;height:18px;color:var(--cyan);stroke-width:2.2;flex-shrink:0}
.credo-list .it h4{font-family:'Space Grotesk';font-size:16px;color:#fff}
.credo-list .it p{color:var(--mut);font-size:14px;margin-top:9px;line-height:1.6}

/* ---------- CTA BAND ---------- */
.cta-band{background:linear-gradient(135deg,var(--panel-2),var(--panel));border:1px solid var(--line-2);border-radius:18px;padding:64px 56px;position:relative;overflow:hidden}
.cta-band .glow{position:absolute;top:-40%;right:-10%;width:50%;height:120%;background:radial-gradient(circle,rgba(46,91,255,.35),transparent 60%);filter:blur(20px)}
.cta-band h2{font-size:clamp(30px,3.8vw,46px);position:relative;max-width:20ch;color:#fff;font-weight:600}
.cta-band p{color:var(--mut);margin-top:18px;font-size:17px;position:relative;max-width:50ch}
.cta-row{display:flex;gap:14px;margin-top:32px;position:relative;flex-wrap:wrap}

/* ---------- CONTACT FORM ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start}
.contact-info .ci{display:flex;gap:14px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--line)}
.contact-info .ci:first-of-type{border-top:1px solid var(--line)}
.contact-info .ci .ico{width:40px;height:40px;border-radius:9px;background:var(--panel);border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center;color:var(--blue-bright);flex-shrink:0}
.contact-info .ci .ico svg{width:19px;height:19px;stroke-width:1.8}
.contact-info .ci .lab{font-family:'IBM Plex Mono';font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--mut-2)}
.contact-info .ci .val{font-size:16px;color:#fff;margin-top:3px}
.contact-info .ci .val a{color:#fff}.contact-info .ci .val a:hover{color:var(--cyan)}
.socials{display:flex;gap:12px;margin-top:24px}
.socials a{width:42px;height:42px;border-radius:9px;border:1px solid var(--line-2);background:var(--panel);display:flex;align-items:center;justify-content:center;color:var(--mut);transition:.18s}
.socials a:hover{color:#fff;border-color:var(--blue);background:rgba(46,91,255,.1)}
.socials a svg{width:20px;height:20px}
.formcard{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:32px;position:relative;overflow:hidden}
.formcard .topglow{position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--blue),transparent)}
.field{margin-bottom:18px}
.field label{display:block;font-family:'IBM Plex Mono';font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--mut);margin-bottom:8px}
.field input,.field textarea{width:100%;background:var(--bg-2);border:1px solid var(--line-2);border-radius:9px;padding:13px 15px;color:var(--txt);font-family:'IBM Plex Sans';font-size:15px;transition:.15s;resize:vertical}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(46,91,255,.18)}
.field input::placeholder,.field textarea::placeholder{color:var(--mut-2)}
.hp{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.formnote{font-size:12.5px;color:var(--mut-2);margin-top:8px;display:flex;align-items:center;gap:7px}
.formnote svg{width:14px;height:14px;color:var(--cyan);flex-shrink:0}
.formmsg{display:none;border-radius:9px;padding:13px 15px;font-size:14px;margin-bottom:18px}
.formmsg.ok{background:rgba(40,200,64,.1);border:1px solid rgba(40,200,64,.4);color:#7ee08a}
.formmsg.err{background:rgba(255,95,87,.1);border:1px solid rgba(255,95,87,.4);color:#ff9b95}

/* ---------- FOOTER ---------- */
footer{background:var(--bg-2);border-top:1px solid var(--line);padding:64px 0 32px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.foot-grid h5{font-family:'IBM Plex Mono';font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mut-2);margin-bottom:16px}
.foot-grid a{display:block;color:var(--mut);font-size:14px;margin-bottom:10px;transition:color .15s}
.foot-grid a:hover{color:var(--cyan)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:54px;padding-top:24px;border-top:1px solid var(--line);font-size:13px;color:var(--mut-2);flex-wrap:wrap;gap:12px}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.vis{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.scan,.scanline,.hero-mark,.marquee{animation:none}}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1024px){
  .hero-in{grid-template-columns:1fr;gap:30px}
  .hero-vis{max-width:420px;order:-1}
  .why-in{grid-template-columns:1fr;gap:36px}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .navlinks,.phone{display:none}
}
@media(max-width:860px){
  .feature{grid-template-columns:1fr;gap:26px}
  .feature .fmedia{order:-1 !important}
  .feature .fcard{aspect-ratio:16/9}
  .split,.contact-grid{grid-template-columns:1fr;gap:32px}
  .credo-list{grid-template-columns:1fr}
}
@media(max-width:640px){
  .wrap,.nav-in,.hero-in,.pagehead-in{padding-left:20px;padding-right:20px}
  .menu-btn{display:block;margin-left:auto}
  .nav-cta .btn-ghost{display:none}
  .svc-grid,.ind-grid,.credo{grid-template-columns:1fr}
  .stats{flex-wrap:wrap;gap:22px}
  .cta-band{padding:44px 26px}
  .foot-grid{grid-template-columns:1fr 1fr}
  section{padding:64px 0}
}
