/* ============================================================
   SPECOPS.AI — SHARED DESIGN SYSTEM
   Applies to: index, vibe-coders, business, federal, pricing
   Score page is standalone (gold/navy brand, separate file)
   ============================================================ */

/* ── TOKENS ── */
:root {
  --navy:      #0D1F3C;
  --navy-mid:  #132744;
  --navy-lt:   #1A3055;
  --card:      #162B4A;
  --card-lt:   #1E3560;
  --white:     #FFFFFF;
  --tw:        #F0F6FF;
  --tg:        #C8D8EE;
  --tm:        #7BA7C8;
  --td:        #4A6F8A;
  --cyan:      #4CA8FF;
  --cyan-b:    #00D4FF;
  --cyan-dim:  rgba(76,168,255,0.09);
  --cyan-bdr:  rgba(76,168,255,0.22);
  --yellow:    #FEBC2E;
  --yel-b:     #FFD060;
  --yel-dim:   rgba(254,188,46,0.08);
  --yel-bdr:   rgba(254,188,46,0.22);
  --green:     #28C840;
  --grn-b:     #34D399;
  --grn-dim:   rgba(40,200,64,0.08);
  --grn-bdr:   rgba(40,200,64,0.22);
  --red:       #EF4444;
  --red-dim:   rgba(239,68,68,0.09);
  --purple:    #A78BFA;
  --orange:    #F97316;
  --bdr:       rgba(255,255,255,0.07);
  --bdr-mid:   rgba(255,255,255,0.12);
  --bdr-cyan:  rgba(76,168,255,0.18);
  --font:      'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --mono:      'JetBrains Mono', monospace;
  --radius:    10px;
  --radius-lg: 16px;
  --shadow-sm: 0 2px 12px rgba(0,0,0,0.25);
  --shadow-md: 0 8px 32px rgba(0,0,0,0.35);
  --shadow-cyan: 0 6px 24px rgba(76,168,255,0.25);
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family: var(--font);
  background: var(--navy);
  color: var(--tg);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { text-decoration:none; color:inherit; }
img { max-width:100%; }
ul { list-style:none; }

/* ── LAYOUT ── */
.container { max-width:1200px; margin:0 auto; padding:0 24px; }
.section { padding:88px 0; }
.section-sm { padding:56px 0; }

/* ── NAV ── */
.nav {
  position: sticky;
  top: 0;
  z-index: 100;
  height: 68px;
  display: flex;
  align-items: center;
  background: rgba(13,31,60,0.94);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--bdr);
}
.nav-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.nav-logo {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-family: var(--mono);
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 2px;
}
.nav-logo .ls { color: var(--white); }
.nav-logo .lo { color: var(--cyan-b); }
.nav-logo .ld { color: var(--tm); font-weight: 400; }
.nav-links {
  display: flex;
  align-items: center;
  gap: 28px;
}
.nav-link {
  font-size: .84rem;
  font-weight: 600;
  color: var(--tm);
  transition: color .2s;
  letter-spacing: .01em;
}
.nav-link:hover, .nav-link.active { color: var(--cyan-b); }
.nav-cta {
  background: linear-gradient(135deg, var(--cyan), #0080FF);
  color: var(--white) !important;
  font-weight: 700;
  font-size: .82rem;
  padding: .5rem 1.15rem;
  border-radius: 7px;
  transition: all .3s;
  box-shadow: 0 4px 14px rgba(76,168,255,.28);
  white-space: nowrap;
}
.nav-cta:hover {
  box-shadow: 0 6px 22px rgba(76,168,255,.5);
  transform: translateY(-1px);
}
/* Mobile nav */
.nav-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 4px;
}
.nav-hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--tg);
  border-radius: 2px;
  transition: all .3s;
}
.nav-mobile {
  display: none;
  position: fixed;
  top: 68px;
  left: 0;
  right: 0;
  background: var(--navy-mid);
  border-bottom: 1px solid var(--bdr);
  padding: 20px 24px;
  flex-direction: column;
  gap: 16px;
  z-index: 99;
}
.nav-mobile.open { display: flex; }
.nav-mobile .nav-link { font-size: .95rem; padding: 6px 0; border-bottom: 1px solid var(--bdr); }
.nav-mobile .nav-cta { text-align:center; padding: .75rem; margin-top: 4px; }

/* ── BUTTONS ── */
.btn-primary {
  display: inline-block;
  background: linear-gradient(135deg, var(--cyan), #0080FF);
  color: var(--white) !important;
  font-weight: 800;
  font-size: .9rem;
  padding: .85rem 1.8rem;
  border-radius: var(--radius);
  transition: all .3s;
  box-shadow: var(--shadow-cyan);
  letter-spacing: .01em;
  cursor: pointer;
  border: none;
}
.btn-primary:hover {
  box-shadow: 0 10px 32px rgba(76,168,255,.5);
  transform: translateY(-2px);
}
.btn-secondary {
  display: inline-block;
  background: transparent;
  border: 1.5px solid var(--yel-bdr);
  color: var(--yellow) !important;
  font-weight: 700;
  font-size: .9rem;
  padding: .85rem 1.8rem;
  border-radius: var(--radius);
  transition: all .3s;
  cursor: pointer;
}
.btn-secondary:hover {
  background: var(--yel-dim);
  border-color: var(--yellow);
}
.btn-ghost {
  display: inline-block;
  background: transparent;
  border: 1.5px solid var(--bdr-mid);
  color: var(--tg) !important;
  font-weight: 600;
  font-size: .88rem;
  padding: .75rem 1.5rem;
  border-radius: var(--radius);
  transition: all .3s;
  cursor: pointer;
}
.btn-ghost:hover {
  border-color: var(--cyan-bdr);
  color: var(--cyan-b) !important;
}

/* ── EYEBROW ── */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(0,212,255,.07);
  border: 1px solid rgba(0,212,255,.18);
  border-radius: 30px;
  padding: 6px 18px;
  font-family: var(--mono);
  font-size: .67rem;
  font-weight: 700;
  color: var(--cyan-b);
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 1.4rem;
}
.eyebrow-yellow {
  background: var(--yel-dim);
  border-color: var(--yel-bdr);
  color: var(--yellow);
}
.eyebrow-green {
  background: var(--grn-dim);
  border-color: var(--grn-bdr);
  color: var(--grn-b);
}
.live-dot {
  width: 7px; height: 7px;
  background: var(--green);
  border-radius: 50%;
  box-shadow: 0 0 6px var(--green);
  animation: pulse 2s ease infinite;
}
@keyframes pulse { 0%,100%{opacity:1;} 50%{opacity:.35;} }

/* ── TYPOGRAPHY ── */
.h-display {
  font-size: clamp(2.4rem, 4.5vw, 3.5rem);
  font-weight: 900;
  color: var(--white);
  line-height: 1.08;
  letter-spacing: -.025em;
}
.h-display .c { color: var(--cyan-b); }
.h-display .y { color: var(--yellow); }
.h-display .g { color: var(--grn-b); }
.h-xl {
  font-size: clamp(1.9rem, 3vw, 2.6rem);
  font-weight: 800;
  color: var(--white);
  line-height: 1.15;
  letter-spacing: -.02em;
}
.h-lg {
  font-size: clamp(1.4rem, 2.2vw, 1.9rem);
  font-weight: 700;
  color: var(--white);
  line-height: 1.25;
}
.h-md {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--white);
}
.lead {
  font-size: 1.05rem;
  color: var(--tg);
  line-height: 1.75;
}
.text-sm { font-size: .875rem; color: var(--tm); }
.text-mono { font-family: var(--mono); font-size: .8rem; color: var(--td); }

/* ── SECTION HEADERS ── */
.section-header { text-align:center; margin-bottom:56px; }
.section-header .h-xl { margin-bottom:.75rem; }
.section-header .lead { max-width:560px; margin:0 auto; }

/* ── CARDS ── */
.card {
  background: var(--card);
  border: 1px solid var(--bdr);
  border-radius: var(--radius-lg);
  padding: 28px;
  transition: all .3s;
}
.card:hover {
  border-color: var(--bdr-cyan);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.card-cyan { border-color: var(--cyan-bdr); }
.card-yellow { border-color: var(--yel-bdr); }
.card-green { border-color: var(--grn-bdr); }

/* ── BADGES ── */
.badge {
  display: inline-block;
  font-family: var(--mono);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 20px;
}
.badge-cyan { background: var(--cyan-dim); color: var(--cyan-b); border: 1px solid var(--cyan-bdr); }
.badge-yellow { background: var(--yel-dim); color: var(--yellow); border: 1px solid var(--yel-bdr); }
.badge-green { background: var(--grn-dim); color: var(--grn-b); border: 1px solid var(--grn-bdr); }
.badge-red { background: var(--red-dim); color: var(--red); border: 1px solid rgba(239,68,68,.2); }

/* ── GRID HELPERS ── */
.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.grid-2-1 { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }

/* ── DIVIDERS ── */
.divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--bdr-mid), transparent);
  margin: 0;
}

/* ── TRUST BAR ── */
.trust-bar {
  display: flex;
  align-items: center;
  gap: 32px;
  flex-wrap: wrap;
}
.trust-item {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: .8rem;
  font-weight: 700;
  color: var(--tm);
  letter-spacing: .02em;
}
.trust-item .ti { font-size: 14px; }
.trust-item .check { color: var(--cyan-b); }

/* ── TERMINAL / CODE BLOCK ── */
.terminal {
  background: #060D1A;
  border: 1px solid rgba(76,168,255,.2);
  border-radius: var(--radius-lg);
  overflow: hidden;
  font-family: var(--mono);
}
.terminal-bar {
  background: var(--navy-mid);
  padding: 10px 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-bottom: 1px solid var(--bdr);
}
.t-dot { width:11px; height:11px; border-radius:50%; }
.t-red { background:#FF5F56; }
.t-yel { background:#FFBD2E; }
.t-grn { background:#27C93F; }
.terminal-url {
  flex: 1;
  text-align: center;
  font-size: .72rem;
  color: var(--td);
}
.terminal-body { padding: 20px 24px; font-size: .82rem; line-height: 1.8; }
.t-line { display:flex; gap:12px; }
.t-prompt { color: var(--cyan-b); }
.t-cmd { color: var(--white); }
.t-out { color: var(--tm); }
.t-ok { color: var(--green); }
.t-warn { color: var(--yellow); }
.t-err { color: var(--red); }
.t-score { color: var(--cyan-b); font-weight:700; font-size:1.1rem; }

/* ── STAT BLOCKS ── */
.stat-block { text-align:center; }
.stat-number {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 900;
  color: var(--white);
  line-height: 1;
  margin-bottom: 4px;
}
.stat-number .c { color: var(--cyan-b); }
.stat-number .y { color: var(--yellow); }
.stat-label { font-size: .85rem; color: var(--tm); line-height: 1.4; }

/* ── CHECK LIST ── */
.check-list { display:flex; flex-direction:column; gap:10px; }
.check-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .9rem;
  color: var(--tg);
}
.check-item .ci { color: var(--cyan-b); flex-shrink:0; margin-top:2px; }
.check-item .ci-y { color: var(--yellow); }
.check-item .ci-g { color: var(--grn-b); }

/* ── CTA BLOCK ── */
.cta-block {
  background: linear-gradient(135deg, var(--navy-mid) 0%, #0E2248 100%);
  border: 1px solid var(--bdr-mid);
  border-radius: var(--radius-lg);
  padding: 56px 48px;
  text-align: center;
}
.cta-row { display:flex; gap:12px; flex-wrap:wrap; justify-content:center; }

/* ── FOOTER ── */
.footer {
  background: var(--navy-mid);
  border-top: 1px solid var(--bdr);
  padding: 56px 0 32px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 48px;
}
.footer-brand { display:flex; align-items:center; gap:.4rem; font-family:var(--mono); font-size:1rem; font-weight:700; letter-spacing:2px; margin-bottom:12px; }
.footer-brand .ls { color:var(--white); }
.footer-brand .lo { color:var(--cyan-b); }
.footer-brand .ld { color:var(--tm); font-weight:400; }
.footer-tagline { font-size:.85rem; color:var(--td); line-height:1.6; max-width:240px; }
.footer-col h4 { font-size:.78rem; font-weight:700; color:var(--tm); letter-spacing:1.5px; text-transform:uppercase; font-family:var(--mono); margin-bottom:14px; }
.footer-col a { display:block; font-size:.88rem; color:var(--td); margin-bottom:8px; transition:color .2s; }
.footer-col a:hover { color:var(--cyan-b); }
.footer-bottom {
  border-top: 1px solid var(--bdr);
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
}
.footer-bottom p { font-size:.8rem; color:var(--td); }
.footer-sdvosb {
  font-family: var(--mono);
  font-size: .68rem;
  font-weight: 700;
  color: var(--yellow);
  background: var(--yel-dim);
  border: 1px solid var(--yel-bdr);
  padding: 4px 12px;
  border-radius: 5px;
  letter-spacing: 1px;
}

/* ── FORM INPUTS ── */
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-label { font-size:.8rem; font-weight:700; color:var(--tm); letter-spacing:.5px; }
.form-input {
  background: var(--navy-mid);
  border: 1px solid var(--bdr-mid);
  border-radius: var(--radius);
  padding: .75rem 1rem;
  color: var(--white);
  font-family: var(--font);
  font-size: .9rem;
  transition: border-color .2s;
  outline: none;
  width: 100%;
}
.form-input:focus { border-color: var(--cyan); }
.form-input::placeholder { color: var(--td); }
textarea.form-input { resize: vertical; min-height: 100px; }

/* ── GLOW BACKGROUNDS ── */
.glow-cyan {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
  background: radial-gradient(circle, rgba(76,168,255,.07) 0%, transparent 70%);
}
.glow-yellow {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
  background: radial-gradient(circle, rgba(254,188,46,.05) 0%, transparent 70%);
}

/* ── ICON BLOCKS ── */
.icon-block {
  width: 48px; height: 48px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  margin-bottom: 16px;
  background: var(--cyan-dim);
  border: 1px solid var(--cyan-bdr);
}
.icon-block-yellow { background: var(--yel-dim); border-color: var(--yel-bdr); }
.icon-block-green { background: var(--grn-dim); border-color: var(--grn-bdr); }

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .section { padding: 64px 0; }
  .grid-2, .grid-3, .grid-2-1 { grid-template-columns: 1fr; }
  .grid-4 { grid-template-columns: 1fr; }
  .nav-links { display: none; }
  .nav-hamburger { display: flex; }
  .cta-block { padding: 40px 24px; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
  .h-display { font-size: 2.2rem; }
  .section-header { margin-bottom: 40px; }
}
@media (max-width: 480px) {
  .container { padding: 0 16px; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; text-align: center; }
}
