:root {
  --bg-1: #09111f;
  --bg-2: #111f38;
  --card: rgba(255, 255, 255, 0.08);
  --border: rgba(255, 255, 255, 0.14);
  --text-soft: rgba(255, 255, 255, 0.72);
  --gold: #f6c453;
  --gold-deep: #d79c1f;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Inter', sans-serif;
  color: #fff;
  background:
    radial-gradient(circle at top left, rgba(246, 196, 83, 0.18), transparent 28%),
    radial-gradient(circle at 85% 15%, rgba(58, 93, 184, 0.22), transparent 24%),
    linear-gradient(135deg, var(--bg-1), var(--bg-2));
  min-height: 100vh;
}

.page-wrap { position: relative; overflow: hidden; }
.page-wrap::before,
.page-wrap::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  filter: blur(70px);
  opacity: 0.35;
  pointer-events: none;
}
.page-wrap::before { width: 280px; height: 280px; background: #ffc857; top: 120px; left: -80px; }
.page-wrap::after { width: 340px; height: 340px; background: #2a5298; bottom: 120px; right: -100px; }

.cursor-glow {
  position: fixed;
  width: 240px;
  height: 240px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(246,196,83,0.18), rgba(246,196,83,0));
  pointer-events: none;
  transform: translate(-50%, -50%);
  z-index: 1;
  opacity: 0;
  transition: opacity .25s ease;
}

.navbar, .hero-section, main, .site-footer { position: relative; z-index: 3; }
.brand-mark {
  width: 42px; height: 42px; border-radius: 12px; display: inline-flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--gold), #fff0b6); color: #111827; font-weight: 800;
}
.hero-section { padding: 3rem 0 2rem; }
.eyebrow {
  display: inline-flex; align-items: center; gap: 8px; font-size: 0.85rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.14em; color: #ffda86;
}
.hero-copy, .subtext { max-width: 680px; }
.mini-pill {
  padding: 0.7rem 1rem; border: 1px solid var(--border); background: rgba(255,255,255,.06);
  border-radius: 999px; color: #fff; font-size: .92rem; transition: transform .25s ease, border-color .25s ease;
}
.mini-pill:hover { transform: translateY(-2px); border-color: rgba(246,196,83,.35); }
.mini-pill i { margin-right: .45rem; color: #ffda86; }
.small-pill { padding: .55rem .9rem; font-size: .82rem; }

.hero-card, .feature-card, .showcase-card, .testimonial-card, .choice-modal {
  border: 1px solid var(--border); background: var(--card); backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px); border-radius: 28px;
}
.hero-card { padding: 1.7rem; position: relative; }
.status-badge {
  display: inline-flex; align-items: center; gap: 8px; margin-bottom: 1rem; padding: .45rem .8rem;
  background: rgba(246,196,83,.15); color: #ffd36f; border: 1px solid rgba(246,196,83,.25); border-radius: 999px; font-size: .88rem; font-weight: 700;
}
.info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .9rem; }
.info-box {
  border-radius: 18px; padding: .95rem 1rem; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08);
  display: flex; gap: .7rem; align-items: flex-start; color: #f3f4f6; font-size: .92rem; text-decoration: none; transition: transform .25s ease, border-color .25s ease, background .25s ease;
}
.info-box:hover { transform: translateY(-4px); border-color: rgba(246,196,83,.35); background: rgba(255,255,255,.08); }
.info-box i { color: #ffd36f; }

.floating-badges { position: relative; z-index: 3; }
.marquee-wrap {
  overflow: hidden; border-radius: 999px; border: 1px solid rgba(255,255,255,.1); background: rgba(255,255,255,.05); padding: .8rem 0;
}
.marquee-track {
  display: flex; gap: 2rem; width: max-content; animation: marquee 24s linear infinite;
}
.marquee-track span { color: #fff; white-space: nowrap; font-weight: 600; opacity: .92; }
.marquee-track i { color: #ffda86; margin-right: .5rem; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-35%); } }

.section-heading { max-width: 760px; margin: 0 auto; }
.feature-card {
  padding: 1.5rem; transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.feature-card:hover { transform: translateY(-8px); border-color: rgba(246,196,83,.35); box-shadow: 0 18px 45px rgba(0,0,0,.18); }
.icon-wrap {
  width: 56px; height: 56px; border-radius: 18px; display: inline-flex; align-items: center; justify-content: center; margin-bottom: 1rem;
  background: rgba(246,196,83,.12); color: #ffd36f; font-size: 1.35rem;
}
.feature-card h5, .showcase-card h3 { color: #fff; }
.feature-card p, .showcase-card p, .testimonial-card p { color: var(--text-soft); margin-bottom: 0; }
.showcase-card, .testimonial-card { padding: 1.8rem; }
.mini-card {
  padding: 1rem 1.1rem; border-radius: 20px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); height: 100%; transition: transform .25s ease, border-color .25s ease;
}
.interactive-panel:hover { transform: translateY(-5px); border-color: rgba(246,196,83,.35); }
.mini-label {
  display: block; font-size: .78rem; text-transform: uppercase; letter-spacing: .12em; color: #ffda86; margin-bottom: .45rem;
}
.quote-mark { font-size: 5rem; line-height: .8; color: #ffda86; }
.quote-text { font-size: 1.15rem; line-height: 1.7; }
.cta-strip {
  background: linear-gradient(135deg, #f6c453, #ffe39a); border-radius: 28px; padding: 2rem; box-shadow: 0 18px 60px rgba(0,0,0,.2);
}
.pb-6 { padding-bottom: 5rem; }
.btn-warning { background: linear-gradient(135deg, var(--gold), #ffde8b); border: none; color: #1f2937; }
.btn-warning:hover { color: #111827; transform: translateY(-1px); }
.btn-outline-light:hover, .btn-outline-dark:hover { transform: translateY(-1px); }
.btn, .social-link { transition: transform .2s ease, box-shadow .2s ease; }
.magnetic-btn:hover { box-shadow: 0 12px 30px rgba(0,0,0,.18); }

.site-footer {
  padding: 4rem 0 2rem; border-top: 1px solid rgba(255,255,255,.08); background: rgba(3, 8, 18, .42);
}
.footer-title {
  font-size: .9rem; letter-spacing: .14em; text-transform: uppercase; color: #ffda86; margin-bottom: 1rem; font-weight: 700;
}
.footer-links li + li { margin-top: .8rem; }
.footer-links a, .contact-stack a {
  color: rgba(255,255,255,.8); text-decoration: none; transition: color .2s ease, transform .2s ease; display: inline-flex; align-items: center;
}
.footer-links a:hover, .contact-stack a:hover { color: #fff; transform: translateX(4px); }
.contact-stack { display: grid; gap: .9rem; }
.contact-stack i { color: #ffda86; margin-right: .65rem; }
.social-grid { display: flex; gap: .75rem; flex-wrap: wrap; }
.social-link {
  width: 42px; height: 42px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center;
  color: #fff; text-decoration: none; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.09);
}
.social-link:hover { transform: translateY(-3px); border-color: rgba(246,196,83,.35); color: #ffda86; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.08); padding-top: 1.5rem; }

.choice-modal { background: rgba(10,17,31,.92); }
.choice-icon {
  width: 72px; height: 72px; border-radius: 24px; display: inline-flex; align-items: center; justify-content: center;
  background: rgba(246,196,83,.15); color: #ffd36f; font-size: 1.9rem; margin-inline: auto;
}
.modal-content { border: 1px solid rgba(255,255,255,.12); }

.reveal-card { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal-card.is-visible { opacity: 1; transform: translateY(0); }
.tilt-card { transform-style: preserve-3d; }

@media (max-width: 991.98px) {
  .hero-section { padding-top: 2rem; }
}
@media (max-width: 767.98px) {
  .display-4 { font-size: 2.35rem; }
  .info-grid { grid-template-columns: 1fr; }
  .marquee-track { gap: 1.2rem; animation-duration: 18s; }
  .cta-strip { padding: 1.5rem; }
}
