/** Shopify CDN: Minification failed

Line 20:8 Expected identifier but found whitespace
Line 20:17 Unexpected "{"
Line 20:27 Expected ":"
Line 22:10 Expected identifier but found whitespace
Line 22:17 Unexpected "{"
Line 22:27 Expected ":"
Line 24:10 Expected identifier but found whitespace
Line 24:17 Unexpected "{"
Line 24:27 Expected ":"

**/
/* =============================================================
   Pins & Needles Comedy — Shopify theme stylesheet
   Black / white / red. American traditional × flyer.
   ============================================================= */

:root {
  --ink:        {{ settings.ink_color | default: '#0A0A0A' }};
  --ink-true:   #000000;
  --paper:      {{ settings.paper_color | default: '#F4EFE6' }};
  --paper-pure: #FFFFFF;
  --blood:      {{ settings.accent_color | default: '#C8102E' }};
  --blood-deep: #8A0A1E;
  --blood-bright:#E3192C;

  --bg:          var(--paper);
  --bg-alt:      var(--paper-pure);
  --bg-invert:   var(--ink);
  --fg:          var(--ink);
  --fg-muted:    #2A2A2A;
  --fg-invert:   var(--paper);
  --accent:      var(--blood);
  --accent-hover:var(--blood-deep);
  --border:      var(--ink);
  --rule:        var(--ink);

  --font-display: "Alfa Slab One", "Rye", Georgia, serif;
  --font-display-alt: "Rye", "Alfa Slab One", Georgia, serif;
  --font-body:    "Oswald", "Arial Narrow", Impact, sans-serif;
  --font-shadow:  "Bungee", "Alfa Slab One", Impact, sans-serif;

  --fs-hero:    clamp(3.5rem, 9vw, 7.5rem);
  --fs-h1:      clamp(2.5rem, 5.5vw, 4.5rem);
  --fs-h2:      clamp(2rem, 4vw, 3rem);
  --fs-h3:      1.75rem;
  --fs-h4:      1.375rem;
  --fs-body:    1.0625rem;
  --fs-small:   0.9375rem;
  --fs-eyebrow: 0.8125rem;

  --space-1: 4px;  --space-2: 8px;  --space-3: 12px;
  --space-4: 16px; --space-5: 24px; --space-6: 32px;
  --space-7: 48px; --space-8: 64px; --space-9: 96px;

  --border-thin:    1px solid var(--ink);
  --border-regular: 2px solid var(--ink);
  --border-heavy:   4px solid var(--ink);
  --border-mega:    8px solid var(--ink);

  --shadow-offset-sm: 3px 3px 0 0 var(--ink);
  --shadow-offset-md: 6px 6px 0 0 var(--ink);
  --shadow-offset-lg: 10px 10px 0 0 var(--ink);
}

*, *::before, *::after { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-body);
  background-image:
    radial-gradient(rgba(0,0,0,0.05) 1px, transparent 1px),
    radial-gradient(rgba(0,0,0,0.03) 1px, transparent 1px);
  background-size: 3px 3px, 7px 7px;
  background-attachment: fixed;
  font-size: var(--fs-body);
  line-height: 1.45;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; display: block; }

.skip-link {
  position: absolute; left: -9999px; top: 0;
  background: var(--ink); color: var(--paper);
  padding: 12px 16px; z-index: 1000;
}
.skip-link:focus { left: 0; }

h1, h2, h3, h4 { margin: 0 0 var(--space-4); }
h1 { font-family: var(--font-display); font-size: var(--fs-h1); line-height: 0.95; text-transform: uppercase; }
h2 { font-family: var(--font-display); font-size: var(--fs-h2); line-height: 1; text-transform: uppercase; }
h3 { font-family: var(--font-body); font-weight: 700; font-size: var(--fs-h3); line-height: 1.1; text-transform: uppercase; letter-spacing: 0.02em; }
h4 { font-family: var(--font-body); font-weight: 700; font-size: var(--fs-h4); text-transform: uppercase; letter-spacing: 0.04em; }

p { font-family: var(--font-body); font-size: var(--fs-body); line-height: 1.5; margin: 0 0 var(--space-4); text-wrap: pretty; }

.eyebrow, .kicker {
  font-family: var(--font-body); font-weight: 700; font-size: var(--fs-eyebrow);
  letter-spacing: 0.18em; text-transform: uppercase;
}

a { color: var(--fg); text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 3px; }
a:hover { color: var(--accent); }

hr { border: 0; border-top: var(--border-heavy); margin: var(--space-6) 0; }

/* ============================================================= */
/*  LAYOUT                                                         */
/* ============================================================= */
.page-width { max-width: 1280px; margin: 0 auto; padding: 0 var(--space-6); }
.section-pad { padding: 88px 40px; }
.section-rule { border-bottom: 4px solid var(--ink); }
.invert { background: var(--bg-invert); color: var(--fg-invert); }
.center { text-align: center; }

.paper-texture {
  background-color: var(--paper);
  background-image:
    radial-gradient(rgba(0,0,0,0.04) 1px, transparent 1px),
    radial-gradient(rgba(0,0,0,0.03) 1px, transparent 1px);
  background-size: 3px 3px, 7px 7px;
  background-position: 0 0, 1px 2px;
}

/* ============================================================= */
/*  BUTTONS                                                        */
/* ============================================================= */
.btn {
  display: inline-block;
  font-family: var(--font-body); font-weight: 700; font-size: 13px;
  letter-spacing: 0.2em; text-transform: uppercase;
  padding: 14px 22px; border: 2px solid var(--ink);
  background: var(--paper-pure); color: var(--ink);
  box-shadow: var(--shadow-offset-sm);
  text-decoration: none; cursor: pointer;
  transition: transform 80ms, box-shadow 80ms;
}
.btn:hover { color: var(--ink); }
.btn:active { transform: translate(3px,3px); box-shadow: 0 0 0 0 var(--ink); }
.btn--primary { background: var(--blood); color: var(--paper-pure); }
.btn--primary:hover { color: var(--paper-pure); }
.btn--invert { background: var(--ink); color: var(--paper); border-color: var(--paper); box-shadow: 8px 8px 0 0 var(--paper); }
.btn--invert:hover { color: var(--paper); }
.btn--lg { padding: 18px 40px; font-size: 16px; }
.btn--block { display: block; width: 100%; text-align: center; }

/* ============================================================= */
/*  HEADER                                                         */
/* ============================================================= */
.site-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 32px; border-bottom: 2px solid var(--ink);
  background: var(--paper); position: sticky; top: 0; z-index: 50;
}
.site-header__brand { display: flex; align-items: center; gap: 12px; text-decoration: none; color: var(--ink); }
.site-header__brand img { width: 40px; height: 40px; object-fit: contain; }
.site-header__brand span { font-family: var(--font-display); font-size: 20px; text-transform: uppercase; letter-spacing: 0.01em; }
.site-nav { display: flex; gap: 26px; align-items: center; }
.site-nav a { font-family: var(--font-body); font-weight: 700; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink); text-decoration: none; }
.site-nav a:hover { color: var(--blood); }
.site-nav__icon { color: var(--ink); display: flex; position: relative; }
.site-nav__cart-count {
  position: absolute; top: -8px; right: -8px;
  background: var(--blood); color: var(--paper-pure);
  font-family: var(--font-body); font-weight: 700; font-size: 10px;
  border: 2px solid var(--ink); min-width: 18px; height: 18px;
  display: flex; align-items: center; justify-content: center;
  padding: 0 4px;
}
.site-nav__tickets {
  font-family: var(--font-body); font-weight: 700; font-size: 12px;
  letter-spacing: 0.2em; text-transform: uppercase;
  background: var(--blood); color: var(--paper-pure);
  padding: 10px 16px; border: 2px solid var(--ink);
  box-shadow: 4px 4px 0 0 var(--ink); text-decoration: none;
}
.site-nav__tickets:hover { color: var(--paper-pure); }

.site-nav__toggle {
  display: none;
  background: transparent; border: 2px solid var(--ink); padding: 8px 10px;
  cursor: pointer;
}
@media (max-width: 860px) {
  .site-header { padding: 12px 16px; }
  .site-nav { display: none; }
  .site-nav.is-open { display: flex; flex-direction: column; position: absolute; top: 100%; left: 0; right: 0; background: var(--paper); padding: 20px; border-bottom: 2px solid var(--ink); gap: 16px; align-items: flex-start; }
  .site-nav__toggle { display: inline-flex; }
}

/* ============================================================= */
/*  HERO                                                           */
/* ============================================================= */
.hero {
  background: var(--paper); padding: 72px 40px 56px; text-align: center;
  border-bottom: 4px solid var(--ink);
  background-image:
    radial-gradient(rgba(0,0,0,0.04) 1px, transparent 1px),
    radial-gradient(rgba(0,0,0,0.03) 1px, transparent 1px);
  background-size: 3px 3px, 7px 7px;
}
.hero--has-bg {
  background-size: cover; background-position: center;
  color: var(--paper);
  padding: 120px 40px 100px;
}
.hero--has-bg .hero__headline,
.hero--has-bg .hero__subheadline,
.hero--has-bg .hero__microcopy,
.hero--has-bg .hero__tagline { color: var(--paper); }
.hero--has-bg .hero__tagline em { color: #ff8c8c; }
.hero--has-bg .hero__badge { color: var(--paper); border-color: var(--paper); background: rgba(0,0,0,0.3); backdrop-filter: blur(4px); }
.hero--has-bg .hero__logo { filter: brightness(0) invert(1); }
.hero__logo { width: min(760px, 88%); margin: 0 auto 20px; }
.hero__logo--small { width: min(360px, 60%); margin: 0 auto 20px; }
.hero__headline {
  font-family: var(--font-display); font-size: clamp(40px, 6vw, 84px);
  line-height: 0.95; text-transform: uppercase; margin: 0 auto 18px; max-width: 1080px;
}
.hero__subheadline {
  font-family: var(--font-body); font-size: clamp(16px, 1.6vw, 20px);
  line-height: 1.4; max-width: 720px; margin: 0 auto 28px;
}
.hero__cta-row { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; margin-bottom: 14px; }
.hero__microcopy {
  font-family: var(--font-body); font-size: 12px; letter-spacing: 0.1em;
  text-transform: uppercase; opacity: 0.75; margin-bottom: 28px;
}
.hero__tagline {
  font-family: var(--font-display); font-size: clamp(16px, 1.6vw, 22px);
  margin-top: 28px; opacity: 0.85;
}
.hero__tagline em { font-style: italic; color: var(--blood); }
.hero__badges { display: inline-flex; gap: 14px; align-items: center; flex-wrap: wrap; justify-content: center; }
.hero__badge {
  font-family: var(--font-body); font-weight: 700; font-size: 12px;
  letter-spacing: 0.2em; text-transform: uppercase;
  padding: 8px 14px; border: 2px solid var(--ink);
}

.tickets-cta { background: var(--ink); color: var(--paper); padding: 88px 40px; text-align: center; border-bottom: 4px solid var(--ink); }
.tickets-cta__inner { max-width: 880px; margin: 0 auto; }
.tickets-cta__kicker { font-family: var(--font-body); font-weight: 700; font-size: 12px; letter-spacing: 0.3em; text-transform: uppercase; opacity: 0.7; margin-bottom: 14px; }
.tickets-cta__title { font-family: var(--font-display); font-size: clamp(40px, 5.5vw, 72px); line-height: 0.95; text-transform: uppercase; margin: 0 0 22px; }
.tickets-cta__venue { font-family: var(--font-body); font-size: 16px; line-height: 1.5; margin-bottom: 8px; }
.tickets-cta__address { font-family: var(--font-body); font-size: 14px; opacity: 0.8; margin-bottom: 6px; }
.tickets-cta__address a { color: var(--blood-bright); text-decoration: underline; }
.tickets-cta__meta { font-family: var(--font-body); font-size: 13px; letter-spacing: 0.15em; text-transform: uppercase; opacity: 0.7; margin-bottom: 28px; }
.tickets-cta__btn-row { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; margin-bottom: 12px; }
.tickets-cta__microcopy { font-family: var(--font-body); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; opacity: 0.6; margin-bottom: 28px; }
.tickets-cta__email { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; max-width: 520px; margin: 0 auto; }
.tickets-cta__email input { flex: 1; min-width: 220px; padding: 14px 16px; border: 2px solid var(--paper); background: transparent; color: var(--paper); font-family: var(--font-body); font-size: 14px; }
.tickets-cta__email input::placeholder { color: rgba(244,239,230,0.5); }
.tickets-cta__email .btn { background: var(--paper); color: var(--ink); }

.show-card__weekday { font-family: var(--font-body); font-weight: 700; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; margin-top: 4px; opacity: 0.7; }
.show-card__address { font-family: var(--font-body); font-size: 12px; opacity: 0.75; margin-bottom: 8px; }
.show-card__address a { color: inherit; text-decoration: underline; }
.show-card__cta-row { margin-top: 14px; display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.show-card.is-soldout { opacity: 0.7; }
.show-card__scarcity {
  margin-top: 10px; padding: 8px 12px;
  font-family: var(--font-body); font-weight: 700; font-size: 12px;
  letter-spacing: 0.1em; text-transform: uppercase;
  border: 2px dashed var(--ink); display: inline-block;
}
.show-card__scarcity.is-low { background: var(--paper-deep, #ebe4d6); }
.show-card__scarcity.is-critical { background: var(--blood); color: var(--paper); border-color: var(--blood); animation: pn-pulse 2s ease-in-out infinite; }
@keyframes pn-pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.7; } }

/* Social Proof */
.proof { background: var(--paper); padding: 80px 40px; border-bottom: 4px solid var(--ink); }
.proof__head { max-width: 1280px; margin: 0 auto 40px; text-align: center; }
.proof__kicker { font-family: var(--font-body); font-weight: 700; font-size: 12px; letter-spacing: 0.3em; text-transform: uppercase; opacity: 0.6; margin-bottom: 8px; }
.proof__title { font-family: var(--font-display); font-size: clamp(32px, 4vw, 56px); text-transform: uppercase; margin: 0; }
.proof__grid { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 900px) { .proof__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .proof__grid { grid-template-columns: 1fr; } }
.proof__cell { background: var(--ink); color: var(--paper); border: 3px solid var(--ink); aspect-ratio: 1 / 1; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; padding: 32px; position: relative; overflow: hidden; }
.proof__cell--photo { padding: 0; }
.proof__cell--photo img { width: 100%; height: 100%; object-fit: cover; }
.proof__cell--photo figcaption { position: absolute; left: 0; right: 0; bottom: 0; padding: 12px 16px; background: rgba(0,0,0,0.7); color: var(--paper); font-family: var(--font-body); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; text-align: left; }
.proof__cell--quote { background: var(--blood); color: var(--paper); }
.proof__quote-mark { font-family: var(--font-display); font-size: 100px; line-height: 0.6; opacity: 0.5; margin-bottom: 8px; }
.proof__quote { font-family: var(--font-display); font-size: clamp(20px, 2.2vw, 28px); line-height: 1.15; text-transform: uppercase; margin: 0 0 16px; }
.proof__attribution { font-family: var(--font-body); font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; font-style: normal; opacity: 0.85; }
.proof__cell--ig { padding: 0; }
.proof__ig-link { display: block; width: 100%; height: 100%; position: relative; color: var(--paper); text-decoration: none; }
.proof__ig-link img { width: 100%; height: 100%; object-fit: cover; display: block; }
.proof__ig-badge { position: absolute; left: 12px; bottom: 12px; display: inline-flex; gap: 8px; align-items: center; padding: 8px 12px; background: rgba(0,0,0,0.85); color: var(--paper); font-family: var(--font-body); font-weight: 700; font-size: 11px; letter-spacing: 0.15em; text-transform: uppercase; }
.proof__placeholder { font-family: var(--font-display); font-size: 24px; text-transform: uppercase; opacity: 0.4; padding: 24px; }
.proof__placeholder--ig { background: linear-gradient(135deg, #833ab4, #fd1d1d, #fcb045); width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: var(--paper); }
.proof__cell--stat { background: var(--paper); color: var(--ink); border-color: var(--ink); }
.proof__stat-num { font-family: var(--font-display); font-size: clamp(80px, 10vw, 140px); line-height: 0.9; }
.proof__stat-label { font-family: var(--font-body); font-weight: 700; font-size: 14px; letter-spacing: 0.2em; text-transform: uppercase; }

/* Tickets embedded page */
.tickets-embed { background: var(--paper); padding: 64px 32px 80px; min-height: 60vh; }
.tickets-embed__inner { max-width: 880px; margin: 0 auto; }
.tickets-embed__kicker { font-family: var(--font-body); font-weight: 700; font-size: 12px; letter-spacing: 0.3em; text-transform: uppercase; opacity: 0.6; margin-bottom: 8px; text-align: center; }
.tickets-embed__title { font-family: var(--font-display); font-size: clamp(36px, 5vw, 64px); text-transform: uppercase; margin: 0 0 16px; text-align: center; }
.tickets-embed__sub { font-family: var(--font-body); font-size: 16px; opacity: 0.8; margin: 0 0 32px; text-align: center; }
.tickets-embed__widget { background: var(--paper-deep, #ebe4d6); border: 3px solid var(--ink); min-height: 700px; }
.tickets-embed__widget iframe { width: 100% !important; min-height: 700px; border: 0; }
.tickets-embed__empty { background: var(--paper-deep, #ebe4d6); border: 2px dashed var(--ink); padding: 32px; font-family: var(--font-body); font-size: 14px; line-height: 1.5; }
.tickets-embed__fallback { margin-top: 24px; text-align: center; font-family: var(--font-body); font-size: 14px; }
.tickets-embed__fallback a { color: var(--blood); font-weight: 700; text-decoration: underline; }

/* Header tickets — leftmost on mobile */
.site-nav__tickets--mobile { display: none; }
@media (max-width: 900px) {
  .site-nav__tickets--mobile { display: inline-flex; align-items: center; padding: 10px 14px; background: var(--blood); color: var(--paper); font-family: var(--font-body); font-weight: 700; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; text-decoration: none; margin-left: auto; margin-right: 12px; }
  .site-nav__tickets--desktop { display: none; }
}
.btn--sm { padding: 10px 16px; font-size: 12px; }
.visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

/* ============================================================= */
/*  SHOWS                                                          */
/* ============================================================= */
.shows { background: var(--paper); padding: 88px 40px; border-bottom: 4px solid var(--ink); }
.shows h2 { font-family: var(--font-display); font-size: clamp(36px, 5vw, 64px); line-height: 0.95; text-transform: uppercase; margin: 0 0 36px; text-align: center; }
.shows__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(380px, 1fr)); gap: 28px; max-width: 1280px; margin: 0 auto; }
.shows--cols-1 .shows__grid { grid-template-columns: 1fr; max-width: 760px; }
.shows--cols-2 .shows__grid { grid-template-columns: repeat(2, 1fr); }
.shows--cols-3 .shows__grid { grid-template-columns: repeat(3, 1fr); }
.shows--cols-4 .shows__grid { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1024px) {
  .shows--cols-3 .shows__grid, .shows--cols-4 .shows__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .shows--cols-2 .shows__grid, .shows--cols-3 .shows__grid, .shows--cols-4 .shows__grid { grid-template-columns: 1fr; }
}
.show-card {
  background: var(--paper-pure); color: var(--ink);
  border: 3px solid var(--ink); box-shadow: 8px 8px 0 0 var(--ink);
  padding: 22px; display: flex; gap: 22px; align-items: flex-start;
  text-decoration: none;
}
.show-card:hover { color: var(--ink); }
.show-card--accent { background: var(--blood); color: var(--paper-pure); }
.show-card--accent:hover { color: var(--paper-pure); }
.show-card__date {
  border-right: 2px solid currentColor; padding-right: 18px;
  text-align: center; min-width: 80px;
}
.show-card__month { font-family: var(--font-body); font-weight: 700; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; }
.show-card__day { font-family: var(--font-display); font-size: 54px; line-height: 0.9; }
.show-card__body { flex: 1; }
.show-card__title { font-family: var(--font-display); font-size: 28px; text-transform: uppercase; line-height: 0.95; margin: 0 0 6px; }
.show-card__venue { font-family: var(--font-body); font-weight: 700; font-size: 13px; letter-spacing: 0.16em; text-transform: uppercase; margin-bottom: 10px; }
.show-card__lineup { font-family: var(--font-body); font-size: 14px; line-height: 1.5; }
.show-card__soldout {
  font-family: var(--font-body); font-weight: 700; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  background: var(--ink); color: var(--paper); padding: 6px 10px; align-self: flex-start;
}

/* ============================================================= */
/*  MERCH                                                          */
/* ============================================================= */
.merch { background: var(--paper-pure); padding: 88px 40px; border-bottom: 4px solid var(--ink); }
.merch__header, .news__header {
  display: flex; align-items: baseline; justify-content: space-between;
  max-width: 1280px; margin: 0 auto 36px; gap: 24px; flex-wrap: wrap;
}
.merch__header h2, .news__header h2 {
  font-family: var(--font-display); font-size: clamp(36px, 5vw, 64px); line-height: 0.95; text-transform: uppercase; margin: 0;
}
.merch__all, .news__all {
  font-family: var(--font-body); font-weight: 700; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink);
}
.merch__grid {
  max-width: 1280px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 20px;
}
.product-card { display: flex; flex-direction: column; gap: 10px; text-decoration: none; color: var(--ink); }
.product-card:hover { color: var(--ink); }
.product-card__img {
  aspect-ratio: 1; border: 2px solid var(--ink); background: var(--paper);
  background-image: repeating-linear-gradient(45deg, rgba(10,10,10,0.05) 0 6px, transparent 6px 14px);
  position: relative; overflow: hidden;
}
.product-card__img img { width: 100%; height: 100%; object-fit: cover; }
.product-card__tag {
  position: absolute; top: 10px; left: 10px; background: var(--blood); color: var(--paper-pure);
  font-family: var(--font-body); font-weight: 700; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase;
  padding: 4px 8px; border: 2px solid var(--ink);
}
.product-card__row { display: flex; justify-content: space-between; align-items: baseline; }
.product-card__name { font-family: var(--font-body); font-weight: 700; font-size: 14px; letter-spacing: 0.08em; text-transform: uppercase; }
.product-card__price { font-family: var(--font-display); font-size: 20px; }

/* ============================================================= */
/*  NEWS                                                           */
/* ============================================================= */
.news { background: var(--paper); padding: 88px 40px; border-bottom: 4px solid var(--ink); }
.news__grid {
  max-width: 1280px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 20px;
}
.news-card {
  text-decoration: none; color: var(--ink);
  border: 2px solid var(--ink); background: var(--paper-pure);
  padding: 20px; display: flex; flex-direction: column; gap: 12px; min-height: 220px;
}
.news-card:hover { color: var(--ink); }
.news-card__img {
  aspect-ratio: 16/9; border: 2px solid var(--ink); background: var(--paper);
  background-image: repeating-linear-gradient(-45deg, rgba(10,10,10,0.05) 0 6px, transparent 6px 14px);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.news-card__img img { max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain; }
.news-card__kicker { font-family: var(--font-body); font-weight: 700; font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; opacity: 0.7; }
.news-card__title { font-family: var(--font-display); font-size: 22px; line-height: 1.05; margin: 0; text-transform: uppercase; }

/* ============================================================= */
/*  ABOUT                                                          */
/* ============================================================= */
.about {
  background: var(--paper); color: var(--ink);
  padding: 88px 40px; border-bottom: 4px solid var(--ink);
  display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start;
  max-width: 1280px; margin: 0 auto;
}
.about__kicker { font-family: var(--font-body); font-weight: 700; font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--blood); margin-bottom: 16px; }
.about__title { font-family: var(--font-display); font-size: clamp(40px, 5vw, 64px); line-height: 0.95; text-transform: uppercase; margin: 0; }
.about__title em { font-style: normal; color: var(--blood); }
.about__body { font-family: var(--font-body); font-size: 16px; line-height: 1.55; }
@media (max-width: 780px) { .about { grid-template-columns: 1fr; gap: 32px; } }

/* ============================================================= */
/*  TICKETS CTA                                                    */
/* ============================================================= */
.tickets-cta { background: var(--ink); color: var(--paper); padding: 88px 40px; text-align: center; }
.tickets-cta__kicker { font-family: var(--font-body); font-weight: 700; font-size: 13px; letter-spacing: 0.22em; text-transform: uppercase; margin-bottom: 16px; color: var(--blood-bright); }
.tickets-cta__title { font-family: var(--font-display); font-size: clamp(52px, 8vw, 110px); line-height: 0.9; text-transform: uppercase; margin: 0 0 24px; }
.tickets-cta__meta { font-family: var(--font-body); font-size: 15px; letter-spacing: 0.16em; text-transform: uppercase; margin-bottom: 36px; opacity: 0.85; }

/* ============================================================= */
/*  FOOTER                                                         */
/* ============================================================= */
.site-footer { background: var(--ink); color: var(--paper); padding: 56px 40px 32px; }
.site-footer__top { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 24px; }
.site-footer__brand { display: flex; align-items: center; gap: 14px; }
.site-footer__brand img { width: 54px; height: 54px; object-fit: contain; filter: invert(1); }
.site-footer__name { font-family: var(--font-display); font-size: 22px; text-transform: uppercase; }
.site-footer__sub { font-family: var(--font-body); font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; opacity: 0.7; }
.site-footer__links { display: flex; gap: 24px; }
.site-footer__links a { color: var(--paper); font-family: var(--font-body); font-weight: 700; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; text-decoration: underline; text-underline-offset: 4px; text-decoration-thickness: 2px; }
.site-footer__bottom {
  margin-top: 40px; padding-top: 20px; border-top: 1px solid var(--paper);
  font-family: var(--font-body); font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; opacity: 0.6;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px;
}

/* ============================================================= */
/*  PRODUCT                                                        */
/* ============================================================= */
.product { display: grid; grid-template-columns: 1.1fr 1fr; gap: 56px; max-width: 1280px; margin: 0 auto; padding: 56px 40px; }
@media (max-width: 860px) { .product { grid-template-columns: 1fr; gap: 32px; padding: 32px 20px; } }
.product__gallery { display: flex; flex-direction: column; gap: 16px; }
.product__main-img { border: 3px solid var(--ink); box-shadow: var(--shadow-offset-md); aspect-ratio: 1; background: var(--paper-pure); overflow: hidden; }
.product__main-img img { width: 100%; height: 100%; object-fit: cover; }
.product__thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.product__thumb { border: 2px solid var(--ink); aspect-ratio: 1; background: var(--paper-pure); overflow: hidden; cursor: pointer; }
.product__thumb img { width: 100%; height: 100%; object-fit: cover; }
.product__vendor { font-family: var(--font-body); font-weight: 700; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--blood); margin-bottom: 10px; }
.product__title { font-family: var(--font-display); font-size: clamp(36px, 4.5vw, 56px); line-height: 0.95; text-transform: uppercase; margin: 0 0 16px; }
.product__price { font-family: var(--font-display); font-size: 32px; margin-bottom: 24px; }
.product__price del { color: var(--fg-muted); margin-left: 12px; font-size: 22px; }
.product__desc { margin: 24px 0; }
.product__option { margin-bottom: 20px; }
.product__option-label { font-family: var(--font-body); font-weight: 700; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; margin-bottom: 8px; display: block; }
.product__option-values { display: flex; flex-wrap: wrap; gap: 8px; }
.product__option-values input[type="radio"] { position: absolute; opacity: 0; pointer-events: none; }
.product__option-values label {
  display: inline-flex; padding: 10px 16px; border: 2px solid var(--ink);
  font-family: var(--font-body); font-weight: 700; font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase;
  cursor: pointer; background: var(--paper-pure);
}
.product__option-values input:checked + label { background: var(--ink); color: var(--paper); }
.product__qty { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; }
.product__qty input { width: 72px; padding: 10px; border: 2px solid var(--ink); font-family: var(--font-body); font-size: 16px; text-align: center; background: var(--paper-pure); }

/* ============================================================= */
/*  COLLECTION                                                     */
/* ============================================================= */
.collection-header { padding: 56px 40px 24px; max-width: 1280px; margin: 0 auto; }
.collection-header h1 { font-family: var(--font-display); font-size: clamp(40px, 6vw, 72px); line-height: 0.95; text-transform: uppercase; margin: 0 0 12px; }
.collection-header p { max-width: 680px; }
.collection-grid { max-width: 1280px; margin: 0 auto; padding: 24px 40px 80px; display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 20px; }
.pagination { display: flex; gap: 12px; justify-content: center; padding: 40px 20px 80px; font-family: var(--font-body); font-weight: 700; font-size: 13px; letter-spacing: 0.18em; text-transform: uppercase; }
.pagination a, .pagination span { padding: 10px 14px; border: 2px solid var(--ink); color: var(--ink); text-decoration: none; background: var(--paper-pure); }
.pagination .current { background: var(--ink); color: var(--paper); }

/* ============================================================= */
/*  CART PAGE                                                      */
/* ============================================================= */
.cart { max-width: 980px; margin: 0 auto; padding: 56px 40px 80px; }
.cart h1 { font-family: var(--font-display); font-size: clamp(40px, 6vw, 72px); line-height: 0.95; text-transform: uppercase; margin: 0 0 32px; }
.cart__empty { text-align: center; padding: 80px 20px; border: 3px dashed var(--ink); }
.cart__items { display: flex; flex-direction: column; gap: 16px; }
.cart__item { display: grid; grid-template-columns: 100px 1fr auto auto; gap: 20px; align-items: center; padding: 16px; border: 2px solid var(--ink); background: var(--paper-pure); }
.cart__item img { width: 100%; aspect-ratio: 1; object-fit: cover; border: 2px solid var(--ink); }
.cart__item-title { font-family: var(--font-body); font-weight: 700; font-size: 15px; text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 4px; }
.cart__item-variant { font-family: var(--font-body); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; opacity: 0.7; }
.cart__item-qty { display: flex; align-items: center; border: 2px solid var(--ink); }
.cart__item-qty button { background: var(--paper-pure); border: none; padding: 8px 12px; font-family: var(--font-body); font-weight: 700; font-size: 14px; cursor: pointer; }
.cart__item-qty input { width: 44px; padding: 8px; border: none; text-align: center; font-family: var(--font-body); font-size: 14px; }
.cart__item-price { font-family: var(--font-display); font-size: 20px; }
.cart__footer { margin-top: 32px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 20px; padding-top: 24px; border-top: 4px solid var(--ink); }
.cart__total { font-family: var(--font-display); font-size: 32px; text-transform: uppercase; }
.cart__note { grid-column: 1 / -1; width: 100%; padding: 12px; border: 2px solid var(--ink); font-family: var(--font-body); font-size: 14px; background: var(--paper-pure); resize: vertical; min-height: 80px; }

/* ============================================================= */
/*  CART DRAWER                                                    */
/* ============================================================= */
.cart-drawer {
  position: fixed; top: 0; right: 0; bottom: 0; width: min(420px, 100%);
  background: var(--paper-pure); border-left: 3px solid var(--ink);
  transform: translateX(100%); transition: transform 240ms cubic-bezier(0.2,0.8,0.2,1);
  z-index: 100; display: flex; flex-direction: column;
}
.cart-drawer.is-open { transform: translateX(0); box-shadow: -12px 0 0 0 rgba(10,10,10,0.15); }
.cart-drawer__overlay {
  position: fixed; inset: 0; background: rgba(10,10,10,0.4);
  opacity: 0; pointer-events: none; transition: opacity 240ms; z-index: 99;
}
.cart-drawer__overlay.is-open { opacity: 1; pointer-events: auto; }
.cart-drawer__header { padding: 20px; border-bottom: 2px solid var(--ink); display: flex; align-items: center; justify-content: space-between; }
.cart-drawer__header h2 { font-family: var(--font-display); font-size: 28px; text-transform: uppercase; margin: 0; }
.cart-drawer__close { background: transparent; border: 2px solid var(--ink); padding: 6px 10px; font-family: var(--font-body); font-weight: 700; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; cursor: pointer; }
.cart-drawer__items { flex: 1; overflow-y: auto; padding: 12px; display: flex; flex-direction: column; gap: 12px; }
.cart-drawer__item { display: grid; grid-template-columns: 72px 1fr; gap: 12px; padding: 12px; border: 2px solid var(--ink); background: var(--paper); }
.cart-drawer__item img { width: 100%; aspect-ratio: 1; object-fit: cover; border: 2px solid var(--ink); }
.cart-drawer__item-title { font-family: var(--font-body); font-weight: 700; font-size: 13px; text-transform: uppercase; letter-spacing: 0.05em; }
.cart-drawer__item-variant { font-family: var(--font-body); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; opacity: 0.7; margin-top: 2px; }
.cart-drawer__item-row { display: flex; justify-content: space-between; align-items: center; margin-top: 6px; }
.cart-drawer__empty { text-align: center; padding: 40px 20px; font-family: var(--font-body); text-transform: uppercase; letter-spacing: 0.18em; font-weight: 700; font-size: 13px; }
.cart-drawer__footer { padding: 20px; border-top: 2px solid var(--ink); background: var(--paper); }
.cart-drawer__subtotal { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 16px; font-family: var(--font-display); font-size: 24px; text-transform: uppercase; }
.cart-drawer__remove { background: transparent; border: 0; font-family: var(--font-body); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; font-weight: 700; text-decoration: underline; cursor: pointer; color: var(--ink); padding: 0; }

/* ============================================================= */
/*  FORMS                                                          */
/* ============================================================= */
input[type="text"], input[type="email"], input[type="password"], input[type="tel"], input[type="search"], input[type="number"], textarea, select {
  width: 100%; padding: 12px 14px;
  border: 2px solid var(--ink); background: var(--paper-pure);
  font-family: var(--font-body); font-size: 15px; color: var(--ink);
  border-radius: 0;
}
label { font-family: var(--font-body); font-weight: 700; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; display: block; margin-bottom: 6px; }
.field { margin-bottom: 16px; }
.form-errors { border: 2px solid var(--blood); background: var(--paper-pure); color: var(--blood); padding: 12px; margin-bottom: 16px; font-family: var(--font-body); font-size: 14px; }
.form-success { border: 2px solid var(--ink); background: var(--paper-pure); padding: 12px; margin-bottom: 16px; font-family: var(--font-body); font-size: 14px; }

/* ============================================================= */
/*  BLOG / ARTICLE                                                 */
/* ============================================================= */
.article { max-width: 760px; margin: 0 auto; padding: 56px 20px 80px; }
.article h1 { font-family: var(--font-display); font-size: clamp(40px, 6vw, 72px); line-height: 0.95; text-transform: uppercase; margin: 0 0 16px; }
.article__meta { font-family: var(--font-body); font-weight: 700; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; opacity: 0.7; margin-bottom: 32px; }
.article__body { font-family: var(--font-body); font-size: 17px; line-height: 1.6; }
.article__body img { border: 2px solid var(--ink); margin: 24px 0; }

/* ============================================================= */
/*  404 / PAGE                                                     */
/* ============================================================= */
.page { max-width: 880px; margin: 0 auto; padding: 56px 20px 80px; }
.page h1 { font-family: var(--font-display); font-size: clamp(40px, 6vw, 72px); line-height: 0.95; text-transform: uppercase; margin: 0 0 24px; }
.page__body { font-family: var(--font-body); font-size: 17px; line-height: 1.6; }
.not-found { text-align: center; padding: 120px 20px; }
.not-found h1 { font-family: var(--font-display); font-size: clamp(80px, 14vw, 220px); line-height: 0.85; margin: 0 0 16px; text-transform: uppercase; color: var(--blood); }

/* ============================================================= */
/*  RESPONSIVE TIGHTENING                                          */
/* ============================================================= */
@media (max-width: 640px) {
  .section-pad, .hero, .shows, .merch, .news, .about, .tickets-cta { padding-left: 20px; padding-right: 20px; }
  .shows__grid { grid-template-columns: 1fr; }
  .show-card { flex-direction: column; gap: 12px; }
  .show-card__date { border-right: 0; border-bottom: 2px solid currentColor; padding-right: 0; padding-bottom: 12px; width: 100%; text-align: left; display: flex; align-items: baseline; gap: 12px; }
  .cart__item { grid-template-columns: 80px 1fr; }
  .cart__item-price, .cart__item-qty { grid-column: 2; }
}
