/* Estrella XV Theme — royal navy, midnight blue, silver, ivory, champagne */
*, *::before, *::after { box-sizing: border-box; }

:root {
  --exv-navy: #07184F;
  --exv-midnight: #02091F;
  --exv-blue: #11358F;
  --exv-silver: #D8D8D8;
  --exv-silver2: #F1F2F5;
  --exv-ivory: #F7F3EA;
  --exv-ivory2: #FFFDF8;
  --exv-gold: #C9A86A;
  --exv-gold2: #F2DFAC;
  --exv-text: #02091F;
  --exv-muted: #343847;
  --exv-serif: 'Cormorant Garamond', Georgia, serif;
  --exv-cinzel: 'Cinzel', serif;
  --exv-decor: 'Cinzel Decorative', serif;
  --exv-sans: 'Jost', Arial, sans-serif;
}

html { scroll-behavior: smooth; }
body.exv-clean-canvas {
  background:
    radial-gradient(circle at 10% 0%, rgba(216,216,216,.35), transparent 28rem),
    linear-gradient(180deg, var(--exv-ivory), #fff);
  color: var(--exv-text);
  font-family: var(--exv-sans);
  font-weight: 300;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; }
a { color: inherit; }
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--exv-ivory); }
::-webkit-scrollbar-thumb { background: var(--exv-gold); border-radius: 9px; }

.site-main { width: 100%; overflow: hidden; }
.elementor-section.elementor-section-boxed > .elementor-container { max-width: 1180px; }

/* Shared XV plugin styling */
.exv-site,
.exv-section,
.exv-card,
.exv-rsvp,
.exv-music-player {
  font-family: var(--exv-sans);
}
.exv-site h1,
.exv-site h2,
.exv-site h3,
.exv-section h1,
.exv-section h2,
.exv-section h3 {
  font-family: var(--exv-serif);
  letter-spacing: .01em;
}
.exv-kicker {
  font-family: var(--exv-cinzel);
  text-transform: uppercase;
  letter-spacing: .28em;
  color: var(--exv-gold);
  font-weight: 600;
}
.exv-hero {
  background:
    radial-gradient(circle at 50% 0%, rgba(216,216,216,.23), transparent 20rem),
    radial-gradient(circle at 18% 25%, rgba(201,168,106,.18), transparent 18rem),
    linear-gradient(145deg, var(--exv-blue) 0%, var(--exv-navy) 38%, var(--exv-midnight) 100%) !important;
}
.exv-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle, rgba(255,255,255,.95) 0 1px, transparent 1.6px),
    radial-gradient(circle, rgba(216,216,216,.85) 0 1px, transparent 1.5px);
  background-size: 54px 54px, 91px 91px;
  opacity: .18;
  pointer-events: none;
}
.exv-hero h1 {
  font-family: var(--exv-decor), var(--exv-serif);
  color: #fff;
}
.exv-date, .exv-quote { color: var(--exv-ivory) !important; }
.exv-btn,
.exv-rsvp button,
.exv-rsvp input[type="submit"],
button.exv-btn {
  background: linear-gradient(135deg, var(--exv-gold), var(--exv-gold2)) !important;
  color: var(--exv-midnight) !important;
  border: 1px solid rgba(255,255,255,.45) !important;
  border-radius: 999px !important;
  box-shadow: 0 12px 30px rgba(2,9,31,.22) !important;
  font-weight: 600 !important;
}
.exv-section h2 { color: var(--exv-navy) !important; }
.exv-card,
.exv-rsvp-wrap,
.exv-rsvp,
.exv-form,
.exv-panel {
  background: rgba(255,255,255,.88) !important;
  border: 1px solid rgba(7,24,79,.12) !important;
  box-shadow: 0 20px 55px rgba(7,24,79,.10) !important;
}
.exv-card { border-radius: 24px !important; }
.exv-card span { color: var(--exv-gold) !important; }
.exv-card h3 { color: var(--exv-navy) !important; }
.exv-palette i { box-shadow: 0 8px 24px rgba(2,9,31,.18) !important; }

/* RSVP form polish */
.exv-rsvp input,
.exv-rsvp select,
.exv-rsvp textarea,
.exv-form input,
.exv-form select,
.exv-form textarea {
  width: 100%;
  border: 1px solid rgba(7,24,79,.18) !important;
  border-radius: 14px !important;
  background: #fff !important;
  color: var(--exv-midnight) !important;
  padding: 13px 15px !important;
  font-family: var(--exv-sans) !important;
}
.exv-rsvp input:focus,
.exv-rsvp select:focus,
.exv-rsvp textarea:focus,
.exv-form input:focus,
.exv-form select:focus,
.exv-form textarea:focus {
  outline: 2px solid rgba(201,168,106,.35) !important;
  border-color: var(--exv-gold) !important;
}

/* Floating music button style */
.exv-music-player,
.exv-music-toggle,
.exv-music-btn {
  background: linear-gradient(145deg, var(--exv-navy), var(--exv-midnight)) !important;
  color: var(--exv-silver) !important;
  border: 1px solid rgba(216,216,216,.35) !important;
  box-shadow: 0 14px 34px rgba(2,9,31,.35) !important;
}

@media (max-width: 780px) {
  body.exv-clean-canvas { background: linear-gradient(180deg, var(--exv-ivory), #fff); }
  .exv-kicker { letter-spacing: .18em; }
}
