/* ============================================================
   AZURITE — Template CSS
   UndanganKu by Bacaunduh
   Slug: azurite | Tier: premium | Category: wedding
   Konsep: Royal Sapphire Ceremonial Luxury
   Palette: Deep Sapphire #06122A + Royal Blue #0F2460 + Gold #D4AF37
   Signature #1: Art Deco animated diamond gate frame (SVG draw)
   Signature #2: Cinema poster couple (vertical name text)
   Mood: Royal European Ceremonial — satu-satunya palette biru royal
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Parisienne&display=swap');

/* ── 1. VARIABLES ──────────────────────────────────────────── */
:root {
  --c-primary:    var(--inv-primary,   #D4AF37);
  --c-secondary:  var(--inv-secondary, #1E50A2);
  --c-sapphire:   #06122A;
  --c-royal:      #0F2460;
  --c-royal2:     #152E78;
  --c-royal3:     #1A3890;
  --c-blue-lt:    #1E50A2;
  --c-blue-pale:  rgba(30,80,162,.3);
  --c-blue-dim:   rgba(30,80,162,.12);
  --c-gold:       #D4AF37;
  --c-gold-lt:    #E8CB68;
  --c-gold-pale:  #F2E4A8;
  --c-gold-dim:   rgba(212,175,55,.16);
  --c-gold-dim2:  rgba(212,175,55,.07);
  --c-pearl:      #F2EDE4;
  --c-champagne:  #EDE0C4;
  --c-ivory:      #F8F4EC;
  --c-text:       rgba(240,232,210,.9);
  --c-text2:      rgba(212,175,55,.7);
  --c-text3:      rgba(240,232,210,.45);
  --c-text4:      rgba(240,232,210,.18);
  --c-border:     rgba(212,175,55,.22);
  --c-border2:    rgba(240,232,210,.1);
  --az-display:   'Cinzel', serif;
  --az-serif:     'Cormorant Garamond', Georgia, serif;
  --az-script:    'Parisienne', cursive;
  --az-text3:     rgba(240,232,210,.45);
  --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(--az-display);
  background:var(--c-sapphire);
  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-sapphire)}
::-webkit-scrollbar-thumb{background:var(--c-gold);border-radius:99px}

/* ── 3. WRAPPER ────────────────────────────────────────────── */
#az-wrap{
  max-width:var(--max-w);margin:0 auto;
  background:var(--c-royal);
  min-height:100vh;position:relative;overflow-x:hidden;
  box-shadow:0 0 100px rgba(0,0,0,.7);
}

/* ── 4. SCROLL REVEAL ──────────────────────────────────────── */
.az-reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.az-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 ───────────────────────────────────────────── */
#az-progress{
  position:fixed;top:0;left:0;height:2px;width:0%;
  background:linear-gradient(90deg,var(--c-blue-lt),var(--c-gold),var(--c-gold-lt),var(--c-gold));
  z-index:9999;pointer-events:none;transition:width .1s linear;
}

/* ── 6. TOAST ──────────────────────────────────────────────── */
#az-toast{
  position:fixed;bottom:5.5rem;left:50%;
  transform:translateX(-50%) translateY(8px);
  background:var(--c-royal2);color:var(--c-pearl);
  border:1px solid var(--c-border);
  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(--az-serif);
}
#az-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── 7. FLOAT CONTROLS ─────────────────────────────────────── */
#az-float{position:fixed;right:1rem;bottom:5%;transform:translateY(-50%);z-index:500;display:none;flex-direction:column;gap:.5rem}
.az-fb{
  width:30px;height:30px;border-radius:50%;
  background:rgba(6,18,42,.85);border:1px solid var(--c-border);
  color:var(--c-text3);
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(8px);transition:all .25s ease;cursor:pointer;
}
.az-fb:hover{border-color:var(--c-gold);color:var(--c-gold)}
.az-fb.az-fb-on{background:var(--c-gold-dim);border-color:var(--c-gold);color:var(--c-gold)}

/* ── 8. GATE — Art Deco Diamond (signature #1) ─────────────── */
#az-gate{
  position:fixed;inset:0;z-index:8000;
  background:var(--c-sapphire);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;cursor:pointer;
}
.az-gate-photo{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:brightness(.28) saturate(.5);
  transform:scale(1.04);
}
.az-gate-vignette{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at center,transparent 20%,rgba(6,18,42,.88) 100%);
}
.az-gate-nophoto{
  position:absolute;inset:0;
  background:linear-gradient(135deg,var(--c-sapphire) 0%,var(--c-royal) 50%,var(--c-sapphire) 100%);
}

/* Diamond SVG container */
.az-diamond-wrap{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  display:flex;align-items:center;justify-content:center;
}
#az-diamond-svg{
  width:360px;max-width:96vw;height:560px;max-height:96vh;
}
/* Diamond path initial state */
.az-d-path{
  stroke-dasharray:1000;stroke-dashoffset:1000;
}

/* Gate content */
.az-gate-body{
  position:relative;z-index:3;
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:0 2.5rem;
  max-width:280px;
}
.az-gate-eyebrow{
  font-family:var(--az-display);font-size:.5rem;letter-spacing:.4em;
  text-transform:uppercase;color:var(--c-text2);margin-bottom:1.5rem;
  opacity:0;animation:azIn .8s ease .3s forwards;
}
.az-gate-names{
  display:flex;flex-direction:column;align-items:center;gap:.25rem;
  margin-bottom:1.375rem;
  opacity:0;animation:azIn .8s ease .55s forwards;
}
.az-gate-name{
  font-family:var(--az-script);font-size:2.25rem;
  color:var(--c-pearl);line-height:1;
}
.az-gate-amp{
  font-family:var(--az-serif);font-style:italic;
  font-size:1rem;color:var(--c-gold);line-height:1.5;
}
.az-gate-date{
  display:flex;align-items:center;gap:.625rem;
  margin-bottom:1.25rem;
  font-family:var(--az-display);font-size:.4375rem;letter-spacing:.2em;
  color:var(--c-text3);
  opacity:0;animation:azIn .8s ease .75s forwards;
}
.az-gate-date-diamond{font-size:.6rem;color:var(--c-gold)}
.az-gate-to{
  font-family:var(--az-serif);font-size:.6875rem;
  color:var(--c-text3);line-height:1.7;margin-bottom:1.625rem;
  opacity:0;animation:azIn .8s ease .9s forwards;
}
.az-gate-to strong{color:var(--c-text);font-weight:400}
.az-gate-btn{
  display:inline-flex;align-items:center;gap:.625rem;
  padding:.75rem 1.5rem;
  background:transparent;border:1px solid var(--c-gold);
  color:var(--c-gold);
  font-family:var(--az-display);font-size:.5rem;font-weight:400;
  letter-spacing:.32em;text-transform:uppercase;
  cursor:pointer;transition:all .3s ease;
  opacity:0;animation:azIn .8s ease 1.05s forwards;
}
.az-gate-btn:hover{background:var(--c-gold-dim);box-shadow:0 0 20px rgba(212,175,55,.18)}
.az-gate-btn-line{width:16px;height:1px;background:rgba(212,175,55,.45);flex-shrink:0}
@keyframes azIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ── 9. BOTTOM NAV ─────────────────────────────────────────── */
#az-nav{
  position:fixed;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:var(--max-w);z-index:400;display:none;
  background:rgba(6,18,42,.94);
  border-top:1px solid rgba(212,175,55,.18);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.az-nav-inner{
  display:flex;align-items:stretch;padding:0 .25rem;
  padding-bottom:env(safe-area-inset-bottom,0);
}
.az-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(--az-display);font-size:.44rem;font-weight:400;
  letter-spacing:.1em;text-transform:uppercase;
  transition:color .2s ease;cursor:pointer;
}
.az-nb:hover{color:var(--c-text3)}
.az-nb.active{color:var(--c-gold)}
.az-nb.active svg{stroke:var(--c-gold);transform:translateY(-1px)}
.az-nb svg{transition:transform .2s;stroke:currentColor}

/* ── 10. SECTION BASE ──────────────────────────────────────── */
.az-sec{padding:3.5rem 0 3rem}
.az-sec-inner{padding:0 1.75rem}
.az-bg-royal{background:var(--c-royal)}
.az-bg-deep {background:var(--c-sapphire)}

.az-sec-lbl{
  font-family:var(--az-display);font-size:.4375rem;letter-spacing:.36em;
  text-transform:uppercase;color:var(--c-text2);
  text-align:center;margin-bottom:1rem;
}
.az-sec-ttl{
  font-family:var(--az-serif);font-size:1.875rem;font-weight:300;
  color:var(--c-pearl);line-height:1.3;text-align:center;
  margin-bottom:2rem;letter-spacing:.01em;
}
.az-sec-ttl em{font-style:italic;color:var(--c-gold)}

/* Royal rule divider */
.az-royal-div{display:flex;align-items:center;gap:.875rem;padding:1rem 1.75rem}
.az-rd-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--c-border),transparent)}
.az-rd-diamond{width:30px;height:20px;flex-shrink:0}

/* ── 11. HERO — Cinematic letterbox ────────────────────────── */
.az-hero{
  position:relative;height:100vh;min-height:580px;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.az-hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  background-color:var(--c-royal);
  filter:brightness(.38) saturate(.65);
  transform:scale(1.04);transition:transform 8s ease;
}
.az-hero-fallback{
  position:absolute;inset:0;
  background:linear-gradient(145deg,var(--c-sapphire) 0%,var(--c-royal3) 100%);
}
.az-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(6,18,42,.55) 0%,rgba(6,18,42,.25) 40%,rgba(6,18,42,.8) 100%);
}

/* Cinematic letterbox bars — unique element */
.az-letterbox-top,.az-letterbox-bot{
  position:absolute;left:0;right:0;z-index:2;
  height:clamp(40px,8vh,72px);
  background:rgba(3,8,18,.85);pointer-events:none;
}
.az-letterbox-top{top:0}
.az-letterbox-bot{bottom:0}

.az-hero-content{
  position:relative;z-index:3;text-align:center;
  padding:0 2rem;display:flex;flex-direction:column;align-items:center;
}
.az-hero-eyebrow{
  font-family:var(--az-display);font-size:.5rem;letter-spacing:.38em;
  text-transform:uppercase;color:var(--c-text2);margin-bottom:1.375rem;
}
.az-hero-names{
  display:flex;flex-direction:column;align-items:center;gap:.25rem;margin-bottom:1.5rem;
}
.az-hero-name{
  font-family:var(--az-script);font-size:3rem;
  color:var(--c-pearl);line-height:1;letter-spacing:.01em;
}
.az-hero-amp{
  font-family:var(--az-serif);font-style:italic;
  font-size:1.125rem;color:var(--c-gold);line-height:1.5;display:block;
}
.az-hero-date{
  display:flex;align-items:center;gap:.875rem;justify-content:center;
}
.az-hero-date-num{
  font-family:var(--az-display);font-size:2.5rem;font-weight:400;
  color:var(--c-pearl);line-height:1;
}
.az-hero-date-sep{
  display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;
  font-family:var(--az-display);font-size:.4375rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--c-text3);
}
.az-hero-date-line{width:32px;height:1px;background:rgba(212,175,55,.3)}
.az-hero-dow{
  font-family:var(--az-display);font-size:.375rem;letter-spacing:.22em;
  color:var(--c-gold);margin-top:.375rem;
}

/* Scroll chevrons */
.az-hero-scroll{
  position:absolute;bottom:clamp(48px,10vh,80px);left:50%;
  transform:translateX(-50%);z-index:4;
  display:flex;flex-direction:column;align-items:center;gap:3px;
}
.az-scroll-chevrons{display:flex;flex-direction:column;gap:4px}
.az-sc-1,.az-sc-2,.az-sc-3{
  width:12px;height:6px;border-left:1.5px solid rgba(212,175,55,.4);
  border-bottom:1.5px solid rgba(212,175,55,.4);
  transform:rotate(-45deg);margin:0 auto;
}
.az-sc-1{animation:chevronFade .9s ease infinite .0s}
.az-sc-2{animation:chevronFade .9s ease infinite .2s}
.az-sc-3{animation:chevronFade .9s ease infinite .4s}
@keyframes chevronFade{0%,100%{opacity:.3}50%{opacity:.9}}

/* ── 12. OPENING ───────────────────────────────────────────── */
.az-bismillah{
  font-family:var(--az-serif);font-size:1.875rem;font-weight:300;
  color:var(--c-gold);margin-bottom:1.5rem;
  line-height:1.6;letter-spacing:.04em;text-align:center;
}
.az-open-txt{
  font-family:var(--az-serif);font-size:.9375rem;font-style:italic;font-weight:300;
  color:var(--c-text3);line-height:2;text-align:center;
  max-width:320px;margin:0 auto;
}

/* ── 13. QUOTE ─────────────────────────────────────────────── */
.az-quote-bg-mark{
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  font-family:var(--az-serif);font-size:16rem;font-weight:700;
  color:rgba(212,175,55,.04);line-height:1;
  pointer-events:none;user-select:none;
}
.az-quote{
  font-family:var(--az-serif);font-size:1.125rem;font-style:italic;font-weight:300;
  color:var(--c-text3);line-height:1.9;text-align:center;
  position:relative;
}
.az-quote-src{
  display:block;font-family:var(--az-display);font-size:.5rem;
  letter-spacing:.14em;color:var(--c-text2);text-align:center;margin-top:1rem;
}

/* ── 14. COUPLE — Cinema Poster (signature #2) ─────────────── */
.az-couple-sec{position:relative;overflow:hidden}
.az-cinema-poster{
  display:flex;position:relative;
  height:clamp(380px,60vh,520px);
  overflow:hidden;
}
.az-cinema-col{
  flex:1;position:relative;overflow:hidden;
}

/* Photo backgrounds */
.az-cinema-photo{
  position:absolute;inset:0;
  background-size:cover;background-position:center top;
  background-color:var(--c-royal3);
  filter:brightness(.5) saturate(.7);
  transition:filter .4s ease;
}
.az-cinema-col:hover .az-cinema-photo{filter:brightness(.58) saturate(.8)}
.az-cinema-nophoto{
  position:absolute;inset:0;
  background:linear-gradient(135deg,var(--c-royal),var(--c-royal3));
  display:flex;align-items:center;justify-content:center;
}
.az-cinema-initial{
  font-family:var(--az-serif);font-size:5rem;font-weight:300;
  color:rgba(212,175,55,.25);
}

/* Gradient veil per column */
.az-cinema-left .az-cinema-veil{
  position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(6,18,42,.3),rgba(6,18,42,.55) 80%,rgba(6,18,42,.85) 100%);
}
.az-cinema-right .az-cinema-veil{
  position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(6,18,42,.85) 0%,rgba(6,18,42,.55) 20%,rgba(6,18,42,.3));
}

/* VERTICAL NAME TEXT — signature #2 unique element */
.az-cinema-vname{
  position:absolute;
  /* Left col: name on right edge, Right col: name on left edge */
  font-family:var(--az-display);font-size:.5rem;letter-spacing:.32em;
  color:rgba(212,175,55,.35);text-transform:uppercase;
  writing-mode:vertical-rl;text-orientation:mixed;
  top:50%;transform:translateY(-50%);
  z-index:2;user-select:none;pointer-events:none;
  transition:color .3s ease;
}
.az-cinema-left  .az-cinema-vname{right:8px;transform:translateY(-50%) rotate(180deg)}
.az-cinema-right .az-cinema-vname{left:8px}
.az-cinema-col:hover .az-cinema-vname{color:rgba(212,175,55,.55)}

/* Bottom info panel */
.az-cinema-info{
  position:absolute;bottom:0;left:0;right:0;z-index:3;
  padding:1.25rem 1rem 1.25rem;
  background:linear-gradient(to top,rgba(6,18,42,.95) 0%,transparent 100%);
}
.az-cinema-left  .az-cinema-info{padding-right:1.5rem}
.az-cinema-right .az-cinema-info{padding-left:1.5rem}

.az-cinema-lbl{
  font-family:var(--az-display);font-size:.4375rem;letter-spacing:.24em;
  text-transform:uppercase;color:var(--c-text2);margin-bottom:.375rem;
}
.az-cinema-nick{
  font-family:var(--az-script);font-size:1.625rem;
  color:var(--c-pearl);line-height:1.1;margin-bottom:.25rem;
}
.az-cinema-full{
  font-family:var(--az-display);font-size:.5rem;letter-spacing:.1em;
  color:var(--c-text3);margin-bottom:.5rem;
}
.az-cinema-par{
  font-family:var(--az-serif);font-size:.75rem;color:var(--c-text3);line-height:1.6;
}
.az-cinema-par strong{color:var(--c-text);font-weight:400}
.az-cinema-bio{
  font-family:var(--az-serif);font-size:.75rem;font-style:italic;
  color:var(--c-text3);line-height:1.7;margin-top:.375rem;
}

/* Gold center divider */
.az-cinema-divider{
  position:absolute;top:0;bottom:0;left:50%;
  width:1px;background:rgba(212,175,55,.35);
  z-index:4;pointer-events:none;
}
.az-cinema-divider::before{
  content:'◆';position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  font-size:.5rem;color:rgba(212,175,55,.5);
  background:var(--c-royal);padding:4px 0;
}

/* Single person fallback */
.az-person-single{
  display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem 0;
}
.az-person-single-photo{
  width:130px;height:130px;border-radius:50%;object-fit:cover;
  border:2px solid rgba(212,175,55,.3);
  box-shadow:0 4px 20px rgba(0,0,0,.3);
}

/* ── 15. TIMELINE ──────────────────────────────────────────── */
.az-story-txt{
  font-family:var(--az-serif);font-size:.9375rem;font-style:italic;font-weight:300;
  color:var(--c-text3);line-height:2;text-align:center;margin-bottom:2.5rem;
}
.az-timeline{padding:0 1.75rem 2rem}
.az-tl-item{display:flex;gap:1rem;align-items:flex-start;margin-bottom:0}
.az-tl-node{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:22px;padding-top:.125rem}
.az-tl-diamond{font-size:.75rem;color:var(--c-gold);flex-shrink:0;line-height:1.5}
.az-tl-stem{width:1px;flex:1;min-height:28px;background:linear-gradient(to bottom,var(--c-border),transparent);margin-top:3px}
.az-tl-card{
  flex:1;background:rgba(212,175,55,.05);
  border:1px solid rgba(212,175,55,.12);
  padding:1.125rem 1.25rem;margin-bottom:1.25rem;
}
.az-tl-year{font-family:var(--az-display);font-size:.4375rem;letter-spacing:.22em;text-transform:uppercase;color:var(--c-text2);margin-bottom:.25rem}
.az-tl-icon{font-size:1.125rem;margin-bottom:.375rem}
.az-tl-title{font-family:var(--az-serif);font-size:.9375rem;font-weight:300;color:var(--c-pearl);line-height:1.4;margin-bottom:.25rem}
.az-tl-desc{font-size:.8125rem;color:var(--c-text3);line-height:1.7}

/* ── 16. EVENTS ────────────────────────────────────────────── */
.az-event{
  position:relative;margin:0 1.75rem 1.5rem;
  background:rgba(212,175,55,.05);border:1px solid rgba(212,175,55,.12);
  overflow:hidden;
}
.az-ev-roman-bg{
  position:absolute;top:-.5rem;right:1rem;
  font-family:var(--az-display);font-size:6rem;font-weight:700;
  color:rgba(212,175,55,.06);line-height:1;
  user-select:none;pointer-events:none;
}
.az-ev-inner{position:relative;z-index:1;padding:1.5rem 1.375rem}
.az-ev-head{display:flex;align-items:flex-start;gap:1rem;margin-bottom:0}
.az-ev-head-left{flex-shrink:0}
.az-ev-roman-sm{
  font-family:var(--az-display);font-size:1.75rem;font-weight:400;
  color:rgba(212,175,55,.25);line-height:1;
}
.az-ev-head-right{flex:1}
.az-ev-type{
  font-family:var(--az-display);font-size:.4375rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--c-text2);margin-bottom:.25rem;
}
.az-ev-hdate{
  font-family:var(--az-display);font-size:.375rem;letter-spacing:.16em;
  color:var(--c-text3);
}
.az-ev-rule{display:flex;align-items:center;gap:.625rem;margin:1rem 0}
.az-ev-rule-line{flex:1;height:1px;background:rgba(212,175,55,.18)}
.az-ev-rule-diamond{font-size:.5rem;color:rgba(212,175,55,.4);flex-shrink:0}
.az-ev-row{display:flex;gap:.75rem;align-items:flex-start;margin-bottom:.875rem}
.az-ev-ico{width:18px;height:18px;flex-shrink:0;margin-top:.125rem;color:var(--c-text2)}
.az-ev-main{font-family:var(--az-serif);font-size:.9375rem;font-weight:300;color:var(--c-pearl);line-height:1.4}
.az-ev-sub{font-size:.75rem;color:var(--c-text3);margin-top:.125rem}
.az-maps-btn{
  display:inline-flex;align-items:center;gap:.5rem;
  margin-top:1rem;padding:.5rem 1.125rem;
  background:var(--c-gold-dim);border:1px solid var(--c-border);
  color:var(--c-gold);font-family:var(--az-display);
  font-size:.4375rem;font-weight:400;letter-spacing:.22em;text-transform:uppercase;
  cursor:pointer;transition:all .25s;text-decoration:none;
}
.az-maps-btn:hover{background:rgba(212,175,55,.22)}
.az-maps-embed{margin-top:1rem;overflow:hidden}
.az-maps-embed iframe{width:100%;height:200px;border:none;display:block}

/* ── 17. COUNTDOWN — Gold horizontal lines ─────────────────── */
.az-cd-row{
  display:flex;align-items:flex-start;justify-content:center;
  gap:.5rem;margin:2rem auto;max-width:360px;
}
.az-cd-cell{display:flex;flex-direction:column;align-items:center;gap:.375rem}
.az-cd-top-line,.az-cd-bot-line{
  width:100%;height:1px;
  background:linear-gradient(90deg,transparent,var(--c-border),transparent);
}
.az-cd-num{
  font-family:var(--az-serif);font-size:clamp(2.25rem,12vw,3.5rem);
  font-weight:300;color:var(--c-pearl);line-height:1.1;
  min-width:2ch;text-align:center;letter-spacing:-.02em;
}
.az-cd-lbl{
  font-family:var(--az-display);font-size:.375rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--c-text3);
}
.az-cd-sep{
  font-size:.5rem;color:rgba(212,175,55,.35);
  align-self:center;margin:0 .125rem;
  padding-bottom:1.5rem;
}

/* ── 18. GALLERY — Full-width stacked ──────────────────────── */
.az-gallery-stack{padding-bottom:2rem}
.az-gal-row{
  position:relative;cursor:pointer;margin-bottom:3px;
  background:var(--c-sapphire);
}
.az-gal-num{
  position:absolute;top:.75rem;left:1rem;z-index:2;
  font-family:var(--az-display);font-size:.5rem;letter-spacing:.2em;
  color:rgba(212,175,55,.55);pointer-events:none;user-select:none;
}
.az-gal-photo{
  position:relative;overflow:hidden;
  height:clamp(220px,45vw,280px);
}
.az-gal-photo img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .6s ease,filter .4s ease;
  filter:saturate(.8);
}
.az-gal-row:hover .az-gal-photo img{transform:scale(1.04);filter:saturate(.9)}
.az-gal-overlay{
  position:absolute;inset:0;background:rgba(6,18,42,0);
  display:flex;align-items:center;justify-content:center;
  transition:background .35s ease;
}
.az-gal-row:hover .az-gal-overlay{background:rgba(6,18,42,.3)}
/* Diamond corner marks */
.az-gal-corner{position:absolute;width:16px;height:16px}
.az-gal-corner::before,.az-gal-corner::after{
  content:'';position:absolute;background:rgba(212,175,55,.6);
  opacity:0;transition:opacity .3s;
}
.az-gal-row:hover .az-gal-corner::before,
.az-gal-row:hover .az-gal-corner::after{opacity:1}
.az-gal-corner::before{width:100%;height:1.5px}
.az-gal-corner::after{width:1.5px;height:100%}
.az-gc-tl{top:8px;left:8px}
.az-gc-tr{top:8px;right:8px;transform:scaleX(-1)}
.az-gc-bl{bottom:8px;left:8px;transform:scaleY(-1)}
.az-gc-br{bottom:8px;right:8px;transform:scale(-1,-1)}
.az-gal-zoom{opacity:0;transition:opacity .3s}
.az-gal-row:hover .az-gal-zoom{opacity:1}

.az-gal-caption-row{
  display:flex;align-items:center;gap:.75rem;
  padding:.5rem 1rem;background:var(--c-sapphire);
}
.az-gal-cap-line{flex:1;height:1px;background:var(--c-border)}
.az-gal-caption{
  font-family:var(--az-serif);font-size:.8125rem;font-style:italic;
  color:var(--c-text3);flex-shrink:0;
  max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

/* ── 19. LIGHTBOX ──────────────────────────────────────────── */
#az-lb{position:fixed;inset:0;z-index:9000;background:rgba(3,8,18,.97);display:none;align-items:center;justify-content:center;padding:1rem}
#az-lb.open{display:flex}
#az-lb-img{max-width:100%;max-height:80vh;object-fit:contain;box-shadow:0 0 80px rgba(0,0,0,.8)}
#az-lb-x{position:absolute;top:1rem;right:1rem;width:36px;height:36px;border:1px solid rgba(212,175,55,.2);background:rgba(212,175,55,.07);color:var(--c-pearl);font-size:1.125rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}
#az-lb-x:hover{background:rgba(212,175,55,.15)}
#az-lb-p,#az-lb-n{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border:1px solid rgba(212,175,55,.14);background:rgba(212,175,55,.06);color:var(--c-pearl);font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
#az-lb-p{left:.75rem}#az-lb-n{right:.75rem}
#az-lb-p:hover,#az-lb-n:hover{background:rgba(212,175,55,.14)}
#az-lb-cap{position:absolute;bottom:1.25rem;left:50%;transform:translateX(-50%);font-size:.75rem;color:var(--c-text3);white-space:nowrap;max-width:90%;overflow:hidden;text-overflow:ellipsis}

/* ── 20. RUNDOWN ───────────────────────────────────────────── */
.az-rundown{display:flex;flex-direction:column}
.az-rd-item{display:flex;gap:.875rem;align-items:flex-start;padding:.875rem 0}
.az-rd-time{width:56px;flex-shrink:0;text-align:right;font-family:var(--az-display);font-size:.5625rem;color:var(--c-gold);padding-top:.25rem;letter-spacing:.06em}
.az-rd-node{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:20px;padding-top:.1875rem;gap:3px}
.az-rd-diamond{font-size:.625rem;color:var(--c-gold);line-height:1}
.az-rd-stem{width:1px;flex:1;min-height:24px;background:linear-gradient(to bottom,var(--c-border),transparent)}
.az-rd-title{font-family:var(--az-serif);font-size:.9375rem;font-weight:300;color:var(--c-pearl);line-height:1.4}
.az-rd-desc{font-size:.8125rem;color:var(--c-text3);line-height:1.7;margin-top:.25rem}

/* ── 21. FORMS ─────────────────────────────────────────────── */
.az-form{display:flex;flex-direction:column;gap:1rem}
.az-fg{display:flex;flex-direction:column;gap:.4375rem}
.az-lbl{font-family:var(--az-display);font-size:.5rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--c-text3)}
.az-lbl small{font-weight:400;text-transform:none;letter-spacing:0}
.az-inp{
  width:100%;padding:.75rem 1rem;
  background:rgba(212,175,55,.05);border:1px solid rgba(212,175,55,.14);
  color:var(--c-pearl);font-size:.875rem;
  font-family:var(--az-serif);outline:none;
  transition:border-color .25s,box-shadow .25s;-webkit-appearance:none;
}
.az-inp:focus{border-color:var(--c-gold);box-shadow:0 0 0 3px rgba(212,175,55,.07)}
.az-inp::placeholder{color:var(--c-text4)}
.az-inp option{background:var(--c-royal)}
.az-attend-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.az-attend{
  padding:.75rem;text-align:center;
  background:rgba(212,175,55,.05);border:1px solid rgba(212,175,55,.12);
  color:var(--c-text3);font-family:var(--az-display);font-size:.5rem;letter-spacing:.1em;
  cursor:pointer;transition:all .25s;
}
.az-attend.active,.az-attend:hover{border-color:var(--c-gold);background:var(--c-gold-dim);color:var(--c-gold)}
.az-submit{
  display:flex;align-items:center;justify-content:center;gap:.625rem;
  width:100%;padding:.875rem 1.5rem;
  background:transparent;border:1px solid var(--c-gold);
  color:var(--c-gold);font-family:var(--az-display);
  font-size:.5rem;font-weight:400;letter-spacing:.28em;text-transform:uppercase;
  cursor:pointer;transition:all .3s;
}
.az-submit:hover{background:var(--c-gold-dim);box-shadow:0 0 24px rgba(212,175,55,.12)}

/* ── 22. WISHES ────────────────────────────────────────────── */
.az-wish{display:flex;gap:.875rem;padding:1.125rem 0;border-bottom:1px solid var(--c-border2)}
.az-wish-av{width:36px;height:36px;flex-shrink:0;background:var(--c-gold-dim);border:1px solid var(--c-border);display:flex;align-items:center;justify-content:center;font-family:var(--az-serif);font-size:.875rem;color:var(--c-gold)}
.az-wish-body{flex:1;min-width:0}
.az-wish-head{display:flex;align-items:baseline;flex-wrap:wrap;gap:.375rem .75rem;margin-bottom:.375rem}
.az-wish-name{font-family:var(--az-serif);font-size:.9375rem;font-weight:300;color:var(--c-pearl)}
.az-wish-rel{font-size:.625rem;color:var(--c-text2);letter-spacing:.08em}
.az-wish-time{font-size:.625rem;color:var(--c-text4);margin-left:auto}
.az-wish-msg{font-size:.8125rem;color:var(--c-text3);line-height:1.75}
.az-loadmore{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem;margin-top:1.25rem;background:transparent;border:1px solid var(--c-border2);color:var(--c-text3);font-family:var(--az-display);font-size:.5rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:all .25s}
.az-loadmore:hover{border-color:var(--c-gold);color:var(--c-gold)}

/* ── 23. GIFT ──────────────────────────────────────────────── */
.az-tabs{display:flex;margin-bottom:1.5rem;border-bottom:1px solid var(--c-border2)}
.az-tab{flex:1;padding:.75rem;text-align:center;font-family:var(--az-display);font-size:.4375rem;letter-spacing:.18em;text-transform:uppercase;color:var(--c-text3);border-bottom:1px solid transparent;margin-bottom:-1px;cursor:pointer;transition:all .25s}
.az-tab.active{color:var(--c-gold);border-bottom-color:var(--c-gold)}
.az-hidden{display:none}
.az-bank{display:flex;align-items:center;gap:1rem;background:rgba(212,175,55,.06);border:1px solid var(--c-border2);padding:1.25rem 1.5rem;margin-bottom:1rem;transition:border-color .25s}
.az-bank:hover{border-color:var(--c-border)}
.az-bank-left{flex:1;min-width:0}
.az-bank-name{font-family:var(--az-display);font-size:.4375rem;letter-spacing:.22em;text-transform:uppercase;color:var(--c-text2);margin-bottom:.375rem}
.az-bank-num{font-family:'Courier New',monospace;font-size:1.25rem;color:var(--c-pearl);letter-spacing:.1em;margin-bottom:.25rem}
.az-bank-holder{font-size:.75rem;color:var(--c-text3)}
.az-copy-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background:var(--c-gold-dim);border:1px solid var(--c-border);color:var(--c-gold);font-family:var(--az-display);font-size:.4375rem;letter-spacing:.14em;cursor:pointer;transition:all .2s;white-space:nowrap}
.az-copy-btn:hover{background:rgba(212,175,55,.22)}
.az-addr-box{background:rgba(212,175,55,.05);border:1px solid var(--c-border2);padding:1.25rem 1.5rem;font-size:.875rem;color:var(--c-text3);line-height:1.9}

/* ── 24. CONTACT ───────────────────────────────────────────── */
.az-contact{display:flex;align-items:center;gap:1rem;background:rgba(212,175,55,.06);border:1px solid var(--c-border2);padding:1.25rem 1.5rem;margin-bottom:1.25rem}
.az-contact-left{flex:1;min-width:0}
.az-contact-name{font-family:var(--az-serif);font-size:1rem;font-weight:300;color:var(--c-pearl)}
.az-contact-phone{font-size:.8125rem;color:var(--c-text3);margin-top:.25rem}
.az-wa-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5625rem 1rem;background:rgba(37,211,102,.08);border:1px solid rgba(37,211,102,.18);color:#25d366;font-size:.75rem;cursor:pointer;transition:background .25s;text-decoration:none;font-family:var(--az-display);letter-spacing:.06em}
.az-wa-btn:hover{background:rgba(37,211,102,.16)}
.az-note{font-size:.8125rem;color:var(--c-text3);line-height:1.8;font-style:italic;padding:.875rem 0;border-top:1px solid var(--c-border2)}

/* ── 25. HASHTAG ───────────────────────────────────────────── */
.az-hashtag-wrap{display:flex;flex-direction:column;gap:.75rem}
.az-hashtag{display:flex;align-items:center;justify-content:space-between;background:rgba(212,175,55,.06);border:1px solid var(--c-border2);padding:1rem 1.25rem;cursor:pointer;transition:border-color .2s}
.az-hashtag:hover{border-color:var(--c-border)}
.az-hashtag span{font-family:var(--az-script);font-size:1.125rem;color:var(--c-gold)}
.az-hashtag svg{color:var(--c-text4);flex-shrink:0}

/* ── 26. CLOSING — Royal Heraldic Seal ─────────────────────── */
.az-closing-sec{
  background:linear-gradient(160deg,var(--c-sapphire) 0%,var(--c-royal) 50%,var(--c-sapphire) 100%);
  text-align:center;padding:4rem 0 5rem;position:relative;overflow:hidden;
}
.az-closing-pattern{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(circle,rgba(212,175,55,.03) 1px,transparent 1px) 0 0 / 28px 28px,
    radial-gradient(circle,rgba(30,80,162,.05) 1px,transparent 1px) 14px 14px / 28px 28px;
}
.az-closing-inner{position:relative;z-index:1;padding:0 1.75rem}

/* Royal seal */
.az-seal{
  width:200px;height:200px;position:relative;
  margin:0 auto 2rem;
  display:flex;align-items:center;justify-content:center;
}
.az-seal svg{position:absolute;inset:0;width:100%;height:100%}
.az-seal-mono{
  position:relative;z-index:1;
  display:flex;align-items:center;gap:.25rem;
  font-family:var(--az-display);font-size:2rem;font-weight:400;
  color:var(--c-gold);
}
.az-seal-amp{font-size:1rem;color:rgba(212,175,55,.5)}

.az-closing-names{
  font-family:var(--az-script);font-size:2.375rem;
  color:var(--c-pearl);line-height:1.2;margin-bottom:1.5rem;
  display:flex;align-items:center;justify-content:center;
  flex-wrap:wrap;gap:.25rem .625rem;
}
.az-closing-amp{font-family:var(--az-serif);font-style:italic;font-size:1.25rem;color:var(--c-gold)}
.az-closing-txt{
  font-family:var(--az-serif);font-size:.9375rem;font-style:italic;font-weight:300;
  color:var(--c-text3);line-height:2;max-width:300px;margin:0 auto;
}
.az-closing-date{
  font-family:var(--az-display);font-size:.4375rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--c-text4);margin:1rem 0 2rem;
}
.az-closing-share{display:flex;align-items:center;justify-content:center;gap:.625rem;flex-wrap:wrap}
.az-cls-btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.625rem 1.125rem;
  background:var(--c-gold-dim);border:1px solid var(--c-border);
  color:var(--c-gold);font-family:var(--az-display);
  font-size:.4375rem;font-weight:400;letter-spacing:.18em;
  cursor:pointer;transition:all .25s;
}
.az-cls-btn:hover{background:rgba(212,175,55,.22)}
.az-brand{margin-top:3rem;font-size:.5rem;letter-spacing:.12em;color:var(--c-text4)}
.az-brand a{color:var(--c-text3);text-decoration:underline;text-underline-offset:3px}

/* ── 27. SHARE SHEET ───────────────────────────────────────── */
#az-share{position:fixed;inset:0;z-index:8500;background:rgba(0,4,14,.72);backdrop-filter:blur(6px);display:none;align-items:flex-end;justify-content:center;padding-bottom:env(safe-area-inset-bottom,0)}
#az-share-panel{background:var(--c-royal);width:100%;max-width:var(--max-w);border-top:1px solid var(--c-gold);padding:0}
.az-share-crest{padding:.75rem 1.75rem 0}
.az-share-crest svg{width:100%;height:40px;display:block}
.az-share-ttl{font-family:var(--az-display);font-size:.5rem;letter-spacing:.3em;text-transform:uppercase;color:var(--c-text2);text-align:center;padding:.875rem 0 .75rem}
.az-share-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;padding:0 1.75rem 1.25rem}
.az-sh-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.875rem .375rem;background:var(--c-royal2);border:1px solid var(--c-border2);font-family:var(--az-display);font-size:.5rem;letter-spacing:.08em;color:var(--c-text3);cursor:pointer;transition:border-color .2s}
.az-sh-btn:hover{border-color:var(--c-border);color:var(--c-text)}
.az-sh-ico{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.125rem}
.az-wa{background:rgba(37,211,102,.1);color:#25d366}
.az-tg{background:rgba(42,171,238,.1);color:#29a8eb}
.az-fb{background:rgba(59,89,152,.12);color:#8b9dc3}
.az-cp{background:var(--c-gold-dim);color:var(--c-gold)}
.az-sh-close{width:100%;padding:.875rem;background:transparent;border-top:1px solid var(--c-border2);color:var(--c-text3);font-family:var(--az-display);font-size:.5rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:color .2s}
.az-sh-close:hover{color:var(--c-gold)}

/* ── 28. INIT ──────────────────────────────────────────────── */
#az-nav{display:none}
#az-float{display:none}

/* ── 29. RESPONSIVE ────────────────────────────────────────── */
@media(max-width:380px){
  .az-hero-name,.az-cinema-nick{font-size:2.375rem}
  .az-gate-name{font-size:1.875rem}
  .az-cd-num{font-size:2rem}
  .az-cinema-poster{height:320px}
  .az-share-grid{grid-template-columns:repeat(2,1fr)}
  .az-seal{width:160px;height:160px}
  .az-seal-mono{font-size:1.625rem}
  .az-closing-names{font-size:1.875rem}
  .az-letterbox-top,.az-letterbox-bot{height:32px}
}
@media(max-width:320px){
  .az-gate-name{font-size:1.625rem}
  .az-hero-name{font-size:2rem}
  .az-cinema-poster{height:280px}
}

#az-nav{display: grid !important; grid-template-columns: repeat(auto-fit, minmax(0, 1fr));}