/* =========================================================
   WHY NOT? POKER NIGHT × FONTAINEBLEAU LAS VEGAS
   Private Registration — brand system per Fontainebleau
   Global Brand Style Guide (colors, type, centered rules)
   ========================================================= */
/* ---- Brand fonts (self-hosted): Agenda (headings) + Avenir (body) ---- */
@font-face{
  font-family:'Agenda';
  src:url('assets/fonts/agendabold.woff2') format('woff2'),
      url('assets/fonts/agendabold.woff') format('woff');
  font-weight:100 900;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:'Avenir';
  src:url('assets/fonts/Avenir-Regular.woff') format('woff');
  font-weight:400;
  font-style:normal;
  font-display:swap;
}

:root{
  /* ---- Brand palette (exact from style guide) ---- */
  --navy:#0A203D;          /* FB Blue / Pantone 296C — primary */
  --navy-deep:#041021;     /* Pantone BLK 6C */
  --navy-mid:#233962;      /* Pantone 534C */
  --royal:#254580;         /* Pantone 7687C */
  --blue-soft:#4C7BB7;     /* Pantone 660U */
  --blue-light:#D7E1EA;    /* Pantone 649U */
  --gold:#89764A;          /* FB Gold / Pantone 871C */
  --gold-alt:#8C734B;      /* Pantone 872C */
  --gold-bright:#B6A06E;   /* lightened gold for text/lines on dark */
  --gray:#54565b;          /* FB Gray / Cool Gray 11C */
  --ivory:#F1ECE0;
  --ivory-dim:#cfc8b8;
  --paper:#FBF9F4;
  --white:#ffffff;

  --line:rgba(241,236,224,0.16);
  --line-strong:rgba(182,160,110,0.55);
  --line-navy:rgba(10,32,61,0.14);

  --display:'Agenda', 'Century Gothic', sans-serif;   /* brand heading font */
  --body:'Avenir', 'Segoe UI', sans-serif;            /* brand body font */

  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--navy-deep);
  color:var(--ivory);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--gold);color:var(--navy-deep)}

/* ---------- shared type ---------- */
/* Headlines: Agenda → Jost, ALL CAPS, wide tracking, centered (brand rule) */
.eyebrow{
  font-family:var(--display);
  font-weight:500;
  font-size:.72rem;
  letter-spacing:.42em;
  text-transform:uppercase;
  color:var(--gold-bright);
}
.display{
  font-family:var(--display);
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:.22em;
  line-height:1.08;
  color:var(--ivory);
}
.serif-accent{ font-style:italic; }
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
.center{text-align:center}

/* hairline + bowtie divider */
.rule{display:flex;align-items:center;justify-content:center;gap:18px;margin:0 auto}
.rule .seg{height:1px;width:64px;background:linear-gradient(90deg,transparent,var(--gold-bright))}
.rule .seg.r{background:linear-gradient(90deg,var(--gold-bright),transparent)}
.rule img{height:16px;width:auto;opacity:.95}

/* ============ NAV ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 44px;
  transition:background .45s ease, padding .45s ease, border-color .45s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(4,16,33,0.88);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);
  padding:14px 44px;
}
.nav-logo{height:52px;width:auto}
.nav-mid{display:flex;align-items:center;gap:36px}
.nav-mid a{
  font-family:var(--display);
  font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;font-weight:400;
  color:var(--ivory-dim);transition:color .25s;
}
.nav-mid a:hover{color:var(--ivory)}
.nav-cta{
  font-family:var(--display);
  font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;font-weight:500;
  color:var(--navy-deep);background:var(--gold);
  padding:12px 26px;border-radius:1px;transition:background .3s, transform .3s;
}
.nav-cta:hover{background:var(--gold-bright);transform:translateY(-1px)}
@media(max-width:860px){.nav-mid a{display:none}.nav{padding:16px 22px}}

/* ============ HERO ============ */
.hero{
  position:relative;min-height:100vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;background:var(--navy-deep);
  padding:104px 24px 80px;
}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 50%}
.hero-veil{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 95% at 50% 42%, rgba(4,16,33,0.46) 0%, rgba(4,16,33,0.64) 55%, rgba(4,16,33,0.90) 100%),
    linear-gradient(180deg, rgba(4,16,33,0.60) 0%, rgba(4,16,33,0.20) 30%, rgba(4,16,33,0.52) 70%, var(--navy-deep) 100%);
}
.hero-inner{position:relative;z-index:3;max-width:920px}
.hero-slider .hero-inner::before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:150%;height:128%;z-index:-1;pointer-events:none;background:radial-gradient(closest-side, rgba(4,16,33,0.66) 0%, rgba(4,16,33,0.34) 58%, rgba(4,16,33,0) 100%)}
.hero-collab{display:flex;align-items:center;justify-content:center;gap:38px;margin:0 auto 56px}
.hero-collab img{height:74px;width:auto;opacity:1;filter:drop-shadow(0 2px 16px rgba(0,0,0,0.78))}
.hero-collab .collab-mark{height:74px}
.hero-collab .collab-divider{width:1px;height:64px;background:var(--line-strong)}
@media(max-width:560px){.hero-collab{gap:26px}.hero-collab img,.hero-collab .collab-mark{height:52px}.hero-collab .collab-divider{height:46px}}
.hero-eyebrow{margin:22px 0 0}
.hero h1{
  font-family:var(--display);font-weight:300;
  font-size:clamp(2.6rem,6.4vw,5.4rem);line-height:1.02;
  letter-spacing:.16em;text-transform:uppercase;color:var(--white);
  text-shadow:0 2px 30px rgba(4,16,33,0.7), 0 1px 4px rgba(0,0,0,0.45);
}
.hero h1 .h1-pre{display:block;font-size:.34em;font-weight:400;letter-spacing:.42em;color:var(--ivory);margin-bottom:.7em;text-shadow:0 1px 12px rgba(0,0,0,0.55)}
.hero h1 strong{font-weight:600;color:#CDB67E}
.hero-host{
  margin-top:26px;display:flex;flex-direction:column;align-items:center;gap:12px;
}
.hero-host .hh-label{
  font-family:var(--display);
  font-size:.66rem;letter-spacing:.36em;text-transform:uppercase;
  color:var(--ivory-dim);font-weight:400;
}
.hero-host img{height:42px;width:auto;opacity:.96}
.hero-meta{
  margin-top:34px;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;
  gap:.5rem 1.6rem;font-family:var(--display);
  font-size:1.12rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-bright);font-weight:400;
  text-shadow:0 2px 14px rgba(0,0,0,0.6);
}
.hero-meta .dot{opacity:.6}
.hero-rule{margin:30px auto 30px}
.hero-actions{display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:center}
/* ---- Mobile hero: declutter, stack meta, scroll cue, no slider controls ---- */
.hero-scroll-cue{display:none;position:absolute;left:50%;bottom:24px;transform:translateX(-50%);z-index:6;flex-direction:column;align-items:center;gap:6px;color:var(--gold-bright);pointer-events:none}
.hero-scroll-cue .chev{width:12px;height:12px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);animation:scrollCue 1.8s ease-in-out infinite}
@keyframes scrollCue{0%,100%{opacity:.35;transform:rotate(45deg) translate(-2px,-2px)}50%{opacity:1;transform:rotate(45deg) translate(2px,2px)}}
@media(max-width:600px){
  .hero-slider{padding:96px 22px 92px}
  .hero-collab{margin:0 auto 34px;gap:22px}
  .hero h1{font-size:clamp(2.2rem,8.6vw,3.1rem);letter-spacing:.09em;line-height:1.08}
  .hero h1 .h1-pre{font-size:.42em;letter-spacing:.32em;margin-bottom:1em}
  .hero-rule{margin:22px auto}
  .hero-meta{margin-top:26px;flex-direction:column;gap:13px;font-size:.92rem;letter-spacing:.18em}
  .hero-meta .dot{display:none}
  .hero-actions{display:none!important}
  .hero-slider .garrow{display:none!important}
  .gallery .garrow{display:none!important}
  .hero-dots{display:none!important}
  .hero-scroll-cue{display:flex}
}
.scroll-hint{
  position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;
  font-family:var(--display);
  font-size:.6rem;letter-spacing:.36em;text-transform:uppercase;color:var(--ivory-dim);
  display:flex;flex-direction:column;align-items:center;gap:9px;opacity:.7;
}
.scroll-hint .bar{width:1px;height:40px;background:linear-gradient(var(--gold-bright),transparent);animation:drip 2.6s ease-in-out infinite}
@keyframes drip{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ============ buttons ============ */
.btn{
  display:inline-flex;align-items:center;gap:.8em;
  font-family:var(--display);font-size:.76rem;letter-spacing:.26em;text-transform:uppercase;font-weight:500;
  padding:17px 34px;border-radius:1px;transition:transform .3s, background .3s, color .3s, border-color .3s;
}
.btn-primary{background:var(--gold);color:var(--navy-deep)}
.btn-primary:hover{background:var(--gold-bright);transform:translateY(-2px)}
.btn-ghost{border:1px solid var(--line-strong);color:var(--ivory)}
.btn-ghost:hover{border-color:var(--gold-bright);color:var(--gold-bright)}
.btn .arrow{transition:transform .3s}
.btn:hover .arrow{transform:translateX(4px)}

/* ============ INVITATION (welcome) ============ */
.invite{position:relative;background:var(--navy);padding:130px 0 120px;text-align:center;overflow:hidden}
.invite .bg-bowtie{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:min(760px,84vw);opacity:.04;pointer-events:none;
}
.invite-inner{position:relative;z-index:2;max-width:760px;margin:0 auto}
.invite h2{
  font-family:var(--display);font-weight:300;
  font-size:clamp(1.9rem,4vw,3.1rem);letter-spacing:.12em;text-transform:uppercase;
  color:var(--ivory);line-height:1.15;margin:26px 0 30px;
}
.invite h2 strong{color:var(--gold-bright);font-weight:500}
.invite p{
  font-size:1.08rem;line-height:1.95;color:var(--blue-light);font-weight:300;
  max-width:62ch;margin:0 auto 1.5rem;letter-spacing:.012em;
}
.invite p:last-child{margin-bottom:0}

/* ============ VENUE bands ============ */
.band{position:relative;min-height:78vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.band-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.band-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(4,16,33,0.62),rgba(4,16,33,0.40) 45%,rgba(4,16,33,0.72))}
.band-veil.light{background:linear-gradient(180deg,rgba(241,236,224,0.30),rgba(241,236,224,0.10) 45%,rgba(241,236,224,0.42))}
.band-inner{position:relative;z-index:2;max-width:760px;padding:90px 40px}
.band h3{
  font-family:var(--display);font-weight:300;
  font-size:clamp(1.8rem,4vw,3rem);letter-spacing:.16em;text-transform:uppercase;line-height:1.12;
  margin:24px 0 24px;
}
.band p{font-size:1.05rem;line-height:1.85;font-weight:300;max-width:54ch;margin:0 auto;letter-spacing:.012em}
.band.dark h3{color:var(--white)} .band.dark p{color:var(--blue-light)}
.band.dark .eyebrow{color:var(--gold-bright)}

/* ============ DETAILS ============ */
.details{position:relative;background:var(--navy-deep);padding:120px 0;text-align:center}
.details-head{margin-bottom:64px}
.details-head h2{
  font-family:var(--display);font-weight:300;
  font-size:clamp(2rem,4.6vw,3.2rem);letter-spacing:.18em;text-transform:uppercase;color:var(--ivory);
  margin-top:22px;
}
.details-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.dcell{background:var(--navy-deep);padding:44px 26px;display:flex;flex-direction:column;align-items:center;gap:14px;transition:background .4s ease;cursor:default}
.dcell:hover{background:var(--gold)}
.dcell .k{font-family:var(--display);font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-bright);transition:color .4s ease}
.dcell .v{font-family:var(--display);font-weight:300;font-size:1.5rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ivory);line-height:1.2;transition:color .4s ease}
.dcell .s{font-size:.86rem;color:var(--blue-light);font-weight:300;letter-spacing:.02em;transition:color .4s ease}
.dcell:hover .k,.dcell:hover .v,.dcell:hover .s{color:var(--navy-deep)}
@media(max-width:880px){.details-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.details-grid{grid-template-columns:1fr}}

/* ============ REGISTER ============ */
.register{position:relative;background:var(--navy);padding:120px 0 130px;overflow:hidden}
.register .bg-bowtie{position:absolute;right:-8%;top:8%;width:min(560px,60vw);opacity:.035;pointer-events:none}
.reg-head{position:relative;z-index:2;text-align:center;max-width:680px;margin:0 auto 56px}
.reg-head h2{font-family:var(--display);font-weight:300;font-size:clamp(2.1rem,5vw,3.4rem);letter-spacing:.16em;text-transform:uppercase;color:var(--ivory);margin:22px 0 22px}
.reg-head p{color:var(--blue-light);font-size:1.04rem;line-height:1.8;font-weight:300}

/* invitation gate banner */
.gate{
  position:relative;z-index:2;max-width:720px;margin:0 auto 30px;
  display:flex;align-items:center;justify-content:center;gap:14px;
  border:1px solid var(--line-strong);background:rgba(137,118,74,0.08);
  padding:16px 24px;border-radius:1px;
  font-family:var(--display);font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-bright);
}
.gate img{height:14px;width:auto}

/* tier cards */
.tiers{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1060px;margin:0 auto 26px}
.tier{
  position:relative;text-align:center;border:1px solid var(--line);background:rgba(255,255,255,0.018);
  padding:40px 30px 32px;border-radius:2px;transition:border-color .3s, background .3s, transform .3s;
  display:flex;flex-direction:column;align-items:center;
}
.tier:hover{border-color:var(--line-strong);transform:translateY(-3px)}
.tier.sel{border-color:var(--gold-bright);background:rgba(137,118,74,0.10)}
.tier-name{font-family:var(--display);font-size:.74rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-bright);font-weight:500}
.tier-price{font-family:var(--display);font-weight:300;font-size:2.9rem;letter-spacing:.04em;color:var(--ivory);margin:18px 0 4px}
.tier-price .cur{font-size:1.2rem;vertical-align:super;color:var(--ivory-dim)}
.tier-unit{font-size:.8rem;color:var(--blue-light);font-weight:300;letter-spacing:.04em}
.tier-divider{width:40px;height:1px;background:var(--line-strong);margin:22px 0}
.tier-list{list-style:none;display:flex;flex-direction:column;gap:12px;width:100%}
.tier-list li{font-size:.9rem;color:var(--blue-light);line-height:1.5;font-weight:300;letter-spacing:.01em}
.tier-pick{margin-top:auto;padding-top:26px;display:flex;align-items:center;gap:10px;font-family:var(--display);font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ivory);font-weight:500}
.tier-radio{width:16px;height:16px;border-radius:50%;border:1.5px solid var(--line-strong);transition:all .25s;position:relative}
.tier.sel .tier-radio{border-color:var(--gold-bright)}
.tier.sel .tier-radio::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--gold-bright)}
@media(max-width:880px){.tiers{grid-template-columns:1fr;max-width:460px}}

/* form panel */
.reg-form{
  position:relative;z-index:2;max-width:860px;margin:30px auto 0;
  border:1px solid var(--line);background:rgba(4,16,33,0.55);backdrop-filter:blur(6px);
  border-radius:2px;padding:52px 52px 46px;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-bottom:26px}
.form-row.one{grid-template-columns:1fr}
.field{display:flex;flex-direction:column;gap:9px;text-align:left}
.field label{font-family:var(--display);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-bright);font-weight:500}
.field label .req{color:var(--blue-soft)}
.field input,.field select,.field textarea{
  font-family:var(--body);font-size:1rem;color:var(--ivory);font-weight:300;
  background:transparent;border:none;border-bottom:1px solid var(--line-strong);
  padding:11px 0;transition:border-color .25s;letter-spacing:.01em;
}
.field input::placeholder,.field textarea::placeholder{color:rgba(215,225,234,0.35)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-bottom-color:var(--gold-bright)}
.field select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23B6A06E' stroke-width='1.4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 2px center}
.field select option{background:var(--navy);color:var(--ivory)}
.field textarea{resize:vertical;min-height:82px}
.field.err input,.field.err select,.field.err textarea{border-bottom-color:#c97b6a}
.field .msg{font-size:.72rem;color:#d98e7d;letter-spacing:.03em;min-height:0;font-weight:400}

/* invitation code field — emphasized */
.field.code input{font-family:var(--display);letter-spacing:.5em;text-transform:uppercase;font-size:1.15rem;text-align:center;border:1px solid var(--line-strong);padding:14px;border-radius:1px}
.field.code input:focus{border-color:var(--gold-bright)}
.field.code label{text-align:center}

/* qty stepper */
.stepper{display:flex;align-items:center;border-bottom:1px solid var(--line-strong);width:fit-content}
.stepper button{width:42px;height:46px;font-size:1.3rem;color:var(--gold-bright);transition:color .2s}
.stepper button:hover{color:var(--ivory)}
.stepper button:disabled{color:var(--gray);cursor:not-allowed}
.stepper .num{width:58px;text-align:center;font-family:var(--display);font-weight:300;font-size:1.6rem;color:var(--ivory)}

/* summary + submit */
.reg-foot{display:flex;align-items:center;justify-content:space-between;gap:30px;margin-top:38px;padding-top:32px;border-top:1px solid var(--line);flex-wrap:wrap}
.summary{text-align:left}
.summary .sl{font-family:var(--display);font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-bright)}
.summary .st{font-family:var(--display);font-weight:300;font-size:2.3rem;color:var(--ivory);margin-top:8px;line-height:1}
.summary .st .cur{font-size:1.1rem;vertical-align:super;color:var(--ivory-dim)}
.summary .sd{font-size:.84rem;color:var(--blue-light);margin-top:8px;font-weight:300}
@media(max-width:680px){.reg-form{padding:36px 24px}.form-row{grid-template-columns:1fr;gap:24px}.reg-foot{justify-content:center;text-align:center}.summary{text-align:center}}

/* ============ CONFIRMATION ============ */
.confirm-overlay{
  position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;
  background:rgba(4,16,33,0.90);backdrop-filter:blur(12px);padding:30px;
  opacity:0;pointer-events:none;transition:opacity .5s;
}
.confirm-overlay.show{opacity:1;pointer-events:auto}
.confirm-card{
  position:relative;max-width:560px;width:100%;text-align:center;
  background:var(--navy);border:1px solid var(--line-strong);border-radius:3px;
  padding:60px 52px 52px;overflow:hidden;
  transform:translateY(24px) scale(.98);transition:transform .55s cubic-bezier(.2,.8,.2,1);
}
.confirm-overlay.show .confirm-card{transform:translateY(0) scale(1)}
.confirm-bowtie{height:40px;width:auto;margin:0 auto 24px;animation:rise .7s cubic-bezier(.2,.8,.2,1) both}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.confirm-card h3{font-family:var(--display);font-weight:300;font-size:2.2rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ivory);line-height:1.1;margin-bottom:18px}
.confirm-card p{color:var(--blue-light);font-size:1rem;line-height:1.75;margin-bottom:8px;font-weight:300}
.confirm-card .em{color:var(--gold-bright)}
.confirm-close{margin-top:30px}
.confirm-x{position:absolute;top:18px;right:22px;font-size:1.3rem;color:var(--ivory-dim);z-index:3;transition:color .2s}
.confirm-x:hover{color:var(--ivory)}

/* ============ FOOTER ============ */
.footer{position:relative;background:var(--navy-deep);padding:80px 0 44px;border-top:1px solid var(--line);text-align:center}
.footer-lockup{display:flex;align-items:center;justify-content:center;gap:56px;flex-wrap:wrap}
.footer-lockup img{height:54px;width:auto;opacity:.95}
.footer-x{font-family:var(--display);font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ivory-dim);font-weight:400}
.footer-partner{margin-top:26px;font-family:var(--display);font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ivory-dim)}
.footer-mission{max-width:600px;margin:26px auto 0;font-size:.96rem;line-height:1.7;color:var(--blue-light);font-weight:300}
.footer-meta{margin-top:72px;padding:0 48px;display:flex;align-items:center;justify-content:space-between;gap:22px 32px;flex-wrap:wrap;font-family:var(--display);font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(215,225,234,0.45)}
.footer-meta .fm-left{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.footer-meta .fm-left span{color:var(--gray)}
.footer-meta .fm-sep{opacity:.6}
.footer-meta .fm-top{display:inline-flex;align-items:center;gap:11px;color:var(--ivory-dim);cursor:pointer;transition:color .25s}
.footer-meta .fm-top:hover{color:var(--gold-bright)}
.footer-meta .fm-top .fm-arrow{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--line-strong);border-radius:50%;font-size:.85rem;transition:border-color .25s,color .25s,transform .25s}
.footer-meta .fm-top:hover .fm-arrow{border-color:var(--gold-bright);transform:translateY(-2px)}
@media(max-width:620px){.footer-meta{justify-content:center;text-align:center}.footer-meta .fm-left{justify-content:center}}

/* ============ POKER ELEMENTS ============ */
.suit-rule{display:flex;align-items:center;justify-content:center;gap:0;margin:0 auto}
.suit-rule .seg{height:1px;width:52px;background:linear-gradient(90deg,transparent,var(--gold-bright))}
.suit-rule .seg.r{background:linear-gradient(90deg,var(--gold-bright),transparent)}
.suit-rule .suit{font-size:.92rem;color:var(--gold-bright);line-height:1}
.suit-rule .suit.mid{opacity:.82}
.suit-rule.head-rule{margin:20px auto 26px}
.hero-rule{margin:30px auto 30px}

/* tier crest */
.tier-crest{font-size:1.25rem;color:var(--gold-bright);margin-bottom:14px;line-height:1;letter-spacing:.1em}

/* ============ PILLARS (hover-gold boxes) ============ */
.pillars{position:relative;z-index:2;margin:84px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pillar{border:1px solid var(--line);background:rgba(255,255,255,0.015);padding:44px 32px;text-align:center;transition:background .4s ease, border-color .4s ease, transform .4s ease;cursor:default}
.pillar:hover{background:var(--gold);border-color:var(--gold);transform:translateY(-5px)}
.pillar .p-suit{font-size:1.5rem;color:var(--gold-bright);line-height:1;margin-bottom:18px;transition:color .4s ease}
.pillar .p-title{font-family:var(--display);font-weight:400;font-size:1.05rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ivory);margin-bottom:14px;transition:color .4s ease}
.pillar .p-desc{font-size:.96rem;line-height:1.65;font-weight:300;color:var(--blue-light);max-width:30ch;margin:0 auto;transition:color .4s ease}
.pillar:hover .p-suit,.pillar:hover .p-title,.pillar:hover .p-desc{color:var(--navy-deep)}
@media(max-width:760px){.pillars{grid-template-columns:1fr;gap:16px;margin-top:60px}}

/* ============ VENUE TEASER ============ */
.venue-teaser{position:relative;background:var(--navy-deep);padding:120px 0;text-align:center;overflow:hidden}
.venue-teaser .bg-suit{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-54%);
  font-size:46vmin;line-height:1;color:rgba(182,160,110,0.045);pointer-events:none;font-family:Georgia,serif;
}
.venue-teaser-inner{position:relative;z-index:2;max-width:700px;margin:0 auto}
.venue-teaser h2{font-family:var(--display);font-weight:300;font-size:clamp(2rem,4.6vw,3.2rem);letter-spacing:.16em;text-transform:uppercase;color:var(--ivory);margin:0 0 24px}
.venue-teaser p{color:var(--blue-light);font-size:1.06rem;line-height:1.85;font-weight:300;max-width:52ch;margin:0 auto 38px}

/* ============ INLINE GALLERY ============ */
.gallery{position:relative;height:min(90vh,800px);min-height:560px;overflow:hidden;background:var(--navy-deep)}
.gallery .gslide{position:absolute;inset:0;opacity:0;transition:opacity 1.3s ease;will-change:opacity}
.gallery .gslide.active{opacity:1;z-index:1}
.gallery .gslide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.06)}
.gallery .gslide.active img{animation:kb 9s ease-out both}
.gallery .gslide.active.k0 img{animation-name:kb0}
.gallery .gslide.active.k1 img{animation-name:kb1}
.gallery .gslide.active.k2 img{animation-name:kb2}
.gallery .gslide.active.k3 img{animation-name:kb3}
@keyframes kb0{from{transform:scale(1.04) translate(0,0)}to{transform:scale(1.16) translate(-2%,-2%)}}
@keyframes kb1{from{transform:scale(1.16) translate(2%,1%)}to{transform:scale(1.04) translate(0,0)}}
@keyframes kb2{from{transform:scale(1.05) translate(-1%,1%)}to{transform:scale(1.17) translate(2%,-2%)}}
@keyframes kb3{from{transform:scale(1.15) translate(0,-2%)}to{transform:scale(1.05) translate(-2%,1%)}}
.gallery .gveil{position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(180deg,rgba(4,16,33,0.55) 0%,rgba(4,16,33,0.08) 28%,rgba(4,16,33,0.20) 56%,rgba(4,16,33,0.85) 100%)}
.gallery .gcap{position:absolute;left:0;right:0;bottom:96px;z-index:5;text-align:center;padding:0 30px}
.gallery .gcap .eyebrow{display:block;margin-bottom:16px}
.gallery .gcap .suit-rule{margin:0 auto 18px}
.gallery .gcap h2{font-family:var(--display);font-weight:300;font-size:clamp(2rem,5vw,3.6rem);letter-spacing:.14em;text-transform:uppercase;color:#fff;line-height:1.05;margin:0}
.gallery .gcap p{font-family:var(--body);font-weight:300;font-size:clamp(.98rem,1.8vw,1.2rem);letter-spacing:.04em;color:var(--blue-light);margin:15px auto 0;max-width:46ch}
.gallery .gcap .eyebrow,.gallery .gcap .suit-rule,.gallery .gcap h2,.gallery .gcap p{opacity:1}
.gallery .gcap.in .eyebrow{animation:capIn .7s .10s ease both}
.gallery .gcap.in .suit-rule{animation:capIn .7s .20s ease both}
.gallery .gcap.in h2{animation:capIn .8s .30s ease both}
.gallery .gcap.in p{animation:capIn .8s .42s ease both}
@keyframes capIn{from{opacity:0;transform:translateY(13px)}to{opacity:1;transform:none}}
.gallery .garrow{position:absolute;top:50%;transform:translateY(-50%);z-index:6;width:56px;height:56px;border:1px solid var(--line-strong);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ivory);font-size:1.15rem;background:rgba(4,16,33,0.25);backdrop-filter:blur(4px);transition:all .3s}
.gallery .garrow:hover{border-color:var(--gold-bright);color:var(--gold-bright);background:rgba(4,16,33,0.5)}
.gallery .garrow.prev{left:30px}.gallery .garrow.next{right:30px}
.gallery .gdots{position:absolute;left:0;right:0;bottom:46px;z-index:6;display:flex;align-items:center;justify-content:center;gap:14px}
.gallery .gdot{width:42px;height:2px;background:rgba(241,236,224,0.22);cursor:pointer;transition:background .3s;padding:0;border-radius:0}
.gallery .gdot.active{background:var(--gold-bright)}
@media(max-width:680px){.gallery .garrow{width:46px;height:46px}.gallery .garrow.prev{left:14px}.gallery .garrow.next{right:14px}.gallery .gcap{bottom:108px}}
@media(prefers-reduced-motion:reduce){.gallery .gslide.active img{animation:none}.gallery .gslide{transition:opacity .3s}}

/* ============ HERO SLIDER ============ */
.hero-slider{position:relative;padding:104px 24px 112px}
.hero-slider .hs-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.3s ease;z-index:0;will-change:opacity}
.hero-slider .hs-slide.active{opacity:1;z-index:1}
.hero-slider .hs-slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.04);transition:transform 8s ease-out}
.hero-slider .hs-slide.active img{transform:scale(1.14)}
.hero-slider .hs-slide:first-child img{object-position:50% 68%}
.hero-slider .hero-veil{z-index:2}
.hero-slider .hero-inner{z-index:3;width:100%}
.hero-slider .hs-cap.in{animation:capIn .85s ease both}
.hs-venue{display:flex;flex-direction:column;align-items:center}
.hs-title{font-family:var(--display);font-weight:300;font-size:clamp(2.2rem,5.6vw,4.4rem);letter-spacing:.14em;text-transform:uppercase;color:#fff;line-height:1.04;margin:0}
.hs-sub{font-family:var(--body);font-weight:300;font-size:clamp(1rem,2vw,1.3rem);letter-spacing:.04em;color:var(--blue-light);margin:16px auto 26px;max-width:46ch}
.hero-slider .garrow{position:absolute;top:50%;transform:translateY(-50%);z-index:6;width:56px;height:56px;border:1px solid var(--line-strong);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ivory);font-size:1.15rem;background:rgba(4,16,33,0.22);backdrop-filter:blur(4px);transition:all .3s}
.hero-slider .garrow:hover{border-color:var(--gold-bright);color:var(--gold-bright);background:rgba(4,16,33,0.5)}
.hero-slider .garrow.prev{left:30px}.hero-slider .garrow.next{right:30px}
.hero-dots{position:absolute;left:0;right:0;bottom:40px;z-index:6;display:flex;align-items:center;justify-content:center;gap:14px}
.hero-dots .gdot{width:42px;height:2px;background:rgba(241,236,224,0.24);cursor:pointer;transition:background .3s;padding:0;border:none;border-radius:0}
.hero-dots .gdot.active{background:var(--gold-bright)}
@media(max-width:680px){.hero-slider .garrow{width:46px;height:46px}.hero-slider .garrow.prev{left:12px}.hero-slider .garrow.next{right:12px}}
@media(prefers-reduced-motion:reduce){.hero-slider .hs-slide.active img{transform:none;transition:none}.hero-slider .hs-slide{transition:opacity .3s}}

/* ============ INVITATION IMAGE LAYOUT ============ */
.venue-sec{background:var(--navy-deep);border-top:1px solid var(--line)}
.invite-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.invite-photo{align-self:center}
.invite-photo img{width:100%;height:560px;object-fit:cover;border:1px solid var(--line-strong);display:block}
.invite-content{text-align:left}
.invite-content .head-rule{justify-content:flex-start;margin:20px 0 26px}
.invite-content p{text-align:left;margin:0 0 1.4rem;max-width:52ch}
.invite-content p:last-child{margin-bottom:0}
@media(max-width:860px){.invite-grid{grid-template-columns:1fr;gap:40px}.invite-photo img{height:320px}.invite-content{text-align:center}.invite-content .head-rule{justify-content:center;margin:20px auto 26px}.invite-content p{text-align:center;margin-left:auto;margin-right:auto}}

/* ============ POKER LOADER ============ */
#loader{position:fixed;inset:0;z-index:99999;background:radial-gradient(120% 100% at 50% 42%, #0c2746 0%, var(--navy-deep) 72%);display:flex;align-items:center;justify-content:center;transition:opacity .7s ease, visibility .7s}
#loader.hide{opacity:0;visibility:hidden;pointer-events:none}
.loader-inner{display:flex;flex-direction:column;align-items:center;gap:44px}
.loader-logo{height:62px;width:auto;opacity:.98;filter:drop-shadow(0 2px 16px rgba(0,0,0,0.6));animation:loaderLogoIn 1s ease both}
@keyframes loaderLogoIn{from{opacity:0;transform:translateY(10px)}to{opacity:.98;transform:none}}
.deal{position:relative;width:240px;height:96px}
.deal .card{
  position:absolute;left:50%;top:8px;width:58px;height:82px;margin-left:-29px;
  border:1px solid var(--gold-bright);border-radius:7px;background:linear-gradient(160deg, rgba(20,32,61,0.92), rgba(8,18,34,0.92));
  display:flex;align-items:center;justify-content:center;font-family:Georgia,serif;font-size:1.85rem;color:var(--gold-bright);
  box-shadow:0 10px 26px rgba(0,0,0,0.5);opacity:0;transform-origin:bottom center;
  animation:deal 3.8s cubic-bezier(.2,.8,.2,1) infinite;
}
.deal .c1{--x:-78px;--r:-19deg;animation-delay:0s}
.deal .c2{--x:-26px;--r:-6deg;animation-delay:.24s}
.deal .c3{--x:26px;--r:6deg;animation-delay:.48s}
.deal .c4{--x:78px;--r:19deg;animation-delay:.72s}
@keyframes deal{
  0%{opacity:0;transform:translate(0,30px) rotate(0deg) scale(.86)}
  12%{opacity:1}
  34%,82%{opacity:1;transform:translate(var(--x),0) rotate(var(--r)) scale(1)}
  100%{opacity:0;transform:translate(var(--x),-8px) rotate(var(--r)) scale(1)}
}
.loader-label{display:none}
.loader-label{font-family:var(--display);font-weight:400;font-size:.82rem;letter-spacing:.42em;text-transform:uppercase;color:var(--gold-bright);white-space:nowrap}
.loader-label::after{content:"....";display:inline-block;width:0;animation:dots 1.4s steps(4) infinite;overflow:hidden;vertical-align:bottom;letter-spacing:.1em}
@keyframes dots{to{width:1.4em}}
@media(prefers-reduced-motion:reduce){.deal .card{animation-duration:.01s;opacity:1;transform:translate(var(--x),0) rotate(var(--r))}.loader-label::after{display:none}}

/* reveal-on-scroll */
.reveal{opacity:0;transform:scale(.99);filter:blur(7px);transition:opacity 1s cubic-bezier(.16,.72,.24,1), transform 1.15s cubic-bezier(.16,.72,.24,1), filter 1s ease}
.reveal.in{opacity:1;transform:none;filter:blur(0)}
.reveal.in > *{animation:revealRise .9s cubic-bezier(.16,.72,.24,1) both}
.reveal.in > *:nth-child(2){animation-delay:.09s}
.reveal.in > *:nth-child(3){animation-delay:.18s}
.reveal.in > *:nth-child(4){animation-delay:.27s}
.reveal.in > *:nth-child(5){animation-delay:.36s}
@keyframes revealRise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;filter:none;transition:none}.reveal.in > *{animation:none}.scroll-hint .bar{animation:none}}
