/* ============================================================
   AMORE — Template CSS
   UndanganKu by Bacaunduh
   Slug: amore | Tier: premium | Category: wedding
   Konsep: Warm Mediterranean Rustic Luxury
   Palette: Terracotta #C4654A + Olive #6B7B45 + Sandy Ivory #F5EDE0
   Signature #1: SVG Arch motifs throughout
   Signature #2: Wavy-edge sections & staggered masonry
   BEDA TOTAL dari Sakura/Aurum/Eden/Celestia
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Raleway:wght@300;400;600;700&family=Pinyon+Script&display=swap');

/* ── 1. VARIABLES ──────────────────────────────────────────── */
:root {
  --c-primary:    var(--inv-primary,   #C4654A);
  --c-secondary:  var(--inv-secondary, #6B7B45);
  --c-terra:      #C4654A;
  --c-terra-lt:   #D4856A;
  --c-terra-pale: #F0D5CC;
  --c-terra-dim:  rgba(196,101,74,.15);
  --c-terra-deep: #A04035;
  --c-olive:      #6B7B45;
  --c-olive-lt:   #8A9E58;
  --c-olive-pale: #D8E4C8;
  --c-olive-dim:  rgba(107,123,69,.14);
  --c-sand:       #F5EDE0;
  --c-warm:       #EFE4D4;
  --c-cream:      #FAF5EE;
  --c-linen:      #F8F1E7;
  --c-brown:      #5C3D2A;
  --c-brown2:     rgba(92,61,42,.7);
  --c-brown3:     rgba(92,61,42,.42);
  --c-brown4:     rgba(92,61,42,.22);
  --c-brown5:     rgba(92,61,42,.1);
  --c-border:     rgba(196,101,74,.2);
  --c-border2:    rgba(92,61,42,.12);
  --am-serif:     'Playfair Display', Georgia, serif;
  --am-script:    'Pinyon Script', cursive;
  --am-sans:      'Raleway', system-ui, sans-serif;
  --am-text2:     var(--c-brown2);
  --am-text3:     var(--c-brown3);
  --max-w:        480px;
  --tr:           .45s cubic-bezier(.25,.8,.25,1);
}

/* ── 2. RESET ──────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:var(--am-sans);
  background:var(--c-sand);
  color:var(--c-brown);
  line-height:1.8;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer;border:none;outline:none;background:none}
input,textarea,select{font-family:inherit}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--c-sand)}
::-webkit-scrollbar-thumb{background:var(--c-terra-pale);border-radius:99px}

/* ── 3. WRAPPER ────────────────────────────────────────────── */
#am-wrap{
  max-width:var(--max-w);margin:0 auto;
  background:var(--c-sand);
  min-height:100vh;position:relative;overflow-x:hidden;
  box-shadow:0 0 60px rgba(92,61,42,.12);
}

/* ── 4. SCROLL REVEAL ──────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:none}
.d1{transition-delay:.12s}.d2{transition-delay:.25s}
.d3{transition-delay:.38s}.d4{transition-delay:.52s}

/* ── 5. SCROLL PROGRESS ────────────────────────────────────── */
#am-prog{
  position:fixed;top:0;left:0;height:3px;width:0%;
  background:linear-gradient(90deg,var(--c-terra),var(--c-olive),var(--c-terra-lt));
  z-index:9999;pointer-events:none;transition:width .1s linear;
}

/* ── 6. TOAST ──────────────────────────────────────────────── */
#am-toast{
  position:fixed;bottom:5.5rem;left:50%;
  transform:translateX(-50%) translateY(8px);
  background:var(--c-brown);color:var(--c-sand);
  padding:.625rem 1.375rem;border-radius:99px;
  font-size:.8125rem;white-space:nowrap;z-index:9998;
  opacity:0;pointer-events:none;transition:all .3s ease;
  font-family:var(--am-sans);
}
#am-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── 7. FLOAT CONTROLS ─────────────────────────────────────── */
#am-float{
  position:fixed;right:1rem;bottom: 5%;;transform:translateY(-50%);
  z-index:500;display:none;flex-direction:column;gap:.5rem;
}
.am-fb{
  width:30px;height:30px;border-radius:50%;
  background:rgba(250,245,238,.9);
  border:1.5px solid var(--c-border);
  color:var(--c-brown3);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 12px rgba(92,61,42,.15);
  transition:all .25s ease;cursor:pointer;
}
.am-fb:hover{border-color:var(--c-terra);color:var(--c-terra);box-shadow:0 4px 16px rgba(196,101,74,.2)}
.am-fb.am-fb-on{background:var(--c-terra-dim);border-color:var(--c-terra);color:var(--c-terra)}

/* ── 8. GATE ───────────────────────────────────────────────── */
#am-gate{
  position:fixed;inset:0;z-index:8000;
  background:var(--c-sand);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;cursor:pointer;
}
.am-gate-photo{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:brightness(.5) saturate(.7);
}
.am-gate-veil{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(245,237,224,.15),rgba(245,237,224,.45) 50%,rgba(245,237,224,.7));
}
.am-gate-placeholder{
  position:absolute;inset:0;
  background:linear-gradient(140deg,var(--c-terra-pale),var(--c-warm),var(--c-olive-pale));
}
/* SVG arch frame — signature #1 */
.am-gate-arch-frame{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;z-index:2;
}
.am-gate-arch-frame svg{width:320px;max-width:90vw;height:540px;max-height:90vh}

/* Gate content */
.am-gate-body{
  position:relative;z-index:3;
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:0 2.5rem;
}
.am-gate-eyebrow{
  font-family:var(--am-sans);font-size:.5625rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--c-terra);
  margin-bottom:1.25rem;
  opacity:0;animation:amIn .8s ease .25s forwards;
}
.am-gate-script{
  font-family:var(--am-script);font-size:3rem;
  color:var(--c-brown);line-height:1;
  opacity:0;animation:amIn .8s ease .4s forwards;
}
.am-gate-script + .am-gate-amp + .am-gate-script{
  animation-delay:.6s;
}
.am-gate-amp{
  font-family:var(--am-serif);font-style:italic;
  font-size:.9375rem;color:var(--c-terra);
  line-height:1.5;
  opacity:0;animation:amIn .8s ease .55s forwards;
}
.am-gate-date{
  display:flex;align-items:center;gap:.75rem;
  font-family:var(--am-sans);font-size:.5625rem;
  letter-spacing:.2em;text-transform:uppercase;color:var(--c-brown3);
  margin:1.125rem 0 1.5rem;
  opacity:0;animation:amIn .8s ease .72s forwards;
}
.am-gate-date-line{flex:1;max-width:28px;height:1px;background:var(--c-terra);opacity:.4}
.am-gate-to{
  font-size:.75rem;color:var(--c-brown3);line-height:1.7;
  margin-bottom:1.5rem;
  opacity:0;animation:amIn .8s ease .82s forwards;
}
.am-gate-to strong{color:var(--c-brown2);font-weight:700}
.am-gate-btn{
  display:inline-flex;align-items:center;gap:.625rem;
  padding:.75rem 1.75rem;
  background:var(--c-terra);
  border:1.5px solid var(--c-terra);
  border-radius:0;color:white;
  font-family:var(--am-sans);font-size:.6875rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  cursor:pointer;transition:all .3s ease;
  box-shadow:0 4px 20px rgba(196,101,74,.3);
  opacity:0;animation:amIn .8s ease .96s forwards;
}
.am-gate-btn:hover{background:var(--c-terra-lt);box-shadow:0 6px 28px rgba(196,101,74,.4);transform:translateY(-1px)}
@keyframes amIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ── 9. BOTTOM NAV ─────────────────────────────────────────── */
#am-nav{
  position:fixed;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:var(--max-w);z-index:400;display:none;
  background:rgba(250,245,238,.95);
  border-top:2px solid var(--c-terra-pale);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  box-shadow:0 -4px 20px rgba(92,61,42,.08);
}
.am-nav-row{
  display:flex;align-items:stretch;padding:0 .25rem;
  padding-bottom:env(safe-area-inset-bottom,0);
}
.am-nb{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:.625rem .25rem;gap:.25rem;
  color:var(--c-brown4);
  font-family:var(--am-sans);font-size:.5rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  transition:color .2s ease;cursor:pointer;
}
.am-nb:hover{color:var(--c-terra)}
.am-nb.active{color:var(--c-terra)}
.am-nb.active svg{stroke:var(--c-terra);transform:translateY(-1px)}
.am-nb svg{transition:transform .2s ease;stroke:currentColor}

/* ── 10. SECTION BASE ──────────────────────────────────────── */
.am-sec{padding:3.5rem 0 3rem;position:relative}
.am-sec-inner{padding:0 1.75rem}
.am-bg-sand{background:var(--c-sand)}
.am-bg-warm{background:var(--c-warm)}
.am-bg-terra{background:var(--c-terra)}
.am-bg-terra-deep{background:linear-gradient(135deg,var(--c-terra-deep) 0%,#8A2E20 100%)}

/* Section label */
.am-lbl{
  font-family:var(--am-sans);font-size:.5625rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--c-terra);
  text-align:center;margin-bottom:.875rem;
}
.am-lbl-white{color:rgba(255,255,255,.7)}
.am-ttl{
  font-family:var(--am-serif);font-size:1.75rem;font-weight:400;
  color:var(--c-brown);line-height:1.3;text-align:center;
  margin-bottom:2rem;letter-spacing:.01em;
}
.am-ttl em{font-style:italic;color:var(--c-terra)}
.am-ttl-white{color:rgba(255,255,255,.95)}
.am-ttl-white em{color:rgba(255,255,255,.7)}

/* Arch ornament divider (signature #1) */
.am-arch-div{
  display:flex;align-items:center;gap:.875rem;margin:1.5rem 0;
}
.am-arch-div-line{
  flex:1;height:1px;
  background:linear-gradient(90deg,transparent,var(--c-border),transparent);
}
.am-line-white{background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent)}
.am-arch-div-svg{width:80px;height:40px;flex-shrink:0}

/* Wavy sections (signature #2) */
.am-wave-top,.am-wave-bot,.am-wave-terra{
  display:block;margin:0;line-height:0;
}
.am-wave-top svg,.am-wave-bot svg,.am-wave-terra svg{width:100%;display:block;height:40px}

/* ── 11. HERO ──────────────────────────────────────────────── */
.am-hero{
  position:relative;height:100vh;min-height:580px;
  display:flex;flex-direction:column;
  align-items:stretch;overflow:hidden;
}
.am-hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  background-color:var(--c-warm);
  transform:scale(1.04);transition:transform 8s ease;
}
.am-hero-veil{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(92,61,42,.2) 0%,rgba(92,61,42,.1) 50%,rgba(92,61,42,.6) 100%);
}
/* Terracotta band — unique hero element */
.am-hero-band{
  position:absolute;bottom:0;left:0;right:0;z-index:2;
  background:rgba(196,101,74,.92);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  padding:2rem 1.75rem 5rem;
}
.am-hero-band-inner{max-width:100%}
.am-hero-eyebrow{
  font-family:var(--am-sans);font-size:.5625rem;letter-spacing:.28em;
  text-transform:uppercase;color:rgba(255,255,255,.65);
  margin-bottom:.875rem;
}
.am-hero-names{
  display:flex;flex-direction:column;align-items:flex-start;
  gap:.125rem;margin-bottom:1.25rem;
}
.am-hero-name{
  font-family:var(--am-script);font-size:3.25rem;
  color:white;line-height:1;letter-spacing:.01em;
}
.am-hero-amp{
  font-family:var(--am-serif);font-style:italic;
  font-size:1rem;color:rgba(255,255,255,.65);line-height:1.5;
  padding-left:.25rem;
}
.am-hero-date{
  display:flex;align-items:center;gap:.875rem;
  font-family:var(--am-sans);font-size:.5625rem;letter-spacing:.16em;
  text-transform:uppercase;color:rgba(255,255,255,.7);
}
.am-hero-date-num{
  font-family:var(--am-serif);font-size:2.5rem;font-weight:600;
  color:white;line-height:1;
}
.am-hero-date-vr{width:1px;height:36px;background:rgba(255,255,255,.3)}
.am-hero-date-right{display:flex;flex-direction:column;gap:.25rem}
/* Wavy hero bottom */
.am-hero-wave{
  position:absolute;bottom:60px;left:0;right:0;z-index:3;
  height:40px;
}
.am-hero-wave svg{width:100%;height:100%;display:block}
/* Scroll mouse */
.am-hero-scroll{
  position:absolute;bottom:1.25rem;right:1.5rem;
  z-index:5;display:flex;align-items:center;justify-content:center;
}
.am-hero-scroll-mouse{
  width:22px;height:34px;border:2px solid rgba(255,255,255,.5);
  border-radius:99px;display:flex;justify-content:center;padding-top:5px;
}
.am-hero-scroll-dot{
  width:3px;height:6px;border-radius:99px;
  background:rgba(255,255,255,.7);
  animation:scrollDot 1.6s ease infinite;
}
@keyframes scrollDot{
  0%{transform:translateY(0);opacity:.8}
  80%{transform:translateY(10px);opacity:0}
  100%{transform:translateY(0);opacity:0}
}

/* ── 12. OPENING ───────────────────────────────────────────── */
.am-bismillah{
  font-family:var(--am-serif);font-size:1.75rem;
  color:var(--c-terra);margin-bottom:1.5rem;
  line-height:1.6;letter-spacing:.04em;
}
.am-open-txt{
  font-family:var(--am-serif);font-size:.9375rem;font-style:italic;
  color:var(--c-brown2);line-height:2;text-align:center;
  max-width:320px;margin:0 auto;
}

/* ── 13. QUOTE ─────────────────────────────────────────────── */
.am-quote-section{
  display:flex;gap:0;
  background:var(--c-terra-dim);
  border-top:1px solid var(--c-terra-pale);
  border-bottom:1px solid var(--c-terra-pale);
  overflow:hidden;
}
.am-quote-stripe{
  width:4px;flex-shrink:0;
  background:linear-gradient(to bottom,var(--c-terra),var(--c-olive));
}
.am-quote-body{padding:2.5rem 2rem}
.am-quote{
  font-family:var(--am-serif);font-size:1.0625rem;font-style:italic;
  color:var(--c-brown);line-height:1.9;position:relative;
}
.am-quote-src{
  display:block;font-family:var(--am-sans);font-size:.6875rem;letter-spacing:.1em;
  color:var(--c-terra);margin-top:.875rem;
}

/* ── 14. COUPLE — Horizontal editorial card ─────────────────── */
.am-person-card{
  display:flex;gap:0;
  background:var(--c-linen);
  border:1px solid var(--c-border2);
  border-radius:4px;overflow:hidden;
  margin-bottom:1.25rem;
  box-shadow:0 4px 20px rgba(92,61,42,.07);
}
.am-person-accent{
  width:4px;flex-shrink:0;
}
.am-accent-terra{background:linear-gradient(to bottom,var(--c-terra),var(--c-terra-lt))}
.am-accent-olive{background:linear-gradient(to bottom,var(--c-olive),var(--c-olive-lt))}

.am-person-photo-box{
  width:110px;flex-shrink:0;position:relative;overflow:hidden;
  background:var(--c-warm);
}
.am-person-photo{
  width:100%;height:100%;object-fit:cover;
  display:block;
}
.am-person-initial{
  width:110px;height:100%;min-height:160px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--am-serif);font-size:3rem;color:var(--c-terra);
}
.am-initial-olive{color:var(--c-olive)}
.am-person-photo-arch{
  position:absolute;bottom:0;left:0;right:0;height:16px;
}
.am-person-photo-arch svg{width:100%;height:100%;display:block}
.am-person-info{flex:1;padding:1.25rem 1.125rem 1.125rem}
.am-person-lbl{
  font-family:var(--am-sans);font-size:.5rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--c-terra);margin-bottom:.375rem;
}
.am-person-nick{
  font-family:var(--am-script);font-size:1.875rem;
  color:var(--c-brown);line-height:1.1;margin-bottom:.25rem;
}
.am-person-full{
  font-family:var(--am-sans);font-size:.75rem;color:var(--c-brown3);
  letter-spacing:.04em;margin-bottom:.75rem;
}
.am-person-par{font-size:.8125rem;color:var(--c-brown3);line-height:1.7}
.am-person-par strong{color:var(--c-brown2);font-weight:700}
.am-person-bio{font-size:.8125rem;color:var(--c-brown3);line-height:1.8;margin-top:.5rem;font-style:italic}

.am-couple-sep{display:flex;align-items:center;gap:.875rem;padding:.5rem 0 1rem}
.am-couple-sep-line{flex:1;height:1px;background:var(--c-border2)}
.am-couple-sep-mono{
  font-family:var(--am-serif);font-size:1.25rem;font-style:italic;
  color:var(--c-terra);flex-shrink:0;
}

/* ── 15. LOVE STORY — Center-spine alternating timeline ──────── */
.am-story-txt{
  font-family:var(--am-serif);font-size:.9375rem;font-style:italic;
  color:var(--c-brown2);line-height:2;text-align:center;margin-bottom:2.5rem;
}
.am-timeline{
  position:relative;padding:0 1.75rem 2rem;
}
.am-tl-spine{
  position:absolute;left:50%;top:0;bottom:0;
  width:1px;
  background:linear-gradient(to bottom,transparent,var(--c-terra-pale),var(--c-terra-pale),transparent);
  transform:translateX(-50%);
  pointer-events:none;
}
.am-tl-row{
  display:flex;align-items:flex-start;gap:.625rem;
  margin-bottom:1.5rem;position:relative;z-index:1;
}
/* Left items: card left, node right */
.am-tl-left{flex-direction:row}
.am-tl-left .am-tl-card{order:1;text-align:right}
.am-tl-left .am-tl-node{order:2;align-self:flex-start;padding-top:.375rem}
.am-tl-left .am-tl-spacer{order:3}
/* Right items: spacer, node, card */
.am-tl-right{flex-direction:row}
.am-tl-right .am-tl-spacer{order:1}
.am-tl-right .am-tl-node{order:2;align-self:flex-start;padding-top:.375rem}
.am-tl-right .am-tl-card{order:3;text-align:left}

.am-tl-card{
  flex:1;background:var(--c-linen);
  border:1px solid var(--c-border2);border-radius:4px;
  padding:.875rem 1rem;
  box-shadow:0 2px 10px rgba(92,61,42,.06);
}
.am-tl-spacer{flex:1}
.am-tl-icon{font-size:1.125rem;margin-bottom:.25rem}
.am-tl-year{
  font-family:var(--am-sans);font-size:.5rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--c-terra);margin-bottom:.25rem;
}
.am-tl-title{font-family:var(--am-serif);font-size:.9375rem;font-weight:600;color:var(--c-brown);line-height:1.4;margin-bottom:.25rem}
.am-tl-desc{font-size:.75rem;color:var(--c-brown3);line-height:1.6}
.am-tl-node{
  width:16px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;
}
.am-tl-dot{
  width:14px;height:14px;border-radius:50%;
  background:var(--c-terra);
  border:2.5px solid var(--c-sand);
  box-shadow:0 0 0 2px var(--c-terra-pale);
}

/* ── 16. EVENTS — Arch-top terracotta cards (signature #1) ─── */
.am-event-card{
  background:var(--c-linen);
  border:1px solid var(--c-border2);
  border-radius:4px;overflow:hidden;
  margin-bottom:1.25rem;
  box-shadow:0 4px 20px rgba(92,61,42,.08);
}
.am-event-arch{
  display:block;height:60px;overflow:hidden;
  background:var(--c-terra);margin-bottom:0;
}
.am-event-arch svg{width:100%;height:60px;display:block}
.am-event-body{padding:1.375rem 1.5rem}
.am-event-row{display:flex;gap:.75rem;align-items:flex-start;margin-bottom:.875rem}
.am-event-ico-box{font-size:1.125rem;flex-shrink:0;margin-top:.125rem}
.am-event-main{font-family:var(--am-serif);font-size:.9375rem;color:var(--c-brown);line-height:1.4}
.am-event-sub{font-size:.75rem;color:var(--c-brown3);margin-top:.125rem}
.am-maps-btn{
  display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;
  padding:.625rem 1.25rem;
  background:var(--c-terra-dim);
  border:1.5px solid var(--c-border);border-radius:99px;
  color:var(--c-terra);font-family:var(--am-sans);
  font-size:.6875rem;font-weight:700;letter-spacing:.08em;
  cursor:pointer;transition:all .25s ease;text-decoration:none;
}
.am-maps-btn:hover{background:var(--c-terra);color:white;border-color:var(--c-terra);box-shadow:0 3px 14px rgba(196,101,74,.3)}
.am-maps-embed{margin-top:1rem;border-radius:4px;overflow:hidden}
.am-maps-embed iframe{width:100%;height:200px;border:none;display:block}

/* ── 17. COUNTDOWN — Terracotta section ────────────────────── */
.am-cd-row{display:flex;align-items:center;justify-content:center;gap:.375rem;margin:2rem 0}
.am-cd-cell{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.am-cd-box{
  width:68px;height:68px;
  background:rgba(255,255,255,.15);
  border:1.5px solid rgba(255,255,255,.25);
  border-radius:4px;
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(4px);
}
.am-cd-num{
  font-family:var(--am-serif);font-size:1.625rem;font-weight:600;
  color:white;line-height:1;
}
.am-cd-lbl{
  font-family:var(--am-sans);font-size:.5625rem;letter-spacing:.14em;
  text-transform:uppercase;color:rgba(255,255,255,.65);
}
.am-cd-colon{
  font-family:var(--am-serif);font-size:1.5rem;
  color:rgba(255,255,255,.4);align-self:flex-start;margin-top:1rem;line-height:1;
}

/* ── 18. GALLERY — Staggered 2-col masonry ─────────────────── */
.am-masonry{
  display:flex;gap:3px;padding:1.25rem 1.75rem 2rem;
  align-items:flex-start;
}
.am-masonry-col{flex:1;display:flex;flex-direction:column;gap:3px}
.am-masonry-item{
  position:relative;overflow:hidden;cursor:pointer;
  border-radius:0;
  background:var(--c-warm);
}
.am-masonry-item img{
  width:100%;display:block;
  transition:transform .5s ease;
  aspect-ratio:4/5;object-fit:cover;
}
.am-masonry-item:nth-child(even) img{aspect-ratio:1/1}
.am-masonry-item:hover img{transform:scale(1.04)}
.am-masonry-overlay{
  position:absolute;inset:0;
  background:rgba(92,61,42,0);
  display:flex;align-items:flex-end;
  transition:background .3s ease;
  padding:.875rem;
}
.am-masonry-item:hover .am-masonry-overlay{background:rgba(92,61,42,.3)}
.am-masonry-cap{
  font-family:var(--am-sans);font-size:.6875rem;color:white;
  font-weight:600;letter-spacing:.04em;
  opacity:0;transition:opacity .3s ease;
  text-shadow:0 1px 4px rgba(0,0,0,.4);
}
.am-masonry-item:hover .am-masonry-cap{opacity:1}

/* ── 19. LIGHTBOX ──────────────────────────────────────────── */
#am-lb{
  position:fixed;inset:0;z-index:9000;
  background:rgba(40,25,15,.96);
  display:none;align-items:center;justify-content:center;padding:1rem;
}
#am-lb.open{display:flex}
#am-lb-img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:2px;box-shadow:0 0 60px rgba(0,0,0,.5)}
#am-lb-x{position:absolute;top:1rem;right:1rem;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:white;font-size:1.125rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}
#am-lb-x:hover{background:rgba(255,255,255,.2)}
#am-lb-p,#am-lb-n{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:white;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
#am-lb-p{left:.75rem}#am-lb-n{right:.75rem}
#am-lb-p:hover,#am-lb-n:hover{background:rgba(255,255,255,.18)}
#am-lb-cap{position:absolute;bottom:1.25rem;left:50%;transform:translateX(-50%);font-size:.75rem;color:rgba(255,255,255,.5);white-space:nowrap;max-width:90%;overflow:hidden;text-overflow:ellipsis}

/* ── 20. RUNDOWN ───────────────────────────────────────────── */
.am-rundown{display:flex;flex-direction:column}
.am-rd-item{display:flex;gap:.875rem;align-items:flex-start;padding:.75rem 0}
.am-rd-time{width:56px;flex-shrink:0;text-align:right;font-family:var(--am-sans);font-size:.75rem;font-weight:700;color:var(--c-terra);padding-top:.1875rem}
.am-rd-node{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:16px;padding-top:.25rem;gap:4px}
.am-rd-dot{width:10px;height:10px;border-radius:50%;background:var(--c-terra);border:2.5px solid var(--c-warm);box-shadow:0 0 0 2px var(--c-terra-pale)}
.am-rd-stem{width:1.5px;flex:1;min-height:24px;background:linear-gradient(to bottom,var(--c-terra-pale),transparent)}
.am-rd-title{font-family:var(--am-serif);font-size:.9375rem;font-weight:600;color:var(--c-brown);line-height:1.4}
.am-rd-desc{font-size:.8125rem;color:var(--c-brown3);line-height:1.7;margin-top:.25rem}

/* ── 21. FORMS ─────────────────────────────────────────────── */
.am-form{display:flex;flex-direction:column;gap:1rem}
.am-fg{display:flex;flex-direction:column;gap:.4375rem}
.am-lbl2{font-family:var(--am-sans);font-size:.625rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--c-brown3)}
.am-lbl2 small{font-weight:400;text-transform:none;letter-spacing:0}
.am-inp{
  width:100%;padding:.75rem 1rem;
  background:var(--c-linen);
  border:1.5px solid var(--c-border2);
  border-radius:4px;color:var(--c-brown);
  font-size:.875rem;font-family:var(--am-sans);
  outline:none;transition:border-color .25s,box-shadow .25s;-webkit-appearance:none;
}
.am-inp:focus{border-color:var(--c-terra);box-shadow:0 0 0 3px rgba(196,101,74,.1)}
.am-inp::placeholder{color:var(--c-brown4)}
.am-inp option{background:var(--c-linen)}
.am-attend-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.am-attend{
  padding:.75rem;text-align:center;
  background:var(--c-linen);border:1.5px solid var(--c-border2);border-radius:4px;
  color:var(--c-brown3);font-family:var(--am-sans);font-size:.8125rem;font-weight:700;
  cursor:pointer;transition:all .25s;
}
.am-attend.active,.am-attend:hover{border-color:var(--c-terra);background:var(--c-terra-dim);color:var(--c-terra)}
.am-submit{
  display:flex;align-items:center;justify-content:center;gap:.625rem;
  width:100%;padding:.875rem 1.5rem;
  background:var(--c-terra);border:none;border-radius:99px;
  color:white;font-family:var(--am-sans);font-size:.8125rem;font-weight:700;letter-spacing:.08em;
  cursor:pointer;transition:all .3s;
  box-shadow:0 4px 18px rgba(196,101,74,.3);
}
.am-submit:hover{background:var(--c-terra-lt);box-shadow:0 6px 24px rgba(196,101,74,.4);transform:translateY(-1px)}

/* ── 22. WISHES ────────────────────────────────────────────── */
.am-wish{display:flex;gap:.875rem;padding:1.125rem 0;border-bottom:1px solid var(--c-brown5)}
.am-wish-av{
  width:36px;height:36px;border-radius:50%;flex-shrink:0;
  background:var(--c-terra-dim);border:1.5px solid var(--c-border);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--am-serif);font-size:.875rem;color:var(--c-terra);
}
.am-wish-body{flex:1;min-width:0}
.am-wish-head{display:flex;align-items:baseline;flex-wrap:wrap;gap:.375rem .75rem;margin-bottom:.375rem}
.am-wish-name{font-family:var(--am-serif);font-size:.9375rem;font-weight:600;color:var(--c-brown)}
.am-wish-rel{font-size:.6875rem;color:var(--c-terra);letter-spacing:.06em}
.am-wish-time{font-size:.6875rem;color:var(--c-brown4);margin-left:auto}
.am-wish-msg{font-size:.8125rem;color:var(--c-brown2);line-height:1.75}
.am-loadmore{
  display:flex;align-items:center;justify-content:center;gap:.5rem;
  width:100%;padding:.875rem;margin-top:1.25rem;
  background:transparent;border:1.5px solid var(--c-border);border-radius:99px;
  color:var(--c-brown3);font-family:var(--am-sans);font-size:.75rem;font-weight:700;
  cursor:pointer;transition:all .25s;
}
.am-loadmore:hover{border-color:var(--c-terra);color:var(--c-terra);background:var(--c-terra-dim)}

/* ── 23. GIFT ──────────────────────────────────────────────── */
.am-tabs{display:flex;margin-bottom:1.5rem;border-bottom:1.5px solid var(--c-border2)}
.am-tab{flex:1;padding:.75rem;text-align:center;font-family:var(--am-sans);font-size:.6875rem;letter-spacing:.1em;text-transform:uppercase;color:var(--c-brown3);border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:all .25s}
.am-tab.active{color:var(--c-terra);border-bottom-color:var(--c-terra)}
.am-hidden{display:none}
/* Bank card with terracotta top accent */
.am-bank{
  background:var(--c-linen);border:1px solid var(--c-border2);
  border-radius:4px;overflow:hidden;margin-bottom:1rem;
  box-shadow:0 2px 10px rgba(92,61,42,.07);
}
.am-bank-terra{height:4px;background:linear-gradient(90deg,var(--c-terra),var(--c-olive))}
.am-bank-body{padding:1.125rem 1.375rem}
.am-bank-name{font-family:var(--am-sans);font-size:.5rem;letter-spacing:.22em;text-transform:uppercase;color:var(--c-terra);margin-bottom:.375rem}
.am-bank-num{font-family:'Courier New',monospace;font-size:1.25rem;color:var(--c-brown);letter-spacing:.1em;margin-bottom:.375rem}
.am-bank-holder{font-size:.8125rem;color:var(--c-brown3);margin-bottom:1rem}
.am-copy-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1rem;border-radius:99px;background:var(--c-terra-dim);border:1.5px solid var(--c-border);color:var(--c-terra);font-family:var(--am-sans);font-size:.6875rem;font-weight:700;cursor:pointer;transition:all .2s}
.am-copy-btn:hover{background:var(--c-terra);color:white;border-color:var(--c-terra)}
.am-addr-box{background:var(--c-linen);border:1px solid var(--c-border2);border-radius:4px;padding:1.25rem 1.5rem;font-size:.875rem;color:var(--c-brown2);line-height:1.9}

/* ── 24. CONTACT ───────────────────────────────────────────── */
.am-contact{display:flex;align-items:center;gap:1rem;background:var(--c-linen);border:1px solid var(--c-border2);border-radius:4px;padding:1.25rem 1.5rem;margin-bottom:1.25rem;box-shadow:0 2px 10px rgba(92,61,42,.06)}
.am-contact-icon{font-size:1.5rem;flex-shrink:0}
.am-contact-body{flex:1;min-width:0}
.am-contact-name{font-family:var(--am-serif);font-size:1rem;font-weight:600;color:var(--c-brown)}
.am-contact-phone{font-size:.8125rem;color:var(--c-brown3);margin-top:.25rem}
.am-wa-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5625rem .875rem;background:rgba(37,211,102,.1);border:1.5px solid rgba(37,211,102,.25);border-radius:99px;color:#25d366;font-size:.75rem;font-weight:700;cursor:pointer;transition:background .25s;text-decoration:none}
.am-wa-btn:hover{background:rgba(37,211,102,.2)}
.am-note{font-size:.8125rem;color:var(--c-brown3);line-height:1.8;font-style:italic;padding:.875rem 0;border-top:1px solid var(--c-brown5)}

/* ── 25. HASHTAG ───────────────────────────────────────────── */
.am-hashtag-wrap{display:flex;flex-direction:column;gap:.75rem}
.am-hashtag{display:flex;align-items:center;justify-content:space-between;background:var(--c-linen);border:1.5px solid var(--c-border);border-radius:4px;padding:1rem 1.25rem;cursor:pointer;transition:border-color .2s}
.am-hashtag:hover{border-color:var(--c-terra)}
.am-hashtag span{font-family:var(--am-serif);font-size:1.0625rem;font-style:italic;color:var(--c-terra)}
.am-hashtag svg{color:var(--c-brown4);flex-shrink:0}

/* ── 26. CLOSING — Sun medallion ───────────────────────────── */
.am-closing-tex{
  position:absolute;inset:0;pointer-events:none;
  /* Subtle textile/linen texture via CSS radial dots */
  background:
    radial-gradient(circle,rgba(255,255,255,.06) 1px,transparent 1px) 0 0 / 18px 18px,
    radial-gradient(circle,rgba(0,0,0,.04) 1px,transparent 1px) 9px 9px / 18px 18px;
}
.am-sun{
  width:200px;height:200px;
  position:relative;margin:0 auto 2rem;
  display:flex;align-items:center;justify-content:center;
}
.am-sun svg{position:absolute;inset:0;width:100%;height:100%}
.am-sun-content{
  position:relative;z-index:1;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:.125rem;
}
.am-sun-name{
  font-family:var(--am-script);font-size:1.5rem;
  color:white;line-height:1.05;
}
.am-sun-amp{
  font-family:var(--am-serif);font-style:italic;
  font-size:.875rem;color:rgba(255,255,255,.6);line-height:1.4;
}
.am-close-txt{
  font-family:var(--am-serif);font-size:.9375rem;font-style:italic;
  color:rgba(255,255,255,.75);line-height:2;text-align:center;
  margin-bottom:1.75rem;max-width:300px;margin-left:auto;margin-right:auto;
}
.am-close-date{
  font-family:var(--am-sans);font-size:.5625rem;letter-spacing:.22em;
  text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:2rem;
}
.am-close-share{display:flex;align-items:center;justify-content:center;gap:.625rem;flex-wrap:wrap}
.am-close-btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.625rem 1.125rem;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:0;
  color:rgba(255,255,255,.8);font-family:var(--am-sans);font-size:.6875rem;font-weight:700;letter-spacing:.08em;
  cursor:pointer;transition:all .25s;
}
.am-close-btn:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.4)}
.am-brand{margin-top:2.5rem;font-size:.6875rem;color:rgba(255,255,255,.35);letter-spacing:.06em}
.am-brand a{color:rgba(255,255,255,.55);text-decoration:underline;text-underline-offset:3px}

/* ── 27. SHARE SHEET ───────────────────────────────────────── */
#am-share{position:fixed;inset:0;z-index:8500;background:rgba(40,25,15,.55);backdrop-filter:blur(6px);display:none;align-items:flex-end;justify-content:center;padding-bottom:env(safe-area-inset-bottom,0)}
#am-share-panel{background:var(--c-linen);width:100%;max-width:var(--max-w);border-radius:0;overflow:hidden}
.am-share-arch{height:32px;background:var(--c-terra);flex-shrink:0}
.am-share-arch svg{width:100%;height:32px;display:block}
.am-share-ttl{font-family:var(--am-sans);font-size:.5625rem;letter-spacing:.26em;text-transform:uppercase;color:var(--c-terra);text-align:center;padding:1.25rem 1.75rem .75rem}
.am-share-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;padding:0 1.75rem 1.25rem}
.am-share-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.875rem .375rem;background:var(--c-cream);border:1px solid var(--c-border2);border-radius:4px;font-family:var(--am-sans);font-size:.6875rem;color:var(--c-brown2);cursor:pointer;transition:border-color .2s}
.am-share-btn:hover{border-color:var(--c-terra)}
.am-sh-ico{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.125rem}
.am-sh-wa{background:rgba(37,211,102,.1);color:#25d366}
.am-sh-tg{background:rgba(42,171,238,.1);color:#29a8eb}
.am-sh-fb{background:rgba(59,89,152,.1);color:#3b5998}
.am-sh-cp{background:var(--c-terra-dim);color:var(--c-terra)}
.am-share-close{width:100%;padding:.875rem;background:transparent;border:none;border-top:1px solid var(--c-border2);color:var(--c-brown3);font-family:var(--am-sans);font-size:.8125rem;font-weight:700;letter-spacing:.08em;cursor:pointer;transition:color .2s;margin:0 0 0}
.am-share-close:hover{color:var(--c-terra)}

/* ── 28. INIT ──────────────────────────────────────────────── */
#am-nav{display:none}
#am-float{display:none}

/* ── 29. RESPONSIVE ────────────────────────────────────────── */
@media(max-width:380px){
  .am-hero-name{font-size:2.75rem}
  .am-gate-script{font-size:2.5rem}
  .am-cd-box{width:58px;height:58px}.am-cd-num{font-size:1.375rem}
  .am-share-grid{grid-template-columns:repeat(2,1fr)}
  .am-sun{width:160px;height:160px}.am-sun-name{font-size:1.25rem}
  .am-tl-card{padding:.625rem .75rem}
}
@media(max-width:320px){
  .am-masonry{flex-direction:column}
  .am-masonry-col{width:100%}
}

#am-nav{display: grid !important; grid-template-columns: repeat(auto-fit, minmax(0, 1fr));}