/* henna-1.css */
:root{--bg:radial-gradient(circle at 55% 55%, rgba(249,115,22,.25), transparent 60%), #120a07;--surface:rgba(255,255,255,.06);--text:rgba(255,255,255,.92);--muted:rgba(255,255,255,.70);--border:rgba(255,255,255,.14);--accent:#f97316;--accentText:#1a0b02;--badgeBg:rgba(255,255,255,.05);--tileBg:rgba(255,255,255,.04);--cueBg:rgba(255,255,255,.04);--timeBg:rgba(249,115,22,.12);--iconBg:rgba(249,115,22,.10);--inputBg:rgba(255,255,255,.06);--ornament:linear-gradient(135deg, rgba(249,115,22,.12), transparent 55%);--ornOpacity:.65;--heroPhotoOpacity:.22;}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--text);font-family:system-ui;line-height:1.55}
.hero{min-height:100vh;display:flex;align-items:center;padding:64px 18px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:var(--ornament);opacity:var(--ornOpacity);pointer-events:none}
.hero-bg{position:absolute;inset:-10%;background-image:var(--hero-image);background-size:cover;background-position:center;filter:blur(var(--hero-blur,0px));transform:scale(1.08);opacity:var(--heroPhotoOpacity, .28)}
.hero-inner{position:relative;max-width:1120px;margin:0 auto;background:var(--surface);border:1px solid var(--border);border-radius:26px;padding:64px 34px;text-align:center;backdrop-filter:saturate(1.15) blur(10px);box-shadow:0 18px 70px rgba(0,0,0,.18)}
.badge{display:inline-block;padding:8px 14px;border-radius:999px;border:1px solid var(--border);background:var(--badgeBg);color:var(--muted);font-weight:800;letter-spacing:.10em;text-transform:uppercase;font-size:12px}
.title{margin:14px 0 8px;font-size:clamp(38px,5vw,70px);letter-spacing:-.02em}
.subtitle{margin:0;color:var(--muted)}
.dot{margin:0 8px}
.countdown{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;max-width:620px;margin:24px auto 10px}
.cd-item{border:1px solid var(--border);border-radius:18px;padding:12px 10px;background:var(--tileBg)}
.cd-num{font-size:30px;font-weight:900}.cd-lbl{font-size:12px;color:var(--muted)}
.note{color:var(--muted)}
.scroll-cue{display:inline-flex;gap:10px;align-items:center;margin:22px auto 0;padding:10px 14px;border-radius:999px;border:1px solid var(--border);text-decoration:none;color:var(--muted);background:var(--cueBg)}
.scroll-cue:hover{filter:brightness(1.05)}
.main{max-width:980px;margin:0 auto;padding:18px;display:flex;flex-direction:column;gap:14px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:26px;padding:18px;box-shadow:0 18px 70px rgba(0,0,0,.10)}
.details-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:0}
.details-grid div{border:1px solid var(--border);border-radius:18px;padding:12px;background:var(--tileBg)}
dt{font-size:12px;color:var(--muted)}dd{margin:4px 0 0;font-weight:800}
.timeline{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.tl-item{display:grid;grid-template-columns:92px 1fr;gap:12px}
.tl-time{font-weight:900;padding:10px 12px;border-radius:16px;border:1px solid var(--border);background:var(--timeBg);text-align:center}
.tl-desc{border:1px solid var(--border);border-radius:16px;padding:10px 12px;background:var(--tileBg);display:flex;gap:10px;align-items:flex-start}
.tl-icon{width:34px;height:34px;display:grid;place-items:center;border-radius:14px;border:1px solid var(--border);background:var(--iconBg)}
.media img,.media video{width:100%;border-radius:18px;border:1px solid var(--border);background:rgba(255,255,255,.02)}
.footer{padding:30px 18px 50px}.footer-inner{max-width:980px;margin:0 auto;text-align:center;color:var(--muted)}
.lock,.welcome{position:fixed;inset:0;background:rgba(0,0,0,.95);display:flex;align-items:center;justify-content:center;padding:20px;z-index: 120;}
.lock-card,.welcome-card{width:min(560px,100%);background:var(--surface);border:1px solid var(--border);border-radius:26px;padding:20px;text-align:center}
.lock-card input{width:100%;padding:12px;border-radius:14px;border:1px solid var(--border);background:var(--inputBg);color:var(--text)}
.lock-card button,.welcome-card button{margin-top:12px;width:100%;padding:12px;border-radius:14px;border:1px solid var(--border);background:var(--accent);color:var(--accentText);font-weight:900;cursor:pointer}
.lock-error{min-height:18px;color:rgba(255,180,180,.95);font-size:12px}
.lock.hidden{display:none}body.locked,body.welcomed{overflow:hidden}
@media(max-width:720px){.details-grid{grid-template-columns:1fr}.countdown{grid-template-columns:repeat(2,minmax(0,1fr))}.tl-item{grid-template-columns:84px 1fr}.hero-inner{padding:44px 18px}}

.lang-btn{pointer-events:auto;position:fixed;top:16px;right:16px;z-index:55;width:44px;height:44px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text);display:grid;place-items:center;box-shadow:var(--shadow,0 12px 40px rgba(0,0,0,.15));cursor:pointer}
.lang-btn:hover{filter:brightness(1.05)}
.lang-menu{position:fixed;top:68px;right:16px;z-index:56;display:none;flex-direction:column;gap:6px;min-width:210px;padding:10px;border-radius:18px;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow,0 12px 40px rgba(0,0,0,.15))}
.lang-menu.open{display:flex}
.lang-menu button{all:unset;cursor:pointer;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text);font-weight:700}
.lang-menu button:hover{filter:brightness(1.05)}

.lang-menu{position:fixed; top:64px; right:16px; z-index:81;}

.audio-toggle{
  position:fixed;
  right:16px;
  bottom:16px;
  z-index:90;
  width:54px;
  height:54px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text);
  display:grid;
  place-items:center;
  cursor:pointer;
  box-shadow:0 18px 70px rgba(0,0,0,.18);
}
.audio-toggle:hover{filter:brightness(1.03)}

.greet-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.greet-item{padding:14px;border:1px solid var(--border);border-radius:16px;background:rgba(255,255,255,.03)}
.greet-label{font-weight:900;letter-spacing:.06em;text-transform:uppercase;font-size:.75rem;opacity:.8;margin-bottom:6px}
.greet-text{font-size:1rem;line-height:1.5}
@media (max-width:720px){.greet-grid{grid-template-columns:1fr}}

.map-wrap{margin-top:12px;border-radius:18px;overflow:hidden;border:1px solid var(--border)}
.map-iframe{width:100%;height:320px;border:0;display:block}
.map-link{color:white; display:inline-block;margin-top:12px;font-weight:900;text-decoration:none;padding:10px 14px;
  border-radius:14px;border:1px solid var(--border);background:rgba(255,255,255,.04)}
.map-link:hover{transform:translateY(-1px)}

.media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:12px}
.media-tile{border:1px solid var(--border);background:rgba(255,255,255,.03);border-radius:18px;overflow:hidden;padding:0;cursor:pointer;position:relative}
.media-thumb{width:100%;height:220px;object-fit:cover;display:block}
.media-badge{position:absolute;bottom:10px;left:10px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);
  background:rgba(0,0,0,.35);backdrop-filter: blur(6px);font-weight:900;font-size:.8rem}
@media (max-width:900px){.media-grid{grid-template-columns:repeat(2,1fr)} .media-thumb{height:200px}}
@media (max-width:560px){.media-grid{grid-template-columns:1fr} .media-thumb{height:220px}}

.no-scroll{overflow:hidden}
.lightbox{position:fixed;inset:0;display:none;z-index:9999}
.lightbox.open{display:block}
.lightbox-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.7)}
.lightbox-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;height:100%;padding:24px}
.lightbox-content{max-width:92vw;max-height:80vh}
.lightbox-close{position:absolute;top:18px;right:22px;width:44px;height:44px;border-radius:999px;border:1px solid rgba(255,255,255,.25);
  background:rgba(0,0,0,.35);color:white;font-size:26px;line-height:1;cursor:pointer}

/* Layout tweaks */
#gallery{margin-bottom:22px}
#map{margin-top:22px}

/* Square gallery tiles */
.media-thumb{aspect-ratio:1/1;height:auto}
.media-grid{align-items:stretch}
.media-thumb{object-fit:cover}

/* Preserve line breaks in greeting texts */
.greet-text{white-space:pre-wrap}
