/* ==========================================================================
   NorthMSP — site stylesheet
   Design system shared across all pages. Dark, premium, engineered.
   ========================================================================== */
:root{
  --black:#08080A;
  --bg:#0A0A0C;
  --surface:#121215;
  --surface-2:#16161A;
  --raised:#1C1C21;
  --navy:#0C1320;
  --navy-deep:#0A0F1A;
  --navy-surface:#10131C;
  --navy-tint:rgba(58,90,150,0.06);
  --white:#F5F3EF;
  --muted:#A2A2AA;
  --faint:#808089;
  --orange:#FF6800;
  --orange-soft:#FF8534;
  --hair:rgba(255,255,255,0.08);
  --hair-2:rgba(255,255,255,0.05);
  --maxw:1240px;
  --display:'Archivo',sans-serif;
  --body:'Sora',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--white);font-family:var(--body);font-weight:300;
  line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
::selection{background:var(--orange);color:#fff}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.05;letter-spacing:-0.02em}
.eyebrow{font-family:var(--display);font-size:.72rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--orange);display:inline-flex;align-items:center;gap:.7rem}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--orange)}
.eyebrow.center{justify-content:center}
p{color:var(--muted);font-size:1.0625rem}
.lead{font-size:1.2rem;color:#C9C9D0;font-weight:300;line-height:1.6}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 2rem}
section{position:relative}
.section-pad{padding:7rem 0}
.section-pad-sm{padding:5rem 0}
.bg-black{background:linear-gradient(180deg, var(--navy-deep) 0%, var(--black) 60%);border-top:1px solid var(--hair)}

/* ---------- buttons ---------- */
.btn{font-family:var(--display);font-weight:600;font-size:.9rem;letter-spacing:.01em;padding:.72rem 1.4rem;border-radius:7px;display:inline-flex;align-items:center;gap:.55rem;transition:transform .18s ease, box-shadow .25s ease, background .25s;cursor:pointer;border:none}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 0 0 0 rgba(255,104,0,0)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px -8px rgba(255,104,0,.55)}
.btn-ghost{background:transparent;color:var(--white);border:1px solid var(--hair)}
.btn-ghost:hover{border-color:rgba(255,255,255,.28);background:rgba(255,255,255,.03)}
.btn .arr{transition:transform .2s}
.btn:hover .arr{transform:translateX(3px)}

/* ---------- nav ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .4s ease, border-color .4s ease;border-bottom:1px solid transparent}
header.scrolled{background:rgba(8,8,10,.82);backdrop-filter:blur(18px);border-bottom:1px solid var(--hair)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.nav-logo img{height:26px;width:auto}
.nav-links{display:flex;align-items:center;gap:2.1rem;list-style:none}
.nav-links>li{position:relative}
.nav-links>li>a{font-size:.92rem;color:#D6D6DC;font-weight:400;position:relative;padding:.4rem 0;transition:color .2s;display:inline-flex;align-items:center}
.nav-links>li>a:hover{color:#fff}
.nav-links a.has-menu::after{content:"";display:inline-block;width:5px;height:5px;border-right:1.5px solid var(--faint);border-bottom:1.5px solid var(--faint);transform:rotate(45deg);margin-left:7px;margin-bottom:2px;transition:border-color .2s,transform .2s}
.nav-links>li:hover a.has-menu::after{border-color:var(--orange);transform:rotate(225deg);margin-bottom:-2px}
.nav-links>li>a[aria-current="page"]{color:#fff}
.nav-links>li>a[aria-current="page"]::before{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:2px;background:var(--orange)}

/* mega menu */
.mega{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);background:rgba(14,14,17,.97);backdrop-filter:blur(20px);border:1px solid var(--hair);border-radius:14px;padding:1.5rem;min-width:540px;opacity:0;visibility:hidden;transition:opacity .25s ease,transform .25s ease;box-shadow:0 30px 60px -20px rgba(0,0,0,.7);z-index:120}
.nav-links>li:hover .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.mega::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:.4rem 2rem}
.mega-grid.single{grid-template-columns:1fr}
.mega-col h5{font-family:var(--display);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin:.4rem 0 .7rem;font-weight:700}
.mega a{display:block;padding:.6rem .7rem;border-radius:8px;transition:background .2s;margin:0 -.3rem}
.mega a:hover{background:rgba(255,255,255,.04)}
.mega a .t{display:block;font-size:.95rem;color:#fff;font-weight:400;font-family:var(--display)}
.mega a .d{display:block;font-size:.8rem;color:var(--faint);margin-top:.15rem;line-height:1.4}
.mega a:hover .t{color:var(--orange)}
.nav-cta{display:flex;align-items:center;gap:1.1rem}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;z-index:130}
.burger span{width:24px;height:2px;background:#fff;transition:.3s}

/* mobile drawer */
.drawer{position:fixed;inset:0;background:rgba(8,8,10,.98);backdrop-filter:blur(8px);z-index:125;transform:translateX(100%);transition:transform .35s cubic-bezier(.16,1,.3,1);padding:6rem 2rem 2rem;overflow-y:auto;display:none}
.drawer.open{transform:translateX(0)}
.drawer a{display:block;font-family:var(--display);font-size:1.4rem;font-weight:600;padding:1rem 0;border-bottom:1px solid var(--hair-2);color:#fff}
.drawer a.sub{font-size:1rem;font-weight:400;color:var(--muted);padding:.6rem 0 .6rem 1rem;border:none}
.drawer .btn{margin-top:1.5rem;width:100%;justify-content:center;font-size:1rem}

/* ---------- page hero (inner pages) ---------- */
.phero{padding:11rem 0 4rem;position:relative;overflow:hidden;border-bottom:1px solid var(--hair)}
.phero-grid{position:absolute;inset:0;z-index:0;opacity:.4;background-image:linear-gradient(var(--hair-2) 1px,transparent 1px),linear-gradient(90deg,var(--hair-2) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse 70% 80% at 80% 20%,#000,transparent 75%)}
.phero-glow{position:absolute;top:-10%;right:-5%;width:520px;height:520px;background:radial-gradient(circle,rgba(255,104,0,.12),transparent 62%);z-index:0;pointer-events:none}
.phero-inner{position:relative;z-index:2;max-width:62ch}
.phero h1{font-size:clamp(2.4rem,5vw,4rem);font-weight:800;letter-spacing:-0.035em;margin-top:1.3rem}
.phero h1 .accent{color:var(--orange)}
.phero .sub{font-size:1.2rem;color:#CFCFD6;margin-top:1.6rem;line-height:1.6;max-width:54ch}
.phero-cta{display:flex;gap:1rem;margin-top:2.2rem;flex-wrap:wrap}
.breadcrumb{font-size:.82rem;color:var(--faint);display:flex;gap:.5rem;align-items:center}
.breadcrumb a:hover{color:var(--orange)}
.breadcrumb span{color:var(--hair)}

/* ---------- section heading ---------- */
.sec-head{max-width:62ch}
.sec-head.center{margin:0 auto;text-align:center}
.sec-head h2{font-size:clamp(2rem,3.6vw,2.9rem);margin-top:1.1rem;letter-spacing:-0.03em}
.sec-head h2 .accent{color:var(--orange)}
.sec-head p{margin-top:1.2rem;font-size:1.12rem;line-height:1.6}

/* ---------- cards ---------- */
.cards-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-top:3.4rem}
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:3.4rem}
.cards-2{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-top:3.4rem}
.card{background:linear-gradient(180deg,var(--navy-surface) 0%, #0C0C10 100%);border:1px solid var(--hair);border-radius:14px;padding:2rem 1.7rem;position:relative;overflow:hidden;transition:transform .3s cubic-bezier(.16,1,.3,1),border-color .3s}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--orange),transparent);transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.card:hover{transform:translateY(-6px);border-color:rgba(255,104,0,.35)}
.card:hover::before{transform:scaleX(1)}
.card .ico{width:42px;height:42px;margin-bottom:1.3rem;color:var(--orange)}
.card h3{font-size:1.22rem;font-weight:700;margin-bottom:.7rem;letter-spacing:-0.01em}
.card p{font-size:.96rem;line-height:1.6}
.card .more{margin-top:1.3rem;font-size:.82rem;font-family:var(--display);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);display:flex;align-items:center;gap:.5rem;transition:color .2s}
.card:hover .more{color:var(--orange)}

/* feature list cards (teach-style services) */
.feat{border:1px solid var(--hair);border-radius:14px;padding:1.9rem 1.7rem;background:var(--surface);transition:background .3s,border-color .3s}
.feat:hover{background:var(--surface-2)}
.feat .ico{width:34px;height:34px;color:var(--orange);margin-bottom:1rem}
.feat h3{font-size:1.1rem;margin-bottom:.6rem;font-weight:700}
.feat p{font-size:.94rem;line-height:1.58}
.feat .fact{margin-top:.9rem;font-size:.82rem;color:var(--orange-soft);font-family:var(--display);font-weight:500}

/* ---------- diff cards ---------- */
.diff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:3.4rem}
.diff{border:1px solid var(--hair);border-radius:14px;padding:1.9rem 1.7rem;background:linear-gradient(160deg, var(--navy-surface), var(--surface) 70%);transition:background .3s,border-color .3s}
.diff:hover{background:var(--surface-2);border-color:rgba(255,104,0,.25)}
.diff .num{font-family:var(--display);font-weight:700;font-size:.8rem;color:var(--orange);letter-spacing:.1em}
.diff h3{font-size:1.12rem;margin:.9rem 0 .65rem;font-weight:700}
.diff p{font-size:.95rem;line-height:1.58}

/* ---------- two-engagement-model split ---------- */
.split-2{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-top:3.4rem}
.model{border:1px solid var(--hair);border-radius:16px;padding:2.4rem;background:var(--surface);position:relative;overflow:hidden}
.model.feature{border:none;background:linear-gradient(150deg, #FF6800 0%, #E85800 70%, #D24E00 100%);position:relative;overflow:hidden}
.model.feature::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 80% 0%, rgba(255,210,160,0.45), transparent 55%);pointer-events:none}
.model.feature .tagline{color:rgba(26,14,4,0.7);position:relative;z-index:2}
.model.feature h3{color:#15100A;position:relative;z-index:2}
.model.feature>p{color:rgba(30,16,4,0.85);position:relative;z-index:2}
.model.feature ul{position:relative;z-index:2}
.model.feature li{color:#241405;border-top-color:rgba(26,14,4,0.16)}
.model.feature li svg{color:#15100A}
.model.feature .btn-primary{background:#15120F;color:#fff;position:relative;z-index:2}
.model.feature .btn-primary:hover{background:#000}
.model .tagline{font-size:.8rem;color:var(--faint);font-family:var(--display);font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.model h3{font-size:1.6rem;margin:.7rem 0 1rem;font-weight:800;letter-spacing:-0.02em}
.model>p{font-size:1rem;line-height:1.6;margin-bottom:1.4rem}
.model ul{list-style:none}
.model li{font-size:.95rem;color:#C2C2C9;padding:.6rem 0;border-top:1px solid var(--hair-2);display:flex;gap:.7rem;line-height:1.5}
.model li:first-child{border-top:none}
.model li svg{width:17px;height:17px;color:var(--orange);flex:none;margin-top:3px}
.model .btn{margin-top:1.6rem}

/* ---------- capability list (long service detail) ---------- */
.cap-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 4rem;margin-top:2.5rem}
.cap{padding:1.4rem 0;border-top:1px solid var(--hair-2);display:flex;gap:1rem;align-items:flex-start}
.cap svg{width:20px;height:20px;color:var(--orange);flex:none;margin-top:4px}
.cap h4{font-size:1.02rem;font-weight:700;margin-bottom:.3rem;font-family:var(--display)}
.cap p{font-size:.9rem;line-height:1.55}

/* ---------- fit columns ---------- */
.fit-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.25rem;margin-top:3.4rem}
.fit-col{border:1px solid var(--hair);border-radius:14px;padding:2rem 1.8rem;background:var(--surface)}
.fit-col.good{border-color:rgba(255,104,0,.3);background:linear-gradient(180deg,rgba(255,104,0,.06),var(--surface) 60%)}
.fit-col h3{font-size:1.05rem;margin-bottom:1.4rem;font-weight:700;display:flex;align-items:center;gap:.6rem}
.fit-col ul{list-style:none}
.fit-col li{font-size:.95rem;color:var(--muted);padding:.62rem 0;border-top:1px solid var(--hair-2);display:flex;gap:.7rem;line-height:1.5}
.fit-col li:first-of-type{border-top:none}
.tick,.cross{flex:none;width:17px;height:17px;margin-top:3px}
.tick{color:var(--orange)}.cross{color:var(--faint)}
.fit-col .secs li{color:#C2C2C9}

/* ---------- process ---------- */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:3.4rem;position:relative}
.steps.steps-5::before{content:"";position:absolute;top:18px;left:6%;right:6%;height:1px;background:var(--hair)}
.step{padding:0 1rem;position:relative}
.step .dot{width:38px;height:38px;border-radius:50%;border:1px solid var(--orange);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;font-size:.85rem;color:var(--orange);background:var(--black);position:relative;z-index:2;margin-bottom:1.4rem}
.step h3{font-size:1.05rem;margin-bottom:.6rem;font-weight:700}
.step p{font-size:.9rem;line-height:1.55}

/* vertical process (how we work detail) */
.vsteps{margin-top:3rem;border-left:1px solid var(--hair);padding-left:0}
.vstep{display:grid;grid-template-columns:80px 1fr;gap:2rem;padding:0 0 3rem 0;position:relative}
.vstep:last-child{padding-bottom:0}
.vstep .vnum{width:56px;height:56px;border-radius:50%;border:1px solid var(--orange);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;font-size:1.1rem;color:var(--orange);background:var(--bg);margin-left:-28px;position:relative;z-index:2}
.vstep .vbody h3{font-size:1.4rem;margin-bottom:.7rem;font-weight:700}
.vstep .vbody p{font-size:1rem;line-height:1.6;max-width:58ch}
.vstep .vbody .tags{margin-top:1rem;display:flex;flex-wrap:wrap;gap:.5rem}

/* ---------- tags ---------- */
.tag{font-size:.78rem;font-weight:400;color:#D0D0D6;border:1px solid var(--hair);border-radius:6px;padding:.4rem .7rem;background:var(--black)}
.tag-row{display:flex;flex-wrap:wrap;gap:.55rem}

/* ---------- northcto bridge ---------- */
.bridge-inner{border:1px solid var(--hair);border-radius:18px;overflow:hidden;display:grid;grid-template-columns:1.3fr 1fr;background:radial-gradient(120% 140% at 100% 0%, rgba(255,104,0,.14), transparent 55%),var(--surface)}
.bridge-l{padding:3.4rem;border-right:1px solid var(--hair)}
.bridge-l h2{font-size:2rem;margin:1.1rem 0 1.2rem;letter-spacing:-0.025em}
.bridge-l p{font-size:1.05rem;line-height:1.62}
.bridge-cta{margin-top:2rem;display:flex;gap:.9rem;flex-wrap:wrap}
.bridge-r{padding:3.4rem;display:flex;flex-direction:column;justify-content:center;gap:1.1rem}
.bridge-r .uc{font-size:.95rem;color:#C2C2C9;display:flex;gap:.7rem;align-items:flex-start;line-height:1.5}
.bridge-r .uc span{color:var(--orange);font-family:var(--display);font-weight:700;font-size:.85rem;flex:none}
.cto-mark{font-family:var(--display);font-weight:700;letter-spacing:-0.01em}
.cto-mark .bar{color:var(--faint);margin:0 .15em;font-weight:400}
.cto-mark .o{color:var(--orange)}
/* Reusable split brand mark — North (inherits) | suffix (orange).
   Use ONLY for logo lockups and deliberate brand statements, never body text. */
.brandmark{font-family:var(--display);font-weight:700;letter-spacing:-0.01em;white-space:nowrap}
.brandmark .bar{color:var(--faint);margin:0 .14em;font-weight:400}
.brandmark .sfx{color:var(--orange)}

/* ---------- trust strip ---------- */
.trust{border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);background:linear-gradient(110deg, var(--black) 0%, var(--black) 55%, rgba(255,104,0,0.04) 100%)}
.trust-row{display:grid;grid-template-columns:repeat(5,1fr)}
.trust-item{padding:2.2rem 1.6rem;border-right:1px solid var(--hair-2)}
.trust-item:last-child{border-right:none}
.trust-item .n{font-family:var(--display);font-weight:700;font-size:1.7rem;color:#fff;letter-spacing:-0.02em;line-height:1}
.trust-item .n b{color:var(--orange)}
.trust-item .l{font-size:.82rem;color:var(--faint);margin-top:.55rem;line-height:1.4}

/* ---------- certs / proof ---------- */
.certs{margin-top:2rem;border:1px solid var(--hair);border-radius:14px;background:var(--surface);padding:2rem}
.certs .big{font-family:var(--display);font-weight:800;font-size:2.6rem;color:#fff;letter-spacing:-0.03em;line-height:1}
.certs .big b{color:var(--orange)}
.certs .cap-txt{font-size:.92rem;color:var(--muted);margin:.5rem 0 1.5rem}
.plist{list-style:none;margin-top:.5rem}
.plist li{font-size:.98rem;color:var(--muted);padding:.8rem 0;border-bottom:1px solid var(--hair-2);display:flex;gap:.8rem;line-height:1.5}
.plist li::before{content:"";width:6px;height:6px;background:var(--orange);transform:rotate(45deg);margin-top:8px;flex:none}

/* ---------- sector cards ---------- */
.sector-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:3.4rem}
.sector{border:1px solid var(--hair);border-radius:14px;padding:2rem 1.8rem;background:var(--surface);border-left:2px solid var(--orange);transition:transform .3s,background .3s}
.sector:hover{transform:translateY(-5px);background:var(--surface-2)}
.sector .ico{width:34px;height:34px;color:var(--orange);margin-bottom:1.1rem}
.sector h3{font-size:1.18rem;font-weight:700;margin-bottom:.7rem;letter-spacing:-0.01em}
.sector p{font-size:.94rem;line-height:1.58}
.sector .know{margin-top:1rem;font-size:.82rem;color:var(--orange-soft);font-family:var(--display);font-weight:500;line-height:1.4}

/* ---------- dont-do ---------- */
.dont-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:3rem}
.dont{border:1px solid var(--hair);border-radius:12px;padding:1.4rem 1.5rem;background:var(--surface);display:flex;gap:.8rem;align-items:flex-start}
.dont svg{width:20px;height:20px;color:var(--faint);flex:none;margin-top:2px}
.dont span{font-size:.98rem;color:#C2C2C9;font-weight:400}

/* ---------- final cta ---------- */
.final{position:relative;overflow:hidden;border-top:1px solid var(--hair);text-align:center;padding:8rem 0}
.final .glow{position:absolute;left:50%;top:55%;transform:translate(-50%,-50%);width:680px;height:680px;background:radial-gradient(circle, rgba(255,104,0,.16), transparent 62%);filter:blur(8px);z-index:0;pointer-events:none}
.final-inner{position:relative;z-index:2}
.final h2{font-size:clamp(2.2rem,4.6vw,3.6rem);letter-spacing:-0.03em;max-width:18ch;margin:1.2rem auto 0}
.final p{font-size:1.18rem;margin:1.5rem auto 0;max-width:54ch}
.final-cta{display:flex;gap:1rem;margin-top:2.4rem;flex-wrap:wrap;justify-content:center}

/* Bold full-orange CTA band */
.final.orange{background:linear-gradient(135deg, #FF6800 0%, #E85800 55%, #C94800 100%);border-top:none}
.final.orange::before{content:"";position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse 80% 60% at 50% 120%, rgba(255,200,140,0.55), transparent 60%);pointer-events:none}
.final.orange .glow{display:none}
.final.orange .eyebrow{color:rgba(255,255,255,0.85)}
.final.orange .eyebrow::before{background:rgba(255,255,255,0.7)}
.final.orange h2{color:#1A0E04}
.final.orange p{color:rgba(40,18,4,0.82)}
.final.orange .btn-primary{background:#15120F;color:#fff}
.final.orange .btn-primary:hover{background:#000;box-shadow:0 12px 30px -10px rgba(0,0,0,.6)}
.final.orange .btn-ghost{background:transparent;color:#1A0E04;border-color:rgba(26,14,4,0.35)}
.final.orange .btn-ghost:hover{border-color:rgba(26,14,4,0.7);background:rgba(255,255,255,0.12)}

/* ---------- contact form ---------- */
.form-wrap{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-top:1rem}
.form-aside h3{font-size:1.3rem;margin-bottom:1.2rem;font-weight:700}
.form-aside .point{display:flex;gap:.8rem;align-items:flex-start;padding:.7rem 0;font-size:1rem;color:#C2C2C9;line-height:1.5}
.form-aside .point svg{width:20px;height:20px;color:var(--orange);flex:none;margin-top:3px}
.form-contact{margin-top:2rem;border-top:1px solid var(--hair-2);padding-top:1.8rem}
.form-contact .ln{font-size:.95rem;color:#C2C2C9;margin-bottom:.7rem;display:flex;gap:.6rem}
.form-contact .ln b{color:var(--orange);font-weight:600;font-family:var(--display);font-size:.82rem;letter-spacing:.04em;min-width:56px}
form .field{margin-bottom:1.2rem}
form label{display:block;font-size:.85rem;color:#C2C2C9;margin-bottom:.5rem;font-family:var(--display);font-weight:500}
form input,form select,form textarea{width:100%;background:var(--surface);border:1px solid var(--hair);border-radius:9px;padding:.85rem 1rem;color:#fff;font-family:var(--body);font-size:1rem;transition:border-color .2s,background .2s}
form input:focus,form select:focus,form textarea:focus{outline:none;border-color:var(--orange);background:var(--surface-2)}
form textarea{resize:vertical;min-height:120px}
form .row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.form-note{font-size:.82rem;color:var(--faint);margin-top:1rem}
.form-msg{padding:1rem;border-radius:9px;margin-bottom:1.2rem;font-size:.95rem;display:none}
.form-msg.ok{display:block;background:rgba(255,104,0,.1);border:1px solid rgba(255,104,0,.3);color:var(--orange-soft)}
.form-msg.err{display:block;background:rgba(255,80,80,.08);border:1px solid rgba(255,80,80,.25);color:#ff9a9a}

/* ---------- footer ---------- */
footer{background:var(--black);border-top:1px solid var(--hair);padding:4.5rem 0 2rem}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:2.5rem;padding-bottom:3rem;border-bottom:1px solid var(--hair-2)}
.foot-logo img{height:24px;margin-bottom:1.3rem}
.foot-brand p{font-size:.92rem;max-width:32ch;line-height:1.6}
.foot-strap{color:var(--orange);font-family:var(--display);font-weight:600;font-size:.9rem;margin-top:1.1rem!important}
.foot-col h4{font-family:var(--display);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-bottom:1.2rem;font-weight:700}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:.7rem}
.foot-col a{font-size:.93rem;color:#C2C2C9;transition:color .2s}
.foot-col a:hover{color:var(--orange)}
.contact-line{font-size:.93rem;color:#C2C2C9;margin-bottom:.7rem;display:flex;gap:.5rem}
.contact-line b{color:var(--orange);font-weight:600;font-family:var(--display);font-size:.82rem;letter-spacing:.04em;min-width:52px}
.foot-rule{height:2px;width:46px;background:var(--orange);margin-bottom:1.3rem}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:2rem;flex-wrap:wrap;gap:1rem}
.foot-bottom p{font-size:.8rem;color:var(--faint);line-height:1.6;max-width:62ch}
.foot-bottom .legal-links{display:flex;gap:1.4rem}
.foot-bottom .legal-links a{font-size:.8rem;color:var(--faint)}
.foot-bottom .legal-links a:hover{color:var(--muted)}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ---------- FAQ ---------- */
.faq{margin-top:3rem;max-width:860px}
.faq-item{border-bottom:1px solid var(--hair)}
.faq-q{width:100%;background:none;border:none;color:#fff;font-family:var(--display);font-weight:600;font-size:1.12rem;text-align:left;padding:1.5rem 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq-q .pm{flex:none;width:22px;height:22px;position:relative;transition:transform .3s}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--orange);transition:opacity .3s}
.faq-q .pm::before{top:10px;left:0;width:22px;height:2px}
.faq-q .pm::after{top:0;left:10px;width:2px;height:22px}
.faq-item.open .pm::after{opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a p{padding:0 0 1.5rem;font-size:1rem;line-height:1.6;max-width:70ch}

/* ---------- hidden-until-ready proof scaffolding ----------
   Components built and styled, kept out of the DOM/flow until real
   content exists. Remove the [hidden] attribute to publish. */
[data-proof]{display:none}

/* ---------- responsive ---------- */
@media(max-width:1080px){
  .cards-4{grid-template-columns:1fr 1fr}
  .trust-row{grid-template-columns:1fr 1fr 1fr}
  .trust-item:nth-child(3){border-right:none}
  .steps.steps-5{grid-template-columns:1fr 1fr 1fr;gap:2rem 0}
  .steps.steps-5::before{display:none}
  .form-wrap{grid-template-columns:1fr;gap:2.5rem}
  .cap-grid{grid-template-columns:1fr;gap:0}
}
@media(max-width:860px){
  .nav-links{display:none}
  .burger{display:flex}
  .drawer{display:block}
  .nav-cta .btn-primary{display:none}
  .diff-grid,.cards-3,.sector-grid,.dont-grid{grid-template-columns:1fr}
  .fit-grid{grid-template-columns:1fr}
  .split-2,.cards-2{grid-template-columns:1fr}
  .bridge-inner{grid-template-columns:1fr}
  .bridge-l{border-right:none;border-bottom:1px solid var(--hair);padding:2.4rem}
  .bridge-r{padding:2.4rem}
  .foot-top{grid-template-columns:1fr 1fr;gap:2rem}
  .section-pad{padding:5rem 0}
  .form .row{grid-template-columns:1fr}
  .vstep{grid-template-columns:1fr;gap:1rem}
  .vstep .vnum{margin-left:0}
  .vsteps{border-left:none;padding-left:0}
}
@media(max-width:560px){
  .wrap{padding:0 1.3rem}
  .cards-4{grid-template-columns:1fr}
  .trust-row{grid-template-columns:1fr 1fr}
  .trust-item:nth-child(3){border-right:1px solid var(--hair-2)}
  .trust-item:nth-child(2n){border-right:none}
  .steps.steps-5{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}
  form .row{grid-template-columns:1fr}
}

/* ==========================================================================
   Per-page signature visuals
   ========================================================================== */

/* Layered security model (Cybersecurity) — concentric defence layers */
.layers{margin-top:3.4rem;display:flex;flex-direction:column;gap:.75rem;max-width:880px}
.layer{position:relative;border:1px solid var(--hair);border-radius:12px;padding:1.3rem 1.6rem;background:var(--surface);display:flex;align-items:center;gap:1.2rem;overflow:hidden;transition:border-color .3s,transform .3s}
.layer:hover{border-color:rgba(255,104,0,.35);transform:translateX(4px)}
.layer .lyr-bar{position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--orange)}
.layer .lyr-n{font-family:var(--display);font-weight:700;font-size:.8rem;color:var(--orange);letter-spacing:.1em;flex:none;width:34px}
.layer .lyr-ico{width:30px;height:30px;color:var(--orange);flex:none}
.layer .lyr-txt h4{font-family:var(--display);font-size:1.05rem;font-weight:700;margin-bottom:.2rem}
.layer .lyr-txt p{font-size:.9rem;line-height:1.5;color:var(--muted)}
.layer.core{margin-left:0}
.layers .layer:nth-child(1){margin-right:0}
.layers .layer:nth-child(2){margin-left:1.5rem}
.layers .layer:nth-child(3){margin-left:3rem}
.layers .layer:nth-child(4){margin-left:4.5rem}
.layers .layer:nth-child(5){margin-left:6rem}
.layers-label{font-size:.78rem;color:var(--faint);font-family:var(--display);font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-top:1.2rem}

/* Cable-to-cloud stack (Infrastructure) */
.stack{margin-top:3.4rem;display:flex;flex-direction:column;gap:2px;border-radius:14px;overflow:hidden;border:1px solid var(--hair);max-width:880px}
.stack-row{display:grid;grid-template-columns:160px 1fr;align-items:center;background:var(--surface);padding:1.3rem 1.6rem;gap:1.5rem;transition:background .3s}
.stack-row:hover{background:var(--surface-2)}
.stack-row .sl{font-family:var(--display);font-weight:700;font-size:.95rem;color:var(--orange);display:flex;align-items:center;gap:.7rem}
.stack-row .sl svg{width:22px;height:22px;flex:none}
.stack-row .sr{font-size:.94rem;color:var(--muted);line-height:1.5}
.stack-grad{height:3px;background:linear-gradient(90deg,var(--orange),transparent)}

/* Lifecycle flow (M365 & Azure) */
.lifecycle{margin-top:3.4rem;display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.lc{padding:1.8rem 1.4rem;border:1px solid var(--hair);background:var(--surface);position:relative;transition:background .3s}
.lc:not(:last-child){border-right:none}
.lc:first-child{border-radius:12px 0 0 12px}
.lc:last-child{border-radius:0 12px 12px 0}
.lc:hover{background:var(--surface-2)}
.lc .lc-n{font-family:var(--display);font-weight:700;font-size:.8rem;color:var(--orange);letter-spacing:.1em}
.lc h4{font-family:var(--display);font-size:1.08rem;font-weight:700;margin:.7rem 0 .5rem}
.lc p{font-size:.88rem;line-height:1.5}
.lc .lc-arrow{position:absolute;right:-11px;top:50%;transform:translateY(-50%);width:22px;height:22px;background:var(--bg);border:1px solid var(--hair);border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:3;color:var(--orange)}
.lc:last-child .lc-arrow{display:none}

@media(max-width:860px){
  .layers .layer{margin-left:0 !important}
  .stack-row{grid-template-columns:1fr;gap:.5rem}
  .lifecycle{grid-template-columns:1fr;gap:2px}
  .lc{border-right:1px solid var(--hair) !important;border-radius:0}
  .lc:first-child{border-radius:12px 12px 0 0}
  .lc:last-child{border-radius:0 0 12px 12px}
  .lc .lc-arrow{display:none}
}

/* Accessibility — visible keyboard focus */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.burger:focus-visible{
  outline:2px solid var(--orange);
  outline-offset:3px;
  border-radius:4px;
}
