/* Reuse tokens */
:root{
  --rvp-bg:#004E89;
  --rvp-bg2:#003560;
  --rvp-text:#ffffff;
  --rvp-muted:#B0C4DE;
  --rvp-primary:#FF6B35;
  --rvp-primaryLight:#FF8C5A;
  --rvp-border:1px solid rgba(255,255,255,.12);
  --rvp-shadow:0 20px 60px rgba(0,0,0,.35);
  --rvp-radius:22px;
  --rvp-container:min(1180px, calc(100% - 32px));
  --mx:0px; --my:0px;

  --light-bg:#F6FAFF;
  --light-surface:rgba(255,255,255,.88);
  --light-border:1px solid rgba(0,0,0,.08);
  --light-shadow:0 18px 50px rgba(0,0,0,.10);
}

.capWrap{ width: var(--rvp-container); margin-inline:auto; }

/* Buttons */
.capBtn{
  display:inline-flex; align-items:center; justify-content:center;
  padding: 12px 14px;
  border-radius: 16px;
  font-weight: 950;
  font-size: 13px;
  text-decoration:none;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color: #fff;
  transition: transform 150ms ease, box-shadow 220ms ease, background 220ms ease, border-color 220ms ease;
}
.capBtn:active{ transform: scale(.985); }
.capBtn--primary{
  background: linear-gradient(180deg, var(--rvp-primaryLight), var(--rvp-primary));
  border-color: rgba(255,107,53,.35);
  box-shadow: 0 16px 44px rgba(255,107,53,.22);
}
.capBtn--ghost{ background: rgba(255,255,255,.10); }
.capBtn--outline{ background: rgba(0,0,0,.18); }

/* HERO */
.capContactHero{
  position:relative; overflow:hidden;
  padding: clamp(58px, 7vw, 110px) 0;
  background:
    radial-gradient(60% 55% at 40% 0%, rgba(255,107,53,.16), rgba(0,0,0,0) 62%),
    linear-gradient(180deg, var(--rvp-bg), var(--rvp-bg2));
  color: var(--rvp-text);
}
.capContactHero__bg{ position:absolute; inset:0; pointer-events:none; opacity:.95; }
.capContactHero__orb{
  position:absolute; width:560px; height:560px; border-radius:999px;
  filter: blur(38px);
  transform: translate3d(calc(var(--mx) * .28), calc(var(--my) * .28), 0);
  will-change: transform;
  opacity:.55; mix-blend-mode: screen;
  animation: cFloat 11s ease-in-out infinite;
}
.capContactHero__orb--1{ left:-240px; top:-260px; background: radial-gradient(circle at 30% 30%, rgba(255,107,53,.32), rgba(255,107,53,0) 60%); }
.capContactHero__orb--2{ right:-260px; top:30px; background: radial-gradient(circle at 35% 35%, rgba(176,196,222,.18), rgba(176,196,222,0) 62%); animation-duration: 13s; }
.capContactHero__grid{
  position:absolute; inset:-40%;
  background:
    linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px);
  background-size: 46px 46px;
  opacity: .10;
  transform: translate3d(calc(var(--mx) * .10), calc(var(--my) * .10), 0);
}
@keyframes cFloat{
  0%,100%{ transform: translate3d(calc(var(--mx) * .28), calc(var(--my) * .28), 0) scale(1); }
  50%{ transform: translate3d(calc(var(--mx) * .38), calc(var(--my) * .38), 0) scale(1.06); }
}

.capContactHero__wrap{
  position:relative;
  width: var(--rvp-container);
  margin-inline:auto;
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 14px;
  align-items: start;
}

.capContactHero__kicker{
  margin:0 0 10px;
  display:inline-flex;
  padding:8px 12px;
  border-radius:999px;
  border: var(--rvp-border);
  background: rgba(0,0,0,.18);
  font-size: 13px;
  font-weight: 900;
}

.capContactHero__title{
  margin:0 0 10px;
  font-size: clamp(28px, 3.4vw, 50px);
  line-height: 1.08;
  text-wrap: balance;
}
.capContactHero__lead{
  margin:0 0 14px;
  color: rgba(255,255,255,.82);
  font-size: clamp(14px, 1.1vw, 17px);
  line-height: 1.75;
}
.capContactHero__actions{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom: 10px; }

.capContactAlert{
  margin-top: 10px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.16);
  padding: 12px;
  color: rgba(255,255,255,.86);
  line-height: 1.6;
  font-weight: 900;
  font-size: 13px;
}
.capContactAlert.is-ok{ border-color: rgba(255,140,90,.35); }
.capContactAlert.is-bad{ border-color: rgba(176,196,222,.25); }

/* Form Card */
.capContactHero__card{
  border-radius: calc(var(--rvp-radius) + 6px);
  border: var(--rvp-border);
  background: linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.10));
  box-shadow: var(--rvp-shadow);
  padding: 16px;
}
.capContactHero__cardTitle{ margin:0 0 12px; font-size: 16px; }

.capForm__grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.capField{ display:grid; gap: 6px; }
.capField--full{ grid-column: 1 / -1; }

.capField span{
  font-size: 12px;
  font-weight: 900;
  color: rgba(255,255,255,.84);
}

.capField input,
.capField select,
.capField textarea{
  width:100%;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  padding: 12px 12px;
  font-size: 13px;
  color:#fff;
  outline:none;
}
.capField textarea{ min-height: 110px; resize: vertical; }
.capField input::placeholder,
.capField textarea::placeholder{ color: rgba(255,255,255,.55); }

.capForm__actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 12px;
}
.capForm__note{
  margin: 10px 0 0;
  color: rgba(255,255,255,.72);
  font-size: 13px;
  line-height: 1.7;
}

/* honeypot hidden */
.capHp{
  position:absolute;
  left:-9999px; top:auto;
  width:1px; height:1px;
  overflow:hidden;
}

/* Info section (Light) */
.capContactInfo{
  background: linear-gradient(180deg, #F6FAFF, #FFFFFF);
  padding: clamp(34px, 4.6vw, 72px) 0;
}
.capInfoGrid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}
.capInfoCard{
  border-radius: var(--rvp-radius);
  border: var(--light-border);
  background: var(--light-surface);
  box-shadow: var(--light-shadow);
  padding: 16px;
  text-decoration:none;
  color: #003560;
}
.capInfoCard strong{ display:block; margin-bottom:4px; }
.capInfoCard span{ display:block; color: rgba(11,18,32,.72); font-size: 13px; line-height:1.6; }

/* Reveal */
[data-cap-reveal]{
  opacity:0;
  transform: translateY(10px);
  transition: opacity 520ms ease, transform 520ms ease;
  will-change: opacity, transform;
}
.is-cap-revealed[data-cap-reveal]{ opacity:1; transform: translateY(0); }

@media (max-width: 980px){
  .capContactHero__wrap{ grid-template-columns: 1fr; }
  .capForm__grid{ grid-template-columns: 1fr; }
  .capInfoGrid{ grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce){
  .capContactHero__orb{ animation:none !important; }
  [data-cap-reveal]{ opacity:1 !important; transform:none !important; transition:none !important; }
}
