/* Subpage-specific styles extracted from the main site bundle. */

.speakers-event-shell {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  border: 1px solid rgb(var(--color-ui-border-rgb));
  border-radius: 2rem;
  background:
    radial-gradient(circle at 50% -6%, rgb(var(--color-brand-primary-rgb) / 0.12), transparent 20%),
    radial-gradient(circle at 82% 12%, rgb(var(--color-brand-primary-rgb) / 0.08), transparent 18%),
    radial-gradient(circle at 18% 88%, rgb(var(--color-brand-deep-rgb) / 0.08), transparent 22%),
    linear-gradient(
      180deg,
      rgb(var(--color-bg-primary-rgb) / 0.95) 0%,
      rgb(var(--color-surface-rgb) / 0.94) 100%
    );
  box-shadow:
    inset 0 1px 0 rgb(var(--color-text-primary-rgb) / 0.03),
    0 30px 100px rgb(var(--color-bg-primary-rgb) / 0.42);
}

.speakers-event-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgb(var(--color-text-primary-rgb) / 0.018) 1px, transparent 1px),
    linear-gradient(rgb(var(--color-text-primary-rgb) / 0.018) 1px, transparent 1px);
  background-size: 74px 74px;
  mask-image: radial-gradient(circle at 66% 42%, black 26%, transparent 92%);
  opacity: 0.16;
  pointer-events: none;
}

.speakers-event-shell::after {
  content: "";
  position: absolute;
  left: 50%;
  top: -1px;
  width: min(34rem, calc(100% - 5rem));
  height: 2px;
  transform: translateX(-50%);
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgb(var(--color-brand-primary-rgb) / 0.08) 18%,
    rgb(var(--color-brand-primary-rgb) / 0.22) 50%,
    rgb(var(--color-brand-primary-rgb) / 0.08) 82%,
    transparent 100%
  );
  box-shadow:
    0 0 16px rgb(var(--color-brand-primary-rgb) / 0.12),
    0 0 40px rgb(var(--color-brand-primary-rgb) / 0.06);
  pointer-events: none;
}

.speakers-event-layout {
  position: relative;
  display: grid;
  gap: 2.75rem;
  padding: 2.4rem 1.35rem;
  z-index: 1;
}

.speakers-event-copy {
  max-width: 26rem;
}

.speakers-event-kicker {
  margin: 0 0 1rem;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: rgb(var(--color-brand-hover-rgb) / 0.92);
}

.speakers-event-headline {
  margin: 0;
  font-family: "Sora", sans-serif;
  font-size: clamp(1.85rem, 3.2vw, 3.15rem);
  font-weight: 700;
  line-height: 1.04;
  letter-spacing: -0.05em;
  color: rgb(var(--color-text-primary-rgb));
  max-width: 11.8ch;
}

.speakers-event-headline > span {
  display: block;
  white-space: nowrap;
}

.speakers-event-body {
  margin: 1.5rem 0 0;
  max-width: 24rem;
  font-size: clamp(1rem, 1.1vw, 1.08rem);
  line-height: 1.7;
  color: rgb(var(--color-text-secondary-rgb) / 0.86);
}

.speakers-event-stats {
  margin-top: 2rem;
  border-top: 1px solid rgb(var(--color-ui-border-rgb) / 0.7);
}

.speakers-event-stat {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem;
  align-items: start;
  padding: 1.35rem 0;
  border-bottom: 1px solid rgb(var(--color-ui-border-rgb) / 0.52);
}

.speakers-event-stat-value {
  min-width: 4.1rem;
  font-family: "Sora", sans-serif;
  font-size: clamp(2rem, 2.8vw, 2.45rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.06em;
  color: rgb(var(--color-brand-primary-rgb));
}

.speakers-event-stat-copy h3 {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.2;
  color: rgb(var(--color-text-primary-rgb));
}

.speakers-event-stat-copy p {
  margin: 0.35rem 0 0;
  max-width: 18rem;
  font-size: 0.98rem;
  line-height: 1.55;
  color: rgb(var(--color-text-secondary-rgb) / 0.74);
}

.speakers-event-grid {
  display: grid;
  gap: 0.85rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.speaker-event-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgb(var(--color-ui-border-rgb) / 0.76);
  border-radius: 1.15rem;
  background:
    linear-gradient(
      180deg,
      rgb(var(--color-bg-primary-rgb) / 0.96) 0%,
      rgb(var(--color-surface-rgb) / 0.9) 100%
    );
  box-shadow:
    inset 0 1px 0 rgb(var(--color-text-primary-rgb) / 0.025),
    0 18px 42px rgb(var(--color-bg-primary-rgb) / 0.34);
  transition:
    transform 220ms ease,
    border-color 220ms ease,
    box-shadow 220ms ease;
}

.speaker-event-card:hover {
  transform: translateY(-2px);
  border-color: rgb(var(--color-brand-primary-rgb) / 0.42);
  box-shadow:
    inset 0 1px 0 rgb(var(--color-text-primary-rgb) / 0.03),
    0 24px 54px rgb(var(--color-bg-primary-rgb) / 0.38),
    0 0 22px rgb(var(--color-brand-primary-rgb) / 0.08);
}

.speaker-event-portrait {
  position: relative;
  aspect-ratio: 0.9 / 1;
  overflow: hidden;
  border-bottom: 1px solid rgb(var(--color-ui-border-rgb) / 0.64);
  background:
    radial-gradient(circle at 50% 82%, rgb(var(--color-brand-primary-rgb) / 0.2), transparent 30%),
    radial-gradient(circle at 18% 24%, rgb(var(--color-brand-primary-rgb) / 0.1), transparent 24%),
    radial-gradient(circle at 50% 24%, rgb(var(--color-text-primary-rgb) / 0.06), transparent 18%),
    radial-gradient(circle at 82% 18%, rgb(var(--color-brand-primary-rgb) / 0.08), transparent 22%),
    radial-gradient(circle at 50% 12%, rgb(var(--color-brand-primary-rgb) / 0.12), transparent 28%),
    linear-gradient(180deg, rgb(var(--color-bg-primary-rgb)) 0%, rgb(var(--color-surface-rgb)) 100%);
  box-shadow:
    inset 0 1px 0 rgb(var(--color-text-primary-rgb) / 0.03),
    inset 0 -26px 68px rgb(var(--color-brand-primary-rgb) / 0.1),
    0 0 36px rgb(var(--color-brand-primary-rgb) / 0.08);
}

.speaker-event-portrait > * {
  position: relative;
  z-index: 1;
}

.speaker-event-portrait::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 74%;
  height: 76%;
  border-radius: 46% 46% 24% 24% / 28% 28% 18% 18%;
  transform: translateX(-50%);
  background:
    radial-gradient(circle at 50% 18%, rgb(var(--color-text-primary-rgb) / 0.18), transparent 18%),
    linear-gradient(
      180deg,
      rgb(var(--color-text-primary-rgb) / 0.06) 0%,
      rgb(var(--color-text-primary-rgb) / 0.015) 24%,
      rgb(var(--color-bg-primary-rgb) / 0.72) 100%
    );
  filter: blur(0.2px);
  opacity: 0.95;
  box-shadow:
    0 18px 46px rgb(var(--color-brand-primary-rgb) / 0.08),
    0 0 34px rgb(var(--color-brand-primary-rgb) / 0.05);
}

.speaker-event-portrait::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 19%;
  width: 32%;
  height: 32%;
  border-radius: 999px;
  transform: translateX(-50%);
  background:
    radial-gradient(circle at 50% 38%, rgb(var(--color-text-primary-rgb) / 0.22), transparent 34%),
    linear-gradient(
      180deg,
      rgb(var(--color-text-primary-rgb) / 0.12) 0%,
      rgb(var(--color-text-primary-rgb) / 0.02) 100%
  );
  box-shadow: 0 0 26px rgb(var(--color-brand-primary-rgb) / 0.06);
  z-index: 1;
}

.speaker-event-portrait::before,
.speaker-event-portrait::after {
  z-index: 1;
}

.speaker-event-portrait::after,
.speaker-editorial-portrait::after {
  pointer-events: none;
}

.speaker-event-portrait::before {
  z-index: 1;
}

.speaker-event-portrait--left::before {
  transform: translateX(-56%);
}

.speaker-event-portrait--right::before {
  transform: translateX(-44%);
}

.speaker-event-portrait--left::after {
  transform: translateX(-58%);
}

.speaker-event-portrait--right::after {
  transform: translateX(-42%);
}

.speaker-event-meta {
  padding: 0.8rem 0.8rem 0.95rem;
}

.speaker-event-meta h3 {
  margin: 0;
  font-family: "Sora", sans-serif;
  font-size: 1.02rem;
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.03em;
  color: rgb(var(--color-text-primary-rgb));
}

.speaker-event-org,
.speaker-event-role {
  position: relative;
  margin: 0.34rem 0 0;
  padding-left: 0.95rem;
  font-size: 0.83rem;
  line-height: 1.35;
}

.speaker-event-org {
  color: rgb(var(--color-text-secondary-rgb) / 0.72);
}

.speaker-event-role {
  color: rgb(var(--color-brand-hover-rgb) / 0.9);
}

.speaker-event-org::before,
.speaker-event-role::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.42rem;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: rgb(var(--color-text-secondary-rgb) / 0.6);
  box-shadow: 0 0 10px rgb(var(--color-text-primary-rgb) / 0.05);
}

.speaker-event-role::before {
  background: rgb(var(--color-brand-primary-rgb));
  box-shadow: 0 0 12px rgb(var(--color-brand-primary-rgb) / 0.18);
}

.speaker-event-card--sam .speaker-event-portrait::before,
.speaker-event-card--ilya .speaker-event-portrait::before,
.speaker-event-card--oriol .speaker-event-portrait::before {
  width: 70%;
}

.speaker-event-card--fei .speaker-event-portrait::before,
.speaker-event-card--sasha .speaker-event-portrait::before,
.speaker-event-card--vivienne .speaker-event-portrait::before {
  width: 68%;
}

.speaker-event-card--demis .speaker-event-portrait::after,
.speaker-event-card--dario .speaker-event-portrait::after,
.speaker-event-card--jakub .speaker-event-portrait::after {
  width: 28%;
}

.speaker-event-card--sam .speaker-event-portrait,
.speaker-event-card--andrej .speaker-event-portrait,
.speaker-event-card--ilya .speaker-event-portrait {
  background:
    radial-gradient(circle at 50% 16%, rgb(var(--color-brand-primary-rgb) / 0.08), transparent 24%),
    linear-gradient(180deg, rgb(var(--color-bg-primary-rgb)) 0%, rgb(var(--color-surface-rgb)) 100%);
}

@media (min-width: 960px) {
  .speakers-event-layout {
    grid-template-columns: minmax(0, 0.7fr) minmax(0, 1.3fr);
    align-items: start;
    padding: 3rem 2rem;
  }

  .speakers-event-copy {
    position: sticky;
    top: 1.5rem;
  }

  .speakers-event-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 639px) {
  .speakers-event-headline {
    max-width: 11ch;
  }

  .speakers-event-stat {
    grid-template-columns: 1fr;
    gap: 0.6rem;
  }

  .speakers-event-stat-value {
    min-width: 0;
  }

  .speakers-event-grid {
    grid-template-columns: 1fr;
  }
}

.program-page {
  position: relative;
  overflow: hidden;
  border: 1px solid rgb(var(--color-ui-border-rgb) / 0.72);
  border-radius: 2rem;
  background:
    radial-gradient(circle at 50% 10%, rgb(var(--color-brand-primary-rgb) / 0.12), transparent 38%),
    linear-gradient(180deg, rgb(var(--color-surface-rgb) / 0.94), rgb(var(--color-bg-primary-rgb) / 0.98));
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.03),
    0 28px 80px rgb(0 0 0 / 0.45);
}

.program-page::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 0%, rgb(var(--color-brand-hover-rgb) / 0.1), transparent 34%),
    linear-gradient(180deg, transparent, rgb(0 0 0 / 0.24));
  pointer-events: none;
}

.program-page-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.82;
}

.program-page-network-svg {
  width: 100%;
  height: 100%;
  fill: none;
  stroke: rgb(var(--color-brand-primary-rgb) / 0.16);
  stroke-width: 1.1;
}

.program-page-network-svg path:nth-child(-n + 2) {
  fill: rgb(var(--color-brand-primary-rgb) / 0.05);
  stroke: none;
}

.program-page-header,
.program-page-stack {
  position: relative;
  z-index: 1;
}

.program-page-header {
  display: grid;
  gap: 1.25rem;
  padding: clamp(2.5rem, 4vw, 4rem) clamp(1.25rem, 3vw, 3.5rem) 2rem;
  max-width: 56rem;
}

.program-page-kicker {
  color: rgb(var(--color-brand-primary-rgb));
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}

.program-page-title {
  font-family: "Sora", sans-serif;
  font-size: clamp(2.2rem, 5vw, 4.8rem);
  font-weight: 700;
  line-height: 1.02;
  max-width: 14ch;
}

.program-page-intro {
  max-width: 44rem;
  color: rgb(var(--color-text-secondary-rgb) / 0.9);
  font-size: clamp(1rem, 1.4vw, 1.1rem);
  line-height: 1.75;
}

.program-page-stack {
  display: grid;
  gap: 1.5rem;
  padding: 0 clamp(1.25rem, 3vw, 3.5rem) clamp(1.25rem, 3vw, 2.5rem);
}

.program-block {
  position: relative;
  overflow: hidden;
  border: 1px solid rgb(var(--color-ui-border-rgb) / 0.7);
  border-radius: 1.6rem;
  background:
    linear-gradient(180deg, rgb(var(--color-surface-rgb) / 0.88), rgb(var(--color-bg-primary-rgb) / 0.92));
  padding: clamp(1.25rem, 2vw, 1.75rem);
  box-shadow: inset 0 1px 0 rgb(255 255 255 / 0.03);
}

.program-block::before {
  content: "";
  position: absolute;
  inset: auto 10% 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    rgb(var(--color-brand-primary-rgb) / 0.3),
    transparent
  );
  pointer-events: none;
}

.program-block-head {
  display: grid;
  gap: 0.7rem;
  margin-bottom: 1.3rem;
  max-width: 46rem;
}

.program-block-head h2 {
  font-family: "Sora", sans-serif;
  font-size: clamp(1.6rem, 2.3vw, 2.5rem);
  font-weight: 700;
  line-height: 1.08;
}

.program-block-head p:last-child {
  color: rgb(var(--color-text-secondary-rgb) / 0.88);
  line-height: 1.75;
}

.program-days-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.program-day-card,
.program-format-card,
.program-flow-card {
  border: 1px solid rgb(var(--color-ui-border-rgb) / 0.7);
  border-radius: 1.25rem;
  background:
    linear-gradient(180deg, rgb(var(--color-surface-rgb) / 0.82), rgb(var(--color-bg-primary-rgb) / 0.9));
  padding: 1rem 1rem 1.1rem;
}

.program-day-label,
.program-flow-time {
  color: rgb(var(--color-brand-primary-rgb));
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.program-day-card h3,
.program-format-card h3,
.program-flow-card h3 {
  margin-top: 0.55rem;
  font-family: "Sora", sans-serif;
  font-size: 1.02rem;
  font-weight: 600;
  line-height: 1.35;
}

.program-day-card p,
.program-format-card p,
.program-flow-card p {
  margin-top: 0.55rem;
  color: rgb(var(--color-text-secondary-rgb) / 0.84);
  font-size: 0.94rem;
  line-height: 1.6;
}

.program-formats-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.program-format-card {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 0.95rem;
}

.program-format-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 999px;
  border: 1px solid rgb(var(--color-brand-primary-rgb) / 0.35);
  color: rgb(var(--color-brand-primary-rgb));
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
}

.program-track-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
}

.program-track-pill {
  border: 1px solid rgb(var(--color-ui-border-rgb) / 0.75);
  border-radius: 999px;
  background: rgb(var(--color-surface-rgb) / 0.78);
  color: rgb(var(--color-text-secondary-rgb) / 0.92);
  padding: 0.8rem 1rem;
  font-size: 0.94rem;
  line-height: 1.2;
}

.program-flow-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.program-block--cta {
  border-color: rgb(var(--color-brand-primary-rgb) / 0.28);
}

.program-cta-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
}

.program-cta-card h2 {
  font-family: "Sora", sans-serif;
  font-size: clamp(1.5rem, 2.2vw, 2.3rem);
  font-weight: 700;
  line-height: 1.08;
  margin-top: 0.7rem;
}

.program-cta-card p:last-child {
  margin-top: 0.8rem;
  max-width: 42rem;
  color: rgb(var(--color-text-secondary-rgb) / 0.88);
  line-height: 1.75;
}

.program-cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
}

.program-cta-button {
  min-width: 11rem;
  justify-content: center;
}

@media (max-width: 1199px) {
  .program-days-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .program-flow-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 899px) {
  .program-formats-grid {
    grid-template-columns: 1fr;
  }

  .program-cta-card {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 767px) {
  .program-page-header {
    padding-bottom: 1.6rem;
  }

  .program-page-stack {
    gap: 1rem;
  }

  .program-days-grid,
  .program-flow-grid {
    grid-template-columns: 1fr;
  }

  .program-track-cloud {
    gap: 0.65rem;
  }

  .program-track-pill {
    width: 100%;
    text-align: center;
  }
}

.tickets-page {
  position: relative;
  overflow: hidden;
  border: 1px solid rgb(var(--color-ui-border-rgb) / 0.78);
  border-radius: 2rem;
  background:
    radial-gradient(circle at 18% 14%, rgb(var(--color-brand-primary-rgb) / 0.08), transparent 24%),
    radial-gradient(circle at 82% 22%, rgb(var(--color-brand-primary-rgb) / 0.06), transparent 22%),
    linear-gradient(
      180deg,
      rgb(var(--color-bg-primary-rgb) / 0.94) 0%,
      rgb(var(--color-surface-rgb) / 0.84) 100%
    );
  box-shadow:
    inset 0 1px 0 rgb(var(--color-text-primary-rgb) / 0.03),
    0 24px 54px rgb(var(--color-bg-primary-rgb) / 0.32);
}

.tickets-page::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, transparent 0%, rgb(var(--color-brand-primary-rgb) / 0.04) 50%, transparent 100%);
  opacity: 0.7;
  pointer-events: none;
}

.tickets-page-header {
  position: relative;
  z-index: 1;
  padding: 2.5rem 2.5rem 0;
}

.tickets-page-kicker {
  margin: 0 0 0.9rem;
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: rgb(var(--color-brand-primary-rgb));
}

.tickets-page-title {
  margin: 0;
  max-width: 18ch;
  font-family: "Sora", sans-serif;
  font-size: clamp(2.1rem, 4.6vw, 4.2rem);
  font-weight: 700;
  line-height: 0.96;
  letter-spacing: -0.05em;
  color: rgb(var(--color-text-primary-rgb));
  text-wrap: balance;
}

.tickets-page-intro {
  margin: 1rem 0 0;
  max-width: 48rem;
  font-size: 1rem;
  line-height: 1.75;
  color: rgb(var(--color-text-secondary-rgb) / 0.86);
}

.tickets-page-layout {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(320px, 0.6fr);
  gap: 1.5rem;
  padding: 2rem 2.5rem 2.5rem;
}

.tickets-page-widget-shell,
.tickets-page-copy-shell {
  position: relative;
  overflow: hidden;
  border: 1px solid rgb(var(--color-ui-border-rgb) / 0.8);
  border-radius: 1.6rem;
  background:
    linear-gradient(
      180deg,
      rgb(var(--color-bg-primary-rgb) / 0.88) 0%,
      rgb(var(--color-surface-rgb) / 0.78) 100%
    );
  box-shadow:
    inset 0 1px 0 rgb(var(--color-text-primary-rgb) / 0.03),
    0 20px 44px rgb(var(--color-bg-primary-rgb) / 0.28);
}

.tickets-page-widget-shell::before,
.tickets-page-copy-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    radial-gradient(circle at 50% 0%, rgb(var(--color-brand-primary-rgb) / 0.08), transparent 40%);
  pointer-events: none;
}

.tickets-page-widget-shell {
  padding: 1rem;
}

.tickets-page-widget-frame {
  min-height: 640px;
  border-radius: 1.2rem;
  border: 1px solid rgb(var(--color-ui-border-rgb) / 0.76);
  background:
    linear-gradient(
      180deg,
      rgb(var(--color-bg-primary-rgb) / 0.94) 0%,
      rgb(var(--color-surface-rgb) / 0.84) 100%
    );
  box-shadow:
    inset 0 1px 0 rgb(var(--color-text-primary-rgb) / 0.03),
    0 0 26px rgb(var(--color-brand-primary-rgb) / 0.06);
}

.tickets-page-widget-frame .weezevent-widget-integration {
  display: block;
  min-height: 600px;
  border-radius: 1.2rem;
  overflow: hidden;
}

.tickets-page-copy-shell {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  padding: 1.6rem;
}

.tickets-page-copy-kicker {
  margin: 0;
  font-size: 0.74rem;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgb(var(--color-brand-primary-rgb));
}

.tickets-page-copy-title {
  margin: 0.2rem 0 0;
  font-family: "Sora", sans-serif;
  font-size: clamp(1.45rem, 2vw, 1.95rem);
  font-weight: 600;
  line-height: 1.08;
  letter-spacing: -0.04em;
  color: rgb(var(--color-text-primary-rgb));
}

.tickets-page-copy-text {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.7;
  color: rgb(var(--color-text-secondary-rgb) / 0.84);
}

.tickets-page-note {
  margin-top: auto;
  padding-top: 1.25rem;
  border-top: 1px solid rgb(var(--color-ui-border-rgb) / 0.7);
}

.tickets-page-note p {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.65;
  color: rgb(var(--color-text-muted-rgb) / 0.95);
}

@media (max-width: 1024px) {
  .tickets-page-layout {
    grid-template-columns: 1fr;
  }

  .tickets-page-copy-shell {
    min-height: auto;
  }
}

@media (max-width: 640px) {
  .tickets-page-header,
  .tickets-page-layout {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }

  .tickets-page-header {
    padding-top: 1.75rem;
  }

  .tickets-page-layout {
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
  }

  .tickets-page-widget-shell,
  .tickets-page-copy-shell {
    border-radius: 1.25rem;
  }

  .tickets-page-widget-frame {
    min-height: 580px;
  }
}

.manifesto-page {
  position: relative;
  overflow: hidden;
  border: 1px solid rgb(var(--color-ui-border-rgb) / 0.76);
  border-radius: 2rem;
  background:
    radial-gradient(circle at 50% 0%, rgb(var(--color-brand-primary-rgb) / 0.12), transparent 34%),
    radial-gradient(circle at 88% 22%, rgb(var(--color-brand-primary-rgb) / 0.06), transparent 18%),
    linear-gradient(180deg, rgb(var(--color-surface-rgb) / 0.95), rgb(var(--color-bg-primary-rgb) / 0.98));
  box-shadow:
    inset 0 1px 0 rgb(var(--color-text-primary-rgb) / 0.04),
    0 32px 96px rgb(var(--color-bg-primary-rgb) / 0.42);
}

.manifesto-page::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgb(var(--color-text-primary-rgb) / 0.02) 1px, transparent 1px),
    linear-gradient(rgb(var(--color-text-primary-rgb) / 0.02) 1px, transparent 1px);
  background-size: 88px 88px;
  mask-image: radial-gradient(circle at 50% 32%, black 20%, transparent 82%);
  opacity: 0.18;
  pointer-events: none;
}

.manifesto-page::after {
  content: "";
  position: absolute;
  left: 50%;
  top: -1px;
  width: min(38rem, calc(100% - 4rem));
  height: 2px;
  transform: translateX(-50%);
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgb(var(--color-brand-primary-rgb) / 0.1) 20%,
    rgb(var(--color-brand-primary-rgb) / 0.3) 50%,
    rgb(var(--color-brand-primary-rgb) / 0.1) 80%,
    transparent 100%
  );
  box-shadow:
    0 0 20px rgb(var(--color-brand-primary-rgb) / 0.16),
    0 0 46px rgb(var(--color-brand-primary-rgb) / 0.08);
  pointer-events: none;
}

.manifesto-page-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.84;
}

.manifesto-network-svg {
  width: 100%;
  height: 100%;
  fill: none;
  stroke: rgb(var(--color-brand-primary-rgb) / 0.15);
  stroke-width: 1.1;
}

.manifesto-network-svg path:nth-child(4),
.manifesto-network-svg path:nth-child(5) {
  fill: rgb(var(--color-brand-primary-rgb) / 0.04);
  stroke: none;
}

.manifesto-hero,
.manifesto-stack {
  position: relative;
  z-index: 1;
}

.manifesto-hero {
  display: grid;
  gap: 1.75rem;
  padding: clamp(2.4rem, 4vw, 4rem) clamp(1.25rem, 3vw, 3rem) 2rem;
}

.manifesto-hero-copy {
  max-width: 40rem;
}

.manifesto-kicker,
.manifesto-section-label,
.manifesto-panel-kicker {
  margin: 0;
  color: rgb(var(--color-brand-primary-rgb));
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.manifesto-title {
  margin-top: 0.85rem;
  max-width: 8.2ch;
  font-size: clamp(2.7rem, 6vw, 5.2rem);
  line-height: 0.92;
}

.manifesto-subtitle {
  margin: 1.25rem 0 0;
  max-width: 30rem;
  font-family: "Sora", sans-serif;
  font-size: clamp(1.1rem, 1.75vw, 1.45rem);
  font-weight: 600;
  line-height: 1.28;
  letter-spacing: -0.03em;
  color: rgb(var(--color-text-primary-rgb));
}

.manifesto-intro,
.manifesto-section-body,
.manifesto-narrative-copy p,
.manifesto-panel-note {
  color: rgb(var(--color-text-secondary-rgb) / 0.88);
  font-size: 1rem;
  line-height: 1.72;
}

.manifesto-intro {
  max-width: 38rem;
  margin: 1rem 0 0;
}

.manifesto-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
  margin-top: 1.6rem;
}

.manifesto-actions--split {
  margin-top: 0;
}

.manifesto-cta-button {
  min-width: 12rem;
  justify-content: center;
}

.manifesto-hero-panel {
  min-width: 0;
}

.manifesto-hero-panel-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgb(var(--color-ui-border-rgb) / 0.8);
  border-radius: 1.65rem;
  background:
    radial-gradient(circle at 84% 18%, rgb(var(--color-brand-primary-rgb) / 0.12), transparent 20%),
    linear-gradient(180deg, rgb(var(--color-bg-primary-rgb) / 0.88), rgb(var(--color-surface-rgb) / 0.84));
  padding: 1.2rem;
  box-shadow:
    inset 0 1px 0 rgb(var(--color-text-primary-rgb) / 0.03),
    0 18px 42px rgb(var(--color-bg-primary-rgb) / 0.32);
}

.manifesto-hero-panel-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgb(var(--color-brand-primary-rgb) / 0.08), transparent 28%);
  opacity: 0.8;
  pointer-events: none;
}

.manifesto-panel-grid {
  position: relative;
  display: grid;
  gap: 0.8rem;
  margin-top: 1rem;
}

.manifesto-panel-node {
  position: relative;
  overflow: hidden;
  border: 1px solid rgb(var(--color-ui-border-rgb) / 0.74);
  border-radius: 1.15rem;
  background:
    linear-gradient(180deg, rgb(var(--color-surface-rgb) / 0.86), rgb(var(--color-bg-primary-rgb) / 0.92));
  padding: 0.9rem 1rem;
}

.manifesto-panel-node::before {
  content: "";
  position: absolute;
  left: 1rem;
  top: 0;
  width: 3.4rem;
  height: 1px;
  background: linear-gradient(90deg, rgb(var(--color-brand-primary-rgb) / 0.6), transparent);
}

.manifesto-panel-node h3,
.manifesto-statement h3,
.manifesto-principle-card h3,
.manifesto-activity-card h3,
.manifesto-section-head h2,
.manifesto-cta-card h2 {
  margin: 0;
  font-family: "Sora", sans-serif;
  font-weight: 600;
  line-height: 1.14;
  letter-spacing: -0.03em;
}

.manifesto-panel-node h3 {
  font-size: 0.98rem;
}

.manifesto-panel-node p,
.manifesto-statement p,
.manifesto-principle-card p,
.manifesto-activity-card p {
  margin: 0.45rem 0 0;
  color: rgb(var(--color-text-secondary-rgb) / 0.8);
  font-size: 0.92rem;
  line-height: 1.58;
}

.manifesto-panel-note {
  margin: 1rem 0 0;
  padding-top: 1rem;
  border-top: 1px solid rgb(var(--color-ui-border-rgb) / 0.7);
}

.manifesto-stack {
  display: grid;
  gap: 1.2rem;
  padding: 0 clamp(1.25rem, 3vw, 3rem) clamp(1.25rem, 3vw, 2.5rem);
}

.manifesto-block {
  position: relative;
  overflow: hidden;
  border: 1px solid rgb(var(--color-ui-border-rgb) / 0.72);
  border-radius: 1.6rem;
  background:
    linear-gradient(180deg, rgb(var(--color-surface-rgb) / 0.84), rgb(var(--color-bg-primary-rgb) / 0.92));
  padding: clamp(1.25rem, 2vw, 1.7rem);
  box-shadow: inset 0 1px 0 rgb(var(--color-text-primary-rgb) / 0.03);
}

.manifesto-block::before {
  content: "";
  position: absolute;
  inset: auto 10% 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    rgb(var(--color-brand-primary-rgb) / 0.28),
    transparent
  );
  pointer-events: none;
}

.manifesto-section-head {
  display: grid;
  gap: 0.8rem;
  max-width: 46rem;
}

.manifesto-section-head--compact {
  max-width: 40rem;
}

.manifesto-section-head h2,
.manifesto-cta-card h2 {
  font-size: clamp(1.65rem, 2.5vw, 2.55rem);
}

.manifesto-narrative-grid,
.manifesto-ecosystem-layout {
  display: grid;
  gap: 1.25rem;
  margin-top: 1.35rem;
}

.manifesto-narrative-copy {
  display: grid;
  gap: 1rem;
  max-width: 34rem;
}

.manifesto-lead {
  margin: 0;
  font-family: "Sora", sans-serif;
  font-size: clamp(1.15rem, 1.6vw, 1.4rem);
  font-weight: 600;
  line-height: 1.35;
  letter-spacing: -0.03em;
  color: rgb(var(--color-text-primary-rgb));
}

.manifesto-narrative-copy p {
  margin: 0;
}

.manifesto-statements {
  display: grid;
  gap: 0.8rem;
}

.manifesto-statement,
.manifesto-principle-card,
.manifesto-activity-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgb(var(--color-ui-border-rgb) / 0.75);
  border-radius: 1.25rem;
  background:
    linear-gradient(180deg, rgb(var(--color-surface-rgb) / 0.82), rgb(var(--color-bg-primary-rgb) / 0.9));
  padding: 1rem 1rem 1.05rem;
}

.manifesto-statement {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.9rem;
  align-items: start;
}

.manifesto-statement-index,
.manifesto-principle-index,
.manifesto-activity-index {
  color: rgb(var(--color-brand-primary-rgb));
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.manifesto-principles-grid,
.manifesto-activity-grid {
  display: grid;
  gap: 1rem;
  margin-top: 1.35rem;
}

.manifesto-principles-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.manifesto-activity-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.manifesto-track-cloud {
  margin-top: auto;
}

.manifesto-cta-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
}

.manifesto-block--cta {
  border-color: rgb(var(--color-brand-primary-rgb) / 0.28);
}

@media (min-width: 960px) {
  .manifesto-hero {
    grid-template-columns: minmax(0, 1.05fr) minmax(20rem, 0.95fr);
    align-items: start;
  }

  .manifesto-narrative-grid,
  .manifesto-ecosystem-layout {
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    align-items: start;
  }
}

@media (max-width: 1199px) {
  .manifesto-principles-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .manifesto-activity-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 899px) {
  .manifesto-cta-card {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 767px) {
  .manifesto-hero {
    padding-bottom: 1.6rem;
  }

  .manifesto-stack {
    gap: 1rem;
  }

  .manifesto-principles-grid,
  .manifesto-activity-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .manifesto-hero,
  .manifesto-stack {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .manifesto-hero {
    padding-top: 1.9rem;
  }

  .manifesto-stack {
    padding-bottom: 1.1rem;
  }

  .manifesto-page,
  .manifesto-block,
  .manifesto-hero-panel-card {
    border-radius: 1.35rem;
  }

  .manifesto-title {
    max-width: 7.6ch;
    font-size: clamp(2.3rem, 13vw, 3.4rem);
  }

  .manifesto-subtitle {
    font-size: 1rem;
    line-height: 1.4;
  }

  .manifesto-intro,
  .manifesto-section-body,
  .manifesto-narrative-copy p,
  .manifesto-panel-note {
    font-size: 0.94rem;
    line-height: 1.62;
  }

  .manifesto-section-head {
    gap: 0.65rem;
  }

  .manifesto-section-head h2,
  .manifesto-cta-card h2 {
    font-size: 1.45rem;
    line-height: 1.14;
  }

  .manifesto-panel-grid,
  .manifesto-statements,
  .manifesto-principles-grid,
  .manifesto-activity-grid {
    gap: 0.8rem;
  }

  .manifesto-statement {
    grid-template-columns: 1fr;
    gap: 0.55rem;
  }

  .manifesto-cta-button {
    width: 100%;
  }
}
