:root{
  --nav-offset: 120px;
  --container: 1160px;

  --bg-1: #08162e;
  --bg-2: #0d2344;
  --bg-3: #14345d;
  --bg-4: #122a4b;
  --bg-5: #0b1830;
  --bg-6: #060d1a;

  --panel: rgba(255,255,255,.08);
  --border: rgba(255,255,255,.16);
  --border-strong: rgba(255,255,255,.26);

  --text: rgba(255,255,255,.95);
  --muted: rgba(255,255,255,.76);

  --accent: #8fd3ff;
  --accent-2: #c4f05f;
  --accent-3: #ffd166;

  --shadow: 0 18px 60px rgba(0,0,0,.35);
  --shadow-soft: 0 12px 28px rgba(0,0,0,.24);

  --radius: 20px;
}

html,
body{
  margin: 0;
  padding: 0;
}

*{
  box-sizing: border-box;
}

body{
  background: var(--bg-6);
  color: var(--text);
  overflow-x: hidden;
}

.ovp-page{
  min-height: 100dvh;
  padding-top: var(--nav-offset);
  padding-bottom: 80px;
  background:
    radial-gradient(circle at top, rgba(143,211,255,.12), transparent 28%),
    linear-gradient(180deg, var(--bg-1), var(--bg-2) 18%, var(--bg-3) 42%, var(--bg-4) 68%, var(--bg-5) 86%, var(--bg-6));
}

.ovp-container{
  width: min(100% - 2rem, var(--container));
  margin-inline: auto;
}

.ovp-section{
  padding: clamp(2.6rem, 5vw, 5.4rem) 0;
}

.ovp-hero__inner{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  text-align: center;
}

.ovp-brand{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .75rem;
}

.ovp-brand__logo{
  width: 108px;
  height: 108px;
  border-radius: 22px;
  border: 1px solid var(--border-strong);
  background: linear-gradient(145deg, rgba(255,255,255,.14), rgba(255,255,255,.05));
  box-shadow: var(--shadow-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  padding: 10px;
}

.ovp-brand__logo img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.ovp-brand__name{
  margin: 0;
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--muted);
}

.ovp-kicker{
  margin: .4rem 0 0;
  color: var(--accent);
  font-weight: 900;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.ovp-launchBanner{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  flex-wrap: wrap;
  max-width: 860px;
  padding: .9rem 1.2rem;
  border-radius: 999px;
  color: #0b1320;
  background: linear-gradient(135deg, var(--accent-3), var(--accent));
  text-decoration: none;
  font-weight: 900;
  box-shadow: var(--shadow);
  border: 1px solid rgba(255,255,255,.35);
}

.ovp-launchBanner span{
  color: #0b2a5a;
}

.ovp-hero h1{
  margin: 0;
  max-width: 980px;
  font-size: clamp(2rem, 4.2vw, 4.2rem);
  line-height: 1.02;
  text-wrap: balance;
}

.ovp-lead{
  margin: 0;
  max-width: 950px;
  color: var(--muted);
  font-size: clamp(1.02rem, 1.2vw, 1.16rem);
  line-height: 1.8;
}

.ovp-cta{
  display: flex;
  justify-content: center;
  gap: .85rem;
  flex-wrap: wrap;
  margin-top: .4rem;
}

.ovp-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 220px;
  padding: .95rem 1.25rem;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 900;
  color: #0b1320;
  background: linear-gradient(135deg, var(--accent), var(--accent-3));
  box-shadow: var(--shadow);
  border: 1px solid rgba(0,0,0,.08);
  transition: transform .15s ease, filter .18s ease;
}

.ovp-btn:hover{
  transform: translateY(-1px);
  filter: brightness(1.04);
}

.ovp-btn--ghost{
  color: var(--text);
  background: transparent;
  border: 1px solid var(--border-strong);
  box-shadow: none;
}

.ovp-heading{
  max-width: 920px;
  margin: 0 auto 1.5rem;
  text-align: center;
}

.ovp-eyebrow{
  margin: 0 0 .45rem;
  color: var(--accent-2);
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-size: .92rem;
}

.ovp-heading h2{
  margin: 0 0 .9rem;
  font-size: clamp(1.8rem, 3vw, 3rem);
  line-height: 1.08;
}

.ovp-heading p{
  margin: 0 auto;
  max-width: 860px;
  color: var(--muted);
  font-size: clamp(1rem, 1.1vw, 1.08rem);
  line-height: 1.7;
}

/* PROCESS 3 - 2 - 1 GO */

.ovp-countdownProcess{
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
  max-width: 1120px;
  margin: 2rem auto 0;
}

.ovp-countdownProcess::before{
  content: "";
  position: absolute;
  left: 8%;
  right: 8%;
  top: 58px;
  height: 3px;
  background: linear-gradient(90deg, transparent, rgba(143,211,255,.8), rgba(255,209,102,.8), transparent);
  z-index: 0;
}

.ovp-countStep{
  position: relative;
  z-index: 1;
  min-height: 260px;
  padding: 1.2rem 1rem;
  border-radius: 28px;
  background:
    radial-gradient(320px 180px at 50% 0%, rgba(143,211,255,.18), transparent 60%),
    rgba(255,255,255,.08);
  border: 1px solid var(--border-strong);
  box-shadow: var(--shadow-soft);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.ovp-countStep__number{
  width: 88px;
  height: 88px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
  font-size: 2.4rem;
  font-weight: 1000;
  color: #0b1320;
  background: linear-gradient(135deg, var(--accent), var(--accent-3));
  box-shadow: 0 18px 44px rgba(0,0,0,.28);
}

.ovp-countStep--go .ovp-countStep__number{
  width: 116px;
  font-size: 2rem;
  background: linear-gradient(135deg, var(--accent-3), var(--accent-2));
}

.ovp-countStep h3{
  margin: 0 0 .6rem;
  font-size: 1.25rem;
}

.ovp-countStep p{
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
  font-weight: 700;
}

.ovp-countStep--three{
  animation: ovpPulse 1.8s ease infinite;
}

.ovp-countStep--two{
  animation: ovpPulse 1.8s ease .18s infinite;
}

.ovp-countStep--one{
  animation: ovpPulse 1.8s ease .36s infinite;
}

.ovp-countStep--go{
  animation: ovpGoGlow 1.8s ease .54s infinite;
}

@keyframes ovpPulse{
  0%, 100%{
    transform: translateY(0);
  }
  50%{
    transform: translateY(-6px);
  }
}

@keyframes ovpGoGlow{
  0%, 100%{
    transform: translateY(0) scale(1);
    box-shadow: var(--shadow-soft);
  }
  50%{
    transform: translateY(-8px) scale(1.02);
    box-shadow: 0 22px 70px rgba(196,240,95,.22);
  }
}

/* CTA FINAL */

.ovp-final__panel{
  max-width: 960px;
  margin: 0 auto;
  padding: 1.4rem 1.25rem;
  text-align: center;
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(143,211,255,.10), rgba(255,255,255,.05)),
    rgba(255,255,255,.06);
  border: 1px solid var(--border-strong);
  box-shadow: var(--shadow);
}

.ovp-final__panel h2{
  margin: 0 0 .8rem;
  font-size: clamp(1.8rem, 3vw, 3rem);
  line-height: 1.06;
}

.ovp-final__panel p{
  margin: 0 auto;
  max-width: 820px;
  color: var(--muted);
  line-height: 1.8;
}

.ovp-page [id]{
  scroll-margin-top: calc(var(--nav-offset) + 18px);
}

/* RESPONSIVE */

@media (max-width: 980px){
  .ovp-countdownProcess{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ovp-countdownProcess::before{
    display: none;
  }
}

@media (max-width: 640px){
  :root{
    --nav-offset: 110px;
  }

  .ovp-page{
    padding-bottom: 70px;
  }

  .ovp-btn{
    width: 100%;
    max-width: 420px;
  }

  .ovp-hero h1{
    font-size: clamp(1.9rem, 8vw, 2.7rem);
  }

  .ovp-lead{
    font-size: 1rem;
  }

  .ovp-brand__logo{
    width: 92px;
    height: 92px;
  }

  .ovp-launchBanner{
    border-radius: 22px;
  }

  .ovp-countdownProcess{
    grid-template-columns: 1fr;
  }

  .ovp-countStep{
    min-height: 220px;
  }
}