/* ============ V5 · BENTO POP (modular vivid tiles) ============ */
:root{
  --bg:#0E0E12; --ink:#16161a; --cream:#FFF7EC;
  --pink:#FF4D8D; --blue:#2D6CFF; --yellow:#FFC43D; --mint:#27D3A2;
  --disp:"Bricolage Grotesque", system-ui, sans-serif;
  --ui:"Space Grotesk", system-ui, sans-serif;
  --pad:clamp(1rem,3vw,2.5rem); --gap:clamp(.7rem,1.5vw,1.1rem);
  --maxw:1200px; --r:22px;
}
body{background:var(--bg);color:var(--cream);font-family:var(--ui);line-height:1.5}
.wrap{max-width:var(--maxw);margin-inline:auto;padding:var(--pad)}
.h{font-family:var(--disp);font-weight:800;font-size:clamp(1.8rem,4vw,3rem);line-height:.98;letter-spacing:-.02em}
.h--light{color:var(--cream)}
.section-h{font-family:var(--disp);font-weight:800;font-size:clamp(1.6rem,4vw,2.6rem);margin:1.5rem .2rem;letter-spacing:-.02em}
.center{text-align:center}
.eyebrow{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;font-weight:700;opacity:.8}
.edit{color:#ffd98a;font-size:.82em;font-style:italic}
em{font-style:italic}

.nav{position:fixed;inset:.6rem .6rem auto .6rem;z-index:60;display:flex;align-items:center;justify-content:space-between;
  padding:.6rem 1rem;background:rgba(20,20,24,.6);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:999px}
.nav__brand{font-family:var(--disp);font-weight:800;background:var(--pink);color:#fff;width:2.1rem;height:2.1rem;display:grid;place-items:center;border-radius:50%}
.nav__links{display:flex;gap:1.2rem;font-size:.82rem;font-weight:500}
.nav__links a:hover{color:var(--yellow)}
.nav__cta{font-weight:700;background:var(--yellow);color:#161616;border-radius:999px;padding:.4rem 1rem;font-size:.8rem}

/* BENTO GRIDS */
.bento{display:grid;gap:var(--gap)}
.bento--hero{grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(120px,auto);padding-top:4.5rem}
.tile--names{grid-column:span 2;grid-row:span 2}
.tile--photo{grid-column:span 2;grid-row:span 2}
.tile--date{grid-column:span 2}
.tile--count{grid-column:span 2}
.bento--2{grid-template-columns:1fr 1fr}
.bento--flip .tile--video{order:0}
.bento--3{grid-template-columns:repeat(3,1fr)}
.bento--4{grid-template-columns:repeat(4,1fr)}

.tile{background:#1b1b22;border-radius:var(--r);padding:clamp(1.2rem,2.5vw,2rem);display:flex;flex-direction:column;gap:.5rem;justify-content:center;
  border:1px solid rgba(255,255,255,.06);transition:transform .25s}
.tile:hover{transform:translateY(-3px)}
.t-pink{background:var(--pink);color:#fff}
.t-blue{background:var(--blue);color:#fff}
.t-yellow{background:var(--yellow);color:#161616}
.t-mint{background:var(--mint);color:#08322a}
.t-ink{background:#1b1b22;color:var(--cream);justify-content:center}
.tile p{font-size:.98rem;opacity:.95}
.tile .edit{opacity:1}
.tile__emoji{font-size:1.8rem}
.tile__t{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;opacity:.85}
.tile h3{font-family:var(--disp);font-weight:800;font-size:1.3rem}
.tile__sm{font-size:.85rem;opacity:.8}
.tile__big{font-family:var(--disp);font-weight:800;font-size:1.4rem}

.tile--names h1{font-family:var(--disp);font-weight:800;font-size:clamp(2.6rem,7vw,5rem);line-height:.86;letter-spacing:-.03em;display:flex;flex-direction:column}
.tile--names .amp{font-size:.6em;opacity:.85}
.tile--names .tile__sub{font-size:1rem;opacity:.9;margin-top:.4rem}

.tile--photo,.tile--img,.tile--video{padding:0;overflow:hidden}
.tile--photo img,.tile--img img{width:100%;height:100%;object-fit:cover;min-height:240px}
.tile--video{display:grid;place-items:center;background:#000}
.tile--video video{width:100%;height:100%;max-height:520px;object-fit:cover}

/* countdown tile */
.cd{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;width:100%}
.cd li{display:flex;flex-direction:column;align-items:center;background:rgba(0,0,0,.12);border-radius:14px;padding:.7rem .3rem}
.cd b{font-family:var(--disp);font-weight:800;font-size:clamp(1.4rem,3vw,2.2rem);line-height:1}
.cd span{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;opacity:.8}

/* gallery slideshow */
.gallery .section-h{text-align:center}
.gallery .slideshow{max-width:840px;margin-inline:auto;border-radius:var(--r);overflow:hidden;border:1px solid rgba(255,255,255,.1);box-shadow:0 30px 60px -30px rgba(0,0,0,.6)}
.gallery .slides{border-radius:var(--r)}
.gallery .dots{color:#fff}

/* form */
.tile--form{gap:.8rem;background:#1b1b22}
.row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.field{display:flex;flex-direction:column;gap:.35rem}
.field>span{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;opacity:.7}
.field input,.field textarea{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.16);border-radius:12px;padding:.7rem .85rem;color:#fff;font-family:var(--ui)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--pink)}
.field--radio{border:0}
.choices{display:flex;gap:1.2rem;margin-top:.2rem;flex-wrap:wrap}
.choices label{display:flex;gap:.5rem;align-items:center}
.choices input{accent-color:var(--pink)}
.btn{font-family:var(--disp);font-weight:800;background:var(--pink);color:#fff;border-radius:999px;padding:.9rem;text-align:center;transition:transform .15s,filter .2s}
.btn:hover{filter:brightness(1.08)}.btn:active{transform:translateY(1px)}.btn[disabled]{opacity:.6}
.btn--ghost{background:transparent;border:1px solid rgba(255,255,255,.3);color:var(--cream);display:inline-block;width:auto;padding:.8rem 1.5rem}
.form__status{font-size:.9rem;min-height:1.2em}
.form__status[data-state="ok"]{color:#9af5cf}.form__status[data-state="err"]{color:#ffb3a3}
.light{opacity:.8}

/* FAQ */
.faq{display:grid;gap:.7rem}
.faq details{background:#1b1b22;border-radius:16px;padding:1rem 1.2rem;border:1px solid rgba(255,255,255,.06)}
.faq summary{font-family:var(--disp);font-weight:700;font-size:1.1rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--pink)}
.faq details[open] summary::after{content:"–"}
.faq details p{margin-top:.6rem;opacity:.85}

/* FOOTER */
.footer{text-align:center;padding:clamp(3rem,7vw,5rem) var(--pad);max-width:var(--maxw);margin-inline:auto}
.footer__line{font-family:var(--disp);font-weight:800;font-size:clamp(2rem,6vw,3.4rem);line-height:1;
  background:linear-gradient(90deg,var(--pink),var(--yellow),var(--mint),var(--blue));-webkit-background-clip:text;background-clip:text;color:transparent}
.footer__cd{margin:1.2rem 0}.footer__cd b{font-family:var(--disp);font-weight:800;font-size:1.5rem;color:var(--yellow)}
.footer__sig{margin-top:1.6rem;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;opacity:.5}

@media (max-width:820px){
  .nav__links{display:none}
  .bento--4{grid-template-columns:1fr 1fr}
  .bento--3{grid-template-columns:1fr}
}
@media (max-width:560px){
  .bento--hero,.bento--2,.bento--4{grid-template-columns:1fr}
  .tile--names,.tile--photo,.tile--date,.tile--count{grid-column:auto;grid-row:auto}
  .row{grid-template-columns:1fr}
  .bento--flip .tile--video{order:1}
}
