/* =========================================================
   Aldi & Feni — Wedding Invitation
   Aesthetic: cinematic, frozen/HUD (igloo.inc-inspired)
   ========================================================= */

:root{
  --ink:        #1c2024;   /* near-black blue */
  --frost:      #f4f6f8;   /* off white */
  --ice:        #cdd8e0;   /* cool grey-blue */
  --steel:      #8a97a3;
  --line:       rgba(28,32,36,.14);
  --gold:       #b08d57;   /* warm accent */
  --gold-soft:  #cbb088;
  --bg:         #eef1f4;
  --shadow:     0 30px 80px -30px rgba(28,32,36,.45);
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'Montserrat', system-ui, sans-serif;
  --mono:  'JetBrains Mono', ui-monospace, monospace;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.is-locked{ overflow:hidden; height:100vh; }
img{ display:block; max-width:100%; }

/* ---------- HUD / monospace labels ---------- */
.hud{
  font-family:var(--mono);
  font-size:.62rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--steel);
}
.hud.center{ text-align:center; }

/* ---------- Ambient snow ---------- */
#snow{
  position:fixed; inset:0;
  width:100%; height:100%;
  pointer-events:none; z-index:60;
  opacity:.55;
}

/* =========================================================
   COVER / GATE
   ========================================================= */
.cover{
  position:fixed; inset:0; z-index:100;
  display:flex; align-items:center; justify-content:center;
  text-align:center; color:var(--frost);
  overflow:hidden;
  transition:opacity 1.1s ease, transform 1.4s cubic-bezier(.7,0,.2,1);
}
.cover__bg{
  position:absolute; inset:0;
  background-size:cover; background-position:center 30%;
  transform:scale(1.12);
  filter:grayscale(.35) brightness(.62) contrast(1.05);
  animation:slowZoom 18s ease-out infinite alternate;
}
@keyframes slowZoom{ to{ transform:scale(1.22); } }
.cover__veil{
  position:absolute; inset:0;
  background:
    radial-gradient(120% 90% at 50% 18%, rgba(20,26,32,.15), rgba(15,20,26,.78) 78%),
    linear-gradient(180deg, rgba(15,20,26,.55), rgba(15,20,26,.35));
}
.cover__inner{
  position:relative; z-index:2;
  padding:2rem 1.4rem;
  max-width:560px;
  animation:coverIn 1.4s .15s both cubic-bezier(.2,.7,.2,1);
}
@keyframes coverIn{ from{opacity:0; transform:translateY(24px);} to{opacity:1; transform:none;} }
.hud--top{ color:rgba(244,246,248,.6); margin-bottom:2rem; }
.cover__eyebrow{
  font-family:var(--serif); font-style:italic;
  font-size:1.25rem; color:var(--gold-soft); margin-bottom:.4rem;
  letter-spacing:.02em;
}
.cover__names{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(3.4rem, 14vw, 6.2rem);
  line-height:.95; letter-spacing:.01em;
}
.cover__names span{ display:block; font-size:.42em; font-style:italic; color:var(--gold-soft); margin:.1em 0; }
.cover__divider{
  display:flex; align-items:center; justify-content:center; gap:.9rem;
  font-family:var(--mono); font-size:.6rem; letter-spacing:.3em;
  color:rgba(244,246,248,.7); margin:1.6rem 0 .8rem;
}
.cover__divider span{ width:38px; height:1px; background:rgba(244,246,248,.4); }
.cover__date{
  font-family:var(--serif); font-size:1.5rem; letter-spacing:.04em;
}
.cover__date sup{ font-size:.55em; }
.cover__guest{ margin:2.2rem 0 1.6rem; }
.cover__guest-label{ font-size:.62rem; letter-spacing:.22em; text-transform:uppercase; color:rgba(244,246,248,.55); margin-bottom:.5rem; }
.cover__guest-name{
  font-family:var(--serif); font-size:1.7rem; color:var(--frost);
  border-bottom:1px solid rgba(244,246,248,.25); display:inline-block;
  padding-bottom:.3rem; min-width:160px;
}
.btn-open{
  margin-top:.6rem; cursor:pointer;
  font-family:var(--mono); font-size:.66rem; letter-spacing:.25em; text-transform:uppercase;
  color:var(--ink); background:var(--frost);
  border:none; border-radius:100px;
  padding:1.05rem 2.2rem;
  transition:transform .4s, background .4s, color .4s, box-shadow .4s;
  box-shadow:0 14px 40px -12px rgba(0,0,0,.6);
}
.btn-open:hover{ transform:translateY(-3px); background:var(--gold); color:#fff; }
.hud--bottom{ color:rgba(244,246,248,.4); margin-top:2.4rem; }

.cover.is-hidden{ opacity:0; transform:scale(1.06); pointer-events:none; }

/* =========================================================
   GENERIC SECTION
   ========================================================= */
.section{
  position:relative;
  padding:clamp(4.5rem,11vw,9rem) clamp(1.3rem,6vw,5rem);
  max-width:1180px; margin:0 auto;
}
.bg-section{ max-width:none; }
.bg-section > *{ max-width:1180px; margin-left:auto; margin-right:auto; }
.bg-section{ background:linear-gradient(180deg, #e7ebef, #eef1f4); }

.center{ text-align:center; }
.section-title{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(2.4rem,7vw,4rem);
  text-align:center; line-height:1.05; margin:.6rem auto 1.4rem;
}
.section-title.light{ color:var(--frost); }
.lead{
  font-family:var(--serif); font-size:clamp(1.15rem,2.4vw,1.5rem);
  line-height:1.6; color:#3a424a; max-width:680px; margin:0 auto 1rem;
  font-weight:400;
}
.lead.light{ color:rgba(244,246,248,.86); }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(34px); }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  max-width:none; min-height:100vh;
  display:flex; flex-direction:column; justify-content:center;
  padding:0; overflow:hidden;
}
.hero__media{ position:absolute; inset:0; overflow:hidden; }
.hero__img{
  position:absolute; left:0; top:-8%;
  width:100%; height:116%; object-fit:cover; object-position:center 22%;
  filter:grayscale(.3) brightness(.7) contrast(1.05);
}
.hero__grade{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(20,26,32,.45), rgba(20,26,32,.25) 40%, rgba(20,26,32,.7));
}
.hero__content{
  position:relative; z-index:2; color:var(--frost);
  padding:0 clamp(1.5rem,7vw,6rem); max-width:760px;
}
.hero__content .hud{ color:var(--gold-soft); margin-bottom:1.4rem; }
.hero__title{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(2.8rem,9vw,5.4rem); line-height:1.02;
}
.hero__mission{
  font-family:var(--serif); font-style:italic;
  font-size:clamp(1.1rem,2.6vw,1.6rem);
  margin-top:1.4rem; color:rgba(244,246,248,.85); max-width:520px;
}
.scroll-cue{
  position:absolute; bottom:2.4rem; left:50%; transform:translateX(-50%);
  z-index:2; font-family:var(--mono); font-size:.6rem; letter-spacing:.25em;
  text-transform:uppercase; color:rgba(244,246,248,.7);
  display:flex; flex-direction:column; align-items:center; gap:.7rem;
}
.scroll-cue__line{ width:1px; height:42px; background:linear-gradient(rgba(244,246,248,.7), transparent); animation:cue 2s ease-in-out infinite; transform-origin:top; }
@keyframes cue{ 0%,100%{ transform:scaleY(.4); opacity:.4;} 50%{ transform:scaleY(1); opacity:1;} }

/* =========================================================
   BRIDE & GROOM
   ========================================================= */
.bismillah{
  font-family:var(--serif); font-size:clamp(1.5rem,5vw,2.4rem);
  text-align:center; color:var(--gold); margin:.6rem auto 1.2rem; line-height:1.8;
}
.salam{
  text-align:center; font-family:var(--mono); font-size:.7rem;
  letter-spacing:.18em; color:var(--steel); margin:0 auto 2rem; text-transform:uppercase;
}
.people{
  display:grid; grid-template-columns:1fr auto 1fr; gap:clamp(1.5rem,4vw,3.5rem);
  align-items:start; margin-top:3.5rem;
}
.people__amp{
  font-family:var(--serif); font-style:italic; font-size:3rem;
  color:var(--gold-soft); align-self:center; padding-top:6rem; text-align:center;
}
.person{ text-align:center; }
.person__frame{ position:relative; overflow:hidden; border-radius:6px; box-shadow:var(--shadow); }
.person__frame img{
  width:100%; aspect-ratio:3/4; object-fit:cover;
  filter:grayscale(.25) contrast(1.03);
  transition:transform 1.2s cubic-bezier(.2,.7,.2,1), filter .8s;
}
.person:hover .person__frame img{ transform:scale(1.05); filter:grayscale(0); }
.person__tag{
  position:absolute; left:.8rem; bottom:.8rem;
  font-family:var(--mono); font-size:.54rem; letter-spacing:.18em;
  color:var(--frost); background:rgba(20,26,32,.5); backdrop-filter:blur(4px);
  padding:.35rem .6rem; border-radius:3px;
}
.person__name{
  font-family:var(--serif); font-weight:600; font-size:clamp(1.4rem,3.4vw,1.9rem);
  margin:1.3rem 0 .2rem;
}
.person__role{ font-family:var(--mono); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:.9rem; }
.person__parents{ font-family:var(--serif); font-size:1.05rem; line-height:1.6; color:#48515a; max-width:380px; margin:0 auto 1.2rem; }
.ig-btn{
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:var(--mono); font-size:.6rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink); text-decoration:none;
  border:1px solid var(--line); border-radius:100px; padding:.6rem 1.1rem;
  transition:.35s;
}
.ig-btn:hover{ background:var(--ink); color:var(--frost); border-color:var(--ink); }

/* =========================================================
   STORY
   ========================================================= */
.story__intro{
  font-family:var(--serif); font-style:italic; font-size:clamp(1.2rem,3vw,1.7rem);
  text-align:center; max-width:640px; margin:0 auto 3rem; line-height:1.6; color:#3a424a;
}
.timeline{
  display:flex; flex-wrap:wrap; gap:1.2rem; justify-content:center; margin-bottom:3rem;
}
.tl-item{
  flex:1 1 280px; max-width:420px;
  border:1px solid var(--line); border-radius:6px; padding:1.6rem 1.8rem;
  background:rgba(255,255,255,.5); backdrop-filter:blur(4px);
}
.tl-date{ font-family:var(--mono); font-size:.62rem; letter-spacing:.2em; color:var(--gold); display:block; margin-bottom:.7rem; }
.tl-item p{ font-family:var(--serif); font-size:1.1rem; line-height:1.55; color:#3a424a; }
.story__prose{ max-width:680px; margin:0 auto; }
.story__prose p{
  font-family:var(--serif); font-size:clamp(1.08rem,2.3vw,1.28rem);
  line-height:1.85; color:#3a424a; margin-bottom:1.6rem; text-align:center;
}
.story__prose blockquote{
  font-family:var(--serif); font-style:italic; font-size:clamp(1.2rem,2.6vw,1.5rem);
  line-height:1.7; color:var(--ink); text-align:center;
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  padding:2rem 1rem; margin:2.4rem 0;
}
.story__quote{ text-align:center; margin:4rem auto 0; max-width:640px; }
.story__quote p{ font-family:var(--serif); font-style:italic; font-size:clamp(1.4rem,3.4vw,2rem); line-height:1.5; color:var(--ink); }
.story__quote figcaption{ font-family:var(--mono); font-size:.65rem; letter-spacing:.2em; color:var(--gold); margin-top:1.2rem; text-transform:uppercase; }

/* =========================================================
   COUNTDOWN
   ========================================================= */
.countdown-sec{ max-width:none; padding:0; overflow:hidden; }
.countdown-sec{ position:relative; }
.countdown-bg{
  position:absolute; left:0; top:-8%; width:100%; height:116%;
  background-size:cover; background-position:center 25%;
  filter:grayscale(.4) brightness(.55) contrast(1.05);
}
.countdown-veil{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(15,20,26,.7), rgba(15,20,26,.55)); }
.countdown-inner{
  position:relative; z-index:2; text-align:center;
  padding:clamp(5rem,12vw,9rem) clamp(1.3rem,6vw,5rem); max-width:900px; margin:0 auto;
}
.countdown-inner .hud{ color:var(--gold-soft); }
.cd{ display:flex; justify-content:center; gap:clamp(.6rem,3vw,2rem); margin-top:2.6rem; }
.cd__cell{
  min-width:clamp(64px,18vw,110px);
  border:1px solid rgba(244,246,248,.22); border-radius:6px;
  padding:1.2rem .6rem; backdrop-filter:blur(6px);
  background:rgba(244,246,248,.06);
}
.cd__cell span{ font-family:var(--serif); font-size:clamp(2rem,7vw,3.4rem); color:var(--frost); display:block; line-height:1; font-variant-numeric:tabular-nums; }
.cd__cell small{ font-family:var(--mono); font-size:.55rem; letter-spacing:.2em; text-transform:uppercase; color:rgba(244,246,248,.6); margin-top:.6rem; display:block; }

/* =========================================================
   EVENTS
   ========================================================= */
.events{ display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.6rem; margin-top:3rem; }
.event-card{
  border:1px solid var(--line); border-radius:8px; padding:2.2rem 2rem; text-align:center;
  background:rgba(255,255,255,.6); backdrop-filter:blur(6px);
  box-shadow:var(--shadow);
}
.event-card__tag{ font-family:var(--mono); font-size:.58rem; letter-spacing:.2em; color:var(--gold); }
.event-card h3{ font-family:var(--serif); font-weight:600; font-size:1.9rem; margin:.6rem 0 1rem; }
.event-card__time{ font-family:var(--serif); font-size:1.15rem; color:#3a424a; }
.event-card hr{ border:none; border-top:1px solid var(--line); width:50px; margin:1.3rem auto; }
.event-card__venue{ font-family:var(--serif); font-weight:600; font-size:1.25rem; margin-bottom:.5rem; }
.event-card__addr{ font-size:.85rem; line-height:1.6; color:#5a636c; max-width:300px; margin:0 auto; }
.map-btn{
  display:flex; align-items:center; justify-content:center; gap:.6rem;
  width:max-content; margin:2.6rem auto 0;
  font-family:var(--mono); font-size:.64rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--frost); background:var(--ink); text-decoration:none;
  padding:1rem 1.8rem; border-radius:100px; transition:.35s;
}
.map-btn:hover{ background:var(--gold); transform:translateY(-3px); }

/* =========================================================
   GALLERY
   ========================================================= */
.gallery-sec{ max-width:1320px; }
.gallery{
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:2.5rem;
}
.g-item{ overflow:hidden; border-radius:5px; box-shadow:var(--shadow); margin:0; }
.g-item img{ width:100%; height:100%; aspect-ratio:3/4; object-fit:cover; filter:grayscale(.2) contrast(1.03); transition:transform 1.1s cubic-bezier(.2,.7,.2,1), filter .6s; }
.g-item:hover img{ transform:scale(1.06); filter:grayscale(0); }

/* =========================================================
   GIFTS
   ========================================================= */
.gifts{ display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.6rem; margin-top:3rem; }
.gift-card{
  border:1px solid var(--line); border-radius:8px; padding:2rem; text-align:center;
  background:linear-gradient(160deg, #fff, #eef1f4);
  box-shadow:var(--shadow);
}
.gift-card--addr{ max-width:560px; margin:1.6rem auto 0; }
.gift-card__bank{ font-family:var(--mono); font-size:.66rem; letter-spacing:.25em; color:var(--gold); display:block; margin-bottom:1.2rem; }
.gift-card__logo{ height:34px; width:auto; margin:0 auto 1.3rem; object-fit:contain; }
.gift-card__label{ font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--steel); }
.gift-card__name{ font-family:var(--serif); font-size:1.2rem; margin:.3rem 0 .8rem; }
.gift-card__no{ font-family:var(--mono); font-size:1.25rem; letter-spacing:.06em; color:var(--ink); margin-bottom:1.2rem; }
.gift-card__no, .gift-card__no a{ color:var(--ink) !important; text-decoration:none !important; }
.gift-card__addr{ font-size:.9rem; line-height:1.6; color:#5a636c; margin-bottom:1.2rem; }
.copy-btn{
  cursor:pointer; font-family:var(--mono); font-size:.6rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink); background:transparent; border:1px solid var(--ink);
  border-radius:100px; padding:.7rem 1.4rem; transition:.3s;
}
.copy-btn:hover{ background:var(--ink); color:var(--frost); }
.copy-btn.copied{ background:var(--gold); border-color:var(--gold); color:#fff; }

/* =========================================================
   RSVP & WISHES
   ========================================================= */
.rsvp-form{
  max-width:540px; margin:3rem auto 0;
  background:rgba(255,255,255,.6); backdrop-filter:blur(6px);
  border:1px solid var(--line); border-radius:10px;
  padding:clamp(1.6rem,4vw,2.4rem); box-shadow:var(--shadow);
}
.field{ margin-bottom:1.4rem; text-align:left; }
.field > label{
  display:block; font-family:var(--mono); font-size:.6rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--steel); margin-bottom:.6rem;
}
.field input[type=text],
.field textarea,
.field select{
  width:100%; font-family:var(--serif); font-size:1.1rem; color:var(--ink);
  background:#fff; border:1px solid var(--line); border-radius:6px;
  padding:.85rem 1rem; transition:border-color .3s, box-shadow .3s;
}
.field input:focus,
.field textarea:focus,
.field select:focus{
  outline:none; border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(176,141,87,.12);
}
.field textarea{ resize:vertical; line-height:1.5; }

/* segmented radio */
.seg{ display:grid; grid-template-columns:repeat(3,1fr); gap:.5rem; }
.seg input{ position:absolute; opacity:0; pointer-events:none; }
.seg label{
  text-align:center; cursor:pointer;
  font-family:var(--mono); font-size:.62rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink); background:#fff; border:1px solid var(--line); border-radius:6px;
  padding:.8rem .4rem; transition:.25s;
}
.seg label:hover{ border-color:var(--gold-soft); }
.seg input:checked + label{ background:var(--ink); color:var(--frost); border-color:var(--ink); }
#rf-hadir:checked + label{ background:var(--gold); border-color:var(--gold); }

.rsvp-note{ font-size:.85rem; margin-bottom:1rem; text-align:center; }
.rsvp-note.ok{ color:#2e7d4f; }
.rsvp-note.err{ color:#b3402f; }
.rsvp-submit{
  width:100%; cursor:pointer;
  font-family:var(--mono); font-size:.66rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--frost); background:var(--ink); border:none; border-radius:100px;
  padding:1.05rem; transition:.3s;
}
.rsvp-submit:hover{ background:var(--gold); }
.rsvp-submit:disabled{ opacity:.6; cursor:wait; }

/* wishes list */
.wishes{ max-width:620px; margin:3.2rem auto 0; }
.wishes__head{ display:flex; align-items:baseline; justify-content:space-between; border-bottom:1px solid var(--line); padding-bottom:.8rem; margin-bottom:1.4rem; }
.wishes__count{ font-family:var(--mono); font-size:.6rem; letter-spacing:.14em; color:var(--gold); text-transform:uppercase; }
.wishes__list{ display:flex; flex-direction:column; gap:1rem; max-height:440px; overflow-y:auto; padding-right:.4rem; }
.wish{
  border:1px solid var(--line); border-radius:8px; padding:1.1rem 1.3rem;
  background:rgba(255,255,255,.55); text-align:left;
}
.wish__top{ display:flex; align-items:center; gap:.6rem; margin-bottom:.5rem; flex-wrap:wrap; }
.wish__name{ font-family:var(--serif); font-weight:600; font-size:1.15rem; }
.wish__badge{ font-family:var(--mono); font-size:.5rem; letter-spacing:.1em; text-transform:uppercase; padding:.22rem .5rem; border-radius:100px; }
.wish__badge.hadir{ background:rgba(176,141,87,.16); color:var(--gold); }
.wish__badge.ragu{ background:rgba(138,151,163,.18); color:var(--steel); }
.wish__badge.tidak{ background:rgba(179,64,47,.12); color:#b3402f; }
.wish__msg{ font-family:var(--serif); font-size:1.05rem; line-height:1.55; color:#3a424a; }
.wish__time{ font-family:var(--mono); font-size:.52rem; letter-spacing:.1em; color:var(--steel); margin-top:.5rem; }
.wishes__empty{ text-align:center; font-family:var(--serif); font-style:italic; color:var(--steel); padding:1.5rem; }

/* =========================================================
   CLOSING
   ========================================================= */
.closing{ max-width:none; padding:0; position:relative; overflow:hidden; }
.closing-bg{ position:absolute; left:0; top:-8%; width:100%; height:116%; background-size:cover; background-position:center 25%; filter:grayscale(.45) brightness(.5) contrast(1.05); }
.closing-veil{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(15,20,26,.72), rgba(15,20,26,.6)); }
.closing-inner{ position:relative; z-index:2; text-align:center; color:var(--frost); padding:clamp(5rem,14vw,10rem) 1.4rem; max-width:680px; margin:0 auto; }
.closing-inner .hud{ color:var(--gold-soft); }
.closing__text{ font-family:var(--serif); font-size:clamp(1.15rem,2.6vw,1.5rem); line-height:1.7; color:rgba(244,246,248,.88); margin:1.6rem 0; }
.closing__names{ font-family:var(--serif); font-weight:500; font-size:clamp(3rem,12vw,5rem); line-height:1; margin:.6rem 0; }
.closing__names span{ font-style:italic; color:var(--gold-soft); font-size:.5em; }
.closing__salam{ font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(244,246,248,.7); margin:1.4rem 0 2.4rem; }

.footer{ text-align:center; padding:3.4rem 1.4rem; background:var(--ink); color:rgba(244,246,248,.6); }
.footer__quote{
  font-family:var(--serif); font-style:italic;
  font-size:clamp(1.3rem,3vw,1.85rem); line-height:1.5;
  color:var(--frost); max-width:680px; margin:0 auto;
  text-shadow:0 1px 24px rgba(203,176,136,.35);
}
.footer__credit{ font-family:var(--mono); font-size:.62rem; letter-spacing:.22em; text-transform:uppercase; margin-top:1.8rem; color:rgba(244,246,248,.45); line-height:2; }
.footer__credit span{ color:var(--gold-soft); font-size:.9rem; letter-spacing:.14em; }

/* =========================================================
   MUSIC TOGGLE
   ========================================================= */
.music-toggle{
  position:fixed; right:1.2rem; bottom:1.2rem; z-index:90;
  width:52px; height:52px; border-radius:50%;
  background:var(--ink); border:1px solid rgba(244,246,248,.2);
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  box-shadow:0 12px 30px -8px rgba(0,0,0,.5);
  transition:transform .3s;
}
.music-toggle:hover{ transform:scale(1.08); }
.music-toggle__bars{ display:flex; align-items:flex-end; gap:2px; height:18px; }
.music-toggle__bars i{ width:2.5px; background:var(--gold-soft); height:6px; border-radius:2px; }
.music-toggle.playing .music-toggle__bars i{ animation:eq .9s ease-in-out infinite; }
.music-toggle.playing .music-toggle__bars i:nth-child(2){ animation-delay:.2s; }
.music-toggle.playing .music-toggle__bars i:nth-child(3){ animation-delay:.4s; }
.music-toggle.playing .music-toggle__bars i:nth-child(4){ animation-delay:.1s; }
@keyframes eq{ 0%,100%{ height:5px;} 50%{ height:18px;} }
.music-toggle__icon{ display:none; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:780px){
  .people{ grid-template-columns:1fr; }
  .people__amp{ padding:1rem 0; }
  .gallery{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:480px){
  .gallery{ grid-template-columns:repeat(2,1fr); gap:8px; }
  .cd__cell{ padding:.9rem .3rem; }
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.01ms !important; transition-duration:.01ms !important; }
  .reveal{ opacity:1 !important; transform:none !important; }
}
