
/*
Theme Name: Ticket to Death
Theme URI: https://example.com/
Author: OpenAI
Description: One-page horror short film festival theme with Customizer controls for texts, buttons, links, and images.
Version: 1.2
License: GPLv2 or later
Text Domain: ticket-to-death
*/

:root{
  --bg:#081424;
  --bg-soft:#0d1b2d;
  --text:#e8e8e8;
  --muted:#aab4c3;
  --red:#cd322e;
  --line:rgba(255,255,255,.09);
  --shadow:0 24px 70px rgba(0,0,0,.45);
  --radius:22px;
  --max:1240px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(205,50,46,.15), transparent 30%),
    radial-gradient(circle at top right, rgba(205,50,46,.12), transparent 24%),
    linear-gradient(180deg, #060d18 0%, #081424 35%, #09111d 100%);
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed; inset:0; pointer-events:none; opacity:.08;
  background-image:
    linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:4px 4px,4px 4px;
  mix-blend-mode:soft-light;
}
img{max-width:100%; height:auto; display:block}
a,a:visited{color:inherit; text-decoration:none}
a:hover{color:#fff}
.container{width:min(calc(100% - 40px), var(--max)); margin:0 auto}
.topbar{
  position:sticky; top:0; z-index:50; backdrop-filter:blur(18px);
  background:rgba(8,20,36,.72); border-bottom:1px solid var(--line)
}
.topbar-inner{
  display:flex; align-items:center; justify-content:space-between; gap:22px; min-height:78px
}
.brand{font-weight:900; letter-spacing:.08em; text-transform:uppercase; font-size:1.1rem; white-space:nowrap}
.brand span{color:var(--red)}
nav{display:flex; gap:18px; flex-wrap:wrap; align-items:center; justify-content:center}
nav a{color:var(--text); font-size:.95rem; opacity:.92; transition:.25s ease}
nav a:hover{opacity:1}
.cta{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:14px 22px; border-radius:14px; border:1px solid rgba(255,255,255,.08);
  color:white; font-weight:700; transition:.25s ease; cursor:pointer
}
.cta.primary{background:linear-gradient(180deg,var(--red) 0%, #aa2825 100%); box-shadow:0 16px 38px rgba(205,50,46,.28)}
.cta.primary:hover{transform:translateY(-2px)}
.cta.secondary{background:rgba(255,255,255,.03)}
.hero{
  position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; padding:70px 0 30px
}
.hero::before{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(6,13,24,.92) 0%, rgba(6,13,24,.78) 42%, rgba(6,13,24,.32) 100%),
    radial-gradient(circle at 75% 20%, rgba(205,50,46,.34), transparent 28%),
    radial-gradient(circle at 85% 70%, rgba(205,50,46,.16), transparent 25%)
}
.hero-art{
  position:absolute; inset:0; opacity:.42; filter:saturate(.8) contrast(1.1); transform:scale(1.04);
  background:
    linear-gradient(180deg, rgba(0,0,0,.2), rgba(0,0,0,.55)),
    center/cover no-repeat
}
.hero-grid{
  position:relative; z-index:2; display:grid;
  grid-template-columns:minmax(0,1.08fr) minmax(360px,.92fr);
  gap:clamp(28px,4vw,56px); align-items:center
}
.hero-content{max-width:620px; position:relative; z-index:2; text-align:left}
.eyebrow{
  display:inline-flex; align-items:center; gap:10px; padding:10px 14px;
  border:1px solid rgba(255,255,255,.08); border-radius:999px; background:rgba(255,255,255,.03);
  color:#f2f2f2; font-size:.85rem; letter-spacing:.08em; text-transform:uppercase
}
.hero h1{
  margin:18px 0 18px; font-size:clamp(3rem,7.2vw,6rem); line-height:.92;
  text-transform:uppercase; letter-spacing:.02em; max-width:10.5ch; text-wrap:balance
}
.hero h1 span{color:var(--red)}
.hero-copy-shell{max-width:620px; padding-right:24px; text-align:left}
.hero p{margin:0; color:var(--muted); font-size:1.08rem; line-height:1.7; text-align:left}
.hero-actions{display:flex; gap:14px; flex-wrap:wrap; margin-top:28px}
.stats-card{
  max-width:460px; width:100%; justify-self:end; align-self:center; margin-top:56px;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.09); box-shadow:var(--shadow);
  border-radius:28px; padding:28px; backdrop-filter:blur(16px)
}
.countdown{display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-top:20px}
.countbox{
  background:rgba(0,0,0,.22); border:1px solid rgba(255,255,255,.08);
  border-radius:18px; padding:18px 12px; text-align:center
}
.countbox strong{display:block; font-size:2rem; margin-bottom:4px}
.section{position:relative; padding:90px 0}
.section-title{display:flex; align-items:center; gap:14px; margin-bottom:18px}
.section-title::before{
  content:""; width:60px; height:2px; background:linear-gradient(90deg,var(--red),transparent)
}
.section h2{margin:0; font-size:clamp(2rem,4vw,3.4rem); text-transform:uppercase; letter-spacing:.04em}
.section-copy{max-width:820px; color:var(--muted); line-height:1.8; margin-bottom:34px; font-size:1.03rem}
.cards-3,.cards-4,.shop-grid,.tickets-grid,.laurel-grid{display:grid; gap:22px}
.cards-3{grid-template-columns:repeat(3,1fr)}
.cards-4{grid-template-columns:repeat(4,1fr)}
.shop-grid{grid-template-columns:repeat(3,1fr)}
.tickets-grid{grid-template-columns:repeat(2,1fr)}
.laurel-grid{grid-template-columns:repeat(4,1fr); gap:18px; margin-top:26px}
.card{
  position:relative; overflow:hidden; border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08); box-shadow:var(--shadow); min-height:300px
}
.card-media,.slide-media{
  height:220px; background-size:cover; background-position:center; position:relative
}
.slide-media{height:360px}
.card-media::after{
  content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.5))
}
.card-body{padding:22px; display:flex; flex-direction:column; gap:10px}
.tag{
  display:inline-block; padding:6px 10px; border-radius:999px; background:rgba(205,50,46,.12);
  color:#ffe6e5; font-size:.7rem; text-transform:uppercase; letter-spacing:.14em; margin-bottom:10px;
  width:fit-content; max-width:max-content; border:1px solid rgba(205,50,46,.18)
}
.tag.highlight{background:var(--red); color:white; animation:pulseGlow 1.8s infinite}
@keyframes pulseGlow{
  0%{box-shadow:0 0 0 0 rgba(205,50,46,.6)}
  70%{box-shadow:0 0 0 12px rgba(205,50,46,0)}
  100%{box-shadow:0 0 0 0 rgba(205,50,46,0)}
}
.card h3,.ticket-card h3{margin:0 0 10px; text-transform:uppercase}
.card h3{font-size:1.3rem}
.card p,.ticket-card p{margin:0; color:var(--muted); line-height:1.7; font-size:.96rem}
.product-price{font-size:1.4rem; font-weight:900; color:#fff; margin-top:6px}
.product-action{margin-top:auto}
.ticket-card{
  position:relative; padding:24px; border-radius:22px; border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)); box-shadow:var(--shadow); overflow:hidden
}
.ticket-card::before{content:""; position:absolute; inset:0; background:radial-gradient(circle at top right, rgba(205,50,46,.14), transparent 38%); pointer-events:none}
.ticket-card.featured{border-color:rgba(205,50,46,.45); background:linear-gradient(180deg, rgba(205,50,46,.14), rgba(255,255,255,.03)); transform:translateY(-4px)}
.ticket-badge{
  display:inline-block; margin-bottom:14px; padding:8px 12px; border-radius:999px;
  background:rgba(205,50,46,.16); color:#ffd9d8; font-size:.76rem; letter-spacing:.08em; text-transform:uppercase; font-weight:700
}
.ticket-price{font-size:2.4rem; font-weight:900; color:#fff; margin-bottom:18px}
.ticket-price span{font-size:1rem; color:var(--muted); font-weight:600}
.faq-accordion{display:grid; gap:14px; margin-top:24px}
.faq-item{
  border:1px solid rgba(255,255,255,.08); border-radius:20px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow:var(--shadow); overflow:hidden; transition:border-color .25s ease, transform .25s ease, background .25s ease
}
.faq-item[open]{border-color:rgba(205,50,46,.28); background:linear-gradient(180deg, rgba(205,50,46,.08), rgba(255,255,255,.02)); transform:translateY(-2px)}
.faq-item summary{
  position:relative; cursor:pointer; list-style:none; padding:22px 58px 22px 24px; font-weight:700; font-size:1.02rem
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+"; position:absolute; right:22px; top:50%; transform:translateY(-50%);
  width:30px; height:30px; border-radius:999px; display:grid; place-items:center;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); color:#fff; font-size:1.2rem
}
.faq-item[open] summary::after{content:"−"; background:rgba(205,50,46,.18); color:#ffd7d6}
.faq-answer{display:grid; grid-template-rows:0fr; transition:grid-template-rows .32s ease}
.faq-item[open] .faq-answer{grid-template-rows:1fr}
.faq-answer-inner{overflow:hidden}
.faq-answer p{margin:0; padding:0 24px 24px; color:var(--muted); line-height:1.8}
.slider-wrap{position:relative; margin-top:30px; overflow:visible}
.slider{display:flex; gap:20px; overflow:hidden; scroll-behavior:smooth}
.slider::-webkit-scrollbar{display:none}
.slide{
  flex:0 0 calc(25% - 15px); border-radius:18px; overflow:hidden;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); transition:transform .3s ease
}
.slide:hover{transform:translateY(-6px) scale(1.02); z-index:2}
.slide-body{padding:14px}
.slide-body h3{margin:0 0 6px; font-size:1rem}
.slide-body p{margin:0; font-size:.85rem; color:var(--muted)}
.slider-btn{
  position:absolute; top:45%; transform:translateY(-50%); background:rgba(0,0,0,.6); border:none;
  color:white; font-size:2rem; padding:8px 12px; cursor:pointer; border-radius:10px; z-index:10
}
.slider-btn.prev{left:-10px}
.slider-btn.next{right:-10px}
.award-card{
  position:relative; min-height:420px; padding:24px 20px 22px; border-radius:22px;
  background:linear-gradient(180deg, rgba(6,13,24,.78), rgba(8,20,36,.96)),
    radial-gradient(circle at top center, rgba(205,50,46,.14), transparent 40%);
  border:1px solid rgba(255,255,255,.08); box-shadow:var(--shadow); display:flex; flex-direction:column; justify-content:space-between; text-align:center
}
.award-card::before{content:""; position:absolute; inset:12px; border:1px solid rgba(255,255,255,.05); border-radius:16px; pointer-events:none}
.award-top{display:flex; align-items:center; justify-content:center; gap:8px; margin-bottom:12px; opacity:.95}
.laurel-svg{width:24px; height:24px; opacity:.9}
.award-title{font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.78)}
.award-sep{width:46px; height:1px; margin:0 auto 18px; background:linear-gradient(90deg, transparent, rgba(255,255,255,.4), transparent)}
.award-film{margin:0 0 8px; font-size:1.35rem; letter-spacing:.08em; text-transform:uppercase; line-height:1.15}
.award-director{color:var(--muted); margin:0 0 22px; font-size:.92rem; line-height:1.5}
.award-cats{display:flex; flex-wrap:wrap; gap:8px; justify-content:center}
.award-cat{
  padding:8px 12px; border-radius:999px; background:rgba(205,50,46,.12); border:1px solid rgba(205,50,46,.22);
  color:#ffe3e2; font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em
}
.footer{
  padding:36px 0 60px; border-top:1px solid var(--line); color:var(--muted);
  background:radial-gradient(circle at 20% 20%, rgba(205,50,46,.12), transparent 40%),
    radial-gradient(circle at 80% 80%, rgba(205,50,46,.08), transparent 50%), #081424
}
.footer-grid{display:grid; grid-template-columns:2fr 1fr 1fr; gap:30px; margin-bottom:30px}
.footer-links{display:flex; flex-direction:column; gap:8px}
.footer-links a{color:#d8d8d8; opacity:.8}
.footer-links a:hover{opacity:1}
@media (max-width:1100px){
  .hero-grid,.cards-4,.cards-3,.shop-grid,.laurel-grid{grid-template-columns:1fr 1fr}
  .hero-grid{grid-template-columns:1fr; align-items:start}
  .stats-card{justify-self:start; max-width:540px; margin-top:10px}
  nav{display:none}
}
@media (max-width:760px){
  .hero{min-height:auto; padding-top:110px}
  .hero-grid,.cards-4,.cards-3,.shop-grid,.countdown,.tickets-grid,.laurel-grid,.footer-grid{grid-template-columns:1fr}
  .topbar-inner{min-height:74px}
  .cta.header-cta{display:none}
  .section{padding:72px 0}
  .hero h1{font-size:clamp(2.8rem,12vw,4rem); max-width:8.4ch}
  .hero-copy-shell{max-width:100%; padding-right:0}
  .stats-card{max-width:100%; margin-top:8px}
  .slide{flex:0 0 calc(100% - 20px)}
}
