
:root{
  --base:#1e1e2e;--mantle:#181825;--crust:#11111b;--text:#cdd6f4;--sub:#a6adc8;
  --over:#313244;--surf:#45475a;--mauve:#cba6f7;--blue:#89b4fa;--green:#a6e3a1;
  --peach:#fab387;--red:#f38ba8;--yellow:#f9e2af;--teal:#94e2d5;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--crust);color:var(--text);
  font:16px/1.6 ui-sans-serif,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 18px}

/* HERO */
.hero,.shero{min-height:88vh;background-size:cover;background-position:center;
  display:flex;flex-direction:column;justify-content:flex-end;position:relative;padding:32px 18px 40px}
.shero{min-height:62vh}
.hero-cap,.shero-cap{max-width:var(--maxw);margin:0 auto;width:100%}
.kicker,.day{letter-spacing:.18em;text-transform:uppercase;font-size:.78rem;color:var(--peach);font-weight:700}
.hero h1{font-size:clamp(2.6rem,8vw,5.2rem);margin:.1em 0 .1em;line-height:1.02;
  font-weight:800;letter-spacing:-.02em;text-shadow:0 3px 30px rgba(0,0,0,.6)}
.shero h1{font-size:clamp(2rem,6vw,3.6rem);margin:.1em 0;font-weight:800;letter-spacing:-.02em;
  text-shadow:0 3px 30px rgba(0,0,0,.6)}
.sub{font-size:1.2rem;color:var(--sub);margin:.2em 0 1em;max-width:38ch}
.shero-cap p{color:var(--sub);font-size:1.05rem;margin:.2em 0 1em}
.home{position:absolute;top:20px;left:0;right:0;max-width:var(--maxw);margin:0 auto;padding:0 18px;
  color:var(--text);font-weight:700;opacity:.92}
.scroll-hint{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);color:var(--sub);
  font-size:.8rem;letter-spacing:.1em;animation:bob 2s infinite}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip,.chips span{background:rgba(49,50,68,.7);backdrop-filter:blur(6px);border:1px solid var(--surf);
  color:var(--text);padding:6px 12px;border-radius:999px;font-size:.85rem;font-weight:600}

/* SECTIONS */
.sec{font-size:1.6rem;margin:2.2em 0 .7em;font-weight:800;letter-spacing:-.01em}
.sec::after{content:"";display:block;width:48px;height:3px;background:var(--mauve);border-radius:3px;margin-top:.35em}
.intro,.narr{font-size:1.15rem;color:var(--text);max-width:68ch;margin:2em auto 0}
.narr{margin-top:2em}

/* MAP */
.bigmap{height:60vh;min-height:420px;border-radius:16px;margin:.5em 0;border:1px solid var(--surf);z-index:0}
.minimap{height:300px;border-radius:14px;margin:1.6em 0;border:1px solid var(--surf);z-index:0}
.leaflet-popup-content-wrapper{background:var(--base);color:var(--text);border-radius:10px}
.leaflet-popup-tip{background:var(--base)}
.leaflet-container{background:#0c0c14}

/* CARDS */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:18px;margin-bottom:1em}
.card{background:var(--base);border:1px solid var(--over);border-radius:16px;overflow:hidden;
  display:flex;flex-direction:column;transition:transform .18s,border-color .18s,box-shadow .18s}
.card:hover{transform:translateY(-4px);border-color:var(--mauve);box-shadow:0 12px 40px rgba(0,0,0,.45)}
.card-img{aspect-ratio:4/3;overflow:hidden;background:var(--mantle)}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.card:hover .card-img img{transform:scale(1.06)}
.card-body{padding:14px 16px 16px}
.card-day{color:var(--peach);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700}
.card-body h3{margin:.25em 0 .1em;font-size:1.25rem;font-weight:800}
.card-body p{margin:0;color:var(--sub);font-size:.95rem}
.card-meta{margin-top:.7em;color:var(--teal);font-size:.82rem;font-weight:600}
.card-meta.ph{color:var(--sub);font-weight:400;font-style:italic}
.card-ph{border-style:dashed;opacity:.85}

/* FACTS */
.facts{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin:1.4em 0}
.factcard{background:var(--mantle);border:1px solid var(--over);border-radius:14px;padding:16px 18px}
.factcard h3{margin:0 0 .5em;font-size:1.05rem;color:var(--yellow);display:flex;justify-content:space-between;
  align-items:center;gap:8px;font-weight:800}
.factcard .elev{background:var(--over);color:var(--teal);font-size:.72rem;padding:3px 8px;border-radius:999px;
  font-weight:700;white-space:nowrap}
.factcard ul{margin:0;padding-left:1.1em}
.factcard li{margin:.35em 0;color:var(--sub);font-size:.92rem}

/* GALLERY */
.galh{font-size:1.4rem;margin:1.8em 0 .6em;font-weight:800}
.galh span{color:var(--sub);font-weight:500;font-size:1rem}
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:7px;margin-bottom:1em}
@media(min-width:700px){.gallery{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}}
.cell{padding:0;border:0;margin:0;cursor:pointer;background:var(--mantle);border-radius:8px;overflow:hidden;
  aspect-ratio:1;position:relative}
.cell img{width:100%;height:100%;object-fit:cover;transition:transform .3s,opacity .3s}
.cell:hover img{transform:scale(1.07)}
.cell .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;color:#fff;background:rgba(0,0,0,.28);text-shadow:0 2px 8px rgba(0,0,0,.6)}
.cell.vid::after{content:"";position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;
  background:var(--red);box-shadow:0 0 0 3px rgba(243,139,168,.25)}

/* PREV/NEXT */
.ptnav{display:flex;justify-content:space-between;gap:12px;margin:2.4em 0 1em;flex-wrap:wrap}
.pn{background:var(--base);border:1px solid var(--over);padding:12px 16px;border-radius:12px;
  font-weight:700;color:var(--text);max-width:48%}
.pn:hover{border-color:var(--mauve)}

/* LIGHTBOX */
.lb{position:fixed;inset:0;background:rgba(8,8,14,.96);z-index:1000;display:none;
  align-items:center;justify-content:center;touch-action:pan-y}
.lb.on{display:flex}
.lb-media{max-width:96vw;max-height:88vh;display:block;margin:auto;border-radius:6px}
.lb video{max-width:96vw;max-height:88vh}
.lb-x,.lb-prev,.lb-next{position:absolute;background:rgba(49,50,68,.7);border:1px solid var(--surf);
  color:#fff;cursor:pointer;border-radius:50%;width:48px;height:48px;font-size:1.5rem;display:flex;
  align-items:center;justify-content:center;backdrop-filter:blur(6px)}
.lb-x{top:16px;right:16px}
.lb-prev{left:12px;top:50%;transform:translateY(-50%)}
.lb-next{right:12px;top:50%;transform:translateY(-50%)}
.lb-count{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);color:var(--sub);
  font-size:.85rem;background:rgba(49,50,68,.6);padding:5px 12px;border-radius:999px}
@media(max-width:600px){.lb-prev,.lb-next{width:40px;height:40px;font-size:1.2rem}}

/* FOOTER */
.foot{max-width:var(--maxw);margin:3em auto 0;padding:28px 18px 40px;color:var(--sub);font-size:.85rem;
  border-top:1px solid var(--over);display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.foot .dot{opacity:.5}
