:root{
  --black:#070303;
  --panel:#12070f;
  --gold:#f6d77d;
  --gold-soft:#d7a940;
  --purple:#7c2bd6;
  --purple-dark:#351050;
  --cream:#fff6d9;
  --muted:rgba(255,246,217,.75);
  --line:rgba(246,215,125,.32);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--black);color:var(--cream);font-family:Inter,system-ui,sans-serif;line-height:1.6;overflow-x:hidden}
a{color:inherit}
.hero{min-height:100vh;display:grid;place-items:center;padding:32px 16px;position:relative;background:radial-gradient(circle at top,#4b176e 0,transparent 34%),radial-gradient(circle at bottom right,#8a5a16 0,transparent 30%),#070303;}
.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(255,255,255,.06),transparent 26%,rgba(255,255,255,.08) 48%,transparent 60%);animation:shimmer 8s ease-in-out infinite;pointer-events:none}
.glow{position:absolute;width:340px;height:340px;border-radius:999px;filter:blur(60px);opacity:.22}.glow-one{background:var(--purple);left:-80px;top:80px}.glow-two{background:var(--gold);right:-80px;bottom:70px}
.hero-card{width:min(1120px,100%);border:1px solid rgba(246,215,125,.55);border-radius:34px;background:rgba(0,0,0,.72);overflow:hidden;box-shadow:0 30px 90px rgba(120,67,9,.26),0 0 40px rgba(246,215,125,.12)}
.hero-logo{display:block;width:100%;max-height:610px;object-fit:cover;background:#000}.hero-content{text-align:center;padding:34px 24px 44px}.eyebrow{letter-spacing:.34em;text-transform:uppercase;color:var(--gold);font-size:.86rem;font-weight:700}.tagline{font-size:clamp(1.05rem,2vw,1.35rem);max-width:760px;margin:18px auto 0;color:var(--muted)}
h1,h2,h3{font-family:Cinzel,Georgia,serif;line-height:1.15;margin:0;color:var(--gold)}h1{font-size:clamp(2.5rem,7vw,5.9rem);text-shadow:0 0 24px rgba(246,215,125,.16)}h2{font-size:clamp(2rem,5vw,4rem)}h3{font-size:1.45rem}.button-row{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:28px}.button{display:inline-flex;align-items:center;justify-content:center;padding:14px 24px;border-radius:999px;text-decoration:none;font-weight:800;transition:.22s ease;min-height:52px}.button.primary{background:linear-gradient(135deg,var(--purple),#9a4be8);box-shadow:0 12px 28px rgba(124,43,214,.3)}.button.primary:hover{transform:translateY(-2px);filter:brightness(1.12)}.button.secondary{border:1px solid var(--gold);background:rgba(0,0,0,.25);color:var(--gold)}.button.secondary:hover{background:var(--gold);color:#1a0b00;transform:translateY(-2px)}
.site-nav{position:sticky;top:0;z-index:20;display:flex;gap:16px;justify-content:center;flex-wrap:wrap;padding:12px 16px;background:rgba(0,0,0,.82);backdrop-filter:blur(14px);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.site-nav a{text-decoration:none;color:var(--gold);font-weight:700;font-size:.95rem}.site-nav a:hover{color:#d9b3ff}
.section{padding:76px 16px;position:relative}.section:after{content:"";position:absolute;inset:auto 8% 0;height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent)}.section-heading{text-align:center;max-width:760px;margin:0 auto 34px}.section-heading p{color:var(--muted);font-size:1.13rem;margin:14px auto 0}.section-icon{width:50px;height:50px;display:grid;place-items:center;border-radius:999px;margin:0 auto 18px;color:var(--gold);border:1px solid var(--line);background:rgba(80,22,111,.6);font-size:1.4rem}.gallery-grid,.card-grid{width:min(1120px,100%);margin:0 auto;display:grid;gap:22px}.gallery-grid{grid-template-columns:repeat(3,1fr)}.card-grid.three{grid-template-columns:repeat(3,1fr)}.card-grid.two{grid-template-columns:repeat(2,1fr)}
figure{margin:0;background:rgba(0,0,0,.55);border:1px solid var(--line);border-radius:26px;overflow:hidden;box-shadow:0 20px 45px rgba(60,14,90,.18)}figure img{width:100%;height:320px;object-fit:cover;display:block;transition:transform .5s ease}figure:hover img{transform:scale(1.045)}figcaption{padding:18px 20px;color:var(--gold);font-family:Cinzel,Georgia,serif;font-size:1.2rem;font-weight:700}.card,.about-box,.contact-box{border:1px solid var(--line);background:linear-gradient(145deg,rgba(18,7,15,.92),rgba(0,0,0,.74));border-radius:26px;padding:26px;box-shadow:0 20px 45px rgba(60,14,90,.18)}.card p{color:var(--muted);margin-bottom:0}.event strong{color:#fff1b8}.center-note{text-align:center;color:var(--muted);margin:24px auto 0;max-width:780px}.about-box{width:min(920px,100%);margin:0 auto;font-size:1.08rem}.about-box p{color:rgba(255,246,217,.88)}.contact-box{text-align:center;width:min(900px,100%);margin:0 auto}.contact-box h3{font-size:clamp(1.5rem,4vw,2.4rem)}.contact-box p{color:var(--muted)}.contact-box a:hover{color:#d9b3ff}footer{text-align:center;padding:38px 16px;color:rgba(255,246,217,.62);border-top:1px solid var(--line)}.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:none}
@keyframes shimmer{0%,100%{opacity:.2;transform:translateX(-20px)}50%{opacity:.55;transform:translateX(20px)}}
@media (max-width:900px){.gallery-grid,.card-grid.three{grid-template-columns:repeat(2,1fr)}.card-grid.two{grid-template-columns:1fr}.hero-logo{max-height:480px}.site-nav{gap:10px}.site-nav a{font-size:.88rem}}
@media (max-width:620px){.gallery-grid,.card-grid.three{grid-template-columns:1fr}.section{padding:58px 14px}.hero{padding:18px 10px}.hero-card{border-radius:24px}.hero-content{padding:26px 18px}.eyebrow{letter-spacing:.18em;font-size:.72rem}.button{width:100%}figure img{height:330px}.site-nav{position:relative}.site-nav a{width:45%;text-align:center}}

/* ===== Contact form + popup (added) ===== */
.contact-form{width:100%;margin:0;text-align:left;display:flex;flex-direction:column;gap:14px}
.form-row{display:flex;flex-direction:column;gap:6px}
.contact-form label{font-size:.9rem;font-weight:700;color:var(--gold)}
.req{color:#ff9a9a}
.opt{color:var(--muted);font-weight:400;font-size:.8rem}
.contact-form input,.contact-form textarea{width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--line);background:rgba(0,0,0,.45);color:var(--cream);font-family:inherit;font-size:1rem}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:rgba(255,246,217,.45)}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 2px rgba(246,215,125,.25)}
.contact-form textarea{resize:vertical;min-height:110px}
.form-status{text-align:center;font-size:.95rem;margin:6px 0 0;min-height:1.3em;color:var(--muted)}
.form-status.success{color:#9fe6a0}
.form-status.error{color:#ff9a9a}
.contact-divider{margin:18px auto 14px;color:var(--muted);font-size:.95rem;text-align:center}

/* Popup dialog */
.contact-dialog{width:min(460px,92vw);max-height:90vh;overflow:auto;border:1px solid var(--line);border-radius:24px;background:linear-gradient(145deg,rgba(18,7,15,.98),rgba(0,0,0,.96));color:var(--cream);padding:30px 26px 26px;box-shadow:0 30px 90px rgba(0,0,0,.6),0 0 40px rgba(124,43,214,.25)}
.contact-dialog::backdrop{background:rgba(7,3,3,.72);backdrop-filter:blur(4px)}
.contact-dialog[open]{animation:dialogIn .25s ease}
@keyframes dialogIn{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}
.dialog-title{text-align:center;margin:0 0 6px;font-size:clamp(1.5rem,5vw,1.9rem)}
.dialog-sub{text-align:center;color:var(--muted);margin:0 0 18px;font-size:.95rem}
.dialog-close{position:absolute;top:10px;right:14px;background:none;border:none;color:var(--gold);font-size:1.9rem;line-height:1;cursor:pointer;padding:4px 10px;border-radius:10px}
.dialog-close:hover{color:#d9b3ff}
.dialog-actions{display:flex;justify-content:center;gap:12px;margin-top:8px;flex-wrap:wrap}
.dialog-actions .button{cursor:pointer;border:none}
@media (max-width:620px){.dialog-actions .button{width:auto;flex:1}}

/* Custom-order fields (revealed only in order mode) */
.order-fields{display:none;flex-direction:column;gap:14px}
.contact-dialog.mode-order .order-fields{display:flex}
.contact-form select{width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--line);background:rgba(0,0,0,.45);color:var(--cream);font-family:inherit;font-size:1rem}
.contact-form select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 2px rgba(246,215,125,.25)}
.contact-form select option{color:#1a0b00}
.contact-form input[type=date]{color-scheme:dark}

/* ===== Facebook QR popup ===== */
.fb-dialog{width:min(380px,92vw);text-align:center}
.fb-qr-card{background:#fff;border-radius:18px;padding:16px;width:min(240px,68vw);margin:4px auto 20px;box-shadow:0 12px 30px rgba(0,0,0,.45)}
.fb-qr-card img{display:block;width:100%;height:auto;border-radius:6px}
.footer-social{margin:10px 0 0}
.footer-social a{color:var(--gold);font-weight:700;text-decoration:none}
.footer-social a:hover{color:#d9b3ff}

/* ===== Active nav highlight (scroll-spy) ===== */
.site-nav a{position:relative;transition:color .2s ease}
.site-nav a.active{color:#fff1b8}
.site-nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;border-radius:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}

/* ===== Clickable gallery images (lightbox triggers) ===== */
.gallery-grid img{cursor:zoom-in}
.gallery-grid img:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

/* ===== Back-to-top button ===== */
.back-to-top{position:fixed;right:20px;bottom:20px;z-index:40;width:50px;height:50px;border-radius:999px;border:1px solid var(--gold);background:linear-gradient(135deg,var(--purple),#9a4be8);color:var(--gold);font-size:1.5rem;line-height:1;cursor:pointer;box-shadow:0 12px 28px rgba(0,0,0,.45);opacity:0;visibility:hidden;transform:translateY(12px);transition:opacity .3s ease,transform .3s ease,visibility .3s ease}
.back-to-top.visible{opacity:1;visibility:visible;transform:none}
.back-to-top:hover{filter:brightness(1.15);transform:translateY(-2px)}
@media (max-width:620px){.back-to-top{right:14px;bottom:14px;width:46px;height:46px}}

/* ===== Lightbox ===== */
.lightbox{width:min(96vw,1100px);max-width:96vw;max-height:94vh;border:none;background:transparent;padding:0;overflow:visible}
.lightbox::backdrop{background:rgba(7,3,3,.9);backdrop-filter:blur(6px)}
.lightbox[open]{display:flex;flex-direction:column;align-items:center;animation:dialogIn .25s ease}
.lightbox-img{max-width:100%;max-height:82vh;width:auto;height:auto;border-radius:18px;border:1px solid var(--line);box-shadow:0 30px 90px rgba(0,0,0,.7);background:#000}
.lightbox-caption{margin:14px 0 0;color:var(--gold);font-family:Cinzel,Georgia,serif;font-size:1.25rem;font-weight:700;text-align:center}
.lightbox-close{position:fixed;top:16px;right:20px;background:rgba(0,0,0,.5);border:1px solid var(--line);color:var(--gold);font-size:2rem;line-height:1;cursor:pointer;width:48px;height:48px;border-radius:999px;display:grid;place-items:center}
.lightbox-close:hover{color:#fff1b8;background:rgba(0,0,0,.75)}
.lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.5);border:1px solid var(--line);color:var(--gold);font-size:2.4rem;line-height:1;cursor:pointer;width:54px;height:54px;border-radius:999px;display:grid;place-items:center;padding-bottom:4px}
.lightbox-nav:hover{color:#fff1b8;background:rgba(0,0,0,.75)}
.lightbox-prev{left:18px}
.lightbox-next{right:18px}
@media (max-width:620px){.lightbox-nav{width:46px;height:46px;font-size:2rem}.lightbox-prev{left:8px}.lightbox-next{right:8px}.lightbox-close{top:10px;right:10px}.lightbox-caption{font-size:1.05rem}}
