/*
 * TiAW — Tijuana Art Week
 * css/tiaw-header.css
 *
 * Organized as:
 * 1. Tokens / Base
 * 2. Shared Layout
 * 3. Shared Components
 * 4. Header / Navigation
 * 5. Hero / Slider
 * 6. Intro / Ticker
 * 7. Program
 * 8. Participants
 * 9. Newsletter
 * 10. Footer
 * 11. Responsive
 */

/* =============================================================
   1. TOKENS / BASE
   ============================================================= */
:root {
  /* Colors */
  --color-accent: #c8e04a;
  --color-dark: #1a1a1a;
  --color-orange: #f15a29;
  --color-orange-bright: #ff612c;
  --color-white: #ffffff;
  --color-cream: #f3ebe7;
  --color-text: #000000;

  --color-text-soft: rgba(0, 0, 0, 0.78);
  --color-text-muted: rgba(0, 0, 0, 0.72);
  --color-text-faint: rgba(0, 0, 0, 0.62);
  --color-text-light: rgba(0, 0, 0, 0.55);

  --color-border: rgba(0, 0, 0, 0.1);
  --color-border-soft: rgba(0, 0, 0, 0.18);
  --color-surface-soft: rgba(255, 255, 255, 0.55);
  --color-surface-soft-strong: rgba(255, 255, 255, 0.85);

  /* Layout */
  --container-main: 90vw;
  --container-wide: 85vw;
  --container-max-wide: 1650px;
  --nav-height: 64px;

  /* Radius */
  --radius-sm: 8px;
  --radius-md: 10px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-2xl: 24px;
  --radius-pill: 999px;

  /* Shadows */
  --shadow-soft: 0 10px 24px rgba(0, 0, 0, 0.06);
  --shadow-float: 0 8px 18px rgba(0, 0, 0, 0.14);

  /* Motion */
  --ease-standard: cubic-bezier(0.4, 0, 0.2, 1);
  --transition-fast: 0.2s ease;
  --transition-base: 0.3s var(--ease-standard);
  --transition-slide: 0.6s var(--ease-standard);

  /* Reusable spacing */
  --section-space: 90px;
  --section-space-lg: 120px;
  --section-space-sm: 64px;
}

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

body {
  margin: 0;
  min-height: 100%;
  overflow-x: hidden;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  color: var(--color-white);
  background: linear-gradient(-45deg, #e3feb1, #e4e3c5, #ffffff, #dba696);
  background-size: 400% 400%;
  background-attachment: scroll;
  animation: gradient 15s ease infinite;
}

@keyframes gradient {
  0% {
    background-position: 0% 50%;
  }

  50% {
    background-position: 100% 50%;
  }

  100% {
    background-position: 0% 50%;
  }
}

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

a {
  color: inherit;
}

/* =============================================================
   2. SHARED LAYOUT
   ============================================================= */
.tiaw-container,
.tiaw-hero__inner,
.tiaw-program__inner,
.tiaw-participants-detail__inner,
.tiaw-newsletter__inner {
  width: var(--container-main);
  margin: 0 auto;
}

.tiaw-intro__inner {
  width: var(--container-wide);
  max-width: var(--container-max-wide);
  margin: 0 auto;
}

.tiaw-section {
  position: relative;
  width: 100%;
}

.tiaw-section--pad-sm {
  padding: var(--section-space-sm) 0;
}

.tiaw-section--pad-md {
  padding: var(--section-space) 0;
}

.tiaw-section--pad-lg {
  padding: var(--section-space-lg) 0;
}

/* =============================================================
   3. SHARED COMPONENTS
   ============================================================= */
.tiaw-btn-pill,
.tiaw-intro__btn,
.tiaw-participant-card__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-pill);
  text-decoration: none;
  transition:
    color var(--transition-base),
    border-color var(--transition-base),
    background-color var(--transition-base),
    opacity var(--transition-base),
    transform var(--transition-fast);
}

.tiaw-intro__btn,
.tiaw-participant-card__link {
  border: 1px solid var(--color-text);
  color: var(--color-text);
  background: transparent;
}

.tiaw-intro__btn:hover,
.tiaw-participant-card__link:hover {
  color: var(--color-orange-bright);
  border-color: var(--color-orange-bright);
}

.tiaw-text-link {
  text-decoration: none;
  transition: color var(--transition-base), border-color var(--transition-base);
}

.tiaw-text-link:hover {
  color: var(--color-orange-bright);
  border-color: var(--color-orange-bright);
}

.tiaw-visually-muted {
  color: var(--color-text-muted);
}

.tiaw-visually-faint {
  color: var(--color-text-faint);
}

/* =============================================================
   4. HEADER / NAVIGATION
   ============================================================= */
.tiaw-site-header {
  position: absolute;
  top: 42px;
  left: 0;
  width: 100%;
  z-index: 120;
  pointer-events: none;
}

.tiaw-nav-shell {
  display: flex;
  justify-content: flex-end;
  width: var(--container-main);
  margin: 0 auto;
  pointer-events: none;
}

.tiaw-nav {
  position: relative;
  width: min(70vw, 528px);
  aspect-ratio: 504 / 72;
  pointer-events: auto;
}

.tiaw-nav__shape {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.tiaw-nav__shape svg {
  width: 100%;
  height: 100%;
}

.tiaw-nav__inner {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  height: 100%;
  padding: 22px 32px 0 48px;
}

.tiaw-nav__menu {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.tiaw-nav__menu > li {
  position: relative;
}

.tiaw-nav__menu > li > a {
  display: block;
  padding: 8px 10px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  color: #5d5753;
  transition: color var(--transition-base);
}

.tiaw-nav__menu > li > a:hover,
.tiaw-nav__menu > li.current-menu-item > a {
  color: var(--color-orange-bright);
}

.tiaw-nav__menu > li.menu-contacto > a {
  padding: 7px 14px;
  border-radius: var(--radius-pill);
  background: var(--color-orange-bright);
  color: var(--color-white);
}

.tiaw-nav__menu > li.menu-contacto > a:hover {
  opacity: 0.9;
  color: var(--color-white);
}

.tiaw-nav__lang {
  display: inline-block;
  padding-top: 8px;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--color-dark);
  transition: color var(--transition-base);
}

.tiaw-nav__lang:hover {
  color: var(--color-orange-bright);
}

/* Submenu */
.tiaw-nav__submenu {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  z-index: 40;
  min-width: 150px;
  margin: 0;
  padding: 10px 0 12px;
  list-style: none;
  background: #efe0d8;
  border-radius: 0 0 var(--radius-xl) var(--radius-xl);
  box-shadow: var(--shadow-soft);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition:
    opacity var(--transition-fast),
    transform var(--transition-fast),
    visibility 0s linear 0.2s;
}

.tiaw-nav__menu > li:hover > .tiaw-nav__submenu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition:
    opacity var(--transition-fast),
    transform var(--transition-fast),
    visibility 0s linear 0s;
}

.tiaw-nav__submenu li a {
  display: block;
  padding: 9px 16px;
  font-size: 13px;
  line-height: 1.25;
  text-decoration: none;
  color: #5d5753;
  transition: color var(--transition-fast), background var(--transition-fast);
}

.tiaw-nav__submenu li a:hover {
  color: var(--color-orange-bright);
}

/* =============================================================
   5. HERO / SLIDER
   ============================================================= */
.tiaw-hero {
  position: relative;
  padding-top: 22px;
  background: linear-gradient(to bottom, #ffffff 0%, rgba(255, 255, 255, 0) 100%);
}

.tiaw-slider-frame {
  position: relative;
  z-index: 1;
  width: 100%;
  aspect-ratio: 16 / 7.6;
  overflow: hidden;
  border-radius: var(--radius-2xl);
}

.tiaw-slider {
  display: flex;
  width: 100%;
  height: 100%;
  will-change: transform;
  transition: transform var(--transition-slide);
}

.tiaw-slide {
  position: relative;
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.tiaw-slide__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  animation: tiawKenBurns 6s ease-out forwards;
}

@keyframes tiawKenBurns {
  from {
    transform: scale(1.05);
  }

  to {
    transform: scale(1);
  }
}

.tiaw-slide__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.1) 0%,
    rgba(0, 0, 0, 0.05) 45%,
    rgba(0, 0, 0, 0.38) 100%
  );
}

.tiaw-slide__content {
  position: absolute;
  right: 34px;
  bottom: 62px;
  z-index: 5;
  text-align: right;
}

.tiaw-slide__title {
  margin: 0 0 4px;
  font-size: clamp(28px, 3.2vw, 56px);
  font-weight: 900;
  line-height: 0.95;
  text-transform: uppercase;
  color: var(--color-orange);
}

.tiaw-slide__excerpt {
  margin: 0;
  font-size: clamp(18px, 1.8vw, 34px);
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  color: var(--color-white);
}

/* Slider controls */
.tiaw-slider__controls {
  position: absolute;
  right: 20px;
  bottom: 18px;
  z-index: 15;
  display: flex;
  gap: 8px;
}

.tiaw-slider__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.92);
  color: var(--color-dark);
  cursor: pointer;
  box-shadow: var(--shadow-float);
  transition: transform var(--transition-fast), opacity var(--transition-fast);
}

.tiaw-slider__btn:hover {
  opacity: 0.92;
  transform: translateY(-1px);
}

.tiaw-slider__btn svg {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: var(--color-dark);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.tiaw-slider__dots {
  position: absolute;
  right: 24px;
  bottom: 8px;
  z-index: 15;
  display: flex;
  gap: 8px;
}

.tiaw-slider__dot {
  width: 7px;
  height: 7px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.45);
  cursor: pointer;
  transition: transform var(--transition-fast), background var(--transition-fast);
}

.tiaw-slider__dot.active {
  background: var(--color-white);
  transform: scale(1.35);
}

/* Decorative green shape */
.tiaw-green-shape {
  position: absolute;
  left: -12px;
  bottom: -24px;
  z-index: 8;
  width: min(65vw, 1280px);
  aspect-ratio: 916 / 494;
  pointer-events: none;
}

.tiaw-green-shape svg {
  width: 100%;
  height: 100%;
}

.tiaw-green-shape__text {
  position: absolute;
  left: 6vw;
  bottom: 4vh;
  display: flex;
  flex-direction: column;
  gap: 2px;
  color: #111111;
}

.tiaw-green-shape__logo {
  font-size: clamp(28px, 3vw, 44px);
  font-weight: 900;
  line-height: 0.95;
  letter-spacing: -0.04em;
}

.tiaw-green-shape__year {
  font-size: clamp(12px, 1vw, 16px);
  font-weight: 600;
  line-height: 1;
}

/* =============================================================
   6. INTRO / TICKER
   ============================================================= */
.tiaw-ticker {
  position: relative;
  width: 100vw;
  padding: 64px 0;
  overflow: hidden;
}

.tiaw-ticker__track {
  display: flex;
  width: max-content;
  animation: tiawTicker 28s linear infinite;
}

.tiaw-ticker__content {
  display: flex;
  align-items: center;
  gap: 18px;
  padding-right: 18px;
  white-space: nowrap;
  font-size: 24px;
  font-weight: 300;
  font-style: italic;
  letter-spacing: 0.04em;
  color: rgba(0, 0, 0, 0.6);
}

.tiaw-ticker__content .bullet {
  font-weight: 600;
  color: var(--color-orange-bright);
}

@keyframes tiawTicker {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-33.333%);
  }
}

.tiaw-intro {
  position: relative;
  width: 100%;
  padding: 64px 0 90px;
}

.tiaw-intro__text {
  max-width: 90vw;
  font-size: clamp(28px, 2.3vw, 52px);
  line-height: 1.08;
  font-weight: 400;
  letter-spacing: 0.0125em;
  color: var(--color-text);
}

.tiaw-intro__text .tiaw-word {
  display: inline-block;
  color: var(--color-text);
  will-change: color;
  transition: color 0.28s ease;
}

.tiaw-intro__text .tiaw-word.is-active {
  color: var(--color-orange-bright);
}

.tiaw-intro__btn {
  margin-top: 34px;
  padding: 12px 22px;
  font-size: 14px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.02em;
}

.tiaw-intro__btn:hover {
  background: var(--color-text);
  color: var(--color-white);
  border-color: var(--color-text);
}

/* =============================================================
   7. PROGRAM
   ============================================================= */
.tiaw-program {
  position: relative;
  width: 100%;
  padding: 90px 0;
}

.tiaw-program__header {
  position: sticky;
  top: 32px;
  z-index: 5;
  margin-bottom: 28px;
  pointer-events: none;
}

.tiaw-program__title {
  margin: 0;
  font-size: clamp(36px, 4vw, 64px);
  line-height: 0.95;
  font-weight: 500;
  letter-spacing: -0.04em;
  color: var(--color-text);
}

.tiaw-program-slider-wrap {
  position: relative;
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 18px;
  align-items: start;
}

.tiaw-program-slider-nav {
  position: sticky;
  top: 140px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding-top: 12px;
}

.tiaw-program-slider__dot {
  width: 10px;
  height: 10px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.18);
  cursor: pointer;
  transition: transform 0.25s ease, background 0.25s ease;
}

.tiaw-program-slider__dot:hover {
  background: rgba(0, 0, 0, 0.38);
  transform: scale(1.2);
}

.tiaw-program-slider__dot.active {
  background: var(--color-orange-bright);
  transform: scale(1.35);
}

.tiaw-program-slider-viewport {
  position: relative;
  overflow: hidden;
  transition: height 0.5s ease;
}

.tiaw-program-slider {
  display: flex;
  flex-direction: column;
  transition: transform var(--transition-slide);
}

.tiaw-program-slide {
  display: grid;
  grid-template-columns: 25% 75%;
  flex: 0 0 auto;
  padding: 20px 0;
  opacity: 0.4;
  transition: opacity 0.4s ease;
}

.tiaw-program-slide.is-active {
  opacity: 1;
}

.tiaw-program-slide__day {
  padding-right: 26px;
}

.tiaw-program-slide__day span {
  display: inline-block;
  font-size: clamp(22px, 2vw, 30px);
  line-height: 1;
  font-weight: 400;
  letter-spacing: -0.03em;
  color: var(--color-text);
}

.tiaw-program-slide__activities {
  display: flex;
  flex-direction: column;
}

.tiaw-program-activity {
  display: grid;
  grid-template-columns: 65% 35%;
  gap: 24px;
  min-height: 110px;
  padding: 18px 0 20px;
  border-bottom: 1px solid var(--color-border);
}

.tiaw-program-activity:last-child {
  border-bottom: none;
}

.tiaw-program-activity__main {
  display: grid;
  grid-template-rows: auto auto 1fr;
  align-content: start;
  gap: 6px;
}

.tiaw-program-activity__time {
  margin: 0;
  font-size: 14px;
  line-height: 1.2;
  font-weight: 400;
  color: rgba(0, 0, 0, 0.7);
}

.tiaw-program-activity__title {
  margin: 0;
  font-size: clamp(18px, 1.5vw, 24px);
  line-height: 1.05;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--color-text);
}

.tiaw-program-activity__description {
  max-width: 92%;
  margin: 0;
  font-size: 14px;
  line-height: 1.35;
  font-weight: 400;
  color: var(--color-text-muted);
}

.tiaw-program-activity__meta {
  display: grid;
  grid-template-rows: auto auto;
  align-content: start;
  justify-items: start;
  gap: 8px;
}

.tiaw-program-activity__venue,
.tiaw-program-activity__location {
  margin: 0;
  font-size: 14px;
  line-height: 1.3;
  font-weight: 400;
}

.tiaw-program-activity__venue {
  font-weight: 500;
  color: var(--color-text);
}

.tiaw-program-activity__location {
  color: var(--color-text-faint);
}

.tiaw-program-activity__description:empty,
.tiaw-program-activity__venue:empty,
.tiaw-program-activity__location:empty {
  display: none;
}

/* =============================================================
   8. PARTICIPANTS
   ============================================================= */
/* List */
.tiaw-participants-list {
  position: relative;
  width: 100%;
  padding: 120px 0;
  overflow: hidden;
}

.tiaw-participants-list__inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 25% 50%;
  gap: 0;
  width: var(--container-main);
  margin: 0 auto;
}

.tiaw-participants-list__shape {
  position: absolute;
  top: 0;
  right: -1vw;
  z-index: 1;
  width: min(65vw, 1280px);
  aspect-ratio: 916 / 494;
  transform: scaleX(-1) scaleY(-1);
  pointer-events: none;
}

.tiaw-participants-list__shape svg {
  width: 100%;
  height: 100%;
}

.tiaw-participants-list__col-meta {
  padding-top: 18px;
  padding-right: 30px;
}

.tiaw-participants-list__legend {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.tiaw-participants-list__legend p {
  margin: 0;
  font-size: 14px;
  line-height: 1.3;
  font-weight: 400;
  color: var(--color-text-muted);
}

.tiaw-participants-list__col-content {
  position: relative;
}

.tiaw-participants-list__rows {
  display: flex;
  flex-direction: column;
}

.tiaw-participants-list__item {
  display: grid;
  grid-template-columns: 60% 40%;
  align-items: center;
  padding: 16px 0;
}

.tiaw-participants-list__name {
  display: inline-block;
  padding-left: 24px;
  font-size: clamp(24px, 2.2vw, 38px);
  line-height: 1;
  font-weight: 400;
  letter-spacing: -0.03em;
  text-decoration: none;
  color: var(--color-text);
  transition: color 0.35s var(--ease-standard);
}

.tiaw-participants-list__type {
  font-size: 24px;
  text-align: center;
  color: rgba(0, 0, 0, 0.7);
  transition: color 0.35s var(--ease-standard);
}

.tiaw-participants-list__item:hover .tiaw-participants-list__name,
.tiaw-participants-list__item:hover .tiaw-participants-list__type {
  color: var(--color-orange-bright);
}

/* Detail */
.tiaw-participants-detail {
  position: relative;
  width: 100%;
  padding: 120px 0 0;
}

.tiaw-participants-detail__viewport {
  position: relative;
  overflow: hidden;
  transition: height 0.5s var(--ease-standard);
}

.tiaw-participants-detail__track {
  display: flex;
  flex-direction: column;
  will-change: transform;
  transition: transform var(--transition-slide);
}

.tiaw-participant-card {
  display: grid;
  grid-template-columns: 30% 28% 42%;
  align-items: start;
  gap: 0;
  padding: 0;
  border-radius: 24px 24px 24px 0;
  background-color: #c4ff5f;
  opacity: 0.3;
  transition: opacity 0.4s var(--ease-standard);
}

.tiaw-participant-card.is-active {
  opacity: 1;
}

.tiaw-participant-card__image {
  position: relative;
  overflow: hidden;
  height:100%;
  border-radius: 24px 0 0 0;
  background: transparent;
}

.tiaw-participant-card__image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.tiaw-participant-card__content {
  padding: 72px 24px 72px 48px;
}

.tiaw-participant-card__name {
  margin: 0 0 24px;
  font-size: clamp(30px, 3vw, 52px);
  line-height: 0.96;
  font-weight: 400;
  letter-spacing: -0.04em;
  color: var(--color-text);
}

.tiaw-participant-card__bio {
  max-width: 92%;
  padding: 24px 0;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 400;
  color: var(--color-text-soft);
}

.tiaw-participant-card__bio p {
  margin: 0 0 14px;
}

.tiaw-participant-card__bio p:last-child {
  margin-bottom: 0;
}

.tiaw-participant-card__meta-title {
  margin: 0 0 12px;
  font-size: 14px;
  line-height: 1;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.58);
}

.tiaw-participant-card__address,
.tiaw-participant-card__location-name {
  color: var(--color-text);
}

.tiaw-participant-card__address {
  margin: 0 0 12px;
  font-size: 15px;
  line-height: 1.45;
}

.tiaw-participant-card__location-name {
  margin: 0 0 6px;
  font-size: 15px;
  line-height: 1.35;
  font-weight: 500;
}

.tiaw-participant-card__link {
  padding: 11px 18px;
  font-size: 14px;
  line-height: 1;
  font-weight: 400;
}

.tiaw-participant-card__link:hover {
  background-color: rgba(255, 97, 44, 0.04);
}

.tiaw-participant-card__map {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1.1;
  overflow: hidden;
  border-radius: 0 24px 24px 0;
  background: rgba(0, 0, 0, 0.06);
}

.tiaw-participant-card__map iframe {
  width: 100%;
  height: 100%;
  border: 0;
}

.tiaw-participant-card__map-link-wrap {
  margin: 0;
}

.tiaw-participant-card__map-link {
  font-size: 14px;
  line-height: 1.3;
  text-decoration: none;
  color: var(--color-text);
  border-bottom: 1px solid rgba(0, 0, 0, 0.22);
  transition: color var(--transition-base), border-color var(--transition-base);
}

.tiaw-participant-card__map-link:hover {
  color: var(--color-orange-bright);
  border-color: var(--color-orange-bright);
}

/* =============================================================
   9. NEWSLETTER
   ============================================================= */
.tiaw-newsletter {
  position: relative;
  width: 100%;
  padding: 0;
  margin-bottom: -150px;
  overflow: hidden;
}

.tiaw-newsletter__inner {
  display: grid;
  grid-template-columns: 30% 25% 45%;
}

.tiaw-newsletter__media {
  position: relative;
  width: 100%;
}

.tiaw-newsletter__media svg {
  width: 100%;
  height: auto;
}

.tiaw-newsletter__formcol {
  padding-top: 24px;
}

.tiaw-newsletter__form form {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 6px;
}

.tiaw-newsletter__eyebrow {
  margin: 0 16px 12px;
  font-size: 14px;
  line-height: 1;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-text-light);
}

.tiaw-newsletter__title {
  margin: 0 0 22px;
  font-size: clamp(28px, 2.5vw, 42px);
  line-height: 0.98;
  font-weight: 400;
  letter-spacing: -0.04em;
  color: var(--color-text);
}

.tiaw-newsletter__form p {
  margin: 0;
}

.tiaw-newsletter__input-wrap {
  position: relative;
  width: 100%;
}

.tiaw-newsletter__input-wrap input[type="email"] {
  width: 98%;
  height: 56px;
  padding: 0 0 0 2%;
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  outline: none;
  background: var(--color-surface-soft);
  font-size: 15px;
  color: var(--color-text);
  transition:
    border-color var(--transition-base),
    background-color var(--transition-base);
}

.tiaw-newsletter__input-wrap input[type="email"]:focus {
  border-color: var(--color-orange-bright);
  background: var(--color-surface-soft-strong);
}

.tiaw-newsletter__input-wrap button {
  position: absolute;
  top: 50%;
  right: 6px;
  height: 44px;
  padding: 0 18px;
  border: 0;
  border-radius: var(--radius-md);
  background: var(--color-text);
  color: var(--color-white);
  font-size: 13px;
  line-height: 1;
  cursor: pointer;
  transform: translateY(-50%);
  transition:
    background-color var(--transition-base),
    color var(--transition-base);
}

.tiaw-newsletter__input-wrap button:hover {
  background: var(--color-orange-bright);
}

/* =============================================================
   10. FOOTER
   ============================================================= */
.tiaw-footer {
  position: relative;
  width: 100%;
  padding: 48px 0 24px;
  margin-bottom: 24px;
  overflow: hidden;
}

.tiaw-footer__inner {
  position: relative;
  display: grid;
  grid-template-columns: 60% 40%;
  align-items: stretch;
  width: 100vw;
  margin: 0 auto;
}

.tiaw-footer__left {
  padding-right: 40px;
  padding-left: 10vw;
}

.tiaw-footer__logo {
  margin: 0 0 20px;
  font-size: clamp(64px, 8vw, 120px);
  line-height: 0.9;
  font-weight: 600;
  color: #120012;
}

.tiaw-footer__eyebrow {
  margin: 0 0 10px;
  font-size: 14px;
  color: rgba(0, 0, 0, 0.7);
}

.tiaw-footer__desc {
  max-width: 560px;
  margin: 0 0 30px;
  font-size: 16px;
  line-height: 1.5;
  color: rgba(0, 0, 0, 0.7);
}

.tiaw-footer__cta {
  display: inline-block;
  padding: 12px 20px;
  border-radius: var(--radius-sm);
  background: var(--color-orange-bright);
  color: var(--color-white);
  text-decoration: none;
  font-size: 14px;
  transition: opacity var(--transition-base);
}

.tiaw-footer__cta:hover {
  opacity: 0.85;
}

.tiaw-footer__right {
  position: relative;
  min-height: 420px;
}

.tiaw-footer__shape {
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 1;
  width: min(90vw, 1980px);
  aspect-ratio: 1308 / 488;
  pointer-events: none;
}

.tiaw-footer__shape svg {
  width: 100%;
  height: 100%;
}

.tiaw-footer__right-content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
  padding: 0 40px 50px 200px;
  color: var(--color-white);
}

.tiaw-footer__contact,
.tiaw-footer__social {
  margin-bottom: 38px;
}

.tiaw-footer__label {
  margin: 0 0 6px;
  font-size: 12px;
  opacity: 0.85;
  color: var(--color-white);
}

.tiaw-footer__right-content a {
  font-size: clamp(18px, 2vw, 22px);
  font-style: italic;
  text-decoration: none;
  color: var(--color-white);
  transition: opacity var(--transition-base);
}

.tiaw-footer__right-content a:hover {
  opacity: 0.8;
}

.tiaw-footer__social-links {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}

.tiaw-footer__bottom {
  position: relative;
  z-index: 5;
  margin: 48px auto 0;
  padding: 24px;
  font-size: 14px;
  color: var(--color-white);
}

/* =============================================================
   11. RESPONSIVE
   ============================================================= */
@media (max-width: 1024px) {
  .tiaw-program-slider-wrap {
    grid-template-columns: 52px 1fr;
    gap: 14px;
  }

  .tiaw-program-slider-viewport {
    min-height: 680px;
  }

  .tiaw-program-slide {
    grid-template-columns: 28% 72%;
    flex-basis: 680px;
    min-height: 680px;
  }

  .tiaw-program-activity {
    grid-template-columns: 60% 40%;
    gap: 18px;
  }

  .tiaw-participant-card {
    grid-template-columns: 32% 40% 28%;
    gap: 22px;
  }

  .tiaw-participant-card__bio {
    max-width: 100%;
  }
}

@media (max-width: 768px) {
  /* Header */
  .tiaw-site-header {
    top: 14px;
  }

  .tiaw-nav-shell {
    width: 92vw;
  }

  .tiaw-nav {
    width: min(92vw, 528px);
    padding: 0 20px;
  }

  .tiaw-nav__inner {
    padding: 16px 18px 0 20px;
  }

  .tiaw-nav__menu {
    display: none;
  }

  .tiaw-nav__lang {
    margin-left: auto;
    padding-top: 6px;
  }

  /* Hero */
  .tiaw-slide__content {
    right: 20px;
    bottom: 80px;
  }

  .tiaw-slider__controls {
    right: 20px;
    bottom: 20px;
  }

  .tiaw-slider__dots {
    bottom: 28px;
  }

  /* Program */
  .tiaw-program {
    padding: 90px 0 100px;
  }

  .tiaw-program__header {
    position: relative;
    top: auto;
    margin-bottom: 20px;
  }

  .tiaw-program-slider-wrap {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .tiaw-program-slider-nav {
    position: relative;
    top: auto;
    order: 2;
    flex-direction: row;
    justify-content: flex-start;
    gap: 12px;
    padding-top: 0;
  }

  .tiaw-program-slider-viewport {
    order: 1;
    min-height: auto;
  }

  .tiaw-program-slider {
    gap: 28px;
    transform: none !important;
  }

  .tiaw-program-slide {
    grid-template-columns: 1fr;
    flex: none;
    min-height: auto;
    gap: 18px;
    padding-top: 16px;
  }

  .tiaw-program-slide__day {
    padding-right: 0;
  }

  .tiaw-program-activity {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 16px 0 18px;
  }

  .tiaw-program-activity__description {
    max-width: 100%;
  }

  /* Participants list */
  .tiaw-participants-list {
    padding: 90px 0 80px;
  }

  .tiaw-participants-list__inner {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .tiaw-participants-list__shape {
    top: 10px;
    right: -4vw;
    width: min(52vw, 280px);
  }

  .tiaw-participants-list__col-meta {
    padding-top: 0;
    padding-right: 0;
  }

  .tiaw-participants-list__item {
    grid-template-columns: 75% 25%;
    min-height: 58px;
    padding: 14px 0;
  }

  .tiaw-participants-list__name {
    font-size: clamp(20px, 6vw, 30px);
  }

  .tiaw-participants-list__type {
    font-size: 16px;
  }

  /* Participants detail */
  .tiaw-participants-detail {
    padding: 10px 0 100px;
  }

  .tiaw-participant-card {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 28px 0 34px;
  }

  .tiaw-participant-card__image {
    max-width: 100%;
    aspect-ratio: 4 / 4.8;
  }

  .tiaw-participant-card__name {
    font-size: clamp(28px, 8vw, 42px);
  }

  .tiaw-participant-card__bio {
    font-size: 15px;
  }

  .tiaw-participant-card__map {
    border-radius: 0 0 24px 24px;
  }

  /* Newsletter */
  .tiaw-newsletter {
    padding: 90px 0 100px;
  }

  .tiaw-newsletter__inner {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .tiaw-newsletter__title {
    font-size: clamp(26px, 8vw, 38px);
  }

  /* Footer */
  .tiaw-footer {
    padding: 80px 0 0;
  }

  .tiaw-footer__inner {
    grid-template-columns: 1fr;
    gap: 30px;
  }

  .tiaw-footer__left {
    padding-right: 0;
  }

  .tiaw-footer__right {
    min-height: 320px;
  }

  .tiaw-footer__right-content {
    padding: 70px 24px 32px 70px;
  }

  .tiaw-footer__bottom {
    margin-top: 24px;
  }
}