/* ================================================================
   REDZONE CYBER — REDESIGN LAYER
   Fonts/sizes preserved. Layout, atmosphere, components upgraded.
   ================================================================ */

/* ================================================================
   STYLESHEET SECTIONS
   1) Global / Shared CSS
   2) Home Page CSS {}
   3) About Page CSS {}
   4) Services Page CSS {}
   5) Contact Page CSS {}
   ================================================================ */

/* -- CSS Variables -- */
:root {
  --brand-red: #c20f1f;
  --brand-red-bright: #ea1d2c;
  --brand-dark: #0a0a0d;
  --brand-deep: #111116;
  --brand-light: #f7f7f8;
  --brand-muted: #9090a0;
  --card-bg: #111116;
  --brand-red-glow: rgba(234,29,44,0.4);
  --panel-border: rgba(255,255,255,0.08);
  --red-border: rgba(234,29,44,0.2);
  --site-shell-width: min(1480px, 95vw);
  --site-text-width: 920px;
  --site-centered-panel-width: min(1240px, calc(100% - 24px));
}

/* -- Base -- */
*, *::before, *::after { box-sizing: border-box; }

body {
  margin: 0;
  font-family: "Inter", sans-serif;
  background:
    radial-gradient(circle at 8% 6%,  rgba(234,29,44,0.16), transparent 32%),
    radial-gradient(circle at 92% 14%, rgba(255,255,255,0.04), transparent 28%),
    radial-gradient(circle at 40% 100%,rgba(234,29,44,0.10), transparent 45%),
    linear-gradient(160deg, #13131a 0%, #0a0a0d 50%, #07070a 100%);
  color: var(--brand-light);
  min-height: 100vh;
  overflow-x: hidden;
}
.bootstrap-shell img,
.bootstrap-shell iframe {
  max-width: 100%;
}

/* subtle noise */
body::after {
  content:"";
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events:none;z-index:9999;opacity:0.35;
}

/* -- Grid bg -- */
.bg-grid {
  position:fixed;inset:0;
  background-image:
    linear-gradient(rgba(234,29,44,0.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(234,29,44,0.055) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.022) 1px, transparent 1px);
  background-size: 96px 96px, 96px 96px, 24px 24px, 24px 24px;
  mask-image: radial-gradient(ellipse at 45% 15%, black 5%, transparent 72%);
  pointer-events:none;z-index:-1;
  animation: gridPulse 9s ease-in-out infinite;
}
@keyframes gridPulse { 0%,100%{opacity:1} 50%{opacity:0.55} }

/* -- Typography -- */
.brand, h1, h2, h3, .footer-grid h3, .cert-card figcaption {
  font-family: "Oxanium", sans-serif;
}
h1 { font-size: clamp(2.15rem, 5.5vw, 4rem); line-height:1.05; margin:12px 0; text-shadow: 0 0 18px rgba(234,29,44,0.1); }
h2 { font-size: clamp(1.5rem, 3vw, 2.1rem); margin-bottom:16px; border-left:4px solid var(--brand-red); padding-left:14px; text-transform:uppercase; letter-spacing:0.04em; }
h3 { margin:0 0 8px; }
.eyebrow { color:var(--brand-red-bright); text-transform:uppercase; letter-spacing:0.18em; font-size:0.75rem; font-weight:700; text-shadow:0 0 10px rgba(234,29,44,0.3); }
.lead, .body-copy { font-size:1.05rem; color:#ccccd8; max-width:var(--site-text-width); line-height:1.7; }

/* -- Header -- */
.site-header {
  width: var(--site-shell-width);
  margin: 18px auto;
  padding: 13px 20px;
  border: 1px solid rgba(234,29,44,0.16);
  border-radius: 10px;
  background: linear-gradient(145deg, rgba(15,15,20,0.94), rgba(8,8,12,0.9));
  backdrop-filter: blur(12px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.3), inset 0 0 0 1px rgba(255,255,255,0.02);
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.site-header.navbar {
  --bs-navbar-padding-x: 0;
  --bs-navbar-padding-y: 0;
  --bs-navbar-color: var(--brand-muted);
  --bs-navbar-hover-color: var(--brand-light);
  --bs-navbar-active-color: var(--brand-light);
  --bs-navbar-toggler-focus-width: 0;
  --bs-navbar-toggler-border-color: rgba(234,29,44,0.24);
  flex-wrap: nowrap;
}
.brand {
  font-weight:800;font-size:1.05rem;letter-spacing:0.08em;
  text-decoration:none;color:var(--brand-light);text-transform:uppercase;
  text-shadow: 0 0 14px rgba(234,29,44,0.18);
  display:inline-flex;align-items:center;justify-content:center;
  padding:4px 10px;border-radius:8px;
  border:1px solid rgba(234,29,44,0.26);
  background:linear-gradient(160deg, rgba(10,10,13,0.86), rgba(17,17,22,0.9));
}
.brand.navbar-brand { margin:0; }
.brand span { color:var(--brand-red-bright); }
.brand img {
  display:block;
  width:clamp(108px, 10vw, 132px);
  height:auto;
  object-fit:contain;
  opacity:0.96;
  filter:drop-shadow(0 0 10px rgba(234,29,44,0.28));
  transition:opacity 0.2s ease, transform 0.2s ease, filter 0.2s ease;
}
.brand:hover img {
  opacity:1;
  transform:translateY(-1px);
  filter:drop-shadow(0 0 14px rgba(234,29,44,0.45));
}
.site-nav-shell {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 14px;
  flex: 1 1 auto;
}
.site-nav-shell[hidden] {
  display: none !important;
}
.main-nav {
  display:flex;
  gap:24px;
  align-items: center;
  width: max-content;
  margin-inline: auto !important;
}
.main-nav .nav-link {
  color:var(--brand-muted);
  text-decoration:none;
  font-size:0.95rem;
  padding:0 0 3px;
  line-height:1.2;
  transition:color 0.2s,border-color 0.2s,background 0.2s;
  border-bottom:2px solid transparent;
}
.main-nav .nav-link:hover,
.main-nav .nav-link.active {
  color:var(--brand-light);
  border-bottom-color: var(--brand-red-bright);
}
.nav-toggle {
  display:none;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(234,29,44,0.24);
  border-radius:8px;
  padding:0.4rem 0.55rem;
  background:linear-gradient(160deg, rgba(10,10,13,0.86), rgba(17,17,22,0.9));
  box-shadow:0 0 0 1px rgba(255,255,255,0.03) inset;
}
.nav-toggle:hover {
  border-color: rgba(234,29,44,0.42);
}
.nav-toggle:focus {
  box-shadow: 0 0 0 2px rgba(234,29,44,0.22);
}
.nav-toggle .navbar-toggler-icon {
  width:1.1em;
  height:1.1em;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='rgba(247,247,248,0.92)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}
.cta-small {
  background:var(--brand-red);color:#fff;text-decoration:none;
  padding:9px 16px;border-radius:7px;font-weight:600;font-size:0.9rem;
  clip-path: polygon(0 0, calc(100% - 7px) 0, 100% 7px, 100% 100%, 7px 100%, 0 calc(100% - 7px));
  box-shadow: 0 0 0 1px rgba(234,29,44,0.2) inset, 0 6px 18px rgba(194,15,31,0.3);
  transition:background 0.2s;
}
.cta-small:hover { background:var(--brand-red-bright); }

/* -- Main container -- */
main { width:var(--site-shell-width);margin:0 auto 140px; }
section { margin-top:64px; }
.section-block { margin-top:76px; animation: rise 0.7s ease both; animation-timeline:view(); animation-range:entry 0% entry 28%; }

@supports (content-visibility: auto) {
  .section-block,
  .detail-section,
  .cta-section,
  .site-footer {
    content-visibility: auto;
    contain-intrinsic-size: 1px 960px;
  }

  .section-block.section-block-eager {
    content-visibility: visible;
    contain-intrinsic-size: auto;
  }
}

/* -- Section label -- */
.section-label {
  font-family:"Oxanium",sans-serif;font-size:0.68rem;font-weight:700;
  letter-spacing:0.22em;text-transform:uppercase;color:rgba(234,29,44,0.65);
  margin:0 0 10px;display:flex;align-items:center;gap:8px;
}
.section-label::before { content:"";display:inline-block;width:22px;height:1px;background:rgba(234,29,44,0.45); }

/* -- Buttons -- */
.btn { text-decoration:none;padding:12px 20px;border-radius:8px;font-weight:600;font-family:"Oxanium",sans-serif;letter-spacing:0.04em;font-size:0.9rem; clip-path:polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 8px 100%, 0 calc(100% - 8px)); }
.btn-primary { background:var(--brand-red);color:#fff;box-shadow:0 6px 20px rgba(194,15,31,0.35);transition:background 0.2s,box-shadow 0.2s; }
.btn-primary:hover { background:var(--brand-red-bright);box-shadow:0 8px 24px rgba(234,29,44,0.5); }
.btn-ghost { border:1px solid rgba(255,255,255,0.18);color:var(--brand-light);background:rgba(255,255,255,0.025);transition:border-color 0.2s,background 0.2s; }
.btn-ghost:hover { border-color:rgba(234,29,44,0.45);background:rgba(234,29,44,0.06); }
.text-link { display:inline-block;margin-top:12px;color:var(--brand-red-bright);text-decoration:none;font-weight:600;font-size:0.9rem;text-shadow:0 0 10px rgba(234,29,44,0.15);transition:color 0.2s; }
.text-link:hover { color:var(--brand-light); }
.section-actions { margin-top:20px; }

/* -- Card surface -- */
.card-surface,
.service-grid article,
.team-card,
.contact-panel,
.stats-grid article,
.attack-grid article,
.format-grid article,
.approach-grid article,
.steps div,
.risk-list li,
.service-panel,
.brand-card,
.experience-grid article,
.partners-grid article,
.awards-grid article {
  border:1px solid var(--panel-border);
  border-radius:10px;
  background:
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(160deg, #191920 0%, var(--card-bg) 100%);
  background-size: 20px 20px, 20px 20px, auto;
  transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
  position:relative;overflow:hidden;
}
/* red corner pip */
.service-grid article::before,
.team-card::before,
.contact-panel::before,
.attack-grid article::before,
.experience-grid article::before,
.partners-grid article::before,
.service-panel::before,
.brand-card::before {
  content:"";position:absolute;top:0;right:0;
  width:40px;height:40px;
  background:linear-gradient(135deg, rgba(234,29,44,0.16), transparent 65%);
  pointer-events:none;
}
.service-grid article:hover,
.team-card:hover,
.attack-grid article:hover,
.experience-grid article:hover,
.partners-grid article:hover,
.brand-card:hover {
  transform:translateY(-3px);
  border-color:rgba(234,29,44,0.5);
  box-shadow:0 14px 30px rgba(0,0,0,0.3);
}

/* -- Grids -- */
.service-grid { display:grid;gap:16px;grid-template-columns:repeat(4,1fr); }
.attack-grid  { display:grid;gap:16px;grid-template-columns:repeat(4,1fr); }
.experience-grid { display:grid;gap:16px;grid-template-columns:repeat(3,1fr); }
.partners-grid { display:grid;gap:16px;grid-template-columns:repeat(2,1fr); }
.brand-grid { display:grid;gap:16px;grid-template-columns:repeat(2,1fr); }
.image-grid { display:grid;gap:14px;grid-template-columns:repeat(4,1fr); }
.cert-grid { display:grid;gap:16px;grid-template-columns:repeat(4,1fr); }
.leadership-grid { display:grid;gap:16px;grid-template-columns:repeat(2,1fr); }
.team-grid { display:grid;gap:16px;grid-template-columns:repeat(4,1fr); }
.team-cert-grid { grid-template-columns:repeat(3,minmax(0,1fr)); }
.steps { display:grid;gap:12px;grid-template-columns:repeat(4,1fr); }
.footer-grid { display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); }

/* article padding */
.service-grid article,.attack-grid article,.experience-grid article,.partners-grid article,.brand-card,.stats-grid article { padding:22px 20px; }
.steps div { padding:18px; }

/* service svc-num */
.svc-num { font-family:"Oxanium",sans-serif;font-size:2.6rem;font-weight:800;color:rgba(234,29,44,0.1);line-height:1;position:absolute;top:8px;right:12px;pointer-events:none;transition:color 0.3s; }
.service-grid article:hover .svc-num { color:rgba(234,29,44,0.2); }

.service-grid p,.attack-grid p,.stats-grid p,.steps p { margin:0;color:var(--brand-muted); }
.steps span { color:var(--brand-red-bright);font-weight:800;font-family:"Oxanium",sans-serif;display:inline-block;margin-bottom:8px;font-size:1.2rem; }

/* attack-grid top bar */
.attack-grid article::after { content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#ea1d2c,transparent);border-radius:10px 10px 0 0; }

/* -- Hero (index) -- */
.hero { margin-top:0;padding-top:28px;position:relative; }
.hero::before { content:"";position:absolute;inset:-20px;background:radial-gradient(circle at 80% 20%, rgba(234,29,44,0.12), transparent 38%),radial-gradient(circle at 10% 80%, rgba(234,29,44,0.07), transparent 40%);filter:blur(8px);z-index:-1; }
.hero-layout { display:grid;grid-template-columns:1fr 1.1fr;gap:18px;align-items:stretch;min-height:140px; }
.hero-copy {
  display:flex;flex-direction:column;justify-content:center;
  padding:10px 20px;border:1px solid rgba(234,29,44,0.2);border-radius:10px;
  background:
    linear-gradient(rgba(255,255,255,0.016) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.016) 1px, transparent 1px),
    linear-gradient(155deg, rgba(26,12,14,0.97) 0%, rgba(13,13,18,0.97) 100%);
  background-size:22px 22px,22px 22px,auto;
  clip-path:polygon(0 0, calc(100% - 16px) 0, 100% 16px, 100% 100%, 0 100%);
  position:relative;overflow:hidden;
}
.hero-copy::after { content:"";position:absolute;bottom:0;left:0;width:220px;height:220px;background:radial-gradient(circle at 0% 100%, rgba(234,29,44,0.14), transparent 70%);pointer-events:none; }
.hero-visual {
  position:relative;margin:0;border:1px solid rgba(255,255,255,0.1);border-radius:10px;
  overflow:hidden;background:#0c0c0e;box-shadow:0 16px 36px rgba(0,0,0,0.35);
  clip-path:polygon(0 0, calc(100% - 16px) 0, 100% 16px, 100% 100%, 16px 100%, 0 calc(100% - 16px));
}
.hero-visual img { width:100%;height:100%;min-height:120px;object-fit:contain;display:block; }
/* scanline */
.scanline::before { content:"";position:absolute;inset:0;background:linear-gradient(transparent 50%, rgba(0,0,0,0.14) 51%);background-size:100% 4px;pointer-events:none;z-index:2; }
/* scanning red line */
.hero-visual::after { content:"";position:absolute;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(234,29,44,0.85),transparent);animation:scan 5s linear infinite;z-index:3; }
@keyframes scan { 0%{top:0%;opacity:1}90%{opacity:0.8}100%{top:100%;opacity:0} }
/* HUD corners */
.hud-tl,.hud-tr,.hud-bl,.hud-br { position:absolute;width:16px;height:16px;z-index:4; }
.hud-tl { top:10px;left:10px;border-top:2px solid rgba(234,29,44,0.9);border-left:2px solid rgba(234,29,44,0.9); }
.hud-tr { top:10px;right:10px;border-top:2px solid rgba(234,29,44,0.9);border-right:2px solid rgba(234,29,44,0.9); }
.hud-bl { bottom:10px;left:10px;border-bottom:2px solid rgba(234,29,44,0.9);border-left:2px solid rgba(234,29,44,0.9); }
.hud-br { bottom:10px;right:10px;border-bottom:2px solid rgba(234,29,44,0.9);border-right:2px solid rgba(234,29,44,0.9); }
/* status badge */
.status-badge { display:inline-flex;align-items:center;gap:7px;background:rgba(234,29,44,0.08);border:1px solid rgba(234,29,44,0.28);border-radius:4px;padding:5px 12px;margin-bottom:18px;width:fit-content; }
.status-badge .dot { width:6px;height:6px;border-radius:50%;background:#ea1d2c;box-shadow:0 0 6px #ea1d2c;animation:blink 1.8s ease-in-out infinite; }
.status-badge span { font-size:0.72rem;font-family:"Oxanium",sans-serif;letter-spacing:0.14em;text-transform:uppercase;color:#ea1d2c; }
@keyframes blink { 0%,100%{opacity:1}50%{opacity:0.25} }
.hero-actions { display:flex;gap:12px;margin-top:16px;flex-wrap:wrap; }
/* hero stats */
.hero-stats { display:flex;gap:20px;margin-top:16px;flex-wrap:wrap;align-items:center; }
.hero-stat { display:flex;flex-direction:column; }
.hero-stat strong { font-family:"Oxanium",sans-serif;font-size:1.35rem;font-weight:700;color:#ea1d2c;line-height:1; }
.hero-stat small { font-size:0.73rem;color:var(--brand-muted);margin-top:3px; }
.hero-stat-divider { width:1px;background:rgba(255,255,255,0.1);align-self:stretch; }

/* -- Threat ticker -- */
.threat-ticker { background:rgba(194,15,31,0.06);border-top:1px solid rgba(234,29,44,0.15);border-bottom:1px solid rgba(234,29,44,0.15);padding:10px 0;overflow:hidden;margin-top:36px;position:relative; }
.threat-ticker::before,.threat-ticker::after { content:"LIVE INTEL";position:absolute;top:50%;transform:translateY(-50%);font-family:"Oxanium",sans-serif;font-size:0.62rem;font-weight:700;letter-spacing:0.15em;color:#ea1d2c;background:var(--brand-dark);padding:0 14px;z-index:2; }
.threat-ticker::before { left:0;border-right:1px solid rgba(234,29,44,0.25); }
.threat-ticker::after { right:0;border-left:1px solid rgba(234,29,44,0.25);content:"?"; }
.ticker-track { display:flex;animation:ticker 30s linear infinite;white-space:nowrap; }
.ticker-track span { display:inline-flex;align-items:center;gap:8px;padding:0 28px;font-size:0.78rem;color:var(--brand-muted); }
.ticker-track span::before { content:"//";color:rgba(234,29,44,0.55);font-family:"Oxanium",sans-serif;font-weight:700; }
@keyframes ticker { from{transform:translateX(0)}to{transform:translateX(-50%)} }

/* -- About banner (index) -- */
.about-banner { position:relative;border:1px solid rgba(234,29,44,0.2);border-radius:12px;overflow:hidden;background:linear-gradient(140deg, rgba(24,10,12,0.97) 0%, rgba(13,13,18,0.98) 65%);padding:36px 40px;display:grid;grid-template-columns:1fr auto;gap:32px;align-items:center; }
.about-banner::before { content:"";position:absolute;inset:0;background:radial-gradient(circle at 90% 50%, rgba(234,29,44,0.12), transparent 50%),linear-gradient(rgba(255,255,255,0.013) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,0.013) 1px, transparent 1px);background-size:auto,22px 22px,22px 22px;pointer-events:none; }
.about-award { display:flex;align-items:center;gap:14px;background:rgba(234,29,44,0.07);border:1px solid rgba(234,29,44,0.24);border-radius:10px;padding:18px 22px;white-space:nowrap; }
.about-award .trophy { font-size:2rem; }
.about-award p { margin:0;font-size:0.78rem;color:var(--brand-muted);line-height:1.55; }
.about-award strong { display:block;font-family:"Oxanium",sans-serif;font-size:0.85rem;color:#ea1d2c;margin-bottom:4px; }

/* -- Image grid -- */
.image-card { margin:0;border:1px solid var(--panel-border);border-radius:10px;overflow:hidden;background:#0c0c0f;position:relative; }
.image-card img { display:block;width:100%;height:220px;object-fit:cover;transition:transform 0.5s ease; }
.image-card:hover img { transform:scale(1.05); }
.image-card figcaption { position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent, rgba(0,0,0,0.78));padding:24px 12px 10px;font-size:0.78rem;color:rgba(255,255,255,0.85);opacity:0;transition:opacity 0.3s; }
.image-card:hover figcaption { opacity:1; }

/* -- CTA section -- */
.cta-section { margin-top:80px;position:relative;border:1px solid rgba(234,29,44,0.28);border-radius:14px;overflow:hidden;padding:60px 48px;text-align:center; }
.cta-section::before { content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% -10%, rgba(234,29,44,0.18), transparent 60%),radial-gradient(ellipse at 50% 110%, rgba(194,15,31,0.08), transparent 50%),linear-gradient(rgba(255,255,255,0.015) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,0.015) 1px, transparent 1px);background-size:auto,auto,22px 22px,22px 22px;pointer-events:none; }
.cta-section h2 { border-left:none;padding-left:0;text-align:center;font-size:clamp(1.7rem, 3.5vw, 2.6rem); }
.cta-section p { color:var(--brand-muted);max-width:720px;margin:0 auto 28px; }
.cta-btns { display:flex;gap:14px;justify-content:center;flex-wrap:wrap; }

/* -- Page hero (inner pages) -- */
.page-hero { margin-top:10px;padding:48px 44px;border:1px solid rgba(234,29,44,0.18);border-radius:12px;background:linear-gradient(155deg, rgba(22,10,12,0.97) 0%, rgba(12,12,16,0.97) 100%);position:relative;overflow:hidden;animation:rise 0.8s ease both; }
.page-hero::before { content:"";position:absolute;inset:0;background:radial-gradient(circle at 95% 10%, rgba(234,29,44,0.14), transparent 45%),linear-gradient(rgba(255,255,255,0.014) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,0.014) 1px, transparent 1px);background-size:auto,22px 22px,22px 22px;pointer-events:none; }
.page-hero::after { content:"";position:absolute;top:0;right:0;width:2px;height:100%;background:linear-gradient(to bottom, #ea1d2c, transparent);opacity:0.5; }

/* -- Service list / panel -- */
.service-list { margin:0;padding-left:20px;color:var(--brand-muted); }
.service-list li { margin:8px 0; }
.service-panel { border:1px solid var(--panel-border);border-radius:10px;background:linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px),linear-gradient(160deg, #191920 0%, var(--card-bg) 100%);background-size:20px 20px,20px 20px,auto;padding:24px; }

/* -- Teams -- */
.team-photo { width:100%;height:300px;object-fit:cover;border-radius:8px;margin-bottom:14px; }
.team-card { padding:20px;border-radius:10px; }
.role { color:var(--brand-red-bright);font-weight:600;font-size:0.85rem;margin-bottom:8px; }
.team-card p { margin:0;color:var(--brand-muted);font-size:0.92rem; }
.team-card h3 { font-size:1rem; }

/* -- Contact -- */
.contact-layout { display:grid;grid-template-columns:1.2fr 0.8fr;gap:18px; }
.contact-panel { padding:28px; }
.info-panel p { color:#ccccd8;margin:0 0 10px; }
form { display:grid;gap:10px; }
input,textarea,button { font-family:inherit;font-size:0.95rem; }
input,textarea { background:#0d0d12;border:1px solid rgba(255,255,255,0.12);color:var(--brand-light);border-radius:8px;padding:12px;width:100%;transition:border-color 0.2s,outline 0.2s; }
input:focus,textarea:focus { outline:2px solid rgba(234,29,44,0.4);border-color:var(--brand-red-bright); }
button { border:none;border-radius:8px;padding:13px 18px;background:var(--brand-red);color:#fff;font-weight:700;cursor:pointer;font-family:"Oxanium",sans-serif;letter-spacing:0.04em;clip-path:polygon(0 0, calc(100% - 7px) 0, 100% 7px, 100% 100%, 0 100%);transition:background 0.2s; }
button:hover { background:var(--brand-red-bright); }
.contact-image { margin:0 0 16px;border-radius:8px;overflow:hidden;border:1px solid var(--panel-border); }
.contact-image img { display:block;width:100%;height:200px;object-fit:cover; }

/* -- Partners -- */
.partners-grid article { display:flex;flex-direction:column; }
.partner-head {
  margin-bottom:14px;
  min-height:102px;
  display:flex;
  align-items:left;
  justify-content:left;
  text-align:center;
}
.partner-logo {
  display:block;
  margin:0 auto;
  width:auto;height:90px;max-width:260px;object-fit:contain;
  filter:drop-shadow(0 0 8px rgba(234,29,44,0.12));
}
.partners-list { margin:0;padding-left:20px;color:var(--brand-muted); }
.partners-list li { margin:8px 0; }

/* -- Certs -- */
.cert-card { margin:0;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,0.1);background:#0e0e14;box-shadow:0 10px 24px rgba(0,0,0,0.28); }
.cert-card img { width:100%;height:240px;object-fit:cover;display:block; }
.cert-card figcaption { padding:12px 14px;color:var(--brand-light);font-family:"Oxanium",sans-serif;font-size:0.88rem;border-top:1px solid rgba(255,255,255,0.08);background:linear-gradient(180deg,rgba(255,255,255,0.03),rgba(0,0,0,0.12)); }

/* -- Brand (ecosystem) -- */
.brand-icon { font-size:2rem;margin-bottom:14px;display:block; }
.brand-card h3 { font-size:1.1rem; }
.brand-card p { margin:4px 0 0;color:var(--brand-muted); }

/* -- Footer -- */
.site-footer { border-top:1px solid rgba(234,29,44,0.15);padding:36px 4% 24px;color:var(--brand-muted);font-size:0.9rem; }
footer { border-top:1px solid rgba(255,255,255,0.08);padding:24px 4%;color:var(--brand-muted);font-size:0.86rem; }
.footer-grid h3 { margin-top:0;color:var(--brand-light);font-size:0.95rem; }
.footer-grid p { margin:0 0 8px; }
.footer-grid a { color:var(--brand-muted);text-decoration:none;transition:color 0.2s; }
.footer-grid a:hover { color:var(--brand-light); }
.social-links {
  display: grid;
  gap: 10px;
  margin-top: 4px;
}
.social-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid rgba(234,29,44,0.2);
  border-radius: 10px;
  background:
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(160deg, rgba(22,22,30,0.96), rgba(10,10,15,0.96));
  background-size: 18px 18px, 18px 18px, auto;
  color: var(--brand-light) !important;
  font-weight: 600;
}
.social-link:hover,
.social-link:focus-visible {
  color: var(--brand-light) !important;
  border-color: rgba(234,29,44,0.38);
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(0,0,0,0.22);
}
.social-link-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(234,29,44,0.14);
  border: 1px solid rgba(234,29,44,0.24);
  color: var(--brand-light);
  font-family: "Oxanium", sans-serif;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.footer-cookie-link {
  padding: 0;
  border: 0;
  background: none;
  color: var(--brand-muted);
  font: inherit;
  cursor: pointer;
  transition: color 0.2s ease;
}
.footer-cookie-link:hover,
.footer-cookie-link:focus-visible {
  color: var(--brand-light);
}
.footer-copy { margin-top:20px;padding-top:18px;border-top:1px solid rgba(255,255,255,0.06);font-size:0.83rem;text-align:center; }

.cookie-banner {
  position: fixed;
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%) translateY(18px);
  width: calc(100vw - 24px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: end;
  padding: 18px 20px;
  border: 1px solid rgba(234,29,44,0.24);
  border-radius: 12px;
  background:
    linear-gradient(rgba(255,255,255,0.015) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.015) 1px, transparent 1px),
    linear-gradient(160deg, rgba(19,19,26,0.98) 0%, rgba(8,8,12,0.98) 100%);
  background-size: 20px 20px, 20px 20px, auto;
  box-shadow: 0 18px 48px rgba(0,0,0,0.45);
  backdrop-filter: blur(14px);
  opacity: 0;
  pointer-events: none;
  z-index: 10020;
  transition: opacity 0.22s ease, transform 0.22s ease;
}
.cookie-banner[hidden] {
  display: none !important;
}
.cookie-banner.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.cookie-banner-copy {
  display: grid;
  gap: 8px;
  grid-column: 1;
}
.cookie-banner-copy h3 {
  margin: 0;
  font-size: 1rem;
}
.cookie-banner-copy p {
  margin: 0;
  color: #cfcfda;
  line-height: 1.6;
}
.cookie-banner-actions {
  display: flex;
  flex-wrap: nowrap;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
  grid-column: 2;
}
.cookie-banner-actions .btn {
  min-width: 168px;
}
.cookie-banner-meta {
  grid-column: 1 / -1;
  color: var(--brand-muted);
  font-size: 0.82rem;
  line-height: 1.5;
}

/* -- Floating WhatsApp -- */
.whatsapp-float {
  position: fixed;
  right: 16px;
  bottom: 90px;
  z-index: 180;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: #25d366;
  color: #ffffff;
  text-decoration: none;
  font-family: "Oxanium", sans-serif;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(255, 255, 255, 0.25);
  transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}
.whatsapp-float:hover {
  transform: translateY(-2px) scale(1.03);
  box-shadow: 0 14px 32px rgba(0, 0, 0, 0.4);
  filter: brightness(1.05);
}
.whatsapp-float svg {
  width: 30px;
  height: 30px;
  display: block;
}

/* -- Floating Scope CTA -- */
.floating-scope-cta {
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  bottom: 16px;
  z-index: 170;
  width: var(--site-centered-panel-width);
  border: 1px solid rgba(234,29,44,0.4);
  border-radius: 12px;
  background: linear-gradient(140deg, rgba(23,23,29,0.96), rgba(14,14,19,0.96));
  box-shadow: 0 14px 36px rgba(0,0,0,0.35);
  backdrop-filter: blur(7px);
  padding: 10px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.floating-scope-cta p {
  margin: 0;
  color: var(--brand-muted);
  font-size: 0.88rem;
}
.floating-scope-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.floating-scope-actions .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
}


/* -- Hero image (fill section) -- */
.hero-visual {
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(circle at 50% 30%, rgba(234,29,44,0.22), transparent 28%),
    radial-gradient(circle at 82% 20%, rgba(114,220,255,0.12), transparent 24%),
    linear-gradient(160deg, #09090c 0%, #11131a 46%, #07070b 100%);
  min-height: clamp(240px, 26vw, 380px);
  padding: 14px;
  isolation: isolate;
}
.hero-visual img {
  display: block;
  object-position: center;
}
.hero-grid-overlay,
.hero-radar,
.hero-codefall,
.hero-orbit,
.hero-ping,
.hero-chip,
.hero-avatar-shell,
.hero-avatar-ghost,
.hero-avatar {
  pointer-events: none;
}
.hero-grid-overlay {
  position: absolute;
  inset: 6% 5%;
  z-index: 0;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  background-image:
    linear-gradient(rgba(234,29,44,0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(234,29,44,0.08) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.035) 1px, transparent 1px);
  background-size: 54px 54px, 54px 54px, 18px 18px, 18px 18px;
  mask-image: radial-gradient(circle at center, black 52%, transparent 92%);
  opacity: 0.58;
  animation: heroGridDrift 15s linear infinite;
}
.hero-radar {
  position: absolute;
  right: 4%;
  top: 50%;
  width: min(38vw, 560px);
  aspect-ratio: 1;
  z-index: 1;
  transform: translateY(-50%);
  mix-blend-mode: screen;
  opacity: 0.7;
}
.hero-radar-ring,
.hero-radar-sweep,
.hero-radar-core {
  position: absolute;
  inset: 0;
  border-radius: 50%;
}
.hero-radar-ring {
  border: 1px solid rgba(114,220,255,0.16);
  box-shadow: inset 0 0 30px rgba(114,220,255,0.04);
}
.hero-radar-ring::before,
.hero-radar-ring::after {
  content: "";
  position: absolute;
  background: rgba(114,220,255,0.22);
}
.hero-radar-ring::before {
  left: 50%;
  top: 8%;
  bottom: 8%;
  width: 1px;
  transform: translateX(-50%);
}
.hero-radar-ring::after {
  top: 50%;
  left: 8%;
  right: 8%;
  height: 1px;
  transform: translateY(-50%);
}
.hero-radar-ring-one { inset: 0; }
.hero-radar-ring-two { inset: 16%; animation: orbitPulse 7s ease-in-out infinite; }
.hero-radar-ring-three { inset: 32%; animation: orbitPulse 5.5s ease-in-out infinite reverse; }
.hero-radar-sweep {
  inset: 4%;
  background: conic-gradient(from 0deg, rgba(114,220,255,0.42), rgba(114,220,255,0.06) 18%, transparent 32%, transparent 100%);
  filter: blur(2px);
  animation: radarSweep 4.5s linear infinite;
}
.hero-radar-core {
  inset: 48%;
  background: radial-gradient(circle, rgba(255,255,255,0.95) 0%, rgba(114,220,255,0.88) 42%, rgba(114,220,255,0.12) 100%);
  box-shadow: 0 0 18px rgba(114,220,255,0.4);
}
.hero-codefall {
  position: absolute;
  top: 9%;
  bottom: 9%;
  width: min(17vw, 220px);
  z-index: 3;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 14px;
  opacity: 0.92;
  mask-image: linear-gradient(transparent, black 14%, black 86%, transparent);
}
.hero-codefall-left {
  left: 2%;
  transform: rotate(-6deg);
}
.hero-codefall-right {
  right: 2%;
  transform: rotate(6deg);
}
.hero-codefall span {
  display: inline-flex;
  width: fit-content;
  max-width: 100%;
  padding: 7px 10px;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  background: linear-gradient(145deg, rgba(9,14,19,0.82), rgba(15,16,23,0.52));
  color: rgba(114,220,255,0.76);
  font-family: "Oxanium", sans-serif;
  font-size: 0.62rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  white-space: nowrap;
  text-shadow: 0 0 16px rgba(114,220,255,0.18);
  box-shadow: 0 14px 28px rgba(0,0,0,0.18);
  animation: codeRainFlow 9s linear infinite;
}
.hero-codefall-left span { align-self: flex-start; }
.hero-codefall-right span {
  align-self: flex-end;
  color: rgba(234,29,44,0.72);
  text-shadow: 0 0 16px rgba(234,29,44,0.18);
}
.hero-codefall span:nth-child(1) { animation-delay: -1.2s; }
.hero-codefall span:nth-child(2) { animation-delay: -3.4s; }
.hero-codefall span:nth-child(3) { animation-delay: -5.2s; }
.hero-codefall span:nth-child(4) { animation-delay: -2.1s; }
.hero-codefall span:nth-child(5) { animation-delay: -6.4s; }
.hero-orbit {
  position: absolute;
  z-index: 1;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow: inset 0 0 40px rgba(255,255,255,0.02);
}
.hero-orbit::before {
  content: "";
  position: absolute;
  inset: 12%;
  border-radius: 50%;
  border: 1px dashed rgba(255,255,255,0.12);
}
.hero-orbit-one {
  top: 8%;
  right: 2%;
  width: min(30vw, 460px);
  aspect-ratio: 1;
  border-color: rgba(234,29,44,0.24);
  animation: orbitSpin 18s linear infinite;
}
.hero-orbit-two {
  left: 5%;
  bottom: 10%;
  width: min(22vw, 320px);
  aspect-ratio: 1;
  border-color: rgba(114,220,255,0.2);
  animation: orbitSpinReverse 13s linear infinite;
}
.hero-ping {
  position: absolute;
  z-index: 2;
  width: 12px;
  height: 12px;
  border-radius: 50%;
}
.hero-ping::after {
  content: "";
  position: absolute;
  inset: -13px;
  border-radius: 50%;
  border: 1px solid currentColor;
  animation: heroPingPulse 2.8s ease-out infinite;
}
.hero-ping-one {
  top: 18%;
  right: 18%;
  color: #72dcff;
  background: #72dcff;
  box-shadow: 0 0 0 8px rgba(114,220,255,0.08), 0 0 18px rgba(114,220,255,0.48);
  animation: pingFloat 5s ease-in-out infinite;
}
.hero-ping-two {
  left: 15%;
  bottom: 24%;
  color: #ea1d2c;
  background: #ea1d2c;
  box-shadow: 0 0 0 8px rgba(234,29,44,0.08), 0 0 18px rgba(234,29,44,0.48);
  animation: pingFloat 4.2s ease-in-out infinite reverse;
}
.hero-chip {
  position: absolute;
  z-index: 4;
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 10px;
  background: linear-gradient(145deg, rgba(12,12,17,0.88), rgba(18,20,28,0.75));
  box-shadow: 0 14px 30px rgba(0,0,0,0.32);
  backdrop-filter: blur(10px);
  clip-path: polygon(0 0, calc(100% - 12px) 0, 100% 12px, 100% 100%, 0 100%);
  animation: chipFloat 6s ease-in-out infinite;
}
.hero-chip span {
  font-family: "Oxanium", sans-serif;
  font-size: 0.62rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.62);
}
.hero-chip strong {
  font-family: "Oxanium", sans-serif;
  font-size: 0.98rem;
  letter-spacing: 0.08em;
  color: #ffffff;
  text-shadow: 0 0 18px rgba(234,29,44,0.18);
}
.hero-chip-top {
  top: 18px;
  left: 18px;
}
.hero-chip-bottom {
  right: 18px;
  bottom: 24px;
  animation-delay: -3s;
}
.hero-avatar-shell {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(82%, 680px);
  aspect-ratio: 0.92;
  z-index: 1;
  transform: translate(-50%, -50%);
  clip-path: polygon(26% 8%, 74% 8%, 92% 28%, 88% 76%, 50% 98%, 12% 76%, 8% 28%);
  background:
    radial-gradient(circle at 50% 38%, rgba(114,220,255,0.18), transparent 30%),
    radial-gradient(circle at 50% 62%, rgba(234,29,44,0.2), transparent 46%),
    linear-gradient(180deg, rgba(114,220,255,0.08), rgba(234,29,44,0.06));
  filter: blur(10px);
  mix-blend-mode: screen;
  opacity: 0.95;
  animation: avatarShellPulse 5.8s ease-in-out infinite;
}
.hero-avatar-shell::before,
.hero-avatar-shell::after {
  content: "";
  position: absolute;
  inset: 10%;
  clip-path: inherit;
}
.hero-avatar-shell::before {
  border: 1px solid rgba(114,220,255,0.22);
  box-shadow: 0 0 24px rgba(114,220,255,0.12);
}
.hero-avatar-shell::after {
  inset: 18%;
  border: 1px solid rgba(234,29,44,0.18);
}
.hero-visual .hero-avatar-ghost,
.hero-visual .hero-avatar {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(88%, 760px);
  height: auto;
  min-height: 0;
  display: block;
  object-fit: contain;
  transform: translate(-50%, -50%);
}
.hero-visual .hero-avatar-ghost {
  z-index: 2;
  opacity: 0.38;
  filter: blur(18px) saturate(1.4) brightness(1.12);
  mix-blend-mode: screen;
  transform: translate(calc(-50% + 18px), calc(-50% + 14px)) scale(1.07);
  animation: avatarGhostFloat 7s ease-in-out infinite;
}
.hero-visual .hero-avatar {
  z-index: 3;
  filter:
    drop-shadow(0 22px 40px rgba(0,0,0,0.5))
    drop-shadow(0 0 24px rgba(114,220,255,0.14))
    drop-shadow(0 0 28px rgba(234,29,44,0.18))
    saturate(1.08)
    contrast(1.06);
  animation: avatarFloat 6.5s ease-in-out infinite, avatarFlicker 8s steps(1) infinite;
}
@keyframes heroGridDrift {
  from { transform: translate3d(0, 0, 0); }
  to { transform: translate3d(-24px, 24px, 0); }
}
@keyframes orbitPulse {
  0%, 100% { opacity: 0.62; transform: scale(1); }
  50% { opacity: 0.92; transform: scale(1.03); }
}
@keyframes orbitSpin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}
@keyframes orbitSpinReverse {
  from { transform: rotate(360deg); }
  to { transform: rotate(0deg); }
}
@keyframes radarSweep {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}
@keyframes codeRainFlow {
  0% {
    opacity: 0;
    transform: translate3d(0, -26px, 0);
  }
  12% {
    opacity: 1;
  }
  50% {
    opacity: 0.92;
  }
  100% {
    opacity: 0;
    transform: translate3d(0, 34px, 0);
  }
}
@keyframes heroPingPulse {
  0% { opacity: 0.75; transform: scale(0.45); }
  70% { opacity: 0; transform: scale(1.25); }
  100% { opacity: 0; transform: scale(1.35); }
}
@keyframes pingFloat {
  0%, 100% { transform: translate3d(0, 0, 0); }
  50% { transform: translate3d(0, -12px, 0); }
}
@keyframes chipFloat {
  0%, 100% { transform: translate3d(0, 0, 0); }
  50% { transform: translate3d(0, -8px, 0); }
}
@keyframes avatarShellPulse {
  0%, 100% {
    opacity: 0.82;
    transform: translate(-50%, -50%) scale(0.98);
  }
  50% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.035);
  }
}
@keyframes avatarFloat {
  0%, 100% {
    transform: translate(-50%, -50%) translate3d(0, 0, 0) scale(1);
  }
  50% {
    transform: translate(-50%, -50%) translate3d(0, -14px, 0) scale(1.025);
  }
}
@keyframes avatarGhostFloat {
  0%, 100% {
    transform: translate(calc(-50% + 18px), calc(-50% + 14px)) scale(1.07);
  }
  50% {
    transform: translate(calc(-50% + 26px), calc(-50% + 6px)) scale(1.1);
  }
}
@keyframes avatarFlicker {
  0%, 16%, 18%, 74%, 100% {
    filter:
      drop-shadow(0 22px 40px rgba(0,0,0,0.5))
      drop-shadow(0 0 24px rgba(114,220,255,0.14))
      drop-shadow(0 0 28px rgba(234,29,44,0.18))
      saturate(1.08)
      contrast(1.06);
  }
  17%, 75% {
    filter:
      drop-shadow(0 22px 40px rgba(0,0,0,0.52))
      drop-shadow(3px 0 16px rgba(114,220,255,0.16))
      drop-shadow(-3px 0 16px rgba(234,29,44,0.18))
      saturate(1.14)
      contrast(1.12);
  }
}
@media (prefers-reduced-motion: reduce) {
  .hero-copy > .status-badge,
  .hero-copy > .hero-tagline,
  .hero-copy > .hero-title,
  .hero-copy > .hero-subcopy,
  .hero-copy > .hero-actions,
  .hero-copy > .hero-stats,
  .hero-tagline span,
  .hero-title-line,
  .hero-scroll-cue,
  .hero-scroll-mouse::before,
  .hero-grid-overlay,
  .hero-radar-ring-two,
  .hero-radar-ring-three,
  .hero-radar-sweep,
  .hero-codefall span,
  .hero-orbit-one,
  .hero-orbit-two,
  .hero-ping-one,
  .hero-ping-two,
  .hero-chip,
  .hero-avatar-shell,
  .hero-avatar-ghost,
  .hero-avatar {
    animation: none !important;
  }
  .hero-copy > .status-badge,
  .hero-copy > .hero-tagline,
  .hero-copy > .hero-title,
  .hero-copy > .hero-subcopy,
  .hero-copy > .hero-actions,
  .hero-copy > .hero-stats,
  .hero-tagline span,
  .hero-title-line,
  .hero-scroll-cue {
    opacity: 1 !important;
    transform: none !important;
  }
}

/* -- Animations -- */
@keyframes rise { from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)} }

/* -- Responsive -- */
@media (max-width:1024px) {
  .service-grid,.attack-grid { grid-template-columns:repeat(2,1fr); }
  .image-grid,.cert-grid { grid-template-columns:repeat(2,1fr); }
  .team-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:991.98px) {
  .site-header.navbar {
    padding: 12px 14px;
    flex-wrap: wrap;
  }
  .nav-toggle {
    display: inline-flex;
  }
  .js .site-nav-shell.nav-ready {
    display: none;
  }
  .js .site-nav-shell.nav-ready.is-open {
    display: flex;
  }
  .site-nav-shell {
    width: 100%;
    margin-top: 10px;
    padding-top: 12px;
    border-top: 1px solid rgba(255,255,255,0.08);
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }
  .main-nav {
    width: 100%;
    margin-inline: 0 !important;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .main-nav .nav-link {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 8px;
    background: rgba(255,255,255,0.02);
  }
  .main-nav .nav-link:hover,
  .main-nav .nav-link.active {
    border-bottom-color: transparent;
    border-color: rgba(234,29,44,0.34);
    background: rgba(234,29,44,0.08);
  }
  .site-nav-shell .cta-small {
    width: 100%;
    text-align: center;
    padding: 10px 14px;
  }
}
@media (min-width:992px) {
  .nav-toggle {
    display: none;
  }
  .site-nav-shell {
    display: flex !important;
  }
}
@media (max-width:768px) {
  .hero-layout { grid-template-columns:1fr; }
  .about-banner { grid-template-columns:1fr; }
  .about-award { white-space:normal; }
  .contact-layout { grid-template-columns:1fr; }
  .steps { grid-template-columns:repeat(2,1fr); }
  .cta-section { padding:36px 22px; }
  .page-hero { padding:32px 24px; }
  .whatsapp-float {
    right: 12px;
    bottom: 84px;
    width: 54px;
    height: 54px;
    font-size: 0.64rem;
  }
  .whatsapp-float svg {
    width: 27px;
    height: 27px;
  }
  .floating-scope-cta {
    width: calc(100% - 16px);
    left: 8px;
    transform: none;
    bottom: 8px;
    padding: 10px;
    flex-direction: column;
    align-items: flex-start;
  }
  .floating-scope-cta p { font-size: 0.82rem; }
  .floating-scope-actions { width: 100%; }
  .floating-scope-actions .btn { flex: 1 1 auto; }
  .cookie-banner {
    bottom: 10px;
    width: calc(100vw - 12px);
    grid-template-columns: 1fr;
    align-items: stretch;
    padding: 16px 14px;
  }
  .cookie-banner-actions {
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    grid-column: 1;
  }
  .cookie-banner-actions .btn {
    width: 100%;
    min-width: 0;
  }
  .cookie-banner-copy,
  .cookie-banner-meta {
    grid-column: 1;
  }
}
@media (max-width:520px) {
  .service-grid,.attack-grid,.image-grid,.cert-grid,.brand-grid,.partners-grid,.experience-grid,.team-grid,.leadership-grid,.steps { grid-template-columns:1fr; }
  .hero-stats { gap:14px; }
}
/* ================================================================
   Page-Specific Sections Moved From Inline Styles
   ================================================================ */

/* ================================================================
   Home Page CSS {}
   ================================================================ */
/* ===== REDESIGN LAYER - fonts/sizes untouched ===== */

    /* Noise texture overlay */
    body::after {
      content: "";
      position: fixed;
      inset: 0;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
      pointer-events: none;
      z-index: 9999;
      opacity: 0.4;
    }

    /* -- Animated grid -- */
    .bg-grid {
      background-image:
        linear-gradient(rgba(234,29,44,0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(234,29,44,0.06) 1px, transparent 1px),
        linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
      background-size: 96px 96px, 96px 96px, 24px 24px, 24px 24px;
      mask-image: radial-gradient(ellipse at 50% 20%, black 10%, transparent 75%);
      animation: gridPulse 8s ease-in-out infinite;
    }
    @keyframes gridPulse {
      0%,100% { opacity: 1; }
      50% { opacity: 0.6; }
    }

    /* -- Navbar tweaks -- */
    .site-header {
      margin: 18px auto;
      border-color: rgba(234,29,44,0.18);
      background: linear-gradient(145deg, rgba(15,15,20,0.94), rgba(8,8,12,0.9));
    }

    /* -- HERO -- */
    .hero {
      margin-top: 8px;
      padding-top: 6px;
      padding-bottom: 8px;
      min-height: auto;
      display: flex;
      align-items: stretch;
    }

    .hero-layout {
      grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
      gap: 18px;
      align-items: stretch;
      min-height: clamp(430px, calc(100svh - 245px), 560px);
      width: 100%;
    }

    .hero-copy {
      display: flex;
      flex-direction: column;
      justify-content: center;
      padding: 20px 24px 18px;
      border-color: rgba(234,29,44,0.22);
      background:
        linear-gradient(rgba(255,255,255,0.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px),
        linear-gradient(150deg, rgba(28,16,18,0.98) 0%, rgba(15,15,17,0.96) 100%);
      background-size: 22px 22px, 22px 22px, auto;
      position: relative;
      overflow: hidden;
    }
    .hero-copy > .status-badge,
    .hero-copy > .hero-tagline,
    .hero-copy > .hero-title,
    .hero-copy > .hero-subcopy,
    .hero-copy > .hero-actions,
    .hero-copy > .hero-stats {
      opacity: 0;
      transform: translate3d(0, 24px, 0);
      animation: heroIntroUp 0.8s cubic-bezier(0.2, 0.9, 0.2, 1) forwards;
    }
    .hero-copy > .status-badge { animation-delay: 0.12s; }
    .hero-copy > .hero-tagline { animation-delay: 0.24s; }
    .hero-copy > .hero-title { animation-delay: 0.34s; }
    .hero-copy > .hero-subcopy { animation-delay: 0.52s; }
    .hero-copy > .hero-actions { animation-delay: 0.68s; }
    .hero-copy > .hero-stats { animation-delay: 0.86s; }

    /* Red corner accent */
    .hero-copy::after {
      content: "";
      position: absolute;
      bottom: 0; left: 0;
      width: 200px; height: 200px;
      background: radial-gradient(circle at 0% 100%, rgba(234,29,44,0.18), transparent 70%);
      pointer-events: none;
    }

    /* Animated scanning line on hero visual */
    .hero-visual::before {
      content: "";
      position: absolute;
      left: 0; right: 0;
      height: 2px;
      background: linear-gradient(90deg, transparent, rgba(234,29,44,0.8), transparent);
      animation: scan 4s linear infinite;
      z-index: 3;
    }
    @keyframes scan {
      0% { top: 0%; opacity: 1; }
      90% { opacity: 1; }
      100% { top: 100%; opacity: 0; }
    }

    /* HUD corner marks on hero visual */
    .hero-visual .hud-tl,
    .hero-visual .hud-tr,
    .hero-visual .hud-bl,
    .hero-visual .hud-br {
      position: absolute;
      width: 18px; height: 18px;
      z-index: 4;
    }
    .hero-visual .hud-tl { top: 10px; left: 10px; border-top: 2px solid rgba(234,29,44,0.9); border-left: 2px solid rgba(234,29,44,0.9); }
    .hero-visual .hud-tr { top: 10px; right: 10px; border-top: 2px solid rgba(234,29,44,0.9); border-right: 2px solid rgba(234,29,44,0.9); }
    .hero-visual .hud-bl { bottom: 10px; left: 10px; border-bottom: 2px solid rgba(234,29,44,0.9); border-left: 2px solid rgba(234,29,44,0.9); }
    .hero-visual .hud-br { bottom: 10px; right: 10px; border-bottom: 2px solid rgba(234,29,44,0.9); border-right: 2px solid rgba(234,29,44,0.9); }

    /* Status badge in hero */
    .status-badge {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      background: rgba(234,29,44,0.1);
      border: 1px solid rgba(234,29,44,0.3);
      border-radius: 4px;
      padding: 5px 12px;
      margin-bottom: 18px;
      width: fit-content;
    }
    .status-badge .dot {
      width: 6px; height: 6px;
      border-radius: 50%;
      background: #ea1d2c;
      box-shadow: 0 0 6px #ea1d2c;
      animation: blink 1.8s ease-in-out infinite;
    }
    .status-badge span {
      font-size: 0.75rem;
      font-family: "Oxanium", sans-serif;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: #ea1d2c;
    }
    @keyframes blink {
      0%,100% { opacity: 1; }
      50% { opacity: 0.3; }
    }

    .hero h1 {
      font-size: clamp(2.20rem, 3.8vw, 3.0rem);
      line-height: 1.04;
      margin: 8px 0 10px;
      max-width: 17ch;
    }
    .hero-tagline {
      margin: 0;
      overflow: hidden;
    }
    .hero-tagline span {
      display: inline-block;
      clip-path: inset(0 100% 0 0);
      animation: heroTaglineReveal 1s cubic-bezier(0.18, 0.9, 0.2, 1) 0.26s forwards;
    }
    .hero-title {
      display: grid;
      gap: 2px;
    }
    .hero-title-line {
      display: block;
      opacity: 0;
      transform: translate3d(0, 110%, 0);
      animation: heroTitleLineIn 0.95s cubic-bezier(0.2, 0.9, 0.2, 1) forwards;
    }
    .hero-title-line:nth-child(1) { animation-delay: 0.38s; }
    .hero-title-line:nth-child(2) { animation-delay: 0.5s; }
    .hero-title-line:nth-child(3) { animation-delay: 0.62s; }
    .hero-subcopy {
      max-width: 42ch;
      margin-top: 0;
    }

    .hero-actions { margin-top: 10px; flex-wrap: wrap; }

    /* Stat pills below CTA */
    .hero-stats {
      display: flex;
      gap: 16px;
      margin-top: 10px;
      flex-wrap: wrap;
    }
    .hero-stat {
      display: flex;
      flex-direction: column;
    }
    .hero-stat strong {
      font-family: "Oxanium", sans-serif;
      font-size: 1.35rem;
      font-weight: 700;
      color: #ea1d2c;
      line-height: 1;
    }
    .hero-stat small {
      font-size: 0.75rem;
      color: var(--brand-muted);
      margin-top: 3px;
    }
    .hero-stat-divider {
      width: 1px;
      background: rgba(255,255,255,0.1);
      align-self: stretch;
    }
    .hero-scroll-cue {
      position: absolute;
      left: 50%;
      bottom: 2px;
      z-index: 6;
      display: inline-flex;
      flex-direction: column;
      align-items: center;
      gap: 8px;
      transform: translateX(-50%);
      opacity: 0;
      animation: heroScrollCueIn 0.9s ease 1.15s forwards;
    }
    .hero-scroll-cue small {
      font-family: "Oxanium", sans-serif;
      font-size: 0.62rem;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: rgba(255,255,255,0.55);
    }
    .hero-scroll-mouse {
      position: relative;
      width: 28px;
      height: 46px;
      border-radius: 18px;
      border: 1px solid rgba(255,255,255,0.24);
      background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.01));
      box-shadow: 0 0 22px rgba(234,29,44,0.08);
    }
    .hero-scroll-mouse::before {
      content: "";
      position: absolute;
      left: 50%;
      top: 9px;
      width: 5px;
      height: 9px;
      border-radius: 999px;
      background: rgba(234,29,44,0.95);
      box-shadow: 0 0 10px rgba(234,29,44,0.4);
      transform: translateX(-50%);
      animation: scrollWheel 1.8s ease-in-out infinite;
    }
    @keyframes heroIntroUp {
      from {
        opacity: 0;
        transform: translate3d(0, 24px, 0);
      }
      to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
      }
    }
    @keyframes heroTaglineReveal {
      from { clip-path: inset(0 100% 0 0); }
      to { clip-path: inset(0 0 0 0); }
    }
    @keyframes heroTitleLineIn {
      from {
        opacity: 0;
        transform: translate3d(0, 110%, 0);
      }
      to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
      }
    }
    @keyframes heroScrollCueIn {
      from {
        opacity: 0;
        transform: translate(-50%, 12px);
      }
      to {
        opacity: 1;
        transform: translate(-50%, 0);
      }
    }
    @keyframes scrollWheel {
      0%, 100% {
        opacity: 0.45;
        transform: translate(-50%, 0);
      }
      50% {
        opacity: 1;
        transform: translate(-50%, 10px);
      }
    }

    /* -- THREAT TICKER -- */
    .threat-ticker {
      background: rgba(194,15,31,0.07);
      border-top: 1px solid rgba(234,29,44,0.18);
      border-bottom: 1px solid rgba(234,29,44,0.18);
      padding: 10px 0;
      overflow: hidden;
      margin-top: 40px;
      position: relative;
    }
    .threat-ticker::before,
    .threat-ticker::after {
      content: "LIVE THREAT INTEL";
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      font-family: "Oxanium", sans-serif;
      font-size: 0.65rem;
      font-weight: 700;
      letter-spacing: 0.15em;
      color: #ea1d2c;
      background: var(--brand-dark);
      padding: 0 14px;
      z-index: 2;
    }
    .threat-ticker::before { left: 0; border-right: 1px solid rgba(234,29,44,0.3); }
    .threat-ticker::after { right: 0; border-left: 1px solid rgba(234,29,44,0.3); content: "\25B6"; font-size: 0.7rem; }
    .ticker-track {
      display: flex;
      gap: 0;
      animation: ticker 28s linear infinite;
      white-space: nowrap;
    }
    .ticker-track span {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 0 28px;
      font-size: 0.8rem;
      color: var(--brand-muted);
    }
    .ticker-track span::before {
      content: "//";
      color: rgba(234,29,44,0.6);
      font-family: "Oxanium", sans-serif;
      font-weight: 700;
    }
    @keyframes ticker {
      from { transform: translateX(0); }
      to { transform: translateX(-50%); }
    }

    /* -- SERVICES -- */
    .service-grid {
      grid-template-columns: repeat(4, 1fr);
    }
    .service-grid article {
      padding: 22px 20px;
      position: relative;
      overflow: hidden;
    }
    /* Number accent */
    .service-grid article .svc-num {
      font-family: "Oxanium", sans-serif;
      font-size: 2.8rem;
      font-weight: 800;
      color: rgba(234,29,44,0.12);
      line-height: 1;
      position: absolute;
      top: 8px; right: 12px;
      pointer-events: none;
      transition: color 0.3s ease;
    }
    .service-grid article:hover .svc-num {
      color: rgba(234,29,44,0.22);
    }

    /* -- ABOUT BANNER -- */
    .about-banner {
      position: relative;
      border: 1px solid rgba(234,29,44,0.22);
      border-radius: 12px;
      overflow: hidden;
      background: linear-gradient(135deg, rgba(28,10,12,0.95) 0%, rgba(14,14,18,0.98) 60%);
      padding: 36px 40px;
      display: grid;
      grid-template-columns: 1fr auto;
      gap: 32px;
      align-items: center;
    }
    .about-banner::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 95% 50%, rgba(234,29,44,0.14), transparent 50%),
        linear-gradient(rgba(255,255,255,0.015) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.015) 1px, transparent 1px);
      background-size: auto, 22px 22px, 22px 22px;
      pointer-events: none;
    }
    .about-award {
      display: flex;
      align-items: center;
      gap: 14px;
      background: rgba(234,29,44,0.08);
      border: 1px solid rgba(234,29,44,0.25);
      border-radius: 10px;
      padding: 18px 22px;
      white-space: nowrap;
    }
    .about-award .trophy {
      font-size: 2rem;
    }
    .about-award p {
      margin: 0;
      font-size: 0.78rem;
      color: var(--brand-muted);
      line-height: 1.5;
    }
    .about-award strong {
      display: block;
      font-family: "Oxanium", sans-serif;
      font-size: 0.85rem;
      color: #ea1d2c;
      margin-bottom: 4px;
    }

    /* -- ECOSYSTEM -- */
    .brand-grid {
      grid-template-columns: repeat(2, 1fr);
    }
    .brand-card {
      padding: 28px;
      position: relative;
    }
    .brand-card h3 {
      font-size: 1.15rem;
      margin-bottom: 10px;
    }
    .brand-card .brand-icon {
      font-size: 2rem;
      margin-bottom: 14px;
      display: block;
    }

    /* -- IMAGE GRID (CyberZim) -- */
    .image-grid {
      grid-template-columns: repeat(4, 1fr);
    }
    .image-card img {
      height: 220px;
    }
    .image-card {
      position: relative;
      overflow: hidden;
    }
    .image-card figcaption {
      position: absolute;
      bottom: 0; left: 0; right: 0;
      background: linear-gradient(transparent, rgba(0,0,0,0.75));
      padding: 20px 12px 10px;
      font-size: 0.78rem;
      color: rgba(255,255,255,0.8);
      opacity: 0;
      transition: opacity 0.3s ease;
    }
    .image-card:hover figcaption { opacity: 1; }
    .image-card:hover img { transform: scale(1.04); transition: transform 0.5s ease; }

    .news-grid {
      display: grid;
      gap: 16px;
      grid-template-columns: repeat(2, 1fr);
    }
    .news-card {
      border: 1px solid var(--panel-border);
      border-radius: 12px;
      padding: 24px 22px;
      background:
        linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px),
        linear-gradient(160deg, #191920 0%, var(--card-bg) 100%);
      background-size: 20px 20px, 20px 20px, auto;
      position: relative;
      overflow: hidden;
    }
    .news-card::before {
      content: "";
      position: absolute;
      top: 0;
      right: 0;
      width: 42px;
      height: 42px;
      background: linear-gradient(135deg, rgba(234,29,44,0.16), transparent 65%);
    }
    .news-card h3 {
      margin: 0 0 10px;
      font-size: 1rem;
    }
    .news-card p {
      margin: 0;
      color: #cbccda;
      line-height: 1.6;
    }
    .news-source {
      margin: 0 0 10px !important;
      color: rgba(234,29,44,0.78) !important;
      font-family: "Oxanium", sans-serif;
      font-size: 0.76rem;
      letter-spacing: 0.08em;
      text-transform: uppercase;
    }
    .news-grid-compact .news-card {
      padding: 22px 20px;
    }

    /* -- WHY CHOOSE US -- */
    .attack-grid {
      grid-template-columns: repeat(4, 1fr);
    }
    .attack-grid article {
      padding: 24px 20px;
      position: relative;
    }
    /* top colored bar */
    .attack-grid article::after {
      content: "";
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 2px;
      background: linear-gradient(90deg, #ea1d2c, transparent);
      border-radius: 10px 10px 0 0;
    }

    /* -- EXPERIENCE -- */
    .experience-grid {
      grid-template-columns: repeat(3, 1fr);
    }
    .experience-grid article {
      padding: 24px;
    }
    .experience-grid h3 {
      font-size: 1rem;
    }

    /* -- PARTNERS -- */
    .partners-grid {
      grid-template-columns: repeat(2, 1fr);
    }

    /* -- CERTS -- */
    .cert-grid {
      grid-template-columns: repeat(4, 1fr);
    }

    /* -- CTA SECTION -- */
    .cta-section {
      margin-top: 80px;
      position: relative;
      border: 1px solid rgba(234,29,44,0.3);
      border-radius: 14px;
      overflow: hidden;
      padding: 56px 48px;
      text-align: center;
    }
    .cta-section::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(ellipse at 50% 0%, rgba(234,29,44,0.2), transparent 60%),
        radial-gradient(ellipse at 50% 100%, rgba(194,15,31,0.1), transparent 50%),
        linear-gradient(rgba(255,255,255,0.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px);
      background-size: auto, auto, 22px 22px, 22px 22px;
      pointer-events: none;
    }
    .cta-section h2 {
      border-left: none;
      padding-left: 0;
      text-align: center;
      font-size: clamp(1.7rem, 3.5vw, 2.6rem);
    }
    .cta-section p {
      color: var(--brand-muted);
      max-width: 560px;
      margin: 0 auto 28px;
    }
    .cta-section .cta-btns {
      display: flex;
      gap: 14px;
      justify-content: center;
      flex-wrap: wrap;
    }

    /* -- FOOTER -- */
    .site-footer {
      width: var(--site-shell-width);
      margin: 0 auto;
      border-radius: 12px 12px 0 0;
      border-top: 1px solid rgba(234,29,44,0.2);
      border-left: 1px solid rgba(255,255,255,0.05);
      border-right: 1px solid rgba(255,255,255,0.05);
      background: rgba(8,8,11,0.6);
      padding: 36px 32px 24px;
    }

    /* -- Section intro labels -- */
    .section-label {
      font-family: "Oxanium", sans-serif;
      font-size: 0.7rem;
      font-weight: 700;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: rgba(234,29,44,0.7);
      margin-bottom: 10px;
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .section-label::before {
      content: "";
      display: inline-block;
      width: 20px; height: 1px;
      background: rgba(234,29,44,0.5);
    }

    /* section entrance animation */
    .section-block {
      animation: rise 0.7s ease both;
      animation-timeline: view();
      animation-range: entry 0% entry 25%;
    }

    /* -- Responsive -- */
    @media (max-width: 960px) {
      .service-grid, .attack-grid { grid-template-columns: 1fr 1fr; }
      .brand-grid, .partners-grid { grid-template-columns: 1fr 1fr; }
      .experience-grid { grid-template-columns: 1fr 1fr; }
      .image-grid { grid-template-columns: repeat(2, 1fr); }
      .news-grid { grid-template-columns: 1fr; }
      .cert-grid { grid-template-columns: repeat(2, 1fr); }
      .about-banner { grid-template-columns: 1fr; }
      .about-award { white-space: normal; }
      .cta-section { padding: 36px 24px; }
    }
    @media (max-width: 600px) {
      .service-grid, .attack-grid, .image-grid, .cert-grid { grid-template-columns: 1fr; }
      .brand-grid, .experience-grid, .partners-grid { grid-template-columns: 1fr; }
      .brand-card, .experience-grid article, .partners-grid article { padding: 18px 16px; }
      .section-block { margin-top: 54px; }
      .cta-section { padding: 28px 16px; }
    }
    @media (max-width: 768px) {
      .hero {
        padding-top: 6px;
        padding-bottom: 8px;
        min-height: auto;
      }
      .hero-layout {
        grid-template-columns: 1fr;
        gap: 10px;
        min-height: auto;
      }
      .hero-copy {
        order: 2;
        padding: 16px 14px;
      }
      .hero-visual {
        order: 1;
        min-height: 300px;
        padding: 12px;
      }
      .hero h1 {
        font-size: clamp(1.25rem, 6.5vw, 1.75rem);
        line-height: 1.08;
        max-width: none;
      }
      .hero .lead {
        font-size: 0.96rem;
        line-height: 1.55;
      }
      .hero-actions {
        margin-top: 8px;
        gap: 10px;
      }
      .hero-actions .btn {
        flex: 1 1 100%;
        text-align: center;
      }
      .hero-stats {
        margin-top: 14px;
        gap: 10px 14px;
      }
      .hero-stat {
        min-width: calc(50% - 8px);
      }
      .hero-stat-divider {
        display: none;
      }
      .about-banner {
        padding: 24px 18px;
        gap: 16px;
      }
      .threat-ticker::before,
      .threat-ticker::after {
        display: none;
      }
      .hero-radar {
        width: min(72vw, 320px);
        right: -2%;
        opacity: 0.52;
      }
      .hero-codefall {
        display: flex;
        top: 14%;
        bottom: 14%;
        width: min(28vw, 108px);
        gap: 8px;
        opacity: 0.7;
      }
      .hero-codefall span {
        padding: 5px 6px;
        font-size: 0.5rem;
        letter-spacing: 0.1em;
        white-space: normal;
        line-height: 1.25;
      }
      .hero-codefall span:nth-child(n+4) {
        display: none;
      }
      .hero-chip {
        display: grid;
        padding: 8px 10px;
      }
      .hero-chip span {
        font-size: 0.5rem;
      }
      .hero-chip strong {
        font-size: 0.72rem;
      }
      .hero-chip-top {
        top: 12px;
        left: 12px;
      }
      .hero-chip-bottom {
        right: 12px;
        bottom: 14px;
      }
      .hero-scroll-cue {
        display: none;
      }
      .hero-avatar-shell {
        width: min(92%, 390px);
        opacity: 0.78;
      }
      .hero-orbit-one {
        width: min(58vw, 250px);
        right: 1%;
      }
      .hero-orbit-two {
        width: min(38vw, 160px);
        left: 2%;
        bottom: 14%;
      }
    }

    .three-d-showcase {
      perspective: 1200px;
    }
    .three-d-carousel-wrap {
      position: relative;
      height: 520px;
      margin-top: 8px;
      border: 1px solid rgba(255,255,255,0.12);
      border-radius: 12px;
      background:
        radial-gradient(circle at 50% 20%, rgba(234,29,44,0.14), transparent 40%),
        linear-gradient(160deg, rgba(24,24,32,0.95), rgba(11,11,16,0.95));
      overflow: hidden;
      box-shadow: 0 20px 40px rgba(0,0,0,0.42);
    }
    .three-d-carousel-wrap::after {
      content: "";
      position: absolute;
      left: 50%;
      transform: translateX(-50%);
      bottom: 22px;
      width: min(860px, 88%);
      height: 42px;
      background: radial-gradient(ellipse at center, rgba(0,0,0,0.58), transparent 70%);
      filter: blur(3px);
      pointer-events: none;
    }
    .three-d-carousel {
      position: absolute;
      left: 50%;
      top: 52%;
      width: 420px;
      height: 265px;
      transform-style: preserve-3d;
      transform: translate(-50%, -50%) rotateX(-9deg);
      animation: carouselSpin 18s linear infinite;
    }
    .three-d-face {
      margin: 0;
      position: absolute;
      inset: 0;
      border-radius: 10px;
      overflow: hidden;
      border: 1px solid rgba(255,255,255,0.22);
      background: #0f1118;
      box-shadow: 0 12px 24px rgba(0,0,0,0.32);
    }
    .three-d-face img {
      display: block;
      width: 100%;
      height: 100%;
      object-fit: cover;
      filter: saturate(1.06) contrast(1.06);
    }
    .three-d-face figcaption {
      position: absolute;
      left: 50%;
      bottom: 10px;
      margin: 0;
      z-index: 3;
      color: #ffffff;
      font-family: "Oxanium", sans-serif;
      font-size: 0.72rem;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      text-align: center;
      background: rgba(10,10,14,0.72);
      border: 1px solid rgba(255,255,255,0.22);
      border-radius: 6px;
      padding: 5px 8px;
      max-width: calc(100% - 24px);
      transform: translateX(-50%);
      backdrop-filter: blur(3px);
    }
    .three-d-face:nth-child(1) { transform: rotateY(0deg) translateZ(440px); }
    .three-d-face:nth-child(2) { transform: rotateY(60deg) translateZ(440px); }
    .three-d-face:nth-child(3) { transform: rotateY(120deg) translateZ(440px); }
    .three-d-face:nth-child(4) { transform: rotateY(180deg) translateZ(440px); }
    .three-d-face:nth-child(5) { transform: rotateY(240deg) translateZ(440px); }
    .three-d-face:nth-child(6) { transform: rotateY(300deg) translateZ(440px); }
    @keyframes carouselSpin {
      from { transform: translate(-50%, -50%) rotateX(-9deg) rotateY(0deg); }
      to { transform: translate(-50%, -50%) rotateX(-9deg) rotateY(360deg); }
    }
    @media (max-width: 960px) {
      .three-d-carousel-wrap { height: 430px; }
      .three-d-carousel {
        width: 300px;
        height: 190px;
      }
      .three-d-face:nth-child(1) { transform: rotateY(0deg) translateZ(320px); }
      .three-d-face:nth-child(2) { transform: rotateY(60deg) translateZ(320px); }
      .three-d-face:nth-child(3) { transform: rotateY(120deg) translateZ(320px); }
      .three-d-face:nth-child(4) { transform: rotateY(180deg) translateZ(320px); }
      .three-d-face:nth-child(5) { transform: rotateY(240deg) translateZ(320px); }
      .three-d-face:nth-child(6) { transform: rotateY(300deg) translateZ(320px); }
    }
    @media (max-width: 560px) {
      .three-d-carousel-wrap { height: 320px; }
      .three-d-carousel {
        width: 210px;
        height: 138px;
      }
      .three-d-face:nth-child(1) { transform: rotateY(0deg) translateZ(200px); }
      .three-d-face:nth-child(2) { transform: rotateY(60deg) translateZ(200px); }
      .three-d-face:nth-child(3) { transform: rotateY(120deg) translateZ(200px); }
      .three-d-face:nth-child(4) { transform: rotateY(180deg) translateZ(200px); }
      .three-d-face:nth-child(5) { transform: rotateY(240deg) translateZ(200px); }
      .three-d-face:nth-child(6) { transform: rotateY(300deg) translateZ(200px); }
    }


/* ================================================================
   About Page CSS {}
   ================================================================ */
/* -- About-page specifics -- */

    /* Team photo aspect - taller for portraits */
    .team-photo { height:320px; }
    .leadership-grid .team-photo { height:450px; }

    /* Leadership cards get a subtle gold/red tint */
    .leadership-grid .team-card {
      border-color: rgba(234,29,44,0.22);
    }

    .team-cert-grid {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    /* Mission strip */
    .mission-strip {
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:16px;
      margin-top:0;
    }
    .mission-item {
      border:1px solid var(--panel-border);
      border-radius:10px;
      padding:24px 20px;
      background:
        linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
        linear-gradient(90deg,rgba(255,255,255,0.012) 1px,transparent 1px),
        linear-gradient(160deg,#191920 0%,var(--card-bg) 100%);
      background-size:20px 20px,20px 20px,auto;
      position:relative;overflow:hidden;
      transition:transform 0.25s ease, border-color 0.25s ease;
    }
    .mission-item:hover { transform:translateY(-3px);border-color:rgba(234,29,44,0.45); }
    .mission-item::before {
      content:"";position:absolute;top:0;right:0;
      width:40px;height:40px;
      background:linear-gradient(135deg,rgba(234,29,44,0.16),transparent 65%);
    }
    .mission-item::after {
      content:"";position:absolute;top:0;left:0;right:0;height:2px;
      background:linear-gradient(90deg,#ea1d2c,transparent);
      border-radius:10px 10px 0 0;
    }
    .mission-icon { font-size:1.8rem;margin-bottom:12px;display:block; }
    .mission-item h3 { margin:0 0 8px; }
    .mission-item p { margin:0;color:var(--brand-muted);font-size:0.93rem; }

    @media(max-width:768px){
      .mission-strip { grid-template-columns:1fr; }
    }


/* ================================================================
   Services Page CSS {}
   ================================================================ */
.services-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(340px, 0.92fr);
  gap: 24px;
  align-items: stretch;
}
.services-hero > * {
  position: relative;
  z-index: 1;
}
.services-hero-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.services-hero .lead {
  max-width: 760px;
}
.services-hero-highlights {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}
.services-hero-highlights span {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border: 1px solid rgba(234,29,44,0.22);
  border-radius: 999px;
  background: rgba(255,255,255,0.03);
  font-family: "Oxanium", sans-serif;
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  color: #e1e2eb;
}
.services-hero-highlights span::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #ea1d2c;
  box-shadow: 0 0 10px rgba(234,29,44,0.6);
}
.services-hero-console {
  min-height: 100%;
}
.services-console-shell {
  height: 100%;
  border: 1px solid rgba(234,29,44,0.2);
  border-radius: 12px;
  padding: 22px;
  background:
    radial-gradient(circle at 100% 0%, rgba(234,29,44,0.18), transparent 34%),
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(160deg, rgba(20,9,11,0.96) 0%, rgba(10,10,14,0.98) 100%);
  background-size: auto, 18px 18px, 18px 18px, auto;
  position: relative;
  overflow: hidden;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.02), 0 16px 36px rgba(0,0,0,0.28);
}
.services-console-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,0.08), transparent 16%),
    linear-gradient(135deg, transparent 0%, rgba(255,255,255,0.03) 48%, transparent 52%);
  pointer-events: none;
}
.services-console-shell::after {
  content: "";
  position: absolute;
  width: 78%;
  height: 2px;
  left: -42%;
  top: 18%;
  background: linear-gradient(90deg, transparent, rgba(234,29,44,0.8), transparent);
  transform: rotate(14deg);
  opacity: 0.7;
  animation: servicesSweep 7s linear infinite;
}
.services-console-head,
.services-console-grid,
.services-console-bar {
  position: relative;
  z-index: 1;
}
.services-console-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
}
.services-console-kicker {
  margin: 0 0 6px;
  font-family: "Oxanium", sans-serif;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(234,29,44,0.72);
}
.services-console-head h3 {
  margin: 0;
  font-size: 1.18rem;
}
.services-console-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(234,29,44,0.28);
  background: rgba(234,29,44,0.08);
  font-family: "Oxanium", sans-serif;
  font-size: 0.74rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #ffe6e8;
}
.services-console-status::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #ea1d2c;
  box-shadow: 0 0 10px rgba(234,29,44,0.55);
}
.services-console-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 18px;
}
.services-console-card {
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  padding: 16px 14px 16px 16px;
  background: rgba(7,7,10,0.62);
  position: relative;
  backdrop-filter: blur(8px);
}
.services-console-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(to bottom, #ea1d2c, transparent);
}
.services-console-code {
  display: inline-block;
  margin-bottom: 10px;
  font-family: "Oxanium", sans-serif;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(234,29,44,0.78);
}
.services-console-card strong {
  display: block;
  margin-bottom: 8px;
  font-family: "Oxanium", sans-serif;
  font-size: 0.95rem;
  color: var(--brand-light);
}
.services-console-card p {
  margin: 0;
  color: #cfd0dc;
  line-height: 1.55;
  font-size: 0.88rem;
}
.services-console-bar {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.08);
}
.services-console-bar div {
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  padding: 12px 10px;
  background: rgba(255,255,255,0.03);
}
.services-console-bar span {
  display: block;
  font-family: "Oxanium", sans-serif;
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(234,29,44,0.7);
}
.services-console-bar strong {
  display: block;
  margin-top: 6px;
  font-size: 0.92rem;
  color: #f0f0f3;
}
.service-proof-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 22px;
}
.service-proof-card {
  border: 1px solid var(--panel-border);
  border-radius: 12px;
  padding: 22px 20px;
  background:
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(160deg, rgba(20,11,13,0.98) 0%, rgba(12,12,16,0.98) 100%);
  background-size: 20px 20px, 20px 20px, auto;
  position: relative;
  overflow: hidden;
  transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}
.service-proof-card:hover {
  transform: translateY(-3px);
  border-color: rgba(234,29,44,0.45);
  box-shadow: 0 14px 30px rgba(0,0,0,0.26);
}
.service-proof-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, #ea1d2c, transparent);
}
.service-proof-kicker {
  margin: 0 0 10px;
  font-family: "Oxanium", sans-serif;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(234,29,44,0.72);
}
.service-proof-card h3 {
  margin: 0 0 10px;
}
.service-proof-card p {
  margin: 0;
  color: #cbccda;
  line-height: 1.6;
}
.services-shell {
  position: relative;
  padding: 34px 32px;
  border: 1px solid rgba(234,29,44,0.14);
  border-radius: 12px;
  background:
    radial-gradient(circle at 100% 0%, rgba(234,29,44,0.12), transparent 34%),
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(160deg, rgba(20,11,13,0.96) 0%, rgba(12,12,16,0.97) 100%);
  background-size: auto, 22px 22px, 22px 22px, auto;
  overflow: hidden;
}
.services-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 16%, rgba(255,255,255,0.05), transparent 14%),
    linear-gradient(135deg, transparent 0%, rgba(255,255,255,0.02) 48%, transparent 52%);
  pointer-events: none;
}
.services-shell > * {
  position: relative;
  z-index: 1;
}
.core-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(4, 1fr);
}
.core-card {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--panel-border);
  border-radius: 10px;
  padding: 26px 22px;
  background:
    linear-gradient(rgba(255,255,255,0.012) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.012) 1px,transparent 1px),
    linear-gradient(160deg,#191920 0%,var(--card-bg) 100%);
  background-size: 20px 20px, 20px 20px, auto;
  position: relative;
  overflow: hidden;
  transition: transform 0.25s, border-color 0.25s, box-shadow 0.25s;
}
.core-card:hover {
  transform: translateY(-3px);
  border-color: rgba(234,29,44,0.5);
  box-shadow: 0 14px 30px rgba(0,0,0,0.3);
}
.core-card::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 40px;
  height: 40px;
  background: linear-gradient(135deg,rgba(234,29,44,0.16),transparent 65%);
}
.core-card::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg,#ea1d2c,transparent);
  border-radius: 10px 10px 0 0;
}
.core-icon {
  display: inline-block;
  font-size: 1.9rem;
  margin-bottom: 14px;
}
.core-card p {
  margin: 0;
  color: var(--brand-muted);
  line-height: 1.6;
}
.core-card .btn {
  margin-top: auto;
  align-self: flex-start;
}
.service-card-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  margin-bottom: 14px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(234,29,44,0.22);
  background: rgba(234,29,44,0.08);
  font-family: "Oxanium", sans-serif;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #ffd9dc;
}
.service-card-badge::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #ea1d2c;
  box-shadow: 0 0 8px rgba(234,29,44,0.4);
}
.core-meta {
  display: grid;
  gap: 8px;
  margin: 14px 0 16px;
  font-size: 0.88rem;
  color: #cfd0db;
}
.core-meta span {
  display: block;
  line-height: 1.45;
}
.core-meta strong {
  color: var(--brand-light);
  font-family: "Oxanium", sans-serif;
  letter-spacing: 0.02em;
}

.decision-grid,
.deliverables-grid,
.engagement-grid {
  display: grid;
  gap: 16px;
}
.decision-grid {
  grid-template-columns: repeat(3, 1fr);
}
.deliverables-grid {
  grid-template-columns: repeat(4, 1fr);
}
.engagement-grid {
  grid-template-columns: repeat(3, 1fr);
}
.decision-card,
.deliverable-card,
.engagement-card {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--panel-border);
  border-radius: 10px;
  padding: 24px 22px;
  background:
    linear-gradient(rgba(255,255,255,0.012) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.012) 1px,transparent 1px),
    linear-gradient(160deg,#191920 0%,var(--card-bg) 100%);
  background-size: 20px 20px, 20px 20px, auto;
  position: relative;
  overflow: hidden;
  transition: transform 0.25s, border-color 0.25s, box-shadow 0.25s;
}
.decision-card:hover,
.deliverable-card:hover,
.engagement-card:hover {
  transform: translateY(-3px);
  border-color: rgba(234,29,44,0.45);
  box-shadow: 0 14px 30px rgba(0,0,0,0.28);
}
.decision-card::before,
.deliverable-card::before,
.engagement-card::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 40px;
  height: 40px;
  background: linear-gradient(135deg,rgba(234,29,44,0.14),transparent 65%);
}
.decision-card::after,
.deliverable-card::after,
.engagement-card::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg,#ea1d2c,transparent);
  border-radius: 10px 10px 0 0;
}
.decision-card h3,
.deliverable-card h3,
.engagement-card h3 {
  margin: 0 0 10px;
}
.decision-card p,
.deliverable-card p,
.engagement-card p {
  margin: 0;
  color: var(--brand-muted);
}
.decision-kicker,
.engagement-kicker {
  margin: 0 0 12px;
  font-family: "Oxanium", sans-serif;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(234,29,44,0.72);
}
.decision-list {
  list-style: none;
  margin: 14px 0 0;
  padding: 0;
  display: grid;
  gap: 10px;
}
.decision-list li {
  position: relative;
  padding-left: 16px;
  color: #d2d3de;
  line-height: 1.55;
  font-size: 0.9rem;
}
.decision-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.6em;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #ea1d2c;
  box-shadow: 0 0 10px rgba(234,29,44,0.4);
}
.deliverable-card p,
.engagement-card p {
  line-height: 1.6;
}
.service-detail-intro .body-copy {
  max-width: 820px;
}
.decision-card .text-link,
.engagement-card .text-link {
  margin-top: auto;
  padding-top: 14px;
}

.service-picker {
  margin-top: 20px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.picker-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  color: var(--brand-light);
  font-family: "Oxanium", sans-serif;
  letter-spacing: 0.03em;
  font-size: 0.85rem;
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.03);
  transition: border-color 0.2s, background 0.2s, transform 0.2s;
}
.picker-chip:hover {
  border-color: rgba(234,29,44,0.45);
  background: rgba(234,29,44,0.08);
  transform: translateY(-1px);
}

.detail-section {
  margin-top: 72px;
  position: relative;
  padding-top: 18px;
}
.detail-section::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 120px;
  height: 1px;
  background: linear-gradient(90deg, rgba(234,29,44,0.82), transparent);
}
.detail-section::after {
  content: "";
  position: absolute;
  top: -5px;
  left: 0;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 1px solid rgba(234,29,44,0.45);
  background: rgba(234,29,44,0.18);
  box-shadow: 0 0 12px rgba(234,29,44,0.32);
}
.detail-panel {
  border: 1px solid var(--panel-border);
  border-radius: 10px;
  background:
    linear-gradient(rgba(255,255,255,0.012) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.012) 1px,transparent 1px),
    linear-gradient(160deg,#191920 0%,var(--card-bg) 100%);
  background-size: 20px 20px, 20px 20px, auto;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 14px 30px rgba(0,0,0,0.2);
}
.detail-panel::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 40px;
  height: 40px;
  background: linear-gradient(135deg,rgba(234,29,44,0.14),transparent 65%);
}
.detail-panel::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, #ea1d2c, transparent);
}
.detail-panel .body-copy {
  margin-bottom: 16px;
}
.detail-two-col {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(2, 1fr);
}

.service-list {
  margin: 0;
  padding-left: 20px;
  color: #cbccda;
}
.service-list li {
  margin: 8px 0;
  line-height: 1.55;
}

.mobile-service-accordion {
  margin-top: 14px;
}
.mobile-service-accordion details {
  border: 1px solid rgba(234,29,44,0.22);
  border-radius: 8px;
  background: rgba(234,29,44,0.06);
  padding: 10px 12px;
}
.mobile-service-accordion summary {
  cursor: pointer;
  font-family: "Oxanium", sans-serif;
  color: var(--brand-light);
  font-size: 0.88rem;
}
.mobile-service-accordion ul {
  margin: 10px 0 0;
  padding-left: 18px;
}
.mobile-service-accordion li {
  margin: 7px 0;
  color: #d4d5df;
}

.stages-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(4, 1fr);
}
.stage-card {
  border: 1px solid var(--panel-border);
  border-radius: 10px;
  padding: 22px 18px;
  background:
    linear-gradient(rgba(255,255,255,0.012) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.012) 1px,transparent 1px),
    linear-gradient(160deg,#191920 0%,var(--card-bg) 100%);
  background-size: 20px 20px, 20px 20px, auto;
  position: relative;
  text-align: center;
  overflow: hidden;
  transition: transform 0.25s, border-color 0.25s, box-shadow 0.25s;
}
.stage-card:hover {
  transform: translateY(-3px);
  border-color: rgba(234,29,44,0.45);
  box-shadow: 0 14px 30px rgba(0,0,0,0.24);
}
.stage-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, #ea1d2c, transparent);
}
.stage-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: 2px solid rgba(234,29,44,0.4);
  background: rgba(234,29,44,0.08);
  font-family: "Oxanium", sans-serif;
  font-weight: 800;
  font-size: 1.1rem;
  color: #ea1d2c;
  margin: 0 auto 14px;
}
.stage-card p {
  margin: 0;
  color: var(--brand-muted);
  font-size: 0.88rem;
}
.stage-duration {
  display: inline-block;
  margin-top: 10px;
  font-size: 0.75rem;
  font-family: "Oxanium", sans-serif;
  letter-spacing: 0.1em;
  color: rgba(234,29,44,0.7);
  background: rgba(234,29,44,0.07);
  border: 1px solid rgba(234,29,44,0.18);
  border-radius: 4px;
  padding: 3px 8px;
}

.case-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(2, 1fr);
}
.case-card {
  border: 1px solid var(--panel-border);
  border-radius: 10px;
  padding: 22px 20px;
  background:
    linear-gradient(rgba(255,255,255,0.012) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.012) 1px,transparent 1px),
    linear-gradient(160deg,#191920 0%,var(--card-bg) 100%);
  background-size: 20px 20px, 20px 20px, auto;
  position: relative;
  overflow: hidden;
  transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}
.case-card:hover {
  transform: translateY(-3px);
  border-color: rgba(234,29,44,0.45);
  box-shadow: 0 14px 30px rgba(0,0,0,0.26);
}
.case-card::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 40px;
  height: 40px;
  background: linear-gradient(135deg,rgba(234,29,44,0.14),transparent 65%);
}
.case-card::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, #ea1d2c, transparent);
}
.case-card h3 {
  margin: 0 0 10px;
}
.case-card p {
  margin: 0 0 8px;
  color: #cbccda;
  line-height: 1.55;
  font-size: 0.92rem;
}
.case-card p:last-child {
  margin-bottom: 0;
}
.case-card strong {
  color: var(--brand-light);
  font-family: "Oxanium", sans-serif;
  font-size: 0.78rem;
  letter-spacing: 0.04em;
}
.case-more {
  margin-top: 10px;
}
.case-more summary {
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(234,29,44,0.3);
  border-radius: 6px;
  background: rgba(234,29,44,0.1);
  color: #f2f2f6;
  font-family: "Oxanium", sans-serif;
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 6px 10px;
}
.case-more[open] summary {
  border-color: rgba(234,29,44,0.6);
}
.case-more p {
  margin-top: 10px;
}

@keyframes servicesSweep {
  0% {
    left: -42%;
    top: 18%;
  }
  100% {
    left: 100%;
    top: 76%;
  }
}

@media (max-width: 1200px) {
  .services-hero {
    grid-template-columns: 1fr;
  }
  .core-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .deliverables-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 960px) {
  .team-cert-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .services-console-grid,
  .services-console-bar,
  .service-proof-strip {
    grid-template-columns: repeat(2, 1fr);
  }
  .decision-grid,
  .engagement-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .detail-two-col {
    grid-template-columns: 1fr;
  }
  .stages-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .case-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 600px) {
  .team-cert-grid {
    grid-template-columns: 1fr;
  }
  .services-hero {
    gap: 18px;
  }
  .services-shell {
    padding: 26px 18px;
  }
  .services-hero-highlights span {
    width: 100%;
    justify-content: flex-start;
  }
  .services-console-head {
    flex-direction: column;
  }
  .decision-grid,
  .deliverables-grid,
  .engagement-grid,
  .services-console-grid,
  .services-console-bar,
  .service-proof-strip,
  .core-grid,
  .stages-grid {
    grid-template-columns: 1fr;
  }
  .detail-panel {
    padding: 22px 18px;
  }
}


/* ================================================================
   Contact Page CSS {}
   ================================================================ */
.contact-layout {
  display: grid;
  grid-template-columns: 1.35fr 0.65fr;
  gap: 18px;
  align-items: start;
}

.form-panel {
  border: 1px solid var(--panel-border);
  border-radius: 12px;
  padding: 34px 32px;
  background:
    linear-gradient(rgba(255,255,255,0.012) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.012) 1px,transparent 1px),
    linear-gradient(155deg,#1a1014 0%,#111116 100%);
  background-size: 20px 20px, 20px 20px, auto;
  position: relative;
  overflow: hidden;
}
.form-panel::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 80px;
  height: 80px;
  background: radial-gradient(circle at 100% 0%,rgba(234,29,44,0.14),transparent 70%);
}
.form-panel::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg,#ea1d2c,transparent);
}
.form-panel h2 {
  border-left: none;
  padding-left: 0;
  text-transform: none;
  letter-spacing: 0;
  margin-bottom: 20px;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
select {
  width: 100%;
  background: #0d0d12;
  border: 1px solid rgba(255,255,255,0.12);
  color: var(--brand-light);
  border-radius: 8px;
  padding: 12px 40px 12px 12px;
  font-family: inherit;
  font-size: 0.95rem;
  transition: border-color 0.2s, outline 0.2s;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(255,255,255,0.7) 50%),
    linear-gradient(135deg, rgba(255,255,255,0.7) 50%, transparent 50%);
  background-position:
    calc(100% - 18px) calc(50% - 3px),
    calc(100% - 12px) calc(50% - 3px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}
select:focus {
  outline: 2px solid rgba(234,29,44,0.4);
  border-color: var(--brand-red-bright);
}
select option {
  background: #111118;
  color: var(--brand-light);
}
.form-note {
  font-size: 0.8rem;
  color: var(--brand-muted);
  margin: 0;
}
.form-alert {
  margin: 0 0 14px;
  border-radius: 8px;
  border: 1px solid transparent;
  padding: 10px 12px;
  font-size: 0.9rem;
  line-height: 1.45;
  display: none;
}
.form-alert.success {
  display: block;
  border-color: rgba(76,175,80,0.45);
  background: rgba(76,175,80,0.12);
  color: #d8f5dd;
}
.form-alert.error {
  display: block;
  border-color: rgba(234,29,44,0.45);
  background: rgba(234,29,44,0.14);
  color: #ffd5d9;
}
.hp-field {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}

.info-sidebar {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.info-card {
  border: 1px solid var(--panel-border);
  border-radius: 10px;
  padding: 22px 20px;
  background:
    linear-gradient(rgba(255,255,255,0.012) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.012) 1px,transparent 1px),
    linear-gradient(160deg,#191920 0%,var(--card-bg) 100%);
  background-size: 20px 20px, 20px 20px, auto;
  position: relative;
  overflow: hidden;
  transition: border-color 0.25s;
}
.info-card:hover {
  border-color: rgba(234,29,44,0.4);
}
.info-card::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 36px;
  height: 36px;
  background: linear-gradient(135deg,rgba(234,29,44,0.14),transparent 65%);
}
.info-card h3 {
  margin: 0 0 14px;
  font-size: 0.95rem;
  color: var(--brand-light);
}

.contact-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
}
.contact-item:last-child {
  margin-bottom: 0;
}
.contact-icon {
  width: 34px;
  height: 34px;
  border-radius: 6px;
  flex-shrink: 0;
  background: rgba(234,29,44,0.1);
  border: 1px solid rgba(234,29,44,0.22);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
}
.contact-item-text strong {
  display: block;
  font-family: "Oxanium", sans-serif;
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(234,29,44,0.7);
  margin-bottom: 3px;
}
.contact-item-text span {
  font-size: 0.9rem;
  color: #ccccd8;
}

.map-card iframe {
  width: 100%;
  height: 220px;
  border: 0;
  border-radius: 8px;
  display: block;
  margin-bottom: 12px;
}
.map-address {
  margin: 0;
  color: #ccccd8;
  font-size: 0.9rem;
  line-height: 1.5;
}

.trust-strip {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 0;
  list-style: none;
  padding: 0;
}
.trust-strip li {
  border: 1px solid var(--panel-border);
  border-radius: 10px;
  padding: 18px 16px;
  background:
    linear-gradient(rgba(255,255,255,0.012) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.012) 1px,transparent 1px),
    linear-gradient(160deg,#191920 0%,var(--card-bg) 100%);
  background-size: 20px 20px, 20px 20px, auto;
  color: #ccccd8;
  font-size: 0.9rem;
  line-height: 1.5;
}

@media (max-width: 980px) {
  .contact-layout {
    grid-template-columns: 1fr;
  }
  .form-row {
    grid-template-columns: 1fr;
  }
  .trust-strip {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .site-footer {
    width: calc(100% - 12px);
    box-sizing: border-box;
    margin: 0 auto;
    padding: 20px 12px 84px;
    border-radius: 12px 12px 0 0;
    border-left: 1px solid rgba(255,255,255,0.08);
    border-right: 1px solid rgba(255,255,255,0.08);
    background: linear-gradient(160deg, rgba(14,14,20,0.96), rgba(9,9,14,0.96));
  }
  .footer-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .footer-grid > div {
    border: 1px solid rgba(255,255,255,0.09);
    border-radius: 10px;
    padding: 14px 12px;
    background:
      linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
      linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px),
      linear-gradient(160deg, rgba(24,24,31,0.96), rgba(14,14,19,0.96));
    background-size: 20px 20px, 20px 20px, auto;
  }
  .footer-grid h3 {
    font-size: 0.9rem;
    margin-bottom: 8px;
  }
  .footer-grid p,
  .footer-grid a {
    font-size: 0.88rem;
    line-height: 1.6;
    overflow-wrap: anywhere;
  }
  .social-link {
    padding: 10px 12px;
  }
  .footer-copy {
    margin-top: 12px;
    padding-top: 12px;
    font-size: 0.78rem;
    line-height: 1.6;
    overflow-wrap: anywhere;
  }
  .footer-copy .dev-credit {
    display: block;
    margin-top: 4px;
  }
  .whatsapp-float {
    right: 10px;
    bottom: 16px;
  }
}

/* ================================================================
   Fluid Compatibility Layer
   Keeps components adaptive across in-between widths, not just
   specific device breakpoints.
   ================================================================ */
img,
video,
canvas,
svg,
iframe {
  max-width: 100%;
}

main,
.site-header,
.site-footer {
  width: min(var(--site-shell-width), calc(100% - 24px));
}

:where(
  .service-grid,
  .attack-grid,
  .image-grid,
  .cert-grid,
  .team-grid,
  .steps,
  .footer-grid,
  .core-grid,
  .decision-grid,
  .deliverables-grid,
  .engagement-grid,
  .case-grid,
  .stages-grid,
  .trust-strip
) {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr));
}

:where(
  .experience-grid,
  .brand-grid,
  .partners-grid,
  .leadership-grid,
  .mission-strip
) {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
}

.hero-layout {
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: clamp(14px, 2vw, 22px);
}

.about-banner {
  grid-template-columns: minmax(0, 1fr) minmax(280px, 0.42fr);
  gap: clamp(18px, 3vw, 32px);
  padding: clamp(24px, 3vw, 36px);
}

.contact-layout {
  grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.92fr);
}

.services-hero {
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.92fr);
}

.services-console-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
}

.services-console-bar {
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.service-proof-strip {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr));
}

.three-d-carousel-wrap {
  height: clamp(340px, 42vw, 520px);
}

.three-d-carousel {
  --carousel-depth: clamp(220px, 32vw, 440px);
  width: clamp(240px, 35vw, 420px);
  height: clamp(155px, 22vw, 265px);
}

.three-d-face:nth-child(1) { transform: rotateY(0deg) translateZ(var(--carousel-depth)); }
.three-d-face:nth-child(2) { transform: rotateY(60deg) translateZ(var(--carousel-depth)); }
.three-d-face:nth-child(3) { transform: rotateY(120deg) translateZ(var(--carousel-depth)); }
.three-d-face:nth-child(4) { transform: rotateY(180deg) translateZ(var(--carousel-depth)); }
.three-d-face:nth-child(5) { transform: rotateY(240deg) translateZ(var(--carousel-depth)); }
.three-d-face:nth-child(6) { transform: rotateY(300deg) translateZ(var(--carousel-depth)); }

@media (max-width: 1180px) {
  .hero-layout,
  .services-hero,
  .about-banner,
  .contact-layout {
    grid-template-columns: 1fr;
  }

  .hero {
    min-height: auto;
  }

  .hero-layout {
    min-height: auto;
  }

  .hero-copy,
  .services-hero-copy,
  .services-console-shell {
    min-width: 0;
  }
}

@media (max-width: 900px) {
  main,
  .site-header,
  .site-footer {
    width: calc(100% - 18px);
  }

  .three-d-carousel-wrap {
    height: clamp(300px, 56vw, 430px);
  }

  .three-d-carousel {
    --carousel-depth: clamp(180px, 28vw, 300px);
    width: clamp(210px, 42vw, 320px);
    height: clamp(135px, 26vw, 200px);
  }
}

/* ================================================================
   Certificate Pile Layout
   ================================================================ */
.cert-wall-section .cert-grid {
  position: relative;
  display: block;
  min-height: clamp(540px, 50vw, 700px);
  padding: 36px 0 28px;
}

.cert-wall-section .cert-card {
  position: absolute;
  margin: 0;
  width: clamp(220px, 19vw, 310px);
  overflow: visible;
  border-radius: 8px;
  border: 1px solid rgba(64, 34, 20, 0.8);
  background: linear-gradient(135deg, rgba(103, 31, 34, 0.94), rgba(41, 18, 19, 0.97));
  box-shadow: 0 18px 28px rgba(0,0,0,0.28), 0 10px 0 rgba(0,0,0,0.08);
  padding: 12px 12px 58px;
}

.cert-wall-section .cert-card::before {
  content: "";
  position: absolute;
  inset: 10px 10px 44px;
  border: 5px solid rgba(30, 10, 11, 0.7);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08);
  pointer-events: none;
}

.cert-wall-section .cert-card::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -16px;
  width: 74%;
  height: 18px;
  transform: translateX(-50%);
  background: radial-gradient(ellipse at center, rgba(0,0,0,0.34), transparent 72%);
  filter: blur(2px);
  pointer-events: none;
}

.cert-wall-section .cert-card img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border: 7px solid #d7c39e;
  background: #efe6cd;
  box-shadow: inset 0 0 0 1px rgba(80, 55, 24, 0.28), 0 10px 18px rgba(0,0,0,0.16);
}

.cert-wall-section .cert-card figcaption {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 10px;
  padding: 8px 10px;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 4px;
  text-align: center;
  font-size: 0.76rem;
  line-height: 1.35;
  letter-spacing: 0.03em;
  background: linear-gradient(180deg, rgba(30,30,36,0.94), rgba(12,12,15,0.96));
  box-shadow: 0 8px 18px rgba(0,0,0,0.22);
}

.cert-wall-section .cert-card:nth-child(1) {
  left: 17%;
  top: 28%;
  z-index: 1;
  transform: rotate(-11deg);
}

.cert-wall-section .cert-card:nth-child(2) {
  left: 29%;
  top: 10%;
  z-index: 2;
  transform: rotate(-6deg);
}

.cert-wall-section .cert-card:nth-child(3) {
  left: 50%;
  top: 8%;
  z-index: 5;
  width: clamp(250px, 21vw, 330px);
  transform: translateX(-50%) rotate(-1deg);
}

.cert-wall-section .cert-card:nth-child(4) {
  right: 27%;
  top: 14%;
  z-index: 3;
  transform: rotate(7deg);
}

.cert-wall-section .cert-card:nth-child(5) {
  right: 15%;
  top: 31%;
  z-index: 1;
  transform: rotate(12deg);
}

@media (max-width: 1180px) {
  .cert-wall-section .cert-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    min-height: auto;
    padding: 0;
  }

  .cert-wall-section .cert-card,
  .cert-wall-section .cert-card:nth-child(1),
  .cert-wall-section .cert-card:nth-child(2),
  .cert-wall-section .cert-card:nth-child(3),
  .cert-wall-section .cert-card:nth-child(4),
  .cert-wall-section .cert-card:nth-child(5) {
    position: relative;
    inset: auto;
    width: 100%;
    transform: none;
  }
}

@media (max-width: 760px) {
  .cert-wall-section .cert-grid {
    grid-template-columns: 1fr;
  }
}

/* ================================================================
   Adaptive Screen Range Layer
   Fine-tune the shell for small laptops through ultra-wide/4K displays.
   ================================================================ */
@media (max-width: 1366px) and (min-width: 901px) {
  :root {
    --site-shell-width: min(1520px, calc(100vw - 12px));
    --site-centered-panel-width: min(1400px, calc(100vw - 20px));
  }

  .hero-layout,
  .about-banner,
  .services-hero,
  .contact-layout {
    gap: clamp(14px, 1.8vw, 22px);
  }

  .page-hero,
  .services-shell,
  .form-panel {
    padding: clamp(24px, 2vw, 32px);
  }
}

@media (max-width: 420px) {
  main,
  .site-header,
  .site-footer {
    width: calc(100% - 12px);
  }

  .page-hero,
  .services-shell,
  .form-panel,
  .about-banner {
    padding: 20px 14px;
  }

  .hero-copy {
    padding: 18px 14px;
  }

  .hero-actions .btn,
  .cta-section .btn,
  .service-picker .picker-chip,
  .site-nav-shell .cta-small {
    width: 100%;
  }

  .hero-stats {
    gap: 12px;
  }
}

@media (min-width: 1600px) {
  :root {
    --site-shell-width: min(1760px, calc(100vw - 56px));
    --site-centered-panel-width: min(1540px, calc(100vw - 88px));
    --site-text-width: 980px;
  }
}

@media (min-width: 2200px) {
  html {
    font-size: 17px;
  }

  :root {
    --site-shell-width: min(2380px, calc(100vw - 96px));
    --site-centered-panel-width: min(2140px, calc(100vw - 140px));
    --site-text-width: 1080px;
  }

  .hero-layout,
  .about-banner,
  .services-hero,
  .contact-layout {
    gap: clamp(24px, 1.8vw, 40px);
  }

  .page-hero,
  .services-shell,
  .form-panel {
    padding: clamp(32px, 2vw, 48px);
  }

  .three-d-carousel-wrap {
    height: clamp(460px, 28vw, 720px);
  }

  .three-d-carousel {
    --carousel-depth: clamp(280px, 18vw, 560px);
    width: clamp(340px, 22vw, 560px);
    height: clamp(220px, 14vw, 360px);
  }

  .hero-radar {
    width: min(32vw, 760px);
  }

  .hero-codefall {
    width: min(14vw, 280px);
  }

  .hero-orbit-one {
    width: min(26vw, 620px);
  }

  .hero-orbit-two {
    width: min(18vw, 420px);
  }
}

@media (min-width: 3200px) {
  html {
    font-size: 18px;
  }

  :root {
    --site-shell-width: min(3200px, calc(100vw - 160px));
    --site-centered-panel-width: min(2860px, calc(100vw - 220px));
    --site-text-width: 1200px;
  }
}

/* ================================================================
   Bootstrap Override Layer
   Keep Redzone styling authoritative when Bootstrap classes overlap.
   ================================================================ */
body.bootstrap-shell {
  --bs-body-bg: transparent;
  --bs-body-color: var(--brand-light);
  --bs-border-color: rgba(255,255,255,0.08);
}

body.bootstrap-shell .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 20px;
  border: none;
  border-radius: 8px;
  font-family: "Oxanium", sans-serif;
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-decoration: none;
  box-shadow: none;
  clip-path: polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 8px 100%, 0 calc(100% - 8px));
}

body.bootstrap-shell .btn.btn-primary {
  background: var(--brand-red);
  color: #fff;
  box-shadow: 0 6px 20px rgba(194,15,31,0.35);
}

body.bootstrap-shell .btn.btn-primary:hover,
body.bootstrap-shell .btn.btn-primary:focus-visible {
  background: var(--brand-red-bright);
  color: #fff;
  box-shadow: 0 8px 24px rgba(234,29,44,0.5);
}

body.bootstrap-shell .btn.btn-ghost {
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.025);
  color: var(--brand-light);
}

body.bootstrap-shell .btn.btn-ghost:hover,
body.bootstrap-shell .btn.btn-ghost:focus-visible {
  border-color: rgba(234,29,44,0.45);
  background: rgba(234,29,44,0.06);
  color: var(--brand-light);
}

body.bootstrap-shell .site-header.navbar .navbar-brand,
body.bootstrap-shell .site-header.navbar .nav-link,
body.bootstrap-shell .site-header.navbar .navbar-toggler {
  box-shadow: none;
}

body.bootstrap-shell .site-header.navbar .main-nav .nav-link {
  color: var(--brand-muted);
}

body.bootstrap-shell .site-header.navbar .main-nav .nav-link:hover,
body.bootstrap-shell .site-header.navbar .main-nav .nav-link.active,
body.bootstrap-shell .site-header.navbar .main-nav .nav-link:focus-visible {
  color: var(--brand-light);
}

body.bootstrap-shell input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
body.bootstrap-shell textarea,
body.bootstrap-shell select {
  background: #0d0d12;
  border: 1px solid rgba(255,255,255,0.12);
  color: var(--brand-light);
  border-radius: 8px;
  box-shadow: none;
}

body.bootstrap-shell input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):focus,
body.bootstrap-shell textarea:focus,
body.bootstrap-shell select:focus {
  border-color: var(--brand-red-bright);
  box-shadow: 0 0 0 2px rgba(234,29,44,0.2);
  outline: none;
}

/* ================================================================
   Final Screen Compatibility Layer
   Fluid shell sizing from phones and small laptops to 4K displays.
   ================================================================ */
:root {
  --screen-shell-gutter: clamp(8px, 1.4vw, 28px);
  --screen-shell-max: 2080px;
  --screen-centered-max: 1840px;
}

main,
.site-header,
.site-footer {
  width: min(calc(100vw - (var(--screen-shell-gutter) * 2)), var(--screen-shell-max));
}

.floating-scope-cta {
  width: min(calc(100vw - (var(--screen-shell-gutter) * 2)), var(--screen-centered-max));
}

section {
  margin-top: clamp(42px, 4vw, 72px);
}

.section-block {
  margin-top: clamp(54px, 5vw, 82px);
}

.hero-layout,
.about-banner,
.services-hero,
.contact-layout {
  gap: clamp(16px, 2vw, 30px);
}

.page-hero,
.about-banner,
.services-shell,
.form-panel {
  padding: clamp(22px, 2.2vw, 40px);
}

.hero-copy,
.services-console-shell {
  padding: clamp(18px, 2vw, 28px);
}

.lead,
.body-copy {
  max-width: min(68ch, var(--site-text-width));
}

.team-photo {
  height: clamp(260px, 24vw, 360px);
}

.leadership-grid .team-photo,
.team-cert-grid .team-photo {
  height: clamp(320px, 32vw, 460px);
}

@media (max-width: 1599.98px) and (min-width: 1024px) {
  :root {
    --screen-shell-gutter: clamp(8px, 1vw, 16px);
    --screen-shell-max: 1600px;
    --screen-centered-max: 1440px;
  }

  .hero-layout,
  .about-banner,
  .services-hero,
  .contact-layout {
    gap: clamp(14px, 1.6vw, 22px);
  }
}

@media (max-width: 1023.98px) {
  :root {
    --screen-shell-gutter: clamp(10px, 3vw, 18px);
    --screen-shell-max: 100vw;
    --screen-centered-max: 100vw;
  }

  .page-hero,
  .about-banner,
  .services-shell,
  .form-panel {
    padding: clamp(18px, 3.2vw, 28px);
  }
}

@media (max-width: 767.98px) {
  .hero-actions .btn,
  .cta-section .btn,
  .site-nav-shell .cta-small {
    width: 100%;
  }

  .hero-stats {
    gap: 12px;
  }
}

@media (min-width: 1920px) {
  :root {
    --screen-shell-gutter: clamp(16px, 1.6vw, 36px);
    --screen-shell-max: 2140px;
    --screen-centered-max: 1920px;
  }

  .hero-layout,
  .about-banner,
  .services-hero,
  .contact-layout {
    gap: clamp(20px, 1.8vw, 34px);
  }
}

@media (min-width: 2560px) {
  html {
    font-size: 17px;
  }

  :root {
    --screen-shell-gutter: clamp(28px, 2.8vw, 88px);
    --screen-shell-max: 2520px;
    --screen-centered-max: 2240px;
  }

  .three-d-carousel-wrap {
    height: clamp(460px, 26vw, 720px);
  }

  .hero-radar {
    width: min(30vw, 760px);
  }
}

@media (min-width: 3840px) {
  html {
    font-size: 18px;
  }

  :root {
    --screen-shell-gutter: clamp(40px, 3.5vw, 140px);
    --screen-shell-max: 3600px;
    --screen-centered-max: 3180px;
  }
}
