/* ============================================================
   PAGE: Comika Comedy Club
   Vibe: site dark mode + sedikit overlay batu bata di bg.
   Palette: dark mode site (#070E22) + brick tint overlay.
============================================================ */

/* ── FORCE DARK MODE SITE COLORS ───────────────────────────── */
.club-page {
  --bg:  #070E22; --bg2: #0E1A35; --bg3: #0B1736;
  --ink: #C9D4E8; --ink2:#EEF4FF; --muted:#7C8DAE;
  --line:rgba(120,170,230,.14);
  --shadow:0 14px 40px rgba(0,0,0,.35);
  --shadow-lg:0 26px 70px rgba(0,0,0,.5);
  --grain-op:.06; --grain-blend:screen;
  /* brick accent — only used for LED marquee & small details */
  --br:#C4581A; --br2:#D96830;
}

/* brick background: tiled image looping over dark navy */
.club-page body {
  background-image: url('https://res.cloudinary.com/zenisme/image/upload/f_auto,q_auto/v1780549359/CCC_pcdo5f.png');
  background-repeat: repeat;
  background-size: auto;     /* tile at natural size */
}

/* ── TOPBAR ─────────────────────────────────────────────────── */
.site-top {
  background: transparent !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
  border-bottom-color: transparent !important;
  transition: background .4s var(--ease), border-bottom-color .4s !important;
}
html.topbar-solid .site-top {
  background: rgba(7,14,34,.88) !important;
  -webkit-backdrop-filter: blur(14px) !important;
  backdrop-filter: blur(14px) !important;
  border-bottom-color: rgba(120,170,230,.14) !important;
}

/* ── HERO ──────────────────────────────────────────────────── */
/* anti kedip: .page:empty dipindah ke inline <style> di comedy-club.html agar URL cukup diubah di 1 file */
.cl-hero {
  position:relative; overflow:hidden; background:#04080F;
  height:100svh; min-height:560px; margin-top:-64px;
  display:flex; align-items:flex-end;
  padding-bottom:clamp(3.5rem,7vw,6rem);
}
@supports not (height:100svh){.cl-hero{height:100vh}}

.cl-slides{position:absolute;inset:0;z-index:0}
.cl-slide{position:absolute;inset:0;opacity:0;transition:opacity 2.2s ease}
.cl-slide.active{opacity:1}
.cl-slide img{width:100%;height:100%;object-fit:cover;transform:scale(1);will-change:transform}
@keyframes cl-zoom{from{transform:scale(1)}to{transform:scale(1.06)}}
.cl-slide.active img{animation:cl-zoom 10s ease-out forwards}
@media(prefers-reduced-motion:reduce){.cl-slide img{transform:scale(1)}.cl-slide.active img{animation:none}}

.cl-overlay{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(
    to bottom,
    rgba(7,14,34,.15) 0%,
    rgba(7,14,34,.28) 35%,
    rgba(7,14,34,.72) 68%,
    rgba(7,14,34,.96) 100%
  );
}

.cl-hero-in{position:relative;z-index:2}

/* neon pill tag */
.cl-neon-tag{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--cy);
  border:1px solid rgba(31,195,243,.4);
  padding:.33rem .9rem;border-radius:100px;margin-bottom:1.4rem;
  box-shadow:0 0 18px rgba(31,195,243,.18),inset 0 0 12px rgba(31,195,243,.06);
}
.cl-neon-tag .dot{
  width:6px;height:6px;border-radius:50%;background:var(--cy);
  box-shadow:0 0 8px var(--cy);
  animation:blink 1.8s ease-in-out infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}

.cl-h1{
  font-family:var(--f-h);
  font-size:clamp(3rem,8.5vw,7rem);
  font-weight:700;line-height:.94;letter-spacing:-.035em;
  color:#fff;margin:0 0 1.2rem;
}
.cl-h1 span{display:block;color:var(--cy)}
.cl-lead{
  font-size:clamp(.96rem,1.6vw,1.1rem);color:rgba(240,232,224,.62);
  line-height:1.74;max-width:48ch;margin:0 0 2rem;
}
.cl-hero-cta{display:flex;gap:.9rem;flex-wrap:wrap}
.cl-btn-outline{
  background:transparent;border:1.5px solid rgba(240,232,224,.28);color:rgba(240,232,224,.8);
  padding:.68rem 1.5rem;border-radius:100px;
  font-size:.86rem;font-weight:600;letter-spacing:.04em;
  text-decoration:none;display:inline-flex;align-items:center;gap:.45rem;
  transition:border-color .25s,color .25s,background .25s;
}
.cl-btn-outline:hover{border-color:var(--cy);color:var(--cy);background:rgba(31,195,243,.08)}

/* ── LED MARQUEE ────────────────────────────────────────────── */
.cl-marquee-strip{
  position:relative; overflow:hidden;
  background:#04080F;
  border-top:2px solid rgba(31,195,243,.18);
  border-bottom:2px solid rgba(31,195,243,.18);
  padding:1.1rem 0;
}
/* scanline overlay */
.cl-marquee-strip::before{
  content:''; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:repeating-linear-gradient(
    0deg,transparent 0px,transparent 3px,rgba(0,0,0,.22) 3px,rgba(0,0,0,.22) 4px
  );
}
/* left/right fade */
.cl-marquee-strip::after{
  content:''; position:absolute; inset:0; z-index:3; pointer-events:none;
  background:linear-gradient(to right,#04080F 0%,transparent 6%,transparent 94%,#04080F 100%);
}
.cl-marquee-track{
  display:flex; width:max-content;
  animation:cl-marquee 28s linear infinite;
}
@keyframes cl-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.cl-marquee-word{
  display:inline-flex; align-items:center;
  font-family:'Courier New',Courier,monospace;
  font-size:1.15rem; font-weight:700; letter-spacing:.3em; text-transform:uppercase;
  color:#fff;
  text-shadow:0 0 8px #fff, 0 0 24px rgba(255,255,255,.6);
  padding:0 2rem; white-space:nowrap;
}
.cl-marquee-sep{
  color:var(--cy);
  text-shadow:0 0 8px var(--cy), 0 0 20px rgba(31,195,243,.7);
  margin:0 .3rem;
}
@media(prefers-reduced-motion:reduce){.cl-marquee-track{animation:none}}

/* ── THE STAGE ──────────────────────────────────────────────── */
.cl-stage{
  padding-top:clamp(1rem,2vw,1.5rem);padding-bottom:clamp(2.5rem,5vw,4.5rem);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,6vw,5.5rem);align-items:center;
}
.cl-stage-photo{
  position:relative;
  line-height:0;
}
.cl-stage-photo img{width:100%;height:auto;display:block}
.cl-stage-text .eyebrow{color:var(--cy);margin-bottom:1rem}
.cl-stage-h2{
  font-family:var(--f-h);font-size:clamp(1.8rem,3.8vw,3rem);
  font-weight:700;color:var(--ink2);line-height:1.08;margin:0 0 1.2rem;
}
.cl-stage-p{font-size:clamp(.95rem,1.5vw,1.05rem);color:var(--muted);line-height:1.8;margin:0 0 2.5rem;max-width:46ch}
.cl-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem}
.cl-stat{
  background:var(--bg2);border:1px solid var(--line);border-radius:14px;
  padding:1.1rem .9rem;text-align:center;
}
.cl-stat b{
  font-family:var(--f-h);font-size:clamp(1.7rem,3.2vw,2.4rem);
  font-weight:700;color:var(--cy);line-height:1;display:block;
  text-shadow:0 0 18px rgba(31,195,243,.35);
}
.cl-stat span{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-weight:600}

/* ── SHOW SCHEDULE — dramatic ticket cards ──────────────────── */
.cl-schedule{padding-block:clamp(4rem,8vw,7rem);border-top:1px solid var(--line)}
.cl-schedule-head{margin-bottom:clamp(2rem,4vw,3rem)}
.cl-schedule-head .eyebrow{display:block;color:var(--cy);margin-bottom:.7rem}
.cl-schedule-head h2{font-family:var(--f-h);font-size:clamp(1.6rem,3.2vw,2.6rem);font-weight:700;color:var(--ink2);margin:0}

.cl-shows{display:flex;flex-direction:column;gap:1px}

/* each show = horizontal full-width ticket */
.cl-show{
  position:relative;overflow:hidden;
  background:var(--bg2);
  border-left:4px solid var(--bg3);
  display:grid;grid-template-columns:100px 1fr auto;align-items:center;
  gap:0;
  text-decoration:none;
  transition:border-left-color .25s,background .25s;
}
.cl-show:first-child{border-radius:16px 16px 0 0}
.cl-show:last-child{border-radius:0 0 16px 16px}
.cl-show:only-child{border-radius:16px}
/* separator */
.cl-show+.cl-show::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:var(--line);
}
.cl-show:hover{border-left-color:var(--cy);background:var(--bg3)}
.cl-show:hover .cl-show-date-box{background:rgba(31,195,243,.15)}

/* date column */
.cl-show-date-box{
  background:var(--bg3);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:1.8rem .8rem;align-self:stretch;
  transition:background .25s;
  gap:.1rem;
}
.cl-show-date-box .d{
  font-family:var(--f-h);font-size:2.4rem;font-weight:700;color:var(--cy);
  line-height:1;letter-spacing:-.03em;
  text-shadow:0 0 12px rgba(31,195,243,.4);
}
.cl-show-date-box .m{
  font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.5);
}

/* info column */
.cl-show-info{padding:1.4rem 1.8rem}
.cl-show-info h3{
  font-family:var(--f-h);font-size:1.15rem;font-weight:700;color:var(--ink2);margin:0 0 .45rem;
}
.cl-show-badges{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:.55rem}
.cl-badge{
  font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:.22rem .6rem;border-radius:6px;
}
.cl-badge.open-mic{background:rgba(31,195,243,.12);color:var(--cy)}
.cl-badge.time{background:rgba(200,190,180,.08);color:var(--muted)}
.cl-badge.loc{background:rgba(200,190,180,.08);color:var(--muted)}
.cl-show-sub{font-size:.82rem;color:var(--muted)}

/* cta column */
.cl-show-action{
  padding:1.4rem 1.8rem;display:flex;align-items:center;justify-content:flex-end;
}
.cl-show-btn{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--cy);
  border:1px solid rgba(31,195,243,.3);border-radius:100px;
  padding:.5rem 1.1rem;white-space:nowrap;
  transition:background .25s,border-color .25s,color .25s;
}
.cl-show:hover .cl-show-btn{background:var(--cy);border-color:var(--cy);color:#04122a}
.cl-show-btn svg{width:13px;height:13px}

/* ── CTA ────────────────────────────────────────────────────── */
.cl-cta .cta-band{
  background:linear-gradient(135deg,var(--b1) 0%,var(--b2) 55%,var(--b3) 100%);
  border:none;
}

/* ── COMIKARD ───────────────────────────────────────────────── */
.cl-comikard {
  position: relative;
  overflow: hidden;
  background: var(--bg);
  padding-block: clamp(4rem,8vw,7rem);
}
/* grid lines overlay */
.cl-comikard::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(120,170,230,.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(120,170,230,.055) 1px, transparent 1px);
  background-size: 52px 52px;
  pointer-events: none;
}
/* fade to bg at bottom */
.cl-comikard::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 45%;
  background: linear-gradient(to bottom, transparent 0%, var(--bg) 100%);
  pointer-events: none;
}
.cl-comikard-inner {
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: 38fr 62fr;
  gap: clamp(2.5rem,5vw,4.5rem);
  align-items: center;
}
.cl-comikard-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.cl-comikard-text .eyebrow {
  color: var(--br2);
  margin-bottom: .9rem;
}
.cl-comikard-h2 {
  font-family: var(--f-h);
  font-size: clamp(3rem,5.5vw,5.2rem);
  font-weight: 700;
  color: var(--ink2);
  line-height: .92;
  letter-spacing: -.045em;
  margin: 0 0 1.5rem;
}
.cl-comikard-desc {
  font-size: clamp(.95rem,1.5vw,1.05rem);
  color: var(--muted);
  line-height: 1.8;
  max-width: 40ch;
  margin: 0 0 2.4rem;
}
/* grid 2 kolom untuk kedua poster, poster ke-2 offset ke bawah */
.cl-comikard-posters {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(10px,2vw,18px);
  align-items: start;
}
.cl-comikard-posters .cl-poster:nth-child(2) {
  margin-top: clamp(1.8rem,4.5vw,3.5rem);
}
.cl-poster {
  flex: 1;
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: none;
  padding: 0;
  cursor: pointer;
  display: block;
  line-height: 0;
  box-shadow: 0 12px 40px rgba(0,0,0,.4);
  transition: transform .35s var(--ease), box-shadow .35s;
}
.cl-poster:hover {
  transform: translateY(-6px) scale(1.015);
  box-shadow: 0 24px 64px rgba(0,0,0,.55);
}
.cl-poster img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform .5s var(--ease);
}
.cl-poster:hover img {
  transform: scale(1.04);
}
.cl-poster-zoom {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(7,14,34,.5);
  opacity: 0;
  transition: opacity .25s;
}
.cl-poster-zoom svg {
  width: 36px; height: 36px;
  stroke: #fff;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,.6));
}
.cl-poster:hover .cl-poster-zoom {
  opacity: 1;
}

/* ── LIGHTBOX ───────────────────────────────────────────────── */
.cl-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .3s ease;
}
.cl-lightbox.is-open {
  opacity: 1;
}
.cl-lightbox[hidden] {
  display: none;
}
.cl-lightbox-bg {
  position: absolute;
  inset: 0;
  background: rgba(4,8,15,.92);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
}
.cl-lightbox-img {
  position: relative;
  z-index: 1;
  max-width: min(90vw, 680px);
  max-height: 90vh;
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: 12px;
  box-shadow: 0 32px 96px rgba(0,0,0,.7);
  transform: scale(.94);
  transition: transform .35s cubic-bezier(.16,1,.3,1);
}
.cl-lightbox.is-open .cl-lightbox-img {
  transform: scale(1);
}
.cl-lightbox-close {
  position: absolute;
  top: 20px; right: 20px;
  z-index: 2;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background .2s, transform .2s;
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}
.cl-lightbox-close:hover {
  background: rgba(255,255,255,.22);
  transform: scale(1.08);
}
.cl-lightbox-close svg { width: 20px; height: 20px; }

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media(max-width:900px){
  .cl-stage{grid-template-columns:1fr}
  /* frame mengikuti rasio asli gambar di semua ukuran layar */
  .cl-stage-photo{max-width:480px;margin-inline:auto}
}
@media(max-width:640px){
  .cl-show{grid-template-columns:80px 1fr}
  .cl-show-action{display:none}
  .cl-show-info{padding:1.1rem 1.2rem}
  .cl-show-date-box{padding:1.4rem .6rem}
  .cl-show-date-box .d{font-size:1.9rem}
  /* stat cards: kecilkan angka/teks supaya kata "Openmic" tidak kepotong
     di kolom sempit, plus overflow-hidden sebagai pengaman */
  .cl-stats{gap:.55rem}
  .cl-stat{padding:1rem .55rem;overflow:hidden}
  .cl-stat b{font-size:clamp(1.2rem,5.2vw,1.8rem);letter-spacing:-.02em}
  .cl-stat span{font-size:.6rem}
  /* hero CTA: tombol full-width & teks 1 baris (tanpa wrap) */
  .cl-hero-cta{flex-direction:column}
  .cl-hero-cta>*{width:100%;justify-content:center}
  /* comikard: stack jadi 1 kolom di mobile */
  .cl-comikard-inner{grid-template-columns:1fr}
  .cl-comikard-posters{max-width:460px;margin-inline:auto}
  .cl-comikard-posters .cl-poster:nth-child(2){margin-top:clamp(1rem,3vw,1.5rem)}
  .cl-poster{border-radius:10px}
  .cl-poster-zoom svg{width:26px;height:26px}
  /* lightbox: full-width di mobile */
  .cl-lightbox-img{max-width:96vw;border-radius:8px}
  .cl-lightbox-close{top:12px;right:12px;width:38px;height:38px}
}
