/* ================================================================
   Кіно Сусідів — light theme + design tokens
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root {
  /* surfaces */
  --bg-0: #F5EDD8;          /* page chrome */
  --bg-1: #EDE5CE;          /* panels */
  --bg-2: #E4DAC2;          /* hover */
  --bg-3: #D9CEB4;          /* drawer header / nested chip */
  --poster-bg: #16140F;     /* poster placeholder — stays dark so stills feel cinematic */

  /* lines */
  --line: rgba(140, 110, 60, 0.25);     /* hairline separators */
  --line-strong: rgba(140, 110, 60, 0.5); /* interactive borders */

  /* type ramp — all verified ≥4.5:1 on #D9D9D9 */
  --t-hi:   #0A0A09;        /* primary headlines */
  --t-mid:  #2A2823;        /* secondary */
  --t-base: #3D3B35;        /* body lead */
  --t-mute: #595650;        /* meta — 5.0:1 on #D9D9D9 */
  --t-soft: #4C4942;        /* long body */
  --t-on-dark: rgb(232,226,212); /* over poster / accent ink */

  /* accents */
  --accent: #F5531A;        /* festival orange */
  --accent-text: #A83200;   /* darkened for text, passes 4.5:1 on --bg-0 */
  --accent-2: #C9A46A;      /* sand */
  --accent-3: #F5531A;      /* festival orange */
  --accent-ink: #0A0A09;
  --accent-chip-bg: #111;   /* dark pill on white */
  --accent-chip-fg: #FFFEF1;

  /* focus */
  --focus: #A83200;
  --focus-shadow: 0 0 0 3px rgba(168, 50, 0, 0.25);

  /* type */
  --ff: "Inter", system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
  --ff-display: "Inter", system-ui, sans-serif;

  /* layout */
  --gutter: 20px;
  --row-h: 56px;
  --max-w: 1440px;

  /* motion */
  --ease: cubic-bezier(0.2, 0.7, 0.2, 1);
  --d-1: 160ms;
  --d-2: 280ms;
  --d-3: 480ms;
  --industry-color: #515A47;
  --industry-color-bg: color-mix(in oklab, var(--industry-color) 12%, #F5EDD8);
  --accent-deep: #0D0D0D;
}

/* ============================== reset ============================== */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-padding-top: 200px; /* clears sticky header + filter-bar (2-row chips) so focused links aren't obscured */ }
body {
  background: var(--bg-0);
  color: var(--t-base);
  font-family: var(--ff);
  font-weight: 300;
  font-size: 1rem;
  line-height: 1.41;
  letter-spacing: 0.04em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  min-height: 100vh;
}
img, svg { display: block; max-width: 100%; }
h1 { text-transform: uppercase; font-weight: 800; }
h2 { text-transform: uppercase; }
button { font: inherit; color: inherit; background: none; border: 0; padding: 0; cursor: pointer; letter-spacing: inherit; }
a { color: inherit; text-decoration: none; }
input, select, textarea { font: inherit; color: inherit; }
[hidden] { display: none !important; }

/* ============================== a11y ============================== */
.skip-link {
  position: fixed; top: -100px; left: 12px; z-index: 100;
  padding: 10px 16px; background: var(--accent-chip-bg); color: var(--accent-chip-fg);
  text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.75rem;
  border-radius: 2px;
}
.skip-link:focus { top: 12px; outline: 2px solid var(--focus); outline-offset: 2px; }

:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 3px;
  border-radius: 1px;
}
.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;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

/* ============================== header ============================== */
.site-header {
  position: sticky; top: 0; z-index: 30;
  background: var(--bg-0);
  border-bottom: 1px solid var(--line);
}
.header-row {
  height: var(--row-h);
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
  padding: 0 var(--gutter);
  max-width: var(--max-w); margin: 0 auto;
}
.brand {
  font-family: var(--ff-display);
  font-size: 0.8125rem;
  letter-spacing: 0.18em;
  color: var(--t-hi);
  text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 8px;
  min-height: 24px;
}
.brand-dot { width: 6px; height: 6px; background: var(--accent); border-radius: 50%; }
.brand:hover { color: var(--accent); }
.brand-logo {
  display: block;
  height: 36px;
  width: auto;
}

.nav-primary { display: flex; gap: 28px; flex-wrap: nowrap; }
.nav-primary a {
  font-size: 0.75rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--t-mid);
  padding: 8px 2px;
  min-height: 44px; display: inline-flex; align-items: center;
  position: relative;
}
.nav-primary a[aria-current="page"] { color: var(--t-hi); }
.nav-primary a[aria-current="page"]::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 4px;
  height: 1px; background: var(--accent);
}
.nav-primary a:hover { color: var(--t-hi); }

.header-meta { display: flex; align-items: center; gap: 20px; }
.contact-mail {
  font-size: 0.6875rem; letter-spacing: 0.14em; color: var(--t-mute);
  min-height: 24px; display: inline-flex; align-items: center;
}
.contact-mail:hover { color: var(--t-hi); }
.lang-switch {
  display: inline-flex; align-items: center; gap: 2px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  padding: 2px;
}
.lang-btn {
  font-size: 0.6875rem; letter-spacing: 0.14em; text-transform: uppercase;
  padding: 6px 10px; min-width: 40px; min-height: 28px;
  color: var(--t-mid); border-radius: 999px;
  transition: color var(--d-1) var(--ease), background var(--d-1) var(--ease);
}
.lang-btn[aria-pressed="true"] {
  background: var(--accent-chip-bg);
  color: var(--accent-chip-fg);
}
.lang-btn:hover:not([aria-pressed="true"]) { color: var(--t-hi); }

/* mobile nav toggle */
.nav-toggle { display: none; }
@media (max-width: 1100px) {
  :root { --row-h: 60px; }
  .nav-primary { display: none; }
  .header-row {
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 0 16px;
  }
  .header-meta { display: flex; align-items: center; gap: 8px; grid-column: 3; }
  .contact-mail { display: none; }
  .nav-toggle {
    display: inline-flex; align-items: center; justify-content: center;
    width: 44px; height: 44px; color: var(--t-mid);
    border: 1px solid var(--line-strong); border-radius: 2px;
  }
  .nav-toggle[aria-expanded="true"] { background: var(--bg-1); color: var(--t-hi); }
  .nav-primary.is-open {
    display: flex; flex-direction: column; gap: 0;
    position: absolute; left: 0; right: 0; top: 100%;
    background: var(--bg-2);
    border-bottom: 3px solid var(--accent);
    padding: 8px var(--gutter);
  }
  .nav-primary.is-open a { padding: 14px 0; border-top: 1px solid var(--line); }
  .nav-primary.is-open a:first-child { border-top: 0; }
  .nav-primary.is-open a[aria-current="page"]::after { display: none; }
}

/* ============================== page intro strip ============================== */
.page-intro {
  border-bottom: 1px solid var(--line);
  background: var(--bg-0);
}
.page-intro-row {
  max-width: var(--max-w); margin: 0 auto;
  padding: 28px var(--gutter);
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 32px;
  align-items: baseline;
}
.page-intro h1 {
  margin: 0;
  font-family: var(--ff-display);
  font-size: clamp(2.5rem, 5.5vw, 5.5rem);
  letter-spacing: -0.015em;
  line-height: 0.9;
  color: var(--t-hi);
}
.page-intro h1 .em { color: var(--accent); }
.page-intro .crumbs {
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
  display: inline-flex; align-items: center; gap: 10px;
}
.page-intro .crumbs::before { content: ""; width: 24px; height: 1px; background: var(--accent); display: inline-block; }
.page-intro .quick-facts {
  display: flex; gap: 24px;
  font-size: 0.75rem; color: var(--t-mid);
  letter-spacing: 0.06em;
  font-variant-numeric: tabular-nums;
}
.page-intro .quick-facts strong { color: var(--t-hi); font-weight: 400; }
@media (max-width: 880px) {
  .page-intro-row { grid-template-columns: 1fr; gap: 16px; }
  .page-intro .quick-facts { flex-wrap: wrap; }
}

/* ============================== filter bar ============================== */
.filter-bar {
  position: sticky; top: var(--row-h); z-index: 20;
  background: var(--bg-0);
  border-bottom: 1px solid var(--line);
}
.filter-row {
  max-width: var(--max-w); margin: 0 auto;
  padding: 14px var(--gutter);
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: start; gap: 12px 24px;
}
.section-chips {
  display: flex; gap: 6px; flex-wrap: wrap;
}
.chip {
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  padding: 10px 16px;
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mid);
  white-space: nowrap;
  background: transparent;
  transition: color var(--d-1), background var(--d-1), border-color var(--d-1);
  min-height: 36px;
  display: inline-flex; align-items: center; gap: 8px;
}
.chip:hover { color: var(--t-hi); border-color: var(--t-hi); }
.chip[aria-pressed="true"] {
  background: var(--accent-chip-bg); color: var(--accent-chip-fg); border-color: var(--accent-chip-bg);
}
.chip--all { color: var(--t-hi); }
.chip--all[aria-pressed="true"] {
  background: transparent; color: var(--t-hi); border-color: var(--t-hi);
}
.chip .count {
  font-size: 0.625rem; letter-spacing: 0.04em; color: inherit; opacity: 0.75;
}
/* programme section panel (mobile dropdown) */
.section-panel { display: none; }
@media (max-width: 640px) {
  .section-chips .chip:not(.chip--all) { display: none; }
  .filter-bar.secs-open .section-panel {
    display: flex; flex-wrap: wrap; gap: 6px;
    padding: 14px var(--gutter) 14px;
    border-top: 1px solid var(--line);
  }
}
.filter-tools { display: flex; gap: 10px; align-items: center; }
.tool-select {
  background: transparent; color: var(--t-mid);
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  padding: 8px 32px 8px 14px;
  font-size: 0.6875rem; letter-spacing: 0.14em; text-transform: uppercase;
  min-height: 36px;
  appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%23787369' stroke-width='1' fill='none'/></svg>");
  background-repeat: no-repeat;
  background-position: right 12px center;
}
.tool-select:hover { color: var(--t-hi); }
.view-toggle {
  display: inline-flex; border: 1px solid var(--line-strong); border-radius: 999px; padding: 2px;
}
.view-toggle button {
  width: 36px; height: 32px; display: inline-flex; align-items: center; justify-content: center;
  color: var(--t-mute); border-radius: 999px;
}
.view-toggle button[aria-pressed="true"] { background: var(--accent-chip-bg); color: var(--accent-chip-fg); }
.view-toggle button:hover:not([aria-pressed="true"]) { color: var(--t-hi); }
@media (max-width: 540px) {
  .filter-tools .view-toggle { display: none; }
  .filter-bar .view-toggle { display: none; }
}

/* ============================== sections ============================== */
.programme {
  max-width: var(--max-w); margin: 0 auto;
}
.section {
  scroll-margin-top: 180px;
}
.section-header {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 48px;
  padding: 40px var(--gutter) 28px;
  align-items: end;
}
.section-num {
  font-size: 0.6875rem; letter-spacing: 0.16em; color: var(--t-mute);
  text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 12px;
  margin-bottom: 16px;
}
.section-num::before { content: ""; width: 18px; height: 1px; background: var(--accent); }
.section-title {
  font-family: var(--ff-display);
  font-weight: 300;
  font-size: clamp(1.5rem, 2vw, 2rem);
  line-height: 1.1;
  letter-spacing: 0.005em;
  text-transform: uppercase;
  color: var(--t-hi);
  margin: 0;
}
.section-title .accent { color: var(--accent); }
.section-intro {
  color: var(--t-base);
  font-size: 0.9375rem; line-height: 1.55; letter-spacing: 0.03em;
  max-width: 56ch;
}
.section-intro .count-pill {
  display: inline-flex; align-items: baseline; gap: 6px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mid); margin-left: 8px;
  white-space: nowrap;
}
@media (max-width: 880px) {
  .section-header { grid-template-columns: 1fr; gap: 16px; padding: 48px var(--gutter) 24px; }
}

/* ============================== programme grid ============================== */
.film-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  align-items: stretch;
}
.film-grid[data-view="list"] { grid-template-columns: 1fr; }
.film-card:nth-child(3n+1) { border-left: 1px solid var(--line); }

@media (max-width: 1100px) {
  .film-grid { grid-template-columns: repeat(2, 1fr); }
  .film-card:nth-child(3n+1) { border-left: 0; }
  .film-card:nth-child(2n+1) { border-left: 1px solid var(--line); }
}
@media (max-width: 640px) {
  .film-grid { grid-template-columns: 1fr; }
  .film-card { border-left: 1px solid var(--line); border-right: 1px solid var(--line); }
}

.film-card {
  position: relative;
  text-align: left;
  display: flex; flex-direction: column;
  background: var(--bg-0);
  border-top: 1px solid var(--line);
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  transition: background var(--d-2) var(--ease);
  overflow: hidden;
  cursor: pointer;
  width: 100%;
}
.film-card:hover, .film-card:focus-visible { background: var(--bg-2); }
.film-card:focus-visible { outline-offset: 2px; z-index: 1; }
.film-card:hover .card-eyebrow,
.film-card:focus-visible .card-eyebrow { color: var(--t-base); }

.poster {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--poster-bg);
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.poster-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.poster-placeholder {
  position: absolute; inset: 0;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.015) 0 12px, rgba(255,255,255,0) 12px 24px),
    linear-gradient(180deg, #1c1a14 0%, #0b0a08 100%);
  display: flex; align-items: center; justify-content: center;
  color: rgba(232,226,212,0.45);
  font-family: ui-monospace, "SFMono-Regular", Menlo, monospace;
  font-size: 0.625rem; letter-spacing: 0.18em; text-transform: uppercase;
}
.poster-badges {
  position: absolute; top: 12px; left: 12px;
  display: flex; gap: 4px; flex-wrap: wrap; max-width: calc(100% - 24px);
}
.poster-badges--top-right {
  left: auto; right: 12px;
}
.poster-badges--bottom {
  top: auto; bottom: 12px;
}
.poster-badges--bottom-right {
  top: auto; bottom: 12px; left: auto; right: 12px;
}
.poster-tag {
  background: var(--accent);
  border: 1px solid var(--accent);
  padding: 5px 9px;
  font-size: 0.625rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: #fff;
}
.poster-num {
  position: absolute; top: 12px; right: 12px;
  font-family: var(--ff-display);
  font-size: 1.75rem;
  letter-spacing: 0.02em;
  color: rgba(232,226,212,0.85);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}

.card-body {
  padding: 22px 22px 26px;
  display: flex; flex-direction: column; gap: 12px;
  min-height: 188px;
}
.card-eyebrow {
  font-size: 0.625rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
  display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
}
.card-eyebrow .dot { width: 3px; height: 3px; background: var(--t-mute); border-radius: 50%; }
.card-title {
  font-family: var(--ff-display);
  font-weight: 300;
  font-size: 1.75rem;
  line-height: 1.02;
  letter-spacing: 0.005em;
  color: var(--t-hi);
  margin: 2px 0 0;
  text-transform: uppercase;
}
.card-meta {
  font-size: 0.75rem; letter-spacing: 0.04em; color: var(--t-base);
  font-variant-numeric: tabular-nums;
}
.card-meta .country-list { color: var(--t-mute); }
.card-cta {
  display: inline-flex; align-items: center; gap: 10px;
  margin-top: auto; padding-top: 8px;
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-hi);
  min-height: 24px;
  border-top: 1px solid var(--line);
}
.card-cta .arrow {
  display: inline-block; width: 18px; height: 1px; background: var(--t-hi);
  position: relative; transition: width var(--d-1);
}
.card-cta .arrow::after {
  content: ""; position: absolute; right: -1px; top: -3px; width: 7px; height: 7px;
  border-top: 1px solid var(--t-hi); border-right: 1px solid var(--t-hi);
  transform: rotate(45deg);
}
.film-card:hover .card-cta { color: var(--accent); }
.film-card:hover .card-cta .arrow { width: 28px; background: var(--accent); }
.film-card:hover .card-cta .arrow::after { border-color: var(--accent); }

/* list-view variant */
.film-grid[data-view="list"] .film-card {
  flex-direction: row;
  border-right: 0;
}
.film-grid[data-view="list"] .poster {
  width: 320px; flex-shrink: 0; aspect-ratio: 4 / 3;
  border-bottom: 0; border-right: 1px solid var(--line);
}
.film-grid[data-view="list"] .card-body {
  flex: 1;
  display: grid;
  grid-template-columns: 2fr 1fr auto;
  gap: 32px; align-items: center;
  min-height: unset;
  padding: 20px 24px;
}
.film-grid[data-view="list"] .card-cta { border-top: 0; padding-top: 0; }
@media (max-width: 880px) {
  .film-grid[data-view="list"] .film-card { flex-direction: column; }
  .film-grid[data-view="list"] .poster { width: 100%; border-right: 0; border-bottom: 1px solid var(--line); }
  .film-grid[data-view="list"] .card-body { grid-template-columns: 1fr; gap: 12px; padding: 22px 22px 26px; }
  .film-grid[data-view="list"] .card-cta { border-top: 1px solid var(--line); padding-top: 8px; }
}

/* ============================== drawer ============================== */
.drawer-scrim {
  position: fixed; inset: 0; z-index: 60;
  background: rgba(10,10,9,0.45);
  backdrop-filter: blur(2px);
  opacity: 0; pointer-events: none;
  transition: opacity var(--d-2) var(--ease);
}
.drawer-scrim.is-open { opacity: 1; pointer-events: auto; }

.drawer {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: 70;
  width: min(860px, 100vw);
  background: var(--bg-0);
  border-left: 1px solid var(--line);
  transform: translateX(100%);
  transition: transform var(--d-3) var(--ease);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.drawer.is-open { transform: translateX(0); }

.drawer-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 24px;
  border-bottom: 1px solid var(--line);
  background: var(--bg-1);
  min-height: 56px;
}
.drawer-head .crumbs {
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--t-mid);
}
.drawer-head .crumbs .sep { margin: 0 10px; opacity: 0.6; }
.icon-btn {
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--t-mid);
  border-radius: 2px;
}
.icon-btn:hover { color: var(--t-hi); background: var(--bg-2); }

.drawer-body {
  flex: 1;
  overflow-y: auto;
  scrollbar-width: thin;
}
.drawer-hero {
  position: relative;
  aspect-ratio: 16/9;
  background: var(--poster-bg);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
}
.drawer-hero .poster-placeholder {
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.018) 0 14px, rgba(255,255,255,0) 14px 28px),
    linear-gradient(160deg, #221f17 0%, #0a0907 100%);
  font-size: 0.6875rem;
}
.play-btn {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%);
  width: 88px; height: 88px; border-radius: 50%;
  background: rgba(10,10,9,0.6);
  border: 1px solid var(--t-on-dark);
  color: var(--t-on-dark);
  display: inline-flex; align-items: center; justify-content: center;
  transition: transform var(--d-2), background var(--d-2);
}
.play-btn:hover { transform: translate(-50%,-50%) scale(1.06); background: rgba(0,0,0,0.85); }

.drawer-section {
  padding: 32px 32px 8px;
  border-bottom: 1px solid var(--line);
}
.drawer-section:last-child { border-bottom: 0; }
.drawer-section h2 {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(2.25rem, 4.5vw, 3.5rem);
  line-height: 0.96; letter-spacing: 0.01em;
  color: var(--t-hi); margin: 0;
  text-wrap: balance;
}
.drawer-section h2 .accent { color: var(--accent); }
.drawer-tagline {
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mute); margin: 20px 0 0;
}
.fact-strip {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
  margin-top: 28px; padding-bottom: 28px;
}
.fact dt {
  font-size: 0.625rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute); margin-bottom: 8px;
}
.fact dd {
  margin: 0; color: var(--t-hi); font-size: 0.875rem; letter-spacing: 0.02em;
}
@media (max-width: 720px) {
  .fact-strip { grid-template-columns: 1fr 1fr; }
  .drawer-section { padding: 24px 22px 8px; }
}

.drawer-h3 {
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mute);
  margin: 0 0 16px;
}
.synopsis, .why-watch {
  color: var(--t-soft);
  font-size: 0.9375rem; line-height: 1.6; letter-spacing: 0.025em;
  max-width: 64ch;
  margin: 0 0 28px;
}

/* films-in-programme list */
.film-list {
  display: flex; flex-direction: column;
  border-top: 1px solid var(--line);
  margin-bottom: 28px;
}
.film-row {
  display: grid;
  grid-template-columns: 28px 1fr auto;
  gap: 24px;
  padding: 18px 0;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
}
.film-row .num {
  font-family: var(--ff-display);
  font-size: 0.8125rem;
  color: var(--t-mute);
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
}
.film-row .film-main {
  display: flex; flex-direction: column; gap: 6px;
}
.film-row .film-title {
  font-family: var(--ff-display); font-weight: 300;
  font-size: 1.125rem; line-height: 1.15;
  letter-spacing: 0.01em;
  color: var(--t-hi);
}
.film-row .film-title .ot {
  display: inline; font-size: 0.8125rem; color: var(--t-mute); letter-spacing: 0.04em;
  font-style: italic;
  margin-left: 10px;
  unicode-bidi: isolate;
}
.film-row .film-meta {
  font-size: 0.75rem; letter-spacing: 0.05em; color: var(--t-mid);
  display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
}
.film-row .film-meta .dot { width: 3px; height: 3px; background: var(--t-mute); border-radius: 50%; }
.film-row .film-syn {
  margin: 0.25rem 0 0; font-size: 0.875rem; line-height: 1.55; color: var(--t-soft);
  max-width: 56ch;
}
.film-row .film-runtime {
  font-family: var(--ff-display);
  font-size: 1rem; color: var(--t-hi); letter-spacing: 0.02em;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
@media (max-width: 720px) {
  .film-row { grid-template-columns: 24px 1fr; }
  .film-row .film-runtime { grid-column: 2; color: var(--t-mute); font-size: 0.8125rem; }
}

/* sessions */
.session-list { display: flex; flex-direction: column; }
.session {
  display: grid;
  grid-template-columns: 70px 1fr auto;
  align-items: center;
  gap: 24px;
  padding: 16px 0;
  border-top: 1px solid var(--line);
}
.session:last-child { border-bottom: 1px solid var(--line); }
.session-date {
  font-family: var(--ff-display); font-size: 1.75rem; letter-spacing: 0.02em;
  color: var(--t-hi); line-height: 1; font-variant-numeric: tabular-nums;
}
.session-date small {
  display: block; font-size: 0.625rem; letter-spacing: 0.18em; color: var(--t-mute);
  text-transform: uppercase; margin-top: 6px; font-family: var(--ff);
}
.session-info {
  display: flex; flex-direction: column; gap: 4px;
  font-size: 0.8125rem; color: var(--t-base);
}
.session-info .venue { color: var(--t-hi); font-size: 0.875rem; letter-spacing: 0.04em; }
.session-info .city {
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--t-mute);
}
.session-times { display: flex; gap: 8px; }
.time-btn {
  width: 88px; min-height: 52px;
  border: 1px solid var(--accent-chip-bg);
  background: var(--accent-chip-bg); color: var(--accent-chip-fg);
  border-radius: 2px;
  font-size: 0.875rem; letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
  padding: 6px 10px;
  transition: background var(--d-1), color var(--d-1);
  display: inline-flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px;
}
.time-btn-time { font-variant-numeric: tabular-nums; line-height: 1; }
.time-btn-label {
  font-size: 0.5625rem; letter-spacing: 0.18em; text-transform: uppercase;
  font-variant-numeric: normal;
  opacity: 0.7; line-height: 1;
}
.time-btn[aria-pressed="true"] { background: var(--accent); color: #fff; border-color: var(--accent); }
.time-btn.sold-out {
  background: transparent; color: var(--t-mute); border-color: var(--line-strong);
  text-decoration: line-through;
  cursor: not-allowed;
}
.time-btn:hover:not(.sold-out):not([aria-pressed="true"]) { background: var(--t-hi); }

.cta-row {
  display: flex; gap: 12px; flex-wrap: wrap;
  padding-bottom: 32px;
}
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 14px 22px;
  min-height: 48px;
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  border-radius: 2px;
  transition: background var(--d-1), color var(--d-1), border-color var(--d-1);
}
.btn-primary { background: var(--accent-chip-bg); color: var(--accent-chip-fg); }
.btn-primary:hover { background: var(--accent); color: #fff; }
.btn-secondary {
  background: transparent; color: var(--t-mid);
  border: 1px solid var(--line-strong);
}
.btn-secondary:hover { color: var(--t-hi); border-color: var(--t-hi); background: var(--bg-2); }
.btn-disabled {
  background: transparent; color: var(--t-mute);
  border: 1px solid var(--line); cursor: not-allowed;
}

@media (max-width: 720px) {
  .session { grid-template-columns: 56px 1fr; }
  .session-times { grid-column: 1 / -1; }
}

/* ============================== subscribe + footer ============================== */
.subscribe {
  border-top: 1px solid var(--line);
}
.subscribe-inner {
  max-width: var(--max-w); margin: 0 auto;
  padding-top: 64px;
}
.subscribe-visual {
  aspect-ratio: 16/9;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.018) 0 16px, rgba(255,255,255,0) 16px 32px),
    radial-gradient(circle at 30% 40%, rgba(245,83,26,0.18), transparent 60%),
    linear-gradient(160deg, #1c1a14 0%, #0b0a08 100%);
  border-right: 1px solid var(--line);
  display: flex; align-items: end; padding: 24px;
  color: rgba(232,226,212,0.45);
  font-family: ui-monospace, monospace; font-size: 0.625rem; letter-spacing: 0.2em; text-transform: uppercase;
}
.subscribe-form {
  padding: 40px 32px;
  background: var(--bg-1);
  border: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 24px; justify-content: center;
}
.subscribe-form h2 {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(2rem, 4vw, 3rem); line-height: 0.96;
  color: var(--t-hi); margin: 0;
  text-wrap: balance;
}
.field {
  display: flex; gap: 0;
  border-top: 1px solid var(--line);
  padding-top: 16px;
}
.field input {
  flex: 1; background: transparent; border: 0;
  color: var(--t-hi);
  font-size: 1rem; letter-spacing: 0.06em;
  padding: 14px 0; min-height: 48px;
  border-bottom: 1px solid var(--line-strong);
}
.field input:focus { outline: 2px solid var(--focus); outline-offset: -1px; border-bottom-color: var(--accent); }
.field input::placeholder { color: var(--t-mute); }
.field button {
  border-bottom: 1px solid var(--line-strong);
  padding: 0 0 0 20px;
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-hi);
  min-height: 48px;
}
.field button:hover { color: var(--accent); }
.field-msg {
  font-size: 0.6875rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--t-mute); margin: -12px 0 0;
}
@media (max-width: 880px) {
  .subscribe-inner { padding-top: 40px; }
}

.site-footer {
  border-top: 1px solid var(--line);
  background: var(--bg-0);
  margin-top: 0;
}
.footer-row {
  max-width: var(--max-w); margin: 0 auto;
  padding: 32px var(--gutter);
  display: flex; justify-content: space-between; align-items: center;
  gap: 32px; flex-wrap: wrap;
}
.eu-block { display: flex; align-items: center; gap: 1rem; color: var(--t-soft); font-size: 0.75rem; line-height: 1.5; flex: 1; min-width: 0; }
.eu-block p { max-width: 72ch; }
.eu-flag { height: 52px; width: auto; max-width: none; flex-shrink: 0; display: block; }
.footer-social { display: flex; gap: 10px; align-items: center; flex-shrink: 0; }
.footer-social-link {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  color: var(--t-base);
  border: 1px solid var(--line-strong);
  border-radius: 2px;
  transition: color var(--d-1), border-color var(--d-1);
}
.footer-social-link:hover { color: var(--accent); border-color: var(--accent); }
.legal {
  border-top: 1px solid var(--line);
  padding: 16px var(--gutter);
  max-width: var(--max-w); margin: 0 auto;
  display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  align-items: center;
  font-size: 0.6875rem; letter-spacing: 0.14em; color: var(--t-mute); text-transform: uppercase;
}
.legal-links { display: flex; gap: 20px; }
.legal a {
  padding: 6px 0;
  min-height: 24px;
  display: inline-flex; align-items: center;
}
@media (max-width: 720px) {
  .footer-row { flex-direction: column; align-items: flex-start; }
  .legal { flex-direction: column; align-items: flex-start; }
}

/* ============================== tickerbar ============================== */
.tickerbar {
  background: var(--accent-chip-bg);
  color: var(--accent-chip-fg);
  overflow: hidden;
  border-bottom: 1px solid var(--line);
  position: relative;
}
.ticker-pause {
  position: absolute; top: 50%; right: 12px;
  transform: translateY(-50%);
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--accent-chip-fg);
  border: 1px solid rgba(255,254,241,0.4);
  border-radius: 50%;
  z-index: 2;
  opacity: 0;
  transition: opacity var(--d-1);
}
.tickerbar:hover .ticker-pause,
.ticker-pause:focus-visible { opacity: 1; }
.tickerbar.is-paused .ticker-pause { opacity: 1; }
.tickerbar.is-paused .ticker-track { animation-play-state: paused; }
.ticker-track {
  display: flex; gap: 48px;
  padding: 8px 0;
  white-space: nowrap;
  animation: ticker 38s linear infinite;
  font-size: 0.6875rem; letter-spacing: 0.22em; text-transform: uppercase;
}
.ticker-track span { display: inline-flex; align-items: center; gap: 16px; }
.ticker-track .bullet { width: 4px; height: 4px; background: var(--accent-chip-fg); border-radius: 50%; opacity: 0.6; }
@keyframes ticker {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* ================================================================
   SCHEDULE PAGE
   ================================================================ */

.schedule-intro {
  border-bottom: 1px solid var(--line);
  background: var(--bg-0);
}
.schedule-intro-row {
  max-width: var(--max-w); margin: 0 auto;
  padding: 56px var(--gutter) 40px;
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 48px;
  align-items: end;
}
.schedule-intro h1 {
  margin: 0;
  font-family: var(--ff-display);
  font-size: clamp(2.5rem, 5.5vw, 5.5rem);
  line-height: 0.9; letter-spacing: -0.015em;
  color: var(--t-hi);
  text-wrap: balance;
}
.schedule-intro h1 .em { color: var(--accent); }
.schedule-intro .sub {
  color: var(--t-base); font-size: 1rem; letter-spacing: 0.03em; line-height: 1.5;
  max-width: 52ch;
}
.schedule-intro .legend {
  display: flex; flex-wrap: wrap; gap: 12px 20px;
  margin-top: 20px;
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--t-mute);
}
.schedule-intro .legend span {
  display: inline-flex; align-items: center; gap: 8px;
}
.schedule-intro .legend .swatch {
  width: 10px; height: 10px; border-radius: 50%; border: 1px solid currentColor;
}
@media (max-width: 880px) {
  .schedule-intro-row { grid-template-columns: 1fr; gap: 20px; padding: 40px var(--gutter) 28px; }
}

/* day picker — full-width strip of buttons */
.day-picker {
  position: sticky; top: var(--row-h); z-index: 20;
  background: var(--bg-0);
  border-bottom: 1px solid var(--line);
}
.day-picker-row {
  max-width: var(--max-w); margin: 0 auto;
  padding: 12px var(--gutter);
  display: flex; gap: 8px; align-items: stretch;
  overflow-x: auto;
  scrollbar-width: thin;
}
.day-btn {
  display: inline-flex; flex-direction: column;
  align-items: center; justify-content: center;
  min-width: 80px; min-height: 60px;
  padding: 8px 14px;
  border: 1px solid var(--line-strong);
  background: transparent;
  color: var(--t-mid);
  border-radius: 4px;
  transition: background var(--d-1), color var(--d-1), border-color var(--d-1);
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
}
.day-btn .num {
  font-family: var(--ff-display); font-size: 1.375rem; line-height: 1; color: var(--t-hi);
}
.day-btn .wk {
  font-size: 0.625rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute); margin-top: 6px;
}
.day-btn[aria-pressed="true"] {
  background: var(--accent-chip-bg); border-color: var(--accent-chip-bg);
}
.day-btn[aria-pressed="true"] .num,
.day-btn[aria-pressed="true"] .wk { color: var(--accent-chip-fg); }
.day-btn:hover:not([aria-pressed="true"]) { border-color: var(--t-hi); }
.day-btn .count {
  font-size: 0.5625rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--t-mute); margin-top: 2px;
}
.day-btn[aria-pressed="true"] .count { color: var(--accent-chip-fg); opacity: 0.7; }

.day-btn.day-all {
  min-width: 110px;
}
.day-btn.day-all .num {
  font-size: 0.875rem; letter-spacing: 0.16em; text-transform: uppercase;
}

/* secondary filter row */
.schedule-filter-row {
  max-width: var(--max-w); margin: 0 auto;
  padding: 14px var(--gutter);
  display: flex; flex-wrap: wrap; gap: 24px;
  align-items: center;
  border-bottom: 1px solid var(--line);
}
.schedule-filter-mobilebar { display: none; }
.schedule-filter-groups { display: contents; }
.schedule-filter-group {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.schedule-filter-chips { display: flex; gap: 8px; flex-wrap: wrap; }
.schedule-filter-group .label {
  font-size: 0.625rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute); margin-right: 4px;
}
.schedule-filter-actions { display: none; }
.schedule-view-desktop { margin-left: auto; }
.schedule-filter-row .view-toggle button {
  width: auto; padding: 0 14px; min-width: 70px; height: 32px;
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  white-space: nowrap;
}

@media (max-width: 720px) {
  .schedule-filter-row {
    padding: 12px var(--gutter);
    gap: 0; flex-direction: column; align-items: stretch;
  }
  .schedule-filter-mobilebar {
    display: flex; align-items: center; gap: 12px; justify-content: space-between;
  }
  .schedule-filter-mobilebar .view-toggle { flex-shrink: 0; }
  .schedule-view-desktop { display: none; }
  .filter-collapse-toggle {
    display: inline-flex; align-items: center; gap: 8px;
    height: 38px; padding: 0 16px;
    border: 1px solid var(--line-strong); border-radius: 999px;
    background: transparent; color: var(--t-hi);
    font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
    flex-shrink: 0;
  }
  .filter-collapse-toggle[aria-expanded="true"] {
    background: var(--accent-chip-bg); color: var(--accent-chip-fg);
    border-color: var(--accent-chip-bg);
  }
  .filter-badge {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 18px; height: 18px; padding: 0 5px; border-radius: 999px;
    background: var(--accent); color: #fff;
    font-size: 0.625rem; letter-spacing: 0; font-variant-numeric: tabular-nums;
  }
  .schedule-filter-groups {
    display: none;
  }
  .schedule-filter-row.is-open .schedule-filter-groups {
    display: flex; flex-direction: column; align-items: stretch;
    gap: 18px; padding: 16px 0 4px;
    margin-top: 12px; border-top: 1px solid var(--line);
  }
  .schedule-filter-row.is-open .schedule-filter-group {
    flex-direction: column; align-items: stretch; gap: 10px;
  }
  .schedule-filter-row.is-open .schedule-filter-chips { flex-wrap: wrap; }
  .schedule-filter-actions {
    display: flex; gap: 8px; align-items: center; justify-content: space-between;
    padding-top: 8px; border-top: 1px solid var(--line);
  }
  .filter-reset, .filter-done {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    height: 44px; padding: 0 18px;
    font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
    border-radius: 999px; flex: 1;
  }
  .filter-reset {
    background: transparent; color: var(--t-mute); border: 1px solid var(--line);
  }
  .filter-done {
    background: var(--accent-chip-bg); color: var(--accent-chip-fg); border: 0;
  }
}

/* day blocks */
.schedule-body { max-width: var(--max-w); margin: 0 auto; }
.schedule-day {
  border-bottom: 1px solid var(--line);
  scroll-margin-top: 180px;
}
.schedule-day-head {
  display: grid;
  grid-template-columns: minmax(160px, auto) 1fr auto;
  align-items: end;
  gap: 24px;
  padding: 40px var(--gutter) 16px;
}
.schedule-day-head .day-num {
  font-family: var(--ff-display);
  font-size: clamp(4.5rem, 11vw, 10rem);
  line-height: 0.85;
  color: var(--t-hi);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
.schedule-day-head .day-meta {
  display: flex; flex-direction: column; gap: 4px;
  padding-bottom: 16px;
  margin: 0; font-size: inherit; font-weight: inherit;
}
.schedule-day-head .day-meta .month {
  color: var(--t-hi);
  font-size: 1.125rem; letter-spacing: 0.04em;
  text-transform: capitalize;
}
.schedule-day-head .day-meta .wkday {
  font-size: 0.75rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
}
.schedule-day-head .day-count {
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--t-mute);
  padding-bottom: 22px;
  font-variant-numeric: tabular-nums;
}
@media (max-width: 720px) {
  .schedule-day-head {
    grid-template-columns: auto 1fr;
    gap: 16px; padding: 28px var(--gutter) 12px;
    align-items: end;
  }
  .schedule-day-head .day-num { font-size: 3.5rem; line-height: 1; }
  .schedule-day-head .day-meta { padding-bottom: 4px; }
  .schedule-day-head .day-meta .month { font-size: 0.875rem; }
  .schedule-day-head .day-meta .wkday { font-size: 0.625rem; }
  .schedule-day-head .day-count {
    grid-column: 1 / -1; padding-bottom: 0; margin-top: -8px;
  }
}

.event-list { display: flex; flex-direction: column; }
.event-row {
  display: grid;
  grid-template-columns: 120px 140px 1fr 200px auto;
  gap: 24px;
  align-items: center;
  padding: 18px var(--gutter);
  border-top: 1px solid var(--line);
  background: var(--bg-0);
  text-align: left;
  width: 100%;
  cursor: pointer;
  transition: background var(--d-1) var(--ease);
  position: relative;
}
.event-row:hover, .event-row:focus-visible { background: var(--bg-1); }
.event-row:focus-visible { outline-offset: 2px; z-index: 1; }

.event-row.is-passive { cursor: default; }

.event-time {
  font-family: var(--ff-display);
  font-size: clamp(1.25rem, 1.6vw, 1.625rem);
  line-height: 1;
  color: var(--t-hi);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
  display: flex; flex-wrap: wrap; align-items: baseline; gap: 6px;
}
.event-time .sep { color: var(--t-mute); font-weight: 300; }
.event-time .end { color: var(--t-mid); font-family: var(--ff-display); font-size: inherit; }

.event-type {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 0.625rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mid);
  white-space: nowrap;
}
.event-type .swatch {
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--type-color, var(--accent));
  flex-shrink: 0;
}

.event-main { min-width: 0; }
.event-title {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.25rem, 1.6vw, 1.625rem);
  line-height: 1.1; letter-spacing: 0.005em;
  text-transform: uppercase;
  color: var(--t-hi);
  margin: 0;
}
.event-sub {
  margin-top: 6px;
  font-size: 0.75rem; letter-spacing: 0.06em;
  color: var(--t-mute);
}
.event-access {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 8px;
  font-size: 0.625rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mid);
  padding: 4px 10px;
  border: 1px solid var(--line-strong); border-radius: 999px;
  min-height: 24px;
}
.event-access.is-soldout {
  color: var(--t-mute); border-color: var(--line); text-decoration: line-through;
}
.event-access.is-gala {
  background: var(--accent); color: #fff; border-color: var(--accent);
}

.event-venue {
  font-size: 0.8125rem; letter-spacing: 0.05em; color: var(--t-mid); line-height: 1.4;
  text-align: right;
}
.event-venue .venue-name { color: var(--t-hi); font-size: 0.875rem; display: inline-flex; align-items: center; gap: 0.375rem; }
.event-venue .city {
  display: block; font-size: 0.625rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute); margin-top: 4px;
}

.event-cta {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  min-height: 44px; padding: 0 16px;
  border-radius: 2px;
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  white-space: nowrap;
}
.event-cta.primary { background: var(--accent-chip-bg); color: var(--accent-chip-fg); }
.event-cta.primary:hover { background: var(--accent); color: #fff; }
.event-cta.secondary {
  background: transparent; color: var(--t-mid);
  border: 1px solid var(--line-strong);
}
.event-cta.secondary:hover { color: var(--t-hi); border-color: var(--t-hi); }
.event-cta.is-soldout {
  background: transparent; color: var(--t-mute); border: 1px solid var(--line);
  cursor: not-allowed; text-decoration: line-through;
}

@media (max-width: 1100px) {
  .event-row {
    grid-template-columns: 1fr auto;
    gap: 4px 14px; padding: 18px var(--gutter) 16px;
    align-items: baseline;
  }
  .event-time { grid-column: 1; grid-row: 1; font-size: 1.25rem; }
  .event-type { grid-column: 2; grid-row: 1; justify-self: end; align-self: center; }
  .event-main { grid-column: 1 / -1; margin-top: 6px; }
  .event-title { font-size: 1.375rem; }
  .event-venue {
    grid-column: 1 / -1; text-align: left; font-size: 0.8125rem; margin-top: 0.375rem;
    display: flex; align-items: baseline; gap: 8px;
  }
  .event-venue .venue-name { font-size: 0.8125rem; }
  .event-venue .city {
    display: inline; margin-top: 0; font-size: 0.625rem; letter-spacing: 0.18em;
    padding-left: 8px; border-left: 1px solid var(--line);
  }
  .event-cta {
    grid-column: 1 / -1; justify-self: stretch; width: 100%;
    margin-top: 0.75rem; min-height: 2.625rem; height: 2.625rem; font-size: 0.6875rem;
  }
}
@media (max-width: 720px) {
  .event-row { padding: 16px var(--gutter) 14px; }
  .event-time { font-size: 1.1875rem; }
  .event-title { font-size: 1.25rem; }
}

/* ================================================================
   HOME PAGE
   ================================================================ */

.home-hero {
  border-bottom: 1px solid var(--line);
  background: var(--bg-0);
}
.home-hero-row {
  max-width: var(--max-w); margin: 0 auto;
  padding: clamp(48px, 6vw, 96px) var(--gutter);
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 56px;
  align-items: end;
}
.home-edition {
  display: inline-flex; align-items: center; gap: 12px;
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
  margin-bottom: 24px;
}
.home-edition::before { content: ""; width: 24px; height: 1px; background: var(--accent); }
.home-edition .dates { color: var(--t-hi); }
.home-hero h1 {
  font-family: var(--ff-display);
  font-size: clamp(4rem, 11vw, 10.5rem);
  line-height: 0.86;
  letter-spacing: -0.015em;
  color: var(--t-hi);
  margin: 0;
  text-wrap: balance;
}
.home-hero h1 .em { color: var(--accent); }
.home-hero .lede {
  font-size: clamp(1rem, 1.6vw, 1.25rem);
  line-height: 1.5; letter-spacing: 0.02em;
  color: var(--t-base);
  max-width: 44ch;
  margin: 0;
}
.home-hero-cta {
  display: flex; flex-wrap: wrap; gap: 12px; align-items: center;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--line);
}
.home-hero-cta .venues {
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
  width: 100%; margin-top: 8px;
}
@media (max-width: 880px) {
  .home-hero-row { grid-template-columns: 1fr; gap: 32px; }
}

/* stats strip */
.home-stats {
  border-bottom: 1px solid var(--line);
  background: var(--bg-0);
}
.home-stats-row {
  max-width: var(--max-w); margin: 0 auto;
  padding: 32px var(--gutter);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.home-stat {
  display: flex; flex-direction: column; gap: 4px;
  padding: 0 24px;
  border-right: 1px solid var(--line);
}
.home-stat:first-child { padding-left: 0; }
.home-stat:last-child { border-right: 0; padding-right: 0; }
.home-stat .num {
  font-family: var(--ff-display);
  font-size: clamp(2.5rem, 5vw, 4rem);
  line-height: 1;
  color: var(--t-hi);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
.home-stat .lab {
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
}
@media (max-width: 720px) {
  .home-stats-row { grid-template-columns: 1fr 1fr; row-gap: 24px; }
  .home-stat:nth-child(2) { border-right: 0; padding-right: 0; }
  .home-stat:nth-child(3) { padding-left: 0; border-top: 1px solid var(--line); padding-top: 24px; }
  .home-stat:nth-child(4) { border-top: 1px solid var(--line); padding-top: 24px; }
}

/* section heading shared on home */
.home-section { border-bottom: 1px solid var(--line); }
.home-section-header {
  max-width: var(--max-w); margin: 0 auto;
  padding: 56px var(--gutter) 32px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 32px;
  align-items: end;
}
.home-section-header .eyebrow {
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
  display: inline-flex; align-items: center; gap: 12px;
  white-space: nowrap;
}
.home-section-header .eyebrow::before { content: ""; width: 24px; height: 1px; background: var(--accent); }
.home-section-header h2 {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(2rem, 4.4vw, 3.5rem);
  line-height: 0.95;
  letter-spacing: 0;
  color: var(--t-hi);
  margin: 0;
  text-wrap: balance;
}
.home-section-header .more {
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-hi);
  display: inline-flex; align-items: center; gap: 10px;
  min-height: 32px;
}
.home-section-header .more svg { transition: transform var(--d-1); }
.home-section-header .more:hover { color: var(--accent); }
.home-section-header .more:hover svg { transform: translateX(4px); }
.home-section-header--no-eyebrow { grid-template-columns: 1fr auto; }
@media (max-width: 880px) {
  .home-section-header { grid-template-columns: 1fr; gap: 12px; padding-top: 40px; }
}

/* about strip */
.home-about {
  max-width: var(--max-w); margin: 0 auto;
  padding: 0 var(--gutter) 56px;
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 64px;
  align-items: start;
}
.home-about p {
  font-size: clamp(1.125rem, 1.6vw, 1.375rem);
  line-height: 1.5; letter-spacing: 0.02em;
  color: var(--t-base);
  margin: 0; max-width: 60ch;
}
.home-about aside {
  display: flex; flex-direction: column; gap: 14px;
  border-left: 1px solid var(--line); padding-left: 24px;
}
.home-about aside dt {
  font-size: 0.625rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute); margin-bottom: 4px;
}
.home-about aside dd {
  margin: 0 0 12px; color: var(--t-hi);
  font-size: 0.875rem; letter-spacing: 0.04em;
}
.home-about aside a {
  align-self: start;
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-hi);
  border-bottom: 1px solid var(--accent);
  padding: 6px 0;
  min-height: 24px;
  display: inline-flex; align-items: center;
}
.home-about aside a:hover { color: var(--accent); }
@media (max-width: 880px) {
  .home-about { grid-template-columns: 1fr; gap: 32px; padding-bottom: 40px; }
  .home-about aside { border-left: 0; border-top: 1px solid var(--line); padding-left: 0; padding-top: 20px; }
}

/* news grid */
.home-news-grid {
  max-width: var(--max-w); margin: 0 auto;
  display: grid; grid-template-columns: repeat(4, 1fr);
  align-items: start;
  border-top: 1px solid var(--line);
  padding: 0 var(--gutter) 32px;
}
.news-card {
  display: flex; flex-direction: column;
  padding: 24px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--bg-0);
  gap: 14px;
  transition: background var(--d-1);
}
.news-card:last-child { border-right: 0; }
.news-card:hover { background: var(--bg-1); }
.news-card .tag {
  font-size: 0.625rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
}
.news-card time {
  font-size: 0.6875rem; letter-spacing: 0.06em; color: var(--t-mute);
  font-variant-numeric: tabular-nums;
}
.news-card h3 {
  font-family: var(--ff-display); font-weight: 300;
  font-size: 1.375rem; line-height: 1.15; letter-spacing: 0.005em;
  color: var(--t-hi);
  margin: 0;
  text-wrap: balance;
}
.news-card p {
  font-size: 0.8125rem; line-height: 1.5; letter-spacing: 0.02em;
  color: var(--t-soft); margin: 0;
}
.news-card .read-more {
  margin-top: auto;
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 12px 20px;
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  background: var(--accent-chip-bg); color: var(--accent-chip-fg);
  border-radius: 2px;
  transition: background var(--d-1), color var(--d-1);
}
.news-card:hover .read-more,
.news-card .read-more:hover { background: var(--accent); color: #fff; }
@media (max-width: 1100px) {
  .home-news-grid { grid-template-columns: repeat(2, 1fr); }
  .news-card:nth-child(2n) { border-right: 0; }
}
@media (max-width: 640px) {
  .home-news-grid { grid-template-columns: 1fr; }
  .news-card { border-right: 0; }
}

/* news card image */
.news-card-img {
  display: block; margin: -24px -24px 0;
  width: calc(100% + 48px);
  max-width: calc(100% + 48px);
  aspect-ratio: 16/9; object-fit: cover;
}

/* page hero (news listing, article) */
.page-hero {
  border-bottom: 1px solid var(--line);
  padding: 56px var(--gutter) 40px;
}
.page-hero-inner {
  max-width: var(--max-w); margin: 0 auto;
}
.page-hero .eyebrow {
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute); margin-bottom: 12px;
  display: inline-flex; align-items: center; gap: 12px;
}
.page-hero .eyebrow::before { content: ""; width: 24px; height: 1px; background: var(--accent); }
.page-hero h1 {
  font-family: var(--ff-display);
  font-size: clamp(2.5rem, 5.5vw, 5.5rem); line-height: 0.9; letter-spacing: -0.015em;
  color: var(--t-hi); margin: 0;
}

/* content wrapper */
.content-wrap {
  max-width: var(--max-w); margin: 0 auto;
  padding-left: var(--gutter); padding-right: var(--gutter);
}

/* news listing page grid */
.news-page-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  padding-top: 32px; padding-bottom: 64px;
}
.news-card--full {
  border: none;
  background: var(--bg-0);
  gap: 0;
}
.news-card--full .news-card-img {
  margin: 0 0 20px; width: 100%;
  border-radius: 2px;
}
.news-card--full .news-card-body {
  display: flex; flex-direction: column; gap: 10px;
  padding: 4px 0 20px;
}
.news-card--full h2 {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.25rem, 2vw, 1.75rem); line-height: 1.15; letter-spacing: 0.005em;
  color: var(--t-hi); margin: 0; text-wrap: balance;
}
.news-card--full p { font-size: 0.8125rem; line-height: 1.5; color: var(--t-soft); margin: 0; }
@media (max-width: 1000px) {
  .news-page-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .news-page-grid { grid-template-columns: 1fr; }
}

/* article page */
.article-page { padding-top: 40px; padding-bottom: 80px; }
.article-not-found { padding: 80px var(--gutter); }
.article-back {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mute); margin-bottom: 32px;
}
.article-back:hover { color: var(--accent); }
.article-header { max-width: 720px; }
.article-meta {
  display: flex; align-items: center; gap: 16px;
  margin-bottom: 20px;
}
.article-meta time { font-size: 0.75rem; letter-spacing: 0.06em; color: var(--t-mute); }
.article-header h1 {
  font-family: var(--ff-display);
  font-size: clamp(2.5rem, 5.5vw, 5.5rem); line-height: 0.9; letter-spacing: -0.015em;
  color: var(--t-hi); margin: 0 0 20px;
}
.article-lead {
  font-size: 1.0625rem; line-height: 1.55; color: var(--t-soft);
  margin: 0; max-width: 640px;
}
.article-cover {
  margin: 40px 0;
  border-radius: 4px; overflow: hidden;
}
.article-cover img {
  width: 100%; max-height: 500px; object-fit: cover; display: block;
}
.article-body {
  max-width: 680px;
  font-size: 1rem; line-height: 1.7; color: var(--t-soft);
  margin-top: 40px;
}
.article-body p { margin: 0 0 1.2em; }
.article-body h2, .article-body h3 {
  font-family: var(--ff-display); font-weight: 300;
  color: var(--t-hi); margin: 1.8em 0 0.6em;
}
.article-body h2 { font-size: clamp(1.375rem, 2.5vw, 1.875rem); }
.article-body h3 { font-size: clamp(1.125rem, 2vw, 1.375rem); }
.article-body strong, .article-body b { font-weight: 600; color: var(--t-hi); }
.article-body em, .article-body i { font-style: italic; }
.article-body a { color: var(--accent-text); text-decoration: underline; text-underline-offset: 3px; }
.article-body a:hover { text-decoration: none; }
.article-body a.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 22px; min-height: 48px;
  background: var(--accent-chip-bg); color: var(--accent-chip-fg);
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  border-radius: 2px; text-decoration: none; margin: 16px 0;
  transition: background var(--d-1), color var(--d-1);
}
.article-body a.btn:hover { background: var(--accent); color: #fff; text-decoration: none; }
.article-body ul, .article-body ol { padding-left: 24px; margin: 0 0 1.2em; }
.article-body li { margin-bottom: 0.4em; }
.article-body blockquote {
  border-left: 3px solid var(--accent); margin: 1.6em 0;
  padding: 8px 20px; font-style: italic; color: var(--t-mid);
}
@media (max-width: 640px) {
  .article-lead { font-size: 0.9375rem; }
  .article-body { font-size: 0.9375rem; }
}

/* partners strip */
.home-partners {
  max-width: var(--max-w); margin: 0 auto;
  padding: 32px var(--gutter) 64px;
}
.home-partners h2 {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.25rem, 1.8vw, 1.625rem);
  color: var(--t-hi); margin: 0 0 28px;
  letter-spacing: 0.01em;
  text-wrap: balance;
}
.partner-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--line); border-left: 1px solid var(--line);
}
.partner-cell {
  aspect-ratio: 2.5 / 1;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--bg-0);
  display: flex; align-items: center; justify-content: center;
  position: relative;
  overflow: hidden;
  transition: background var(--d-1);
  text-decoration: none;
}
.partner-cell:hover { background: var(--bg-1); }
.partner-logo {
  max-height: 51px;
  max-width: 72%;
  width: auto;
  object-fit: contain;
  display: block;
}
.partner-logo--small { max-height: 33px; }
@media (max-width: 640px) {
  .partner-grid { grid-template-columns: repeat(2, 1fr); }
}

/* programme page: per-programme partner logos */
.prog-partners {
  max-width: var(--max-w); margin: 0 auto;
  padding: clamp(28px, 3.5vw, 48px) var(--gutter) clamp(36px, 4.5vw, 56px);
  border-top: 1px solid var(--line);
}
.prog-partners-label {
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 20px;
}
.prog-partners-label::before {
  content: ""; width: 20px; height: 1px; background: var(--accent);
}
/* override: flex so the container has no borders of its own;
   each cell draws its own full rectangle, no overflow line */
.prog-partners .partner-grid {
  display: flex;
  flex-wrap: wrap;
  border: none;
  grid-template-columns: unset;
  max-width: unset;
}
.prog-partners .partner-cell {
  width: 180px;
  flex-shrink: 0;
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
  margin-right: -1px;
  margin-bottom: -1px;
}
@media (max-width: 640px) {
  .prog-partners .partner-cell { width: 50%; }
}

/* next screenings strip */
.home-next-list {
  max-width: var(--max-w); margin: 0 auto;
  padding-bottom: 32px;
}
.home-next-list .event-row {
  border-top: 1px solid var(--line);
}

/* ----------------------------------------------------------------
   HOME V2 — editorial hero layout
   ---------------------------------------------------------------- */

/* hero */
.hv2-hero { background: var(--bg-0); border-bottom: 1px solid var(--line); }
.hv2-hero-inner { max-width: var(--max-w); margin: 0 auto; }

.hv2-hero-eyebrow {
  display: flex; align-items: center; gap: 12px;
  padding: clamp(16px, 2.5vw, 28px) var(--gutter);
  border-bottom: 1px solid var(--line);
  font-size: 0.5625rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--t-mute);
}
.hv2-hero-eyebrow::before { content: ""; width: 24px; height: 1px; background: var(--accent); flex-shrink: 0; }

.hv2-hero-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-bottom: 1px solid var(--line);
}
.hv2-hero-left {
  padding: clamp(28px, 5vw, 72px) var(--gutter);
  display: flex; align-items: flex-start;
  border-right: 1px solid var(--line);
}
.hv2-hero-tagline {
  font-family: var(--ff-display); font-weight: 800;
  font-size: clamp(3rem, 7.5vw, 8rem);
  line-height: 0.94; letter-spacing: -0.025em;
  color: var(--t-hi); margin: 0;
  text-wrap: balance;
}
.hv2-hero-right {
  padding: clamp(28px, 5vw, 72px) var(--gutter);
  display: flex; flex-direction: column; gap: 18px; justify-content: center;
}
.hv2-hero-body { display: contents; }
.hv2-hero-body p {
  font-size: clamp(0.875rem, 1.1vw, 1.0625rem);
  line-height: 1.68; color: var(--t-base); margin: 0;
}

.hv2-hero-bottom {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center; gap: 24px;
  padding: clamp(20px, 2.8vw, 36px) var(--gutter);
}
.hv2-kpis { display: flex; gap: clamp(20px, 4.5vw, 64px); align-items: flex-end; flex-wrap: wrap; margin: 0; }
.hv2-kpi { display: flex; flex-direction: column; gap: 5px; }
.hv2-kpi dt {
  font-size: 0.875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute); line-height: 1;
}
.hv2-kpi dd {
  margin: 0;
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.375rem, 2.8vw, 2.5rem);
  line-height: 0.9; letter-spacing: 0.01em;
  color: var(--t-hi); text-transform: uppercase;
}
.hv2-hero-cta { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; flex-shrink: 0; }

@media (max-width: 760px) {
  .hv2-hero-cols { grid-template-columns: 1fr; }
  .hv2-hero-left { border-right: 0; border-bottom: 1px solid var(--line); min-height: auto; padding-bottom: clamp(24px, 5vw, 48px); }
  .hv2-hero-bottom { grid-template-columns: 1fr; gap: 20px; }
  .hv2-kpis { gap: 24px; }
}

/* facts strip */
.hv2-facts-strip { background: var(--bg-0); border-bottom: 1px solid var(--line); }
.hv2-facts-inner { max-width: var(--max-w); margin: 0 auto; padding: 28px var(--gutter); }
.hv2-facts {
  display: grid; grid-template-columns: repeat(4, 1fr); margin: 0; padding: 0;
}
.hv2-fact { padding: 0 24px; border-right: 1px solid var(--line); }
.hv2-fact:first-child { padding-left: 0; }
.hv2-fact:last-child { border-right: 0; }
.hv2-fact dd {
  margin: 0; font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.25rem, 2.2vw, 2rem); line-height: 1;
  color: var(--t-hi); letter-spacing: 0.005em;
}
.hv2-fact dt {
  margin-top: 7px; font-size: 0.6875rem;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--t-mute);
}
@media (max-width: 880px) {
  .hv2-facts { grid-template-columns: 1fr 1fr; row-gap: 20px; }
  .hv2-fact:nth-child(2n) { border-right: 0; }
  .hv2-fact:nth-child(2n+1) { padding-left: 0; }
  .hv2-fact:nth-child(n+3) { padding-top: 20px; border-top: 1px solid var(--line); }
}

/* featured split ("not to miss") */
.hv2-featured .home-section-header {
  padding-bottom: 20px;
  grid-template-columns: 1fr auto;
}
.hv2-featured .home-section-header h2 {
  font-size: clamp(1.25rem, 2.4vw, 2.125rem);
  white-space: nowrap;
}
@media (max-width: 540px) {
  .hv2-featured .home-section-header {
    grid-template-columns: 1fr;
  }
  .hv2-featured .home-section-header h2 {
    white-space: normal;
    font-size: clamp(1.75rem, 8vw, 2.75rem);
  }
}
.hv2-featured-grid {
  max-width: var(--max-w); margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(24px, 3.5vw, 56px);
  align-items: start;
  padding: 0 var(--gutter) 32px;
}
.hv2-lead {
  display: block; text-decoration: none; color: inherit;
  transition: opacity var(--d-1);
}
.hv2-lead:hover { opacity: 0.88; }
.hv2-lead-media {
  position: relative;
  height: 340px;
  display: flex; flex-direction: column;
  justify-content: space-between;
  padding: 18px 20px 22px;
  overflow: hidden;
}
.hv2-lead-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.07) 1px, transparent 1px);
  background-size: 28px 28px;
  mix-blend-mode: overlay;
  pointer-events: none;
}
.hv2-lead-media::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: 0; height: 55%;
  background: linear-gradient(to top, rgba(0,0,0,0.38), transparent);
  pointer-events: none; z-index: 1;
}
.hv2-lead-top {
  position: relative; z-index: 2;
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 12px;
}
.hv2-lead-tag {
  font-size: 0.6875rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: #fff; font-weight: 600;
}
.hv2-lead-prem {
  font-size: 0.625rem; letter-spacing: 0.14em; text-transform: uppercase;
  background: var(--accent-deep, #B82920); color: #fff;
  padding: 4px 9px; border-radius: 2px; font-weight: 500;
  white-space: nowrap;
}
/* numbered list beside the lead card */
.hv2-list {
  list-style: none; margin: 0; padding: 0;
  border-top: 1px solid var(--line);
  align-self: center;
}
.hv2-list li { border-bottom: 1px solid var(--line); }
.hv2-list li:last-child { border-bottom: 0; }
.hv2-list a {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 16px; align-items: center;
  padding: 18px 4px;
  text-decoration: none; color: inherit;
  transition: padding var(--d-1);
}
.hv2-list a:hover { padding-left: 10px; padding-right: 0; }
.hv2-list-idx {
  font-family: var(--ff-display); font-weight: 300;
  font-size: 1.25rem; color: var(--t-mute);
  font-variant-numeric: tabular-nums;
}
.hv2-list-main { display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.hv2-list-title {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.0625rem, 1.5vw, 1.375rem);
  line-height: 1.12; letter-spacing: 0.005em;
  color: var(--t-hi);
}
.hv2-list-sub {
  font-size: 0.6875rem; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--t-mute);
}
.hv2-list-right {
  display: flex; align-items: center; gap: 10px; flex-shrink: 0;
}
.hv2-list-prem {
  font-size: 0.625rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--accent-text); font-weight: 500;
}
.hv2-list-arrow { color: var(--t-mute); transition: color var(--d-1); }
.hv2-list a:hover .hv2-list-arrow { color: var(--accent); }
@media (max-width: 880px) {
  .hv2-featured-grid { grid-template-columns: 1fr; }
  .hv2-lead-media { height: 240px; }
  .hv2-list { border-top: 0; }
}

/* industry teaser */
.hv2-industry-grid {
  max-width: var(--max-w); margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  padding: 0 var(--gutter) 32px;
}
.hv2-ind-card {
  display: flex; flex-direction: column;
  text-decoration: none; color: inherit;
  border: 1px solid var(--line);
  background: var(--bg-0);
  transition: border-color var(--d-1);
}
.hv2-ind-card:hover { border-color: var(--t-hi); }
.hv2-ind-media {
  position: relative;
  aspect-ratio: 16 / 9;
  display: flex; align-items: flex-end;
  padding: 12px;
}
.hv2-ind-media .kind {
  font-size: 0.6875rem; letter-spacing: 0.2em; text-transform: uppercase;
  font-weight: 600;
}
.hv2-ind-media .lang-badge {
  position: absolute; top: 12px; right: 12px;
  font-size: 0.625rem; letter-spacing: 0.14em; text-transform: uppercase;
  background: var(--accent-deep, #B82920); color: #fff;
  padding: 3px 7px; border-radius: 2px; font-weight: 500;
}
.hv2-ind-body {
  padding: 18px 20px 22px;
  display: flex; flex-direction: column; gap: 8px;
}
.hv2-ind-when {
  font-size: 0.75rem; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--t-mute);
}
.hv2-ind-body h3 {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.0625rem, 1.4vw, 1.3125rem);
  line-height: 1.15; letter-spacing: 0.005em;
  color: var(--t-hi);
  margin: 0;
  text-wrap: balance;
}
@media (max-width: 880px) {
  .hv2-industry-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .hv2-industry-grid { grid-template-columns: 1fr; }
}


/* ================================================================
   PROGRAMME DETAIL PAGE
   ================================================================ */


.back-bar {
  border-bottom: 1px solid var(--line);
  background: var(--bg-0);
}
.back-bar-row {
  max-width: var(--max-w); margin: 0 auto;
  padding: 14px var(--gutter);
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.back-link {
  display: inline-flex; align-items: center; gap: 12px;
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mid);
  min-height: 36px;
}
.back-link:hover { color: var(--accent); }
.back-link svg { transition: transform var(--d-1); }
.back-link:hover svg { transform: translateX(-3px); }

.prog-section-tag {
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mute);
  display: inline-flex; align-items: center; gap: 10px;
}
.prog-section-tag .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); }

/* hero (light, two columns: title + curator note) */
.prog-hero {
  background: var(--bg-0);
  color: var(--t-base);
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.prog-hero-inner {
  max-width: var(--max-w); margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.prog-hero-text {
  padding: 40px clamp(20px, 4vw, 56px);
  display: flex; flex-direction: column; justify-content: start; gap: 14px;
  position: relative;
  z-index: 2;
  border-right: 1px solid var(--line);
}
.prog-hero-num {
  font-family: var(--ff-display);
  font-size: clamp(4.5rem, 11vw, 11.25rem);
  line-height: 0.85;
  color: rgba(10,10,9,0.08);
  letter-spacing: 0;
  margin: 0;
}
.prog-hero-title {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(2.5rem, 5.2vw, 4.75rem);
  line-height: 0.96; letter-spacing: 0.005em;
  color: var(--t-hi);
  margin: 4px 0 0;
  text-wrap: balance;
}
.prog-hero-title .em { color: var(--accent); }
.prog-hero-meta {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px 32px;
  margin-top: 8px;
  border-top: 1px solid var(--line);
  padding-top: 16px;
}
.prog-hero-meta dt {
  font-size: 0.625rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute); margin-bottom: 6px;
}
.prog-hero-meta dd { margin: 0; font-size: 0.875rem; color: var(--t-hi); letter-spacing: 0.03em; }

.prog-hero-cta {
  margin-top: auto;
  padding-top: 18px;
  display: flex;
}
.prog-hero-cta .btn {
  padding: 16px 26px;
  font-size: 0.75rem; letter-spacing: 0.18em;
}

.prog-hero-still {
  position: relative;
  background: var(--bg-1);
  border-left: 1px solid var(--line);
  padding: 40px clamp(20px, 4vw, 56px);
  display: flex; flex-direction: column; gap: 16px; justify-content: start;
  color: var(--t-base);
}
.prog-hero-still .note-eyebrow {
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
  display: inline-flex; align-items: center; gap: 12px;
}
.prog-hero-still .note-eyebrow::before { content: ""; width: 24px; height: 1px; background: var(--accent); }
.prog-hero-still .curator-note {
  font-size: clamp(1rem, 1.5vw, 1.1875rem);
  line-height: 1.5; letter-spacing: 0.02em;
  color: var(--t-hi);
  margin: 0;
  text-wrap: pretty;
}
.prog-hero-still .curator-credit {
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mute);
  display: inline-flex; align-items: center; gap: 12px;
  margin-top: 8px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}
@media (max-width: 880px) {
  .prog-hero-inner { grid-template-columns: 1fr; }
  .prog-hero-still { padding: 32px 20px; border-left: 0; border-top: 1px solid var(--line); }
  .prog-hero-text { padding: 40px 20px; }
  .prog-hero-meta { grid-template-columns: 1fr 1fr; }
}

/* practical info as horizontal strip below the hero */
.prog-practical-strip {
  border-bottom: 1px solid var(--line);
  background: var(--bg-0);
}
.prog-practical-strip-row {
  max-width: var(--max-w); margin: 0 auto;
  padding: 32px var(--gutter);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.prog-practical-strip .item.is-off .ic { color: var(--t-mute); opacity: 0.5; }
.prog-practical-strip .item.is-off .body { color: var(--t-mute); }
.prog-practical-strip .item {
  display: flex; gap: 14px; align-items: start;
  padding: 0 20px;
  border-right: 1px solid var(--line);
}
.prog-practical-strip .item:first-child { padding-left: 0; }
.prog-practical-strip .item:last-child { border-right: 0; padding-right: 0; }
.prog-practical-strip .item .ic {
  flex-shrink: 0; color: var(--accent);
  padding-top: 2px;
}
.prog-practical-strip .item .body {
  display: flex; flex-direction: column; gap: 6px;
  font-size: 0.8125rem; line-height: 1.45;
  color: var(--t-base);
  letter-spacing: 0.02em;
  min-width: 0;
}
.prog-practical-strip .item .body strong {
  display: block;
  font-size: 0.625rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
  font-weight: 400;
  margin-bottom: 2px;
}
@media (max-width: 880px) {
  .prog-practical-strip-row { grid-template-columns: 1fr 1fr; row-gap: 24px; }
  .prog-practical-strip .item { padding: 0 16px; }
  .prog-practical-strip .item:nth-child(odd) { padding-left: 0; border-right: 1px solid var(--line); }
  .prog-practical-strip .item:nth-child(even) { border-right: 0; padding-right: 0; }
  .prog-practical-strip .item:nth-child(n+3) { padding-top: 24px; border-top: 1px solid var(--line); }
}

/* AD / SDH chips in the hero */
.access-chips {
  list-style: none; margin: 22px 0 0; padding: 16px 0 0;
  display: flex; flex-wrap: wrap; gap: 10px;
  border-top: 1px solid var(--line);
}
.access-chip {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 12px 8px 10px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  font-size: 0.75rem; letter-spacing: 0.04em;
  color: var(--t-hi);
  background: var(--bg-0);
  line-height: 1;
}
.access-chip .ac-ic {
  display: inline-flex; width: 22px; height: 22px;
  align-items: center; justify-content: center;
  color: var(--accent);
}
.access-chip .ac-abbr {
  font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase;
  font-size: 0.6875rem;
  padding-right: 8px; border-right: 1px solid var(--line);
}
.access-chip .ac-label { color: var(--t-base); }
.access-chip .ac-status {
  display: inline-flex; width: 18px; height: 18px;
  align-items: center; justify-content: center;
  border-radius: 50%;
  color: #fff;
  background: var(--accent);
  margin-left: 2px;
}
.access-chip.is-off {
  color: var(--t-mute);
  background: transparent;
  border-color: var(--line);
}
.access-chip.is-off .ac-ic { color: var(--t-mute); opacity: 0.55; }
.access-chip.is-off .ac-abbr { color: var(--t-mute); border-right-color: var(--line); }
.access-chip.is-off .ac-label { color: var(--t-mute); text-decoration: line-through; text-decoration-thickness: 1px; text-underline-offset: 2px; }
.access-chip.is-off .ac-status { background: transparent; color: var(--t-mute); border: 1px solid var(--line-strong); }

/* meta-bar / ctas */
.prog-actions {
  border-bottom: 1px solid var(--line);
  background: var(--bg-0);
}
.prog-actions-row {
  max-width: var(--max-w); margin: 0 auto;
  padding: 18px var(--gutter);
  display: flex; flex-wrap: wrap; gap: 12px;
  align-items: center;
}
.prog-actions-row .key-info {
  margin-right: auto;
  display: flex; gap: 24px; align-items: center; flex-wrap: wrap;
  font-size: 0.75rem; letter-spacing: 0.06em; color: var(--t-mid);
}
.prog-actions-row .key-info strong { color: var(--t-hi); font-weight: 400; }
@media (max-width: 880px) {
  .prog-actions-row .key-info { width: 100%; margin-right: 0; }
}

/* content */
.prog-body {
  max-width: var(--max-w); margin: 0 auto;
  padding: 0 var(--gutter);
}
.prog-content-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 64px;
  padding: 64px 0;
  border-bottom: 1px solid var(--line);
  align-items: start;
}
.prog-note {
  font-size: 1.125rem; line-height: 1.55; letter-spacing: 0.025em;
  color: var(--t-base);
  max-width: 60ch;
}
.prog-note p { margin: 0 0 20px; }
.prog-note .pull {
  font-family: var(--ff-display);
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  line-height: 1.15; color: var(--t-hi);
  margin: 28px 0;
  border-top: 1px solid var(--line);
  padding-top: 28px;
  text-wrap: balance;
}
.prog-curator {
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mute); margin-top: 24px;
  display: flex; gap: 12px; align-items: center;
}
.prog-curator::before { content: ""; width: 20px; height: 1px; background: var(--accent); }
.prog-practical {
  display: flex; flex-direction: column; gap: 18px;
  border: 1px solid var(--line);
  padding: 24px;
  background: var(--bg-1);
  height: fit-content;
  position: sticky; top: 100px;
}
.prog-practical h3 {
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mute); margin: 0;
}
.prog-practical .item {
  display: flex; gap: 12px; align-items: start;
  font-size: 0.8125rem; line-height: 1.45; color: var(--t-base);
  letter-spacing: 0.02em;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--line);
}
.prog-practical .item:last-child { border-bottom: 0; padding-bottom: 0; }
.prog-practical .item .ic {
  width: 22px; flex-shrink: 0; color: var(--accent);
  display: inline-flex; align-items: start; justify-content: center;
  padding-top: 2px;
}
.prog-practical .item strong {
  display: block; color: var(--t-hi); font-weight: 400;
  font-size: 0.6875rem; letter-spacing: 0.14em; text-transform: uppercase;
  margin-bottom: 4px;
}
@media (max-width: 880px) {
  .prog-content-grid { grid-template-columns: 1fr; gap: 32px; padding: 40px 0; }
  .prog-practical { position: static; }
}

.prog-films-section {
  padding: 40px 0;
  border-bottom: 1px solid var(--line);
}
.prog-section-title {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(2.5rem, 5vw, 4rem);
  line-height: 0.94; letter-spacing: 0.005em;
  color: var(--t-hi);
  margin: 0 0 12px;
}
.prog-section-eyebrow {
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
  display: inline-flex; align-items: center; gap: 12px;
  margin-bottom: 16px;
}
.prog-section-eyebrow::before { content: ""; width: 24px; height: 1px; background: var(--accent); }
.prog-section-intro {
  color: var(--t-base); font-size: 0.9375rem; line-height: 1.55; letter-spacing: 0.03em;
  margin: 0 0 32px; max-width: 56ch;
}

.film-entries {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
}
.film-entry {
  display: flex;
  flex-direction: column;
  padding: 24px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--bg-0);
  align-items: stretch;
}
.film-entry:nth-child(2n) { border-right: 0; }
.film-entry .still {
  aspect-ratio: 16 / 10;
  width: 100%;
  margin-bottom: 18px;
  background: var(--poster-bg);
  position: relative;
  overflow: hidden;
}
.film-entry .still .still-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  transform: scale(1.35);
}
.film-entry .still .placeholder {
  position: absolute; inset: 0;
  background: linear-gradient(160deg, var(--still-a, #1c1a14), var(--still-b, #0a0907));
  display: flex; align-items: center; justify-content: center;
  color: rgba(232,226,212,0.35);
  font-family: ui-monospace, monospace;
  font-size: 0.625rem; letter-spacing: 0.22em; text-transform: uppercase;
}
.film-entry .still .placeholder::before {
  content: ""; position: absolute; inset: 0;
  background: repeating-linear-gradient(135deg, rgba(255,255,255,0.014) 0 12px, rgba(255,255,255,0) 12px 24px);
}
.film-entry .still .num {
  position: absolute; top: 12px; left: 12px;
  font-family: var(--ff-display); font-size: 1rem; color: var(--t-on-dark);
  letter-spacing: 0.08em;
  background: rgba(0,0,0,0.4); padding: 4px 10px;
}
.film-entry .still .duration {
  position: absolute; bottom: 12px; right: 12px;
  font-size: 0.625rem; letter-spacing: 0.14em; color: var(--t-on-dark);
  background: rgba(0,0,0,0.55); padding: 4px 8px;
  font-variant-numeric: tabular-nums;
}

.film-entry .body { display: flex; flex-direction: column; gap: 10px; min-width: 0; }
.film-entry .title {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.5rem, 2vw, 2rem);
  line-height: 1.02; letter-spacing: 0.005em;
  text-transform: uppercase;
  color: var(--t-hi);
  margin: 0;
}
.film-entry .title .ot {
  display: block; font-size: 0.875rem; color: var(--t-mute); letter-spacing: 0.05em;
  margin-top: 4px; font-style: italic; font-weight: 300;
  unicode-bidi: isolate;
}
.film-entry .meta {
  display: flex; gap: 16px 20px; flex-wrap: wrap;
  font-size: 0.75rem; letter-spacing: 0.06em; color: var(--t-mid);
}
.film-entry .meta .label {
  font-size: 0.625rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--t-mute);
  display: block; margin-bottom: 2px;
}
.film-entry .meta strong { color: var(--t-hi); font-weight: 400; }
.film-entry .syn {
  font-size: 0.875rem; line-height: 1.55; letter-spacing: 0.025em;
  color: var(--t-soft); margin: 4px 0 0;
  max-width: 60ch;
}
@media (max-width: 880px) {
  .film-entries { grid-template-columns: 1fr; }
  .film-entry { border-right: 0; }
  .film-entry:nth-child(2n) { border-right: 0; }
  .film-entry .still { aspect-ratio: 4/3; }
}

.prog-sessions-section {
  padding: 40px 0;
  border-bottom: 1px solid var(--line);
}
.prog-session-row {
  display: grid;
  grid-template-columns: 140px 1fr auto;
  gap: 28px;
  padding: 22px 0;
  border-top: 1px solid var(--line);
  align-items: center;
}
.prog-session-row:last-child { border-bottom: 1px solid var(--line); }
.prog-session-row .date {
  font-family: var(--ff-display); font-size: 2rem;
  color: var(--t-hi); letter-spacing: 0.02em;
  font-variant-numeric: tabular-nums;
}
.prog-session-row .date small {
  display: block;
  font-family: var(--ff); font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mute); margin-top: 6px;
}
.prog-session-row .where {
  font-size: 0.875rem; color: var(--t-hi); letter-spacing: 0.04em;
}
.prog-session-row .where small {
  display: block; font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mute); margin-top: 4px;
}
.prog-session-row .times { display: flex; gap: 8px; flex-wrap: wrap; }

@media (max-width: 640px) {
  .prog-session-row {
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    gap: 8px 12px;
    padding: 12px 0;
  }
  .prog-session-row .date {
    grid-column: 1; grid-row: 1;
    font-size: 1rem;
  }
  .prog-session-row .date small {
    display: inline; margin-top: 0; margin-left: 6px;
  }
  .prog-session-row .where {
    grid-column: 2; grid-row: 1;
    align-self: center;
  }
  .prog-session-row .times {
    grid-column: 1 / -1; grid-row: 2;
    flex-direction: column;
  }
  .prog-session-row .times .time-btn {
    width: 100%; flex-direction: row; gap: 8px;
    justify-content: center; min-height: 44px;
  }
}

/* prev / next */
.prog-prevnext {
  display: grid; grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.prog-prevnext a {
  display: flex; flex-direction: column; gap: 8px;
  padding: 32px var(--gutter);
  color: var(--t-mid);
  transition: background var(--d-1);
}
.prog-prevnext a:hover { background: var(--bg-1); color: var(--t-hi); }
.prog-prevnext a .dir {
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--t-mute);
}
.prog-prevnext a .ttl {
  font-family: var(--ff-display);
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  line-height: 1.05; color: var(--t-hi);
}
.prog-prevnext .next { text-align: right; border-left: 1px solid var(--line); }
.prog-prevnext .next:only-child { grid-column: 2; }
.prog-prevnext .prev:only-child { grid-column: 1; }
@media (max-width: 720px) {
  .prog-prevnext { grid-template-columns: 1fr; }
  .prog-prevnext .next { text-align: left; border-left: 0; border-top: 1px solid var(--line); }
}

.cal-wrap {
  max-width: var(--max-w);
  margin: 0 auto;
  overflow-x: auto;
  scrollbar-width: thin;
  border-bottom: 1px solid var(--line);
}
.cal-wrap.is-hidden { display: none; }
.cal-scroll-outer {
  position: relative;
}
@media (max-width: 720px) {
  .cal-scroll-outer::after {
    content: "";
    position: absolute;
    top: 0; right: 0; bottom: 0;
    width: 64px;
    background: linear-gradient(to right, transparent, var(--bg-0));
    pointer-events: none;
    z-index: 30;
    transition: opacity 0.2s;
  }
  .cal-scroll-outer.is-scrolled-end::after {
    opacity: 0;
  }
}
.cal {
  display: grid;
  grid-template-columns: 64px repeat(7, minmax(150px, 1fr));
  min-width: 1100px;
  background: var(--bg-0);
}
.cal-corner {
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--bg-1);
  position: sticky; top: 0; left: 0; z-index: 6;
}
.cal-day-head {
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--bg-1);
  padding: 14px 16px;
  position: sticky; top: 0; z-index: 4;
  display: flex; flex-direction: column; gap: 4px;
}
.cal-day-head .num {
  font-family: var(--ff-display);
  font-size: 1.75rem;
  line-height: 1;
  color: var(--t-hi);
  font-variant-numeric: tabular-nums;
}
.cal-day-head .wk {
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
}
.cal-day-head .cnt {
  font-size: 0.625rem; letter-spacing: 0.14em; color: var(--t-mute);
  margin-top: 2px;
  font-variant-numeric: tabular-nums;
}
.cal-day-head.is-today { background: var(--bg-2); }
.cal-day-head.is-today .num { color: var(--accent); }

.cal-time-col {
  display: flex; flex-direction: column;
  border-right: 1px solid var(--line);
  background: var(--bg-1);
  position: sticky; left: 0; z-index: 3;
}
.cal-hour {
  flex-shrink: 0;
  height: 64px;
  display: flex; align-items: start; justify-content: end;
  padding: 4px 10px 0;
  font-size: 0.625rem; letter-spacing: 0.14em;
  color: var(--t-mute);
  font-variant-numeric: tabular-nums;
  border-bottom: 1px solid var(--line);
}
.cal-hour:last-child { border-bottom: 0; }

.cal-day-col {
  position: relative;
  border-right: 1px solid var(--line);
  background: var(--bg-0);
}
.cal-day-col:last-child { border-right: 0; }
.cal-day-col.is-today { background: rgba(0, 0, 0, 0.025); }
.cal-grid-lines {
  position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(
      to bottom,
      transparent 0,
      transparent 63px,
      var(--line) 63px,
      var(--line) 64px
    );
  pointer-events: none;
}

.cal-event {
  position: absolute;
  left: 0; right: 0;
  padding: 6px 8px;
  border-radius: 2px;
  background: var(--cal-bg, var(--accent));
  color: var(--cal-fg, #fff);
  font-family: var(--ff);
  font-size: 0.6875rem; line-height: 1.25;
  letter-spacing: 0.02em;
  text-align: left;
  cursor: pointer;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,0.15);
  transition: transform var(--d-1) var(--ease), box-shadow var(--d-1) var(--ease);
  z-index: 2;
  display: flex; flex-direction: column; gap: 2px;
}
.cal-event:hover, .cal-event:focus-visible {
  z-index: 4;
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(0,0,0,0.25);
}
.cal-event .ev-time {
  font-family: var(--ff-display);
  font-size: 0.6875rem;
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
  opacity: 0.92;
}
.cal-event .ev-title {
  font-family: var(--ff-display);
  font-size: 0.8125rem; line-height: 1.1;
  letter-spacing: 0.005em;
  text-transform: none;
  font-weight: 300;
}
.cal-event .ev-venue {
  font-size: 0.5625rem; letter-spacing: 0.16em; text-transform: uppercase;
  opacity: 0.8; margin-top: auto;
}
.cal-event.is-soldout {
  background: transparent !important;
  color: var(--t-mute) !important;
  border: 1px dashed var(--line-strong);
  text-decoration: line-through;
}
.cal-event.is-tiny .ev-venue { display: none; }
.cal-event.is-tiny .ev-title { font-size: 0.6875rem; }
.cal-event.spans-midnight::after {
  content: "→";
  position: absolute; bottom: 4px; right: 6px;
  font-size: 0.875rem; line-height: 1; opacity: 0.7;
}

/* view toggle button row */
.view-toggle.schedule-view {
  margin-left: auto;
}

@media (max-width: 720px) {
  .cal-corner, .cal-day-head { height: auto; padding: 10px 12px; }
  .cal-day-head .num { font-size: 1.375rem; }
}

/* ================================================================
   SCHEDULE PAGE / responsive tail
   ================================================================ */

/* empty state */
.schedule-empty {
  padding: 80px var(--gutter);
  text-align: center;
  color: var(--t-mute);
  font-size: 0.875rem; letter-spacing: 0.06em;
  border-top: 1px solid var(--line);
}
.schedule-empty button {
  margin-top: 16px;
  padding: 12px 20px; min-height: 44px;
  border: 1px solid var(--line-strong);
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-hi);
  background: transparent;
}
.schedule-empty button:hover { background: var(--bg-2); }

/* ---- Industry hero ---- */
.ind-hero {
  padding: 48px 0 56px;
  background: var(--bg-0);
}
.ind-hero-inner {
  max-width: var(--max-w); margin: 0 auto;
  padding: 0 var(--gutter);
}
.ind-hero-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 0.75rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mid);
  margin-bottom: 28px;
}
.ind-hero-eyebrow .dot {
  width: 10px; height: 10px; border-radius: 50%;
  display: inline-block;
}
.ind-hero-title {
  font-family: var(--ff-display);
  font-size: clamp(2.5rem, 5.5vw, 5.5rem);
  line-height: 0.9;
  letter-spacing: -0.015em;
  margin: 0 0 24px;
  max-width: 18ch;
  text-wrap: balance;
}
.ind-hero-intro {
  font-size: clamp(0.9375rem, 1.2vw, 1.125rem);
  line-height: 1.55;
  color: var(--t-mid);
  max-width: 56ch;
  margin: 0 0 36px;
}
.ind-hero-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  padding-top: 24px;
  max-width: 720px;
}
.ind-hero-stats > div {
  padding: 0 18px;
  border-right: 1px solid var(--line);
}
.ind-hero-stats > div:first-child { padding-left: 0; }
.ind-hero-stats > div:last-child { border-right: 0; padding-right: 0; }
.ind-hero-stats .num {
  font-family: var(--ff-display);
  font-size: 2rem;
  line-height: 1;
  color: var(--t-hi);
  margin-bottom: 6px;
}
.ind-hero-stats .lbl {
  font-size: 0.625rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--t-mute);
}
@media (max-width: 720px) {
  .ind-hero { padding: 32px 0 40px; }
  .ind-hero-eyebrow { margin-bottom: 18px; }
  .ind-hero-title { margin-bottom: 18px; }
  .ind-hero-intro { margin-bottom: 28px; }
  .ind-hero-stats {
    grid-template-columns: 1fr 1fr;
    row-gap: 18px;
  }
  .ind-hero-stats > div:nth-child(2n) { border-right: 0; }
  .ind-hero-stats > div:nth-child(odd) { padding-left: 0; }
  .ind-hero-stats > div:nth-child(n+3) {
    padding-top: 18px;
    border-top: 1px solid var(--line);
  }
}

/* ---- Industry filter row (similar to schedule) ---- */
.ind-filter-row {
  background: var(--bg-0);
  position: sticky;
  top: var(--row-h);
  z-index: 19;
}
.ind-filter-row .ind-filter-mobilebar { display: none; }
.ind-filter-groups {
  display: flex; flex-wrap: wrap;
  gap: 28px;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 16px var(--gutter);
  align-items: center;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.ind-filter-group {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.ind-filter-group .label {
  font-size: 0.625rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
  margin-right: 4px;
}
.ind-filter-chips {
  display: flex; gap: 6px; flex-wrap: wrap;
}
.ind-filter-actions { display: none; }
@media (max-width: 880px) {
  .ind-filter-row {
    padding: 12px var(--gutter);
    flex-direction: column;
  }
  .ind-filter-row .ind-filter-mobilebar {
    display: flex; align-items: center;
    max-width: var(--max-w);
    margin: 0 auto;
    padding: 0;
  }
  .ind-filter-groups {
    display: none;
  }
  .ind-filter-row.is-open .ind-filter-groups {
    display: flex; flex-direction: column; align-items: stretch;
    gap: 18px;
    padding: 16px 0 0;
    margin-top: 12px;
    border-top: 1px solid var(--line);
  }
  .ind-filter-row.is-open .ind-filter-group {
    flex-direction: column; align-items: stretch; gap: 10px;
  }
  .ind-filter-actions {
    display: flex; gap: 8px; align-items: center; justify-content: space-between;
    padding: 12px 0;
    border-top: 1px solid var(--line);
  }
}

/* ---- Industry list (day groups + cards) ---- */
.ind-list {
  padding: 32px 0 80px;
  background: var(--bg-0);
}
.ind-list-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.ind-empty {
  padding: 80px 0;
  text-align: center;
  color: var(--t-mute);
}
.ind-empty .btn { margin-top: 18px; }

.ind-day-group {
  padding: 36px 0 8px;
  border-top: 1px solid var(--line);
}
.ind-day-group:first-child { border-top: 0; padding-top: 12px; }
.ind-day-head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 20px;
  align-items: baseline;
  margin-bottom: 24px;
}
.ind-day-head .day-num {
  font-family: var(--ff-display);
  font-size: clamp(3rem, 5vw, 5rem);
  line-height: 0.9;
  color: var(--t-hi);
}
.ind-day-head .day-meta {
  display: flex; flex-direction: column;
  padding-bottom: 8px;
}
.ind-day-head .day-meta .month {
  font-size: 1rem;
  color: var(--t-base);
  letter-spacing: 0.02em;
  text-transform: capitalize;
}
.ind-day-head .day-meta .wkday {
  font-size: 0.6875rem;
  color: var(--t-mute);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin-top: 2px;
}
.ind-day-head .day-count {
  font-size: 0.6875rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--t-mute);
  padding-bottom: 8px;
}
@media (max-width: 720px) {
  .ind-day-head {
    grid-template-columns: auto 1fr;
    gap: 16px;
  }
  .ind-day-head .day-num { font-size: 3rem; }
  .ind-day-head .day-count {
    grid-column: 1 / -1;
    padding-bottom: 0;
  }
}

.ind-card-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* ---- Industry card (option 0: thumbnail + body + arrow) ---- */
.ind-card {
  display: grid;
  grid-template-columns: 200px 1fr auto;
  gap: 24px;
  padding: 18px;
  border: 1px solid var(--line);
  background: var(--bg-0);
  color: inherit;
  text-decoration: none;
  transition: border-color 0.15s, background 0.15s, transform 0.15s;
  align-items: stretch;
}
.ind-card:hover {
  border-color: var(--t-hi);
  background: var(--bg-1);
}
.ind-card-side {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.ind-card-thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.ind-card-thumb-img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  display: block !important;
}
.ind-card-thumb-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: 16px 16px;
  mix-blend-mode: overlay;
  pointer-events: none;
}
.ind-card-thumb-kind {
  position: absolute;
  left: 12px; bottom: 10px;
  font-size: 0.6875rem; letter-spacing: 0.2em;
  font-weight: 600;
  text-transform: uppercase;
  pointer-events: none;
  z-index: 2;
}
.ind-card-date {
  display: flex; align-items: baseline; gap: 8px;
  padding: 0 4px;
  font-variant-numeric: tabular-nums;
}
.ind-card-date .num {
  font-family: var(--ff-display);
  font-size: 2rem;
  line-height: 1;
  color: var(--t-hi);
}
.ind-card-date .mon {
  font-size: 0.75rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--t-mute);
}
.ind-card-date .wd {
  margin-left: auto;
  font-size: 0.6875rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--t-mute);
}

.ind-card-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
  padding-top: 2px;
}
.ind-card-meta-top {
  display: flex; align-items: center; gap: 16px;
  flex-wrap: wrap;
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
}
.ind-kind {
  display: inline-flex; align-items: center;
  padding: 4px 9px;
  background: var(--industry-color);
  color: #FFFEF1;
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border-radius: 2px;
  line-height: 1.2;
}
.ind-lang {
  display: inline-flex; align-items: center;
  padding: 4px 9px;
  background: var(--accent-deep);
  color: #fff;
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border-radius: 2px;
  line-height: 1.2;
}
.ind-full {
  display: inline-flex;
  font-size: 0.625rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #fff;
  background: var(--t-hi);
  padding: 4px 8px;
}
.ind-card-title {
  font-family: var(--ff-display);
  font-weight: 300;
  font-size: clamp(1.25rem, 1.6vw, 1.625rem);
  line-height: 1.1;
  margin: 0;
  color: var(--t-hi);
  text-wrap: balance;
  letter-spacing: 0.005em;
}
.ind-card-summary {
  font-size: 0.875rem;
  line-height: 1.5;
  color: var(--t-mid);
  margin: 0;
  max-width: 64ch;
}
.ind-card-foot {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 16px;
  align-items: baseline;
  margin-top: 4px;
  padding-top: 10px;
  border-top: 1px dashed var(--line);
}
.ind-card-where {
  display: flex; gap: 8px; align-items: baseline;
  font-size: 0.8125rem;
  color: var(--t-base);
  font-variant-numeric: tabular-nums;
}
.ind-card-where .time { color: var(--t-hi); font-weight: 500; }
.ind-card-where .sep { color: var(--t-mute); }
.ind-card-where .venue { color: var(--t-mid); display: inline-flex; align-items: center; gap: 5px; }

/* wheelchair / accessibility badge */
.venue-accessible { display: inline-flex; align-items: center; flex-shrink: 0; margin-left: 5px; }
.wheelchair-icon {
  width: 14px; height: 14px;
  opacity: 0.5;
  vertical-align: middle;
}
.ind-card-speakers {
  font-size: 0.8125rem;
  letter-spacing: 0.04em;
  color: var(--t-mid);
}
.ind-card-capacity {
  display: flex; align-items: center; gap: 10px;
  margin-top: 4px;
  font-size: 0.6875rem;
  color: var(--t-mute);
}
.ind-card-capacity .bar {
  flex: 1;
  height: 3px;
  background: var(--line);
  position: relative;
  overflow: hidden;
}
.ind-card-capacity .bar span {
  display: block;
  height: 100%;
  background: var(--industry-color);
  transition: width 0.3s;
}
.ind-card-capacity .cap-text {
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.06em;
  flex-shrink: 0;
}

.ind-card-arrow {
  display: flex; align-items: center; justify-content: center;
  width: 40px;
  color: var(--t-mute);
  transition: color 0.15s, transform 0.15s;
}
.ind-card:hover .ind-card-arrow {
  color: var(--t-hi);
  transform: translateX(4px);
}

@media (max-width: 720px) {
  .ind-card {
    grid-template-columns: 48px 1fr;
    gap: 12px 14px;
    padding: 14px 16px;
  }
  .ind-card-thumb { display: none; }
  .ind-card-side {
    align-self: start;
    gap: 0;
    padding-top: 2px;
  }
  .ind-card-date {
    flex-direction: column;
    align-items: center;
    gap: 1px;
    padding: 0;
  }
  .ind-card-date .num { font-size: 1.375rem; }
  .ind-card-date .mon { font-size: 0.625rem; }
  .ind-card-date .wd  { display: none; }
  .ind-card-arrow { display: none; }
  .ind-card-title { font-size: 1.125rem; }
  .ind-card-summary { font-size: 0.8125rem; }
  .ind-card-meta-top { gap: 10px; }
}

@media (max-width: 880px) {
  .ind-card {
    grid-template-columns: 140px 1fr;
    gap: 16px;
    padding: 14px;
  }
  .ind-card-arrow { display: none; }
  .ind-card-side { gap: 10px; }
  .ind-card-date .num { font-size: 1.375rem; }
  .ind-card-date .wd { display: none; }
}
@media (max-width: 540px) {
  .ind-card {
    grid-template-columns: 1fr;
    gap: 14px;
    padding: 14px;
  }
  .ind-card-side {
    flex-direction: row;
    align-items: center;
    gap: 16px;
  }
  .ind-card-thumb {
    width: 96px;
    aspect-ratio: 4/3;
    flex-shrink: 0;
  }
  .ind-card-date {
    padding: 0;
  }
}

/* ---- Industry event DETAIL page ---- */
.ind-detail-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mid);
  margin-bottom: 8px;
}
.ind-detail-eyebrow .dot {
  width: 10px; height: 10px; border-radius: 50%;
  display: inline-block;
}
.ind-detail-eyebrow .sep { color: var(--line-strong); }
.ind-detail-eyebrow .lang-pill {
  padding: 3px 8px;
  border: 1px solid var(--line);
  font-size: 0.625rem;
  letter-spacing: 0.14em;
}
.ind-detail-summary {
  font-size: clamp(0.9375rem, 1.2vw, 1.125rem);
  line-height: 1.5;
  color: var(--t-mid);
  margin: -8px 0 24px;
  max-width: 50ch;
}

.ind-detail-register {
  margin-top: 28px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
}
.ind-detail-register .btn-large {
  padding: 0 28px;
  min-height: 56px; height: 56px;
  font-size: 0.75rem;
  letter-spacing: 0.18em;
}
.ind-detail-register .register-meta {
  margin-top: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: 380px;
}
.ind-detail-register .cap-bar {
  height: 4px;
  background: var(--line);
  overflow: hidden;
}
.ind-detail-register .cap-bar span {
  display: block;
  height: 100%;
  background: var(--industry-color);
}
.ind-detail-register .cap-text {
  font-size: 0.8125rem;
  color: var(--t-mid);
}
.ind-detail-register .cap-text strong { color: var(--t-hi); }
.ind-detail-register .cap-note {
  font-size: 0.6875rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--t-mute);
}
.ind-detail-register-full {
  display: flex; flex-direction: column; gap: 6px;
  padding: 16px 18px;
  background: var(--bg-1);
  border: 1px solid var(--line);
}
.ind-detail-register-full strong {
  font-size: 0.75rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--t-hi);
}
.ind-detail-register-full span {
  font-size: 0.8125rem;
  color: var(--t-mid);
}

/* Side panel on detail hero */
.ind-detail-side {
  display: flex; flex-direction: column; gap: 24px;
  padding: 0 !important;
  background: transparent !important;
}
.ind-side-thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.ind-side-thumb-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.08) 1px, transparent 1px);
  background-size: 24px 24px;
  mix-blend-mode: overlay;
}
.ind-side-thumb-kind {
  position: absolute;
  top: 14px; left: 14px;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  color: rgba(255,255,255,0.95);
  font-weight: 600;
}
.ind-side-thumb-date {
  position: absolute;
  bottom: 14px; right: 14px;
  display: flex; align-items: baseline; gap: 6px;
  color: #fff;
}
.ind-side-thumb-date .num {
  font-family: var(--ff-display);
  font-size: 3rem;
  line-height: 0.9;
}
.ind-side-thumb-date .mon {
  font-size: 0.6875rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.ind-side-speakers {
  padding: 0;
}
.ind-side-speaker-list {
  list-style: none; padding: 0; margin: 12px 0 0;
  display: flex; flex-direction: column; gap: 14px;
}
.ind-side-speaker-list li {
  display: flex; align-items: center; gap: 14px;
}
.ind-side-speaker-list strong {
  display: block;
  font-size: 0.875rem;
  color: var(--t-hi);
  font-weight: 500;
}
.ind-side-speaker-list span {
  display: block;
  font-size: 0.75rem;
  color: var(--t-mute);
  margin-top: 2px;
}
.speaker-avatar {
  border-radius: 50%;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.85);
  font-family: var(--ff-display);
  font-weight: 400;
  letter-spacing: 0.02em;
  object-fit: cover;
}

/* Industry sections (about, speakers, related) */
.ind-section {
  padding: 60px 0;
  border-top: 1px solid var(--line);
}
.ind-section-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.ind-section-title {
  font-family: var(--ff-display);
  font-weight: 300;
  font-size: clamp(1.75rem, 3vw, 2.75rem);
  line-height: 1.02;
  letter-spacing: 0.005em;
  margin: 0 0 28px;
  color: var(--t-hi);
}
.ind-section-body {
  font-size: 1rem;
  line-height: 1.65;
  color: var(--t-base);
  max-width: 64ch;
  text-wrap: pretty;
}
.ind-partners {
  margin-top: 32px;
}
.ind-partners ul {
  list-style: none; margin: 8px 0 0; padding: 0;
  display: flex; gap: 8px; flex-wrap: wrap;
}
.ind-partners li {
  padding: 6px 12px;
  border: 1px solid var(--line);
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  color: var(--t-mid);
}

.ind-section-speakers {
  background: transparent;
  border-top: 0;
  padding-top: 0;
}
.ind-section-speakers .ind-section-inner {
  border-top: 1px solid var(--line);
  padding-top: 60px;
}
/* drop hero's edge-to-edge border when speakers section follows immediately */
.prog-hero:has(+ .ind-section-speakers) {
  border-bottom: 0;
}
.ind-speaker-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  border-top: 1px solid var(--line);
}
.ind-speaker-card {
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 20px;
  padding: 28px 32px 28px 0;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  align-items: start;
  position: relative;
}
.ind-speaker-card:nth-child(2n) { border-right: 0; padding-right: 0; }
.ind-speaker-card:nth-child(2n+1) { padding-left: 0; }
.ind-speaker-card:nth-child(2n) { padding-left: 32px; }
/* last row: drop bottom border */
.ind-speaker-grid.is-3 .ind-speaker-card:nth-last-child(-n+1) { border-bottom: 0; padding-bottom: 0; }
.ind-speaker-grid.is-4 .ind-speaker-card:nth-last-child(-n+2) { border-bottom: 0; padding-bottom: 0; }
.ind-speaker-grid.is-5 .ind-speaker-card:nth-last-child(-n+1) { border-bottom: 0; padding-bottom: 0; }
.ind-speaker-grid.is-6 .ind-speaker-card:nth-last-child(-n+2) { border-bottom: 0; padding-bottom: 0; }
/* odd-count last item: span full row */
.ind-speaker-grid.is-3 .ind-speaker-card:last-child,
.ind-speaker-grid.is-5 .ind-speaker-card:last-child {
  grid-column: 1 / -1;
  padding-right: 0;
  padding-left: 0;
  border-right: 0;
}
.ind-speaker-card .speaker-avatar {
  margin-top: 4px;
  width: 88px !important;
  height: 88px !important;
}
.ind-speaker-card .role-badge {
  position: absolute;
  top: 28px;
  right: 32px;
  font-size: 0.6875rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #fff;
  background: var(--accent-deep);
  padding: 4px 10px;
  border-radius: 2px;
  font-weight: 500;
}
.ind-speaker-card:nth-child(2n) .role-badge { right: 0; }
@media (max-width: 880px) {
  .ind-speaker-grid {
    grid-template-columns: 1fr;
  }
  .ind-speaker-card {
    grid-template-columns: 72px 1fr;
    padding: 24px 0 !important;
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }
  .ind-speaker-card .speaker-avatar {
    width: 72px !important;
    height: 72px !important;
  }
  .ind-speaker-card .role-badge { right: 0 !important; }
  .ind-speaker-grid .ind-speaker-card:last-child {
    grid-column: auto !important;
    border-bottom: 0;
    padding-bottom: 0 !important;
  }
}
.ind-speaker-body h3 {
  font-family: var(--ff-display);
  font-weight: 300;
  font-size: 1.375rem;
  line-height: 1.1;
  margin: 0 0 6px;
  color: var(--t-hi);
  letter-spacing: 0.005em;
}
.ind-speaker-body .role {
  font-size: 0.8125rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--t-mute);
  margin-bottom: 12px;
}
.ind-speaker-body p {
  font-size: 0.9375rem;
  line-height: 1.6;
  color: var(--t-base);
  margin: 0;
}

/* Related */
.ind-related-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 360px));
  gap: 16px;
}
.ind-related-card {
  display: flex; flex-direction: column;
  text-decoration: none;
  color: inherit;
  border: 1px solid var(--line);
  background: var(--bg-0);
  transition: border-color 0.15s, transform 0.15s;
}
.ind-related-card:hover {
  border-color: var(--t-hi);
}
.ind-related-card .thumb {
  position: relative;
  aspect-ratio: 16 / 9;
  padding: 12px;
}
.ind-related-card .thumb .kind {
  font-size: 0.6875rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.95);
  font-weight: 600;
}
.ind-related-card .body {
  padding: 14px 16px 18px;
}
.ind-related-card .time {
  font-size: 0.75rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--t-mute);
  margin-bottom: 8px;
}
.ind-related-card h3 {
  font-family: var(--ff-display);
  font-weight: 300;
  font-size: 1.25rem;
  line-height: 1.15;
  margin: 0 0 6px;
  color: var(--t-hi);
  letter-spacing: 0.005em;
}
.ind-related-card p {
  font-size: 0.8125rem;
  line-height: 1.45;
  color: var(--t-mid);
  margin: 0;
}

/* Hero access notice (replaces stats block) */
.ind-hero-access {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 0 0;
  border-top: 1px solid var(--line);
  margin-top: 8px;
  max-width: 560px;
}
.ind-hero-access .ic {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
}
.ind-hero-access .body {
  display: flex; flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.ind-hero-access strong {
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--t-hi);
}
.ind-hero-access span {
  font-size: 0.875rem;
  line-height: 1.5;
  letter-spacing: 0.02em;
  color: var(--t-base);
}


/* Hero side panel — cap-note under the register CTA */
.prog-hero-still .ind-side-cap-note {
  margin-top: 10px;
  font-size: 0.6875rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--t-mute);
}


/* Industry event hero — When/Where with icons */
.ind-hero-meta {
  list-style: none; padding: 0; margin: 32px 0 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
}
.ind-hero-meta li {
  display: flex; gap: 16px; align-items: flex-start;
  min-width: 0;
}
.ind-hero-meta .ic {
  flex-shrink: 0;
  color: var(--accent);
  padding-top: 4px;
}
.ind-hero-meta .body {
  display: flex; flex-direction: column;
  gap: 6px;
  min-width: 0;
}
.ind-hero-meta .body strong {
  font-size: 1.125rem;
  line-height: 1.25;
  color: var(--t-hi);
  font-weight: 400;
  letter-spacing: 0.01em;
  text-wrap: balance;
}
.ind-hero-meta .body span {
  font-size: 0.8125rem;
  color: var(--t-mute);
  letter-spacing: 0.06em;
  font-variant-numeric: tabular-nums;
}
@media (max-width: 880px) {
  .ind-hero-meta {
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }
  .ind-hero-meta li:last-child {
    grid-column: 1 / -1;
  }
}
@media (max-width: 540px) {
  .ind-hero-meta {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .ind-hero-meta li:last-child { grid-column: auto; }
  .ind-hero-meta .body strong { font-size: 1rem; }
}


/* Industry-coloured marker in schedule legend & event-row */
.event-row .event-type[data-type="industry"]::before,
.event-row .event-type-industry::before {
  background: var(--industry-color);
}


/* Side thumb on industry-event detail (image-slot + brand color) */
.ind-detail-side-thumb {
  position: relative !important;
  overflow: hidden;
  padding: 0 !important;
  aspect-ratio: 4 / 3;
  min-height: 280px;
  background: #F5531A;
}
.ind-detail-side-thumb-img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  display: block !important;
}

/* Override existing date/kind labels to use font-weight 300 + proper z-index */
.ind-detail-side-thumb .ind-side-thumb-kind,
.ind-detail-side-thumb .ind-side-thumb-date {
  z-index: 2;
  pointer-events: none;
}
.ind-detail-side-thumb .ind-side-thumb-date .num {
  font-weight: 300;
  font-size: 3.5rem;
}

/* Register CTA in the left column of the hero */
.ind-hero-cta {
  margin-top: 32px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
  display: flex; flex-direction: column; align-items: flex-start;
  gap: 12px;
}
.ind-hero-cta .btn-primary {
  min-height: 48px;
}
.ind-hero-cta-note {
  font-size: 0.6875rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--t-mute);
}

/* Related card thumb — image-slot inside */
.ind-related-card .thumb {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  padding: 0;
}
.ind-related-thumb-img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  display: block !important;
}
.ind-related-card .thumb .kind {
  position: absolute;
  left: 12px; bottom: 10px;
  font-size: 0.6875rem;
  letter-spacing: 0.2em;
  font-weight: 600;
  text-transform: uppercase;
  pointer-events: none;
  z-index: 2;
}

/* ============================== nav dropdown ============================== */
.nav-dropdown { position: relative; display: inline-flex; align-items: center; }
.nav-dropdown-trigger {
  font-size: 0.75rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--t-mid);
  padding: 8px 2px;
  min-height: 44px;
  display: inline-flex; align-items: center; gap: 7px;
  background: none; border: 0; cursor: pointer;
  position: relative;
  font-family: inherit;
}
.nav-dropdown-trigger:hover { color: var(--t-hi); }
.nav-dropdown-trigger[aria-current="page"] { color: var(--t-hi); }
.nav-dropdown-trigger .caret {
  transition: transform var(--d-1) var(--ease);
  color: var(--t-mute);
}
.nav-dropdown.is-open .nav-dropdown-trigger { color: var(--t-hi); }
.nav-dropdown.is-open .nav-dropdown-trigger .caret { transform: rotate(180deg); }
.nav-dropdown-menu {
  position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(6px);
  min-width: 220px;
  background: var(--bg-0);
  border: 1px solid var(--line-strong);
  box-shadow: 0 18px 40px -16px rgba(0,0,0,0.28);
  display: flex; flex-direction: column;
  padding: 6px;
  opacity: 0; visibility: hidden;
  transition: opacity var(--d-1) var(--ease), transform var(--d-1) var(--ease);
  z-index: 60;
}
.nav-dropdown.is-open .nav-dropdown-menu {
  opacity: 1; visibility: visible;
  transform: translateX(-50%) translateY(8px);
}
.nav-dropdown-menu a {
  font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--t-mid);
  padding: 12px 14px;
  min-height: 0;
  display: flex; align-items: center;
  transition: background var(--d-1) var(--ease), color var(--d-1) var(--ease);
}
.nav-dropdown-menu a::after { display: none; }
.nav-dropdown-menu a:hover { background: var(--bg-1); color: var(--t-hi); }
.nav-dropdown-menu a[aria-current="page"] { color: var(--accent-text); }

/* mobile: dropdown becomes flat expanded group */
@media (max-width: 1100px) {
  .nav-primary.is-open .nav-dropdown {
    display: flex; flex-direction: column; align-items: stretch;
    border-top: 1px solid var(--line);
  }
  .nav-primary.is-open .nav-dropdown-trigger {
    padding: 14px 0; min-height: 0; justify-content: space-between;
    width: 100%;
  }
  .nav-primary.is-open .nav-dropdown-menu {
    position: static; transform: none; opacity: 1; visibility: visible;
    border: 0; box-shadow: none; padding: 0 0 8px 0;
    min-width: 0; background: transparent;
  }
  .nav-primary.is-open .nav-dropdown-menu a {
    padding: 12px 0 12px 16px; border-top: 1px solid var(--line);
    letter-spacing: 0.14em;
  }
}

/* ============================== about pages ============================== */
.abt-head {
  border-bottom: 1px solid var(--line);
  background: var(--bg-0);
}
.abt-head-inner {
  max-width: var(--max-w); margin: 0 auto;
  padding: clamp(40px, 5vw, 72px) var(--gutter) clamp(32px, 4vw, 48px);
}
.abt-eyebrow {
  display: flex; align-items: center; gap: 12px;
  font-size: 0.75rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mid);
  margin-bottom: clamp(24px, 4vw, 48px);
}
.abt-eyebrow .mark { width: 28px; height: 2px; background: var(--accent); flex-shrink: 0; }
.abt-title {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.875rem, 4vw, 3.75rem);
  line-height: 1.02; letter-spacing: 0.005em;
  color: var(--t-hi);
  margin: 0;
  max-width: 22ch;
  text-wrap: balance;
}
.abt-lead {
  font-size: clamp(1rem, 1.4vw, 1.1875rem);
  line-height: 1.55; color: var(--t-mid);
  margin: 24px 0 0; max-width: 60ch;
}

.abt-body-section { background: var(--bg-0); }
.abt-body-inner {
  max-width: var(--max-w); margin: 0 auto;
  padding: clamp(40px, 5vw, 72px) var(--gutter);
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: clamp(36px, 5vw, 88px);
  align-items: start;
}
.abt-prose {
  display: flex; flex-direction: column; gap: 20px;
  max-width: 64ch;
}
.abt-prose p {
  font-size: 1rem; line-height: 1.65; color: var(--t-base);
  margin: 0; text-wrap: pretty;
}
.abt-aside { align-self: start; }
.abt-facts {
  margin: 0; padding: 24px 0 0;
  border-top: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 24px;
}
.abt-facts > div { display: flex; flex-direction: column; gap: 6px; }
.abt-facts dd {
  margin: 0;
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(2.25rem, 4vw, 3.5rem); line-height: 0.95;
  color: var(--t-hi); letter-spacing: 0.005em;
}
.abt-facts dt {
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mute);
}
@media (max-width: 880px) {
  .abt-body-inner { grid-template-columns: 1fr; gap: 36px; }
  .abt-facts { flex-direction: row; flex-wrap: wrap; gap: 28px 40px; }
}
.abt-body-inner--single { grid-template-columns: 1fr; }
.abt-body-inner--single .abt-prose { max-width: 72ch; }

/* what-we-do blocks */
.abt-blocks {
  max-width: var(--max-w); margin: 0 auto;
  padding: clamp(20px, 3vw, 40px) var(--gutter) clamp(40px, 5vw, 72px);
}
.abt-block {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: clamp(24px, 4vw, 64px);
  padding: clamp(28px, 4vw, 48px) 0;
  border-top: 1px solid var(--line);
}
.abt-block:last-child { border-bottom: 1px solid var(--line); }
.abt-block-tag {
  font-size: 0.75rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--accent-text);
  padding-top: 6px;
}
.abt-block-main h2 {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.5rem, 2.4vw, 2.25rem); line-height: 1.05;
  letter-spacing: 0.005em; color: var(--t-hi);
  margin: 0 0 16px; text-wrap: balance;
}
.abt-block-main p {
  font-size: 1rem; line-height: 1.65; color: var(--t-base);
  margin: 0; max-width: 62ch; text-wrap: pretty;
}
@media (max-width: 760px) {
  .abt-block { grid-template-columns: 1fr; gap: 12px; }
  .abt-block-tag { padding-top: 0; }
}

/* team */
.abt-team {
  max-width: var(--max-w); margin: 0 auto;
  padding: clamp(20px, 3vw, 40px) var(--gutter) clamp(40px, 5vw, 72px);
}
.abt-team-grid {
  list-style: none; margin: 0; padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px 32px;
}
.abt-person {
  display: flex; flex-direction: column; gap: 16px; align-items: flex-start;
}
.abt-person-av {
  width: 72px; height: 72px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display); font-weight: 300;
  font-size: 1.375rem; letter-spacing: 0.02em;
  flex-shrink: 0;
}
.abt-person-av--photo {
  object-fit: cover; display: block;
}
.abt-person-name {
  font-size: 1rem; color: var(--t-hi); font-weight: 500;
  letter-spacing: 0.01em;
}
.abt-person-role {
  font-size: 0.8125rem; color: var(--t-mid); line-height: 1.4;
  margin-top: 4px;
}
.abt-person-mail {
  display: inline-block; margin-top: 8px;
  font-size: 0.75rem; letter-spacing: 0.04em; color: var(--t-mute);
  word-break: break-word;
}
.abt-person-mail:hover { color: var(--accent); }
@media (max-width: 880px) {
  .abt-team-grid { grid-template-columns: repeat(3, 1fr); gap: 32px 24px; }
}
@media (max-width: 600px) {
  .abt-team-grid { grid-template-columns: repeat(2, 1fr); gap: 28px 20px; }
  .abt-person-av { width: 3.75rem; height: 3.75rem; font-size: 1.1875rem; }
}

/* volunteers extras */
.abt-deadline {
  margin-top: 8px; padding-top: 20px;
  border-top: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 6px;
}
.abt-deadline .lbl {
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mute);
}
.abt-deadline .val {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.375rem, 2vw, 1.875rem); color: var(--t-hi);
}
.abt-perks {
  list-style: none; margin: 0; padding: 24px 0 0;
  border-top: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 20px;
}
.abt-perks li { display: flex; flex-direction: column; gap: 4px; }
.abt-perks strong {
  font-size: 0.8125rem; letter-spacing: 0.04em; color: var(--t-hi); font-weight: 500;
}
.abt-perks span { font-size: 0.875rem; line-height: 1.5; color: var(--t-mid); }

/* archive */
.abt-archive {
  max-width: var(--max-w); margin: 0 auto;
  padding: clamp(20px, 3vw, 40px) var(--gutter) clamp(40px, 5vw, 72px);
}
.abt-archive-list { list-style: none; margin: 0; padding: 0; }
.abt-archive-list li { border-top: 1px solid var(--line); }
.abt-archive-list li:last-child { border-bottom: 1px solid var(--line); }
.abt-archive-row {
  display: grid;
  grid-template-columns: 120px 1fr auto;
  gap: 24px; align-items: baseline;
  padding: 22px 4px;
  text-decoration: none; color: inherit;
  transition: padding var(--d-1) var(--ease), background var(--d-1) var(--ease);
}
.abt-archive-row:hover { padding-left: 14px; padding-right: 0; background: var(--bg-1); }
.abt-archive-list .yr {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.75rem, 2.6vw, 2.5rem); color: var(--t-hi);
  font-variant-numeric: tabular-nums;
}
.abt-archive-list .ed {
  font-size: 0.9375rem; color: var(--t-base); letter-spacing: 0.02em;
  align-self: center;
}
.abt-archive-list .dl {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 0.75rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--t-mute);
  align-self: center;
  transition: color var(--d-1) var(--ease);
}
.abt-archive-row:hover .dl { color: var(--accent); }
.abt-archive-note {
  margin: 1.75rem 0 0; font-size: 0.875rem; color: var(--t-mute);
  max-width: 56ch; line-height: 1.6;
}
@media (max-width: 600px) {
  .abt-archive-row { grid-template-columns: 72px 1fr auto; gap: 16px; }
  .abt-archive-list .ed { font-size: 0.8125rem; }
  .abt-archive-list .dl { gap: 0.375rem; font-size: 0.6875rem; }
}

/* legal pages */
.legal-prose { max-width: 72ch; gap: 16px; }
.legal-h3 {
  font-family: var(--ff-display); font-weight: 400;
  font-size: clamp(0.9375rem, 1.4vw, 1.125rem); color: var(--t-hi);
  margin: 8px 0 0; letter-spacing: 0.01em;
}
.legal-ul {
  padding-left: 22px; margin: 0;
  display: flex; flex-direction: column; gap: 6px;
}
.legal-ul li { font-size: 1rem; line-height: 1.65; color: var(--t-base); }
.legal-contacts {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 6px;
  padding: 16px 20px; background: var(--bg-1); border: 1px solid var(--line); border-radius: 4px;
}
.legal-contacts li { font-size: 0.9375rem; color: var(--t-base); line-height: 1.5; }
.legal-contact-label { font-weight: 500; color: var(--t-hi); }

/* shared CTA band */
.abt-cta {
  border-top: 1px solid var(--line);
  background: var(--bg-1);
}
.abt-cta--light { background: var(--bg-0); }
.abt-cta-inner {
  max-width: var(--max-w); margin: 0 auto;
  padding: clamp(40px, 5vw, 72px) var(--gutter);
}
.abt-cta h2 {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.625rem, 3vw, 2.75rem); line-height: 1.04;
  letter-spacing: 0.005em; color: var(--t-hi);
  margin: 0 0 14px; text-wrap: balance;
}
.abt-cta p {
  font-size: 1rem; line-height: 1.55; color: var(--t-mid);
  margin: 0 0 28px; max-width: 52ch;
}
.abt-cta-row { display: flex; flex-wrap: wrap; gap: 12px; }
@media (max-width: 720px) {
  .abt-cta-row { flex-direction: column; }
  .abt-cta-row .btn { width: 100%; }
}

/* =============================================================
   TICKETS & PASSES page (tickets.html)
   ============================================================ */
.tkt-section {
  max-width: var(--max-w); margin: 0 auto;
  padding: clamp(36px, 4vw, 56px) var(--gutter) clamp(40px, 5vw, 64px);
  border-bottom: 1px solid var(--line);
}
.tkt-section-head {
  display: flex; align-items: baseline; justify-content: space-between;
  flex-wrap: wrap; gap: 12px 32px;
  margin-bottom: clamp(24px, 3vw, 36px);
}
.tkt-section-head h2 {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.75rem, 3.4vw, 3rem); line-height: 1.02;
  letter-spacing: 0.005em; color: var(--t-hi);
  margin: 0;
}
.tkt-section-head p {
  font-size: 0.875rem; line-height: 1.5; color: var(--t-mute);
  letter-spacing: 0.04em; margin: 0; max-width: 40ch;
}

.tkt-grid {
  display: grid;
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
}
.tkt-grid--2 { grid-template-columns: repeat(2, 1fr); }
.tkt-grid--3 { grid-template-columns: repeat(3, 1fr); }

.tkt-card {
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 28px 26px 26px;
  display: flex; flex-direction: column; gap: 14px;
  background: var(--bg-0);
}
.tkt-card-name {
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
}
.tkt-price {
  display: flex; align-items: baseline; gap: 6px; flex-wrap: wrap;
  font-variant-numeric: tabular-nums;
}
.tkt-price .amt {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(2.5rem, 5vw, 3.75rem); line-height: 0.92;
  letter-spacing: -0.01em; color: var(--t-hi);
}
.tkt-price.is-free .amt { font-size: clamp(1.625rem, 3vw, 2.25rem); }
.tkt-price .cur {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.25rem, 2vw, 1.625rem); color: var(--accent-text);
}
.tkt-price .per {
  font-size: 0.6875rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--t-mute); margin-left: 4px;
}
.tkt-card-desc {
  font-size: 0.875rem; line-height: 1.55; color: var(--t-base);
  letter-spacing: 0.02em; margin: 0; text-wrap: pretty;
}
.tkt-card-cta {
  display: inline-flex; align-items: center; gap: 10px;
  margin-top: auto; padding-top: 14px;
  border-top: 1px solid var(--line);
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-hi); min-height: 24px;
  text-decoration: none;
}
.tkt-card-cta svg { transition: transform var(--d-1) var(--ease); }
.tkt-card-cta:hover { color: var(--accent-text); }
.tkt-card-cta:hover svg { transform: translateX(4px); }
.tkt-card-cta:focus-visible { outline: 2px solid var(--focus); outline-offset: 2px; border-radius: 2px; }

.tkt-pass {
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 30px 26px;
  display: flex; flex-direction: column; gap: 24px;
  background: var(--bg-0);
}
.tkt-pass-top { display: flex; flex-direction: column; gap: 12px; }
.tkt-pass .btn { margin-top: auto; }

.tkt-section--info { background: var(--bg-1); }
.tkt-info-grid {
  margin: 0;
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
}
.tkt-info-item {
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 26px 28px;
}
.tkt-info-item dt {
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent-text); margin-bottom: 12px;
}
.tkt-info-item dd {
  margin: 0; font-size: 0.9062rem; line-height: 1.6;
  color: var(--t-base); letter-spacing: 0.02em;
  max-width: 48ch; text-wrap: pretty;
}

@media (max-width: 880px) {
  .tkt-grid--2, .tkt-grid--3 { grid-template-columns: 1fr; }
  .tkt-info-grid { grid-template-columns: 1fr; }
  .tkt-pass .btn, .tkt-visitor-cta .btn { width: 100%; }
}

.tkt-prose { max-width: 92ch; gap: 18px; }
.tkt-prose p { color: var(--t-soft); }

.tkt-tiers {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column;
}
.tkt-tiers li {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline; gap: 2px 16px;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
}
.tkt-tiers li:first-child { padding-top: 0; }
.tkt-tiers li:last-child { border-bottom: 0; padding-bottom: 0; }
.tier-label {
  font-size: 0.6875rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--t-mid);
}
.tier-price {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.625rem, 2.6vw, 2.125rem); line-height: 0.95;
  color: var(--t-hi); text-align: right;
  font-variant-numeric: tabular-nums;
  display: inline-flex; align-items: baseline; gap: 4px;
}
.tier-price .cur { font-size: 0.55em; color: var(--accent-text); }
.tier-note {
  grid-column: 1 / -1;
  font-size: 0.75rem; letter-spacing: 0.03em; color: var(--t-mute);
  margin-top: 2px;
}

.tkt-passes-docs {
  margin-top: clamp(28px, 3vw, 40px);
  padding-top: clamp(24px, 3vw, 32px);
  border-top: 1px solid var(--line);
}
.tkt-passes-docs p { font-size: 0.9062rem; line-height: 1.6; }

.tkt-subhead {
  display: flex; align-items: baseline; justify-content: space-between;
  flex-wrap: wrap; gap: 6px 32px;
  margin-bottom: 18px;
}
.tkt-subhead h3 {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.25rem, 2vw, 1.75rem); line-height: 1.05;
  color: var(--t-hi); margin: 0; letter-spacing: 0.005em;
}
.tkt-subhead p {
  font-size: 0.8125rem; line-height: 1.5; color: var(--t-mute);
  letter-spacing: 0.04em; margin: 0; max-width: 44ch;
}

.tkt-tier-card {
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 28px 26px 30px;
  display: flex; flex-direction: column; gap: 16px;
  background: var(--bg-0);
}
.tkt-tier-card.is-featured {
  background: var(--accent-chip-bg);
  color: var(--accent-chip-fg);
}
.tkt-tier-card.is-featured .tkt-card-name { color: rgba(255,254,241,0.66); }
.tkt-tier-card.is-featured .tkt-price .amt { color: var(--accent-chip-fg); }
.tkt-tier-card.is-featured .tkt-price .cur { color: var(--accent); }
.tkt-price--big .amt { font-size: clamp(3rem, 6vw, 4.75rem); }
.tkt-deadline {
  display: inline-flex; align-self: flex-start; align-items: center;
  padding: 7px 14px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  font-size: 0.6875rem; letter-spacing: 0.1em;
  color: var(--t-mid);
}
.tkt-tier-card.is-featured .tkt-deadline {
  border-color: rgba(255,254,241,0.4);
  color: var(--accent-chip-fg);
}

.tkt-visitor-cta {
  display: flex;
  padding: 24px 0 0;
}
.tkt-grid--gap-top { margin-top: clamp(40px, 5vw, 64px); }
.tkt-section--noline { border-bottom: 0; }

/* ---- tickets v2: chooser hint under the hero lead ---- */
.tkt-lead-row {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: clamp(36px, 5vw, 88px);
  align-items: start;
}
.tkt-lead-row .abt-lead { white-space: pre-line; }
.tkt-hint {
  margin: 27px 0 0; max-width: 56ch;
  font-size: 13.5px; line-height: 1.55; letter-spacing: 0.03em;
  color: var(--t-mute);
  padding-left: 14px;
  border-left: 2px solid var(--accent);
}
@media (max-width: 880px) {
  .tkt-lead-row { grid-template-columns: 1fr; gap: 0; }
  .tkt-hint { margin-top: 18px; }
}

/* ---- tickets v2: footnote inside a pass card ---- */
.tkt-card-foot {
  margin: 0; padding-top: 12px;
  border-top: 1px solid var(--line);
  font-size: 12.5px; line-height: 1.55; letter-spacing: 0.02em;
  color: var(--t-mute); text-wrap: pretty;
}

/* ---- tickets v2: buy-where hint + rules-intro hint ---- */
.tkt-rules-hint {
  margin: clamp(20px, 2.5vw, 28px) 0 0; max-width: 72ch;
  font-size: 13.5px; line-height: 1.6; letter-spacing: 0.02em;
  color: var(--t-mute);
}
.tkt-rules-hint--intro {
  margin: 0 0 clamp(20px, 2.5vw, 28px);
  color: var(--t-soft);
}

/* ---- tickets v2: free entry section ---- */
.tkt-section--free { scroll-margin-top: 90px; }

.tkt-free-groups {
  display: flex; align-items: baseline; flex-wrap: wrap;
  gap: 12px 24px;
  margin: 0 0 clamp(20px, 2.5vw, 28px);
}
.tkt-free-groups-label {
  font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent-text); white-space: nowrap;
}
.tkt-free-groups ul {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-wrap: wrap; gap: 8px;
}
.tkt-free-groups li {
  padding: 7px 14px;
  font-size: 13px; letter-spacing: 0.04em; line-height: 1;
  color: var(--t-hi);
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  white-space: nowrap;
}

.tkt-free-tag {
  display: inline-flex; align-self: flex-start; align-items: center;
  padding: 5px 10px;
  font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent-text);
  border: 1px solid currentColor;
  border-radius: 2px;
}

/* ---- tickets v2: grouped, scannable pass rules ---- */
.tkt-rules {
  display: flex; flex-direction: column;
}
.tkt-rules-group {
  display: grid; grid-template-columns: 220px 1fr;
  gap: 16px 48px;
  padding: clamp(20px, 2.5vw, 28px) 0;
  border-top: 1px solid var(--line);
}
.tkt-rules-label {
  font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent-text);
  padding-top: 3px;
}
.tkt-rules-group ul {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 14px;
  max-width: 76ch;
}
.tkt-rules-group li {
  font-size: 14.5px; line-height: 1.6; letter-spacing: 0.02em;
  color: var(--t-soft); text-wrap: pretty;
  padding-left: 18px; position: relative;
}
.tkt-rules-group li::before {
  content: ""; position: absolute; left: 0; top: 0.72em;
  width: 7px; height: 1px; background: var(--t-mute);
}
.tkt-rules-group li strong {
  font-weight: 600; color: var(--t-hi);
}
@media (max-width: 880px) {
  .tkt-rules-group { grid-template-columns: 1fr; gap: 10px; }
}

/* =============================================================
   SUBMIT YOUR FILM page (submit.html)
   ============================================================ */
.sub-intro {
  max-width: var(--max-w); margin: 0 auto;
  padding: clamp(36px, 4vw, 56px) var(--gutter) clamp(40px, 5vw, 64px);
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(28px, 4vw, 64px); align-items: start;
}
.sub-announce {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.375rem, 2.4vw, 2rem); line-height: 1.15;
  color: var(--accent-text); letter-spacing: 0.005em;
  margin: 0 0 22px; text-wrap: balance;
}
.sub-intro-text .abt-prose { max-width: 46ch; }
.sub-cta-row {
  display: flex; flex-wrap: wrap; gap: 12px;
  margin-top: 28px;
}
.sub-legal-note {
  margin-top: 24px;
  padding: 0 var(--gutter);
  font-size: 0.6875rem; letter-spacing: 0.12em; text-transform: uppercase;
}
.sub-legal-note a { color: var(--t-mute); }
.sub-legal-note a:hover { color: var(--t-hi); }
.sub-photo {
  margin: 0; display: flex; flex-direction: column; gap: 10px;
}
.sub-photo-img {
  width: 100%; height: auto; display: block;
  aspect-ratio: 4 / 3; object-fit: cover;
  border: 1px solid var(--line);
}
.sub-photo figcaption {
  font-size: 0.6875rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--t-mute);
}

.tkt-section--deadlines {
  padding-top: clamp(8px, 2vw, 16px);
}

.sub-deadline-date {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.625rem, 3vw, 2.375rem); line-height: 1.0;
  color: var(--t-hi); letter-spacing: 0.005em;
}
.tkt-tier-card.is-featured .sub-deadline-date { color: var(--accent-chip-fg); }
.sub-fee {
  display: inline-flex; align-items: baseline; gap: 8px;
  padding-top: 4px;
}
.sub-fee .amt {
  font-size: 1.25rem; font-variant-numeric: tabular-nums;
  color: var(--accent-text);
}
.sub-fee .lbl {
  font-size: 0.6875rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--t-mute);
}
.tkt-tier-card.is-featured .sub-fee .amt { color: var(--accent); }
.tkt-tier-card.is-featured .sub-fee .lbl { color: rgba(255,254,241,0.6); }

.sub-platform {
  position: relative;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 28px 26px;
  display: flex; flex-direction: column; gap: 12px;
  background: var(--bg-0);
  text-decoration: none; color: inherit;
  transition: background var(--d-1) var(--ease);
}
.sub-platform:hover { background: var(--bg-1); }
.sub-platform:focus-visible { outline: 2px solid var(--focus); outline-offset: 2px; z-index: 1; }
.sub-platform-name {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.25rem, 2vw, 1.625rem); line-height: 1.05;
  color: var(--t-hi); letter-spacing: 0.005em;
}
.sub-platform-name svg { color: var(--t-mute); transition: transform var(--d-1) var(--ease), color var(--d-1) var(--ease); }
.sub-platform:hover .sub-platform-name { color: var(--accent-text); }
.sub-platform:hover .sub-platform-name svg { color: var(--accent-text); transform: translate(2px, -2px); }

@media (max-width: 880px) {
  .sub-intro { grid-template-columns: 1fr; }
  .sub-photo { order: -1; }
  .sub-cta-row { flex-direction: column; }
  .sub-cta-row .btn { width: 100%; }
}

/* ============================================================
   ACCESSIBILITY PAGE  (.acc-*)
   ============================================================ */

/* Adapted programme cards */
.acc-format {
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: var(--r-card);
  padding: clamp(20px, 3vw, 32px);
  display: flex; flex-direction: column; gap: 12px;
}
.acc-format-top {
  display: flex; align-items: flex-start; gap: 10px;
}
.acc-format-ic {
  display: flex; align-items: center; justify-content: center;
  width: 24px; height: 24px; flex-shrink: 0;
  color: var(--accent);
}
.acc-abbr {
  font-family: var(--ff-display); font-weight: 700;
  font-size: 0.8125rem; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--accent-text);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  padding: 2px 7px; border-radius: 4px;
}
.acc-format-name {
  font-family: var(--ff-display); font-weight: 500;
  font-size: clamp(1rem, 1.6vw, 1.1875rem);
  color: var(--t-hi);
}
.acc-format-desc {
  font-size: 0.875rem; line-height: 1.55; color: var(--t-base);
}

/* Shared points list */
.acc-points-wrap {
  padding: clamp(16px, 2.5vw, 28px) clamp(16px, 3vw, 32px);
}
.acc-points-wrap--card {
  border: 1px solid var(--line);
  background: var(--bg-1);
  border-radius: var(--r-card);
}
.acc-lead {
  font-size: clamp(0.875rem, 1.3vw, 1rem); line-height: 1.6;
  color: var(--t-base); margin-bottom: 16px;
}
.acc-points {
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 8px 24px;
}
.acc-points li {
  display: flex; align-items: baseline; gap: 8px;
  font-size: 0.875rem; line-height: 1.5; color: var(--t-base);
}
.acc-points .tick {
  flex-shrink: 0; width: 6px; height: 6px;
  border-radius: 50%; background: var(--accent);
  margin-top: 5px;
}
.acc-foot {
  margin-top: 12px;
  font-size: 0.8125rem; line-height: 1.5; color: var(--t-mute);
  font-style: italic;
}

/* Podyv steps */
.acc-steps {
  background: var(--bg-0);
  border-radius: var(--r-card);
  padding: clamp(18px, 2.5vw, 28px);
  display: flex; flex-direction: column; gap: 10px;
}
.acc-steps--open {
  background: transparent;
  border-radius: 0;
  padding-left: 0; padding-right: 0;
}
.tkt-grid--open {
  border-top: none;
  border-left: none;
  gap: clamp(20px, 4vw, 48px);
}
.acc-steps-tag {
  font-family: var(--ff-display); font-weight: 600;
  font-size: 0.6875rem; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--accent-text);
  padding-bottom: 8px;
  border-bottom: 1px solid var(--line);
}
.acc-steps-lead {
  font-size: 0.8125rem; line-height: 1.5; color: var(--t-mute);
}
.acc-steps-list {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 8px;
  counter-reset: none;
}
.acc-steps-list li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 0.8125rem; line-height: 1.5; color: var(--t-base);
}
.acc-step-n {
  flex-shrink: 0;
  font-family: var(--ff-display); font-weight: 600; font-size: 0.6875rem;
  color: var(--accent-text); letter-spacing: 0.02em; min-width: 20px;
  padding-top: 1px;
}

/* Legend */
.acc-legend {
  list-style: none; margin: 0; padding: clamp(16px, 2.5vw, 28px) clamp(16px, 3vw, 32px);
  display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 12px 32px;
}
.acc-legend-row {
  display: flex; align-items: center; gap: 10px;
}
.acc-legend-ic {
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; width: 24px; color: var(--accent);
}
.acc-legend-label {
  font-size: 0.875rem; line-height: 1.4; color: var(--t-base);
}

/* FAQ accordion */
.acc-faq {
  border-top: 1px solid var(--line);
}
.acc-faq--in-card {
  border-top: none;
}
.acc-faq-item {
  border-bottom: 1px solid var(--line);
}
.acc-faq-item summary {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 18px clamp(16px, 3vw, 32px);
  cursor: pointer; list-style: none;
  font-size: clamp(0.875rem, 1.3vw, 1rem); font-weight: 500; color: var(--t-hi);
  transition: color var(--d-1) var(--ease);
}
.acc-faq-item summary::-webkit-details-marker { display: none; }
.acc-faq-item summary:hover { color: var(--accent-text); }
.acc-faq-item summary:focus-visible { outline: 2px solid var(--focus); outline-offset: 2px; }
.acc-faq-mark {
  flex-shrink: 0; width: 20px; height: 20px;
  border-radius: 50%; border: 1.5px solid currentColor;
  display: flex; align-items: center; justify-content: center;
  position: relative;
}
.acc-faq-mark::before,
.acc-faq-mark::after {
  content: ""; position: absolute;
  width: 8px; height: 1.5px;
  background: currentColor; border-radius: 1px;
}
.acc-faq-mark::after {
  transform: rotate(90deg);
  transition: transform var(--d-1) var(--ease), opacity var(--d-1) var(--ease);
}
.acc-faq-item[open] .acc-faq-mark::after { transform: rotate(0deg); opacity: 0; }
.acc-faq-item > p {
  padding: 0 clamp(16px, 3vw, 32px) 18px;
  font-size: 0.875rem; line-height: 1.6; color: var(--t-base);
  margin: 0;
}

/* Contact email link */
.acc-mail {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--ff-display); font-weight: 400;
  font-size: clamp(1.125rem, 2vw, 1.5rem);
  color: var(--accent-text); text-decoration: none;
  margin-top: 8px;
  transition: opacity var(--d-1) var(--ease);
}
.acc-mail:hover { opacity: 0.75; }
.acc-mail:focus-visible { outline: 2px solid var(--focus); outline-offset: 4px; }
.acc-mail-ic { display: flex; align-items: center; color: var(--accent); }
.acc-outro {
  margin-top: 16px;
  font-size: 0.875rem; line-height: 1.6; color: var(--t-mute);
}

@media (max-width: 540px) {
  .acc-points { grid-template-columns: 1fr; }
  .acc-legend { grid-template-columns: 1fr; }
}

/* ================================================================
   PROGRAMME MODE TABS (Short films | Feature films)
   ================================================================ */

.programme-mode-tabs {
  display: flex;
  border-bottom: 1px solid var(--line);
  background: var(--bg-0);
  padding: 0 var(--gutter);
  max-width: var(--max-w);
  margin: 0 auto;
}
.mode-tab {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 16px 0;
  margin-right: 32px;
  font-size: 0.6875rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mute);
  border-bottom: 2px solid transparent;
  transition: color var(--d-1), border-color var(--d-1);
  position: relative; bottom: -1px;
}
.mode-tab:hover { color: var(--t-hi); }
.mode-tab.is-active {
  color: var(--t-hi);
  border-bottom-color: var(--accent);
}
.mode-tab-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 22px; height: 18px;
  padding: 0 5px;
  background: var(--bg-2);
  border-radius: 999px;
  font-size: 0.625rem; letter-spacing: 0.1em;
  color: var(--t-mid);
  font-variant-numeric: tabular-nums;
}
.mode-tab.is-active .mode-tab-count {
  background: var(--accent);
  color: #fff;
}

/* ================================================================
   FEATURE FILMS LIST (index page)
   ================================================================ */

.feature-films-list {
  max-width: var(--max-w); margin: 0 auto;
  display: flex; flex-direction: column;
  border-top: 1px solid var(--line);
}
.feature-films-empty {
  max-width: var(--max-w); margin: 0 auto;
  padding: 80px var(--gutter);
  text-align: center; color: var(--t-mute);
  font-size: 0.875rem;
}

/* Feature film card (list row) */
.feature-film-card {
  position: relative;
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 0;
  border-bottom: 1px solid var(--line);
  background: var(--bg-0);
  text-decoration: none; color: inherit;
  transition: background var(--d-1);
}
.feature-film-card:hover { background: var(--bg-1); }
.feature-film-card:focus-visible { outline: 2px solid var(--focus); outline-offset: 2px; z-index: 1; }

.ff-card-poster {
  position: relative;
  aspect-ratio: 2 / 3;
  overflow: hidden;
  background: var(--poster-bg);
  flex-shrink: 0;
  min-height: 180px;
  max-height: 300px;
}
.ff-card-poster-img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center top;
  display: block;
}
.ff-card-poster-placeholder {
  width: 100%; height: 100%;
  background: linear-gradient(160deg, var(--still-a, #1a1614) 0%, var(--still-b, #0d0b09) 100%);
}
.ff-card-runtime {
  position: absolute; bottom: 10px; right: 10px;
  font-size: 0.625rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--t-on-dark);
  background: rgba(0,0,0,0.5); padding: 3px 8px;
  font-variant-numeric: tabular-nums;
}
.ff-card-badge {
  position: absolute; top: 10px; left: 10px;
  font-size: 0.5625rem; letter-spacing: 0.14em; text-transform: uppercase;
  background: var(--accent); color: #fff;
  padding: 3px 7px;
  font-weight: 600;
}

.ff-card-body {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 20px;
  padding: 24px var(--gutter) 24px 24px;
  align-items: start;
}
.ff-card-no {
  font-family: var(--ff-display); font-weight: 300;
  font-size: 1.5rem; line-height: 1;
  color: rgba(10,10,9,0.12);
  font-variant-numeric: tabular-nums;
  padding-top: 4px;
}
.ff-card-main { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.ff-card-title {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(1.25rem, 2.2vw, 1.75rem);
  line-height: 1.05; letter-spacing: 0.005em;
  color: var(--t-hi); margin: 0;
  text-wrap: balance;
  text-transform: uppercase;
}
.ff-card-orig {
  font-size: 0.75rem; letter-spacing: 0.06em;
  color: var(--t-mute);
}
.ff-card-meta { display: flex; flex-direction: column; gap: 5px; margin: 6px 0 0; }
.ff-card-director {
  font-size: 0.8125rem; letter-spacing: 0.04em;
  color: var(--t-mid);
}
.ff-card-facts {
  display: flex; flex-wrap: wrap; align-items: center; gap: 6px;
  font-size: 0.75rem; letter-spacing: 0.04em; color: var(--t-mute);
}
.ff-card-dot { opacity: 0.4; }
.ff-card-dates {
  font-size: 0.6875rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--t-mute); margin-top: 4px;
  font-variant-numeric: tabular-nums;
}
.ff-card-cta {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 0.625rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--t-mute);
  padding-top: 4px;
  white-space: nowrap;
}
.ff-card-cta .arrow {
  width: 20px; height: 1px; background: currentColor;
  position: relative; display: inline-block; flex-shrink: 0;
}
.ff-card-cta .arrow::after {
  content: ""; position: absolute; right: 0; top: 50%;
  width: 5px; height: 5px;
  border-right: 1px solid currentColor; border-top: 1px solid currentColor;
  transform: translateY(-50%) rotate(45deg);
}
.feature-film-card:hover .ff-card-cta { color: var(--accent); }

@media (max-width: 880px) {
  .feature-film-card { grid-template-columns: 140px 1fr; }
  .ff-card-poster { max-height: 220px; }
  .ff-card-body { grid-template-columns: 1fr auto; gap: 12px; padding: 16px; }
  .ff-card-no { display: none; }
}
@media (max-width: 600px) {
  .feature-film-card { grid-template-columns: 110px 1fr; }
  .ff-card-poster { max-height: 180px; }
  .ff-card-body { padding: 12px; gap: 8px; }
  .ff-card-cta { display: none; }
}

/* ================================================================
   FILM DETAIL PAGE  (film.html)
   ================================================================ */

/* two-column hero */
.film-hero {
  background: var(--bg-0);
}
.film-hero-inner {
  max-width: var(--max-w); margin: 0 auto;
  display: grid;
  grid-template-columns: 1.45fr 1fr;
  grid-template-areas: "left right";
  gap: 0;
  align-items: start;
}

/* left column */
.film-hero-left {
  grid-area: left;
  padding: clamp(28px, 4vw, 56px) clamp(20px, 4vw, 56px) clamp(28px, 4vw, 56px) var(--gutter);
  display: flex; flex-direction: column; gap: 20px;
}

/* breadcrumb */
.film-breadcrumb {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  font-size: 0.625rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--t-mute);
}
.film-breadcrumb-link { color: inherit; text-decoration: none; opacity: 0.65; }
.film-breadcrumb-link:hover { opacity: 1; color: var(--accent); }
.film-breadcrumb-sep { opacity: 0.35; }

/* title */
.film-title {
  font-family: 'Inter', sans-serif; font-weight: 700;
  font-size: clamp(2.75rem, 6vw, 5.5rem);
  line-height: 0.94; letter-spacing: 0.005em;
  color: var(--t-hi);
  margin: 0;
  text-wrap: balance;
  text-transform: uppercase;
}
.film-title .em { color: var(--accent); }

/* orig · director · year */
.film-orig-line {
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px;
  font-size: 0.9375rem; letter-spacing: 0.02em;
  color: var(--t-mid);
}
.film-orig { color: var(--t-mute); font-style: italic; }
.film-sep { opacity: 0.35; }

/* synopsis sections */
.film-synopsis-sections {
  display: flex; flex-direction: column; gap: 14px;
  max-width: 600px;
  margin-top: 20px;
}
.film-synopsis-block { display: flex; flex-direction: column; gap: 6px; }
.film-section-eyebrow {
  font-size: 0.75rem; letter-spacing: 0.12em; text-transform: uppercase;
  font-weight: 700; color: var(--t-hi);
  padding-bottom: 6px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 2px;
}
.film-synopsis-text {
  font-size: clamp(0.9375rem, 1.3vw, 1.0625rem);
  line-height: 1.55; letter-spacing: 0.02em;
  color: var(--t-base);
  margin: 0;
}

/* meta strip — 4 columns: Country / Runtime / Language / Year */
.film-meta-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  margin: 0;
  border-top: 1px solid var(--line);
  padding-top: 16px;
}
.film-meta-grid > div { padding: 0 16px; border-right: 1px solid var(--line); }
.film-meta-grid > div:first-child { padding-left: 0; }
.film-meta-grid > div:last-child { border-right: 0; }
.film-meta-grid dt {
  font-size: 0.5625rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--t-mute); margin-bottom: 6px;
}
.film-meta-grid dd {
  margin: 0;
  font-size: 0.875rem; letter-spacing: 0.04em;
  color: var(--t-hi); font-weight: 700;
  line-height: 1.3;
  text-transform: uppercase;
}
.film-subs-note {
  display: block;
  font-size: 0.75rem; color: var(--t-mute); margin-top: 3px;
}

/* awards + director bio */
.film-awards-dir {
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
  padding-top: 16px;
}
.film-awards-list {
  list-style: none; margin: 8px 0 0; padding: 0;
  display: flex; flex-direction: column; gap: 8px;
}
.film-awards-list li {
  display: flex; gap: 8px; align-items: flex-start;
  font-size: 0.8125rem; line-height: 1.45;
  color: var(--t-base);
}
.film-awards-list li svg { flex-shrink: 0; margin-top: 3px; color: #F47125; }
.film-director-name {
  font-size: 0.9375rem; letter-spacing: 0.04em;
  color: var(--t-hi); font-weight: 500;
  margin: 8px 0 4px;
  text-transform: uppercase;
}
.film-dirbio-text {
  font-size: 0.8125rem; line-height: 1.5; color: var(--t-base);
  margin: 0;
}

@media (max-width: 880px) {
  .film-awards-dir { grid-template-columns: 1fr; gap: 16px; }
  .film-meta-grid { grid-template-columns: repeat(2, 1fr); row-gap: 16px; }
  .film-meta-grid > div:nth-child(2) { border-right: 0; }
  .film-meta-grid > div:nth-child(3) { padding-left: 0; padding-top: 16px; border-top: 1px solid var(--line); }
  .film-meta-grid > div:nth-child(4) { padding-top: 16px; border-top: 1px solid var(--line); }
}

/* right column — poster panel */
.film-hero-right {
  grid-area: right;
  padding: clamp(28px, 4vw, 56px) var(--gutter) clamp(28px, 4vw, 56px) clamp(20px, 4vw, 48px);
  display: flex; flex-direction: column; gap: 20px;
}


.film-poster-panel {
  position: relative;
  background: var(--poster-bg);
  color: var(--t-on-dark);
  overflow: hidden;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 16px;
  min-height: 340px;
}
.film-poster-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center top;
  display: block;
  z-index: 0;
}
.film-poster-placeholder {
  position: absolute; inset: 0;
  background: linear-gradient(160deg, var(--still-a, #1c1a14) 0%, var(--still-b, #0b0a08) 100%);
  z-index: 0;
}

/* film-strip top/bottom */
.film-strip-top,
.film-strip-bottom {
  position: absolute; left: 0; right: 0; height: 10px;
  background: repeating-linear-gradient(90deg, rgba(244,236,226,0.25) 0 3px, transparent 3px 12px);
  z-index: 3;
}
.film-strip-top { top: 0; }
.film-strip-bottom { bottom: 0; }

.film-poster-top-row,
.film-poster-bottom-row {
  position: relative; z-index: 2;
}
.film-poster-top-row {
  display: flex; justify-content: flex-end; align-items: flex-start;
}
.film-poster-eyebrow {
  font-size: 0.5625rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(244,236,226,0.7);
  font-variant-numeric: tabular-nums;
}
.film-poster-monogram {
  font-size: 0.5625rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(244,236,226,0.55);
  font-weight: 700;
}
.film-poster-title-block {
  display: flex; flex-direction: column; gap: 5px;
}
.film-poster-title {
  display: block;
  font-family: var(--ff-display); font-weight: 800;
  font-size: clamp(1rem, 1.8vw, 1.375rem);
  line-height: 1; letter-spacing: 0.01em; text-transform: uppercase;
  color: var(--t-on-dark);
}
.film-poster-country-line {
  display: block;
  font-size: 0.5625rem; letter-spacing: 0.16em; text-transform: uppercase;
  opacity: 0.6; margin-top: 5px;
}
.film-poster-dir-label {
  font-size: 0.625rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(244,236,226,0.6);
}

/* film body (below hero) — mirrors hero grid so sessions align with left column */
.film-body {
  max-width: var(--max-w); margin: 0 auto;
  display: grid;
  grid-template-columns: 1.45fr 1fr;
}
.film-body-main {
  padding: clamp(24px, 3.5vw, 48px) clamp(20px, 4vw, 56px) clamp(24px, 3.5vw, 48px) var(--gutter);
}
.film-body-aside {
  padding: clamp(24px, 3.5vw, 48px) var(--gutter) clamp(24px, 3.5vw, 48px) clamp(20px, 4vw, 48px);
}

/* screenings card */
.film-screenings-card {
  border: 1.5px solid var(--t-hi);
  background: var(--bg-1);
}
.film-screenings-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 16px;
  border-bottom: 1.5px solid var(--t-hi);
  font-size: 0.75rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--t-hi);
  font-weight: 700;
}
.film-screenings-monogram {
  font-size: 0.5625rem; letter-spacing: 0.22em; text-transform: uppercase;
  font-weight: 700;
}
.film-screening-row {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px 16px;
}
.film-screening-row.has-separator { border-top: 1px solid var(--line); }
.film-screening-info { display: flex; flex-direction: column; gap: 4px; }
.film-screening-day {
  font-size: 0.5625rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--t-mute);
  font-variant-numeric: tabular-nums;
}
.film-screening-time-venue {
  display: flex; align-items: center; gap: 8px;
  font-size: 1.375rem; letter-spacing: -0.01em;
  color: var(--t-hi);
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.05;
}
.film-screening-tags { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; margin-top: 4px; }
.film-tag-chip {
  font-size: 0.5625rem; letter-spacing: 0.14em; text-transform: uppercase;
  font-weight: 700;
  background: var(--t-hi); color: var(--bg-0);
  padding: 3px 7px;
}
.film-screening-qa {
  font-size: 0.5625rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--t-mute);
}
.film-reserve-btn {
  width: 100%; justify-content: center;
  font-size: 0.625rem; letter-spacing: 0.14em;
  padding: 10px 14px; min-height: 40px;
}

/* related films */
.film-related { display: flex; flex-direction: column; gap: 12px; }
.film-related-header {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line-strong);
  font-size: 0.75rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--t-hi); font-weight: 700;
}
.film-related-all {
  color: var(--t-mute); text-decoration: none; opacity: 0.7;
  font-size: 1rem;
  transition: color var(--d-1), opacity var(--d-1);
}
.film-related-all:hover { color: var(--accent); opacity: 1; }
.film-related-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
}
.film-related-card {
  position: relative; overflow: hidden;
  aspect-ratio: 5 / 3;
  background: var(--poster-bg);
  border: 1.5px solid var(--t-hi);
  text-decoration: none; color: #0A0A0A;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 10px;
  transition: opacity var(--d-1);
}
.film-related-card:hover { opacity: 0.85; }
.film-related-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
  opacity: 0.85;
}
.film-related-placeholder {
  position: absolute; inset: 0; z-index: 0;
}
.film-related-top, .film-related-bottom { position: relative; z-index: 2; }
.film-related-top { display: flex; align-items: flex-start; }
.film-related-blob {
  position: absolute; bottom: -5%; left: 40%;
  width: 70%; height: 65%;
  background: rgba(0,0,0,0.15);
  border-radius: 45% 55% 60% 40% / 55% 45% 40% 60%;
  z-index: 1; pointer-events: none;
}
.film-related-badges { display: flex; gap: 4px; flex-wrap: wrap; }
.film-related-badge {
  background: #AF886D;
  padding: 4px 8px;
  font-size: 0.5625rem; letter-spacing: 0.16em; text-transform: uppercase;
  font-weight: 700;
  color: var(--t-hi);
  line-height: 1.2;
}
.film-related-title-badge {
  display: inline-block;
  background: #AF886D;
  padding: 5px 9px;
  font-size: clamp(0.6875rem, 1vw, 0.875rem);
  letter-spacing: 0.04em; text-transform: uppercase;
  font-weight: 600;
  color: var(--t-hi);
  line-height: 1.2;
  text-wrap: balance;
  max-width: 100%;
}

/* responsive: collapse to single column — poster → title → details → synopsis */
@media (max-width: 960px) {
  .film-hero-inner {
    display: flex;
    flex-direction: column;
  }
  .film-hero-left,
  .film-hero-right {
    display: contents;
  }
  .film-poster-panel   { order: 1; min-height: 260px; width: 100%; }
  .film-title          { order: 2; padding: 28px var(--gutter) 0; }
  .film-details-panel  { order: 3; margin: 20px var(--gutter) 0; }
  .film-synopsis-sections { order: 4; padding: 0 var(--gutter) 28px; max-width: 100%; }
  .film-awards-dir     { order: 5; padding: 0 var(--gutter) 28px; }

  .film-body {
    display: block;
  }
  .film-body-main {
    padding: 24px var(--gutter);
  }
}
@media (max-width: 600px) {
  .film-title { font-size: 2.25rem; }
  .film-related-grid { grid-template-columns: 1fr; gap: 0; }
  .film-related-card { aspect-ratio: 16 / 9; border-left: 0; border-right: 0; }
  .film-related-card + .film-related-card { border-top: 0; }
}

/* details panel — right column below poster */
.film-details-panel {
  border: 1.5px solid var(--t-hi);
}
.film-details-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 16px;
  border-bottom: 1.5px solid var(--t-hi);
  font-size: 0.75rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--t-hi);
  font-weight: 700;
}
.film-details-monogram {
  font-size: 0.5625rem; letter-spacing: 0.22em; text-transform: uppercase; font-weight: 700;
}
.film-details-item {
  display: flex; gap: 14px; align-items: flex-start;
  padding: 12px 16px;
  border-bottom: 1px solid var(--line);
}
.film-details-item:last-child { border-bottom: 0; }
.film-details-ic { color: #F47125; flex-shrink: 0; margin-top: 2px; }
.film-details-body { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.film-details-label {
  font-size: 0.6875rem; letter-spacing: 0.12em; text-transform: uppercase;
  font-weight: 700; color: var(--t-hi);
}
.film-details-value {
  font-size: 0.875rem; color: var(--t-hi); line-height: 1.4;
}

/* related films — full-width section below body */
.film-related-section {
  padding: 0 var(--gutter) 24px;
}
@media (max-width: 600px) {
  .film-related-section { padding: 0 0 24px; }
  .film-related-header { padding: 0 var(--gutter) 10px; }
}

/* pull strip — film facts footer bar */
.film-pull-strip {
  display: flex; justify-content: space-between; align-items: center;
  border-top: 1.5px solid var(--t-hi);
  padding: 12px var(--gutter);
  font-size: 0.6875rem; letter-spacing: 0.14em; text-transform: uppercase;
  font-weight: 700; color: var(--t-hi);
  gap: 16px;
}
.film-pull-monogram {
  display: flex; align-items: center; gap: 10px;
  font-size: 0.5625rem; letter-spacing: 0.22em; text-transform: uppercase;
  font-weight: 700;
}
.film-pull-fact { opacity: 0.85; }
.film-pull-num { font-variant-numeric: tabular-nums; }

/* ── Film poster play button ─────────────────────────────────────────────── */
.film-poster-play {
  position: absolute; z-index: 4;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  background: none; border: none; cursor: pointer;
  color: var(--bg-0);
  padding: 0;
  opacity: 0.9;
  transition: opacity 0.18s, transform 0.18s;
}
.film-poster-play:hover { opacity: 1; transform: translate(-50%, -50%) scale(1.06); }
.film-poster-play span {
  font-size: 0.5625rem; letter-spacing: 0.2em; text-transform: uppercase;
  font-weight: 700; text-shadow: 0 1px 4px rgba(0,0,0,0.7);
}

/* ── Trailer modal ───────────────────────────────────────────────────────── */
.trailer-backdrop {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.88);
  z-index: 2000;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
}
.trailer-inner {
  position: relative;
  width: 100%; max-width: 960px;
  aspect-ratio: 16 / 9;
  background: #000;
}
.trailer-iframe {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: none;
}
.trailer-close {
  position: absolute; top: -40px; right: 0;
  background: none; border: none;
  color: #fff; font-size: 1.25rem;
  cursor: pointer; padding: 4px 8px;
  opacity: 0.75; line-height: 1;
}
.trailer-close:hover { opacity: 1; }
