/* ============================================================
   Soundspace — global chrome + homepage components
   Ported from approved mockup v27. Loaded site-wide.
   Depends on tokens.css (variables + buttons + kicker).
   ============================================================ */

*{box-sizing:border-box}
:where(.ss-header,.hero,.announced,.section,.ss-footer) :where(h1,h2,h3,h4,p,ul,ol,li,figure){margin:0;padding:0;list-style:none}

/* cosmic background layers (fixed) ----------------------------- */
.cosmos-canvas{position:fixed;inset:0;z-index:0;pointer-events:none;width:100%;height:100%;background:radial-gradient(120% 90% at 50% -10%,#0C1024,var(--bg-900) 60%,#05060F)}
.nebula{position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(55% 45% at 14% 8%, rgba(111,168,255,.22), transparent 60%),radial-gradient(50% 42% at 88% 90%, rgba(183,156,255,.20), transparent 60%),radial-gradient(42% 38% at 82% 14%, rgba(0,168,137,.16), transparent 60%)}
@keyframes nebula{0%{transform:translate3d(0,0,0) scale(1)}100%{transform:translate3d(-2.5%,2%,0) scale(1.1)}}
.grain{position:fixed;inset:0;z-index:9990;pointer-events:none;opacity:.045;mix-blend-mode:soft-light;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
@media(prefers-reduced-motion:reduce){.nebula{animation:none}}

/* layout container -------------------------------------------- */
.ss-wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);position:relative;z-index:2}
/* breathe a little on very large monitors */
@media(min-width:1700px){:root{--maxw:1400px}}
.ss-main{position:relative;z-index:1;display:block}
a{color:inherit}

/* scroll reveal ----------------------------------------------- */
.js-reveal .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.js-reveal .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.js-reveal .reveal{opacity:1;transform:none;transition:none}}

/* ===== NEON MARQUEE HEADER ===== */
.ss-header{position:sticky;top:0;z-index:50;background:rgba(8,10,24,.86);backdrop-filter:blur(12px)}
.ss-header .nav{display:flex;align-items:center;justify-content:space-between;height:66px;gap:20px}
.brand{position:relative;display:flex;align-items:center;gap:13px;font-family:var(--display);font-weight:800;font-size:21px;letter-spacing:.1em;color:var(--cream);text-decoration:none}
.brand .bword{text-shadow:0 0 12px rgba(43,216,182,.3)}
.ntube{display:flex;flex-direction:column;gap:3px}
.ntube i{display:block;height:2.5px;border-radius:99px;background:#E6FBF4;box-shadow:0 0 4px var(--teal-neon),0 0 10px rgba(43,216,182,.8);animation:flick 6s infinite}
.neon-stack{display:flex;flex-direction:column;gap:6px;align-items:flex-start}
.ndiv{display:flex;gap:4px;align-self:center}
.ndiv i{display:block;width:3px;height:26px;border-radius:99px;background:#E6FBF4;box-shadow:0 0 4px var(--teal-neon),0 0 12px rgba(43,216,182,.85);animation:flick 6s infinite}
.ndiv i:nth-child(2){height:18px;align-self:center}
@keyframes flick{0%,96%,100%{opacity:1}97%{opacity:.5}98.5%{opacity:.9}}
.ss-header .nav ul{display:flex;gap:14px;list-style:none;font-family:var(--mono);font-size:12.5px;text-transform:uppercase;letter-spacing:.08em;margin:0;padding:0}
.ss-header .nav ul a{display:inline-block;padding:8px 5px;color:var(--text-dim);transition:.15s;text-decoration:none}
.ss-header .nav ul a:hover{color:var(--mint)}
.ss-header .nav ul a[aria-current="page"]{color:var(--teal-neon);text-shadow:0 0 10px rgba(43,216,182,.45)}

/* hamburger — shown below 880px, toggles the nav panel */
.menu-btn{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:10px;border:1px solid rgba(43,216,182,.6);border-radius:10px;background:rgba(43,216,182,.08);cursor:pointer;transition:.16s}
.menu-btn i{display:block;height:2px;border-radius:99px;background:var(--mint);box-shadow:0 0 6px rgba(43,216,182,.7);transition:.2s}
.menu-btn:hover{background:rgba(43,216,182,.16)}
.menu-btn:focus-visible{outline:3px solid var(--mint);outline-offset:2px}
.nav-open .menu-btn i:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-open .menu-btn i:nth-child(2){opacity:0}
.nav-open .menu-btn i:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-ig{display:none}
@media(max-width:880px){
  .menu-btn{display:flex}
  .ss-header .socials{display:none}
  .nav-ig{display:block}
  .ss-header .nav ul{display:none}
  .nav-open .nav ul{display:flex;position:absolute;top:66px;left:0;right:0;flex-direction:column;gap:0;background:rgba(8,10,24,.97);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:8px 0 14px}
  .nav-open .nav ul a{display:block;padding:15px var(--gut);font-size:14px}
  .nav-open .nav ul a[aria-current="page"]{border-left:3px solid var(--teal-neon);padding-left:calc(var(--gut) - 3px)}
  .nav-ig svg{width:21px;height:21px;fill:currentColor;display:block}
  .nav-open .nav-ig a:hover{color:var(--mint)}
}
.socials{display:flex;gap:8px;align-items:center}
.soc{width:35px;height:35px;display:grid;place-items:center;border-radius:50%;border:1.5px solid rgba(43,216,182,.6);color:#FFFCEF;background:rgba(43,216,182,.08);box-shadow:0 0 11px rgba(43,216,182,.28);transition:.16s}
.soc svg{width:16px;height:16px;fill:currentColor}
.soc:hover{color:#fff;border-color:var(--teal-neon);background:rgba(43,216,182,.16);box-shadow:0 0 20px rgba(43,216,182,.6);transform:translateY(-2px)}
@media(max-width:520px){.brand{font-size:17px;gap:9px}.soc{width:31px;height:31px}.socials{gap:6px}}
@media(max-width:600px){.soc-extra{display:none}}
@media(max-width:520px){.brand .neon-stack{display:none}}

/* HERO -------------------------------------------------------- */
.hero{position:relative;overflow:hidden}
.hero .ss-wrap{display:grid;grid-template-columns:1fr 380px;gap:30px;align-items:center;padding:38px 46px 42px 24px;min-height:400px}
.hero .nextup{grid-column:2;width:100%}
/* shrink-wrapped headline (width:min-content), weighted slightly left of
   center — dead-center reads as drifting toward the card */
.hero-intro{grid-column:1;align-self:center;justify-self:start;margin-left:clamp(16px,14%,150px)}
.hero-tag{font-family:var(--display);font-weight:800;font-size:clamp(28px,3.6vw,44px);line-height:1.16;letter-spacing:.005em;text-transform:uppercase;color:var(--cream);width:min-content;text-wrap:balance;overflow-wrap:normal;word-break:normal;hyphens:none}
.hero-sub{font-family:var(--mono);font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);margin-top:14px}
.hero-sub::before{content:"\2014 ";color:var(--green-bright)}

/* NOW PLAYING card ------------------------------------------- */
.nextup{position:relative;z-index:2;background:var(--bg-850);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 0 40px rgba(43,216,182,.1),0 18px 50px rgba(0,0,0,.5)}
/* bombastic live-pink banner: bright pink under the big display text (large-
   text contrast), deep rose under the small date so it stays AA-legible */
.nextup .top{position:relative;display:flex;align-items:center;justify-content:space-between;gap:10px;background:linear-gradient(100deg,#F00069,#B4306B 48%,#8E2455);color:#FFFCEF;padding:10px 16px;font-family:var(--mono);font-weight:700;font-size:11.5px;letter-spacing:.08em;text-transform:uppercase}
.nextup .top .np{font-family:var(--display);font-size:16px;font-weight:800;letter-spacing:.04em;text-shadow:0 0 16px rgba(240,0,105,.7),0 1px 0 rgba(0,0,0,.3)}
.nextup .top .np .np-star{display:inline-block;font-style:normal;margin-right:3px;animation:npPulse 1.6s ease-in-out infinite}
@keyframes npPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}
@media(prefers-reduced-motion:reduce){.nextup .top .np .np-star{animation:none}}
.nextup .top .when-dow{color:#FFFCEF}
.nextup .top::before{content:"";position:absolute;left:0;right:0;top:0;height:2.5px;background:#FF4D94;box-shadow:0 0 14px rgba(240,0,105,.95)}
.nextup .img{position:relative;aspect-ratio:1/1;background:var(--bg-800);overflow:hidden}
.nextup .img img{width:100%;height:100%;object-fit:cover;display:block}
/* letterbox non-16:9 poster art: full artwork on a blurred self-backdrop */
.poster-bg{position:absolute!important;inset:0;object-fit:cover!important;filter:blur(20px) saturate(1.15) brightness(.5);transform:scale(1.18)}
img.poster{position:relative;z-index:1;object-fit:contain!important}
.nextup .meta{padding:12px 18px 2px}
/* compact title (wraps naturally) so the poster owns the card */
.nextup h2{font-family:var(--display);font-weight:800;font-size:15.5px;line-height:1.25;text-transform:uppercase;color:var(--cream);margin-bottom:5px}
.nextup .when{font-family:var(--mono);font-size:12px;color:var(--text-dim);display:flex;gap:10px;padding:0 18px 13px}
.nextup .pad{padding:0 18px 18px}
.nextup .pad .btn{width:100%}
@media(max-width:880px){.hero .ss-wrap{grid-template-columns:1fr;gap:18px;padding:14px 16px 24px;min-height:0}.hero .nextup{grid-column:1;max-width:370px;justify-self:center;width:100%}
  /* mobile: card comes first — hide the value-prop visually but keep the h1 for AT/SEO */
  .hero-intro{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}}

/* offerings blurb band (hero → just-announced) ----------------- */
.blurb{position:relative;z-index:2}
/* contained panel, SOLID brand teal — a deliberate pop of color.
   Legibility at small caps sizes: weight 700 (800 clogs counters), NO text
   shadow (blurs edges on a flat bg), stars solid with no glow (pink-on-teal
   halation reads as noise). */
/* pointed ribbon ends: outer layer = faux neon border (clip-path clips real
   borders), inner layer = teal fill; drop-shadow follows the clipped shape */
.blurb-band{--bcut:26px;position:relative;background:rgba(43,216,182,.6);padding:1.5px;clip-path:polygon(0 50%,var(--bcut) 0,calc(100% - var(--bcut)) 0,100% 50%,calc(100% - var(--bcut)) 100%,var(--bcut) 100%);filter:drop-shadow(0 0 14px rgba(0,168,137,.35))}
.blurb-line{margin:0;background:#24544E;clip-path:polygon(0 50%,var(--bcut) 0,calc(100% - var(--bcut)) 0,100% 50%,calc(100% - var(--bcut)) 100%,var(--bcut) 100%);padding:15px 52px;text-align:center;font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:clamp(12.5px,1.7vw,15.5px);letter-spacing:.04em;color:var(--cream);line-height:1.7;overflow-wrap:normal;word-break:normal}
.blurb-line .bw{white-space:nowrap}
.blurb-line i{font-style:normal;color:var(--pink-soft);margin:0 .28em;font-size:.68em;vertical-align:.12em}
/* one uninterrupted line from 1080px up (size curve keeps it inside .ss-wrap);
   tight-but-readable wrap below */
@media(min-width:1080px){.blurb-line{white-space:nowrap;font-size:clamp(12.5px,1.15vw,14.8px)}}
@media(min-width:1700px){.blurb-line{font-size:16.2px}}
@media(max-width:600px){
  .blurb-line{font-size:12.5px;line-height:1.6}
  /* restore full-bleed strips on phones (no pointed ends edge-to-edge) */
  .blurb .ss-wrap,.announced .ss-wrap{padding:0}
  .blurb .blurb-band{clip-path:none;padding:0;background:#24544E;filter:none}
  .blurb .blurb-line{clip-path:none;background:transparent;padding:14px 12px}
  .announced .abar{border-left:0;border-right:0;border-radius:0}
}
/* pull Upcoming closer to the announced bar */
#week{padding-top:26px}
.blurb-line .more{font-family:var(--serif);font-style:italic;text-transform:none;font-weight:600;letter-spacing:.01em;color:#FFC6DC}

/* date badge -------------------------------------------------- */
.datebadge{position:absolute;top:10px;left:10px;width:58px;height:58px;display:grid;place-items:center;z-index:2}
.datebadge::before{content:"";position:absolute;inset:-5px;background:repeating-conic-gradient(var(--mint) 0 9deg,transparent 9deg 22deg);border-radius:50%;z-index:-1;opacity:.85}
.datebadge .disc{width:44px;height:44px;border-radius:50%;background:var(--cream);color:var(--ink);border:2px solid var(--ink);display:grid;place-content:center;text-align:center;line-height:1}
.datebadge .d{font-family:var(--display);font-weight:800;font-size:18px}
.datebadge .m{font-size:8px;font-weight:700;letter-spacing:.1em}

/* JUST ANNOUNCED bar ----------------------------------------- */
.announced{position:relative;z-index:2;padding:22px 0 8px}
.abar{position:relative;border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,rgba(8,10,24,.6),rgba(8,10,24,.12));padding:14px 0;overflow:hidden}
.abar::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(var(--blue),var(--purple));box-shadow:0 0 12px rgba(111,168,255,.5)}
.abar-head{padding:0 var(--gut);margin-bottom:12px}
/* infinite right-to-left marquee: chips duplicated in PHP so translate(-50%)
   loops seamlessly; per-chip margin (NOT flex gap) keeps both halves identical.
   GPU transform inside the clipped .abar panel; pauses on hover/focus. */
.achips{display:flex;width:max-content;padding:2px var(--gut) 8px;user-select:none;animation:amarq 46s linear infinite;transform:translate3d(0,0,0);will-change:transform;backface-visibility:hidden}
.achips:hover,.achips:focus-within{animation-play-state:paused}
@keyframes amarq{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
.achips::-webkit-scrollbar{display:none}
@media(prefers-reduced-motion:reduce){
  .achips{animation:none;width:auto;overflow-x:auto;justify-content:safe center;scrollbar-width:none;-ms-overflow-style:none;cursor:grab}
  .achips.dragging{cursor:grabbing}
  .achips--fit{cursor:default}
  .achip--dup{display:none}
}
.achip{flex:0 0 auto;display:flex;align-items:center;gap:13px;width:288px;margin-right:32px;padding:12px 15px;border:1px solid var(--line);border-radius:12px;background:var(--bg-850);transition:border-color .16s,box-shadow .16s,transform .16s;text-decoration:none;-webkit-user-drag:none}
.achip:hover{transform:translateY(-2px);border-color:var(--blue);box-shadow:0 0 22px rgba(111,168,255,.22)}
.achip .adate{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:0 0 auto;width:48px;padding:6px 0;border-radius:9px;background:var(--bg-800);border:1px solid var(--line)}
.achip .adate .am{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;color:var(--blue)}
.achip .adate .ad{font-family:var(--display);font-weight:800;font-size:21px;line-height:1;color:var(--cream)}
.achip .adate .adow{font-family:var(--mono);font-size:8.5px;letter-spacing:.08em;color:var(--text-dim);margin-top:2px}
.achip .ainfo{display:flex;flex-direction:column;min-width:0;flex:1}
.achip .atitle{font-family:var(--display);font-weight:700;font-size:13.5px;line-height:1.15;text-transform:uppercase;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.achip .ameta{font-family:var(--mono);font-size:10.5px;color:var(--text-dim);margin-top:5px}
.achip .ago{flex:0 0 auto;font-family:var(--display);color:var(--blue);font-size:16px;opacity:.7}
.achip:hover .ago{opacity:1}
@media(max-width:520px){.achip{width:256px;margin-right:22px}}

/* sections + Upcoming viewport ------------------------------- */
.section{position:relative;padding:64px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:26px}
.sec-head h2{font-family:var(--display);font-weight:800;font-size:clamp(28px,4vw,42px);text-transform:uppercase;letter-spacing:-.01em;color:var(--cream)}
.viewport{position:relative;border:1px solid var(--line);border-radius:20px;padding:24px 30px 38px;background:linear-gradient(180deg,rgba(8,10,24,.5),rgba(8,10,24,.1));box-shadow:inset 0 0 90px rgba(0,0,0,.45),0 0 40px rgba(111,168,255,.06)}
.viewport-foot{display:flex;justify-content:flex-end;margin-top:26px}
.viewport::before,.viewport::after{content:"";position:absolute;width:22px;height:22px;border:2px solid var(--teal-neon);opacity:.55;box-shadow:0 0 8px rgba(43,216,182,.5)}
.viewport::before{top:10px;left:10px;border-right:0;border-bottom:0}
.viewport::after{bottom:10px;right:10px;border-left:0;border-top:0}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid{grid-template-columns:1fr}
  #week .ss-wrap{padding:0}
  .viewport{padding:20px 14px 28px;border-radius:0;border-left:0;border-right:0}
  .sec-head{margin-bottom:18px}
  .sec-head h2{font-size:clamp(13px,3.6vw,20px);letter-spacing:-.01em}}
.card{background:var(--bg-850);border:1px solid var(--line);border-radius:15px;overflow:hidden;display:flex;flex-direction:column;transition:.18s}
.card:hover{transform:translateY(-4px);border-color:var(--blue);box-shadow:0 0 28px rgba(111,168,255,.28)}
.card .imgwrap{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--bg-800)}
.card .imgwrap img{width:100%;height:100%;object-fit:cover;display:block}
.card .body{padding:15px 17px 19px;display:flex;flex-direction:column;flex:1}
.card h3{font-family:var(--display);font-weight:700;font-size:17px;line-height:1.1;text-transform:uppercase;color:var(--cream);margin-bottom:9px}
.card .meta{font-family:var(--mono);font-size:11.5px;color:var(--text-dim);display:flex;gap:9px;margin-bottom:15px}
.card .foot{margin-top:auto}
.card .ticket{position:relative;display:flex;align-items:center;justify-content:center;gap:.4em;color:var(--mint);font-family:var(--display);font-weight:700;font-size:12.5px;letter-spacing:.07em;text-transform:uppercase;padding:11px;transition:.16s;overflow:hidden;border:1.5px solid transparent;background:linear-gradient(var(--bg-850),var(--bg-850)) padding-box,linear-gradient(120deg,var(--blue),var(--teal-neon) 55%,var(--purple)) border-box;clip-path:polygon(0 0,calc(100% - 11px) 0,100% 11px,100% 100%,11px 100%,0 calc(100% - 11px));text-decoration:none}
.card .ticket::before{content:"\00BB";opacity:.8}
.card .ticket:hover{color:#fff;filter:drop-shadow(0 0 14px rgba(43,216,182,.5))}

/* carousel ---------------------------------------------------- */
.carousel-wrap{position:relative}
.carousel{display:flex;gap:16px;overflow-x:auto;padding:4px 0 8px;scrollbar-width:none;-ms-overflow-style:none}
.carousel::-webkit-scrollbar{display:none}
.slide{flex:0 0 auto;width:300px;border-radius:14px;overflow:hidden;border:1px solid var(--line);position:relative;background:var(--bg-850)}
.slide img{display:block;width:100%;aspect-ratio:4/5;height:auto;object-fit:cover;object-position:center}
.slide::after{content:"";position:absolute;inset:0;box-shadow:inset 0 -60px 50px -30px rgba(5,6,15,.85);pointer-events:none}
@media(max-width:600px){.slide{width:240px}}
.carrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:36px;height:36px;display:grid;place-items:center;border-radius:50%;border:1px solid var(--line);background:rgba(8,10,24,.72);backdrop-filter:blur(8px);color:var(--mint);font-family:var(--display);font-size:21px;line-height:1;cursor:pointer;transition:.16s;opacity:.85}
.carrow:hover{opacity:1;border-color:var(--blue);color:#fff;box-shadow:0 0 16px rgba(111,168,255,.4)}
.carrow:focus-visible{outline:3px solid var(--mint);outline-offset:2px}
.carrow--prev{left:6px}.carrow--next{right:6px}
@media(max-width:520px){.carrow{width:32px;height:32px;font-size:18px}}

/* footer ------------------------------------------------------ */
.ss-footer{border-top:1px solid var(--line);padding:32px 0 38px;position:relative;z-index:1}
.fgrid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}
.ss-footer h4{font-family:var(--display);font-weight:800;font-size:20px;text-transform:uppercase;color:var(--cream);margin-bottom:7px}
.ss-footer p,.ss-footer li{color:var(--text-dim);font-size:14px;line-height:1.7;list-style:none}
.ss-footer .lbl{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--blue);margin-bottom:6px}
.ss-footer a{text-decoration:none}
.ss-footer a:hover{color:var(--mint)}
/* Connect column: labeled, visually separated link groups */
.connect-list li{margin-bottom:9px}
.connect-list li:last-child{margin-bottom:0}
.connect-list .clbl{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);line-height:1.5}
.connect-list a{color:var(--teal-neon);line-height:1.5}
.connect-list a:hover{color:var(--green-bright)}
@media(max-width:780px){.fgrid{grid-template-columns:1fr;gap:18px}.ss-footer{padding:26px 0 32px}}
/* tighten the last section (past-trips carousel) into the footer */
#past{padding:44px 0 36px}

/* bar menu page ----------------------------------------------- */
.ss-barmenu{margin:0;display:flex;justify-content:center;padding:34px 16px 72px}
.ss-barmenu img{display:block;width:100%;max-width:520px;height:auto;border-radius:16px;box-shadow:0 0 0 1px rgba(43,216,182,.22),0 26px 70px -18px rgba(0,0,0,.7)}
@media(max-width:600px){.ss-barmenu{padding:22px 14px 52px}.ss-barmenu img{max-width:430px}}

/* about + contact pages ---------------------------------------- */
.ss-page{max-width:840px;margin:0 auto;padding:26px 0 40px}
.ss-page .kicker{display:block;margin-bottom:14px}
.ss-page h1{font-family:var(--display);font-weight:800;font-size:clamp(27px,4.2vw,44px);line-height:1.08;text-transform:uppercase;color:var(--cream);margin:0 0 10px;text-wrap:balance}
.ss-page .h1-eyebrow{display:block;font-family:var(--mono);font-weight:700;font-size:clamp(12px,1.3vw,14px);letter-spacing:.2em;color:var(--text-dim);margin-bottom:12px}
.ss-page .est{font-family:var(--mono);font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--pink-soft);text-shadow:0 0 12px rgba(240,0,105,.5);margin:0 0 24px}
.ss-page h2{font-family:var(--display);font-weight:700;font-size:clamp(20px,3vw,28px);text-transform:uppercase;color:var(--cream);margin:34px 0 14px}
.screen-reader-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.ss-page p{color:var(--text);font-size:16.5px;line-height:1.65;max-width:640px;margin:0 0 18px}
.ss-page .accent{font-family:var(--serif);font-style:italic;font-size:19px;color:var(--purple)}
.ss-page .ss-cta{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}
.ss-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:32px 0}
@media(max-width:700px){.ss-info-grid{grid-template-columns:1fr}}
.ss-info{background:var(--bg-850);border:1px solid var(--line);border-radius:15px;padding:22px 24px}
.ss-info .lbl{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--blue);margin-bottom:10px}
.ss-info p,.ss-info li{color:var(--text);font-size:15.5px;line-height:1.85;margin:0;list-style:none}
.ss-info ul{margin:0;padding:0}
.ss-info a{color:var(--teal-neon);text-decoration:none}
.ss-info a:hover{color:var(--green-bright)}
.ss-map{border-radius:15px;overflow:hidden;border:1px solid var(--line);margin-top:6px}
.ss-map iframe{display:block;width:100%;height:330px;border:0}
.ss-photo{border-radius:15px;overflow:hidden;border:1px solid var(--line);margin:30px 0;position:relative}
.ss-photo img{display:block;width:100%;height:auto}
.ss-photo::after{content:"";position:absolute;inset:0;box-shadow:inset 0 -60px 50px -30px rgba(5,6,15,.6);pointer-events:none}

/* events listing page (Eventbrite-feed, in sync with homepage) ------ */
.events-page{padding-top:50px}
.events-head{margin-bottom:30px}
.events-head .kicker{display:block;margin-bottom:12px}
.events-head h1{font-family:var(--display);font-weight:800;font-size:clamp(30px,5vw,52px);line-height:1.05;text-transform:uppercase;letter-spacing:.005em;color:var(--cream)}
.events-sub{margin-top:13px;color:var(--text-dim);font-size:15px;max-width:560px;line-height:1.6}
.grid--events{margin-top:4px}
.events-empty{color:var(--text-dim);font-size:16px;line-height:1.7;padding:24px 0 10px;max-width:560px}
.events-empty a{color:var(--teal-neon)}
@media(max-width:600px){.events-page{padding-top:32px}.events-head{margin-bottom:22px}}

/* ============================================================
   The Events Calendar — dark cosmic retheme (TEC 6.x)
   TEC themes everything via --tec-color-* vars (default = light
   theme: dark text on white). We remap those vars to our dark
   palette so titles/dates/nav/search/icons are legible. The
   `body` prefix wins specificity vs TEC's own .tribe-common defs.
   ============================================================ */
body .tribe-common,
body .tribe-events{
  --tec-color-text-primary:var(--cream);
  --tec-color-text-primary-light:var(--text-dim);
  --tec-color-text-secondary:var(--text-dim);
  --tec-color-text-disabled:#5a6478;
  --tec-color-text-event-date:var(--text);
  --tec-color-text-events-title:var(--cream);
  --tec-color-text-event-title:var(--cream);

  --tec-color-icon-primary:var(--text-dim);
  --tec-color-icon-primary-alt:var(--text-dim);
  --tec-color-icon-secondary:#6b7794;
  --tec-color-icon-active:var(--cream);
  --tec-color-icon-disabled:#5a6478;
  --tec-color-event-icon:var(--text-dim);
  --tec-color-event-icon-hover:var(--teal-neon);

  --tec-color-accent-primary:var(--teal-neon);
  --tec-color-accent-primary-hover:var(--green-bright);
  --tec-color-accent-primary-active:var(--green-bright);
  --tec-color-accent-primary-background:rgba(43,216,182,.12);
  --tec-color-accent-secondary:var(--cream);

  --tec-color-link-primary:var(--cream);
  --tec-color-link-accent:var(--teal-neon);
  --tec-color-link-accent-hover:var(--green-bright);

  --tec-color-background:var(--bg-850);
  --tec-color-background-secondary:var(--bg-800);
  --tec-color-background-secondary-hover:#1d2342;
  --tec-color-background-transparent:rgba(14,17,36,.72);

  --tec-color-border-default:var(--line);
  --tec-color-border-secondary:rgba(124,168,255,.16);
  --tec-color-border-hover:var(--blue);
  --tec-color-border-tertiary:rgba(124,168,255,.3);
  --tec-color-border-active:var(--teal-neon);
}
/* event titles on-brand: display font, brass-on-hover */
.tribe-events-calendar-list__event-title-link{font-family:var(--display);font-weight:700;letter-spacing:-.01em;color:var(--cream)}
.tribe-events-calendar-list__event-title-link:hover,
.tribe-events-calendar-list__event-title-link:focus{color:var(--teal-neon)}
/* month separator hairline */
.tribe-events-calendar-list__month-separator-text{color:var(--cream)}
/* search + datepicker inputs: dark field, light text */
.tribe-events-c-search__input,
.tribe-common-form-control-text__input,
.tribe-events-c-top-bar__datepicker-input{background:var(--bg-850)!important;color:var(--cream)!important;border-color:var(--line)!important}
.tribe-events-c-search__input::placeholder,
.tribe-common-form-control-text__input::placeholder{color:var(--text-dim)!important;opacity:1}
/* subscribe/view dropdown panels: dark surface + readable links */
.tribe-events-c-subscribe-dropdown__content,
.tribe-events-c-view-selector__content{background:var(--bg-850);border-color:var(--line)}
.tribe-events-c-subscribe-dropdown__list-item-link:hover{color:var(--teal-neon)}
