/* ============================================================
   WEDDING DIGITAL INVITATION — MAIN STYLESHEET
   Theme: Navy Blue + White | Luxury Minimalist
   ============================================================ */

/* ── Google Fonts Import ─────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Great+Vibes&family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Poppins:wght@300;400;500;600&display=swap');

/* ── CSS Custom Properties ───────────────────────────────── */
:root {
  /* Core Palette — Navy + White */
  --navy-deep:    #0A1628;
  --navy-dark:    #0D1F3C;
  --navy-mid:     #14294E;
  --navy-light:   #1C3461;
  --navy-soft:    #2C4A7A;
  --gold:         #C9A84C;
  --gold-light:   #E8D5A3;
  --gold-pale:    #F5EDD6;
  --white:        #FFFFFF;
  --off-white:    #F8F7F4;
  --cream:        #FAF8F2;
  --text-dark:    #1A1A2E;
  --text-mid:     #3D3D5C;
  --text-light:   #6B6B8A;
  --divider:      rgba(201,168,76,0.3);

  /* Typography */
  --font-script:  'Great Vibes', cursive;
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'Poppins', system-ui, sans-serif;

  /* Spacing */
  --section-py:   6rem;
  --container:    1140px;

  /* Transitions */
  --ease:         cubic-bezier(0.4, 0, 0.2, 1);
  --duration:     0.4s;

  /* Shadows */
  --shadow-sm:    0 2px 12px rgba(10,22,40,0.08);
  --shadow-md:    0 8px 32px rgba(10,22,40,0.12);
  --shadow-lg:    0 20px 60px rgba(10,22,40,0.18);
}

/* ── Reset & Base ────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: var(--font-body);
  color: var(--text-dark);
  background: var(--off-white);
  overflow-x: hidden;
  line-height: 1.7;
}

img { display: block; max-width: 100%; height: auto; }

a { color: inherit; text-decoration: none; }

/* ── Utility Classes ─────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 1.5rem;
}

.text-center { text-align: center; }
.text-gold   { color: var(--gold); }
.text-navy   { color: var(--navy-dark); }
.text-white  { color: var(--white); }

.section-label {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 0.75rem;
}

.section-title {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 600;
  color: var(--navy-dark);
  line-height: 1.25;
  margin-bottom: 1rem;
}

.section-title.light { color: var(--white); }

.divider-ornament {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin: 1.5rem auto;
}

.divider-ornament::before,
.divider-ornament::after {
  content: '';
  flex: 1;
  max-width: 80px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold));
}

.divider-ornament::after {
  background: linear-gradient(90deg, var(--gold), transparent);
}

.divider-ornament span {
  color: var(--gold);
  font-size: 1.2rem;
}

/* ── Music Player ────────────────────────────────────────── */
#music-player {
  position: fixed;
  bottom: 1.5rem;
  left: 1.5rem;
  z-index: 1000;
  background: var(--navy-dark);
  border: 1px solid rgba(201,168,76,0.4);
  color: var(--white);
  border-radius: 50px;
  padding: 0.6rem 1.2rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  box-shadow: var(--shadow-md);
  cursor: pointer;
  transition: all var(--duration) var(--ease);
  backdrop-filter: blur(8px);
}

#music-player:hover { background: var(--navy-mid); transform: translateY(-2px); }

#music-player .music-icon {
  width: 36px;
  height: 36px;
  background: linear-gradient(135deg, var(--gold), #A87C2A);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
}

#music-player .music-icon.playing { animation: spin 4s linear infinite; }

#music-player .music-info { font-size: 0.7rem; }
#music-player .music-info strong { display: block; font-size: 0.78rem; font-weight: 600; }

@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

/* ── Cover Opening / Envelope ────────────────────────────── */
#cover-opening {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: var(--navy-deep);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 2rem;
  transition: opacity 0.8s var(--ease), visibility 0.8s;
}

#cover-opening.hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

#cover-opening .cover-ornament {
  width: 120px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  margin: 1.2rem auto;
}

#cover-opening .cover-label {
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--gold-light);
  margin-bottom: 1rem;
}

#cover-opening .cover-verse {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(0.85rem, 2vw, 1rem);
  color: rgba(255,255,255,0.65);
  max-width: 520px;
  line-height: 1.9;
  margin-bottom: 0.5rem;
}

#cover-opening .cover-verse-source {
  font-size: 0.72rem;
  color: var(--gold);
  letter-spacing: 0.1em;
  margin-bottom: 2.5rem;
}

#cover-opening .cover-names {
  font-family: var(--font-script);
  font-size: clamp(3rem, 8vw, 5.5rem);
  color: var(--white);
  line-height: 1.35;
  margin: 0.5rem 0;
  text-shadow: 0 4px 30px rgba(201,168,76,0.3);
  display: flex;
  flex-direction: column;
  align-items: center;
}

#cover-opening .cover-ampersand {
  font-family: var(--font-script);
  font-size: clamp(2rem, 5vw, 3.5rem);
  color: var(--gold);
  display: block;
  line-height: 1;
  margin: 0.15em 0;
}

#cover-opening .cover-invite-text {
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin: 1.5rem 0 0.5rem;
}

#cover-opening .guest-name {
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 3vw, 1.6rem);
  color: var(--gold-light);
  margin-bottom: 2.5rem;
  font-style: italic;
}

.btn-open-invitation {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  background: transparent;
  border: 1.5px solid var(--gold);
  color: var(--white);
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 1rem 2.5rem;
  border-radius: 50px;
  cursor: pointer;
  transition: all var(--duration) var(--ease);
  position: relative;
  overflow: hidden;
}

.btn-open-invitation::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--gold) 0%, #A87C2A 100%);
  opacity: 0;
  transition: opacity var(--duration) var(--ease);
}

.btn-open-invitation:hover::before { opacity: 1; }
.btn-open-invitation:hover { border-color: transparent; transform: translateY(-2px); box-shadow: 0 8px 30px rgba(201,168,76,0.35); }
.btn-open-invitation span { position: relative; z-index: 1; }

/* ── Hero Section ────────────────────────────────────────── */
#hero {
  min-height: 100vh;
  background: var(--navy-deep);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.hero-bg-pattern {
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(201,168,76,0.08) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 100% 100%, rgba(28,52,97,0.6) 0%, transparent 50%);
  pointer-events: none;
}

/* Decorative corner flourishes */
.hero-corner {
  position: absolute;
  width: 160px;
  height: 160px;
  opacity: 0.2;
  pointer-events: none;
}
.hero-corner.tl { top: 2rem; left: 2rem; border-top: 1.5px solid var(--gold); border-left: 1.5px solid var(--gold); }
.hero-corner.tr { top: 2rem; right: 2rem; border-top: 1.5px solid var(--gold); border-right: 1.5px solid var(--gold); }
.hero-corner.bl { bottom: 2rem; left: 2rem; border-bottom: 1.5px solid var(--gold); border-left: 1.5px solid var(--gold); }
.hero-corner.br { bottom: 2rem; right: 2rem; border-bottom: 1.5px solid var(--gold); border-right: 1.5px solid var(--gold); }

.hero-content {
  text-align: center;
  position: relative;
  z-index: 1;
  padding: 5rem 1.5rem 4rem;
}

.hero-label {
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 2rem;
  display: block;
  animation: fadeInUp 0.8s var(--ease) 0.2s both;
}

.hero-couple-photo {
  width: clamp(160px, 28vw, 240px);
  height: clamp(160px, 28vw, 240px);
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--gold);
  box-shadow: 0 0 0 8px rgba(201,168,76,0.12), var(--shadow-lg);
  margin: 0 auto 2rem;
  animation: fadeInUp 0.8s var(--ease) 0.3s both;
}

.hero-names {
  font-family: var(--font-script);
  font-size: clamp(3.5rem, 9vw, 7rem);
  color: var(--white);
  line-height: 1.3;
  animation: fadeInUp 0.8s var(--ease) 0.4s both;
  text-shadow: 0 4px 40px rgba(201,168,76,0.2);
  display: flex;
  flex-direction: column;
  align-items: center;
}

.hero-names .ampersand {
  font-family: var(--font-script);
  font-size: 0.65em;
  color: var(--gold);
  display: block;
  line-height: 1;
  margin: 0.12em 0;
}

.hero-hashtag {
  font-family: var(--font-body);
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  color: rgba(255,255,255,0.5);
  margin-top: 1.2rem;
  animation: fadeInUp 0.8s var(--ease) 0.5s both;
}

.hero-date-badge {
  display: inline-flex;
  align-items: center;
  gap: 1rem;
  margin: 2rem auto 0;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(201,168,76,0.3);
  border-radius: 50px;
  padding: 0.7rem 2rem;
  animation: fadeInUp 0.8s var(--ease) 0.6s both;
}

.hero-date-badge span {
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  color: var(--gold-light);
  text-transform: uppercase;
}

.hero-date-badge .dot {
  width: 4px;
  height: 4px;
  background: var(--gold);
  border-radius: 50%;
}

.hero-scroll-hint {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  color: rgba(255,255,255,0.35);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  animation: bounce 2s ease-in-out infinite;
}

.hero-scroll-hint::after {
  content: '';
  width: 1px;
  height: 40px;
  background: linear-gradient(to bottom, rgba(201,168,76,0.6), transparent);
}

/* ── Countdown Section ───────────────────────────────────── */
#countdown {
  background: var(--navy-dark);
  padding: var(--section-py) 0;
  position: relative;
  overflow: hidden;
}

#countdown::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}

#countdown::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}

.countdown-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  max-width: 600px;
  margin: 2.5rem auto 0;
}

.countdown-item {
  text-align: center;
  position: relative;
}

.countdown-item:not(:last-child)::after {
  content: ':';
  position: absolute;
  right: -0.75rem;
  top: 50%;
  transform: translateY(-60%);
  font-family: var(--font-display);
  font-size: 2rem;
  color: var(--gold);
  opacity: 0.5;
}

.countdown-number {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 6vw, 4rem);
  font-weight: 600;
  color: var(--white);
  line-height: 1;
  display: block;
}

.countdown-label {
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-top: 0.4rem;
  display: block;
}

/* ── Couple Section ──────────────────────────────────────── */
#couple {
  background: var(--cream);
  padding: var(--section-py) 0;
}

.couple-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 3rem;
  align-items: center;
  margin-top: 3rem;
}

.couple-card {
  text-align: center;
  padding: 2.5rem 1.5rem;
  background: var(--white);
  border-radius: 1.5rem;
  box-shadow: var(--shadow-sm);
  border: 1px solid rgba(201,168,76,0.15);
  transition: transform var(--duration) var(--ease), box-shadow var(--duration) var(--ease);
}

.couple-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-md);
}

.couple-photo-wrap {
  width: 160px;
  height: 160px;
  margin: 0 auto 1.5rem;
  position: relative;
}

.couple-photo-wrap::before {
  content: '';
  position: absolute;
  inset: -6px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--gold), transparent, var(--gold));
  animation: rotateBorder 6s linear infinite;
}

.couple-photo {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
  position: relative;
  z-index: 1;
  border: 4px solid var(--white);
}

@keyframes rotateBorder {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

.couple-name {
  font-family: var(--font-script);
  font-size: clamp(1.6rem, 3.5vw, 2.2rem);
  color: var(--navy-dark);
  margin-bottom: 0.25rem;
}

.couple-fullname {
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-style: italic;
  color: var(--text-mid);
  margin-bottom: 1rem;
}

.couple-parents {
  font-size: 0.78rem;
  color: var(--text-light);
  line-height: 1.8;
}

.couple-parents strong { color: var(--text-mid); }

.couple-instagram {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-top: 1rem;
  font-size: 0.75rem;
  color: var(--navy-soft);
  font-weight: 500;
  transition: color var(--duration);
}

.couple-instagram:hover { color: var(--gold); }

.couple-divider {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
}

.couple-divider .ampersand-big {
  font-family: var(--font-script);
  font-size: clamp(3rem, 6vw, 5rem);
  color: var(--gold);
  line-height: 1;
}

.couple-divider .couple-divider-line {
  width: 1px;
  height: 60px;
  background: linear-gradient(to bottom, transparent, var(--gold), transparent);
}

/* ── Story / Timeline Section ────────────────────────────── */
#story {
  background: var(--navy-deep);
  padding: var(--section-py) 0;
  position: relative;
}

.timeline {
  position: relative;
  max-width: 700px;
  margin: 3rem auto 0;
  padding: 0 1rem;
}

/* Center vertical line */
.timeline::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 1px;
  transform: translateX(-50%);
  background: linear-gradient(to bottom, transparent, var(--gold), var(--gold), transparent);
}

.timeline-item {
  display: grid;
  grid-template-columns: 1fr 60px 1fr;
  gap: 1rem;
  margin-bottom: 3rem;
  align-items: start;
}

.timeline-item:nth-child(odd) .timeline-content { grid-column: 1; text-align: right; }
.timeline-item:nth-child(odd) .timeline-dot     { grid-column: 2; }
.timeline-item:nth-child(odd) .timeline-empty   { grid-column: 3; }

.timeline-item:nth-child(even) .timeline-empty   { grid-column: 1; }
.timeline-item:nth-child(even) .timeline-dot     { grid-column: 2; }
.timeline-item:nth-child(even) .timeline-content { grid-column: 3; text-align: left; }

.timeline-dot {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
}

.timeline-dot .dot-icon {
  width: 48px;
  height: 48px;
  background: var(--navy-mid);
  border: 2px solid var(--gold);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  position: relative;
  z-index: 1;
  transition: all var(--duration) var(--ease);
}

.timeline-item:hover .dot-icon {
  background: var(--gold);
  transform: scale(1.1);
}

.timeline-content {
  padding: 1.2rem;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(201,168,76,0.15);
  border-radius: 1rem;
  transition: all var(--duration) var(--ease);
}

.timeline-content:hover {
  background: rgba(255,255,255,0.07);
  border-color: rgba(201,168,76,0.3);
}

.timeline-year {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 0.25rem;
}

.timeline-title {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 600;
  color: var(--white);
  margin-bottom: 0.4rem;
}

.timeline-desc {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.7;
}

/* ── Events Section ──────────────────────────────────────── */
#events {
  background: var(--cream);
  padding: var(--section-py) 0;
}

.events-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 2rem;
  margin-top: 3rem;
}

.event-card {
  background: var(--white);
  border-radius: 1.5rem;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  border: 1px solid rgba(201,168,76,0.12);
  transition: all var(--duration) var(--ease);
}

.event-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-md);
}

.event-card-header {
  background: linear-gradient(135deg, var(--navy-dark), var(--navy-mid));
  padding: 1.5rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.event-card-header::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(201,168,76,0.12), transparent 70%);
}

.event-type-badge {
  display: inline-block;
  background: rgba(201,168,76,0.15);
  border: 1px solid rgba(201,168,76,0.3);
  color: var(--gold-light);
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 0.3rem 1rem;
  border-radius: 50px;
  margin-bottom: 0.75rem;
  position: relative;
}

.event-name {
  font-family: var(--font-script);
  font-size: clamp(1.8rem, 4vw, 2.5rem);
  color: var(--white);
  position: relative;
  line-height: 1.2;
}

.event-card-body {
  padding: 1.75rem;
}

.event-detail-row {
  display: flex;
  align-items: flex-start;
  gap: 0.9rem;
  padding: 0.75rem 0;
  border-bottom: 1px solid rgba(201,168,76,0.1);
}

.event-detail-row:last-child { border-bottom: none; }

.event-detail-icon {
  width: 36px;
  height: 36px;
  background: var(--gold-pale);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  flex-shrink: 0;
}

.event-detail-text { flex: 1; }
.event-detail-text .label {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--gold);
  display: block;
  margin-bottom: 0.15rem;
}
.event-detail-text .value {
  font-family: var(--font-display);
  font-size: 0.92rem;
  font-weight: 500;
  color: var(--navy-dark);
}
.event-detail-text .sub-value {
  font-size: 0.78rem;
  color: var(--text-light);
  margin-top: 0.1rem;
}

.btn-maps {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  margin-top: 1.25rem;
  text-align: center;
  background: linear-gradient(135deg, var(--navy-dark), var(--navy-mid));
  color: var(--white);
  padding: 0.85rem;
  border-radius: 0.75rem;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  transition: all var(--duration) var(--ease);
}

.btn-maps:hover {
  background: linear-gradient(135deg, var(--gold), #A87C2A);
  transform: translateY(-2px);
}

/* ── Tombol Add to Calendar ──────────────────────────────────── */
.btn-calendar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  margin-top: 0.65rem;
  text-align: center;
  background: transparent;
  color: var(--gold);
  padding: 0.85rem;
  border: 1.5px solid var(--gold);
  border-radius: 0.75rem;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  transition: all var(--duration) var(--ease);
}

.btn-calendar:hover {
  background: var(--gold);
  color: var(--navy-dark);
  transform: translateY(-2px);
}

/* ── Countdown Hari-H Message ────────────────────────────────── */
.countdown-hariH {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  margin-top: 1rem;
  animation: fadeInUp 0.8s var(--ease) both;
}

.countdown-hariH .hariH-ornament {
  color: var(--gold);
  animation: hariHPulse 2.5s ease-in-out infinite;
}

.countdown-hariH .hariH-text {
  font-family: var(--font-script);
  font-size: clamp(1.75rem, 6vw, 2.75rem);
  color: var(--gold);
  text-align: center;
  line-height: 1.3;
  text-shadow: 0 2px 20px rgba(201,168,76,0.3);
}

@keyframes hariHPulse {
  0%, 100% { transform: scale(1); opacity: 0.85; }
  50%      { transform: scale(1.12); opacity: 1; }
}

/* ── Gallery Section ─────────────────────────────────────── */
#gallery {
  background: var(--navy-deep);
  padding: var(--section-py) 0;
}

/* ── Gallery Showcase (foto besar + thumbnail strip) ────────── */
.gallery-showcase {
  max-width: 540px;
  margin: 2.5rem auto 0;
}

/* Foto utama besar */
.gallery-main {
  position: relative;
  width: 100%;
  border-radius: 1rem;
  overflow: hidden;
  background: var(--navy-mid);
  box-shadow: var(--shadow-lg);
  aspect-ratio: 3 / 4;
}

.gallery-main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: opacity 0.35s var(--ease);
}

.gallery-main-caption {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  padding: 1.5rem 1.25rem 1rem;
  background: linear-gradient(to top, rgba(10,22,40,0.85), transparent);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.95rem;
  color: var(--white);
  text-align: center;
}

/* Thumbnail strip — scroll horizontal */
.gallery-thumbs {
  display: flex;
  gap: 0.6rem;
  margin-top: 0.85rem;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 0.25rem 0.25rem 0.75rem;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--gold) transparent;
}

/* Custom scrollbar (webkit) */
.gallery-thumbs::-webkit-scrollbar { height: 5px; }
.gallery-thumbs::-webkit-scrollbar-track { background: rgba(255,255,255,0.08); border-radius: 10px; }
.gallery-thumbs::-webkit-scrollbar-thumb { background: var(--gold); border-radius: 10px; }

.gallery-thumb {
  flex: 0 0 auto;
  width: 90px;
  height: 90px;
  border: 2px solid transparent;
  border-radius: 0.6rem;
  overflow: hidden;
  padding: 0;
  cursor: pointer;
  background: var(--navy-mid);
  transition: border-color 0.25s var(--ease), transform 0.2s var(--ease);
  -webkit-tap-highlight-color: transparent;
}

.gallery-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: opacity 0.25s var(--ease);
}

.gallery-thumb.active {
  border-color: var(--gold);
  transform: scale(1.04);
}

.gallery-thumb:not(.active) img { opacity: 0.65; }
.gallery-thumb:hover:not(.active) img { opacity: 0.85; }

@media (min-width: 640px) {
  .gallery-thumb { width: 100px; height: 100px; }
}

/* Lightbox */
#lightbox {
  position: fixed;
  inset: 0;
  z-index: 9998;
  background: rgba(0,0,0,0.95);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  opacity: 0;
  visibility: hidden;
  transition: all var(--duration) var(--ease);
}

#lightbox.active { opacity: 1; visibility: visible; }

#lightbox img {
  max-width: 90vw;
  max-height: 90vh;
  object-fit: contain;
  border-radius: 0.5rem;
  box-shadow: var(--shadow-lg);
}

#lightbox-close {
  position: fixed;
  top: 1.5rem;
  right: 1.5rem;
  background: rgba(255,255,255,0.1);
  border: none;
  color: var(--white);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 1.4rem;
  transition: background var(--duration);
  z-index: 9999;
}

#lightbox-close:hover { background: rgba(255,255,255,0.2); }

/* ── RSVP Section ────────────────────────────────────────── */
#rsvp {
  background: var(--cream);
  padding: var(--section-py) 0;
}

.rsvp-form-wrap {
  max-width: 600px;
  margin: 2.5rem auto 0;
  background: var(--white);
  border-radius: 1.5rem;
  padding: 2.5rem;
  box-shadow: var(--shadow-md);
  border: 1px solid rgba(201,168,76,0.15);
}

.form-group {
  margin-bottom: 1.35rem;
}

.form-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--navy-dark);
  margin-bottom: 0.5rem;
}

.form-control {
  width: 100%;
  padding: 0.85rem 1.1rem;
  border: 1.5px solid #E2E4EE;
  border-radius: 0.75rem;
  font-family: var(--font-body);
  font-size: 0.88rem;
  color: var(--text-dark);
  background: var(--off-white);
  transition: all var(--duration) var(--ease);
  outline: none;
}

.form-control:focus {
  border-color: var(--navy-soft);
  background: var(--white);
  box-shadow: 0 0 0 3px rgba(44,74,122,0.1);
}

.form-control::placeholder { color: var(--text-light); }

.attendance-options {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
}

.attendance-option input { display: none; }

.attendance-option label {
  display: block;
  text-align: center;
  padding: 0.8rem 0.5rem;
  border: 1.5px solid #E2E4EE;
  border-radius: 0.75rem;
  font-size: 0.78rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--duration) var(--ease);
  color: var(--text-mid);
}

.attendance-option input:checked + label {
  border-color: var(--navy-dark);
  background: var(--navy-dark);
  color: var(--white);
}

.attendance-option label:hover { border-color: var(--navy-soft); }

.attendance-option label .option-icon { font-size: 1.3rem; display: block; margin-bottom: 0.25rem; }

.btn-submit {
  width: 100%;
  padding: 1rem;
  background: linear-gradient(135deg, var(--navy-dark), var(--navy-mid));
  color: var(--white);
  border: none;
  border-radius: 0.75rem;
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all var(--duration) var(--ease);
  margin-top: 0.5rem;
}

.btn-submit:hover {
  background: linear-gradient(135deg, var(--gold), #A87C2A);
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(201,168,76,0.3);
}

.btn-submit:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }

/* ── Wishes Section ──────────────────────────────────────── */
#wishes {
  background: var(--navy-dark);
  padding: var(--section-py) 0;
}

.wishes-form-wrap {
  max-width: 600px;
  margin: 0 auto 3rem;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(201,168,76,0.2);
  border-radius: 1.25rem;
  padding: 2rem;
}

.wishes-form-wrap .form-control {
  background: rgba(255,255,255,0.07);
  border-color: rgba(255,255,255,0.1);
  color: var(--white);
}

.wishes-form-wrap .form-control:focus {
  border-color: var(--gold);
  background: rgba(255,255,255,0.1);
  box-shadow: 0 0 0 3px rgba(201,168,76,0.15);
}

.wishes-form-wrap .form-label { color: rgba(255,255,255,0.7); }

.wishes-list {
  max-width: 700px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  max-height: 500px;
  overflow-y: auto;
  padding-right: 0.5rem;
}

.wishes-list::-webkit-scrollbar { width: 4px; }
.wishes-list::-webkit-scrollbar-track { background: transparent; }
.wishes-list::-webkit-scrollbar-thumb { background: rgba(201,168,76,0.3); border-radius: 4px; }

.wish-card {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(201,168,76,0.12);
  border-radius: 1rem;
  padding: 1.25rem 1.5rem;
  animation: fadeInUp 0.5s var(--ease) both;
}

.wish-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.6rem;
}

.wish-avatar {
  width: 38px;
  height: 38px;
  background: linear-gradient(135deg, var(--navy-soft), var(--navy-light));
  border: 1.5px solid rgba(201,168,76,0.3);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 600;
  color: var(--gold-light);
  flex-shrink: 0;
}

.wish-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--gold-light);
}

.wish-date {
  font-size: 0.68rem;
  color: rgba(255,255,255,0.35);
  margin-left: auto;
}

.wish-message {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.65);
  line-height: 1.7;
  font-style: italic;
}

/* ── Digital Envelope Section ────────────────────────────── */
#envelope {
  background: var(--cream);
  padding: var(--section-py) 0;
}

.envelope-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.75rem;
  max-width: 700px;
  margin: 2.5rem auto 0;
}

.bank-card {
  background: linear-gradient(135deg, var(--navy-dark) 0%, var(--navy-mid) 50%, var(--navy-light) 100%);
  border-radius: 1.25rem;
  padding: 2rem;
  position: relative;
  overflow: hidden;
  transition: transform var(--duration) var(--ease), box-shadow var(--duration) var(--ease);
  box-shadow: var(--shadow-md);
}

.bank-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.bank-card::before {
  content: '';
  position: absolute;
  top: -40%;
  right: -20%;
  width: 200px;
  height: 200px;
  background: radial-gradient(circle, rgba(201,168,76,0.12), transparent 70%);
}

.bank-logo-text {
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--gold-light);
  margin-bottom: 1.5rem;
  letter-spacing: 0.05em;
}

.bank-account-number {
  font-family: 'Courier New', monospace;
  font-size: 1.3rem;
  font-weight: 600;
  color: var(--white);
  letter-spacing: 0.15em;
  margin-bottom: 0.4rem;
}

.bank-account-name {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.65);
  font-style: italic;
}

.btn-copy {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin-top: 1.25rem;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  color: var(--white);
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  padding: 0.5rem 1rem;
  border-radius: 50px;
  cursor: pointer;
  transition: all var(--duration) var(--ease);
}

.btn-copy:hover { background: rgba(201,168,76,0.2); border-color: var(--gold); }

.envelope-note {
  text-align: center;
  margin-top: 2rem;
  font-size: 0.8rem;
  color: var(--text-light);
  font-style: italic;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

/* ── WhatsApp Share Section ──────────────────────────────── */
#share-section {
  background: var(--navy-dark);
  padding: 5rem 0;
  text-align: center;
}

.btn-whatsapp {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  background: #25D366;
  color: var(--white);
  padding: 1rem 2.5rem;
  border-radius: 50px;
  font-size: 0.9rem;
  font-weight: 600;
  transition: all var(--duration) var(--ease);
  box-shadow: 0 4px 20px rgba(37,211,102,0.3);
  border: none;
  cursor: pointer;
}

.btn-whatsapp:hover {
  background: #1DA851;
  transform: translateY(-3px);
  box-shadow: 0 8px 30px rgba(37,211,102,0.4);
}

/* ── Footer ──────────────────────────────────────────────── */
footer {
  background: var(--navy-deep);
  padding: 3rem 0;
  text-align: center;
  border-top: 1px solid rgba(201,168,76,0.15);
}

footer .footer-names {
  font-family: var(--font-script);
  font-size: 2.5rem;
  color: var(--gold-light);
  display: block;
  margin-bottom: 0.5rem;
}

footer .footer-date {
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  color: rgba(255,255,255,0.4);
  text-transform: uppercase;
}

footer .footer-credit {
  margin-top: 2rem;
  font-size: 0.7rem;
  color: rgba(255,255,255,0.2);
}

/* ── Scroll-Reveal Animations ────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s var(--ease), transform 0.7s var(--ease);
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Navigation Dots ─────────────────────────────────────── */
#nav-dots {
  position: fixed;
  right: 1.25rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 500;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.nav-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(201,168,76,0.3);
  border: 1.5px solid rgba(201,168,76,0.5);
  cursor: pointer;
  transition: all var(--duration) var(--ease);
  position: relative;
}

.nav-dot.active, .nav-dot:hover {
  background: var(--gold);
  border-color: var(--gold);
  transform: scale(1.3);
}

.nav-dot::before {
  content: attr(data-label);
  position: absolute;
  right: calc(100% + 0.75rem);
  top: 50%;
  transform: translateY(-50%);
  background: var(--navy-dark);
  color: var(--gold-light);
  font-size: 0.65rem;
  font-weight: 500;
  padding: 0.2rem 0.5rem;
  border-radius: 4px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration);
}

.nav-dot:hover::before { opacity: 1; }

/* ── Scroll Progress Bar (Mobile) ────────────────────────────── */
#scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  width: 0%;
  background: linear-gradient(90deg, var(--gold), var(--gold-light));
  z-index: 600;
  transition: width 0.1s linear;
  box-shadow: 0 0 8px rgba(201,168,76,0.5);
  display: none;  /* default hidden, hanya muncul di mobile */
}

@media (max-width: 768px) {
  #scroll-progress { display: block; }
}


/* ── Notification Toast ──────────────────────────────────── */
.toast {
  position: fixed;
  bottom: 5rem;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  z-index: 9999;
  background: var(--navy-dark);
  color: var(--white);
  padding: 0.85rem 1.5rem;
  border-radius: 50px;
  font-size: 0.82rem;
  font-weight: 500;
  border: 1px solid rgba(201,168,76,0.3);
  box-shadow: var(--shadow-md);
  opacity: 0;
  transition: all 0.3s var(--ease);
  max-width: 88vw;
  text-align: center;
  line-height: 1.4;
}

.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast.success { border-color: #22C55E; }
.toast.error   { border-color: #EF4444; }

/* ── Maps Section ────────────────────────────────────────── */
.maps-embed-wrapper {
  width: 100%;
  height: 350px;
  border-radius: 1rem;
  overflow: hidden;
  border: 1px solid rgba(201,168,76,0.2);
  margin-top: 1.5rem;
  box-shadow: var(--shadow-sm);
}

.maps-embed-wrapper iframe {
  width: 100%;
  height: 100%;
  border: none;
}

/* ── Responsive Design ───────────────────────────────────── */
@media (max-width: 900px) {
  :root { --section-py: 4rem; }

  .couple-grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  .couple-divider {
    flex-direction: row;
    justify-content: center;
  }
  .couple-divider .couple-divider-line {
    width: 60px;
    height: 1px;
    background: linear-gradient(to right, transparent, var(--gold), transparent);
  }

  .timeline::before { left: 30px; transform: none; }
  .timeline-item {
    grid-template-columns: 60px 1fr !important;
    grid-template-rows: auto;
  }
  .timeline-item:nth-child(odd) .timeline-content,
  .timeline-item:nth-child(even) .timeline-content {
    grid-column: 2 !important;
    grid-row: 1 !important;
    text-align: left !important;
  }
  .timeline-item:nth-child(odd) .timeline-dot,
  .timeline-item:nth-child(even) .timeline-dot {
    grid-column: 1 !important;
    grid-row: 1 !important;
  }
  .timeline-item .timeline-empty { display: none; }

  /* gallery-grid removed (using showcase layout) */
  

  .countdown-grid { gap: 0.75rem; max-width: 360px; }

  #nav-dots { display: none; }
}

@media (max-width: 600px) {
  :root { --section-py: 3rem; }

  .rsvp-form-wrap { padding: 1.5rem; }
  .wishes-form-wrap { padding: 1.5rem; }
  .attendance-options { grid-template-columns: 1fr; }

  /* gallery-grid removed (using showcase layout) */

  .hero-corner { width: 80px; height: 80px; }

  .countdown-grid { max-width: 300px; gap: 0.5rem; }
  .countdown-item:not(:last-child)::after { right: -0.5rem; }

  #music-player { bottom: 1rem; left: 1rem; padding: 0.5rem 0.9rem; }
  #music-player .music-info { display: none; }
}

/* ── Reduced Motion ──────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* ── Amplop Digital Fix ──────────────────────────────────────── */
.section-gift {
  padding   : 5rem 1.5rem;
  background: var(--white, #fff);
}
.section-gift .container {
  max-width : 700px;
  margin    : 0 auto;
}
.bank-cards {
  display              : grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap                  : 1.25rem;
  margin-top           : 2rem;
  max-width            : 700px;
  margin-left          : auto;
  margin-right         : auto;
}
.bank-card {
  background    : linear-gradient(135deg, #0A1628 0%, #14294E 100%) !important;
  border-radius : 16px !important;
  padding       : 1.75rem 2rem !important;
  color         : #fff !important;
  max-width     : 400px !important;
  width         : 100% !important;
  margin        : 0 auto !important;
  box-shadow    : 0 8px 32px rgba(10,22,40,.3) !important;
}
.bank-logo-text {
  font-size   : 1.3rem !important;
  font-weight : 700 !important;
  color       : #C9A84C !important;
  margin-bottom: 1rem !important;
  letter-spacing: .05em !important;
}
.bank-account-number {
  font-size     : 1.4rem !important;
  font-weight   : 700 !important;
  letter-spacing: .15em !important;
  color         : #fff !important;
  margin-bottom : .5rem !important;
  font-family   : monospace !important;
}
.bank-account-name {
  font-size   : .85rem !important;
  color       : rgba(255,255,255,.6) !important;
  font-style  : italic !important;
  margin-bottom: 1.25rem !important;
}
.btn-copy {
  display       : inline-flex !important;
  align-items   : center !important;
  gap           : .4rem !important;
  padding       : .55rem 1.25rem !important;
  background    : rgba(255,255,255,.1) !important;
  border        : 1px solid rgba(255,255,255,.2) !important;
  border-radius : 30px !important;
  color         : #fff !important;
  font-size     : .82rem !important;
  cursor        : pointer !important;
  transition    : all .2s !important;
  font-weight   : 500 !important;
}
.btn-copy:hover {
  background : rgba(255,255,255,.2) !important;
  transform  : translateY(-1px) !important;
}

@media (max-width: 600px) {
  .bank-cards { grid-template-columns: 1fr !important; }
  .bank-card  { max-width: 100% !important; padding: 1.5rem !important; }
  .bank-account-number { font-size: 1.2rem !important; letter-spacing: .1em !important; }
}

/* ── Gift Tabs ───────────────────────────────────────────────── */
.gift-tabs {
  display        : flex;
  justify-content: center;
  gap            : .5rem;
  margin         : 1.5rem 0 2rem;
}
.gift-tab-btn {
  padding       : .6rem 1.75rem;
  border-radius : 30px;
  border        : 2px solid rgba(255,255,255,.2);
  background    : transparent;
  color         : rgba(255,255,255,.6);
  font-size     : .85rem;
  font-weight   : 600;
  cursor        : pointer;
  transition    : all .25s;
}
.gift-tab-btn.active {
  background   : rgba(255,255,255,.15);
  border-color : var(--gold, #C9A84C);
  color        : #fff;
}
.gift-tab-content { animation: fadeIn .3s ease; }
@keyframes fadeIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }

/* ── QRIS ────────────────────────────────────────────────────── */
.qris-container { display:flex; justify-content:center; padding:1rem 0; }
.qris-card {
  background    : rgba(255,255,255,.05);
  border        : 1px solid rgba(255,255,255,.1);
  border-radius : 16px;
  padding       : 2rem;
  text-align    : center;
  max-width     : 320px;
  width         : 100%;
}
.qris-label {
  color        : rgba(255,255,255,.7);
  font-size    : .85rem;
  margin-bottom: 1.25rem;
}
.qris-image {
  width        : 100%;
  max-width    : 250px;
  border-radius: 12px;
  border       : 4px solid #fff;
  box-shadow   : 0 8px 32px rgba(0,0,0,.3);
}
.qris-note {
  color      : rgba(255,255,255,.4);
  font-size  : .75rem;
  margin-top : 1rem;
}

/* ── Copy button feedback ────────────────────────────────────── */
.btn-copy.copied {
  background : rgba(34,197,94,.2) !important;
  border-color: rgba(34,197,94,.4) !important;
  color      : #86efac !important;
}

/* ── Gift Tabs ───────────────────────────────────────────────── */
.gift-tabs { display:flex; justify-content:center; gap:.5rem; margin:1.5rem 0 2rem; flex-wrap:wrap; }
.gift-tab-btn {
  padding:.6rem 1.75rem; border-radius:30px;
  border:2px solid rgba(255,255,255,.2); background:transparent;
  color:rgba(255,255,255,.6); font-size:.85rem; font-weight:600;
  cursor:pointer; transition:all .25s;
}
.gift-tab-btn.active { background:rgba(255,255,255,.15); border-color:#C9A84C; color:#fff; }
.gift-tab-content { animation:fadeInUp .3s ease; }
@keyframes fadeInUp { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }

/* ── QRIS ────────────────────────────────────────────────────── */
.qris-container { display:flex; justify-content:center; padding:1rem 0; }
.qris-card {
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1);
  border-radius:16px; padding:2rem; text-align:center; max-width:320px; width:100%;
}
.qris-label { color:rgba(255,255,255,.7); font-size:.85rem; margin-bottom:1.25rem; }
.qris-image { width:100%; max-width:250px; border-radius:12px; border:4px solid #fff; box-shadow:0 8px 32px rgba(0,0,0,.3); }
.qris-note { color:rgba(255,255,255,.4); font-size:.75rem; margin-top:1rem; }

/* ── Gift Tabs Override (background terang) ──────────────────── */
.section-gift .gift-tabs { margin: 1.5rem 0 2rem; }
.section-gift .gift-tab-btn {
  border : 2px solid #0A1628 !important;
  color  : #0A1628 !important;
  background: transparent !important;
  font-weight: 600 !important;
  padding: .6rem 1.5rem !important;
  border-radius: 30px !important;
  cursor: pointer !important;
  transition: all .25s !important;
  font-size: .85rem !important;
}
.section-gift .gift-tab-btn.active {
  background : #0A1628 !important;
  color      : #C9A84C !important;
  border-color: #0A1628 !important;
}
.section-gift .gift-tab-btn:hover {
  background: rgba(10,22,40,.08) !important;
}

/* ═══════════════════════════════════════════════════════════════
   AMPLOP DIGITAL — Complete Redesign (Mobile-First)
   ═══════════════════════════════════════════════════════════════ */
.section-gift { padding: 4rem 1.25rem !important; }
.section-gift .container { max-width: 600px !important; margin: 0 auto !important; }
.gift-tabs { display:flex !important; justify-content:center !important; gap:.5rem !important; margin:2rem 0 1.75rem !important; }
.gift-tab-btn { flex:1 !important; max-width:180px !important; padding:.7rem 1rem !important; border-radius:10px !important; border:2px solid #0A1628 !important; background:transparent !important; color:#0A1628 !important; font-size:.82rem !important; font-weight:600 !important; cursor:pointer !important; transition:all .2s !important; touch-action:manipulation !important; user-select:none !important; -webkit-tap-highlight-color:transparent !important; }
.gift-tab-btn.active, .gift-tab-btn:active { background:#0A1628 !important; color:#C9A84C !important; border-color:#0A1628 !important; }
.bank-cards { display:grid !important; grid-template-columns:1fr !important; gap:1rem !important; max-width:480px !important; margin:0 auto !important; }
@media(min-width:600px){ .bank-cards { grid-template-columns:repeat(auto-fit,minmax(200px,1fr)) !important; } }
.bank-card { background:linear-gradient(145deg,#0A1628 0%,#14294E 100%) !important; border-radius:16px !important; padding:1.5rem !important; color:#fff !important; box-shadow:0 6px 24px rgba(10,22,40,.25) !important; max-width:100% !important; }
.bank-logo-text { font-size:1.1rem !important; font-weight:800 !important; color:#C9A84C !important; letter-spacing:.08em !important; margin-bottom:.85rem !important; }
.bank-account-number { font-size:1.3rem !important; font-weight:700 !important; letter-spacing:.12em !important; font-family:'Courier New',monospace !important; margin-bottom:.4rem !important; word-break:break-all !important; }
.bank-account-name { font-size:.8rem !important; color:rgba(255,255,255,.55) !important; font-style:italic !important; margin-bottom:1.1rem !important; }
.btn-copy { display:inline-flex !important; align-items:center !important; gap:.4rem !important; padding:.55rem 1.25rem !important; background:rgba(255,255,255,.1) !important; border:1px solid rgba(255,255,255,.25) !important; border-radius:30px !important; color:#fff !important; font-size:.8rem !important; font-weight:500 !important; cursor:pointer !important; touch-action:manipulation !important; -webkit-tap-highlight-color:transparent !important; }
.btn-copy:active { transform:scale(.96) !important; }
.qris-container { display:flex !important; justify-content:center !important; padding:.5rem 0 !important; }
.qris-card { background:#fff !important; border-radius:20px !important; padding:1.75rem 1.5rem !important; text-align:center !important; max-width:320px !important; width:100% !important; box-shadow:0 8px 32px rgba(10,22,40,.15) !important; }
.qris-label { color:#0A1628 !important; font-size:.88rem !important; font-weight:600 !important; margin-bottom:1.25rem !important; }
.qris-image { width:100% !important; max-width:240px !important; border-radius:12px !important; border:none !important; display:block !important; margin:0 auto !important; box-shadow:0 4px 16px rgba(0,0,0,.1) !important; }
.qris-note { color:#64748B !important; font-size:.75rem !important; margin-top:1rem !important; }
@media(max-width:400px){ .gift-tab-btn{font-size:.76rem !important;padding:.6rem .75rem !important;} .bank-account-number{font-size:1.1rem !important;} }

/* ── Gift Section Final Override ─────────────────────────────── */
#gift .section-ornament { display:none !important; }
#gift .section-header   { margin-bottom:1rem !important; }
#gift .section-title    { margin-bottom:.5rem !important; }

.gift-tab-btn {
  -webkit-appearance : none !important;
  appearance         : none !important;
  outline            : none !important;
  touch-action       : manipulation !important;
  cursor             : pointer !important;
  border             : 2px solid #0A1628 !important;
  background         : #fff !important;
  color              : #0A1628 !important;
  padding            : .65rem 1.1rem !important;
  border-radius      : 10px !important;
  font-size          : .82rem !important;
  font-weight        : 600 !important;
  flex               : 1 !important;
  max-width          : 160px !important;
  transition         : all .2s !important;
}
.gift-tab-btn.active {
  background: #0A1628 !important;
  color     : #C9A84C !important;
}
.gift-tabs {
  display         : flex !important;
  gap             : .5rem !important;
  justify-content : center !important;
  margin          : 1.5rem 0 !important;
  padding         : 0 !important;
}

/* ── Lightbox Nav Fix ─────────────────────────────────────────── */
#lightbox {
  opacity     : 0 !important;
  visibility  : hidden !important;
  transition  : opacity .3s, visibility .3s !important;
}
#lightbox.active {
  opacity    : 1 !important;
  visibility : visible !important;
}
#lightbox img {
  transition : opacity .15s !important;
  max-width  : calc(100vw - 120px) !important;
  max-height : 75vh !important;
}

/* ── Gallery Performance ─────────────────────────────────────── */
.gallery-main img, .gallery-thumb img {
  transform: translateZ(0);  /* GPU acceleration */
}
.reveal {
  transition: opacity .5s ease-out, transform .5s ease-out !important;
}

/* ── SVG Line Icons (pengganti emoji) ────────────────────────── */
/* Ornamen pembatas antar section */
.divider-ornament .ornament-svg {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
  width: 28px;
  height: 28px;
}
.divider-ornament .ornament-svg svg {
  width: 100%;
  height: 100%;
}

/* Ikon di dalam kartu Detail Acara */
.event-detail-icon svg {
  width: 18px;
  height: 18px;
  color: var(--gold-dark, #B8923D);
}

/* ── Photo Tone Harmonization (filter halus penyeragam) ──────── */
/* Tujuan: semua foto galeri terasa satu "keluarga warna" tanpa
   mengubah file asli. Sangat halus — saturasi sedikit turun +
   warmth seragam + kontras lembut. */
.gallery-main img,
.gallery-thumb img {
  filter:
    saturate(0.92)      /* turunkan saturasi tipis agar tidak norak */
    contrast(1.02)      /* kontras lembut */
    brightness(1.01)
    sepia(0.06);        /* sentuhan hangat seragam (sangat tipis) */
  transition: filter 0.4s var(--ease), opacity 0.35s var(--ease);
}

/* Overlay navy super tipis di foto utama agar menyatu dengan tema */
.gallery-main::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    160deg,
    rgba(10, 22, 40, 0.06) 0%,
    rgba(10, 22, 40, 0.00) 45%,
    rgba(201, 168, 76, 0.04) 100%
  );
  pointer-events: none;
  border-radius: inherit;
  z-index: 1;
}

/* Pastikan caption tetap di atas overlay */
.gallery-main-caption { z-index: 2; }

/* ════════════════════════════════════════════════════════════
   HERO FLOATING PARTICLES + BACKGROUND TEXTURE
   ════════════════════════════════════════════════════════════ */

/* ── Container partikel (menutupi hero) ──────────────────────── */
.hero-particles {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 1;
}

/* ── Partikel emas (bulat berkilau) ──────────────────────────── */
.particle {
  position: absolute;
  top: -20px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%,
    rgba(255, 240, 200, 0.95),
    rgba(201, 168, 76, 0.6) 60%,
    rgba(201, 168, 76, 0) 100%);
  box-shadow: 0 0 6px rgba(201, 168, 76, 0.4);
  animation-name: particleFall;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
  will-change: transform, opacity;
}

/* ── Partikel berbentuk kelopak (petal) ──────────────────────── */
.particle.petal {
  border-radius: 50% 0 50% 0;
  background: linear-gradient(135deg,
    rgba(255, 235, 190, 0.85),
    rgba(201, 168, 76, 0.5));
  box-shadow: 0 0 8px rgba(201, 168, 76, 0.3);
  animation-name: petalFall;
}

/* ── Animasi jatuh + goyang (drift) untuk bulat ──────────────── */
@keyframes particleFall {
  0% {
    transform: translateY(0) translateX(0);
    opacity: 0;
  }
  10% { opacity: 1; }
  90% { opacity: 1; }
  100% {
    transform: translateY(105vh) translateX(var(--drift, 0));
    opacity: 0;
  }
}

/* ── Animasi jatuh + berputar untuk kelopak ──────────────────── */
@keyframes petalFall {
  0% {
    transform: translateY(0) translateX(0) rotate(0deg);
    opacity: 0;
  }
  10% { opacity: 1; }
  90% { opacity: 1; }
  100% {
    transform: translateY(105vh) translateX(var(--drift, 0)) rotate(360deg);
    opacity: 0;
  }
}

/* ════════════════════════════════════════════════════════════
   BACKGROUND TEXTURE — motif samar di area navy
   ════════════════════════════════════════════════════════════ */
/* Tekstur halus berbasis SVG pattern (floral/dot) dengan opacity rendah.
   Diterapkan pada body agar semua section navy terasa lebih "berkelas". */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.4;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(201,168,76,0.04) 0%, transparent 8%),
    radial-gradient(circle at 80% 20%, rgba(201,168,76,0.03) 0%, transparent 7%),
    radial-gradient(circle at 60% 70%, rgba(201,168,76,0.03) 0%, transparent 9%),
    radial-gradient(circle at 35% 85%, rgba(201,168,76,0.04) 0%, transparent 8%),
    url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23C9A84C' stroke-opacity='0.03' stroke-width='1'%3E%3Cpath d='M30 5 Q35 20 30 30 Q25 20 30 5 Z'/%3E%3Cpath d='M30 55 Q35 40 30 30 Q25 40 30 55 Z'/%3E%3Cpath d='M5 30 Q20 35 30 30 Q20 25 5 30 Z'/%3E%3Cpath d='M55 30 Q40 35 30 30 Q40 25 55 30 Z'/%3E%3Ccircle cx='30' cy='30' r='2'/%3E%3C/g%3E%3C/svg%3E");
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat, repeat;
  background-size: auto, auto, auto, auto, 120px 120px;
}

/* Pastikan konten tetap di atas tekstur */
#main-content, #cover-opening { position: relative; z-index: 1; }

/* Section dengan background terang (putih/cream) tidak perlu tekstur navy */
.section-events,
.section-gift,
#gift { position: relative; z-index: 1; }
