:root {
  --navy:       #080F28;
  --navy-mid:   #0A1640;
  --navy-card:  #060C1E;
  --navy-deep:  #040810;
  --blue:       #1845C0;
  --blue-h:     #1C4ED8;
  --gold:       #B08C38;
  --gold-l:     #C9A84C;
  --gold-dim:   rgba(176,140,56,0.18);
  --white:      #FFFFFF;
  --w85: rgba(255,255,255,0.85);
  --w55: rgba(255,255,255,0.55);
  --w30: rgba(255,255,255,0.30);
  --w12: rgba(255,255,255,0.07);
  --w05: rgba(255,255,255,0.035);
  --border: rgba(255,255,255,0.07);
  --border-h: rgba(255,255,255,0.12);
  --fd: 'Barlow Condensed', sans-serif;
  --fb: 'Barlow', sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);background:var(--navy);color:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{text-decoration:none;color:inherit}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:0 72px;height:64px;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--border);
  background:rgba(8,15,40,0.97);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
.logo{display:flex;align-items:center}
.logo-img{height:60px;width:auto;display:block}
.nav-links{display:flex;gap:40px;list-style:none}
.nav-links a{font-size:10.5px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--w55);transition:color .2s}
.nav-links a:hover{color:var(--white)}
.nav-btn{
  font-size:10.5px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;
  padding:9px 24px;border:1px solid rgba(176,140,56,0.6);color:var(--gold-l);
  transition:all .2s;
}
.nav-btn:hover{background:var(--gold-l);color:var(--navy);border-color:var(--gold-l)}

/* ── HERO ── */
.hero{
  position:relative;min-height:100vh;
  display:flex;flex-direction:column;justify-content:center;
  padding:120px 72px 160px;overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 50% 50% at 72% 48%, rgba(24,69,192,0.14) 0%, transparent 60%),
    linear-gradient(158deg, #080F28 0%, #060C1C 58%, #040810 100%);
}
.hero-lines{
  position:absolute;inset:0;z-index:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.028) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.028) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 75% 65% at 50% 50%,black 25%,transparent 100%);
}
/* subtle diagonal accent line */
.hero-accent{
  position:absolute;right:0;top:0;bottom:0;z-index:0;
  width:1px;
  background:linear-gradient(180deg,transparent 0%,rgba(176,140,56,0.2) 35%,rgba(176,140,56,0.2) 65%,transparent 100%);
  right:72px;
}
.hero-z{
  position:absolute;right:-100px;top:50%;transform:translateY(-50%);
  font-family:var(--fd);font-size:clamp(240px,32vw,480px);
  font-weight:700;color:rgba(255,255,255,0.016);
  user-select:none;pointer-events:none;line-height:1;letter-spacing:-8px;
}
.hero-inner{position:relative;z-index:1;max-width:680px}

/* eyebrow */
.eyebrow{display:flex;align-items:center;gap:16px;margin-bottom:40px}
.eyebrow-line{width:32px;height:1px;background:var(--gold)}
.eyebrow span{
  font-size:10px;font-weight:600;letter-spacing:4px;
  text-transform:uppercase;color:var(--gold);
  opacity:0.9;
}

/* HEADLINE — the centrepiece */
.h1-wrap{margin-bottom:40px;line-height:1}
.h1-security{
  font-family:var(--fd);
  font-size:clamp(56px,8vw,108px);
  font-weight:700;letter-spacing:-1.5px;
  color:var(--white);display:block;line-height:0.97;
}
.h1-executed{
  font-family:var(--fd);
  font-size:clamp(64px,9.2vw,124px);
  font-weight:700;font-style:italic;
  letter-spacing:-2px;
  display:block;line-height:0.92;
  color:transparent;
  -webkit-text-stroke:1.5px var(--gold-l);
  margin-top:-4px;
  filter:drop-shadow(0 0 20px rgba(201,168,76,0.08));
}
.h1-outcomes{
  display:block;
  font-family:var(--fb);
  font-size:clamp(11px,1.1vw,14px);
  font-weight:500;
  letter-spacing:4px;
  color:var(--w30);
  text-transform:uppercase;
  margin-top:22px;
  padding-left:2px;
}

.hero-desc{
  font-size:16px;font-weight:300;line-height:1.88;
  color:rgba(255,255,255,0.68);max-width:420px;margin-bottom:52px;
}
.hero-desc strong{color:var(--w85);font-weight:500}

.hero-btns{display:flex;gap:16px;align-items:center}
.btn-p{
  font-size:10.5px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;
  padding:14px 32px;background:var(--blue);color:var(--white);
  border:1px solid var(--blue);transition:background .2s;
}
.btn-p:hover{background:var(--blue-h)}
.btn-g{
  font-size:10.5px;font-weight:500;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--w55);
  display:flex;align-items:center;gap:10px;transition:color .2s;
}
.btn-g:hover{color:var(--white)}
.btn-g svg{transition:transform .2s}
.btn-g:hover svg{transform:translateX(4px)}

/* trust strip */
.trust{
  position:absolute;bottom:0;left:0;right:0;z-index:1;
  border-top:1px solid rgba(255,255,255,0.12);display:flex;
  background:rgba(5,10,25,0.72);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.ti{
  flex:1;padding:26px 56px;border-right:1px solid rgba(255,255,255,0.09);
  display:flex;align-items:center;gap:16px;
}
.ti:last-child{border-right:none}
.ti-icon{color:var(--gold-l);flex-shrink:0;}
.ti-icon svg{width:15px;height:15px}
.ti-label{font-size:11.5px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.65);margin-bottom:5px}
.ti-val{font-size:15.5px;font-weight:600;color:rgba(255,255,255,0.98)}

/* ── DIVIDER ── */
.divider{
  width:100%;height:1px;
  background:linear-gradient(90deg,transparent 0%,rgba(176,140,56,0.3) 30%,rgba(176,140,56,0.3) 70%,transparent 100%);
}

/* ── SECTIONS ── */
.sec{padding:128px 72px;position:relative;z-index:1}
.sec-inner{max-width:1120px;margin:0 auto}
.sec-tag{display:flex;align-items:center;gap:12px;margin-bottom:68px}
.sec-tag-line{width:24px;height:1px;background:var(--gold)}
.sec-tag span{font-size:9.5px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--gold);opacity:.85}
.sec-h2{
  font-family:var(--fd);font-size:clamp(32px,3.6vw,50px);
  font-weight:700;line-height:1.06;color:var(--white);
}
.sec-h2 em{font-style:normal;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,0.28)}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:start}
.about-left .sec-h2{margin-bottom:40px}
.about-left p{font-size:16px;line-height:1.88;color:rgba(255,255,255,0.68);margin-bottom:22px}
.about-left p strong{color:var(--w85);font-weight:500}

.pillars{display:flex;flex-direction:column}
.pillar{
  padding:26px 0;border-top:1px solid var(--border);
  display:flex;gap:22px;align-items:flex-start;
  transition:border-color .35s ease;
}
.pillar:hover{border-top-color:var(--border-h)}
.pillar:last-child{border-bottom:1px solid var(--border)}
.p-num{
  font-family:var(--fd);font-size:11px;font-weight:600;
  color:var(--gold);letter-spacing:1px;min-width:24px;
  margin-top:2px;opacity:.8;
}
.p-title{font-size:13.5px;font-weight:600;color:var(--white);margin-bottom:6px;letter-spacing:.2px}
.p-desc{font-size:13px;color:var(--w55);line-height:1.7}

/* ── SERVICES ── */
.sec-dark{background:linear-gradient(180deg,var(--navy) 0%,var(--navy-deep) 55%,var(--navy) 100%)}
.svc-header{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:end;margin-bottom:60px}
.svc-header p{font-size:15px;color:rgba(255,255,255,0.65);line-height:1.78}

/* grid with intentional visual hierarchy */
.svc-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--border);
  border:1px solid var(--border);
}
/* first card spans 2 columns — visual anchor */
.svc-grid .svc:first-child{
  grid-column:span 1;
}
.svc{
  background:var(--navy-card);
  padding:36px 32px;position:relative;overflow:hidden;
  transition:background .4s ease;
  display:flex;flex-direction:column;
}
.svc::after{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,var(--gold),transparent);
  opacity:0;transition:opacity .45s ease;
}
.svc:hover{background:#081226}
.svc:hover::after{opacity:.5}

.svc-icon{
  width:38px;height:38px;margin-bottom:24px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--border);color:#3D78FF;
  transition:border-color .35s ease;
}
.svc:hover .svc-icon{border-color:var(--border-h)}
.svc-icon svg{width:18px;height:18px}
.svc-n{
  font-family:var(--fd);font-size:10px;font-weight:600;
  color:var(--w30);letter-spacing:3px;margin-bottom:10px;
}
.svc-title{font-size:16px;font-weight:600;color:var(--white);margin-bottom:13px;line-height:1.25}
.svc-desc{font-size:14px;color:rgba(255,255,255,0.65);line-height:1.72}

/* ── PARTNERSHIPS ── */
.p-sec{
  padding:128px 72px;
  background:linear-gradient(180deg,var(--navy) 0%,#050B1A 100%);
  border-top:1px solid var(--border);
}
.p-inner{max-width:1120px;margin:0 auto}
.p-top{display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:start;margin-bottom:80px}
.p-top h2{font-family:var(--fd);font-size:clamp(32px,3.6vw,50px);font-weight:700;line-height:1.06;color:var(--white)}
.p-top h2 .g{color:var(--gold-l)}
.p-top .right p{font-size:16px;color:rgba(255,255,255,0.68);line-height:1.88;margin-bottom:20px}
.p-top .right p strong{color:var(--w85);font-weight:500}
/* not-a-distributor statement */
.not-dist{
  margin-top:24px;
  padding:18px 22px;
  border-left:2px solid var(--gold);
  background:var(--gold-dim);
}
.not-dist p{
  font-size:14.5px;color:rgba(255,255,255,0.88);line-height:1.68;
  font-style:italic;
}

/* value cards — 2 rows of 3, subtle alternating weight */
.val-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--border);border:1px solid var(--border);
  margin-bottom:72px;
}
.val{background:var(--navy-card);padding:28px 26px;transition:background .4s ease;position:relative}
.val:hover{background:#081226}
.val-n{
  font-family:var(--fd);font-size:32px;font-weight:700;
  color:rgba(255,255,255,0.04);line-height:1;
  position:absolute;top:20px;right:22px;
}
.val-title{font-size:9.5px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:12px;opacity:.85}
.val-desc{font-size:14px;color:rgba(255,255,255,0.65);line-height:1.72}

/* sectors */
.sectors-row{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--border);border:1px solid var(--border);
}
.sector{
  background:var(--navy-card);padding:26px 24px;
  display:flex;align-items:flex-start;gap:12px;
  transition:background .4s ease;
}
.sector:hover{background:#081226}
.s-dot{width:4px;height:4px;border-radius:50%;background:var(--gold);margin-top:7px;flex-shrink:0}
.s-name{font-size:13.5px;font-weight:600;color:var(--white);margin-bottom:5px}
.s-desc{font-size:12.5px;color:rgba(255,255,255,0.42);line-height:1.55}

/* ── CONTACT ── */
.c-sec{
  padding:128px 72px;
  background:linear-gradient(180deg,var(--navy) 0%,var(--navy-deep) 100%);
  border-top:1px solid var(--border);
}
.c-inner{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:start}
.c-left h2{font-family:var(--fd);font-size:clamp(32px,3.6vw,50px);font-weight:700;color:var(--white);line-height:1.06;margin-bottom:22px}
.c-left p{font-size:15px;color:var(--w55);line-height:1.85;margin-bottom:40px}
.c-items{display:flex;flex-direction:column;gap:18px}
.c-item{display:flex;align-items:center;gap:14px}
.c-ico{width:36px;height:36px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0;opacity:.85}
.c-ico svg{width:15px;height:15px}
.c-lbl{font-size:9.5px;letter-spacing:2.5px;text-transform:uppercase;color:var(--w30);margin-bottom:3px}
.c-val{font-size:15px;color:rgba(255,255,255,0.88)}
.c-form{display:flex;flex-direction:column;gap:14px}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg{display:flex;flex-direction:column;gap:7px}
.fg label{font-size:9.5px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--w30)}
.fg input,.fg textarea,.fg select{
  background:var(--w05);border:1px solid var(--border);
  color:var(--white);padding:13px 16px;
  font-family:var(--fb);font-size:14px;outline:none;
  transition:border-color .35s ease;resize:none;-webkit-appearance:none;
}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:rgba(176,140,56,0.4)}
.fg input::placeholder,.fg textarea::placeholder{color:var(--w30)}
.fg select option{background:#0A1640}
.fg textarea{min-height:112px}
.f-submit{
  margin-top:6px;font-size:10.5px;font-weight:600;letter-spacing:2.5px;
  text-transform:uppercase;padding:14px;background:var(--blue);
  color:var(--white);border:1px solid var(--blue);cursor:pointer;
  width:100%;transition:background .2s;font-family:var(--fb);
}
.f-submit:hover{background:var(--blue-h)}

/* ── FOOTER ── */
footer{
  padding:30px 72px;border-top:1px solid var(--border);
  display:flex;justify-content:center;gap:40px;align-items:center;
  background:var(--navy-deep);
}
.f-logo{display:flex;align-items:center}
.f-logo-img{height:36px;width:auto;display:block}
.f-copy{font-size:11px;color:var(--w30);letter-spacing:.3px}
.f-badge{
  font-size:9.5px;color:var(--w30);letter-spacing:2px;
  text-transform:uppercase;border:1px solid var(--border);padding:6px 14px;
}


/* featured service cards — structural emphasis only */
.svc-featured{
  border-left:2px solid rgba(176,140,56,0.25);
  padding-left:30px;
}
.svc-featured .svc-title{
  font-size:16.5px;
}
.svc-featured .svc-n{
  color:rgba(176,140,56,0.5);
}


/* ── MOBILE RESPONSIVE ── */
@media (max-width: 768px) {
  nav { padding: 0 24px; }
  .nav-links { display: none; }
  .nav-btn { font-size: 10px; padding: 8px 16px; }

  .hero { padding: 100px 24px 220px; }
  .hero-inner { max-width: 100%; }
  .h1-security, .h1-executed { font-size: clamp(46px, 13vw, 72px); }
  .h1-outcomes { font-size: 12px; letter-spacing: 3px; margin-top: 16px; }
  .hero-desc { font-size: 15px; max-width: 100%; }
  .hero-z { display: none; }
  .hero-accent { display: none; }
  .trust { flex-direction: column; }
  .ti { padding: 14px 24px; border-right: none; border-bottom: 1px solid var(--border); }
  .ti:last-child { border-bottom: none; }
  .ti-val { font-size: 13px; }
  .ti-label { font-size: 10.5px; }

  .sec { padding: 72px 24px; }
  .p-sec { padding: 72px 24px; }
  .c-sec { padding: 72px 24px; }

  .about-grid { grid-template-columns: 1fr; gap: 48px; }
  .about-left p { font-size: 15px; }

  .svc-header { grid-template-columns: 1fr; gap: 20px; }
  .svc-header p { text-align: left; }
  .svc-grid { grid-template-columns: 1fr; }
  .svc { padding: 28px 24px; }
  .svc-desc { font-size: 14px; }

  .p-top { grid-template-columns: 1fr; gap: 40px; }
  .val-grid { grid-template-columns: 1fr; }
  .val { padding: 24px 20px; }
  .val-desc { font-size: 14px; }
  .sectors-row { grid-template-columns: 1fr 1fr; }
  .sector { padding: 20px 18px; }

  .c-inner { grid-template-columns: 1fr; gap: 48px; }
  .c-left h2 { font-size: clamp(28px, 8vw, 40px); }
  .c-left p { font-size: 15px; }
  .f-row { grid-template-columns: 1fr; }

  footer { flex-direction: column; gap: 14px; text-align: center; padding: 28px 24px; }

  .sec-h2 { font-size: clamp(28px, 7vw, 40px); }
  .p-top h2 { font-size: clamp(28px, 7vw, 40px); }
}

@media (max-width: 480px) {
  .sectors-row { grid-template-columns: 1fr; }
  .hero-btns { flex-direction: column; align-items: flex-start; gap: 14px; }
  .h1-security, .h1-executed { font-size: clamp(40px, 14vw, 60px); }
}

@media (min-width: 769px) and (max-width: 1024px) {
  nav { padding: 0 36px; }
  .hero { padding: 110px 36px 140px; }
  .sec { padding: 88px 36px; }
  .p-sec { padding: 88px 36px; }
  .c-sec { padding: 88px 36px; }
  .about-grid { gap: 48px; }
  .p-top { gap: 48px; }
  .c-inner { gap: 48px; }
  .svc-grid { grid-template-columns: repeat(2, 1fr); }
  .val-grid { grid-template-columns: repeat(2, 1fr); }
  .sectors-row { grid-template-columns: repeat(2, 1fr); }
  footer { padding: 28px 36px; }
}

/* ── FADE ── */
.fi{opacity:0;transform:translateY(16px);animation:fi .6s ease forwards}
.fi1{animation-delay:.06s}.fi2{animation-delay:.18s}
.fi3{animation-delay:.3s}.fi4{animation-delay:.44s}
@keyframes fi{to{opacity:1;transform:translateY(0)}}