/* ===== ROOT & RESET ===== */
:root {
  --bg-deep:    #010a14;
  --bg-dark:    #020d1c;
  --bg-card:    #071525;
  --bg-card-h:  #0c1d30;
  --cyan:       #00d4ff;
  --cyan-dim:   rgba(0,212,255,0.55);
  --cyan-glow:  rgba(0,212,255,0.10);
  --cyan-bdr:   rgba(0,212,255,0.20);
  --teal:       #64ffda;
  --red:        #ff3b5c;
  --red-glow:   rgba(255,59,92,0.18);
  --text:       #b8d4e8;
  --text-hi:    #e2f2ff;
  --text-dim:   #4a7a9b;
  --border:     rgba(0,212,255,0.14);
  --font-disp:  'Orbitron', monospace;
  --font-body:  'Rajdhani', sans-serif;
  --font-mono:  'Share Tech Mono', monospace;
  --ease:       cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --glow:       0 0 22px rgba(0,212,255,0.4), 0 0 60px rgba(0,212,255,0.12);
  --r:          8px;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  background: var(--bg-deep);
  color: var(--text);
  line-height: 1.65;
  overflow-x: hidden;
}

/* Scrollbar */
::-webkit-scrollbar            { width: 5px; }
::-webkit-scrollbar-track      { background: var(--bg-dark); }
::-webkit-scrollbar-thumb      { background: var(--cyan-bdr); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover{ background: var(--cyan); }

/* Canvas + scanlines */
#particleCanvas {
  position: fixed; inset: 0;
  z-index: 0; pointer-events: none;
}
.scanlines {
  position: fixed; inset: 0;
  z-index: 1; pointer-events: none;
  background: repeating-linear-gradient(
    0deg, transparent, transparent 2px,
    rgba(0,0,0,0.025) 2px, rgba(0,0,0,0.025) 4px
  );
}
header, section, footer, .threat-ticker-bar { position: relative; z-index: 10; }

/* ===== TYPOGRAPHY ===== */
h1,h2,h3,h4 { font-family: var(--font-disp); line-height: 1.15; }
h1 { font-size: clamp(2rem, 5vw, 3.8rem); }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.6rem); }
h3 { font-size: clamp(1rem, 2vw, 1.3rem); }
.font-mono { font-family: var(--font-mono); }
.accent     { color: var(--cyan); }
.logo-accent{ color: var(--teal); }

/* ===== LAYOUT ===== */
.container { width:100%; max-width:1200px; margin:0 auto; padding:0 24px; }
section    { padding: 90px 0; }

/* ===== BUTTONS ===== */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 28px;
  border: none; border-radius: var(--r);
  font-family: var(--font-disp); font-size: 0.72rem;
  font-weight: 600; letter-spacing: 0.06em;
  text-decoration: none; cursor: pointer;
  transition: all 0.3s var(--ease);
}
.btn-primary { background: var(--cyan); color: var(--bg-deep); }
.btn-primary:hover {
  background: #10eeff;
  box-shadow: var(--glow);
  transform: translateY(-3px);
}
.btn-outline {
  background: transparent;
  border: 1.5px solid var(--cyan-bdr);
  color: var(--cyan);
}
.btn-outline:hover {
  border-color: var(--cyan); background: var(--cyan-glow);
  box-shadow: var(--glow); transform: translateY(-3px);
}
.btn-full { width:100%; justify-content:center; }

/* ===== SECTION HEADER ===== */
.section-header { text-align:center; margin-bottom: 3.5rem; }
.section-tag {
  display: inline-block; font-size: 0.75rem;
  color: var(--cyan); letter-spacing: 0.14em;
  margin-bottom: 0.7rem; opacity: 0.75;
}
.section-header h2 { color: var(--text-hi); }
.section-desc {
  text-align:center; max-width:780px;
  margin: -2.5rem auto 3rem;
  color: var(--text-dim); font-size: 1rem;
}

/* Reveal animation */
.reveal {
  opacity: 0; transform: translateY(26px);
  transition: opacity 0.6s var(--ease), transform 0.6s var(--ease);
}
.reveal.visible { opacity:1; transform:translateY(0); }

/* ===== HEADER ===== */
header {
  position: fixed; top:0; left:0; width:100%;
  z-index: 1000; padding: 18px 0;
  transition: all 0.4s var(--ease);
  border-bottom: 1px solid transparent;
}
header.scrolled {
  padding: 11px 0;
  background: rgba(1,10,20,0.94);
  backdrop-filter: blur(20px);
  border-bottom-color: var(--border);
}
nav { display:flex; justify-content:space-between; align-items:center; }
.logo {
  display:flex; align-items:center; gap:10px;
  text-decoration:none; font-family: var(--font-disp);
  font-size: 1.3rem; font-weight:700; color: var(--text-hi);
}
.logo img { height:32px; width:auto; object-fit:contain; }

.nav-links { display:flex; list-style:none; gap:6px; align-items:center; }
.nav-link {
  color: var(--text); text-decoration:none;
  font-family: var(--font-disp); font-size: 0.62rem;
  letter-spacing: 0.08em; padding: 8px 13px; border-radius: 4px;
  transition: all 0.25s;
}
.nav-link:hover { color: var(--cyan); background: var(--cyan-glow); }
.nav-cta { border: 1.5px solid var(--cyan-bdr); color: var(--cyan); }
.nav-cta:hover { background: var(--cyan); color: var(--bg-deep); border-color: var(--cyan); }

/* Hamburger */
.mobile-menu-btn {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:8px;
}
.mobile-menu-btn span {
  display:block; width:24px; height:2px;
  background: var(--cyan); border-radius:2px; transition: all 0.3s;
}
.mobile-menu-btn.open span:nth-child(1){ transform: rotate(45deg) translate(5px,5px); }
.mobile-menu-btn.open span:nth-child(2){ opacity:0; }
.mobile-menu-btn.open span:nth-child(3){ transform: rotate(-45deg) translate(5px,-5px); }

.mobile-menu-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,0.65);
  opacity:0; visibility:hidden; transition:all 0.3s; z-index:999;
}
.mobile-menu-overlay.active { opacity:1; visibility:visible; }

/* ===== HERO ===== */
.hero {
  min-height:100vh; display:flex; align-items:center;
  padding-top: 90px;
  background: radial-gradient(ellipse at 20% 50%, rgba(0,212,255,0.04) 0%, transparent 60%),
              radial-gradient(ellipse at 80% 20%, rgba(100,255,218,0.03) 0%, transparent 50%),
              linear-gradient(160deg, #010a14 0%, #020d1c 60%, #011525 100%);
  overflow: hidden;
}
.hero-content {
  display:flex; align-items:center;
  justify-content:space-between; gap:60px;
  padding: 40px 0 20px;
}
.hero-text { flex:1; max-width:600px; }

/* Hero tag */
.hero-tag {
  display:inline-flex; align-items:center; gap:10px;
  margin-bottom:1.2rem; font-size:0.74rem;
  color: var(--cyan-dim); letter-spacing:0.12em;
}
.tag-dot {
  width:8px; height:8px; border-radius:50%;
  background: var(--red); box-shadow: 0 0 8px var(--red);
  animation: blink 1.5s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1;} 50%{opacity:0.25;} }

/* Heading */
.hero-title {
  display:block; color: var(--text-hi);
  font-weight:800; margin-bottom:0.15rem;
  position:relative;
}
.hero-accent { color: var(--cyan); text-shadow: 0 0 35px rgba(0,212,255,0.45); }

/* Glitch */
.glitch::before, .glitch::after {
  content: attr(data-text);
  position:absolute; top:0; left:0; width:100%; height:100%;
  font-family: inherit; font-weight: inherit; font-size: inherit;
}
.glitch::before { color: var(--red);  animation: glitch-a 4s infinite; }
.glitch::after  { color: var(--teal); animation: glitch-b 4s infinite; }
@keyframes glitch-a {
  0%,89%,100%{ clip-path:inset(100% 0 0 0); transform:translate(0); }
  90%{ clip-path:inset(20% 0 60% 0); transform:translate(-4px, 2px); }
  92%{ clip-path:inset(55% 0 25% 0); transform:translate(4px,-2px); }
  94%{ clip-path:inset(80% 0  5% 0); transform:translate(-2px,1px); }
}
@keyframes glitch-b {
  0%,87%,100%{ clip-path:inset(100% 0 0 0); transform:translate(0); }
  88%{ clip-path:inset(10% 0 80% 0); transform:translate(4px,-2px); }
  90%{ clip-path:inset(60% 0 20% 0); transform:translate(-4px,2px); }
  92%{ clip-path:inset(30% 0 50% 0); transform:translate(2px,-1px); }
}

.hero-sub {
  font-size:1.05rem; color: var(--text);
  margin: 1.2rem 0 1rem; line-height:1.8;
}
.hero-typing {
  font-family: var(--font-mono); font-size:0.88rem;
  color: var(--teal); margin-bottom:2rem; min-height:1.5em;
}
.typing-prefix { color: var(--cyan-dim); margin-right:6px; }
.cursor { display:inline-block; color:var(--cyan); animation:blink 0.8s infinite; }
.hero-btns { display:flex; gap:16px; flex-wrap:wrap; }

/* Shield visual */
.hero-visual { flex: 0 0 360px; display:flex; justify-content:center; }
.shield-container {
  position:relative; width:320px; height:320px;
  display:flex; align-items:center; justify-content:center;
}
.shield-ring {
  position:absolute; border-radius:50%; border:1px solid;
  animation: spin linear infinite;
}
.ring-1 { width:100%;height:100%; border-color:rgba(0,212,255,0.18); border-style:dashed; animation-duration:22s; }
.ring-2 { width:70%; height:70%; border-color:rgba(0,212,255,0.3); border-top-color:var(--cyan); animation-duration:13s; animation-direction:reverse; }
.ring-3 { width:44%;height:44%; border-color:rgba(100,255,218,0.25); border-right-color:var(--teal); animation-duration:8s; }
@keyframes spin { from{transform:rotate(0deg);} to{transform:rotate(360deg);} }

.shield-core {
  width:118px; height:118px; border-radius:50%; z-index:2;
  background: linear-gradient(135deg,rgba(0,212,255,0.14),rgba(0,15,35,0.9));
  border: 1.5px solid var(--cyan-bdr);
  display:flex; align-items:center; justify-content:center;
  font-size:2.4rem; color:var(--cyan);
  box-shadow: var(--glow), inset 0 0 30px rgba(0,212,255,0.07);
  animation: core-pulse 3s ease-in-out infinite;
}
@keyframes core-pulse {
  0%,100%{ box-shadow: var(--glow), inset 0 0 30px rgba(0,212,255,0.07); }
  50%    { box-shadow: 0 0 45px rgba(0,212,255,0.65), 0 0 90px rgba(0,212,255,0.2), inset 0 0 40px rgba(0,212,255,0.14); }
}

.orbit { position:absolute; border-radius:50%; animation: spin linear infinite; }
.orbit-1 { width:100%;height:100%; animation-duration:22s; }
.orbit-2 { width:70%; height:70%; animation-duration:13s; animation-direction:reverse; }
.orbit-3 { width:44%;height:44%; animation-duration:8s; }
.orbit-dot {
  position:absolute; top:-5px; left:50%; transform:translateX(-50%);
  width:10px;height:10px; border-radius:50%;
  background:var(--cyan); box-shadow:0 0 12px var(--cyan);
}
.dot-red  { background:var(--red);  box-shadow:0 0 12px var(--red); }
.dot-teal { background:var(--teal); box-shadow:0 0 12px var(--teal); }

.shield-hex {
  position:absolute; font-family:var(--font-mono);
  font-size:0.6rem; color:var(--cyan-dim);
  animation: hex-drift 4.5s ease-in-out infinite;
}
.hex-1{top:6%;right:14%;animation-delay:0s;}
.hex-2{top:18%;left:4%;animation-delay:1.1s;}
.hex-3{bottom:10%;right:9%;animation-delay:2.2s;}
.hex-4{bottom:22%;left:14%;animation-delay:3.3s;}
@keyframes hex-drift {
  0%,100%{opacity:0.35;transform:translateY(0);} 50%{opacity:0.9;transform:translateY(-9px);}
}

/* Hero stats bar */
.hero-stats {
  display:flex; align-items:stretch;
  margin-top:3rem;
  background: rgba(7,21,37,0.8);
  border:1px solid var(--border); border-radius:var(--r);
  backdrop-filter:blur(10px); overflow:hidden;
}
.stat-item { flex:1; padding:28px 20px; text-align:center; }
.stat-num {
  font-family:var(--font-disp);
  font-size:clamp(1.5rem,2.8vw,2.2rem); font-weight:700;
  color:var(--cyan); text-shadow:0 0 20px rgba(0,212,255,0.5);
  margin-bottom:6px;
}
.stat-label { font-size:0.83rem; color:var(--text-dim); line-height:1.4; }
.stat-divider { width:1px; background:var(--border); flex-shrink:0; }

/* ===== THREAT TICKER ===== */
.threat-ticker-bar {
  display:flex; align-items:center; height:44px; overflow:hidden;
  background: linear-gradient(90deg, rgba(255,59,92,0.12) 0%, rgba(7,21,37,0.96) 18%);
  border-top:1px solid rgba(255,59,92,0.28);
  border-bottom:1px solid rgba(255,59,92,0.28);
}
.ticker-label {
  flex-shrink:0; padding:0 18px; height:100%;
  display:flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:0.7rem;
  color:var(--red); letter-spacing:0.08em; white-space:nowrap;
  border-right:1px solid rgba(255,59,92,0.28);
  background:rgba(255,59,92,0.07);
}
.ticker-track { flex:1; overflow:hidden; height:100%; }
.ticker-content {
  display:inline-flex; align-items:center; height:100%;
  white-space:nowrap; animation: ticker 45s linear infinite;
  font-family:var(--font-mono); font-size:0.74rem; color:var(--text);
}
.ticker-content span { padding:0 36px; }
.ticker-content span::after { content:'//'; padding-left:36px; opacity:0.25; }
@keyframes ticker { from{transform:translateX(0);} to{transform:translateX(-50%);} }

/* ===== WHY US ===== */
.why-us { background:var(--bg-dark); }
.impact-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:24px;
}
.impact-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--r); padding:36px 22px; text-align:center;
  position:relative; overflow:hidden;
  transition: all 0.35s var(--ease);
}
.impact-card:hover {
  border-color:var(--cyan-bdr); background:var(--bg-card-h);
  transform:translateY(-7px);
  box-shadow:0 16px 50px rgba(0,212,255,0.08);
}
.card-glow-line {
  position:absolute; inset:0; bottom:auto; height:2px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
  transform:scaleX(0); transition:transform 0.4s;
}
.impact-card:hover .card-glow-line { transform:scaleX(1); }
.impact-icon {
  width:56px; height:56px; margin:0 auto 16px;
  border-radius:50%; background:var(--cyan-glow);
  border:1px solid var(--cyan-bdr);
  display:flex; align-items:center; justify-content:center;
  font-size:1.25rem; color:var(--cyan);
}
.impact-num {
  font-family:var(--font-disp);
  font-size:clamp(1.8rem,3vw,2.6rem); font-weight:800;
  color:var(--cyan); text-shadow:0 0 18px rgba(0,212,255,0.4);
  margin-bottom:8px;
}
.impact-label { font-size:0.88rem; color:var(--text-dim); }

/* ===== ABOUT ===== */
.about { background:var(--bg-deep); }
.about-content {
  display:flex; gap:80px; align-items:center; margin-bottom:4rem;
}
.about-text { flex:1; }
.about-text p { color:var(--text); margin-bottom:1.2rem; line-height:1.8; }

/* Radar */
.about-visual { flex: 0 0 300px; display:flex; justify-content:center; }
.radar-container {
  position:relative; width:280px; height:280px;
  margin-bottom: 30px;
}

/* Grid rings */
.radar-circle {
  position:absolute; border-radius:50%;
  top:50%; left:50%; transform:translate(-50%,-50%);
}
.r1{width:100%;height:100%;border:1px solid rgba(0,212,255,0.22);}
.r2{width:73%; height:73%;border:1px solid rgba(0,212,255,0.15);}
.r3{width:47%; height:47%;border:1px solid rgba(0,212,255,0.15);}
.r4{width:20%; height:20%;border:1px solid rgba(0,212,255,0.25); background:rgba(0,212,255,0.06);}

/* Crosshair lines */
.radar-cross {
  position:absolute; top:50%; left:50%;
  background:rgba(0,212,255,0.1);
}
.radar-cross.h{ width:100%; height:1px; transform:translate(-50%,-50%); }
.radar-cross.v{ width:1px; height:100%; transform:translate(-50%,-50%); }

/* Sweep — full circle with conic-gradient, rotated as a whole */
.radar-sweep {
  position:absolute; inset:0;
  border-radius:50%;
  background: conic-gradient(
    from 0deg,
    rgba(0,212,255,0)    0deg,
    rgba(0,212,255,0)    280deg,
    rgba(0,212,255,0.04) 310deg,
    rgba(0,212,255,0.18) 340deg,
    rgba(0,212,255,0.55) 356deg,
    rgba(0,212,255,0.7)  360deg
  );
  animation: radar-spin 3s linear infinite;
}

/* Tip line — thin bright arm at the sweep's leading edge */
.radar-sweep::after {
  content:'';
  position:absolute; top:50%; left:50%;
  width:50%; height:1.5px;
  background:linear-gradient(90deg, rgba(0,212,255,0.8), rgba(0,212,255,0));
  transform-origin: 0 50%;
}

@keyframes radar-spin { from{transform:rotate(0deg);} to{transform:rotate(360deg);} }

/* Threat blips */
.radar-blip {
  position:absolute; width:8px; height:8px; border-radius:50%; z-index:2;
  background:var(--red); box-shadow:0 0 8px var(--red), 0 0 18px var(--red);
  animation:blip 2s ease-in-out infinite;
}
.b1{top:28%;left:62%;animation-delay:0s;}
.b2{top:65%;left:24%;animation-delay:0.75s;}
.b3{top:18%;left:36%;animation-delay:1.5s;}
@keyframes blip{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.15;transform:scale(0.35);}}

.radar-label {
  position:absolute; bottom:-28px; left:50%; transform:translateX(-50%);
  font-size:0.6rem; color:var(--cyan-dim); white-space:nowrap; letter-spacing:0.12em;
}

/* Values */
.values-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.value-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--r); padding:28px 20px; text-align:center;
  transition:all 0.35s var(--ease);
}
.value-card:hover {
  border-color:var(--cyan-bdr); transform:translateY(-5px);
  box-shadow:0 10px 35px rgba(0,212,255,0.07);
}
.value-icon {
  width:52px; height:52px; margin:0 auto 14px;
  border-radius:50%; background:var(--cyan-glow);
  border:1px solid var(--cyan-bdr);
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; color:var(--cyan);
}
.value-card h4 { font-size:0.85rem; color:var(--text-hi); margin-bottom:8px; }
.value-card p  { font-size:0.83rem; color:var(--text-dim); }

/* ===== SERVICES ===== */
.services { background:var(--bg-dark); }
.service-tabs {
  display:flex; justify-content:center;
  gap:8px; flex-wrap:wrap; margin-bottom:30px;
}
.tab-btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 22px; background:var(--bg-card);
  border:1px solid var(--border); border-radius:var(--r);
  color:var(--text-dim); font-family:var(--font-mono);
  font-size:0.76rem; cursor:pointer; transition:all 0.3s;
}
.tab-btn:hover, .tab-btn.active {
  background:var(--cyan); color:var(--bg-deep);
  border-color:var(--cyan); box-shadow:0 0 22px rgba(0,212,255,0.3);
}
.tab-content {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--r); padding:40px; min-height:340px;
}
.tab-pane { display:none; animation:fadeUp 0.4s var(--ease); }
.tab-pane.active { display:block; }
@keyframes fadeUp{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}
.tab-header { margin-bottom:26px; }
.tab-header h3 { color:var(--cyan); margin-bottom:6px; }
.tab-header p  { color:var(--text-dim); font-size:0.93rem; }

.service-list { list-style:none; }
.service-list li {
  display:flex; align-items:center; gap:16px;
  padding:14px 0; border-bottom:1px solid rgba(0,212,255,0.05);
  color:var(--text); font-size:1rem; transition:all 0.28s;
}
.service-list li:last-child { border-bottom:none; }
.service-list li:hover { color:var(--text-hi); padding-left:8px; }
.service-list i {
  width:36px; height:36px; flex-shrink:0;
  border-radius:6px; background:var(--cyan-glow);
  border:1px solid var(--cyan-bdr);
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--cyan); font-size:0.85rem;
}

/* ===== CLIENTS ===== */
.clients { background:var(--bg-deep); }
.clients-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.client-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--r); padding:36px 26px; text-align:center;
  position:relative; overflow:hidden;
  transition:all 0.35s var(--ease);
}
.client-card::after {
  content:''; position:absolute; inset:-2px;
  border-radius:inherit; border:1.5px solid var(--cyan);
  opacity:0; transition:opacity 0.35s;
}
.client-card:hover { transform:translateY(-7px); box-shadow:0 16px 50px rgba(0,212,255,0.1); }
.client-card:hover::after { opacity:1; }
.client-icon {
  width:64px; height:64px; margin:0 auto 18px;
  border-radius:50%; background:var(--cyan-glow);
  border:1.5px solid var(--cyan-bdr);
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; color:var(--cyan);
  transition:all 0.35s;
}
.client-card:hover .client-icon {
  background:rgba(0,212,255,0.18);
  box-shadow:0 0 22px rgba(0,212,255,0.3);
}
.client-card h4 { font-size:0.95rem; color:var(--text-hi); margin-bottom:6px; }
.client-card p  { font-size:0.83rem; color:var(--text-dim); }

/* ===== TESTIMONIALS ===== */
.testimonials { background:var(--bg-dark); }
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.testimonial-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--r); padding:30px;
  position:relative; transition:all 0.35s var(--ease);
}
.testimonial-card:hover {
  border-color:rgba(100,255,218,0.2); transform:translateY(-5px);
  box-shadow:0 10px 35px rgba(100,255,218,0.05);
}
.quote-mark { font-size:2.2rem; color:rgba(100,255,218,0.13); margin-bottom:14px; }
.testimonial-card p {
  font-size:0.93rem; color:var(--text);
  line-height:1.78; font-style:italic; margin-bottom:22px;
}
.client-info { display:flex; align-items:center; gap:13px; }
.client-avatar {
  width:44px; height:44px; border-radius:50%; flex-shrink:0;
  background:linear-gradient(135deg,var(--cyan),var(--teal));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-disp); font-size:0.68rem;
  font-weight:700; color:var(--bg-deep);
}
.client-info strong { display:block; font-family:var(--font-disp); font-size:0.76rem; color:var(--text-hi); }
.client-info span   { font-size:0.78rem; color:var(--text-dim); }

/* ===== EXPERTISE ===== */
.team { background:var(--bg-deep); }
.certifications { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.cert-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--r); padding:26px;
  position:relative; overflow:hidden;
  transition:all 0.35s var(--ease);
}
.cert-card::before {
  content:''; position:absolute; top:0;left:0;right:0; height:2px;
  background:linear-gradient(90deg,var(--cyan),var(--teal));
  transform:scaleX(0); transform-origin:left; transition:transform 0.4s;
}
.cert-card:hover { border-color:var(--cyan-bdr); transform:translateY(-5px); box-shadow:0 10px 35px rgba(0,212,255,0.08); }
.cert-card:hover::before { transform:scaleX(1); }
.cert-icon {
  width:46px; height:46px; border-radius:7px;
  background:var(--cyan-glow); border:1px solid var(--cyan-bdr);
  display:flex; align-items:center; justify-content:center;
  font-size:1.15rem; color:var(--cyan); margin-bottom:14px;
}
.cert-card h3 { font-size:0.8rem; color:var(--cyan); margin-bottom:14px; letter-spacing:0.06em; }
.cert-list { list-style:none; }
.cert-list li {
  display:flex; align-items:flex-start; gap:9px;
  padding:7px 0; border-bottom:1px solid rgba(0,212,255,0.05);
  font-size:0.86rem; color:var(--text);
}
.cert-list li:last-child { border-bottom:none; }
.cert-list i { color:var(--teal); font-size:0.72rem; margin-top:3px; flex-shrink:0; }

/* ===== CONTACT ===== */
.contact { background:var(--bg-dark); }
.contact-content { display:flex; gap:60px; align-items:flex-start; }
.contact-info { flex:1; }
.contact-info h3 { font-size:1.15rem; color:var(--text-hi); margin-bottom:10px; }
.contact-info > p { color:var(--text-dim); margin-bottom:2rem; line-height:1.75; }
.info-item { display:flex; gap:15px; align-items:flex-start; margin-bottom:22px; }
.info-icon {
  width:42px; height:42px; border-radius:7px; flex-shrink:0;
  background:var(--cyan-glow); border:1px solid var(--cyan-bdr);
  display:flex; align-items:center; justify-content:center;
  color:var(--cyan); font-size:0.95rem;
}
.info-item h4 { font-family:var(--font-mono); font-size:0.72rem; color:var(--cyan); margin-bottom:3px; }
.info-item p  { font-size:0.88rem; color:var(--text); }

.social-links { display:flex; gap:10px; margin-top:26px; }
.social-links a {
  width:40px; height:40px; border-radius:7px;
  background:var(--bg-card); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--cyan); text-decoration:none; transition:all 0.28s;
}
.social-links a:hover {
  background:var(--cyan); color:var(--bg-deep);
  box-shadow:var(--glow); transform:translateY(-3px);
}

/* Form */
.contact-form { flex:1; }
.form-group { margin-bottom:18px; }
.form-group label {
  display:block; font-family:var(--font-mono);
  font-size:0.68rem; color:var(--cyan-dim);
  letter-spacing:0.1em; margin-bottom:7px;
}
.form-group input,
.form-group textarea {
  width:100%; padding:13px 15px;
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--r); color:var(--text-hi);
  font-family:var(--font-body); font-size:0.94rem;
  transition:all 0.28s; resize:none;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color:var(--text-dim); }
.form-group input:focus,
.form-group textarea:focus {
  outline:none; border-color:var(--cyan-bdr);
  box-shadow:0 0 0 3px rgba(0,212,255,0.07), 0 0 20px rgba(0,212,255,0.1);
  background:var(--bg-card-h);
}

/* ===== FOOTER ===== */
footer {
  background:rgba(1,5,12,0.98);
  border-top:1px solid var(--border);
  padding:60px 0 30px;
}
.footer-content { display:flex; gap:60px; flex-wrap:wrap; margin-bottom:40px; }
.footer-brand { flex:2; min-width:270px; }
.footer-brand .logo { margin-bottom:14px; }
.footer-brand p { font-size:0.88rem; color:var(--text-dim); line-height:1.75; max-width:350px; }
.footer-links { flex:1; min-width:150px; }
.footer-links h4 {
  font-family:var(--font-disp); font-size:0.7rem;
  letter-spacing:0.12em; color:var(--cyan); margin-bottom:18px;
}
.footer-links ul  { list-style:none; }
.footer-links li  { margin-bottom:9px; }
.footer-links a   { color:var(--text-dim); text-decoration:none; font-size:0.88rem; transition:color 0.25s; }
.footer-links a:hover { color:var(--cyan); }

.footer-bottom {
  display:flex; justify-content:space-between; align-items:center;
  padding-top:26px; border-top:1px solid var(--border);
  flex-wrap:wrap; gap:14px;
}
.footer-bottom p { font-size:0.8rem; color:var(--text-dim); }
.footer-status { display:flex; align-items:center; gap:8px; font-size:0.72rem; color:var(--teal); }
.status-dot {
  width:8px; height:8px; border-radius:50%;
  background:var(--teal); box-shadow:0 0 8px var(--teal);
  animation:blink 2s ease-in-out infinite;
}

/* ===== RESPONSIVE ===== */
@media (max-width:1024px) {
  .impact-grid    { grid-template-columns:repeat(2,1fr); }
  .certifications { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:900px) {
  .hero-content   { flex-direction:column; text-align:center; }
  .hero-visual    { display:none; }
  .hero-btns      { justify-content:center; }
  .about-content  { flex-direction:column; }
  .about-visual   { display:none; }
  .values-grid    { grid-template-columns:repeat(2,1fr); }
  .clients-grid   { grid-template-columns:repeat(2,1fr); }
  .testimonials-grid { grid-template-columns:1fr; }
}
@media (max-width:768px) {
  .mobile-menu-btn { display:flex; }
  .nav-links {
    position:fixed; top:0; right:-100%;
    width:min(300px,80vw); height:100vh;
    background:rgba(1,10,20,0.97);
    border-left:1px solid var(--border);
    backdrop-filter:blur(20px);
    flex-direction:column; justify-content:center;
    align-items:center; gap:22px;
    transition:right 0.4s var(--ease); z-index:1001;
  }
  .nav-links.active { right:0; }
  .nav-link { font-size:0.72rem; padding:12px 24px; }
  .contact-content { flex-direction:column; }
  .hero-stats { flex-direction:column; }
  .stat-divider { width:100%; height:1px; }
}
@media (max-width:580px) {
  section           { padding:65px 0; }
  .impact-grid      { grid-template-columns:1fr 1fr; }
  .values-grid      { grid-template-columns:1fr; }
  .clients-grid     { grid-template-columns:1fr; }
  .certifications   { grid-template-columns:1fr; }
  .tab-content      { padding:24px 18px; }
  .tab-btn          { font-size:0.68rem; padding:9px 13px; }
  .hero-stats       { display:none; }
  .ticker-label     { display:none; }
  .process-track    { flex-direction:column; align-items:center; gap:32px; }
  .process-line     { display:none; }
}

/* ===== HERO GRID BACKGROUND ===== */
.hero::before {
  content:''; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(0,212,255,0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,212,255,0.035) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 40%, transparent 100%);
}

/* ===== SCROLL PROGRESS BAR ===== */
#progressBar {
  position:fixed; top:0; left:0; height:2px; width:0%;
  background:linear-gradient(90deg, var(--cyan), var(--teal));
  z-index:9999; transition:width 0.1s linear;
  box-shadow:0 0 8px var(--cyan);
}

/* ===== PRELOADER ===== */
#preloader {
  position:fixed; inset:0; z-index:99999;
  background:var(--bg-deep);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:18px;
  transition:opacity 0.5s var(--ease), visibility 0.5s;
}
#preloader.hidden { opacity:0; visibility:hidden; }

.pre-shield {
  font-size:3rem; color:var(--cyan);
  text-shadow:0 0 30px var(--cyan), 0 0 60px rgba(0,212,255,0.3);
  animation:core-pulse 1.5s ease-in-out infinite;
  z-index:1;
}
.pre-ring {
  position:absolute; border-radius:50%;
  border:1.5px solid rgba(0,212,255,0.35);
  width:120px; height:120px;
  animation:pre-expand 1.5s ease-out infinite;
}
.pre-ring.r2 {
  width:160px; height:160px;
  border-color:rgba(0,212,255,0.18);
  animation-delay:0.4s;
}
@keyframes pre-expand {
  0%  { transform:scale(0.6); opacity:1; }
  100%{ transform:scale(1.6); opacity:0; }
}
.pre-bar {
  width:200px; height:2px;
  background:rgba(0,212,255,0.12);
  border-radius:2px; overflow:hidden;
  margin-top:24px;
}
.pre-fill {
  height:100%; width:0%;
  background:linear-gradient(90deg,var(--cyan),var(--teal));
  transition:width 0.1s linear;
  box-shadow:0 0 8px var(--cyan);
}
.pre-text {
  font-size:0.65rem; color:var(--cyan-dim);
  letter-spacing:0.14em; margin-top:6px;
}

/* ===== BACK TO TOP ===== */
#backToTop {
  position:fixed; bottom:90px; right:24px; z-index:500;
  width:44px; height:44px; border-radius:8px;
  background:var(--bg-card); border:1px solid var(--cyan-bdr);
  color:var(--cyan); font-size:1rem; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  opacity:0; transform:translateY(12px);
  transition:all 0.3s var(--ease);
  box-shadow:0 4px 20px rgba(0,0,0,0.3);
}
#backToTop.visible { opacity:1; transform:translateY(0); }
#backToTop:hover {
  background:var(--cyan); color:var(--bg-deep);
  box-shadow:var(--glow); transform:translateY(-3px);
}

/* ===== FLOATING CTA ===== */
#floatingCta {
  position:fixed; bottom:24px; right:24px; z-index:500;
  display:flex; align-items:center; gap:9px;
  padding:12px 18px; border-radius:50px;
  background:var(--cyan); color:var(--bg-deep);
  font-family:var(--font-disp); font-size:0.68rem;
  font-weight:700; letter-spacing:0.06em;
  text-decoration:none;
  box-shadow:var(--glow), 0 6px 24px rgba(0,0,0,0.4);
  transition:all 0.3s var(--ease);
  opacity:0; transform:translateY(12px);
}
#floatingCta.visible { opacity:1; transform:translateY(0); }
#floatingCta:hover {
  background:#10eeff;
  box-shadow:0 0 35px rgba(0,212,255,0.65), 0 8px 30px rgba(0,0,0,0.4);
  transform:translateY(-3px);
}
#floatingCta span { white-space:nowrap; }
@media(max-width:480px){ #floatingCta span { display:none; } #floatingCta { border-radius:50%; padding:13px; } }

/* ===== PROCESS SECTION ===== */
.process { background:var(--bg-dark); }
.process-track {
  display:flex; justify-content:space-between; align-items:flex-start;
  gap:0; position:relative; margin-top:1rem;
}
.process-line {
  position:absolute; top:52px; left:calc(12.5% + 16px); right:calc(12.5% + 16px);
  height:1px;
  background:linear-gradient(90deg,
    transparent 0%,
    var(--cyan-bdr) 15%,
    var(--cyan-bdr) 85%,
    transparent 100%);
  z-index:0;
}
.process-step {
  flex:1; display:flex; flex-direction:column;
  align-items:center; text-align:center;
  padding:0 16px; position:relative; z-index:1;
}
.step-num {
  font-family:var(--font-mono); font-size:0.65rem;
  color:var(--cyan-dim); letter-spacing:0.12em; margin-bottom:10px;
}
.step-icon {
  width:64px; height:64px; border-radius:50%; margin-bottom:18px;
  background:var(--bg-card);
  border:1.5px solid var(--cyan-bdr);
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; color:var(--cyan);
  transition:all 0.35s var(--ease);
  box-shadow:0 0 0 0 rgba(0,212,255,0);
}
.process-step:hover .step-icon {
  background:rgba(0,212,255,0.12);
  border-color:var(--cyan);
  box-shadow:0 0 25px rgba(0,212,255,0.3);
  transform:translateY(-4px);
}
.process-step h4 {
  font-size:0.95rem; color:var(--text-hi); margin-bottom:10px;
}
.process-step p {
  font-size:0.85rem; color:var(--text-dim); line-height:1.7; max-width:200px;
}

/* Nav scrollspy active */
.nav-link.active-section { color:var(--cyan); }
