/* ============================================================
   LUMINA — Template CSS
   UndanganKu by Bacaunduh
   Slug: lumina | Tier: premium | Category: wedding
   Konsep: Contemporary Luminous Aurora
   Palette: Deep Space + Teal #00C9A7 + Violet #6B4EFF + Rose #FF6B8A
   Signature #1: CSS animated aurora borealis background (pure CSS)
   Signature #2: SVG circular ring countdown (4 concentric rings)
   + Glassmorphism card system throughout entire template
   Satu-satunya template contemporary/luminous di seluruh koleksi
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;600;700&family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300;1,400&family=Sacramento&display=swap');

/* ── 1. VARIABLES ──────────────────────────────────────────── */
:root {
  --c-primary:    var(--inv-primary,   #00C9A7);
  --c-secondary:  var(--inv-secondary, #6B4EFF);
  --c-space:      #08091A;
  --c-deep:       #0C0E22;
  --c-deep2:      #10122A;
  --c-teal:       #00C9A7;
  --c-teal-lt:    #4DDFC8;
  --c-teal-dim:   rgba(0,201,167,.18);
  --c-teal-glow:  rgba(0,201,167,.08);
  --c-violet:     #6B4EFF;
  --c-violet-lt:  #9B82FF;
  --c-violet-dim: rgba(107,78,255,.18);
  --c-violet-glow:rgba(107,78,255,.08);
  --c-rose:       #FF6B8A;
  --c-rose-lt:    #FF9DB3;
  --c-rose-dim:   rgba(255,107,138,.18);
  --c-rose-glow:  rgba(255,107,138,.08);
  --c-white:      rgba(255,255,255,.92);
  --c-text:       rgba(255,255,255,.88);
  --c-text2:      rgba(255,255,255,.55);
  --c-text3:      rgba(255,255,255,.32);
  --c-text4:      rgba(255,255,255,.14);
  /* Glassmorphism */
  --glass-bg:     rgba(255,255,255,.07);
  --glass-border: rgba(255,255,255,.12);
  --glass-blur:   20px;
  --glass-shadow: 0 8px 32px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.08);
  --lm-display:   'Space Grotesk', system-ui, sans-serif;
  --lm-serif:     'Cormorant Garamond', Georgia, serif;
  --lm-script:    'Sacramento', cursive;
  --max-w:        480px;
  --tr:           .4s 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(--lm-display);
  background:var(--c-space);
  color:var(--c-text);
  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:3px}
::-webkit-scrollbar-track{background:var(--c-space)}
::-webkit-scrollbar-thumb{background:var(--c-teal);border-radius:99px}

/* ── 3. WRAPPER ────────────────────────────────────────────── */
#lm-wrap{
  max-width:var(--max-w);margin:0 auto;
  background:var(--c-deep);
  min-height:100vh;position:relative;overflow-x:hidden;
  box-shadow:0 0 80px rgba(0,0,0,.8);
}

/* ── 4. SCROLL REVEAL ──────────────────────────────────────── */
.lm-reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.lm-reveal.visible{opacity:1;transform:none}
.d1{transition-delay:.12s}.d2{transition-delay:.25s}
.d3{transition-delay:.38s}.d4{transition-delay:.52s}
.d5{transition-delay:.66s}

/* ── 5. PROGRESS ───────────────────────────────────────────── */
#lm-progress{
  position:fixed;top:0;left:0;height:2px;width:0%;
  background:linear-gradient(90deg,var(--c-teal),var(--c-violet),var(--c-rose));
  z-index:9999;pointer-events:none;transition:width .1s linear;
}

/* ── 6. TOAST ──────────────────────────────────────────────── */
#lm-toast{
  position:fixed;bottom:5.5rem;left:50%;
  transform:translateX(-50%) translateY(8px);
  background:var(--glass-bg);color:var(--c-text);
  border:1px solid var(--glass-border);
  backdrop-filter:blur(16px);
  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(--lm-display);
}
#lm-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── 7. FLOAT CONTROLS ─────────────────────────────────────── */
#lm-float{position:fixed;right:1rem;bottom:5%;transform:translateY(-50%);z-index:500;display:none;flex-direction:column;gap:.5rem}
.lm-fb{
  width:30px;height:30px;border-radius:50%;
  background:var(--glass-bg);border:1px solid var(--glass-border);
  color:var(--c-text3);
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(12px);transition:all .25s ease;cursor:pointer;
}
.lm-fb:hover{border-color:var(--c-teal);color:var(--c-teal);box-shadow:0 0 16px var(--c-teal-dim)}
.lm-fb.lm-fb-on{background:var(--c-teal-glow);border-color:var(--c-teal);color:var(--c-teal)}

/* ── 8. AURORA ANIMATION (SIGNATURE #1) ────────────────────── */
/*
  Pure CSS keyframe animated radial gradients — 3 layers
  Each layer moves in different direction at different speed
  Result = aurora borealis light simulation
  NO JavaScript, NO SVG — pure CSS magic
*/
.lm-aurora {
  position: absolute; inset: 0;
  z-index: 0; overflow: hidden; pointer-events: none;
}
.lm-aurora-layer {
  position: absolute; inset: -100%;
  border-radius: 50%;
}
/* Layer 1: Teal aurora */
.lm-al-1 {
  background: radial-gradient(ellipse 80% 60% at 40% 40%,
    rgba(0,201,167,.22) 0%,
    rgba(0,201,167,.08) 40%,
    transparent 70%
  );
  animation: auroraFloat1 14s ease-in-out infinite;
}
/* Layer 2: Violet aurora */
.lm-al-2 {
  background: radial-gradient(ellipse 70% 50% at 70% 60%,
    rgba(107,78,255,.2) 0%,
    rgba(107,78,255,.07) 45%,
    transparent 70%
  );
  animation: auroraFloat2 18s ease-in-out infinite;
}
/* Layer 3: Rose aurora */
.lm-al-3 {
  background: radial-gradient(ellipse 60% 45% at 30% 70%,
    rgba(255,107,138,.16) 0%,
    rgba(255,107,138,.06) 45%,
    transparent 70%
  );
  animation: auroraFloat3 12s ease-in-out infinite;
}

@keyframes auroraFloat1 {
  0%   { transform: translate(0, 0)   rotate(0deg)   scale(1); }
  33%  { transform: translate(8%, 5%) rotate(8deg)   scale(1.08); }
  66%  { transform: translate(-5%, 8%) rotate(-5deg)  scale(0.96); }
  100% { transform: translate(0, 0)   rotate(0deg)   scale(1); }
}
@keyframes auroraFloat2 {
  0%   { transform: translate(0, 0)    rotate(0deg)   scale(1); }
  25%  { transform: translate(-6%, -4%) rotate(-6deg)  scale(1.06); }
  75%  { transform: translate(7%, 6%)  rotate(10deg)  scale(0.94); }
  100% { transform: translate(0, 0)    rotate(0deg)   scale(1); }
}
@keyframes auroraFloat3 {
  0%   { transform: translate(0, 0)   rotate(0deg)   scale(1); }
  40%  { transform: translate(5%, -6%) rotate(12deg)  scale(1.1); }
  80%  { transform: translate(-8%, 4%) rotate(-8deg)  scale(0.92); }
  100% { transform: translate(0, 0)   rotate(0deg)   scale(1); }
}
/* Dimmer aurora for sections where we don't want it too bright */
.lm-aurora-dim .lm-al-1 { opacity: .55; }
.lm-aurora-dim .lm-al-2 { opacity: .5; }
.lm-aurora-dim .lm-al-3 { opacity: .45; }

/* Small aurora for share panel header */
.lm-aurora-sm { height: 64px; inset: 0; }
.lm-aurora-sm .lm-aurora-layer { inset: -200%; }

/* ── 9. GLASSMORPHISM CARD SYSTEM ──────────────────────────── */
/*
  Every card in Lumina uses glassmorphism
  backdrop-filter: blur + semi-transparent bg + luminous border
  Different sizes for different use cases
*/
.lm-glass-card {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--glass-border);
  box-shadow: var(--glass-shadow);
  border-radius: 16px;
  position: relative;
}
.lm-glass-sm {
  border-radius: 12px;
  --glass-blur: 16px;
}
.lm-glass-xs {
  border-radius: 8px;
  --glass-blur: 12px;
}

/* Luminous glow per color — placed as absolute child inside glass card */
.lm-glass-glow {
  position: absolute; width: 160px; height: 160px;
  border-radius: 50%; pointer-events: none;
  filter: blur(50px); z-index: 0;
  opacity: .6;
}
.lm-glow-teal   { background: var(--c-teal);   top: 0; left: 0; transform: translate(-40%, -40%); }
.lm-glow-violet { background: var(--c-violet); top: 0; right: 0; transform: translate(40%, -40%); }
.lm-glow-rose   { background: var(--c-rose);   bottom: 0; right: 0; transform: translate(40%, 40%); }

/* Color utilities */
.lm-color-teal   { color: var(--c-teal)!important; }
.lm-color-violet { color: var(--c-violet-lt)!important; }
.lm-color-rose   { color: var(--c-rose-lt)!important; }

/* Glow line utilities */
.lm-glow-teal-line   { background: linear-gradient(90deg,transparent,var(--c-teal),transparent)!important; }
.lm-glow-violet-line { background: linear-gradient(90deg,transparent,var(--c-violet),transparent)!important; }
.lm-glow-rose-line   { background: linear-gradient(90deg,transparent,var(--c-rose),transparent)!important; }

/* ── 10. GATE ──────────────────────────────────────────────── */
#lm-gate {
  position: fixed; inset: 0; z-index: 8000;
  background: var(--c-space);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; cursor: pointer;
}
.lm-gate-photo {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  filter: brightness(.18) saturate(.6);
  z-index: 1;
}
.lm-gate-card {
  position: relative; z-index: 3;
  padding: 2.5rem 2rem;
  width: calc(100% - 3rem); max-width: 340px;
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 1.125rem;
}
.lm-gate-eyebrow {
  font-family: var(--lm-display); font-size: .5rem;
  letter-spacing: .32em; text-transform: uppercase;
  color: var(--c-text2);
  opacity: 0; animation: lmIn .8s ease .2s forwards;
}
.lm-gate-names {
  display: flex; flex-direction: column; align-items: center; gap: .25rem;
  opacity: 0; animation: lmIn .8s ease .4s forwards;
}
.lm-gate-name {
  font-family: var(--lm-script); font-size: 2.5rem;
  color: var(--c-text); line-height: 1; letter-spacing: .01em;
}
.lm-gate-amp {
  font-family: var(--lm-serif); font-style: italic;
  font-size: 1rem; color: var(--c-teal); line-height: 1.5;
}
.lm-gate-date {
  display: flex; align-items: center; gap: .75rem; width: 100%;
  font-family: var(--lm-display); font-size: .5rem;
  letter-spacing: .2em; text-transform: uppercase; color: var(--c-text2);
  opacity: 0; animation: lmIn .8s ease .6s forwards;
}
.lm-gate-date-line { flex: 1; height: 1px; }
.lm-gate-to {
  display: flex; flex-direction: column; gap: .2rem;
  opacity: 0; animation: lmIn .8s ease .75s forwards;
}
.lm-gate-to-lbl { font-size: .5rem; letter-spacing: .2em; text-transform: uppercase; color: var(--c-text3); }
.lm-gate-to-name { font-family: var(--lm-serif); font-size: 1rem; font-weight: 300; color: var(--c-text); }

/* Glowing CTA button */
.lm-gate-btn {
  position: relative; overflow: hidden;
  display: inline-flex; align-items: center; gap: .625rem;
  padding: .875rem 2rem;
  background: transparent; border: 1px solid var(--c-teal);
  border-radius: 99px; color: var(--c-teal);
  font-family: var(--lm-display); font-size: .5625rem;
  font-weight: 600; letter-spacing: .18em; text-transform: uppercase;
  cursor: pointer; transition: all .3s ease;
  opacity: 0; animation: lmIn .8s ease .9s forwards;
}
.lm-gate-btn:hover { background: var(--c-teal-dim); box-shadow: 0 0 24px var(--c-teal-dim); }
.lm-gate-btn-glow {
  position: absolute; inset: 0; border-radius: 99px;
  background: radial-gradient(ellipse at center, var(--c-teal-glow) 0%, transparent 70%);
  animation: btnGlow 2s ease infinite;
}
@keyframes btnGlow { 0%,100% { opacity:.5; } 50% { opacity:1; } }
.lm-gate-btn-txt { position: relative; z-index: 1; }

/* Floating particles */
.lm-gate-particles { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.lm-p {
  position: absolute; border-radius: 50%;
  animation: particleFloat 4s ease infinite;
}
.lm-p1 { width:4px; height:4px; background:var(--c-teal);   top:15%; left:10%; animation-delay:0s;   opacity:.6; }
.lm-p2 { width:3px; height:3px; background:var(--c-violet); top:25%; right:12%; animation-delay:.8s; opacity:.5; }
.lm-p3 { width:5px; height:5px; background:var(--c-rose);   top:70%; left:8%;  animation-delay:1.6s; opacity:.5; }
.lm-p4 { width:3px; height:3px; background:var(--c-teal);   bottom:20%; right:10%; animation-delay:2.4s; opacity:.4; }
.lm-p5 { width:4px; height:4px; background:var(--c-violet); bottom:30%; left:15%; animation-delay:.4s;  opacity:.45; }
.lm-p6 { width:3px; height:3px; background:var(--c-rose);   top:45%; right:8%; animation-delay:2s;    opacity:.4; }
@keyframes particleFloat {
  0%,100% { transform: translateY(0) scale(1); opacity: var(--o, .5); }
  50%      { transform: translateY(-12px) scale(1.2); opacity: calc(var(--o, .5) * .5); }
}

@keyframes lmIn { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:none; } }

/* ── 11. BOTTOM NAV ────────────────────────────────────────── */
#lm-nav {
  position:fixed;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:var(--max-w);z-index:400;display:none;
  background:rgba(8,9,26,.92);
  border-top:1px solid var(--glass-border);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
}
.lm-nav-inner{display:flex;align-items:stretch;padding:0 .25rem;padding-bottom:env(safe-area-inset-bottom,0)}
.lm-nb{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:.625rem .25rem;gap:.25rem;
  color:var(--c-text4);
  font-family:var(--lm-display);font-size:.5rem;font-weight:400;
  letter-spacing:.1em;text-transform:uppercase;
  transition:color .2s ease;cursor:pointer;
}
.lm-nb:hover{color:var(--c-text2)}
.lm-nb.active{color:var(--c-teal)}
.lm-nb.active svg{stroke:var(--c-teal);transform:translateY(-1px)}
.lm-nb svg{transition:transform .2s;stroke:currentColor}

/* ── 12. SECTION BASE ──────────────────────────────────────── */
.lm-sec{padding:3.5rem 0 3rem}
.lm-sec-inner{padding:0 1.75rem}
.lm-bg-space{background:var(--c-space)}
.lm-bg-deep {background:var(--c-deep)}
.lm-bg-cd   {background:var(--c-deep2)}
.lm-text-center{text-align:center}

.lm-sec-lbl{
  font-family:var(--lm-display);font-size:.5rem;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--c-teal);text-align:center;margin-bottom:1rem;
}
.lm-sec-ttl{
  font-family:var(--lm-serif);font-size:1.875rem;font-weight:300;
  color:var(--c-text);line-height:1.3;text-align:center;
  margin-bottom:2rem;letter-spacing:.01em;
}
.lm-sec-ttl em{font-style:italic;color:var(--c-teal-lt)}

/* Divider */
.lm-divider{display:flex;align-items:center;gap:.75rem;padding:0 .5rem}
.lm-div-line{flex:1;height:1px}
.lm-div-dot{
  width:6px;height:6px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--c-teal),var(--c-violet));
  box-shadow:0 0 8px var(--c-teal-dim);
}

/* ── 13. HERO ──────────────────────────────────────────────── */
.lm-hero{
  position:relative;height:100vh;min-height:580px;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.lm-hero-aurora{z-index:1}
.lm-hero-photo{
  position:absolute;inset:0;z-index:2;
  background-size:cover;background-position:center;
  filter:brightness(.28) saturate(.6);
}
.lm-hero-photo-veil{
  position:absolute;inset:0;z-index:3;
  background:linear-gradient(to bottom,rgba(8,9,26,.3) 0%,rgba(8,9,26,.5) 100%);
}
.lm-hero-content{
  position:relative;z-index:4;text-align:center;padding:0 2rem;
  display:flex;flex-direction:column;align-items:center;
}
.lm-hero-eyebrow{
  font-family:var(--lm-display);font-size:.5rem;
  letter-spacing:.32em;text-transform:uppercase;color:var(--c-text2);margin-bottom:1.25rem;
}
.lm-hero-names{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin-bottom:1.5rem}
.lm-hero-groom,.lm-hero-bride{
  font-family:var(--lm-script);font-size:3.25rem;
  color:var(--c-text);line-height:1;letter-spacing:.01em;display:block;
}
.lm-hero-amp{
  font-family:var(--lm-serif);font-style:italic;
  font-size:1.125rem;color:var(--c-teal);line-height:1.5;
}
.lm-hero-date{
  font-family:var(--lm-display);font-size:.5rem;
  letter-spacing:.2em;text-transform:uppercase;
  padding:.625rem 1.375rem;
}
.lm-glass-sm.lm-hero-date{border-radius:99px}

/* Scroll cue */
.lm-hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:5;display:flex;flex-direction:column;align-items:center;gap:.375rem}
.lm-hs-line{width:1px;height:36px}
.lm-hs-dot{width:5px;height:5px;border-radius:50%;background:var(--c-teal);box-shadow:0 0 8px var(--c-teal);animation:hsDot 1.6s ease infinite}
@keyframes hsDot{0%,100%{opacity:.8;transform:translateY(0)}50%{opacity:.2;transform:translateY(8px)}}

/* ── 14. OPENING ───────────────────────────────────────────── */
.lm-bismillah{
  font-family:var(--lm-serif);font-size:1.875rem;font-weight:300;
  color:var(--c-teal-lt);margin-bottom:1rem;
  line-height:1.6;letter-spacing:.04em;
}
.lm-open-txt{
  font-family:var(--lm-serif);font-size:.9375rem;font-style:italic;font-weight:300;
  color:var(--c-text2);line-height:2;
  max-width:320px;margin:0 auto;
}

/* ── 15. QUOTE ─────────────────────────────────────────────── */
.lm-quote{
  font-family:var(--lm-serif);font-size:1.0625rem;font-style:italic;font-weight:300;
  color:var(--c-text2);line-height:1.9;text-align:center;position:relative;z-index:1;
}
.lm-quote-src{
  display:block;font-family:var(--lm-display);font-size:.5625rem;
  letter-spacing:.12em;color:var(--c-teal);text-align:center;margin-top:1rem;position:relative;z-index:1;
}

/* ── 16. COUPLE ────────────────────────────────────────────── */
.lm-couple-card{padding:1.5rem;margin:0 1.75rem}
.lm-cc-inner{display:flex;gap:1.25rem;align-items:flex-start;position:relative;z-index:1}
.lm-cc-photo-wrap{position:relative;flex-shrink:0;width:100px;height:100px}
.lm-cc-photo{
  width:100px;height:100px;border-radius:50%;object-fit:cover;
  border:2px solid rgba(255,255,255,.1);
}
.lm-cc-initial{
  width:100px;height:100px;border-radius:50%;
  background:var(--glass-bg);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--lm-serif);font-size:2.5rem;font-weight:300;color:var(--c-teal);
}
/* Glowing ring around photo */
.lm-cc-ring{
  position:absolute;inset:-4px;border-radius:50%;
  border:1.5px solid transparent;
  transition:border-color .3s;
}
.lm-ring-teal  {border-color:rgba(0,201,167,.4);box-shadow:0 0 12px rgba(0,201,167,.2);}
.lm-ring-violet{border-color:rgba(107,78,255,.4);box-shadow:0 0 12px rgba(107,78,255,.2);}

.lm-cc-info{flex:1;min-width:0}
.lm-cc-lbl{font-family:var(--lm-display);font-size:.5rem;letter-spacing:.2em;text-transform:uppercase;color:var(--c-teal);margin-bottom:.375rem}
.lm-cc-nick{font-family:var(--lm-script);font-size:1.75rem;color:var(--c-text);line-height:1.1;margin-bottom:.25rem}
.lm-cc-full{font-family:var(--lm-display);font-size:.6875rem;color:var(--c-text2);margin-bottom:.5rem}
.lm-cc-par{font-size:.8125rem;color:var(--c-text2);line-height:1.7}
.lm-cc-par strong{color:var(--c-text);font-weight:600}
.lm-cc-bio{font-size:.8125rem;color:var(--c-text3);line-height:1.8;margin-top:.375rem;font-style:italic}

/* ── 17. TIMELINE ──────────────────────────────────────────── */
.lm-story-txt{
  font-family:var(--lm-serif);font-size:.9375rem;font-style:italic;font-weight:300;
  color:var(--c-text2);line-height:2;text-align:center;margin-bottom:2.5rem;
}
.lm-timeline{padding:0 1.75rem 2rem}
.lm-tl-item{display:flex;gap:1rem;align-items:flex-start;margin-bottom:0}
.lm-tl-node{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:20px;padding-top:.25rem}
.lm-tl-dot{
  width:12px;height:12px;border-radius:50%;flex-shrink:0;
  border:2px solid transparent;
}
.lm-tl-dot-teal  {background:var(--c-teal);box-shadow:0 0 10px var(--c-teal-dim),0 0 0 3px rgba(0,201,167,.15)}
.lm-tl-dot-violet{background:var(--c-violet);box-shadow:0 0 10px var(--c-violet-dim),0 0 0 3px rgba(107,78,255,.15)}
.lm-tl-dot-rose  {background:var(--c-rose);box-shadow:0 0 10px var(--c-rose-dim),0 0 0 3px rgba(255,107,138,.15)}
.lm-tl-stem{width:1px;flex:1;min-height:28px;background:linear-gradient(to bottom,var(--glass-border),transparent);margin-top:4px}
.lm-tl-card{flex:1;padding:1.125rem 1.25rem;margin-bottom:1.25rem}
.lm-tl-card > *{position:relative;z-index:1}
.lm-tl-year{font-family:var(--lm-display);font-size:.5rem;letter-spacing:.2em;text-transform:uppercase;color:var(--c-teal);margin-bottom:.25rem}
.lm-tl-icon{font-size:1.125rem;margin-bottom:.375rem}
.lm-tl-title{font-family:var(--lm-serif);font-size:.9375rem;font-weight:300;color:var(--c-text);line-height:1.4;margin-bottom:.25rem}
.lm-tl-desc{font-size:.8125rem;color:var(--c-text2);line-height:1.7}

/* ── 18. EVENTS ────────────────────────────────────────────── */
.lm-event-card{padding:1.5rem}
.lm-event-card > *:not(.lm-glass-glow){position:relative;z-index:1}
.lm-ev-inner > *{position:relative;z-index:1}
.lm-ev-type{
  font-family:var(--lm-display);font-size:.5rem;
  letter-spacing:.28em;text-transform:uppercase;margin-bottom:.625rem;font-weight:600;
}
.lm-ev-divider{width:100%;height:1px;margin-bottom:1rem}
.lm-ev-row{display:flex;gap:.75rem;align-items:flex-start;margin-bottom:.875rem}
.lm-ev-ico{flex-shrink:0;margin-top:.125rem}
.lm-ev-main{font-family:var(--lm-serif);font-size:.9375rem;font-weight:300;color:var(--c-text);line-height:1.4}
.lm-ev-sub{font-size:.75rem;color:var(--c-text2);margin-top:.125rem}
.lm-maps-btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.5625rem 1.125rem;border-radius:99px;
  font-family:var(--lm-display);font-size:.5rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  cursor:pointer;transition:all .25s;text-decoration:none;margin-top:.625rem;
  border:1px solid;
}
.lm-btn-teal  {border-color:var(--c-teal);color:var(--c-teal);background:var(--c-teal-glow)}
.lm-btn-teal:hover{background:var(--c-teal-dim)}
.lm-btn-violet{border-color:var(--c-violet-lt);color:var(--c-violet-lt);background:var(--c-violet-glow)}
.lm-btn-violet:hover{background:var(--c-violet-dim)}
.lm-btn-rose  {border-color:var(--c-rose-lt);color:var(--c-rose-lt);background:var(--c-rose-glow)}
.lm-btn-rose:hover{background:var(--c-rose-dim)}
.lm-maps-embed{margin-top:1rem;overflow:hidden;border-radius:8px}
.lm-maps-embed iframe{width:100%;height:200px;border:none;display:block}

/* ── 19. COUNTDOWN — SVG Circular Ring (SIGNATURE #2) ──────── */
.lm-cd-ring-wrap{
  position:relative;display:inline-block;
  width:280px;height:280px;
  margin:1.5rem auto;
}
.lm-cd-svg{
  width:100%;height:100%;
  transform:rotate(-90deg); /* Start from top */
}
.lm-ring-track{
  stroke:rgba(255,255,255,.06);
  stroke-width:6;fill:none;
}
.lm-ring-active{
  stroke-width:6;fill:none;
  stroke-linecap:round;
  transition:stroke-dashoffset .9s ease;
}
.lm-ring-teal  {stroke:var(--c-teal);  filter:drop-shadow(0 0 4px var(--c-teal))}
.lm-ring-violet{stroke:var(--c-violet);filter:drop-shadow(0 0 4px var(--c-violet))}
.lm-ring-rose  {stroke:var(--c-rose);  filter:drop-shadow(0 0 4px var(--c-rose))}
.lm-ring-white {stroke:rgba(255,255,255,.7);filter:drop-shadow(0 0 3px rgba(255,255,255,.4))}

/* Center display inside the ring */
.lm-cd-center{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:80px;height:80px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:0;border-radius:50%;text-align:center;
}
.lm-cd-num{
  font-family:var(--lm-display);font-size:1.625rem;font-weight:700;
  color:var(--c-text);line-height:1;
}
.lm-cd-lbl{font-family:var(--lm-display);font-size:.45rem;letter-spacing:.18em;text-transform:uppercase;color:var(--c-text2)}

/* Labels positioned around the ring */
.lm-cd-labels{
  position:absolute;top:0;left:0;right:0;bottom:0;
  pointer-events:none;
}
.lm-cd-label{
  position:absolute;display:flex;flex-direction:column;align-items:center;gap:1px;
}
.lm-cd-label span:first-child{
  font-family:var(--lm-display);font-size:.875rem;font-weight:600;color:var(--c-text);
}
.lm-cd-unit-lbl{font-family:var(--lm-display);font-size:.375rem;letter-spacing:.14em;text-transform:uppercase;color:var(--c-text3)}
/* Position labels at the "end" of each ring (top position after rotate(-90deg)) */
.lm-cd-label-h{top:8px;right:60px;}
.lm-cd-label-m{bottom:8px;right:60px;}
.lm-cd-label-s{bottom:8px;left:60px;}

/* ── 20. GALLERY — CSS Columns Masonry ─────────────────────── */
.lm-masonry{
  column-count:2;column-gap:3px;
  padding:0 1.75rem 2rem;
}
.lm-mas-item{
  position:relative;overflow:hidden;cursor:pointer;
  break-inside:avoid;margin-bottom:3px;
  border-radius:4px;
  display:block;
}
.lm-mas-item img{
  width:100%;display:block;
  transition:transform .5s ease,filter .4s ease;
  filter:saturate(.8);
}
.lm-mas-item:hover img{transform:scale(1.05);filter:saturate(1)}

/* Glass caption overlay */
.lm-mas-cap{
  position:absolute;bottom:0;left:0;right:0;
  padding:.5rem .75rem;
  font-family:var(--lm-display);font-size:.625rem;
  letter-spacing:.06em;color:var(--c-text);
  transform:translateY(100%);transition:transform .3s ease;
  border-radius:0 0 4px 4px;
}
.lm-mas-item:hover .lm-mas-cap{transform:translateY(0)}

/* Overlay with zoom icon */
.lm-mas-overlay{
  position:absolute;inset:0;
  background:rgba(8,9,26,0);
  display:flex;align-items:center;justify-content:center;
  transition:background .3s ease;
}
.lm-mas-item:hover .lm-mas-overlay{background:rgba(8,9,26,.35)}
.lm-mas-overlay svg{opacity:0;transition:opacity .3s}
.lm-mas-item:hover .lm-mas-overlay svg{opacity:1}

/* ── 21. LIGHTBOX ──────────────────────────────────────────── */
#lm-lb{position:fixed;inset:0;z-index:9000;background:rgba(4,5,14,.97);display:none;align-items:center;justify-content:center;padding:1rem}
#lm-lb.open{display:flex}
#lm-lb-img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:4px;box-shadow:0 0 80px rgba(0,0,0,.8)}
#lm-lb-x{position:absolute;top:1rem;right:1rem;width:36px;height:36px;border-radius:50%;background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--c-text);font-size:1.125rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}
#lm-lb-x:hover{background:rgba(255,255,255,.12)}
#lm-lb-p,#lm-lb-n{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--c-text);font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
#lm-lb-p{left:.75rem}#lm-lb-n{right:.75rem}
#lm-lb-p:hover,#lm-lb-n:hover{background:rgba(255,255,255,.12)}
#lm-lb-cap{position:absolute;bottom:1.25rem;left:50%;transform:translateX(-50%);font-size:.75rem;color:var(--c-text2);white-space:nowrap;max-width:90%;overflow:hidden;text-overflow:ellipsis}

/* ── 22. RUNDOWN ───────────────────────────────────────────── */
.lm-rundown{display:flex;flex-direction:column}
.lm-rd-item{display:flex;gap:.875rem;align-items:flex-start;padding:.875rem 0}
.lm-rd-time{width:56px;flex-shrink:0;text-align:right;font-family:var(--lm-display);font-size:.6875rem;padding-top:.1875rem;font-weight:600}
.lm-rd-node{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:20px;padding-top:.25rem;gap:4px}
.lm-rd-stem{width:1px;flex:1;min-height:24px;background:linear-gradient(to bottom,var(--glass-border),transparent)}
.lm-rd-title{font-family:var(--lm-serif);font-size:.9375rem;font-weight:300;color:var(--c-text);line-height:1.4}
.lm-rd-desc{font-size:.8125rem;color:var(--c-text2);line-height:1.7;margin-top:.25rem}

/* ── 23. FORMS ─────────────────────────────────────────────── */
.lm-form{display:flex;flex-direction:column;gap:1rem}
.lm-fg{display:flex;flex-direction:column;gap:.4375rem}
.lm-lbl{font-family:var(--lm-display);font-size:.5rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--c-text3)}
.lm-lbl small{text-transform:none;letter-spacing:0}
.lm-inp{
  width:100%;padding:.75rem 1rem;
  background:rgba(255,255,255,.05);
  border:1px solid var(--glass-border);
  border-radius:8px;color:var(--c-text);font-size:.875rem;
  font-family:var(--lm-display);outline:none;
  transition:border-color .25s,box-shadow .25s;-webkit-appearance:none;
}
.lm-inp:focus{border-color:var(--c-teal);box-shadow:0 0 0 3px var(--c-teal-glow)}
.lm-inp::placeholder{color:var(--c-text4)}
.lm-inp option{background:var(--c-deep)}
.lm-attend-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.lm-attend{
  padding:.75rem;text-align:center;
  background:rgba(255,255,255,.04);border:1px solid var(--glass-border);
  border-radius:8px;color:var(--c-text2);font-family:var(--lm-display);
  font-size:.5625rem;font-weight:600;letter-spacing:.1em;
  cursor:pointer;transition:all .25s;
}
.lm-attend.active,.lm-attend:hover{border-color:var(--c-teal);color:var(--c-teal);background:var(--c-teal-glow);box-shadow:0 0 12px var(--c-teal-glow)}
.lm-submit{
  display:flex;align-items:center;justify-content:center;gap:.625rem;
  width:100%;padding:.875rem 1.5rem;
  border:1px solid;border-radius:99px;
  font-family:var(--lm-display);font-size:.5rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  cursor:pointer;transition:all .3s;
}
.lm-submit-teal  {border-color:var(--c-teal);color:var(--c-teal);background:var(--c-teal-glow)}
.lm-submit-teal:hover{background:var(--c-teal-dim);box-shadow:0 0 20px var(--c-teal-glow)}
.lm-submit-violet{border-color:var(--c-violet-lt);color:var(--c-violet-lt);background:var(--c-violet-glow)}
.lm-submit-violet:hover{background:var(--c-violet-dim);box-shadow:0 0 20px var(--c-violet-glow)}

/* ── 24. WISHES ────────────────────────────────────────────── */
.lm-wish{display:flex;gap:.875rem;padding:1rem 1.25rem}
.lm-wish-av{width:36px;height:36px;border-radius:50%;flex-shrink:0;background:var(--c-teal-glow);border:1px solid rgba(0,201,167,.25);display:flex;align-items:center;justify-content:center;font-family:var(--lm-display);font-size:.875rem;font-weight:700;color:var(--c-teal)}
.lm-wish-body{flex:1;min-width:0}
.lm-wish-head{display:flex;align-items:baseline;flex-wrap:wrap;gap:.375rem .75rem;margin-bottom:.375rem}
.lm-wish-name{font-family:var(--lm-display);font-size:.9375rem;font-weight:600;color:var(--c-text)}
.lm-wish-rel{font-size:.625rem;color:var(--c-teal);letter-spacing:.08em}
.lm-wish-time{font-size:.625rem;color:var(--c-text4);margin-left:auto}
.lm-wish-msg{font-size:.8125rem;color:var(--c-text2);line-height:1.75}
.lm-loadmore{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem;margin-top:1rem;background:transparent;border:1px solid var(--glass-border);border-radius:99px;color:var(--c-text2);font-family:var(--lm-display);font-size:.5rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:all .25s}
.lm-loadmore:hover{border-color:var(--c-teal);color:var(--c-teal)}

/* ── 25. GIFT ──────────────────────────────────────────────── */
.lm-tabs{display:flex;margin-bottom:1.5rem;border-bottom:1px solid var(--glass-border)}
.lm-tab{flex:1;padding:.75rem;text-align:center;font-family:var(--lm-display);font-size:.5rem;letter-spacing:.18em;text-transform:uppercase;color:var(--c-text3);border-bottom:1.5px solid transparent;margin-bottom:-1px;cursor:pointer;transition:all .25s}
.lm-tab.active{color:var(--c-teal);border-bottom-color:var(--c-teal)}
.lm-hidden{display:none}
.lm-bank{display:flex;align-items:center;gap:1rem;padding:1.125rem 1.375rem}
.lm-bank > *:not(.lm-glass-glow){position:relative;z-index:1}
.lm-bank-left{flex:1;min-width:0}
.lm-bank-name{font-family:var(--lm-display);font-size:.5rem;letter-spacing:.2em;text-transform:uppercase;color:var(--c-teal);margin-bottom:.375rem}
.lm-bank-num{font-family:'Courier New',monospace;font-size:1.25rem;color:var(--c-text);letter-spacing:.1em;margin-bottom:.25rem}
.lm-bank-holder{font-size:.75rem;color:var(--c-text2)}
.lm-copy-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background:var(--c-teal-glow);border:1px solid rgba(0,201,167,.25);border-radius:99px;color:var(--c-teal);font-family:var(--lm-display);font-size:.5rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;position:relative;z-index:1}
.lm-copy-btn:hover{background:var(--c-teal-dim)}
.lm-addr-box{padding:1.25rem 1.5rem;font-size:.875rem;color:var(--c-text2);line-height:1.9}
.lm-addr-box > *{position:relative;z-index:1}

/* ── 26. CONTACT ───────────────────────────────────────────── */
.lm-contact-inner{display:flex;align-items:center;gap:1rem;position:relative;z-index:1}
.lm-contact-left{flex:1;min-width:0}
.lm-contact-name{font-family:var(--lm-serif);font-size:1rem;font-weight:300;color:var(--c-text)}
.lm-contact-phone{font-size:.8125rem;color:var(--c-text2);margin-top:.25rem}
.lm-wa-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5625rem 1rem;background:rgba(37,211,102,.1);border:1px solid rgba(37,211,102,.2);border-radius:99px;color:#25d366;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .25s;text-decoration:none;font-family:var(--lm-display)}
.lm-wa-btn:hover{background:rgba(37,211,102,.18)}
.lm-note{font-size:.8125rem;color:var(--c-text2);line-height:1.8;font-style:italic;padding:.875rem 0;border-top:1px solid var(--glass-border)}

/* ── 27. HASHTAG ───────────────────────────────────────────── */
.lm-hashtag-wrap{display:flex;flex-direction:column;gap:.75rem}
.lm-hashtag{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;cursor:pointer;transition:all .2s}
.lm-ht-text{font-family:var(--lm-script);font-size:1.25rem;position:relative;z-index:1}
.lm-hashtag svg{color:var(--c-text3);flex-shrink:0;position:relative;z-index:1}

/* ── 28. CLOSING ───────────────────────────────────────────── */
.lm-closing-sec{
  position:relative;text-align:center;
  padding:4rem 0 5rem;overflow:hidden;
  background:var(--c-space);
}
.lm-closing-inner{position:relative;z-index:5;padding:0 1.75rem}

/* Sacred geometry */
.lm-sacred-geo{
  width:200px;height:200px;
  margin:0 auto 2rem;
  position:relative;
}
.lm-sacred-geo svg{width:100%;height:100%;display:block;animation:geoRotate 40s linear infinite}
@keyframes geoRotate{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* Glass closing card */
.lm-closing-card{padding:2rem 1.75rem;max-width:340px;margin:0 auto 2rem}
.lm-closing-names{
  font-family:var(--lm-script);font-size:2.375rem;
  color:var(--c-text);line-height:1.2;margin-bottom:1.5rem;
  display:flex;align-items:center;justify-content:center;
  flex-wrap:wrap;gap:.375rem .75rem;
  position:relative;z-index:1;
}
.lm-closing-amp{font-family:var(--lm-serif);font-style:italic;font-size:1.25rem;color:var(--c-teal)}
.lm-closing-txt{
  font-family:var(--lm-serif);font-size:.9375rem;font-style:italic;font-weight:300;
  color:var(--c-text2);line-height:2;max-width:300px;margin:0 auto;
  position:relative;z-index:1;
}
.lm-closing-date{
  font-family:var(--lm-display);font-size:.5rem;letter-spacing:.24em;
  text-transform:uppercase;color:var(--c-text3);margin-top:.875rem;
  position:relative;z-index:1;
}
.lm-closing-share{display:flex;align-items:center;justify-content:center;gap:.625rem;flex-wrap:wrap;margin-bottom:2rem}
.lm-cls-btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.625rem 1.125rem;border-radius:99px;
  font-family:var(--lm-display);font-size:.5rem;font-weight:600;letter-spacing:.12em;
  cursor:pointer;transition:all .25s;border:1px solid;
}
.lm-cls-teal  {border-color:rgba(0,201,167,.35);color:var(--c-teal);background:var(--c-teal-glow)}
.lm-cls-teal:hover{background:var(--c-teal-dim)}
.lm-cls-violet{border-color:rgba(107,78,255,.35);color:var(--c-violet-lt);background:var(--c-violet-glow)}
.lm-cls-violet:hover{background:var(--c-violet-dim)}
.lm-cls-rose  {border-color:rgba(255,107,138,.35);color:var(--c-rose-lt);background:var(--c-rose-glow)}
.lm-cls-rose:hover{background:var(--c-rose-dim)}
.lm-brand{font-size:.5625rem;letter-spacing:.1em;color:var(--c-text4)}
.lm-brand a{color:var(--c-text3);text-decoration:underline;text-underline-offset:3px}

/* ── 29. SHARE SHEET ───────────────────────────────────────── */
#lm-share{position:fixed;inset:0;z-index:8500;background:rgba(0,0,8,.7);backdrop-filter:blur(8px);display:none;align-items:flex-end;justify-content:center;padding-bottom:env(safe-area-inset-bottom,0)}
#lm-share-panel{background:var(--c-deep);width:100%;max-width:var(--max-w);border-top:1px solid var(--c-teal);overflow:hidden}
.lm-share-aurora{height:64px;position:relative;overflow:hidden}
.lm-share-inner{padding:1.25rem 1.75rem 1.75rem}
.lm-share-ttl{font-family:var(--lm-display);font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;color:var(--c-text2);text-align:center;margin-bottom:1.25rem}
.lm-share-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.25rem}
.lm-sh-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.875rem .375rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;font-family:var(--lm-display);font-size:.6875rem;color:var(--c-text2);cursor:pointer;transition:border-color .2s}
.lm-sh-btn:hover{border-color:var(--c-teal)}
.lm-sh-ico{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.125rem}
.lm-wa{background:rgba(37,211,102,.1);color:#25d366}
.lm-tg{background:rgba(42,171,238,.1);color:#29a8eb}
.lm-fb{background:rgba(59,89,152,.1);color:#8b9dc3}
.lm-cp{background:var(--c-teal-glow);color:var(--c-teal)}
.lm-sh-close{width:100%;padding:.875rem;background:transparent;border:none;border-top:1px solid var(--glass-border);color:var(--c-text3);font-family:var(--lm-display);font-size:.5rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:color .2s}
.lm-sh-close:hover{color:var(--c-teal)}

/* ── 30. INIT ──────────────────────────────────────────────── */
#lm-nav{display:none}
#lm-float{display:none}

/* ── 31. RESPONSIVE ────────────────────────────────────────── */
@media(max-width:380px){
  .lm-hero-groom,.lm-hero-bride{font-size:2.75rem}
  .lm-gate-name{font-size:2rem}
  .lm-cd-ring-wrap{width:240px;height:240px}
  .lm-share-grid{grid-template-columns:repeat(2,1fr)}
  .lm-closing-names{font-size:1.875rem}
  .lm-masonry{column-count:2}
}
@media(max-width:320px){
  .lm-gate-name{font-size:1.75rem}
  .lm-hero-groom,.lm-hero-bride{font-size:2.375rem}
  .lm-cd-ring-wrap{width:200px;height:200px}
}

#lm-nav{display: grid !important; grid-template-columns: repeat(auto-fit, minmax(0, 1fr));}