/* ===== TTC design system — shared across all pages (toptorontoclubs.com rebuild) ===== */
:root{
  --bg:#070809;--green:#4ade2f;--green-soft:#86f06a;--green-deep:#1f7a16;
  --text:#f4f6f4;--muted:#9aa39a;--faint:#6b736b;--radius:22px;--maxw:1280px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Sora',system-ui,sans-serif;background:var(--bg);color:var(--text);
  -webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative;line-height:1.5}
a{color:inherit;text-decoration:none}
button,.cta,.btn-ghost,.gl-login,.segment button,.stepper button{touch-action:manipulation;-webkit-tap-highlight-color:transparent}
img{max-width:100%}
.aurora{position:fixed;inset:0;z-index:-2;overflow:hidden;background:radial-gradient(120% 90% at 50% -10%,#0d130c 0%,var(--bg) 55%)}
.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;mix-blend-mode:screen;
  background:radial-gradient(circle,var(--green) 0%,var(--green-deep) 45%,transparent 70%);animation:drift 28s ease-in-out infinite}
.blob.b1{width:680px;height:680px;top:-180px;left:-140px}
.blob.b2{width:540px;height:540px;top:46%;right:-180px;opacity:.38;animation-delay:-9s}
.blob.b3{width:760px;height:760px;bottom:-320px;left:32%;opacity:.32;animation-delay:-16s}
@keyframes drift{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(70px,40px) scale(1.08)}66%{transform:translate(-40px,30px) scale(.95)}}
/* muted background for content/info pages (home page stays vivid) */
body.dim .aurora{background:radial-gradient(120% 90% at 50% -10%,#090c09 0%,var(--bg) 48%)}
body.dim .aurora .blob{opacity:.16}
body.dim .aurora .blob.b1{opacity:.18}
.grain{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
/* liquid glass (subtle, real — never a corny bright stripe) */
.glass{position:relative;isolation:isolate;
  background:linear-gradient(155deg,rgba(255,255,255,.07) 0%,rgba(255,255,255,.022) 50%,rgba(255,255,255,.042) 100%);
  backdrop-filter:blur(26px) saturate(170%) brightness(1.02);-webkit-backdrop-filter:blur(26px) saturate(170%) brightness(1.02);
  border:1px solid rgba(255,255,255,.085);border-radius:var(--radius);
  box-shadow:0 18px 50px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.09),inset 0 -22px 48px -32px rgba(0,0,0,.55)}
.glass::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:-1;
  background:linear-gradient(160deg,rgba(255,255,255,.055) 0%,transparent 34%)}
/* darker-tinted glass (Apple Pay / system sheet look) — translucent + frosted */
.glass-dark{position:relative;isolation:isolate;
  background:linear-gradient(165deg,rgba(34,38,34,.55) 0%,rgba(14,17,14,.62) 100%);
  backdrop-filter:blur(44px) saturate(180%) brightness(1.06);-webkit-backdrop-filter:blur(44px) saturate(180%) brightness(1.06);
  border:1px solid rgba(255,255,255,.13);border-radius:var(--radius);
  box-shadow:0 28px 70px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.1),inset 0 -30px 60px -40px rgba(0,0,0,.5)}
.glass-dark::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:-1;
  background:linear-gradient(160deg,rgba(255,255,255,.06) 0%,transparent 32%)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.narrow{max-width:820px;margin:0 auto;padding:0 26px}
/* nav */
nav.top{position:sticky;top:14px;z-index:60;margin:14px auto 0;max-width:var(--maxw);padding:0 14px}
.navbar{display:flex;align-items:center;gap:16px;padding:11px 12px 11px 22px;border-radius:60px}
.brand{font-weight:800;letter-spacing:-.02em;font-size:18px;display:flex;align-items:center;gap:9px;white-space:nowrap}
.brand .logo{height:30px;width:auto;display:block}
.brand-fallback{display:flex;align-items:center;gap:9px}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 16px var(--green)}
.navlinks{display:flex;gap:4px;margin-left:8px}
.navlinks a{color:var(--muted);font-size:14px;font-weight:500;padding:8px 13px;border-radius:30px;transition:.18s}
.navlinks a:hover{color:var(--text);background:rgba(255,255,255,.07)}
.navbar .cta{margin-left:auto}
.cta{background:var(--green);color:#06210a;font-weight:700;padding:11px 20px;border-radius:30px;font-size:14px;
  box-shadow:0 6px 24px rgba(74,222,47,.32);transition:.18s;white-space:nowrap;display:inline-flex;align-items:center;gap:7px;cursor:pointer;border:none}
.cta:hover{transform:translateY(-1px);box-shadow:0 10px 30px rgba(74,222,47,.5)}
.cta svg{width:15px;height:15px}
.t-short{display:none}
.user-ava{width:38px;height:38px;flex:0 0 38px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:15px;color:#06210a;background:linear-gradient(180deg,#84f266,#4ade2f);box-shadow:0 4px 14px rgba(74,222,47,.35);text-transform:uppercase;transition:.18s;margin-left:4px;cursor:pointer}
.user-ava:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(74,222,47,.5)}
.burger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:4.5px;width:40px;height:40px;flex:0 0 auto;
  border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.06);border-radius:50%;cursor:pointer;padding:0}
.burger span{width:17px;height:2px;background:var(--text);border-radius:2px;transition:.22s}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.menu-panel{position:fixed;top:70px;left:12px;right:12px;z-index:69;padding:10px;border-radius:22px;display:none;flex-direction:column;gap:1px;max-height:calc(100vh - 140px);overflow-y:auto}
.menu-panel.open{display:flex;animation:menuIn .2s ease}
@keyframes menuIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
.menu-panel a{color:var(--text);padding:13px 16px;border-radius:13px;font-size:15px;font-weight:500;transition:.15s}
.menu-panel a:hover,.menu-panel a:active{background:rgba(255,255,255,.07);color:var(--green-soft)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:13px 22px;border-radius:30px;font-weight:600;font-size:14.5px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);backdrop-filter:blur(10px);transition:.18s;color:#fff;cursor:pointer}
.btn-ghost:hover{background:rgba(255,255,255,.18)}
.btn-ghost svg{width:17px;height:17px}
/* breadcrumb */
.crumb{max-width:var(--maxw);margin:18px auto 0;padding:0 26px;color:var(--faint);font-size:13px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.crumb a{color:var(--muted)}.crumb a:hover{color:var(--green-soft)}.crumb .sep{opacity:.5}
/* rails */
section{margin-top:40px}
.rail-head{display:flex;align-items:baseline;justify-content:space-between;max-width:var(--maxw);margin:0 auto 14px;padding:0 26px}
.rail-head h2{font-size:clamp(20px,2.6vw,27px);font-weight:700;letter-spacing:-.02em}
.rail-head a{color:var(--muted);font-size:13px;font-weight:600;transition:.15s}
.rail-head a:hover{color:var(--green-soft)}
.rail-wrap{position:relative;max-width:var(--maxw);margin:0 auto;padding:0 26px}
.rail{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x proximity;padding:14px 0 18px;scrollbar-width:none;scroll-behavior:smooth}
.rail::-webkit-scrollbar{display:none}
.arrow{position:absolute;top:0;bottom:18px;width:54px;display:flex;align-items:center;justify-content:center;z-index:5;cursor:pointer;border:none;color:#fff;font-size:26px;opacity:0;transition:.2s;background:linear-gradient(90deg,rgba(7,8,9,.9),transparent)}
.rail-wrap:hover .arrow{opacity:1}
.arrow.r{right:0;background:linear-gradient(270deg,rgba(7,8,9,.9),transparent)}.arrow.l{left:0}.arrow:hover{color:var(--green-soft)}
.poster{flex:0 0 230px;scroll-snap-align:start;position:relative;aspect-ratio:3/4;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.08);background:linear-gradient(160deg,#13391044,#0a0d0a);transition:.28s cubic-bezier(.2,.7,.2,1)}
.poster img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.4s}
.poster .ov{position:absolute;inset:0;background:linear-gradient(180deg,transparent 38%,rgba(4,6,4,.9) 92%)}
.poster .body{position:absolute;left:0;right:0;bottom:0;padding:15px}
.poster .tag{display:inline-block;font-size:10px;font-weight:600;color:var(--green-soft);background:rgba(74,222,47,.14);border:1px solid rgba(74,222,47,.28);padding:3px 9px;border-radius:20px;margin-bottom:8px;letter-spacing:.04em}
.poster h3{font-size:18px;font-weight:700;letter-spacing:-.01em}
.poster .area{color:#b6bcb4;font-size:12px;margin-top:2px}
.poster .play{position:absolute;top:14px;right:14px;width:42px;height:42px;border-radius:50%;background-color:var(--green);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%2306210a'%3E%3Cpath d='M8 5v14l11-7z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:54% center;background-size:15px;font-size:0;transform:scale(0) translateY(-6px);transition:.25s;box-shadow:0 6px 20px rgba(74,222,47,.5)}
.poster:hover{transform:translateY(-8px) scale(1.04);border-color:rgba(255,255,255,.2);box-shadow:0 26px 50px rgba(0,0,0,.6),0 0 0 1px rgba(74,222,47,.25)}
.poster:hover img{transform:scale(1.08)}.poster:hover .play{transform:scale(1) translateY(0)}
.poster.wide{flex-basis:340px;aspect-ratio:16/10}
/* article / content pages (clubs, guides, bottle service) */
.article{max-width:860px;margin:26px auto 0;padding:0 26px}
.byline{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:13.5px;margin:18px 0 6px}
.byline .ava{flex:0 0 30px;width:30px;height:30px;border-radius:50%;background:rgba(74,222,47,.15);border:1px solid rgba(74,222,47,.3);display:grid;place-items:center;color:var(--green-soft);font-weight:700;font-size:12px}
.byline b{color:var(--text);font-weight:600}
.article h1{font-size:clamp(32px,5.5vw,52px);font-weight:800;letter-spacing:-.03em;line-height:1.02;margin:6px 0 14px}
.article .lede{color:#dfe4dd;font-size:clamp(16px,2vw,18.5px);line-height:1.55;font-weight:500;margin-bottom:10px}
.eyebrow{display:block;font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--green-soft);margin:40px 0 6px}
.eyebrow+h2{margin-top:2px}
.article h2{font-size:clamp(23px,3.2vw,32px);font-weight:800;letter-spacing:-.025em;line-height:1.12;margin:40px 0 14px}
.article h3{font-size:clamp(17px,2vw,19px);font-weight:700;letter-spacing:-.01em;color:#eef2ec;margin:24px 0 9px}
.article p{color:#bcc3b8;font-size:16.5px;line-height:1.74;margin:0 0 16px}
.article p.note{font-size:14px;color:var(--faint);line-height:1.6}
.article a:not(.cta):not(.btn-ghost){color:var(--green-soft);text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(134,240,106,.4)}
.article a.maplink:not(.cta):not(.btn-ghost){color:inherit;text-decoration:none;border-bottom:0;cursor:pointer}
.article a.maplink:not(.cta):not(.btn-ghost):hover{color:var(--green-soft)}
/* on-brand dark map (interactive) */
.mapwrap{position:relative;height:300px;border-radius:var(--radius);overflow:hidden;border:1px solid rgba(255,255,255,.12);margin-top:14px;box-shadow:0 18px 50px rgba(0,0,0,.5)}
.mapwrap iframe{width:100%;height:100%;border:0;display:block;filter:invert(.91) hue-rotate(180deg) saturate(.8) contrast(.92) brightness(1.05)}
.mapwrap::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(70% 80% at 25% 15%,rgba(74,222,47,.14),transparent 60%);mix-blend-mode:soft-light}
.mapwrap::before{content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;box-shadow:inset 0 0 0 1px rgba(74,222,47,.14);z-index:2}
.map-actions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}
/* edit a pass's guest count */
.passedit{margin-top:12px}
.passedit summary{cursor:pointer;list-style:none;color:var(--green-soft);font-size:12.5px;font-weight:600}
.passedit summary::-webkit-details-marker{display:none}
.passedit-form{margin-top:11px;display:flex;flex-direction:column;gap:10px}
.passedit-form .field>label{font-size:10px}
.article ul{margin:0 0 16px;padding-left:2px;list-style:none}
.article ul li{color:#c4cabf;font-size:16px;line-height:1.65;padding-left:24px;position:relative;margin-bottom:9px}
.article ul li::before{content:"";position:absolute;left:2px;top:9px;width:7px;height:7px;border-radius:50%;background:var(--green)}
.hero-venue{position:relative;max-width:var(--maxw);margin:18px auto 0;height:min(58vh,460px);border-radius:26px;overflow:hidden}
.hero-venue .bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04)}
/* video header support: drop a <video class="bgvid" autoplay muted loop playsinline poster=img> after .bg */
.hero-venue .bgvid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
@media(prefers-reduced-motion:reduce){.hero-venue .bgvid{display:none}}
.hero-venue .scrim{position:absolute;inset:0;background:linear-gradient(0deg,var(--bg) 1%,rgba(5,7,5,.35) 45%,transparent 80%),radial-gradient(70% 60% at 15% 90%,rgba(74,222,47,.16),transparent 60%)}
.hero-venue .inner{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:34px 36px}
.hero-venue h1{font-size:clamp(34px,6vw,60px);font-weight:800;letter-spacing:-.035em;line-height:1;margin-bottom:12px}
.v-meta{display:flex;gap:11px;align-items:center;color:var(--muted);font-size:13.5px;flex-wrap:wrap;margin-bottom:18px}
.v-meta b{color:var(--green-soft);font-weight:600}.v-meta .sep{width:4px;height:4px;border-radius:50%;background:var(--faint)}
.v-actions{display:flex;gap:11px;flex-wrap:wrap}
.infogrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:12px;margin:6px 0 8px}
.infocard{padding:15px 16px;border-radius:16px;display:flex;gap:11px;align-items:flex-start}
.infocard svg{width:19px;height:19px;color:var(--green-soft);flex:0 0 auto;margin-top:2px;stroke-width:1.8}
.infocard .k{font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.07em;font-weight:600;margin-bottom:4px}
.infocard .val{font-size:15.5px;font-weight:600;color:var(--text);line-height:1.3}
/* gallery */
.gallery{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}
.gallery.g3{grid-template-columns:repeat(3,minmax(0,1fr))}
@media(max-width:760px){.gallery{gap:10px}}
.gallery a{position:relative;display:block;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.1);aspect-ratio:4/5;background:linear-gradient(160deg,#13391044,#0a0d0a)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:.35s}
.gallery a:hover img{transform:scale(1.05)}
.gallery .cap{position:absolute;left:0;right:0;bottom:0;padding:12px 14px;font-weight:700;font-size:15px;background:linear-gradient(0deg,rgba(4,6,4,.85),transparent)}
.gallery .cap small{display:block;font-weight:500;font-size:12px;color:var(--muted)}
.faq details{border-bottom:1px solid rgba(255,255,255,.08);padding:4px 0}
.faq summary{cursor:pointer;list-style:none;padding:16px 2px;font-weight:600;font-size:17px;display:flex;justify-content:space-between;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--green-soft);font-weight:400;font-size:22px;line-height:1}
.faq details[open] summary::after{content:"\2013"}
.faq .a{padding:0 2px 18px;color:#c4cabf;font-size:16px;line-height:1.7}
/* ===== Booking form — compact, app-style ===== */
.gl-card{padding:0;overflow:hidden}
.gl-form{padding:16px;display:flex;flex-direction:column;gap:11px;position:relative}
.gl-top{display:flex;justify-content:space-between;align-items:center;gap:10px}
.gl-kicker{font-size:12px;color:var(--muted)}
.gl-login{background:transparent;border:0;color:var(--green-soft);font-weight:600;font-size:13px;cursor:pointer;font-family:inherit;padding:0}
.gl-login:hover{text-decoration:underline}
.pair{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.field{display:flex;flex-direction:column;gap:5px;min-width:0}
.field>label{font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--faint)}
.field input,.field select,.field textarea{width:100%;padding:11px 13px;font-family:inherit;font-size:14.5px;color:var(--text);
  background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.11);border-radius:11px;outline:none;transition:.16s}
.field input::placeholder,.field textarea::placeholder{color:var(--faint)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:rgba(74,222,47,.5);background:rgba(74,222,47,.045);box-shadow:0 0 0 3px rgba(74,222,47,.1)}
.field textarea{min-height:54px;resize:vertical}
.field input[type=date]{color-scheme:dark}
.field select{appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2386f06a' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:15px;padding-right:36px}
.field option{background:#0d0f0d;color:var(--text)}
.segment{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:4px;border-radius:12px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.11)}
.segment button{appearance:none;background:transparent;border:0;color:var(--muted);font-family:inherit;font-weight:600;font-size:13.5px;padding:10px 6px;border-radius:9px;cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center;gap:6px}
.segment button svg{width:15px;height:15px}
.segment button.on{color:#06140a;background:linear-gradient(180deg,#84f266,#4ade2f);box-shadow:0 4px 12px rgba(74,222,47,.3)}
.stepper{display:flex;align-items:center;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.11);border-radius:11px;overflow:hidden}
.stepper button{appearance:none;background:transparent;border:0;color:var(--text);width:40px;height:44px;font-size:20px;line-height:1;cursor:pointer;transition:.15s;display:flex;align-items:center;justify-content:center;flex:0 0 auto;user-select:none;-webkit-user-select:none}
.stepper button:active{background:rgba(74,222,47,.22);color:var(--green-soft)}
@media(hover:hover){.stepper button:hover{background:rgba(74,222,47,.13);color:var(--green-soft)}}
.stepper .num{flex:1;text-align:center;font-weight:700;font-size:16px;min-width:0;user-select:none;-webkit-user-select:none}
.gl-form .opt{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);cursor:pointer}
.gl-form .opt input{appearance:none;-webkit-appearance:none;width:20px;height:20px;flex:0 0 auto;border-radius:6px;border:1.5px solid rgba(255,255,255,.2);background:rgba(255,255,255,.04);cursor:pointer;transition:.15s;position:relative}
.gl-form .opt input:checked{background:var(--green);border-color:var(--green)}
.gl-form .opt input:checked::after{content:"";position:absolute;left:6.5px;top:3px;width:4px;height:9px;border:solid #06210a;border-width:0 2.5px 2.5px 0;transform:rotate(45deg)}
.gl-form .submit{justify-content:center;padding:14px;font-size:15px;margin-top:2px;width:100%}
.gl-form .hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.article .disclaimer{color:var(--faint);font-size:11.5px;line-height:1.5;opacity:.9;padding:0 16px 16px;margin:0}
.foot-legal{max-width:var(--maxw);margin:30px auto 0;padding:0 26px;color:var(--faint);font-size:10.5px;line-height:1.55;opacity:.7}
/* post-submit choice */
.sent-msg{display:none;margin:16px;padding:18px;border-radius:14px;background:rgba(74,222,47,.1);border:1px solid rgba(74,222,47,.3)}
.sent-msg.show{display:block}
.sent-h{font-size:18px;font-weight:800;letter-spacing:-.02em;color:var(--green-soft)}
.article .sent-p{font-size:13.5px;color:#c9cfc8;margin:5px 0 14px;line-height:1.5}
.sent-actions{display:flex;flex-direction:column;gap:9px}
.sent-actions .cta{justify-content:center;padding:13px}
.sent-actions .gl-login{align-self:center;padding:5px}
/* modal */
.modal{display:none;position:fixed;inset:0;z-index:200;background:rgba(4,6,4,.72);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);align-items:center;justify-content:center;padding:22px}
.modal.open{display:flex;animation:menuIn .2s ease}
.modal-card{position:relative;max-width:400px;width:100%;padding:26px;border-radius:20px;text-align:left}
.modal-card h3{font-size:20px;font-weight:800;letter-spacing:-.02em;margin-bottom:4px}
.modal-card p{font-size:13.5px;color:#c4cabf;line-height:1.6;margin-bottom:18px}
.modal-x{position:absolute;top:12px;right:15px;background:none;border:0;color:var(--muted);font-size:26px;line-height:1;cursor:pointer;padding:0}
/* auth forms */
.auth-form{display:flex;flex-direction:column;gap:11px;margin-top:12px}
.auth-form input{width:100%;padding:12px 14px;font-family:inherit;font-size:15px;color:var(--text);background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.11);border-radius:11px;outline:none;transition:.16s}
.auth-form input::placeholder{color:var(--faint)}
.auth-form input:focus{border-color:rgba(74,222,47,.5);background:rgba(74,222,47,.045);box-shadow:0 0 0 3px rgba(74,222,47,.1)}
.auth-form .pair{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.auth-form .cta{margin-top:3px}
.auth-err{color:#f0784a;font-size:13px;line-height:1.4}
.auth-err:empty{display:none}
.auth-switch{font-size:13px;color:var(--muted);margin-top:13px;text-align:center}
.auth-switch button{background:none;border:0;color:var(--green-soft);font-weight:600;cursor:pointer;font-family:inherit;font-size:13px;padding:0}
/* passes + history (account page) */
.passgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px;margin-top:6px}
.pass{padding:18px}
.pass .pv{font-size:18px;font-weight:800;letter-spacing:-.02em}
.pass .pmeta{color:var(--muted);font-size:13px;margin-top:3px}
.pass .pcode{margin-top:14px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:23px;font-weight:700;letter-spacing:4px;color:var(--green-soft);background:rgba(74,222,47,.08);border:1px solid rgba(74,222,47,.25);border-radius:12px;padding:13px;text-align:center}
.histlist{display:flex;flex-direction:column;gap:9px;margin-top:6px}
.histrow{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:13px 16px;border-radius:14px}
.histrow .pmeta{color:var(--muted);font-size:13px;margin-top:2px}
.badge{display:inline-block;font-size:11px;font-weight:700;padding:4px 11px;border-radius:20px;letter-spacing:.03em;white-space:nowrap;flex:0 0 auto}
.badge.pending{color:#f0c44a;background:rgba(240,196,74,.12);border:1px solid rgba(240,196,74,.3)}
.badge.confirmed{color:var(--green-soft);background:rgba(74,222,47,.12);border:1px solid rgba(74,222,47,.3)}
.badge.declined{color:#f0784a;background:rgba(240,120,74,.12);border:1px solid rgba(240,120,74,.3)}
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;max-width:var(--maxw);margin:0 auto;padding:0 26px}
.tile{position:relative;height:118px;border-radius:14px;overflow:hidden;padding:18px;display:flex;align-items:flex-start;font-weight:700;font-size:20px;letter-spacing:-.01em;transition:.2s;border:1px solid rgba(255,255,255,.08)}
.tile:hover{transform:translateY(-4px);box-shadow:0 20px 42px -8px rgba(0,0,0,.6),0 0 0 1px rgba(74,222,47,.22);z-index:3}
.tile img{position:absolute;width:96px;height:96px;object-fit:cover;border-radius:10px;right:-14px;bottom:-12px;transform:rotate(22deg);box-shadow:0 10px 26px rgba(0,0,0,.5)}
/* global "Hot events" ads module (Eventbrite posters) */
.hot-events{margin-top:46px}
.hot-events .ev{flex:0 0 300px;scroll-snap-align:start;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.1);background:#0c0f0c;transition:.25s cubic-bezier(.2,.7,.2,1);display:block}
.hot-events .ev .pic{position:relative;overflow:hidden;background:#0a0d0a}
.hot-events .ev img{width:100%;height:auto;display:block;transition:.4s}
.hot-events .ev:first-child{flex-basis:380px}
.hot-events .ev:hover{transform:translateY(-6px);border-color:rgba(74,222,47,.32);box-shadow:0 22px 46px rgba(0,0,0,.55)}
.hot-events .ev:hover img{transform:scale(1.05)}
.hot-events .ev .body{padding:13px 14px}
.hot-events .ev .tag{display:inline-block;font-size:10px;font-weight:700;color:var(--green-soft);background:rgba(74,222,47,.14);border:1px solid rgba(74,222,47,.28);padding:3px 9px;border-radius:20px;letter-spacing:.04em;margin-bottom:8px}
.hot-events .ev h3{font-size:15px;font-weight:700;letter-spacing:-.01em;line-height:1.25}
.hot-events .ev .get{margin-top:9px;font-size:12.5px;font-weight:600;color:var(--green-soft);display:flex;align-items:center;gap:5px}
/* when injected above the guestlist form (inside .article), fit the content column */
.hot-events.in-article{margin:30px 0}
.hot-events.in-article .rail-head,.hot-events.in-article .rail-wrap{max-width:none;margin-left:0;margin-right:0;padding-left:0;padding-right:0}
.hot-events.in-article .rail{padding-left:0;padding-right:0}
@media(max-width:760px){.hot-events{margin-top:34px}.hot-events .ev{flex-basis:250px}.hot-events .ev:first-child{flex-basis:300px}}
.bigcta{max-width:var(--maxw);margin:40px auto 0;padding:56px 40px;border-radius:30px;text-align:center;position:relative;overflow:hidden}
.bigcta::after{content:"";position:absolute;inset:0;background:radial-gradient(90% 130% at 50% 0%,rgba(74,222,47,.2),transparent 60%);z-index:-1}
.bigcta h2{font-size:clamp(26px,4vw,42px);font-weight:800;letter-spacing:-.025em;margin-bottom:12px}
.bigcta p{color:var(--muted);margin:0 auto 26px;max-width:480px}
footer{margin-top:56px;padding:50px 0 40px;border-top:1px solid rgba(255,255,255,.08)}
.fgrid{display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between;max-width:var(--maxw);margin:0 auto;padding:0 26px}
.fcol h4{font-size:12.5px;color:var(--faint);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;font-weight:600}
.fcol a{display:block;color:var(--muted);font-size:14px;margin-bottom:9px;transition:.15s}.fcol a:hover{color:var(--green-soft)}
.fbar{max-width:var(--maxw);margin:36px auto 0;padding:0 26px;color:var(--faint);font-size:13px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.mobnav{display:none}
@media(max-width:900px){.navlinks{display:none}.burger{display:flex}}
@media(max-width:760px){
  :root{--radius:18px}
  body{padding-bottom:86px}
  .wrap,.narrow,.rail-head,.tiles,.fgrid,.fbar,.crumb,.article{padding-left:16px;padding-right:16px}
  .rail-wrap{padding:0}
  nav.top{position:fixed;top:0;left:0;right:0;margin:0;padding:10px 12px 0;z-index:70;max-width:none}
  .navbar{padding:7px 7px 7px 16px;gap:8px}
  .brand .logo{height:17px}
  .cta{padding:9px 13px;font-size:12px}
  .t-long{display:none}.t-short{display:inline}
  .rail-head h2{font-size:20px}.rail-head a{font-size:12px}
  .arrow{display:none}
  .rail{gap:11px;padding:10px 16px 12px;scroll-padding-left:16px}
  .poster{flex-basis:150px;border-radius:13px}.poster.wide{flex-basis:256px}
  .poster h3{font-size:15px}.poster .area{font-size:11px}.poster .play{display:none}.poster:hover{transform:none;box-shadow:none}
  .hero-venue{margin-top:0;height:62vh;min-height:400px;border-radius:0 0 24px 24px}
  .hero-venue .inner{padding:22px 18px 28px}
  .article{margin-top:20px}
  .article h1{font-size:clamp(28px,8vw,36px)}
  .article .lede{font-size:15.5px;line-height:1.5}
  .article h2{font-size:21px;margin:30px 0 11px}
  .article h3{font-size:16px;margin:20px 0 8px}
  .article p{font-size:15px;line-height:1.68}
  .article ul li{font-size:14.5px}
  .eyebrow{font-size:11px;margin:28px 0 5px}
  .infocard .val{font-size:14px}.infocard .k{font-size:10px}
  .faq summary{font-size:15px;padding:14px 2px}.faq .a{font-size:14px}
  .article .disclaimer{font-size:10px;line-height:1.45;padding:0 14px 14px}
  .foot-legal{padding:0 16px;font-size:9px}
  .tiles{grid-template-columns:1fr 1fr;gap:11px}
  .tile{height:96px;font-size:16px;padding:14px;border-radius:13px}.tile img{width:66px;height:66px;right:-10px;bottom:-8px}
  .bigcta{margin-top:30px;padding:40px 20px;border-radius:22px}.fgrid{gap:28px}
  .mobnav{display:flex;position:fixed;left:12px;right:12px;bottom:12px;z-index:90;justify-content:space-around;padding:9px 6px;border-radius:24px}
  .mobnav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;font-weight:600;color:var(--muted);padding:3px}
  .mobnav a svg{width:21px;height:21px}.mobnav a.on{color:var(--green-soft)}
}
