:root {
    --bg: #090811;
    --surface: #151222;
    --surface-2: #21162c;
    --text: #fffafc;
    --muted: #c9beca;
    --pink: #ff3d8d;
    --pink-dark: #d91f70;
    --blue: #7ce8ff;
    --line: rgba(255,255,255,.14);
    --shadow: 0 20px 55px rgba(0,0,0,.26);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: var(--text);
    background: var(--bg);
}
* { box-sizing: border-box; }
html { color-scheme: dark; scroll-behavior: smooth; scrollbar-color: var(--pink-dark) transparent; }
body { margin: 0; background: var(--bg); color: var(--text); line-height: 1.6; }
body::before, body::after { content: ""; position: fixed; inset: 0; pointer-events: none; z-index: -1; }
body::before {
    background:
        radial-gradient(55% 45% at 8% -8%, rgba(124,232,255,.10), transparent 60%),
        radial-gradient(50% 45% at 100% -6%, rgba(255,61,141,.15), transparent 55%),
        radial-gradient(50% 40% at 50% 118%, rgba(255,61,141,.08), transparent 60%);
}
body::after {
    opacity: .045;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
::selection { background: var(--pink); color: #fff; }
a,button { touch-action: manipulation; -webkit-tap-highlight-color: rgba(124,232,255,.28); }
a { color: inherit; }
img { max-width: 100%; display: block; }
h1,h2,h3,p { margin-top: 0; }
h1,h2,h3 { text-wrap: balance; font-family: "Bricolage Grotesque", ui-sans-serif, system-ui, sans-serif; font-weight: 800; font-optical-sizing: auto; }
.brand { font-family: "Bricolage Grotesque", ui-sans-serif, system-ui, sans-serif; }
h1 { font-size: clamp(2.45rem,7vw,5.4rem); line-height: 1.02; letter-spacing: -.07em; max-width: 900px; }
h2 { font-size: clamp(1.9rem,4vw,3.2rem); line-height: 1.08; letter-spacing: -.045em; }
h3 { font-size: 1.25rem; line-height: 1.18; }
[id] { scroll-margin-top: 92px; }
:focus-visible { outline: 3px solid var(--blue); outline-offset: 4px; }
.wrap { width: min(1160px,calc(100% - 36px)); margin-inline: auto; }
.narrow { max-width: 760px; }
.center { text-align: center; }
.event-grid + .center { margin-top: 34px; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link { position: fixed; z-index: 10; top: -80px; left: 10px; padding: 8px 12px; background: white; color: #111; }
.skip-link:focus { top: 10px; }
.site-header { position: sticky; top: 0; z-index: 5; background: rgba(9,8,17,.94); border-bottom: 1px solid var(--line); backdrop-filter: blur(16px); }
.nav { min-height: 74px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.brand { display: flex; align-items: center; gap: 10px; font-weight: 900; letter-spacing: -.04em; text-decoration: none; }
.brand img { border-radius: 50%; }
.nav-links { display: flex; align-items: center; gap: 22px; }
.nav-links a,.footer-links a,.text-link { color: var(--blue); font-weight: 800; text-decoration: none; }
.nav-links a:hover,.footer-links a:hover,.text-link:hover { text-decoration: underline; }
.nav-toggle { display: none; border: 1px solid var(--line); background: var(--surface); color: var(--text); border-radius: 999px; padding: 8px 14px; font-weight: 800; }
.hero,.page-hero { background: radial-gradient(circle at 75% 35%,rgba(255,61,141,.2),transparent 35%),linear-gradient(135deg,#100c18,#171021); }
.hero { padding: 78px 0 58px; }
.page-hero { padding: 74px 0; }
.hero-grid,.detail-grid,.split { display: grid; grid-template-columns: minmax(0,1.45fr) minmax(280px,.75fr); gap: 42px; align-items: center; }
.hero-copy,.page-hero p,.section-heading p { color: var(--muted); font-size: 1.08rem; max-width: 700px; }
.hero-image { width: 100%; height: 340px; object-fit: cover; object-position: center; border-radius: 22px; border: 1px solid rgba(255,255,255,.08); box-shadow: 0 34px 80px rgba(0,0,0,.5), 0 0 0 1px rgba(255,61,141,.12); }
.eyebrow { display: inline-flex; align-items: center; gap: 9px; color: var(--pink); text-transform: uppercase; letter-spacing: .14em; font-weight: 900; font-size: .75rem !important; }
.eyebrow::before { content: ""; width: 22px; height: 2px; border-radius: 2px; background: linear-gradient(90deg, var(--pink), transparent); }
.hero-actions,.card-actions,.list-actions { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.trust-row { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 25px; color: var(--muted); font-weight: 800; font-size: .9rem; }
.trust-row span { padding: 6px 10px; background: rgba(255,255,255,.06); border-radius: 999px; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; padding: 11px 17px; border-radius: 999px; font-weight: 900; text-decoration: none; transition: transform .18s ease, box-shadow .18s ease, background-position .35s ease, border-color .18s ease; }
.button:hover { transform: translateY(-2px); }
.button:active { transform: translateY(0); }
.button-primary { color: white; background: linear-gradient(110deg,var(--pink),var(--pink-dark) 55%,var(--pink)); background-size: 220% 100%; background-position: 0 0; box-shadow: 0 10px 28px rgba(255,61,141,.22); }
.button-primary:hover { background-position: 100% 0; box-shadow: 0 16px 38px rgba(255,61,141,.34); }
.button-ghost { border: 1px solid var(--line); background: rgba(255,255,255,.04); color: white; }
.button-ghost:hover { border-color: var(--blue); background: rgba(124,232,255,.08); }
.section { padding: 72px 0; }
.section-alt { padding: 72px 0; background: var(--surface); border-block: 1px solid var(--line); }
.section-heading { margin-bottom: 28px; }
.event-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(min(100%,320px),1fr)); gap: 18px; }
.event-card,.area-card,.info-card,.booking-panel,.feature-list div,.empty-state { background: var(--surface); border: 1px solid var(--line); border-radius: 18px; overflow: hidden; box-shadow: var(--shadow); }
.event-card { display: flex; flex-direction: column; transition: transform .24s ease, border-color .24s ease, box-shadow .24s ease; }
.event-card:hover { transform: translateY(-5px); border-color: var(--pink); box-shadow: 0 30px 64px rgba(0,0,0,.42), 0 0 0 1px rgba(255,61,141,.28); }
.card-image-link { background: var(--surface-2); overflow: hidden; }
.card-image { width: 100%; aspect-ratio: 16/9; object-fit: cover; transition: transform .45s cubic-bezier(.2,.7,.2,1); }
.event-card:hover .card-image { transform: scale(1.06); }
.price { font-weight: 800; }
.price-free { color: #052a31; background: var(--blue); padding: 1px 9px; border-radius: 999px; font-size: .82em; letter-spacing: .01em; }
.card-body { display: flex; flex-direction: column; flex: 1; padding: 18px; }
.card-body h3 a { text-decoration: none; }
.card-body h3 a:hover { text-decoration: underline; }
.card-meta { color: var(--muted); font-size: .94rem; }
.card-actions { margin-top: auto; padding-top: 8px; }
.pill-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.pill { display: inline-block; padding: 4px 9px; border-radius: 999px; color: white; background: var(--pink-dark); font-size: .72rem; font-weight: 900; text-transform: uppercase; letter-spacing: .04em; }
.pill-muted { color: #170a0f; background: #ffd2df; }
.area-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(230px,1fr)); gap: 14px; }
.area-card { display: flex; min-height: 158px; padding: 18px; flex-direction: column; justify-content: space-between; text-decoration: none; transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease; }
.area-card:hover { transform: translateY(-4px); border-color: var(--pink); box-shadow: 0 24px 50px rgba(0,0,0,.36); }
.area-card span,.area-card small { color: var(--muted); }
.area-card strong { font-size: 1.08rem; }
.comedian-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.comedian-card { padding: 22px; background: var(--surface); border: 1px solid var(--line); border-radius: 18px; box-shadow: var(--shadow); transition: transform .22s ease, border-color .22s ease; }
.comedian-card:hover { transform: translateY(-4px); border-color: var(--pink); }
.comedian-card p,.comedian-card li { color: var(--muted); }
.comedian-card ul { padding-left: 20px; }
.comedian-portrait,.act-card img { object-fit: cover; border-radius: 50%; border: 3px solid var(--pink); transition: transform .3s ease, border-color .3s ease; }
.comedian-card:hover .comedian-portrait { transform: scale(1.04); }
.comedian-portrait { margin-bottom: 14px; }
.roster-block { padding-top: 58px; }
.act-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(150px,1fr)); gap: 12px; }
.act-card { display: flex; flex-direction: column; align-items: center; gap: 7px; padding: 16px; text-align: center; background: var(--surface); border: 1px solid var(--line); border-radius: 14px; transition: transform .2s ease, border-color .2s ease; }
.act-card:hover { transform: translateY(-4px); border-color: var(--pink); }
.act-card:hover img { transform: scale(1.06); border-color: var(--blue); }
.act-card span { color: var(--muted); font-size: .86rem; }
.gallery-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; }
.gallery-grid img { width: 100%; aspect-ratio: 2/1; object-fit: cover; border-radius: 16px; box-shadow: var(--shadow); transition: transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .3s ease; }
.gallery-grid img:hover { transform: scale(1.03); box-shadow: 0 28px 60px rgba(0,0,0,.45); }
.feature-list { display: grid; gap: 12px; }
.feature-list.three { grid-template-columns: repeat(3,1fr); }
.feature-list div { padding: 18px; }
.feature-list span { display: block; color: var(--muted); }
.newsletter { background: linear-gradient(135deg,var(--surface-2),#33112b); }
.faq-list { display: grid; gap: 12px; }
.faq-item { background: var(--surface); border: 1px solid var(--line); border-radius: 14px; padding: 4px 18px; transition: border-color .2s ease, background .2s ease; }
.faq-item:hover { border-color: rgba(255,61,141,.5); }
.faq-item[open] { border-color: var(--pink); background: var(--surface-2); }
.faq-item summary { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 14px 0; font-weight: 800; font-size: 1.05rem; cursor: pointer; list-style: none; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; color: var(--pink); font-size: 1.5rem; font-weight: 800; line-height: 1; transition: transform .2s ease; }
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item p { color: var(--muted); padding: 0 0 16px; margin: 0; max-width: 64ch; }
.booking-panel,.info-card { padding: 22px; }
.booking-panel h2 { font-size: 1.7rem; }
.date-list { list-style: none; padding: 0; display: grid; gap: 10px; }
.date-list li { display: flex; justify-content: space-between; align-items: center; gap: 15px; padding: 14px; border: 1px solid var(--line); border-radius: 14px; background: var(--surface); }
.date-list span { display: block; color: var(--muted); }
.link-cloud { display: flex; flex-wrap: wrap; gap: 15px; }
.notice { padding: 13px; color: #211; background: #ffd2df; border-radius: 12px; }
.empty-state { grid-column: 1 / -1; padding: 24px; }
.site-footer { padding: 42px 0 20px; border-top: 1px solid var(--line); color: var(--muted); }
.footer-grid { display: flex; justify-content: space-between; gap: 24px; }
.footer-links { display: flex; flex-wrap: wrap; gap: 16px; }
.footer-bottom { padding-top: 25px; font-size: .85rem; }
@media (max-width:760px) {
    .nav-toggle { display: block; }
    .nav-links { display: none; position: absolute; inset: 74px 0 auto; padding: 18px; background: var(--surface); border-bottom: 1px solid var(--line); }
    .nav-links.open { display: grid; }
    .hero-grid,.detail-grid,.split { grid-template-columns: 1fr; }
    .hero { padding-top: 54px; }
    .hero-image { order: -1; height: 230px; }
    .comedian-grid,.gallery-grid { grid-template-columns: 1fr; }
    .feature-list.three { grid-template-columns: 1fr; }
    .date-list li,.footer-grid { align-items: flex-start; flex-direction: column; }
}
@media (prefers-reduced-motion:reduce) {
    html { scroll-behavior: auto; }
    .button { transition: none; }
    .button:hover { transform: none; }
    .faq-item summary::after { transition: none; }
}
@media (prefers-reduced-motion:no-preference) {
    @keyframes rise { from { opacity: 0; translate: 0 10px; } to { opacity: 1; translate: 0 0; } }
    .hero-grid > div > *, .hero-image { animation: rise .65s cubic-bezier(.2,.7,.2,1) both; }
    .hero-grid > div > *:nth-child(1) { animation-delay: .04s; }
    .hero-grid > div > *:nth-child(2) { animation-delay: .12s; }
    .hero-grid > div > *:nth-child(3) { animation-delay: .20s; }
    .hero-grid > div > *:nth-child(4) { animation-delay: .28s; }
    .hero-image { animation-delay: .14s; animation-duration: .8s; }
    @supports (animation-timeline: view()) {
        .event-card, .area-card, .comedian-card, .act-card, .feature-list div, .faq-item, .gallery-grid img, .section-heading {
            animation: rise linear both;
            animation-timeline: view();
            animation-range: entry 0% entry 26%;
        }
    }
}
