/* =========================================================
   CYBERVATE — design tokens
   ========================================================= */
:root{
  --cv-bg:        #080B14;
  --cv-bg-soft:   #0D1322;
  --cv-surface:   #121A2E;
  --cv-surface-2: #161F38;
  --cv-border:    rgba(255,255,255,.08);
  --cv-border-2:  rgba(255,255,255,.14);

  --cv-blue:      #2F5BFF;
  --cv-cyan:      #3FC5F0;
  --cv-green:     #00E0A4;
  --cv-amber:     #FFB23F;
  --cv-red:       #FF5470;

  --cv-text:      #F4F6FC;
  --cv-text-dim:  #8B93A7;
  --cv-text-dim2: #5C6480;

  --cv-grad:      linear-gradient(95deg, var(--cv-blue) 0%, var(--cv-cyan) 100%);
  --cv-grad-soft: linear-gradient(95deg, rgba(47,91,255,.18), rgba(63,197,240,.18));

  --cv-font-display: 'Space Grotesk', sans-serif;
  --cv-font-body: 'Inter', sans-serif;
  --cv-font-mono: 'JetBrains Mono', monospace;

  --cv-radius: 16px;
  --cv-radius-sm: 10px;
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior:auto !important; }
}

*{ box-sizing:border-box; }
html{
  scroll-behavior:smooth;
  overflow-x:hidden;
  width:100%;
}
body{
  background: var(--cv-bg);
  color: var(--cv-text);
  font-family: var(--cv-font-body);
  font-size: 16px;
  line-height: 1.65;
  overflow-x: hidden;
  width:100%;
  position: relative;
}

/* =========================================================
   PRELOADER
   ========================================================= */
body.cv-loading{ overflow:hidden; }
.cv-preloader{
  position: fixed; inset: 0; z-index: 9999;
  display:flex; align-items:center; justify-content:center;
  background: var(--cv-bg);
  transition: opacity .6s ease, visibility .6s ease;
}
.cv-preloader.is-hidden{ opacity:0; visibility:hidden; pointer-events:none; }
.cv-preloader__inner{ display:flex; flex-direction:column; align-items:center; gap:1.6rem; }
.cv-preloader__icon{
  width: 72px; height:72px; object-fit: contain;
  filter: drop-shadow(0 0 24px rgba(63,197,240,.45));
  animation: cvPreloaderPop .7s cubic-bezier(.34,1.56,.64,1) both, cvPreloaderFloat 2.2s ease-in-out .7s infinite;
}
@keyframes cvPreloaderPop{
  0%{ opacity:0; transform: scale(.4) rotate(-8deg); }
  60%{ opacity:1; transform: scale(1.08) rotate(2deg); }
  100%{ opacity:1; transform: scale(1) rotate(0); }
}
@keyframes cvPreloaderFloat{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-6px); }
}
.cv-preloader__bar{
  width: 140px; height:3px; border-radius:3px; background: rgba(255,255,255,.08); overflow:hidden;
}
.cv-preloader__bar span{
  display:block; height:100%; width:40%; border-radius:3px;
  background: var(--cv-grad);
  animation: cvPreloaderBar 1.1s ease-in-out infinite;
}
@keyframes cvPreloaderBar{
  0%{ transform: translateX(-100%); }
  100%{ transform: translateX(350%); }
}
@media (prefers-reduced-motion: reduce){
  .cv-preloader__icon, .cv-preloader__bar span{ animation: none; }
}

a{ color: inherit; text-decoration:none; }
::selection{ background: var(--cv-blue); color:#fff; }

h1,h2,h3,h4,h5,h6{ font-family: var(--cv-font-display); font-weight:600; letter-spacing:-.01em; }
.cv-mono{ font-family: var(--cv-font-mono); }

:focus-visible{ outline: 2px solid var(--cv-cyan); outline-offset: 3px; border-radius: 4px; }

/* =========================================================
   BACKDROP — grid + glow blobs (fixed, behind everything)
   ========================================================= */
.bg-grid{
  position: fixed; inset:0; z-index:-2; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 0%, black 40%, transparent 90%);
}
.bg-glow{ position:fixed; z-index:-1; pointer-events:none; border-radius:50%; filter: blur(90px); opacity:.35; }
.bg-glow--a{ width:560px; height:560px; top:-180px; left:-120px; background: var(--cv-blue); animation: drift1 22s ease-in-out infinite; }
.bg-glow--b{ width:480px; height:480px; top:30%; right:-160px; background: var(--cv-cyan); opacity:.22; animation: drift2 26s ease-in-out infinite; }
@keyframes drift1{ 0%,100%{ transform: translate(0,0); } 50%{ transform: translate(60px, 40px); } }
@keyframes drift2{ 0%,100%{ transform: translate(0,0); } 50%{ transform: translate(-50px, -60px); } }

/* =========================================================
   NAVBAR
   ========================================================= */
.cv-navbar{
  background: rgba(8,11,20,.55);
  backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--cv-border);
  padding: .85rem 0;
  transition: background .3s, padding .3s, border-color .3s;
  z-index: 1000;
}
.cv-navbar.is-scrolled{ background: rgba(8,11,20,.85); padding:.55rem 0; border-bottom-color: var(--cv-border-2); }

.cv-brand{ display:flex; align-items:center; }
.cv-brand__logo{ height:30px; width:auto; display:block; }
.cv-brand__logo--footer{ height:32px; }

.cv-nav-link{ color: var(--cv-text-dim) !important; font-weight:500; font-size:.95rem; padding: .5rem .9rem !important; position:relative; transition:color .2s; }
.cv-nav-link:hover, .cv-nav-link.active{ color:#fff !important; }
.cv-nav-link.active::after{
  content:""; position:absolute; left:.9rem; right:.9rem; bottom:.1rem; height:2px; background: var(--cv-grad); border-radius:2px;
}
.navbar-toggler.cv-toggler{
  display:none; border:1px solid var(--cv-border-2); border-radius: 10px; padding:.5rem .6rem;
  background: rgba(255,255,255,.03); position:relative; z-index:1100; line-height:0;
}
.navbar-toggler.cv-toggler:focus{ box-shadow: 0 0 0 3px rgba(63,197,240,.2); }
.cv-toggler-icon{
  display:inline-grid; grid-template-columns: repeat(3, 5px); grid-template-rows: repeat(3, 5px);
  gap:3px; width:21px; height:21px;
}
.cv-toggler-icon span{
  display:block; width:5px; height:5px; border-radius:1.5px;
  background: var(--cv-cyan); opacity:.85; transition: background .25s, opacity .25s, transform .25s;
}
/* subtle diagonal "data" pulse across the grid, like a matrix code grid */
.cv-toggler-icon span:nth-child(1),.cv-toggler-icon span:nth-child(5),.cv-toggler-icon span:nth-child(9){ background: var(--cv-grad); opacity:1; }
.navbar-toggler.cv-toggler[aria-expanded="true"] .cv-toggler-icon span{ background: var(--cv-text-dim2); opacity:.5; }
.navbar-toggler.cv-toggler[aria-expanded="true"] .cv-toggler-icon span:nth-child(1),
.navbar-toggler.cv-toggler[aria-expanded="true"] .cv-toggler-icon span:nth-child(5),
.navbar-toggler.cv-toggler[aria-expanded="true"] .cv-toggler-icon span:nth-child(9){ background: var(--cv-cyan); opacity:1; }
@media (max-width: 991.98px){
  .navbar-toggler.cv-toggler{ display:inline-flex !important; align-items:center; justify-content:center; }
}

/* =========================================================
   NAV DROPDOWNS (Products / Solutions)
   ========================================================= */
.cv-dropdown .dropdown-toggle::after{ vertical-align: 2px; opacity:.6; }
.cv-dropdown-menu{
  background: var(--cv-surface); border:1px solid var(--cv-border-2); border-radius: var(--cv-radius);
  padding: .6rem; box-shadow: 0 24px 50px -20px rgba(0,0,0,.65); margin-top: .6rem !important;
  min-width: 280px;
}
.cv-dropdown-item{
  display:flex; align-items:flex-start; gap:.7rem; padding:.6rem .7rem; border-radius: var(--cv-radius-sm);
  color: var(--cv-text-dim); transition: background .2s, color .2s; white-space:normal;
}
.cv-dropdown-item:hover, .cv-dropdown-item:focus{ background: rgba(255,255,255,.05); color:#fff; }
.cv-dropdown-item__icon{
  flex:none; width:30px; height:30px; border-radius:9px; display:flex; align-items:center; justify-content:center;
  background: var(--cv-grad-soft); border:1px solid var(--cv-border-2); color: var(--cv-cyan); margin-top:1px;
}
.cv-dropdown-item__title{ display:block; font-size:.88rem; font-weight:600; color:#fff; }
.cv-dropdown-item__tag{ display:block; font-family: var(--cv-font-mono); font-size:.72rem; color: var(--cv-text-dim2); margin-top:1px; }
.cv-dropdown-item--all{ justify-content:center; font-weight:600; color: var(--cv-cyan); }
.cv-dropdown-divider{ border-color: var(--cv-border); margin:.4rem 0; }
@media (min-width: 992px){
  .cv-dropdown-menu--grid.show{
    width: 600px; min-width: 600px; max-height:none; overflow:visible;
    display:grid; grid-template-columns: 1fr 1fr; gap:.15rem .5rem; padding: .9rem;
  }
  .cv-dropdown-menu--grid li{ display:contents; }
  .cv-dropdown-menu--grid .cv-dropdown-span2 > *{ grid-column: 1 / -1; }
}
@media (max-width: 991.98px){
  .cv-dropdown-menu{ background: rgba(255,255,255,.03); border-color: var(--cv-border); box-shadow:none; }
}

/* =========================================================
   CUSTOM NETWORK CURSOR
   ========================================================= */
body.cv-custom-cursor, body.cv-custom-cursor a, body.cv-custom-cursor button,
body.cv-custom-cursor .cv-btn, body.cv-custom-cursor .nav-link{ cursor:none; }
body.cv-custom-cursor input, body.cv-custom-cursor textarea, body.cv-custom-cursor select{ cursor:auto !important; }
#cvCursorCanvas{ position:fixed; inset:0; z-index:100000; pointer-events:none; width:100%; height:100%; }
@media (pointer: coarse){
  #cvCursorCanvas{ display:none; }
}

/* =========================================================
   BUTTONS
   ========================================================= */
.cv-btn{
  font-family: var(--cv-font-display); font-weight:600; font-size:.92rem;
  padding: .68rem 1.4rem; border-radius: 999px; border:1px solid transparent;
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem; white-space:nowrap;
}
.cv-btn--primary{ background: var(--cv-grad); color:#04060C; box-shadow: 0 8px 24px -8px rgba(63,197,240,.55); }
.cv-btn--primary:hover{ transform: translateY(-2px); box-shadow: 0 12px 30px -6px rgba(63,197,240,.7); color:#04060C; }
.cv-btn--ghost-glow{ background: rgba(255,255,255,.04); border-color: var(--cv-border-2); color:#fff; }
.cv-btn--ghost-glow:hover{ border-color: var(--cv-cyan); box-shadow: 0 0 0 1px var(--cv-cyan) inset, 0 8px 22px -10px rgba(63,197,240,.6); color:#fff; transform: translateY(-2px); }
.cv-btn--lg{ padding:.9rem 1.9rem; font-size:1rem; }
.cv-btn--block{ width:100%; }

/* =========================================================
   SECTION SCAFFOLDING
   ========================================================= */
.cv-section{ padding: 6.5rem 0; position:relative; }
.cv-section--tight{ padding: 4.5rem 0; }
.cv-eyebrow{
  font-family: var(--cv-font-mono); font-size:.78rem; letter-spacing:.12em; text-transform:uppercase;
  color: var(--cv-cyan); display:inline-flex; align-items:center; gap:.5rem; margin-bottom:1rem;
}
.cv-eyebrow::before{ content:""; width:7px; height:7px; border-radius:50%; background: var(--cv-green); box-shadow: 0 0 10px var(--cv-green); }
.cv-heading{ font-size: clamp(1.9rem, 3.4vw, 2.7rem); color:#fff; margin-bottom: 1rem; }
.cv-sub{ color: var(--cv-text-dim); font-size:1.08rem; max-width: 640px; }
.cv-divider{ height:1px; background: linear-gradient(90deg, transparent, var(--cv-border-2), transparent); }

/* =========================================================
   HERO
   ========================================================= */
.cv-hero{ padding: 9.5rem 0 5rem; position:relative; }
.cv-hero__badge{
  display:inline-flex; align-items:center; gap:.55rem; font-family: var(--cv-font-mono); font-size:.8rem;
  color: var(--cv-text-dim); border:1px solid var(--cv-border-2); border-radius:999px; padding:.4rem .9rem; background: rgba(255,255,255,.03);
}
.cv-hero__title{ font-size: clamp(2.4rem, 5vw, 3.85rem); line-height:1.07; color:#fff; margin:1.3rem 0 1.2rem; }
.cv-hero__title .cv-grad-text{
  background: var(--cv-grad); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.cv-hero__lead{ color: var(--cv-text-dim); font-size:1.15rem; max-width:540px; margin-bottom: 2rem; }
.cv-hero__cta{ display:flex; gap:1rem; flex-wrap:wrap; }

.cv-hero__stats{ display:flex; gap:2.2rem; margin-top:3rem; flex-wrap:wrap; }
.cv-hero__stat-num{ font-family:var(--cv-font-display); font-size:1.7rem; color:#fff; font-weight:700; }
.cv-hero__stat-label{ font-size:.8rem; color: var(--cv-text-dim2); text-transform:uppercase; letter-spacing:.06em; }

/* --- Terminal panel (signature element) --- */
.cv-terminal{
  background: linear-gradient(180deg, var(--cv-surface), var(--cv-bg-soft));
  border:1px solid var(--cv-border-2); border-radius: var(--cv-radius);
  box-shadow: 0 30px 70px -30px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.02) inset;
  overflow:hidden; transform: perspective(1200px) rotateY(-2deg) rotateX(1deg);
}
.cv-terminal__bar{
  display:flex; align-items:center; gap:.5rem; padding:.7rem 1rem; background: rgba(255,255,255,.03); border-bottom:1px solid var(--cv-border);
}
.cv-terminal__dot{ width:10px; height:10px; border-radius:50%; }
.cv-terminal__dot--r{ background:#FF5F56; } .cv-terminal__dot--y{ background:#FFBD2E; } .cv-terminal__dot--g{ background:#27C93F; }
.cv-terminal__title{ margin-left:auto; margin-right:auto; font-family: var(--cv-font-mono); font-size:.75rem; color: var(--cv-text-dim2); }
.cv-terminal__body{ padding:1.1rem 1.2rem; font-family: var(--cv-font-mono); font-size:.82rem; color:#A7E7FF; height: 300px; overflow:hidden; position:relative; }
.cv-terminal__line{ white-space:nowrap; opacity:0; animation: cvLineIn .4s ease forwards; margin-bottom:.45rem; }
.cv-terminal__line .ok{ color: var(--cv-green); }
.cv-terminal__line .warn{ color: var(--cv-amber); }
.cv-terminal__line .bad{ color: var(--cv-red); }
.cv-terminal__line .dim{ color: var(--cv-text-dim2); }
.cv-terminal__cursor{ display:inline-block; width:7px; height:14px; background: var(--cv-cyan); vertical-align:-2px; animation: blink 1s step-end infinite; }
@keyframes cvLineIn{ to{ opacity:1; } }
@keyframes blink{ 50%{ opacity:0; } }

/* network map svg pulses */
.cv-netmap__node{ animation: nodePulse 2.4s ease-in-out infinite; }
.cv-netmap__node--2{ animation-delay:.4s; } .cv-netmap__node--3{ animation-delay:.8s; } .cv-netmap__node--4{ animation-delay:1.2s; }
@keyframes nodePulse{ 0%,100%{ opacity:.55; r:4; } 50%{ opacity:1; r:6; } }
.cv-netmap__packet{ animation: packetMove linear infinite; }
@keyframes packetMove{ 0%{ offset-distance: 0%; opacity:0;} 8%{opacity:1;} 92%{opacity:1;} 100%{ offset-distance: 100%; opacity:0; } }

/* =========================================================
   LOGO STRIP / MARQUEE
   ========================================================= */
.cv-marquee{ overflow:hidden; position:relative; mask-image: linear-gradient(90deg, transparent, black 12%, black 88%, transparent); }
.cv-marquee__track{ display:flex; gap:3.5rem; width:max-content; animation: marquee 28s linear infinite; }
@keyframes marquee{ from{ transform: translateX(0); } to{ transform: translateX(-50%); } }
.cv-marquee__item{ font-family: var(--cv-font-mono); color: var(--cv-text-dim2); font-size:.95rem; letter-spacing:.04em; white-space:nowrap; }

/* =========================================================
   CARDS — products / features
   ========================================================= */
.cv-card{
  background: linear-gradient(160deg, var(--cv-surface), var(--cv-bg-soft));
  border:1px solid var(--cv-border); border-radius: var(--cv-radius);
  padding: 1.9rem; height:100%; position:relative; overflow:hidden;
  transition: transform .35s ease, border-color .35s ease, box-shadow .35s ease;
}
.cv-card::before{
  content:""; position:absolute; inset:-1px; border-radius: inherit; padding:1px;
  background: var(--cv-grad); opacity:0; transition: opacity .35s ease;
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude; pointer-events:none;
}
.cv-card:hover{ transform: translateY(-6px); box-shadow: 0 24px 50px -24px rgba(63,197,240,.25); }
.cv-card:hover::before{ opacity:1; }
.cv-card__icon{
  width:50px; height:50px; border-radius: 13px; display:flex; align-items:center; justify-content:center;
  background: var(--cv-grad-soft); border:1px solid var(--cv-border-2); margin-bottom:1.2rem; color: var(--cv-cyan); font-size:1.35rem;
}
.cv-card__tag{ font-family: var(--cv-font-mono); font-size:.72rem; color: var(--cv-text-dim2); letter-spacing:.08em; text-transform:uppercase; }
.cv-card h3{ font-size:1.18rem; color:#fff; margin:.5rem 0 .65rem; }
.cv-card p{ color: var(--cv-text-dim); font-size:.93rem; margin-bottom:0; }
.cv-card__link{ display:inline-flex; align-items:center; gap:.4rem; margin-top:1.1rem; font-size:.85rem; font-weight:600; color: var(--cv-cyan); }
.cv-card__link svg{ transition: transform .25s; }
.cv-card:hover .cv-card__link svg{ transform: translateX(4px); }

/* Contact page info cards (Email / NOC hotline / Headquarters) — kept a
   consistent height and internal rhythm regardless of how much copy each one has. */
.cv-contact-card{
  min-height: 168px; height:auto; display:flex; flex-direction:column; justify-content:center;
}
.cv-contact-card .cv-card__icon{ margin-bottom: 1rem; }
.cv-contact-card h3{ margin-top:0; }
.cv-contact-card p + p{ margin-top:.35rem; }
@media (max-width: 575.98px){
  .cv-contact-card{ min-height: 0; }
}

/* product page detail block */
.cv-product-block{ padding: 4.5rem 0; border-bottom:1px solid var(--cv-border); }
.cv-product-block:last-of-type{ border-bottom:none; }
.cv-product-block__num{ font-family: var(--cv-font-mono); color: var(--cv-text-dim2); font-size:.85rem; }
.cv-product-block__visual{
  background: linear-gradient(160deg, var(--cv-surface), var(--cv-bg-soft)); border:1px solid var(--cv-border-2); border-radius: var(--cv-radius);
  padding: 1.6rem; height:100%;
}
.cv-spec-list{ list-style:none; padding:0; margin:1.4rem 0 0; display:grid; gap:.6rem; }
.cv-spec-list li{ display:flex; gap:.6rem; color: var(--cv-text-dim); font-size:.95rem; align-items:flex-start; }
.cv-spec-list li svg{ flex:none; margin-top:3px; color: var(--cv-green); }

/* gauges / meter bars used on product visuals */
.cv-meter{ margin-bottom:1rem; }
.cv-meter__top{ display:flex; justify-content:space-between; font-family: var(--cv-font-mono); font-size:.78rem; color: var(--cv-text-dim); margin-bottom:.4rem; }
.cv-meter__track{ height:8px; border-radius:6px; background: rgba(255,255,255,.06); overflow:hidden; }
.cv-meter__fill{ height:100%; border-radius:6px; background: var(--cv-grad); width:0%; transition: width 1.4s cubic-bezier(.16,1,.3,1); }

/* =========================================================
   STAT STRIP
   ========================================================= */
.cv-stat-strip{ border-top:1px solid var(--cv-border); border-bottom:1px solid var(--cv-border); background: rgba(255,255,255,.015); }
.cv-stat{ text-align:center; padding: 2.6rem 1rem; }
.cv-stat__num{ font-family: var(--cv-font-display); font-size: clamp(2rem,4vw,2.6rem); color:#fff; font-weight:700; }
.cv-stat__num .cv-grad-text{ background: var(--cv-grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.cv-stat__label{ color: var(--cv-text-dim); font-size:.88rem; margin-top:.3rem; }

/* =========================================================
   TIMELINE / PROCESS (used sparingly — onboarding, real sequence)
   ========================================================= */
.cv-flow{ position:relative; padding-left: 2.6rem; }
.cv-flow::before{ content:""; position:absolute; left:11px; top:6px; bottom:6px; width:2px; background: linear-gradient(180deg, var(--cv-blue), var(--cv-cyan), transparent); }
.cv-flow__step{ position:relative; padding-bottom: 2.4rem; }
.cv-flow__step::before{ content:""; position:absolute; left:-2.6rem; top:2px; width:14px; height:14px; border-radius:50%; background: var(--cv-bg); border:2px solid var(--cv-cyan); box-shadow:0 0 0 4px rgba(63,197,240,.12); }
.cv-flow__step h4{ color:#fff; font-size:1.05rem; margin-bottom:.4rem; }
.cv-flow__step p{ color: var(--cv-text-dim); margin:0; font-size:.93rem; }

/* =========================================================
   TABS (solutions by audience)
   ========================================================= */
.cv-tabbar{ display:flex; gap:.6rem; flex-wrap:wrap; border-bottom:1px solid var(--cv-border); padding-bottom: 1.2rem; }
.cv-tabbtn{
  font-family: var(--cv-font-display); font-weight:600; font-size:.9rem; color: var(--cv-text-dim);
  background: transparent; border:1px solid var(--cv-border-2); border-radius:999px; padding:.55rem 1.2rem; transition: all .25s;
}
.cv-tabbtn.active, .cv-tabbtn:hover{ color:#04060C; background: var(--cv-grad); border-color:transparent; }

/* =========================================================
   QUOTE / CTA BAND
   ========================================================= */
.cv-cta-band{
  background: radial-gradient(circle at 20% 20%, rgba(47,91,255,.25), transparent 60%), radial-gradient(circle at 80% 80%, rgba(63,197,240,.2), transparent 60%), var(--cv-surface);
  border:1px solid var(--cv-border-2); border-radius: 24px; padding: 3.6rem; text-align:center; position:relative; overflow:hidden;
}

/* =========================================================
   FORMS (contact)
   ========================================================= */
.cv-field label{ font-size:.85rem; color: var(--cv-text-dim); margin-bottom:.4rem; display:block; font-weight:500; }
.cv-field .form-control, .cv-field .form-select{
  background: rgba(255,255,255,.03); border:1px solid var(--cv-border-2); color:#fff; border-radius: var(--cv-radius-sm);
  padding:.75rem 1rem; font-family: var(--cv-font-body);
}
.cv-field .form-control::placeholder{ color: var(--cv-text-dim2); }
.cv-field .form-control:focus, .cv-field .form-select:focus{
  background: rgba(255,255,255,.05); border-color: var(--cv-cyan); box-shadow: 0 0 0 3px rgba(63,197,240,.15); color:#fff;
}

/* =========================================================
   FOOTER
   ========================================================= */
.cv-footer{ background: var(--cv-bg-soft); border-top:1px solid var(--cv-border); padding: 4.5rem 0 1.6rem; margin-top: 4rem; }
.cv-footer__tagline{ color: var(--cv-text-dim); font-size:.92rem; margin: 1.1rem 0 1.2rem; max-width:320px; }
.cv-footer__address{ display:flex; gap:.5rem; align-items:flex-start; color: var(--cv-text-dim); font-size:.85rem; max-width:300px; margin-bottom:1.1rem; }
.cv-footer__address svg{ color: var(--cv-cyan); margin-top:2px; }
.cv-footer__status{ display:flex; align-items:center; gap:.5rem; font-family: var(--cv-font-mono); font-size:.8rem; color: var(--cv-green); }
.cv-pulse-dot{ width:8px; height:8px; border-radius:50%; background: var(--cv-green); box-shadow:0 0 0 0 rgba(0,224,164,.6); animation: pulseDot 1.8s infinite; }
@keyframes pulseDot{ 0%{ box-shadow:0 0 0 0 rgba(0,224,164,.55);} 70%{ box-shadow:0 0 0 8px rgba(0,224,164,0);} 100%{ box-shadow:0 0 0 0 rgba(0,224,164,0);} }
.cv-footer__head{ font-family: var(--cv-font-mono); font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; color:#fff; margin-bottom:1.1rem; }
.cv-footer__list{ list-style:none; padding:0; margin:0; display:grid; gap:.65rem; }
.cv-footer__list a{ color: var(--cv-text-dim); font-size:.9rem; transition: color .2s; }
.cv-footer__list a:hover{ color: var(--cv-cyan); }
.cv-footer__list--mono li{ font-family: var(--cv-font-mono); color: var(--cv-text-dim); font-size:.85rem; }
.cv-footer__rule{ border-color: var(--cv-border); margin: 2.6rem 0 1.4rem; }
.cv-footer__bottom{ color: var(--cv-text-dim2); font-size:.84rem; }

/* =========================================================
   LEGAL / ARTICLE PAGES
   ========================================================= */
.cv-article{ max-width: 760px; }
.cv-article h2{ color:#fff; font-size:1.5rem; margin-top:2.6rem; margin-bottom:1rem; scroll-margin-top: 110px; }
.cv-article h2:first-of-type{ margin-top:0; }
.cv-article h3{ color:#fff; font-size:1.1rem; margin-top:1.6rem; margin-bottom:.7rem; }
.cv-article p, .cv-article li{ color: var(--cv-text-dim); font-size:.98rem; line-height:1.8; }
.cv-article ul, .cv-article ol{ padding-left:1.3rem; margin-bottom:1.1rem; }
.cv-article li{ margin-bottom:.5rem; }
.cv-article strong{ color:#fff; }
.cv-article a{ color: var(--cv-cyan); text-decoration: underline; text-decoration-color: rgba(63,197,240,.3); }
.cv-toc{ background: var(--cv-surface); border:1px solid var(--cv-border-2); border-radius: var(--cv-radius); padding:1.6rem; position:sticky; top:100px; }
.cv-toc__title{ font-family: var(--cv-font-mono); font-size:.75rem; text-transform:uppercase; letter-spacing:.08em; color: var(--cv-text-dim2); margin-bottom:1rem; }
.cv-toc ul{ list-style:none; padding:0; margin:0; display:grid; gap:.65rem; }
.cv-toc a{ color: var(--cv-text-dim); font-size:.88rem; text-decoration:none; transition: color .2s; }
.cv-toc a:hover{ color: var(--cv-cyan); }
.cv-updated{ font-family: var(--cv-font-mono); font-size:.8rem; color: var(--cv-text-dim2); }

/* status page */
.cv-status-row{ display:flex; align-items:center; justify-content:space-between; padding: 1.1rem 1.4rem; border:1px solid var(--cv-border); border-radius: var(--cv-radius-sm); background: var(--cv-surface); margin-bottom: .8rem; }
.cv-status-pill{ display:inline-flex; align-items:center; gap:.5rem; font-family: var(--cv-font-mono); font-size:.78rem; padding:.3rem .7rem; border-radius:999px; }
.cv-status-pill--ok{ background: rgba(0,224,164,.1); color: var(--cv-green); border:1px solid rgba(0,224,164,.3); }

/* scroll reveal helper fallback when AOS absent */
.cv-fade-up{ opacity:0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }
.cv-fade-up.is-visible{ opacity:1; transform:none; }

@media (max-width: 991.98px){
  .cv-hero{ padding-top: 7.5rem; text-align:center; }
  .cv-hero__cta{ justify-content:center; }
  .cv-hero__stats{ justify-content:center; }
  .cv-terminal{ transform:none; margin-top: 2.5rem; }
  .navbar-collapse{
    background: var(--cv-bg-soft); border:1px solid var(--cv-border); border-radius: var(--cv-radius); margin-top:1rem; padding:1rem;
    max-height: calc(100vh - 100px); overflow-y: auto; -webkit-overflow-scrolling: touch;
  }
  .cv-dropdown-menu{ max-height: none; }
}
