:root {
  --ink: #0a0706;
  --ink-2: #14100e;
  --parchment: #f3ead6;
  --parchment-2: #ece1c7;
  --curtain: #9b1c1c;
  --curtain-deep: #6b0f0f;
  --gold: #c9a24b;
  --gold-soft: #e6c87a;
  --rule: rgba(243, 234, 214, 0.18);
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Archivo', sans-serif;
  background: var(--ink);
  color: var(--parchment);
  line-height: 1.55;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
body::before {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 1000;
  opacity: 0.07; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
a { color: inherit; text-decoration: none; }
.serif { font-family: 'Fraunces', serif; font-optical-sizing: auto; }
.mono  { font-family: 'JetBrains Mono', monospace; }

/* NAV */
nav.top {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 36px; background: rgba(10, 7, 6, 0.72);
  backdrop-filter: blur(14px); border-bottom: 1px solid var(--rule);
}
nav.top .brand { font-family: 'Fraunces', serif; font-weight: 800; font-style: italic; font-size: 22px; letter-spacing: -0.01em; }
nav.top .brand span { color: var(--gold-soft); }
nav.top ul { list-style: none; display: flex; gap: 28px; font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; }
nav.top ul a { opacity: 0.75; transition: opacity .25s, color .25s; }
nav.top ul a:hover, nav.top ul a.active { opacity: 1; color: var(--gold-soft); }
nav.top .tickets { border: 1px solid var(--gold); color: var(--gold-soft); padding: 9px 18px; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; transition: background .3s, color .3s; }
nav.top .tickets:hover { background: var(--gold); color: var(--ink); }
@media (max-width: 820px) { nav.top ul { display: none; } nav.top { padding: 14px 20px; } }

/* BUTTONS */
.btn { display: inline-flex; align-items: center; gap: 10px; padding: 16px 28px; font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase; font-weight: 700; transition: transform .25s, background .25s, color .25s; cursor: pointer; border: none; }
.btn.primary { background: var(--curtain); color: var(--parchment); }
.btn.primary:hover { background: var(--gold); color: var(--ink); transform: translateY(-2px); }
.btn.ghost { background: transparent; color: var(--parchment); border: 1px solid var(--parchment-2); }
.btn.ghost:hover { background: var(--parchment); color: var(--ink); }
.btn .arrow { transition: transform .25s; }
.btn:hover .arrow { transform: translateX(4px); }

/* HERO (landing) */
.hero { position: relative; min-height: 100vh; padding: 140px 36px 80px; overflow: hidden; isolation: isolate; }
.curtain { position: absolute; top: 0; bottom: 0; width: 22%; background: repeating-linear-gradient(90deg, var(--curtain-deep) 0px, var(--curtain) 14px, var(--curtain-deep) 28px, #4a0808 36px, var(--curtain-deep) 52px); z-index: -1; pointer-events: none; }
.curtain.left  { left: 0;  clip-path: polygon(0 0, 100% 0, 75% 100%, 0 100%); }
.curtain.right { right: 0; clip-path: polygon(0 0, 100% 0, 100% 100%, 25% 100%); }
.curtain::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(0,0,0,0.2), rgba(0,0,0,0.65)); mix-blend-mode: multiply; }
.curtain.right::after { background: linear-gradient(270deg, rgba(0,0,0,0.2), rgba(0,0,0,0.65)); }
@media (max-width: 760px) { .curtain { width: 10%; } }
.spotlight { position: absolute; top: -10%; left: 50%; transform: translateX(-50%); width: 120vw; height: 120vh; background: radial-gradient(ellipse at 50% 20%, rgba(255, 234, 194, 0.22) 0%, rgba(255, 234, 194, 0.08) 22%, transparent 55%); z-index: -1; pointer-events: none; }
.stage-floor { position: absolute; bottom: 0; left: 0; right: 0; height: 18vh; background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.6) 100%), repeating-linear-gradient(90deg, #1a120f 0px, #1a120f 60px, #0d0a08 62px, #0d0a08 64px); transform: perspective(600px) rotateX(45deg); transform-origin: bottom; z-index: -1; opacity: 0.55; }
.hero-inner { max-width: 1280px; margin: 0 auto; position: relative; }
.kicker { display: inline-flex; align-items: center; gap: 14px; font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--gold-soft); margin-bottom: 36px; padding: 8px 16px; border: 1px solid var(--gold); border-radius: 999px; opacity: 0; animation: fadeUp .9s .15s forwards; }
.kicker .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold-soft); box-shadow: 0 0 10px var(--gold-soft); animation: pulse 2s infinite; }
h1.display { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(56px, 11vw, 180px); line-height: 0.88; letter-spacing: -0.03em; color: var(--parchment); margin-bottom: 24px; }
h1.display .it { font-style: italic; font-weight: 300; color: var(--gold-soft); }
h1.display .on { display: block; font-size: 0.42em; letter-spacing: 0.5em; font-weight: 600; color: var(--parchment-2); text-transform: uppercase; margin: 10px 0 6px; }
h1.display .word { display: inline-block; opacity: 0; transform: translateY(40px); animation: fadeUp 1s forwards; }
h1.display .word:nth-child(1) { animation-delay: .25s; }
h1.display .word:nth-child(2) { animation-delay: .45s; }
h1.display .word:nth-child(3) { animation-delay: .65s; }
.hero-sub { max-width: 620px; font-size: clamp(16px, 1.4vw, 19px); color: var(--parchment-2); opacity: 0; animation: fadeUp 1s .85s forwards; margin-bottom: 44px; }
.hero-sub em { color: var(--gold-soft); font-style: italic; }
.hero-cta { display: flex; gap: 18px; flex-wrap: wrap; opacity: 0; animation: fadeUp 1s 1s forwards; }
.marquee { position: absolute; bottom: 40px; left: 0; right: 0; overflow: hidden; white-space: nowrap; opacity: 0; animation: fadeUp 1s 1.2s forwards; }
.marquee-track { display: inline-block; animation: scroll 38s linear infinite; font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: clamp(32px, 5.5vw, 72px); color: rgba(243, 234, 214, 0.12); letter-spacing: -0.01em; }
.marquee-track span { padding: 0 40px; }
.marquee-track span::after { content: "★"; color: var(--gold); margin-left: 40px; font-size: 0.6em; vertical-align: middle; }
@keyframes scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes fadeUp { to { opacity: 1; transform: translateY(0); } }
@keyframes pulse  { 0%,100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.4; transform: scale(1.2); } }

/* SECTIONS */
section { position: relative; padding: 140px 36px; }
section .container { max-width: 1280px; margin: 0 auto; }
.section-label { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--gold-soft); margin-bottom: 18px; display: flex; align-items: center; gap: 14px; }
.section-label::before { content: ""; display: block; width: 36px; height: 1px; background: var(--gold); }
.section-title { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(40px, 6vw, 88px); line-height: 0.95; letter-spacing: -0.025em; margin-bottom: 24px; }
.section-title em { font-style: italic; color: var(--gold-soft); font-weight: 300; }
.section-intro { max-width: 620px; font-size: 18px; color: var(--parchment-2); margin-bottom: 70px; }

/* ACT I */
.act-one { background: var(--parchment); color: var(--ink); }
.act-one .section-label { color: var(--curtain-deep); }
.act-one .section-label::before { background: var(--curtain-deep); }
.act-one .section-intro { color: #3c3229; }
.act-one .section-title em { color: var(--curtain); }
.manifesto-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: start; }
@media (max-width: 900px) { .manifesto-grid { grid-template-columns: 1fr; gap: 40px; } }
.pull-quote { font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: clamp(28px, 3.4vw, 44px); line-height: 1.2; color: var(--ink); border-left: 3px solid var(--curtain); padding-left: 30px; }
.pull-quote::before { content: "“"; font-size: 100px; color: var(--curtain); line-height: 0.5; display: block; margin-bottom: 10px; }
.contrasts { display: grid; gap: 2px; background: #3c3229; border: 2px solid var(--ink); }
.contrast-row { display: grid; grid-template-columns: 1fr 1fr; background: var(--parchment); }
.contrast-row > div { padding: 22px 24px; font-size: 15px; }
.contrast-row .bad { background: var(--parchment-2); color: #6b5544; text-decoration: line-through; text-decoration-color: var(--curtain); font-family: 'Fraunces', serif; font-style: italic; }
.contrast-row .good { background: var(--ink); color: var(--parchment); font-weight: 500; letter-spacing: 0.01em; }

/* ACT II (cities) */
.act-two { background: var(--ink); padding-top: 160px; }
.cities { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; margin-top: 20px; }
@media (max-width: 960px) { .cities { grid-template-columns: 1fr; } }
.city-card { position: relative; padding: 40px 32px 36px; border: 1px solid var(--rule); background: linear-gradient(180deg, rgba(243,234,214,0.02), rgba(243,234,214,0.05)); overflow: hidden; transition: transform .4s, border-color .4s; display: block; color: inherit; }
.city-card:hover { transform: translateY(-6px); border-color: var(--gold); }
.city-card .num { font-family: 'Fraunces', serif; font-weight: 300; font-style: italic; font-size: 14px; color: var(--gold-soft); letter-spacing: 0.2em; margin-bottom: 12px; }
.city-card h3 { font-family: 'Fraunces', serif; font-weight: 400; font-size: 64px; letter-spacing: -0.02em; line-height: 1; margin-bottom: 8px; }
.city-card .date { font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0.15em; color: var(--parchment-2); text-transform: uppercase; margin-bottom: 24px; padding-bottom: 18px; border-bottom: 1px dashed var(--rule); }
.city-card .venue { font-size: 14px; color: var(--parchment-2); margin-bottom: 28px; min-height: 42px; }
.city-card .city-svg { margin: 8px 0 22px; height: 80px; opacity: 0.7; }
.city-card .status { display: inline-block; font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; padding: 6px 12px; border: 1px solid var(--curtain); color: var(--curtain); background: rgba(155, 28, 28, 0.08); }
.city-card .status.live { border-color: var(--gold); color: var(--gold-soft); background: rgba(201, 162, 75, 0.1); }
.city-card .arrow-cta { margin-top: 22px; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold-soft); display: flex; align-items: center; gap: 8px; transition: gap .25s; }
.city-card:hover .arrow-cta { gap: 14px; }

/* ACT III (experience) */
.act-three { background: linear-gradient(180deg, var(--ink) 0%, #150d0b 100%); position: relative; }
.act-three::before { content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 1px; height: 80px; background: var(--gold); }
.experience-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px; }
.exp { padding: 32px 28px; border-top: 1px solid var(--rule); position: relative; }
.exp .exp-num { font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: 48px; color: var(--gold-soft); line-height: 1; margin-bottom: 24px; }
.exp h4 { font-family: 'Fraunces', serif; font-weight: 600; font-size: 22px; margin-bottom: 12px; }
.exp p { font-size: 15px; color: var(--parchment-2); line-height: 1.6; }
.exp.a { grid-column: span 7; }
.exp.b { grid-column: span 5; }
.exp.c { grid-column: span 4; }
.exp.d { grid-column: span 4; }
.exp.e { grid-column: span 4; }
@media (max-width: 900px) { .exp, .exp.a, .exp.b, .exp.c, .exp.d, .exp.e { grid-column: span 12; } }

/* ACT IV (partners) */
.act-four { background: var(--curtain-deep); color: var(--parchment); overflow: hidden; position: relative; }
.act-four::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 80% 20%, rgba(201, 162, 75, 0.25) 0%, transparent 50%), repeating-linear-gradient(90deg, transparent 0, transparent 48px, rgba(0,0,0,0.15) 48px, rgba(0,0,0,0.15) 50px); pointer-events: none; }
.act-four .container { position: relative; z-index: 1; }
.act-four .section-label { color: var(--gold-soft); }
.act-four .section-label::before { background: var(--gold-soft); }
.act-four .section-title em { color: var(--gold-soft); }
.partner-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; background: rgba(0,0,0,0.3); border: 1px solid rgba(201, 162, 75, 0.3); margin-top: 40px; }
@media (max-width: 760px) { .partner-grid { grid-template-columns: 1fr; } }
.partner-tier { background: var(--curtain-deep); padding: 40px 32px; position: relative; }
.partner-tier .tier-ribbon { position: absolute; top: 0; right: 0; background: var(--gold); color: var(--ink); font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.2em; padding: 5px 12px; text-transform: uppercase; }
.partner-tier h4 { font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: 36px; letter-spacing: -0.01em; margin-bottom: 4px; }
.partner-tier .act-no { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--gold-soft); margin-bottom: 24px; }
.partner-tier ul { list-style: none; margin-top: 16px; }
.partner-tier li { font-size: 14px; padding: 10px 0; border-bottom: 1px dashed rgba(243, 234, 214, 0.15); display: flex; align-items: flex-start; gap: 10px; }
.partner-tier li:last-child { border-bottom: none; }
.partner-tier li::before { content: "❖"; color: var(--gold-soft); flex-shrink: 0; }

/* ACT V (ticket) */
.act-five { background: var(--parchment); color: var(--ink); padding: 140px 36px; }
.ticket-wrap { max-width: 980px; margin: 0 auto; position: relative; }
.ticket { display: grid; grid-template-columns: 1fr 260px; background: var(--ink); color: var(--parchment); position: relative; box-shadow: 20px 20px 0 var(--curtain); }
@media (max-width: 720px) { .ticket { grid-template-columns: 1fr; } }
.ticket-body { padding: 50px 48px; }
.ticket-body .t-label { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.3em; color: var(--gold-soft); text-transform: uppercase; margin-bottom: 18px; }
.ticket-body h3 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(34px, 4.5vw, 56px); line-height: 1; letter-spacing: -0.02em; margin-bottom: 22px; }
.ticket-body h3 em { font-style: italic; color: var(--gold-soft); font-weight: 300; }
.ticket-body p { font-size: 16px; color: var(--parchment-2); margin-bottom: 32px; max-width: 420px; }
.ticket-form { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 14px; }
@media (max-width: 600px) { .ticket-form { grid-template-columns: 1fr; } }
.ticket-form input, .ticket-form select { background: transparent; border: 1px solid var(--rule); padding: 14px 16px; color: var(--parchment); font-family: inherit; font-size: 14px; outline: none; transition: border-color .25s; }
.ticket-form input::placeholder, .ticket-form select { color: #8a7e70; }
.ticket-form input:focus, .ticket-form select:focus { border-color: var(--gold); }
.ticket-form select option { background: var(--ink); color: var(--parchment); }
.ticket-form .full { grid-column: span 2; }
@media (max-width: 600px) { .ticket-form .full { grid-column: span 1; } }
.ticket-stub { background: radial-gradient(circle at 0% 50%, transparent 12px, var(--curtain) 12px), var(--curtain); padding: 48px 28px; display: flex; flex-direction: column; justify-content: space-between; position: relative; border-left: 2px dashed rgba(243, 234, 214, 0.35); }
@media (max-width: 720px) { .ticket-stub { border-left: none; border-top: 2px dashed rgba(243, 234, 214, 0.35); background: var(--curtain); } }
.ticket-stub .admit { font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: 32px; line-height: 1; margin-bottom: 14px; }
.ticket-stub .stub-details { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.15em; line-height: 1.8; color: rgba(243, 234, 214, 0.9); }
.ticket-stub .stub-details span { display: block; }
.ticket-stub .stub-no { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.2em; opacity: 0.7; margin-top: 18px; }

/* FOOTER */
footer { background: var(--ink-2); color: var(--parchment-2); padding: 80px 36px 40px; border-top: 1px solid var(--rule); }
.foot-grid { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 60px; }
@media (max-width: 760px) { .foot-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .foot-grid { grid-template-columns: 1fr; } }
footer h5 { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--gold-soft); margin-bottom: 20px; }
footer .brand-big { font-family: 'Fraunces', serif; font-weight: 400; font-style: italic; font-size: 36px; line-height: 1; margin-bottom: 18px; color: var(--parchment); }
footer .brand-big span { color: var(--gold-soft); }
footer ul { list-style: none; }
footer li { font-size: 14px; padding: 6px 0; }
footer li a { transition: color .2s; }
footer li a:hover { color: var(--gold-soft); }
footer .foot-bottom { max-width: 1280px; margin: 0 auto; padding-top: 30px; border-top: 1px solid var(--rule); display: flex; justify-content: space-between; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.12em; color: #7a6e60; flex-wrap: wrap; gap: 12px; }

.reveal { opacity: 0; transform: translateY(30px); transition: opacity 1s ease, transform 1s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
.toast { position: fixed; bottom: 30px; left: 50%; transform: translateX(-50%) translateY(200%); background: var(--ink); color: var(--parchment); padding: 16px 28px; border: 1px solid var(--gold); font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0.15em; text-transform: uppercase; z-index: 2000; transition: transform .5s cubic-bezier(0.22, 1, 0.36, 1); }
.toast.show { transform: translateX(-50%) translateY(0); }

/* EDITION PAGES */
.ed-hero { position: relative; padding: 160px 36px 100px; overflow: hidden; isolation: isolate; min-height: 75vh; display: flex; align-items: center; }
.ed-hero .container { max-width: 1280px; margin: 0 auto; position: relative; width: 100%; }
.ed-hero::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 80% 30%, var(--ed-accent, var(--curtain)) 0%, transparent 55%), radial-gradient(ellipse at 10% 80%, rgba(201,162,75,0.18) 0%, transparent 60%); opacity: 0.35; z-index: -1; }
.ed-hero::after { content: ""; position: absolute; inset: 0; background: repeating-linear-gradient(0deg, transparent 0, transparent 60px, rgba(243,234,214,0.03) 60px, rgba(243,234,214,0.03) 61px); z-index: -1; }
.breadcrumb { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--parchment-2); margin-bottom: 36px; opacity: 0; animation: fadeUp .8s .1s forwards; }
.breadcrumb a { color: var(--gold-soft); }
.breadcrumb a:hover { color: var(--parchment); }
.breadcrumb .sep { margin: 0 10px; opacity: 0.5; }
.ed-hero h1 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(64px, 12vw, 200px); line-height: 0.88; letter-spacing: -0.035em; margin-bottom: 32px; opacity: 0; animation: fadeUp 1s .25s forwards; }
.ed-hero h1 em { font-style: italic; font-weight: 300; color: var(--gold-soft); }
.ed-hero .edition-no { font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: 20px; color: var(--gold-soft); margin-bottom: 10px; letter-spacing: 0.08em; opacity: 0; animation: fadeUp .9s .2s forwards; }
.ed-meta { display: grid; grid-template-columns: repeat(4, auto); gap: 40px; margin-top: 40px; padding-top: 32px; border-top: 1px solid var(--rule); opacity: 0; animation: fadeUp 1s .65s forwards; max-width: 900px; }
@media (max-width: 760px) { .ed-meta { grid-template-columns: 1fr 1fr; gap: 28px; } }
.ed-meta .m-label { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--gold-soft); margin-bottom: 6px; }
.ed-meta .m-value { font-family: 'Fraunces', serif; font-size: 22px; font-weight: 400; color: var(--parchment); line-height: 1.2; }
.ed-actions { display: flex; gap: 18px; flex-wrap: wrap; margin-top: 44px; opacity: 0; animation: fadeUp 1s .85s forwards; }

.ed-subnav { background: var(--ink-2); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); position: sticky; top: 62px; z-index: 50; }
.ed-subnav .container { max-width: 1280px; margin: 0 auto; padding: 0 36px; display: flex; gap: 6px; overflow-x: auto; }
.ed-subnav a { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; padding: 18px 22px; color: var(--parchment-2); border-bottom: 2px solid transparent; transition: color .25s, border-color .25s; white-space: nowrap; }
.ed-subnav a:hover { color: var(--parchment); }
.ed-subnav a.active { color: var(--gold-soft); border-bottom-color: var(--gold); }

.ed-body { background: var(--ink); padding: 130px 36px; }
.ed-body .container { max-width: 1280px; margin: 0 auto; }
.two-col { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: start; }
@media (max-width: 900px) { .two-col { grid-template-columns: 1fr; gap: 40px; } }
.two-col .lede { font-family: 'Fraunces', serif; font-weight: 300; font-size: clamp(24px, 2.6vw, 32px); line-height: 1.35; color: var(--parchment); }
.two-col .lede em { font-style: italic; color: var(--gold-soft); }
.two-col .body p { font-size: 17px; color: var(--parchment-2); margin-bottom: 22px; line-height: 1.7; }
.two-col .body p:first-letter { font-family: 'Fraunces', serif; font-weight: 400; font-style: italic; font-size: 3.2em; float: left; line-height: 0.9; padding: 6px 10px 0 0; color: var(--gold-soft); }

.program { margin-top: 100px; border-top: 1px solid var(--rule); padding-top: 60px; }
.program h2 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(36px, 5vw, 56px); margin-bottom: 50px; letter-spacing: -0.02em; }
.program h2 em { font-style: italic; color: var(--gold-soft); font-weight: 300; }
.day-tag { display: inline-block; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--ink); background: var(--gold); padding: 5px 12px; margin: 40px 0 20px; }
.program-row { display: grid; grid-template-columns: 140px 1fr; gap: 40px; padding: 22px 0; border-bottom: 1px dashed var(--rule); align-items: baseline; }
@media (max-width: 600px) { .program-row { grid-template-columns: 1fr; gap: 4px; } }
.program-row .t { font-family: 'JetBrains Mono', monospace; font-size: 14px; letter-spacing: 0.1em; color: var(--gold-soft); }
.program-row .e .title { font-family: 'Fraunces', serif; font-size: 22px; font-weight: 500; margin-bottom: 4px; }
.program-row .e .title em { font-style: italic; font-weight: 300; color: var(--gold-soft); }
.program-row .e .meta { font-size: 14px; color: var(--parchment-2); }

/* SPEAKERS */
.speakers-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; background: var(--rule); border: 1px solid var(--rule); margin-top: 60px; }
@media (max-width: 900px) { .speakers-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .speakers-grid { grid-template-columns: 1fr; } }
.speaker { background: var(--ink); padding: 36px 30px 32px; position: relative; transition: background .35s; display: flex; flex-direction: column; gap: 16px; overflow: hidden; }
.speaker:hover { background: #1a120f; }
.speaker .portrait { width: 100%; aspect-ratio: 1 / 1.15; background: linear-gradient(180deg, #241814 0%, #12090a 100%); position: relative; overflow: hidden; margin-bottom: 6px; border: 1px solid var(--rule); }
.speaker .portrait .initials { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: 96px; color: rgba(243,234,214,0.18); letter-spacing: -0.04em; }
.speaker .portrait .spot-glow { position: absolute; top: -20%; left: 30%; width: 120%; height: 120%; background: radial-gradient(circle at 30% 20%, rgba(255,234,194,0.15) 0%, transparent 55%); }
.speaker .portrait.has-photo { background: var(--ink-2); }
.speaker .portrait.has-photo img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(0.85) contrast(1.05); transition: filter .4s, transform .6s; }
.speaker:hover .portrait.has-photo img { filter: saturate(1) contrast(1); transform: scale(1.03); }
.speaker .portrait.has-photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 50%, rgba(10,7,6,0.55) 100%); pointer-events: none; }
.speaker .portrait .tag { position: absolute; bottom: 14px; left: 14px; background: var(--gold); color: var(--ink); font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 0.25em; text-transform: uppercase; padding: 4px 9px; z-index: 2; }
.speaker h3 { font-family: 'Fraunces', serif; font-weight: 400; font-size: 26px; letter-spacing: -0.01em; line-height: 1.1; }
.speaker .role { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.15em; color: var(--gold-soft); text-transform: uppercase; }
.speaker .talk { font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: 17px; line-height: 1.4; color: var(--parchment-2); padding-top: 14px; border-top: 1px dashed var(--rule); }
.speaker .talk::before { content: "“"; color: var(--gold-soft); }
.speaker .talk::after { content: "”"; color: var(--gold-soft); }
.speaker .talk-pending { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(243,234,214,0.4); padding-top: 14px; border-top: 1px dashed var(--rule); }
.speaker.is-linked { cursor: pointer; }
.speaker.is-linked:hover h3 { color: var(--gold-soft); }
.speaker .read-more { margin-top: auto; padding-top: 16px; font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold-soft); display: flex; align-items: center; gap: 8px; transition: gap .25s; }
.speaker.is-linked:hover .read-more { gap: 14px; }
.speakers-lineup-note { max-width: 720px; margin: 80px auto 30px; text-align: center; font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: 20px; color: var(--parchment-2); padding: 30px 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }

/* SPEAKER DETAIL PAGE */
.sp-detail .breadcrumb a:hover { color: var(--parchment); }
.sp-detail-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: start; margin-top: 20px; }
@media (max-width: 900px) { .sp-detail-grid { grid-template-columns: 1fr; gap: 40px; } }
.sp-portrait { width: 100%; aspect-ratio: 1 / 1.15; background: var(--ink-2); position: relative; overflow: hidden; border: 1px solid var(--rule); }
.sp-portrait .initials { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: 180px; color: rgba(243,234,214,0.18); }
.sp-portrait .spot-glow { position: absolute; top: -20%; left: 30%; width: 120%; height: 120%; background: radial-gradient(circle at 30% 20%, rgba(255,234,194,0.15) 0%, transparent 55%); }
.sp-portrait.has-photo img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(0.9) contrast(1.05); }
.sp-portrait.has-photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 60%, rgba(10,7,6,0.5) 100%); pointer-events: none; }
.sp-right .sp-role { font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0.22em; color: var(--gold-soft); text-transform: uppercase; margin-bottom: 14px; }
.sp-right .sp-name { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(48px, 7vw, 84px); line-height: 0.95; letter-spacing: -0.03em; margin-bottom: 40px; }
.sp-talk-block { margin-bottom: 50px; padding: 30px 32px; border-left: 3px solid var(--gold); background: linear-gradient(90deg, rgba(201,162,75,0.06), transparent 70%); }
.sp-talk-label { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--gold-soft); margin-bottom: 14px; }
.sp-talk-title { font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: clamp(26px, 3.4vw, 38px); line-height: 1.15; letter-spacing: -0.015em; margin-bottom: 20px; color: var(--parchment); }
.sp-abstract { font-size: 17px; line-height: 1.65; color: var(--parchment-2); }
.sp-bio { font-size: 17px; line-height: 1.75; color: var(--parchment-2); padding-top: 32px; border-top: 1px solid var(--rule); }

/* VENUE */
.venue-hero-visual { margin-top: 60px; display: grid; grid-template-columns: 1fr 1fr; gap: 0; border: 1px solid var(--rule); }
@media (max-width: 800px) { .venue-hero-visual { grid-template-columns: 1fr; } }
.venue-sketch { background: var(--ink-2); padding: 50px; display: flex; align-items: center; justify-content: center; min-height: 420px; border-right: 1px solid var(--rule); position: relative; overflow: hidden; }
@media (max-width: 800px) { .venue-sketch { border-right: none; border-bottom: 1px solid var(--rule); } }
.venue-sketch svg { width: 100%; height: auto; max-height: 360px; color: var(--gold-soft); opacity: 0.85; }
.venue-details { padding: 50px; background: var(--ink); }
.venue-details .label { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--gold-soft); margin-bottom: 18px; }
.venue-details h2 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(32px, 4vw, 44px); letter-spacing: -0.02em; line-height: 1; margin-bottom: 10px; }
.venue-details h2 em { font-style: italic; color: var(--gold-soft); font-weight: 300; }
.venue-details .address { font-size: 15px; color: var(--parchment-2); margin-bottom: 28px; line-height: 1.6; }
.venue-details dl { display: grid; grid-template-columns: 140px 1fr; gap: 14px 24px; padding-top: 24px; border-top: 1px solid var(--rule); }
.venue-details dt { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold-soft); padding-top: 3px; }
.venue-details dd { font-size: 15px; line-height: 1.5; color: var(--parchment); }
.venue-features { margin-top: 120px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
@media (max-width: 900px) { .venue-features { grid-template-columns: 1fr; } }
.venue-feat { padding: 34px 28px; border: 1px solid var(--rule); background: linear-gradient(180deg, rgba(243,234,214,0.02), transparent); position: relative; }
.venue-feat .num { font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; color: var(--gold-soft); font-size: 32px; margin-bottom: 18px; line-height: 1; }
.venue-feat h4 { font-family: 'Fraunces', serif; font-size: 22px; margin-bottom: 10px; font-weight: 500; }
.venue-feat p { font-size: 14px; color: var(--parchment-2); line-height: 1.6; }
.venue-story { margin-top: 120px; max-width: 880px; margin-left: auto; margin-right: auto; text-align: center; padding: 60px 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.venue-story h3 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(28px, 3.4vw, 40px); letter-spacing: -0.02em; line-height: 1.15; margin-bottom: 22px; }
.venue-story h3 em { font-style: italic; color: var(--gold-soft); font-weight: 300; }
.venue-story p { font-size: 17px; color: var(--parchment-2); line-height: 1.7; max-width: 640px; margin: 0 auto; }
.venue-getting-there { margin-top: 80px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; background: var(--rule); border: 1px solid var(--rule); }
@media (max-width: 760px) { .venue-getting-there { grid-template-columns: 1fr; } }
.gt { background: var(--ink); padding: 32px 28px; }
.gt .icon { color: var(--gold-soft); margin-bottom: 14px; font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: 28px; }
.gt h4 { font-family: 'Fraunces', serif; font-weight: 500; font-size: 20px; margin-bottom: 8px; }
.gt p { font-size: 14px; color: var(--parchment-2); line-height: 1.5; }

/* ===========================================================
   SPONSORS PAGE
   =========================================================== */
.spon-intro { background: var(--ink); padding: 130px 36px 80px; }
.spon-intro .container { max-width: 1280px; margin: 0 auto; }
.spon-why { display: grid; grid-template-columns: 1fr 1fr; gap: 70px; align-items: start; margin-top: 30px; }
@media (max-width: 900px) { .spon-why { grid-template-columns: 1fr; gap: 36px; } }
.spon-why .lede { font-family: 'Fraunces', serif; font-weight: 300; font-size: clamp(24px, 2.6vw, 32px); line-height: 1.35; color: var(--parchment); }
.spon-why .lede em { font-style: italic; color: var(--gold-soft); }
.spon-why .body p { font-size: 17px; color: var(--parchment-2); margin-bottom: 20px; line-height: 1.7; }

/* highlights / why-sponsor chips */
.spon-highlights { background: linear-gradient(180deg, var(--ink) 0%, #150d0b 100%); padding: 110px 36px; }
.spon-highlights .container { max-width: 1280px; margin: 0 auto; }
.hl-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 50px; }
@media (max-width: 900px) { .hl-grid { grid-template-columns: 1fr; } }
.hl { padding: 30px 28px; border: 1px solid var(--rule); background: linear-gradient(180deg, rgba(243,234,214,0.02), transparent); }
.hl .hl-ic { font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; color: var(--gold-soft); font-size: 30px; margin-bottom: 14px; }
.hl h4 { font-family: 'Fraunces', serif; font-weight: 600; font-size: 20px; margin-bottom: 8px; }
.hl p { font-size: 14px; color: var(--parchment-2); line-height: 1.6; }

/* tiers */
.tiers { background: var(--ink); padding: 130px 36px; }
.tiers .container { max-width: 1280px; margin: 0 auto; }
.tier-list { display: flex; flex-direction: column; gap: 24px; margin-top: 60px; }
.tier-card { position: relative; border: 1px solid var(--rule); background: linear-gradient(180deg, rgba(243,234,214,0.02), rgba(243,234,214,0.04)); padding: 44px 44px; display: grid; grid-template-columns: 240px 1fr; gap: 50px; align-items: start; transition: border-color .35s, transform .35s; overflow: hidden; }
@media (max-width: 820px) { .tier-card { grid-template-columns: 1fr; gap: 24px; padding: 34px 28px; } }
.tier-card:hover { border-color: var(--gold); transform: translateY(-3px); }
.tier-card.feature { border-color: var(--gold); background: linear-gradient(180deg, rgba(201,162,75,0.08), rgba(155,28,28,0.06)); }
.tier-card .t-price { font-family: 'Fraunces', serif; font-weight: 300; font-size: clamp(48px, 6vw, 72px); line-height: 0.9; letter-spacing: -0.03em; color: var(--gold-soft); }
.tier-card .t-name { font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--parchment); margin-top: 14px; }
.tier-card .t-limit { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--curtain); margin-top: 16px; display: inline-block; border: 1px solid var(--curtain); padding: 5px 10px; background: rgba(155,28,28,0.08); }
.tier-card.feature .t-limit { color: var(--gold-soft); border-color: var(--gold); background: rgba(201,162,75,0.1); }
.tier-card .t-tag { font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: 19px; color: var(--parchment-2); margin-bottom: 22px; line-height: 1.35; }
.tier-card .t-inherit { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--gold-soft); margin-bottom: 18px; }
.tier-card ul { list-style: none; display: grid; grid-template-columns: 1fr 1fr; gap: 12px 30px; }
@media (max-width: 560px) { .tier-card ul { grid-template-columns: 1fr; } }
.tier-card li { font-size: 15px; color: var(--parchment); padding-left: 24px; position: relative; line-height: 1.45; }
.tier-card li::before { content: "❖"; position: absolute; left: 0; color: var(--gold-soft); }
.ribbon-main { position: absolute; top: 0; right: 0; background: var(--gold); color: var(--ink); font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.2em; padding: 6px 14px; text-transform: uppercase; }

/* media booth */
.media-booth { background: var(--curtain-deep); color: var(--parchment); position: relative; overflow: hidden; padding: 120px 36px; }
.media-booth::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 80% 20%, rgba(201,162,75,0.22) 0%, transparent 55%); pointer-events: none; }
.media-booth .container { max-width: 1280px; margin: 0 auto; position: relative; z-index: 1; }
.media-booth .section-label { color: var(--gold-soft); }
.media-booth .section-label::before { background: var(--gold-soft); }
.media-booth .section-title em { color: var(--gold-soft); }
.booth-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 44px; }
@media (max-width: 760px) { .booth-grid { grid-template-columns: 1fr; } }
.booth-item { border: 1px solid rgba(243,234,214,0.18); border-left: 3px solid var(--gold); padding: 22px 26px; font-size: 16px; background: rgba(0,0,0,0.15); }
.booth-item strong { color: var(--gold-soft); font-weight: 600; }

/* sponsors placeholder strip (homepage) */
.our-sponsors { background: var(--ink); padding: 110px 36px; border-top: 1px solid var(--rule); }
.our-sponsors .container { max-width: 1280px; margin: 0 auto; text-align: center; }
.our-sponsors .section-label { justify-content: center; }
.our-sponsors h2 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(32px, 4.5vw, 56px); letter-spacing: -0.02em; margin-bottom: 16px; }
.our-sponsors h2 em { font-style: italic; color: var(--gold-soft); font-weight: 300; }
.our-sponsors > .container > p { color: var(--parchment-2); font-size: 17px; max-width: 560px; margin: 0 auto 50px; }
.sponsor-slots { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 44px; }
@media (max-width: 760px) { .sponsor-slots { grid-template-columns: 1fr 1fr; } }
.slot { aspect-ratio: 16 / 9; border: 1px dashed var(--rule); display: flex; align-items: center; justify-content: center; background: linear-gradient(180deg, rgba(243,234,214,0.015), transparent); transition: border-color .3s, color .3s; }
.slot span { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(243,234,214,0.35); }
.slot:hover { border-color: var(--gold); }
.slot:hover span { color: var(--gold-soft); }

/* tiered sponsor display */
.sponsor-tier-block { margin-bottom: 54px; }
.sponsor-tier-block:last-of-type { margin-bottom: 40px; }
.sponsor-tier-head { display: flex; align-items: center; gap: 18px; margin-bottom: 24px; }
.sponsor-tier-head .st-name { font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0.28em; text-transform: uppercase; white-space: nowrap; }
.sponsor-tier-head .st-line { flex: 1; height: 1px; background: var(--rule); }
.sponsor-tier-head.platinum .st-name { color: #e9e4d8; }
.sponsor-tier-head.gold .st-name { color: var(--gold-soft); }
.sponsor-tier-head.silver .st-name { color: #c9c9d2; }
.sponsor-tier-head.bronze .st-name { color: #c08457; }

.sponsor-row { display: grid; gap: 16px; }
.sponsor-row.cols-1 { grid-template-columns: minmax(0, 380px); justify-content: center; }
.sponsor-row.cols-2 { grid-template-columns: repeat(2, 1fr); max-width: 760px; margin: 0 auto; }
.sponsor-row.cols-3 { grid-template-columns: repeat(3, 1fr); }
.sponsor-row.cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 760px) { .sponsor-row.cols-3, .sponsor-row.cols-4 { grid-template-columns: 1fr 1fr; } .sponsor-row.cols-2 { grid-template-columns: 1fr; } }

.sponsor-logo { aspect-ratio: 16 / 9; border: 1px solid var(--rule); background: linear-gradient(180deg, rgba(243,234,214,0.02), transparent); display: flex; align-items: center; justify-content: center; padding: 24px; transition: border-color .35s, transform .35s; overflow: hidden; }
.sponsor-logo:hover { border-color: var(--gold); transform: translateY(-3px); }
.sponsor-logo.platinum { aspect-ratio: 21 / 9; }
.sponsor-logo img { max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain; }
.sponsor-logo .placeholder { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(243,234,214,0.3); }

/* ===========================================================
   TICKETS PAGE
   =========================================================== */
.tk-cards { background: var(--ink); padding: 130px 36px 90px; }
.tk-cards .container { max-width: 1280px; margin: 0 auto; }
.tk-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 60px; align-items: stretch; }
@media (max-width: 900px) { .tk-grid { grid-template-columns: 1fr; max-width: 460px; margin-left: auto; margin-right: auto; } }
.tk-card { border: 1px solid var(--rule); background: linear-gradient(180deg, rgba(243,234,214,0.02), rgba(243,234,214,0.04)); padding: 40px 34px 36px; display: flex; flex-direction: column; position: relative; transition: transform .35s, border-color .35s; overflow: hidden; }
.tk-card:hover { transform: translateY(-6px); border-color: var(--gold); }
.tk-card.feature { border-color: var(--gold); background: linear-gradient(180deg, rgba(201,162,75,0.09), rgba(155,28,28,0.06)); }
.tk-card .tk-ribbon { position: absolute; top: 0; right: 0; background: var(--gold); color: var(--ink); font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.2em; padding: 6px 14px; text-transform: uppercase; }
.tk-card .tk-name { font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--gold-soft); margin-bottom: 18px; }
.tk-card .tk-price { font-family: 'Fraunces', serif; font-weight: 300; font-size: 68px; line-height: 0.9; letter-spacing: -0.03em; color: var(--parchment); }
.tk-card .tk-price .cur { font-size: 32px; vertical-align: super; color: var(--gold-soft); }
.tk-card .tk-sub { font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: 17px; color: var(--parchment-2); margin: 14px 0 28px; padding-bottom: 24px; border-bottom: 1px dashed var(--rule); min-height: 30px; }
.tk-card ul { list-style: none; display: flex; flex-direction: column; gap: 12px; margin-bottom: 32px; flex: 1; }
.tk-card li { font-size: 14.5px; color: var(--parchment); padding-left: 26px; position: relative; line-height: 1.45; }
.tk-card li.no { color: rgba(243,234,214,0.35); }
.tk-card li::before { content: "✓"; position: absolute; left: 0; color: var(--gold-soft); font-weight: 700; }
.tk-card li.no::before { content: "—"; color: rgba(243,234,214,0.3); font-weight: 400; }
.tk-card .btn { width: 100%; justify-content: center; margin-top: auto; }

/* comparison table */
.tk-compare { background: linear-gradient(180deg, var(--ink) 0%, #150d0b 100%); padding: 110px 36px; }
.tk-compare .container { max-width: 1080px; margin: 0 auto; }
.tk-table-wrap { margin-top: 50px; overflow-x: auto; border: 1px solid var(--rule); }
table.tk-table { width: 100%; border-collapse: collapse; min-width: 560px; }
table.tk-table th, table.tk-table td { padding: 16px 20px; text-align: center; border-bottom: 1px solid var(--rule); }
table.tk-table thead th { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold-soft); background: var(--ink-2); position: sticky; top: 0; }
table.tk-table thead th .p { display: block; font-family: 'Fraunces', serif; font-size: 22px; letter-spacing: 0; text-transform: none; color: var(--parchment); margin-top: 6px; }
table.tk-table tbody th { text-align: left; font-weight: 400; font-size: 15px; color: var(--parchment); font-family: 'Archivo', sans-serif; }
table.tk-table td .y { color: var(--gold-soft); font-weight: 700; }
table.tk-table td .n { color: rgba(243,234,214,0.28); }
table.tk-table tbody tr:hover { background: rgba(243,234,214,0.03); }
table.tk-table col.vip, table.tk-table th.vip, table.tk-table td.vip { background: rgba(201,162,75,0.06); }
.tk-note { text-align: center; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.12em; color: var(--parchment-2); margin-top: 30px; }

/* ===========================================================
   PARTNERS / ORGANISER (homepage)
   =========================================================== */
.partners-band { background: var(--ink-2); padding: 100px 36px; border-top: 1px solid var(--rule); }
.partners-band .container { max-width: 1280px; margin: 0 auto; }
.partners-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 60px; margin-top: 20px; }
@media (max-width: 900px) { .partners-cols { grid-template-columns: 1fr; gap: 50px; } }
.partners-col h4 { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--gold-soft); margin-bottom: 24px; padding-bottom: 14px; border-bottom: 1px solid var(--rule); }
.partner-plates { display: flex; flex-direction: column; gap: 14px; }
.partner-plate { display: flex; align-items: center; gap: 16px; padding: 20px 22px; border: 1px solid var(--rule); background: linear-gradient(180deg, rgba(243,234,214,0.02), transparent); transition: border-color .3s, transform .3s; min-height: 78px; }
.partner-plate:hover { border-color: var(--gold); transform: translateY(-2px); }
.partner-plate img { max-height: 42px; max-width: 150px; width: auto; height: auto; object-fit: contain; filter: brightness(0) invert(1); opacity: 0.9; }
.partner-plate .pp-text { display: flex; flex-direction: column; }
.partner-plate .pp-name { font-family: 'Fraunces', serif; font-weight: 500; font-size: 20px; color: var(--parchment); letter-spacing: -0.01em; line-height: 1.1; }
.partner-plate .pp-url { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.12em; color: var(--parchment-2); margin-top: 4px; }
.partner-plate:hover .pp-name { color: var(--gold-soft); }

/* organiser strip */
.organiser { background: var(--ink); padding: 70px 36px; border-top: 1px solid var(--rule); text-align: center; }
.organiser .container { max-width: 1280px; margin: 0 auto; }
.organiser .o-label { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--parchment-2); margin-bottom: 14px; }
.organiser a.o-name { font-family: 'Fraunces', serif; font-style: italic; font-weight: 400; font-size: clamp(26px, 3.4vw, 38px); color: var(--parchment); letter-spacing: -0.01em; transition: color .3s; }
.organiser a.o-name:hover { color: var(--gold-soft); }
