/* ===========================================================
   STTPS · Special Task Team Private Security
   Premium dark theme · emerald + champagne accents
   Pure CSS — no frameworks
   =========================================================== */

:root{
  /* base */
  --bg:        #06100b;
  --bg-2:      #081711;
  --panel:     #0b1f17;
  --panel-2:   #0e2a1e;
  --line:      rgba(120, 220, 170, .12);
  --line-2:    rgba(120, 220, 170, .22);

  /* brand */
  --green:     #1c9d5b;
  --green-br:  #26d986;
  --green-glow:#3ee89a;
  --green-deep:#0a3a23;

  /* luxe */
  --gold:      #cbab6a;
  --gold-soft: #e3cd9a;

  /* type */
  --ink:       #eaf4ee;
  --ink-soft:  #aebfb5;
  --ink-mute:  #7b8c83;

  --maxw: 1200px;
  --r: 16px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --font: "Sora", system-ui, sans-serif;
  --font-body: "Inter", system-ui, sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
svg{ display:block; }

::selection{ background:var(--green-glow); color:#03130b; }

/* ---------- atmosphere ---------- */
#net{
  position:fixed; inset:0;
  width:100%; height:100%;
  z-index:0; pointer-events:none;
  opacity:.55;
}
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none;
  background-image:radial-gradient(circle at 50% 0%, rgba(38,217,134,.10), transparent 60%);
  mix-blend-mode:screen;
}
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(1100px 600px at 80% -10%, rgba(28,157,91,.14), transparent 60%),
    radial-gradient(900px 700px at -10% 30%, rgba(13,58,35,.40), transparent 55%),
    linear-gradient(180deg, var(--bg), var(--bg-2) 60%, var(--bg));
}
main, .nav, .footer{ position:relative; z-index:2; }

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,40px); }
.section{ padding:clamp(70px,9vw,130px) 0; }
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,72px); align-items:center; }
.grid-2.align-top{ align-items:start; }

/* ---------- type ---------- */
.h2{ font-family:var(--font); font-weight:700; font-size:clamp(1.9rem,3.6vw,3rem); line-height:1.1; letter-spacing:-.02em; }
.kicker{
  font-family:var(--font); font-weight:600; font-size:.78rem; letter-spacing:.28em;
  text-transform:uppercase; color:var(--green-br); margin-bottom:1.1rem;
  display:flex; align-items:center; gap:.6rem;
}
.kicker::before{ content:""; width:34px; height:1px; background:linear-gradient(90deg,var(--green-br),transparent); }
.kicker.centered{ justify-content:center; }
.kicker.centered::after{ content:""; width:34px; height:1px; background:linear-gradient(270deg,var(--green-br),transparent); }
.lead{ font-size:clamp(1.05rem,1.6vw,1.22rem); color:var(--ink-soft); margin-top:1.2rem; }
.body{ color:var(--ink-mute); margin-top:1rem; }
.centered{ text-align:center; }
.narrow{ max-width:660px; margin-inline:auto; }
.grad{
  background:linear-gradient(100deg,var(--green-glow),var(--gold-soft));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.sec-head{ margin-bottom:clamp(40px,5vw,64px); }

/* ---------- buttons ---------- */
.btn{
  font-family:var(--font); font-weight:600; font-size:.95rem;
  padding:.85rem 1.5rem; border-radius:999px; cursor:pointer;
  display:inline-flex; align-items:center; gap:.5rem; border:1px solid transparent;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .3s, color .3s;
  white-space:nowrap;
}
.btn.lg{ padding:1.05rem 2rem; font-size:1.02rem; }
.btn.full{ width:100%; justify-content:center; }
.btn-primary{
  background:linear-gradient(100deg,var(--green-br),var(--green));
  color:#02140b; box-shadow:0 10px 30px -10px rgba(38,217,134,.6);
}
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 18px 40px -12px rgba(38,217,134,.75); }
.btn-outline{ border-color:var(--line-2); color:var(--ink); background:rgba(255,255,255,.02); }
.btn-outline:hover{ border-color:var(--green-br); color:var(--green-br); transform:translateY(-3px); }
.btn-ghost{ border-color:var(--line-2); color:var(--ink); font-size:.85rem; padding:.6rem 1.1rem; }
.btn-ghost:hover{ background:var(--green-br); color:#02140b; border-color:var(--green-br); }

/* ---------- nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; gap:24px;
  padding:18px clamp(20px,5vw,40px);
  transition:background .4s var(--ease), padding .4s var(--ease), border-color .4s, backdrop-filter .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(6,16,11,.78); backdrop-filter:blur(16px) saturate(140%);
  border-bottom-color:var(--line); padding-top:12px; padding-bottom:12px;
}
.brand{ display:flex; align-items:center; gap:12px; margin-right:auto; }
/* real logo, no background — just a soft greenish glow halo behind it */
.brand-mark{ position:relative; display:inline-flex; }
.brand-mark::before{
  content:""; position:absolute; inset:-45%; z-index:-1; border-radius:50%;
  background:radial-gradient(circle, rgba(38,217,134,.5), rgba(38,217,134,.14) 45%, transparent 70%);
  filter:blur(8px);
}
.logo-img{ display:block; }
.brand-text{ display:flex; flex-direction:column; line-height:1; }
.brand-text strong{ font-family:var(--font); font-weight:800; letter-spacing:.16em; font-size:1.1rem; }
.brand-text em{ font-style:normal; font-size:.66rem; letter-spacing:.24em; text-transform:uppercase; color:var(--ink-mute); margin-top:3px; white-space:nowrap; }
.nav-links{ display:flex; gap:30px; }
.nav-links a{ font-size:.92rem; color:var(--ink-soft); position:relative; transition:color .3s; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:-6px; width:0; height:1.5px; background:var(--green-br); transition:width .3s var(--ease); }
.nav-links a:hover{ color:var(--ink); }
.nav-links a:hover::after{ width:100%; }
.nav-toggle{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px; }
.nav-toggle span{ width:24px; height:2px; background:var(--ink); border-radius:2px; transition:.3s var(--ease); }
.nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2){ opacity:0; }
.nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- hero ---------- */
.hero{ min-height:100svh; display:flex; align-items:center; position:relative; padding-top:90px; }
.hero-inner{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,40px); max-width:920px; }
.eyebrow{
  display:inline-flex; align-items:center; gap:.6rem; font-family:var(--font);
  font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-soft); padding:.5rem 1rem; border:1px solid var(--line);
  border-radius:999px; background:rgba(255,255,255,.02);
}
.eyebrow .dot{ width:8px; height:8px; border-radius:50%; background:var(--green-glow); box-shadow:0 0 0 0 rgba(62,232,154,.6); animation:pulse 2.4s infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(62,232,154,.55);} 70%{ box-shadow:0 0 0 10px rgba(62,232,154,0);} 100%{ box-shadow:0 0 0 0 rgba(62,232,154,0);} }
.hero-title{ font-family:var(--font); font-weight:800; font-size:clamp(2.6rem,7vw,5.4rem); line-height:1.02; letter-spacing:-.03em; margin-top:1.6rem; }
.hero-sub{ font-size:clamp(1.05rem,1.7vw,1.3rem); color:var(--ink-soft); max-width:640px; margin-top:1.6rem; }
.hero-actions{ display:flex; gap:16px; margin-top:2.4rem; flex-wrap:wrap; }
.hero-tag{ margin-top:3rem; }
.tagline{ font-family:var(--font); font-weight:300; font-style:italic; font-size:clamp(1.2rem,2.4vw,1.7rem); color:var(--gold-soft); letter-spacing:.02em; }

.hero-scan{ position:absolute; right:max(-120px,-8vw); top:50%; transform:translateY(-50%); width:min(560px,52vw); aspect-ratio:1; pointer-events:none; opacity:.85; }
.radar{ position:absolute; inset:0; display:grid; place-items:center; }
.radar-ring{ position:absolute; border:1px solid var(--line-2); border-radius:50%; }
.radar-ring:nth-child(1){ inset:0; }
.radar-ring:nth-child(2){ inset:18%; }
.radar-ring:nth-child(3){ inset:36%; }
.radar-sweep{
  position:absolute; inset:0; border-radius:50%;
  background:conic-gradient(from 0deg, rgba(62,232,154,.32), transparent 28%);
  -webkit-mask:radial-gradient(circle, transparent 8%, #000 9%);
  mask:radial-gradient(circle, transparent 8%, #000 9%);
  animation:sweep 5.5s linear infinite;
}
@keyframes sweep{ to{ transform:rotate(360deg); } }
.radar-core{ width:14px; height:14px; border-radius:50%; background:var(--green-glow); box-shadow:0 0 24px var(--green-glow); }
.radar-blip{ position:absolute; width:9px; height:9px; border-radius:50%; background:var(--gold-soft); box-shadow:0 0 14px var(--gold); animation:blip 5.5s ease-in-out infinite; }
.radar-blip.b1{ top:24%; left:62%; animation-delay:.4s; }
.radar-blip.b2{ top:64%; left:34%; animation-delay:2.4s; }
.radar-blip.b3{ top:56%; left:70%; animation-delay:3.8s; }
@keyframes blip{ 0%,82%,100%{ opacity:0; transform:scale(.4);} 88%{ opacity:1; transform:scale(1);} }

.scroll-cue{ position:absolute; bottom:30px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; font-size:.7rem; letter-spacing:.24em; text-transform:uppercase; color:var(--ink-mute); }
.scroll-cue span{ width:22px; height:34px; border:1.5px solid var(--line-2); border-radius:12px; position:relative; }
.scroll-cue span::after{ content:""; position:absolute; top:6px; left:50%; transform:translateX(-50%); width:3px; height:7px; border-radius:2px; background:var(--green-br); animation:scrolly 1.8s var(--ease) infinite; }
@keyframes scrolly{ 0%{ opacity:0; top:6px;} 40%{ opacity:1;} 80%{ opacity:0; top:18px;} 100%{ opacity:0;} }

/* ---------- trust strip ---------- */
.trust{ border-block:1px solid var(--line); background:rgba(8,23,17,.6); overflow:hidden; }
.trust-track{ display:flex; align-items:center; gap:30px; white-space:nowrap; padding:18px 0; width:max-content; animation:marquee 32s linear infinite; }
.trust-track span{ font-family:var(--font); font-size:.82rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-soft); }
.trust-track i{ width:6px; height:6px; border-radius:50%; background:var(--gold); flex:none; }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* ---------- about ---------- */
.about-stats{ display:flex; gap:clamp(20px,4vw,48px); margin-top:2.6rem; flex-wrap:wrap; }
.about-stats div{ display:flex; flex-direction:column; }
.about-stats strong{ font-family:var(--font); font-weight:700; font-size:clamp(1.8rem,3vw,2.4rem); color:var(--green-br); line-height:1; }
.about-stats span{ font-size:.82rem; color:var(--ink-mute); margin-top:.5rem; letter-spacing:.04em; }

.about-card{
  position:relative; border:1px solid var(--line); border-radius:var(--r);
  background:linear-gradient(160deg, var(--panel), var(--bg-2));
  padding:clamp(28px,4vw,44px); overflow:hidden;
}
.ac-glow{ position:absolute; top:-60px; right:-60px; width:220px; height:220px; border-radius:50%; background:radial-gradient(circle, rgba(38,217,134,.28), transparent 70%); filter:blur(8px); }
.ac-label{ font-family:var(--font); font-size:.74rem; letter-spacing:.26em; text-transform:uppercase; color:var(--gold); }
.ac-quote{ font-family:var(--font); font-weight:300; font-size:clamp(1.25rem,2.4vw,1.7rem); line-height:1.4; margin-top:1.4rem; color:var(--ink); }
.ac-line{ height:1px; background:linear-gradient(90deg,var(--gold),transparent); margin:1.8rem 0; }
.ac-list{ list-style:none; display:grid; gap:.85rem; }
.ac-list li{ position:relative; padding-left:1.7rem; color:var(--ink-soft); font-size:.98rem; }
.ac-list li::before{ content:""; position:absolute; left:0; top:.5em; width:9px; height:9px; border:1.5px solid var(--green-br); border-radius:50%; }

/* ---------- overview / features ---------- */
.overview{ border-top:1px solid var(--line); }
.feature-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.feature{
  border:1px solid var(--line); border-radius:var(--r); padding:30px 26px;
  background:linear-gradient(170deg, rgba(14,42,30,.5), rgba(8,23,17,.3));
  transition:transform .45s var(--ease), border-color .45s, box-shadow .45s; position:relative; overflow:hidden;
}
.feature::after{ content:""; position:absolute; inset:0; background:radial-gradient(280px 160px at 50% -10%, rgba(38,217,134,.18), transparent 70%); opacity:0; transition:opacity .45s; }
.feature:hover{ transform:translateY(-8px); border-color:var(--line-2); box-shadow:0 24px 50px -28px rgba(0,0,0,.8); }
.feature:hover::after{ opacity:1; }
.f-ico{ width:54px; height:54px; border-radius:14px; display:grid; place-items:center; border:1px solid var(--line-2); background:rgba(38,217,134,.06); margin-bottom:20px; }
.f-ico svg{ width:26px; height:26px; fill:none; stroke:var(--green-br); stroke-width:1.7; }
.feature h3{ font-family:var(--font); font-weight:600; font-size:1.12rem; margin-bottom:.6rem; }
.feature p{ font-size:.94rem; color:var(--ink-mute); }
.overview-foot{ text-align:center; margin-top:clamp(36px,5vw,56px); font-size:clamp(1.1rem,2vw,1.45rem); font-family:var(--font); font-weight:300; color:var(--ink-soft); max-width:760px; margin-inline:auto; }
.overview-foot strong{ color:var(--ink); font-weight:600; }

/* ---------- competencies ---------- */
.competencies{ background:linear-gradient(180deg, transparent, rgba(8,23,17,.5), transparent); }
.comp-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.comp{
  position:relative; border:1px solid var(--line); border-radius:var(--r);
  padding:36px 30px; background:rgba(8,23,17,.45); overflow:hidden;
  transition:transform .45s var(--ease), border-color .45s;
}
.comp:hover{ transform:translateY(-6px); border-color:var(--line-2); }
.comp-num{ font-family:var(--font); font-weight:800; font-size:2.6rem; color:transparent; -webkit-text-stroke:1.5px var(--line-2); display:block; line-height:1; margin-bottom:.4rem; }
.comp h3{ font-family:var(--font); font-weight:700; font-size:1.3rem; margin-bottom:1.6rem; padding-bottom:1.2rem; border-bottom:1px solid var(--line); }
.comp ul{ list-style:none; display:grid; gap:1.4rem; }
.comp li{ font-size:.92rem; color:var(--ink-mute); }
.comp li strong{ display:block; font-family:var(--font); font-weight:600; font-size:1rem; color:var(--ink); margin-bottom:.35rem; }
.feature-comp{ background:linear-gradient(170deg, rgba(14,42,30,.7), rgba(8,23,17,.4)); border-color:var(--line-2); }
.feature-comp .comp-num{ -webkit-text-stroke:1.5px var(--green-br); }
.comp-flare{ position:absolute; bottom:-80px; left:50%; transform:translateX(-50%); width:240px; height:160px; background:radial-gradient(circle, rgba(38,217,134,.22), transparent 70%); filter:blur(10px); }

/* ---------- vision / advantages ---------- */
.adv-stack{ display:grid; gap:18px; }
.adv{ display:flex; gap:20px; align-items:flex-start; border:1px solid var(--line); border-radius:14px; padding:24px 26px; background:rgba(8,23,17,.4); transition:border-color .4s, transform .4s var(--ease); }
.adv:hover{ border-color:var(--line-2); transform:translateX(6px); }
.adv-i{ font-family:var(--font); font-weight:700; font-size:1rem; color:var(--gold); border:1px solid var(--line-2); border-radius:10px; padding:.4rem .7rem; flex:none; }
.adv h4{ font-family:var(--font); font-weight:600; font-size:1.12rem; margin-bottom:.4rem; }
.adv p{ font-size:.94rem; color:var(--ink-mute); }

/* ---------- cta banner ---------- */
.cta-banner{ position:relative; padding:clamp(60px,8vw,100px) 0; text-align:center; border-block:1px solid var(--line); background:linear-gradient(120deg, rgba(10,58,35,.5), rgba(38,217,134,.08)); overflow:hidden; }
.cta-banner::before{ content:""; position:absolute; inset:0; background:radial-gradient(600px 300px at 50% 120%, rgba(38,217,134,.22), transparent 70%); }
.cta-banner .wrap{ position:relative; }
.cta-banner h2{ font-family:var(--font); font-weight:700; font-size:clamp(1.8rem,4vw,3rem); letter-spacing:-.02em; }
.cta-banner p{ color:var(--ink-soft); margin:1rem 0 2rem; font-size:1.1rem; }

/* ---------- contact ---------- */
.contact-list{ list-style:none; display:grid; gap:1.2rem; margin-top:2.4rem; }
.contact-list li{ display:flex; gap:16px; align-items:flex-start; }
.contact-list .ci{ width:46px; height:46px; flex:none; display:grid; place-items:center; border:1px solid var(--line); border-radius:12px; background:rgba(38,217,134,.05); transition:border-color .3s, background .3s; }
.contact-list .ci svg{ width:21px; height:21px; fill:none; stroke:var(--green-br); stroke-width:1.7; }
.contact-list li:hover .ci{ border-color:var(--line-2); background:rgba(38,217,134,.1); }
.contact-list strong{ display:block; font-family:var(--font); font-weight:600; font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--green-br); margin-bottom:.25rem; }
.contact-list a:hover{ color:var(--green-br); }

.creds{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:2.4rem; }
.cred{ border:1px solid var(--line); border-radius:12px; padding:14px 18px; font-family:var(--font); font-size:.92rem; background:rgba(8,23,17,.4); }
.cred span{ display:block; font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-bottom:.3rem; }

.contact-form{ border:1px solid var(--line); border-radius:var(--r); padding:clamp(26px,3.5vw,40px); background:linear-gradient(160deg, var(--panel), var(--bg-2)); display:grid; gap:18px; align-content:start; }
.cf-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.contact-form label{ display:grid; gap:.5rem; font-family:var(--font); font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); }
.contact-form input, .contact-form select, .contact-form textarea{
  font-family:var(--font-body); font-size:.98rem; color:var(--ink);
  background:rgba(3,12,8,.6); border:1px solid var(--line); border-radius:10px;
  padding:.85rem 1rem; width:100%; transition:border-color .3s, box-shadow .3s; resize:vertical;
}
.contact-form input::placeholder, .contact-form textarea::placeholder{ color:var(--ink-mute); }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus{ outline:none; border-color:var(--green-br); box-shadow:0 0 0 3px rgba(38,217,134,.14); }
.contact-form select{ appearance:none; background-image:linear-gradient(45deg,transparent 50%,var(--green-br) 50%),linear-gradient(135deg,var(--green-br) 50%,transparent 50%); background-position:calc(100% - 20px) 1.35rem, calc(100% - 14px) 1.35rem; background-size:6px 6px,6px 6px; background-repeat:no-repeat; }
.cf-note{ font-family:var(--font-body); font-size:.9rem; text-transform:none; letter-spacing:0; padding:.8rem 1rem; border-radius:10px; background:rgba(38,217,134,.1); border:1px solid var(--line-2); color:var(--green-br); }

/* ---------- footer ---------- */
.footer{ border-top:1px solid var(--line); background:rgba(5,13,9,.7); padding-top:clamp(40px,5vw,64px); }
.footer-grid{ display:flex; justify-content:space-between; align-items:center; gap:30px; flex-wrap:wrap; padding-bottom:30px; border-bottom:1px solid var(--line); }
.f-brand{ display:flex; align-items:center; gap:14px; }
.f-brand strong{ display:block; font-family:var(--font); font-weight:600; font-size:1rem; }
.tagline-sm{ font-family:var(--font); font-style:italic; font-weight:300; color:var(--gold-soft); font-size:.9rem; }
.f-links{ display:flex; gap:26px; flex-wrap:wrap; }
.f-links a{ font-size:.9rem; color:var(--ink-soft); transition:color .3s; }
.f-links a:hover{ color:var(--green-br); }
.footer-base{ display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; padding:24px 0 40px; font-size:.82rem; color:var(--ink-mute); }
.footer-base .f-reg{ color:var(--ink-soft); }

/* ---------- reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(30px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* ---------- responsive ---------- */
@media (max-width:980px){
  .feature-grid{ grid-template-columns:1fr 1fr; }
  .comp-grid{ grid-template-columns:1fr; }
  .hero-scan{ opacity:.35; right:-30%; }
}
@media (max-width:760px){
  .nav-cta{ display:none; }
  .nav-toggle{ display:flex; }
  .nav-links{
    position:fixed; top:0; right:0; bottom:auto; left:auto;
    height:100vh; height:100dvh; width:min(78vw,320px);
    flex-direction:column; gap:6px; padding:100px 30px 40px;
    background:rgba(6,16,11,.98); backdrop-filter:blur(20px);
    border-left:1px solid var(--line); transform:translateX(100%);
    transition:transform .45s var(--ease);
    overflow-y:auto;
  }
  .nav-links.open{ transform:none; }
  .nav-links a{ font-size:1.1rem; padding:.6rem 0; }
  .grid-2{ grid-template-columns:1fr; }
  .feature-grid{ grid-template-columns:1fr; }
  .cf-grid{ grid-template-columns:1fr; }
  .creds{ grid-template-columns:1fr; }
  .hero-scan{ display:none; }
  .scroll-cue{ display:none; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; }
  .reveal{ opacity:1; transform:none; }
  html{ scroll-behavior:auto; }
}
