/* ===========================================================
   vd-shared.css — VINdicated.ai shared header, footer, tokens
   Drop into every page's <head> via:
     <link rel="stylesheet" href="/vd-shared.css">

   Required fonts (also load these in every page's <head>):
     <link href="https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;0,900;1,400&family=Inter:wght@300;400;500;600;700&family=Fraunces:opsz,wght@9..144,400;9..144,600;9..144,700;9..144,800;9..144,900&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap" rel="stylesheet">
   =========================================================== */

:root {
  --vd-ink: #0B1437;
  --vd-ink-2: #1E3A8A;
  --vd-ink-3: #001F3F;
  --vd-red: #FF4136;
  --vd-paper: #F4F6FA;
  --vd-paper-2: #EAEEF5;
  --vd-line: rgba(11,20,55,0.10);
  --vd-grain: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.06 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
}

/* Reserve space for fixed nav on every page */
body { padding-top: 82px; background: #FFFFFF; }
@media (max-width: 768px) { body { padding-top: 76px; } }

/* =====================================================
   FLOATING GLASS NAV PILL
   ===================================================== */
.vd-nav {
  position: fixed;
  top: 14px;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - 32px);
  max-width: 1180px;
  background: rgba(255,255,255,0.78);
  backdrop-filter: saturate(180%) blur(22px);
  -webkit-backdrop-filter: saturate(180%) blur(22px);
  border: 1px solid rgba(11,20,55,0.08);
  border-radius: 999px;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 12px 32px -8px rgba(11,20,55,0.14),
    0 4px 16px -4px rgba(11,20,55,0.08);
  padding: 4px 6px 4px 14px;
  z-index: 9999;
  font-family: 'Plus Jakarta Sans','Inter',-apple-system,BlinkMacSystemFont,sans-serif;
}
.vd-nav-inner { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.vd-nav-logo-block { display: flex; align-items: center; gap: 6px; text-decoration: none; }
.vd-nav-logo-block img { height: 38px; width: auto; display: block; }
.vd-nav-logo { font-family: 'Fraunces','Playfair Display',Georgia,serif; font-size: 18px; font-weight: 800; letter-spacing: -0.02em; color: var(--vd-ink); line-height: 1; }
.vd-nav-logo span { color: var(--vd-red); }
.vd-nav-tagline { font-family: 'Inter','Plus Jakarta Sans',sans-serif; font-size: 10px; font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(11,20,55,0.55); margin-top: 2px; }
.vd-nav-desktop { display: flex; align-items: center; gap: 2px; }

.vd-btn-ghost {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 12.5px; font-weight: 600; color: var(--vd-ink);
  text-decoration: none; padding: 7px 12px; border-radius: 999px;
  border: 1px solid transparent; background: transparent;
  transition: background .2s ease, color .2s ease;
}
.vd-btn-ghost:hover { background: rgba(11,20,55,0.06); }
.vd-btn-ghost.vd-active { background: rgba(30,58,138,0.10); color: var(--vd-ink-2); }
.vd-btn-cta {
  background: var(--vd-ink) !important;
  color: #fff !important;
  font-weight: 700 !important;
  margin-left: 6px;
  padding: 9px 16px !important;
}
.vd-btn-cta:hover { background: var(--vd-red) !important; }
.vd-pill { background: var(--vd-ink-2); color: #fff; font-size: 10px; font-weight: 700; padding: 2px 6px; border-radius: 4px; letter-spacing: 0.04em; }
.vd-ext { font-size: 11px; color: var(--vd-ink-2); font-weight: 700; }

.vd-mobile-btn {
  display: none;
  background: none; border: 1.5px solid var(--vd-ink-2);
  border-radius: 8px; padding: 8px 10px; cursor: pointer;
  flex-direction: column; gap: 5px; align-items: center; justify-content: center;
}
.vd-mobile-btn span { display: block; width: 20px; height: 2px; background: var(--vd-ink-2); border-radius: 2px; transition: all 0.2s; }

.vd-mobile-menu {
  display: none;
  position: fixed; top: 78px; left: 16px; right: 16px;
  flex-direction: column;
  background: rgba(252,251,248,0.96);
  backdrop-filter: blur(18px);
  border: 1px solid rgba(11,20,55,0.08);
  border-radius: 20px;
  box-shadow: 0 20px 60px -10px rgba(11,20,55,0.25);
  padding: 12px 20px 16px;
  z-index: 9998;
}
.vd-mobile-menu.vd-open { display: flex; }
.vd-mobile-link {
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-size: 15px; font-weight: 500; color: var(--vd-ink-2);
  text-decoration: none; padding: 12px 0;
  border-bottom: 1px solid #F3F4F6;
  display: flex; justify-content: space-between; align-items: center;
}
.vd-mobile-link.vd-active { color: var(--vd-red); }
.vd-mobile-link:last-child { border-bottom: none; }
.vd-mobile-cta {
  font-weight: 600 !important;
  color: #fff !important;
  background: var(--vd-red);
  padding: 14px 16px !important;
  border-radius: 9999px;
  text-align: center;
  justify-content: center;
  margin-top: 12px;
  border-bottom: none !important;
}

@media (max-width: 768px) {
  .vd-nav { padding: 4px 6px 4px 10px; border-radius: 22px; }
  .vd-nav-tagline { display: none; }
  .vd-nav-desktop { display: none; }
  .vd-mobile-btn { display: flex; }
}

/* =====================================================
   TEXTURED NAVY FOOTER
   ===================================================== */
.vd-footer {
  position: relative;
  overflow: hidden;
  padding: 48px 40px 24px;
  width: 100%;
  box-sizing: border-box;
  background:
    radial-gradient(700px 400px at 90% 0%, rgba(255,65,54,0.10), transparent 60%),
    linear-gradient(160deg, #0B1437 0%, #1E3A8A 70%, #243B8A 100%);
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
}
.vd-footer::before {
  content: ""; position: absolute; inset: 0;
  background-image: repeating-linear-gradient(90deg, rgba(255,255,255,0.05) 0 1px, transparent 1px 24px);
  pointer-events: none; z-index: 0;
}
.vd-footer::after {
  content: ""; position: absolute; inset: 0;
  background-image: var(--vd-grain);
  background-size: 200px 200px;
  opacity: 0.40;
  mix-blend-mode: overlay;
  pointer-events: none; z-index: 0;
}
.vd-footer > * { position: relative; z-index: 1; }

.vd-footer .footer-inner {
  max-width: 1200px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1.3fr 0.9fr 0.9fr 0.9fr;
  gap: 32px;
}
.vd-footer .footer-brand-col { display: flex; flex-direction: column; }
.vd-footer .footer-col-head {
  font-family: 'Inter','Plus Jakarta Sans',sans-serif;
  font-size: 11px; font-weight: 700; letter-spacing: 2px;
  text-transform: uppercase; color: rgba(255,255,255,0.55);
  margin-bottom: 16px;
}
.vd-footer .footer-link {
  display: block;
  font-family: 'Inter','Plus Jakarta Sans',sans-serif;
  font-size: 13.5px; font-weight: 500;
  color: rgba(255,255,255,0.85);
  text-decoration: none;
  padding: 6px 0;
  background: none; border: none; cursor: pointer; text-align: left; width: 100%;
  transition: color .2s ease, transform .2s ease;
}
.vd-footer .footer-link:hover { color: #fff; transform: translateX(2px); }
.vd-footer .footer-bottom {
  max-width: 1200px; margin: 36px auto 0;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,0.12);
  display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 12px;
}
.vd-footer .footer-disclaimer {
  max-width: 1200px; margin: 16px auto 0;
  font-family: 'Inter','Plus Jakarta Sans',sans-serif;
  font-size: 11px; color: rgba(255,255,255,0.4);
  text-align: center; line-height: 1.6;
}
@media (max-width: 900px) {
  .vd-footer { padding: 32px 20px; }
  .vd-footer .footer-inner { grid-template-columns: 1fr 1fr; gap: 24px; }
}
@media (max-width: 540px) {
  .vd-footer .footer-inner { grid-template-columns: 1fr; }
}

/* =====================================================
   PERSISTENT FLOATING CTA (bottom-right)
   ===================================================== */
.vd-floating-cta {
  position: fixed;
  bottom: 22px; right: 22px;
  z-index: 9000;
  background: var(--vd-red);
  color: #fff !important;
  font-family: 'Plus Jakarta Sans','Inter',sans-serif;
  font-weight: 700; font-size: 14px;
  padding: 14px 22px; border-radius: 999px;
  text-decoration: none !important;
  box-shadow:
    0 12px 30px -8px rgba(255,65,54,0.6),
    0 4px 10px rgba(11,20,55,0.18),
    inset 0 1px 0 rgba(255,255,255,0.25);
  display: inline-flex; align-items: center; gap: 8px;
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
  opacity: 0; transform: translateY(20px); pointer-events: none;
}
.vd-floating-cta.vd-visible { opacity: 1; transform: translateY(0); pointer-events: auto; }
.vd-floating-cta:hover {
  background: #E0382E; transform: translateY(-2px);
  box-shadow: 0 18px 40px -10px rgba(255,65,54,0.7), 0 6px 14px rgba(11,20,55,0.22);
}
.vd-floating-cta svg { width: 14px; height: 14px; }
@media (max-width: 768px) {
  .vd-floating-cta { bottom: 16px; right: 16px; padding: 12px 18px; font-size: 13px; }
}
