:root{
  --bg:#080403;
  --panel:rgba(12,7,5,.72);
  --panel-strong:rgba(7,4,3,.86);
  --gold:#e8b75e;
  --gold-light:#ffe5a3;
  --red:#d9452d;
  --red-dark:#4e0e0a;
  --cream:#fff2d4;
  --muted:#d4bea0;
  --line:rgba(255,217,151,.18);
  --shadow:0 28px 90px rgba(0,0,0,.62);
}

*{box-sizing:border-box}

html{min-height:100%; background:var(--bg);}

body{
  margin:0;
  min-height:100vh;
  color:var(--cream);
  font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;
  overflow-x:hidden;
  background:#080403;
}

.site-bg{
  position:fixed;
  inset:0;
  background:
    linear-gradient(90deg, rgba(0,0,0,.72), rgba(0,0,0,.16) 42%, rgba(0,0,0,.68)),
    linear-gradient(180deg, rgba(0,0,0,.1), rgba(0,0,0,.6) 68%, rgba(0,0,0,.92)),
    url("assets/couch-culture-theater-bg.jpg");
  background-size:cover;
  background-position:center;
  z-index:-5;
}

.grain{
  position:fixed;
  inset:0;
  z-index:-4;
  pointer-events:none;
  opacity:.12;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,.16) 0 1px, transparent 1px),
    radial-gradient(circle at 60% 70%, rgba(255,255,255,.12) 0 1px, transparent 1px);
  background-size:34px 34px, 47px 47px;
}

.curtain{
  position:fixed;
  top:0;
  bottom:0;
  width:min(16vw,220px);
  pointer-events:none;
  z-index:-3;
  opacity:.64;
  background:
    repeating-linear-gradient(90deg,
      rgba(42,5,5,.8) 0 18px,
      rgba(120,17,13,.52) 18px 31px,
      rgba(30,4,4,.78) 31px 52px);
  filter:blur(.2px);
}
.curtain-left{left:0; box-shadow:32px 0 120px rgba(85,9,7,.45)}
.curtain-right{right:0; box-shadow:-32px 0 120px rgba(85,9,7,.45)}

.shell{
  width:min(1160px, calc(100% - 32px));
  margin:0 auto;
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:40px 0;
}

.experience-card{
  width:100%;
  border:1px solid var(--line);
  border-radius:34px;
  background:
    radial-gradient(circle at 50% -18%, rgba(214,75,45,.28), transparent 34%),
    linear-gradient(180deg, rgba(14,8,6,.76), rgba(4,3,3,.86));
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  box-shadow:var(--shadow), inset 0 1px 0 rgba(255,255,255,.06);
  padding:clamp(22px, 4vw, 48px);
  position:relative;
  overflow:hidden;
}

.experience-card::before{
  content:"";
  position:absolute;
  inset:14px;
  border-radius:26px;
  border:1px solid rgba(255,226,164,.08);
  pointer-events:none;
}

.brand{
  text-align:center;
  max-width:850px;
  margin:0 auto 30px;
  position:relative;
  z-index:2;
}

.brand-logo{
  width:min(540px, 92%);
  display:block;
  margin:0 auto 12px;
  filter:drop-shadow(0 0 24px rgba(232,183,94,.22));
}

.kicker{
  margin:8px 0 10px;
  color:var(--gold);
  text-transform:uppercase;
  letter-spacing:.34em;
  font-size:.78rem;
  font-weight:900;
}

h1{
  font-family:Cinzel, Georgia, serif;
  font-size:clamp(2.6rem, 7vw, 6.5rem);
  line-height:.94;
  margin:0;
  letter-spacing:.03em;
  text-shadow:0 0 28px rgba(216,69,45,.28);
}

.hero-copy{
  color:var(--muted);
  font-size:clamp(1rem, 2vw, 1.24rem);
  line-height:1.6;
  max-width:760px;
  margin:18px auto 0;
}

.ticket-panel{
  max-width:820px;
  margin:32px auto;
  position:relative;
  z-index:2;
}

.ticket-panel label{
  display:block;
  margin:0 0 10px;
  color:#f4d797;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.84rem;
}

.ticket-row{
  display:flex;
  gap:12px;
  padding:10px;
  border:1px solid rgba(255,221,154,.2);
  border-radius:24px;
  background:rgba(0,0,0,.48);
  box-shadow:inset 0 0 35px rgba(255,178,82,.04), 0 20px 44px rgba(0,0,0,.32);
}

input{
  flex:1;
  min-width:0;
  border:none;
  outline:none;
  color:white;
  background:rgba(255,255,255,.055);
  border-radius:18px;
  padding:18px 20px;
  font-size:1.18rem;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
}

input::placeholder{color:rgba(255,239,205,.32)}

button,
.primary-action,
.secondary-action{
  border:none;
  cursor:pointer;
  text-decoration:none;
  font-weight:1000;
  border-radius:18px;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}

.ticket-row button{
  color:#1b0b04;
  background:linear-gradient(135deg, #ffe7a8, #d99031 55%, #ffce76);
  padding:18px 24px;
  font-size:1rem;
  box-shadow:0 0 30px rgba(231,163,66,.26);
  white-space:nowrap;
}

.ticket-row button:hover,
.primary-action:hover,
.secondary-action:hover{
  transform:translateY(-2px);
}

.error{
  color:#ffb2a4;
  min-height:22px;
  margin:10px 8px 0;
  font-weight:700;
}

.access-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin:28px 0 18px;
  position:relative;
  z-index:2;
}

.access-card{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:18px;
  align-items:start;
  padding:24px;
  border-radius:28px;
  background:linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.025));
  border:1px solid rgba(255,226,164,.14);
  box-shadow:0 18px 50px rgba(0,0,0,.26);
}

.viewer-card{
  box-shadow:0 18px 50px rgba(0,0,0,.26), inset 0 0 34px rgba(206,54,33,.08);
}

.member-card{
  box-shadow:0 18px 50px rgba(0,0,0,.26), inset 0 0 34px rgba(232,183,94,.08);
}

.access-icon{
  width:64px;
  height:64px;
  display:grid;
  place-items:center;
  border-radius:21px;
  background:rgba(0,0,0,.42);
  border:1px solid rgba(255,220,157,.14);
  font-size:2rem;
}

.access-label{
  color:var(--gold);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.76rem;
  margin:0 0 8px;
  font-weight:1000;
}

.access-card h2{
  font-family:Cinzel, Georgia, serif;
  margin:0 0 8px;
  font-size:clamp(1.3rem,2.4vw,2rem);
}

.access-card p:last-child{
  color:var(--muted);
  line-height:1.5;
  margin:0;
}

.member-note{
  margin:18px auto 0;
  max-width:840px;
  text-align:center;
  color:#ecd8b8;
  background:rgba(0,0,0,.38);
  border:1px solid rgba(255,226,164,.11);
  border-radius:22px;
  padding:16px 18px;
  position:relative;
  z-index:2;
}

.member-note strong{color:#fff2d4}

.feature-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-top:22px;
  position:relative;
  z-index:2;
}

.feature{
  padding:18px 14px;
  text-align:center;
  border-radius:20px;
  background:rgba(0,0,0,.32);
  border:1px solid rgba(255,226,164,.1);
}

.feature span{display:block; font-size:1.5rem; margin-bottom:8px}
.feature strong{display:block; color:#fff2d4; font-size:.9rem}
.feature small{display:block; color:#bfae96; margin-top:5px}

.hidden{display:none !important}

.accepted{
  max-width:860px;
  text-align:center;
  margin:auto;
}

.accepted-badge{
  width:92px;
  height:92px;
  border-radius:999px;
  margin:0 auto 20px;
  display:grid;
  place-items:center;
  color:#1b0b04;
  font-size:3rem;
  font-weight:1000;
  background:linear-gradient(135deg, #fff3c4, #d99031);
  box-shadow:0 0 55px rgba(231,163,66,.36);
}

.action-stack{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  max-width:720px;
  margin:32px auto 20px;
}

.primary-action,
.secondary-action{
  min-height:72px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-size:1.08rem;
}

.primary-action{
  color:#190904;
  background:linear-gradient(135deg, #ffe7a8, #d99031 55%, #ffce76);
  box-shadow:0 0 38px rgba(231,163,66,.25);
}

.secondary-action{
  color:#fff1d0;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,226,164,.2);
}

.mini-guide{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  max-width:760px;
  margin:22px auto;
}

.mini-guide div{
  text-align:left;
  border:1px solid rgba(255,226,164,.11);
  background:rgba(0,0,0,.31);
  border-radius:18px;
  padding:16px;
}

.mini-guide strong{
  display:block;
  color:var(--gold-light);
  margin-bottom:6px;
}

.mini-guide span{
  color:var(--muted);
  line-height:1.45;
}

.back-button{
  margin-top:10px;
  background:transparent;
  color:#d8b981;
  border:1px solid rgba(255,226,164,.16);
  padding:12px 16px;
}

@keyframes entrance{
  from{opacity:0; transform:translateY(16px) scale(.985)}
  to{opacity:1; transform:translateY(0) scale(1)}
}
.experience-card{animation:entrance .5s ease both}

@media (max-width: 800px){
  .shell{
    width:calc(100% - 22px);
    padding:18px 0;
    align-items:start;
  }
  .site-bg{
    background-position:center top;
  }
  .curtain{display:none}
  .experience-card{
    border-radius:26px;
    padding:20px;
  }
  .experience-card::before{
    inset:8px;
    border-radius:20px;
  }
  .brand-logo{
    width:min(390px, 100%);
  }
  .kicker{
    letter-spacing:.22em;
    font-size:.68rem;
  }
  h1{
    font-size:clamp(2.25rem, 14vw, 4rem);
  }
  .hero-copy{
    font-size:1rem;
  }
  .ticket-row{
    flex-direction:column;
    border-radius:22px;
  }
  .ticket-row button{
    width:100%;
    min-height:58px;
  }
  input{
    width:100%;
    text-align:center;
    font-size:1rem;
  }
  .access-grid,
  .feature-row,
  .action-stack,
  .mini-guide{
    grid-template-columns:1fr;
  }
  .access-card{
    grid-template-columns:1fr;
    text-align:center;
  }
  .access-icon{
    margin:auto;
  }
  .feature{
    display:grid;
    grid-template-columns:auto 1fr;
    column-gap:12px;
    text-align:left;
    align-items:center;
  }
  .feature span{
    grid-row:1 / span 2;
    margin:0;
  }
  .mini-guide div{text-align:center}
}

@media (max-width: 420px){
  .experience-card{padding:16px}
  .brand-logo{margin-top:4px}
  .ticket-panel{margin:24px auto}
  .access-card{padding:18px}
}
