/**
 * The Salt Rim — Events/Themes Template Stylesheet
 *
 * Shared styles for all 7 theme landing pages under /events/.
 * Each page sets a body class (e.g., body.theme-birthday) which
 * scopes a per-theme --theme-accent color override.
 *
 * Depends on: tokens.css, landing.css
 */

/* ============================================================
   THEME ACCENT VARIABLES (one stylesheet, 7 theme variants)
   ============================================================ */

/* Default fallback: generic gold accent on cream */
body[class*="theme-"] {
  --theme-accent: #C9A84C;
  --theme-accent-soft: rgba(201, 168, 76, 0.15);
  --theme-accent-2: #131E35;
  --theme-hero-gradient: radial-gradient(ellipse at 30% 20%, rgba(201, 168, 76, 0.14) 0%, transparent 55%),
                         linear-gradient(180deg, #F2EDE4 0%, #EDE6D8 100%);
}

body.theme-birthday {
  --theme-accent: #C28A80;              /* dusty rose — readable on cream */
  --theme-accent-soft: rgba(194, 138, 128, 0.14);
  --theme-accent-2: #C9A84C;
  --theme-hero-gradient: radial-gradient(ellipse at 30% 20%, rgba(194, 138, 128, 0.14) 0%, transparent 55%),
                         radial-gradient(ellipse at 75% 85%, rgba(201, 168, 76, 0.10) 0%, transparent 50%),
                         linear-gradient(180deg, #F2EDE4 0%, #EDE6D8 100%);
}

body.theme-corporate {
  --theme-accent: #1E3A5F;              /* deep navy */
  --theme-accent-soft: rgba(30, 58, 95, 0.12);
  --theme-accent-2: #C9A84C;
  --theme-hero-gradient: radial-gradient(ellipse at 30% 20%, rgba(30, 58, 95, 0.08) 0%, transparent 55%),
                         radial-gradient(ellipse at 75% 85%, rgba(201, 168, 76, 0.08) 0%, transparent 50%),
                         linear-gradient(180deg, #F2EDE4 0%, #E9E4D7 100%);
}

body.theme-engagement {
  --theme-accent: #B87A8B;              /* muted rose — readable on cream */
  --theme-accent-soft: rgba(184, 122, 139, 0.14);
  --theme-accent-2: #C9A84C;
  --theme-hero-gradient: radial-gradient(ellipse at 30% 20%, rgba(184, 122, 139, 0.14) 0%, transparent 55%),
                         radial-gradient(ellipse at 75% 85%, rgba(201, 168, 76, 0.10) 0%, transparent 50%),
                         linear-gradient(180deg, #F2EDE4 0%, #EFE5DD 100%);
}

body.theme-quinces {
  --theme-accent: #6B3FA0;              /* royal purple */
  --theme-accent-soft: rgba(107, 63, 160, 0.14);
  --theme-accent-2: #C9A84C;
  --theme-hero-gradient: radial-gradient(ellipse at 30% 20%, rgba(107, 63, 160, 0.12) 0%, transparent 55%),
                         radial-gradient(ellipse at 75% 85%, rgba(201, 168, 76, 0.10) 0%, transparent 50%),
                         linear-gradient(180deg, #F2EDE4 0%, #ECE4E0 100%);
}

body.theme-holiday {
  --theme-accent: #1F5A3A;              /* deep green */
  --theme-accent-soft: rgba(31, 90, 58, 0.14);
  --theme-accent-2: #C9A84C;
  --theme-hero-gradient: radial-gradient(ellipse at 30% 20%, rgba(31, 90, 58, 0.12) 0%, transparent 55%),
                         radial-gradient(ellipse at 75% 85%, rgba(201, 168, 76, 0.12) 0%, transparent 50%),
                         linear-gradient(180deg, #F2EDE4 0%, #E7ECE3 100%);
}

body.theme-housewarming {
  --theme-accent: #B5532A;              /* terracotta */
  --theme-accent-soft: rgba(181, 83, 42, 0.14);
  --theme-accent-2: #131E35;
  --theme-hero-gradient: radial-gradient(ellipse at 30% 20%, rgba(181, 83, 42, 0.14) 0%, transparent 55%),
                         radial-gradient(ellipse at 75% 85%, rgba(201, 168, 76, 0.08) 0%, transparent 50%),
                         linear-gradient(180deg, #F2EDE4 0%, #EDE2D3 100%);
}

body.theme-custom {
  --theme-accent: #A8893A;              /* gold on cream — readable */
  --theme-accent-soft: rgba(201, 168, 76, 0.15);
  --theme-accent-2: #131E35;
  --theme-hero-gradient: radial-gradient(ellipse at 30% 20%, rgba(201, 168, 76, 0.14) 0%, transparent 55%),
                         linear-gradient(180deg, #F2EDE4 0%, #EDE6D8 100%);
}

/* ============================================================
   THEME HERO
   ============================================================ */

.theme-hero {
  position: relative;
  padding: calc(var(--space-24) + 80px) 0 var(--space-20);
  background: var(--theme-hero-gradient);
  color: var(--navy);
  overflow: hidden;
  isolation: isolate;
}

.theme-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 85% 15%, rgba(19, 30, 53, 0.03) 0%, transparent 35%),
    radial-gradient(circle at 15% 80%, var(--theme-accent-soft) 0%, transparent 40%);
  pointer-events: none;
  z-index: -1;
}

.theme-hero-inner {
  max-width: 860px;
  margin: 0 auto;
  text-align: center;
}

.theme-hero-eyebrow {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: var(--font-size-xs);
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--theme-accent);
  margin-bottom: var(--space-6);
  padding: var(--space-2) var(--space-4);
  border: 1px solid var(--theme-accent);
  border-radius: var(--radius-full);
  background: var(--theme-accent-soft);
}

.theme-hero-headline {
  font-family: var(--font-serif);
  font-size: var(--fluid-5xl);
  font-weight: 700;
  line-height: 1.05;
  color: var(--navy);
  margin: 0 0 var(--space-6);
  letter-spacing: -0.02em;
}

/* Thin left-accent rule on the headline when used in media layout */
.theme-hero-inner.has-media .theme-hero-headline {
  padding-left: var(--space-5);
  border-left: 3px solid var(--theme-accent);
}

.theme-hero-headline em {
  color: var(--theme-accent);
  font-style: italic;
  font-weight: 600;
}

.theme-hero-subhead {
  font-family: var(--font-sans);
  font-size: var(--fluid-lg);
  color: rgba(19, 30, 53, 0.72);
  margin: 0 auto var(--space-10);
  max-width: 640px;
  line-height: 1.55;
}

.theme-hero-ctas {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  flex-wrap: wrap;
}

/* ============================================================
   THEME INTRO ("How We Do X")
   ============================================================ */

.theme-intro {
  padding: var(--space-20) 0;
  background: var(--cream);
  color: var(--black);
}

.theme-intro-inner {
  max-width: 960px;
  margin: 0 auto;
  text-align: center;
}

.theme-intro h2 {
  font-family: var(--font-serif);
  font-size: var(--fluid-3xl);
  font-weight: 700;
  color: var(--black);
  margin: var(--space-4) 0 var(--space-8);
  line-height: 1.15;
}

.theme-intro h2 em {
  color: var(--theme-accent);
  font-style: italic;
}

.theme-intro-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-8);
  margin-top: var(--space-10);
  text-align: left;
}

.theme-intro-item {
  background: var(--white);
  border: 1px solid var(--cream-dark);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  transition: transform var(--transition-base), border-color var(--transition-base);
}

.theme-intro-item:hover {
  transform: translateY(-2px);
  border-color: var(--theme-accent);
}

.theme-intro-item h3 {
  font-family: var(--font-serif);
  font-size: var(--font-size-xl);
  font-weight: 600;
  color: var(--black);
  margin: 0 0 var(--space-3);
}

.theme-intro-item p {
  font-size: var(--font-size-base);
  color: var(--gray-600);
  line-height: 1.65;
  margin: 0;
}

.theme-intro-item-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  background: var(--theme-accent-soft);
  color: var(--theme-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  margin-bottom: var(--space-4);
}

/* ============================================================
   CORPORATE RETAINER CALLOUT (corporate theme only)
   ============================================================ */

.corporate-retainer-callout {
  max-width: 960px;
  margin: 0 auto var(--space-12);
  padding: var(--space-8) var(--space-10);
  background: var(--navy);
  border: 1px solid var(--navy);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  flex-wrap: wrap;
  box-shadow: 0 24px 60px rgba(19, 30, 53, 0.18);
  position: relative;
}

.corporate-retainer-callout::before {
  content: '';
  position: absolute;
  left: 0;
  top: 20%;
  bottom: 20%;
  width: 3px;
  background: var(--gold);
  border-radius: 0 2px 2px 0;
}

.corporate-retainer-callout-content {
  flex: 1 1 320px;
  color: var(--cream);
}

.corporate-retainer-callout .retainer-eyebrow {
  font-family: var(--font-sans);
  font-size: var(--font-size-xs);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 600;
  display: block;
  margin-bottom: var(--space-2);
}

.corporate-retainer-callout h3 {
  font-family: var(--font-serif);
  font-size: var(--font-size-2xl);
  font-weight: 600;
  color: var(--cream);
  margin: 0 0 var(--space-2);
}

.corporate-retainer-callout p {
  font-size: var(--font-size-base);
  color: rgba(242, 237, 228, 0.8);
  margin: 0;
  line-height: 1.55;
}

.corporate-retainer-callout .btn {
  flex-shrink: 0;
}

/* ============================================================
   PACKAGE SELECTION SECTION
   ============================================================ */

.theme-packages {
  padding: var(--space-24) 0;
  background: var(--white);
  color: var(--black);
}

.theme-packages-header {
  text-align: center;
  max-width: 760px;
  margin: 0 auto var(--space-12);
}

.theme-packages-header h2 {
  font-family: var(--font-serif);
  font-size: var(--fluid-4xl);
  font-weight: 700;
  color: var(--black);
  margin: var(--space-4) 0 var(--space-4);
  line-height: 1.1;
}

.theme-packages-header h2 em {
  color: var(--theme-accent);
  font-style: italic;
}

.theme-packages-header p {
  font-size: var(--font-size-lg);
  color: var(--gray-600);
  margin: 0;
  line-height: 1.55;
}

/* Guest Band Selector */
.guest-band-selector {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-2);
  max-width: 780px;
  margin: 0 auto var(--space-12);
  padding: var(--space-3);
  background: var(--cream);
  border: 1px solid var(--cream-dark);
  border-radius: var(--radius-full);
}

.band-pill {
  flex: 1 1 auto;
  min-width: 90px;
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-sans);
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--gray-600);
  background: transparent;
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: all var(--transition-fast);
  white-space: nowrap;
  min-height: 44px;
}

.band-pill:hover {
  color: var(--black);
  background: var(--white);
}

.band-pill.active {
  background: var(--navy);
  color: var(--theme-accent);
  box-shadow: var(--shadow-md);
}

.band-pill-label {
  display: block;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.08em;
  opacity: 0.7;
  margin-top: 2px;
  text-transform: uppercase;
}

/* Package grid */
.pkg-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-6);
  max-width: 1240px;
  margin: 0 auto;
}

@media (min-width: 1100px) {
  .pkg-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.pkg-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--white);
  border: 1px solid var(--cream-dark);
  border-radius: var(--radius-lg);
  padding: var(--space-8) var(--space-6) var(--space-6);
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
  overflow: hidden;
}

.pkg-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--theme-accent);
}

.pkg-card.featured {
  border: 2px solid var(--theme-accent);
  box-shadow: 0 8px 32px var(--theme-accent-soft);
  background: linear-gradient(180deg, var(--white) 0%, var(--cream) 100%);
}

.pkg-card.featured::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--theme-accent) 0%, var(--gold) 100%);
}

.pkg-badge {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  padding: var(--space-1) var(--space-3);
  background: var(--theme-accent);
  color: var(--white);
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-sm);
}

.pkg-name {
  font-family: var(--font-serif);
  font-size: var(--font-size-2xl);
  font-weight: 700;
  color: var(--black);
  margin: 0 0 var(--space-1);
  line-height: 1.15;
}

.pkg-duration {
  font-family: var(--font-sans);
  font-size: var(--font-size-xs);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--theme-accent);
  margin-bottom: var(--space-5);
  display: block;
}

.pkg-price {
  font-family: var(--font-serif);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--black);
  line-height: 1;
  margin-bottom: var(--space-2);
}

.pkg-price.quote {
  font-size: 1.75rem;
  color: var(--theme-accent);
  font-style: italic;
}

.pkg-price-note {
  font-size: var(--font-size-xs);
  color: var(--gray-500);
  margin-bottom: var(--space-5);
  min-height: 16px;
}

.pkg-desc {
  font-size: var(--font-size-sm);
  color: var(--gray-600);
  line-height: 1.55;
  margin-bottom: var(--space-5);
}

.pkg-features {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-6);
  flex: 1 1 auto;
}

.pkg-features li {
  position: relative;
  padding: var(--space-2) 0 var(--space-2) var(--space-6);
  font-size: var(--font-size-sm);
  color: var(--gray-700);
  line-height: 1.5;
  border-bottom: 1px solid var(--cream);
}

.pkg-features li:last-child { border-bottom: none; }

.pkg-features li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 14px;
  width: 14px;
  height: 14px;
  background: var(--theme-accent-soft);
  border: 1px solid var(--theme-accent);
  border-radius: 50%;
}

.pkg-features li::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 18px;
  width: 5px;
  height: 8px;
  border-right: 2px solid var(--theme-accent);
  border-bottom: 2px solid var(--theme-accent);
  transform: rotate(45deg);
}

.pkg-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  width: 100%;
  padding: var(--space-4) var(--space-6);
  font-family: var(--font-sans);
  font-size: var(--font-size-base);
  font-weight: 600;
  text-decoration: none;
  border-radius: var(--radius-md);
  transition: all var(--transition-base);
  min-height: 48px;
}

.pkg-card .pkg-cta {
  background: var(--navy);
  color: var(--cream);
  border: 1px solid var(--navy);
}

.pkg-card .pkg-cta:hover {
  background: var(--navy-light);
  color: var(--theme-accent);
  transform: translateY(-1px);
}

.pkg-card.featured .pkg-cta {
  background: var(--theme-accent);
  color: var(--white);
  border-color: var(--theme-accent);
  box-shadow: 0 4px 20px var(--theme-accent-soft);
}

.pkg-card.featured .pkg-cta:hover {
  background: var(--gold-dark);
  border-color: var(--gold-dark);
  box-shadow: var(--shadow-gold);
}

/* ============================================================
   COCKTAIL EXAMPLES
   ============================================================ */

.theme-cocktails {
  padding: var(--space-24) 0;
  background: var(--cream);
  color: var(--black);
}

.theme-cocktails-header {
  text-align: center;
  max-width: 760px;
  margin: 0 auto var(--space-12);
}

.theme-cocktails-header h2 {
  font-family: var(--font-serif);
  font-size: var(--fluid-3xl);
  font-weight: 700;
  margin: var(--space-4) 0;
  line-height: 1.15;
}

.theme-cocktails-header h2 em {
  color: var(--theme-accent);
  font-style: italic;
}

.theme-cocktails-header p {
  font-size: var(--font-size-lg);
  color: var(--gray-600);
  line-height: 1.55;
  margin: 0;
}

.cocktail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-6);
  max-width: 1120px;
  margin: 0 auto var(--space-10);
}

.cocktail-tile {
  background: var(--white);
  border: 1px solid var(--cream-dark);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  text-align: center;
  transition: transform var(--transition-base), border-color var(--transition-base);
}

.cocktail-tile:hover {
  transform: translateY(-3px);
  border-color: var(--theme-accent);
}

.cocktail-tile-icon {
  font-size: 28px;
  color: var(--theme-accent);
  margin-bottom: var(--space-3);
}

.cocktail-tile-name {
  font-family: var(--font-serif);
  font-size: var(--font-size-xl);
  font-weight: 600;
  color: var(--black);
  margin: 0 0 var(--space-2);
}

.cocktail-tile-desc {
  font-size: var(--font-size-sm);
  color: var(--gray-600);
  line-height: 1.55;
  margin: 0;
}

.theme-cocktails-footer {
  text-align: center;
}

.theme-cocktails-footer a {
  color: var(--theme-accent);
  text-decoration: none;
  font-weight: 600;
  font-family: var(--font-sans);
  font-size: var(--font-size-base);
  border-bottom: 1px solid var(--theme-accent);
  padding-bottom: 2px;
  transition: opacity var(--transition-fast);
}

.theme-cocktails-footer a:hover { opacity: 0.7; }

/* ============================================================
   FINAL CTA
   ============================================================ */

.theme-final-cta {
  padding: var(--space-24) 0;
  background: var(--cream);
  color: var(--navy);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.theme-final-cta::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 1px;
  height: 80px;
  background: linear-gradient(to bottom, transparent, var(--theme-accent));
  opacity: 0.7;
}

.theme-final-cta-inner {
  max-width: 720px;
  margin: 0 auto;
}

.theme-final-cta h2 {
  font-family: var(--font-serif);
  font-size: var(--fluid-4xl);
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 var(--space-5);
  line-height: 1.1;
}

.theme-final-cta h2 em {
  color: var(--theme-accent);
  font-style: italic;
}

.theme-final-cta p {
  font-size: var(--fluid-lg);
  color: var(--gray-600);
  margin: 0 0 var(--space-10);
  line-height: 1.55;
}

.theme-final-cta-ctas {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
}

.theme-final-cta-secondary {
  color: var(--gray-600);
  font-size: var(--font-size-sm);
  font-family: var(--font-sans);
}

.theme-final-cta-secondary a {
  color: var(--theme-accent);
  text-decoration: none;
  font-weight: 600;
  border-bottom: 1px solid var(--theme-accent);
  padding-bottom: 1px;
}

.theme-final-cta-secondary a:hover { opacity: 0.75; }

/* ============================================================
   THEME FAQ
   ============================================================ */

.theme-faq {
  padding: var(--space-24) 0;
  background: var(--white);
  color: var(--black);
}

.theme-faq-header {
  text-align: center;
  max-width: 720px;
  margin: 0 auto var(--space-12);
}

.theme-faq-header h2 {
  font-family: var(--font-serif);
  font-size: var(--fluid-3xl);
  font-weight: 700;
  margin: var(--space-4) 0 var(--space-3);
  line-height: 1.15;
}

.theme-faq-header h2 em {
  color: var(--theme-accent);
  font-style: italic;
}

.theme-faq-header p {
  font-size: var(--font-size-lg);
  color: var(--gray-600);
  margin: 0;
}

.theme-faq-list {
  max-width: 820px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.theme-faq-item {
  background: var(--white);
  border: 1px solid var(--cream-dark);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color var(--transition-fast);
}

.theme-faq-item[open] {
  border-color: var(--theme-accent);
  box-shadow: 0 4px 20px var(--theme-accent-soft);
}

.theme-faq-summary {
  padding: var(--space-5) var(--space-6);
  font-family: var(--font-sans);
  font-size: var(--font-size-base);
  font-weight: 600;
  color: var(--black);
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  min-height: 48px;
  transition: color var(--transition-fast);
}

.theme-faq-summary::-webkit-details-marker { display: none; }

.theme-faq-summary:hover { color: var(--theme-accent); }

.theme-faq-summary::after {
  content: "";
  width: 28px;
  height: 28px;
  flex-shrink: 0;
  border-radius: 50%;
  background: var(--theme-accent-soft);
  border: 1px solid var(--theme-accent);
  background-image: linear-gradient(var(--theme-accent), var(--theme-accent)),
                    linear-gradient(var(--theme-accent), var(--theme-accent));
  background-size: 12px 2px, 2px 12px;
  background-position: center;
  background-repeat: no-repeat;
  transition: transform var(--transition-base), background-color var(--transition-base);
}

.theme-faq-item[open] .theme-faq-summary::after {
  background: var(--theme-accent);
  background-image: linear-gradient(var(--white), var(--white));
  background-size: 12px 2px;
  background-position: center;
  background-repeat: no-repeat;
  transform: rotate(180deg);
}

.theme-faq-answer {
  padding: 0 var(--space-6) var(--space-5);
  font-size: var(--font-size-base);
  color: var(--gray-600);
  line-height: 1.75;
}

/* ============================================================
   INTER-THEME FOOTER LINK STRIP
   ============================================================ */

.theme-cross-links {
  padding: var(--space-16) 0;
  background: var(--cream);
  border-top: 1px solid var(--cream-dark);
  color: var(--navy);
  text-align: center;
}

.theme-cross-links-title {
  font-family: var(--font-sans);
  font-size: var(--font-size-xs);
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold-dark);
  margin-bottom: var(--space-6);
}

.theme-cross-links-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-2) var(--space-4);
  list-style: none;
  padding: 0;
  margin: 0;
}

.theme-cross-links-list a {
  font-family: var(--font-sans);
  font-size: var(--font-size-sm);
  font-weight: 500;
  color: var(--gray-700);
  text-decoration: none;
  padding: var(--space-2) var(--space-4);
  border: 1px solid var(--cream-dark);
  border-radius: var(--radius-full);
  background: var(--white);
  transition: all var(--transition-fast);
}

.theme-cross-links-list a:hover {
  color: var(--gold-dark);
  border-color: var(--gold);
}

.theme-cross-links-list a[aria-current="page"] {
  color: var(--navy);
  background: var(--gold);
  border-color: var(--gold);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 640px) {
  .theme-hero {
    padding: calc(var(--space-20) + 48px) 0 var(--space-16);
  }

  .theme-hero-ctas .btn,
  .theme-final-cta-ctas .btn {
    width: 100%;
    max-width: 320px;
  }

  .guest-band-selector {
    border-radius: var(--radius-lg);
  }

  .band-pill {
    flex: 1 1 45%;
    min-width: 0;
  }

  .pkg-card {
    padding: var(--space-6) var(--space-5) var(--space-5);
  }

  .corporate-retainer-callout {
    flex-direction: column;
    align-items: flex-start;
    padding: var(--space-5);
  }

  .corporate-retainer-callout .btn {
    width: 100%;
  }
}


/* ============================================================
   THEME HERO MEDIA SLOT (P2 #16)
   Easy-swap image slot. Uses data-theme-hero-img on the element,
   JS probes the file and sets background-image on load. Until
   loaded (or if missing), shows a subtle gradient placeholder.
   ============================================================ */

.theme-hero-inner.has-media {
  max-width: 1160px;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--space-10);
  align-items: center;
  text-align: left;
}

.theme-hero-inner.has-media .theme-hero-eyebrow {
  margin-left: 0;
}

.theme-hero-inner.has-media .theme-hero-subhead {
  margin-left: 0;
  margin-right: 0;
}

.theme-hero-inner.has-media .theme-hero-ctas {
  justify-content: flex-start;
}

.theme-hero-media {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 2;
  border-radius: var(--radius-lg, 12px);
  overflow: hidden;
  background-color: var(--white);
  background-image:
    radial-gradient(circle at 30% 30%, var(--theme-accent-soft) 0%, transparent 55%),
    radial-gradient(circle at 75% 75%, rgba(19, 30, 53, 0.04) 0%, transparent 55%);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border: 1px solid var(--cream-dark);
  box-shadow: 0 24px 60px rgba(19, 30, 53, 0.12);
  display: flex;
  align-items: center;
  justify-content: center;
}

.theme-hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.theme-hero-media.has-image {
  background-color: transparent;
  background-image: var(--theme-hero-image, none);
}

.theme-hero-media.has-image .theme-hero-media-placeholder,
.theme-hero-media:has(img) .theme-hero-media-placeholder {
  display: none;
}

.theme-hero-media-placeholder {
  color: var(--gray-500);
  font-family: var(--font-sans);
  font-size: var(--font-size-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: var(--space-3) var(--space-5);
  background: var(--cream);
  border: 1px solid var(--cream-dark);
  border-radius: var(--radius-full, 999px);
}

@media (max-width: 780px) {
  .theme-hero-inner.has-media {
    grid-template-columns: 1fr;
    text-align: center;
    gap: var(--space-8);
  }
  .theme-hero-inner.has-media .theme-hero-eyebrow,
  .theme-hero-inner.has-media .theme-hero-subhead {
    margin-left: auto;
    margin-right: auto;
  }
  .theme-hero-inner.has-media .theme-hero-ctas {
    justify-content: center;
  }
  .theme-hero-media {
    order: 2;
    aspect-ratio: 16 / 9;
  }
}


/* ============================================================
   THEME 200+ FORM (P1 #15)
   Revealed when the 200+ band is selected on theme pages.
   ============================================================ */

.pkg-grid.is-200-muted {
  opacity: 0.45;
  filter: grayscale(0.25);
  pointer-events: none;
  transition: opacity 0.25s ease, filter 0.25s ease;
}

.theme-200-form {
  margin-top: var(--space-10);
  background: var(--white);
  border: 1px solid var(--cream-dark);
  border-radius: var(--radius-lg, 12px);
  padding: var(--space-8) var(--space-8);
  color: var(--navy);
  box-shadow: 0 12px 40px rgba(19, 30, 53, 0.06);
}

.theme-200-inner {
  max-width: 640px;
  margin: 0 auto;
}

.theme-200-title {
  font-family: var(--font-serif);
  font-size: var(--fluid-2xl, 1.75rem);
  color: var(--navy);
  margin: 0 0 var(--space-3);
  text-align: center;
}

.theme-200-sub {
  font-family: var(--font-sans);
  color: var(--gray-600);
  font-size: var(--font-size-base);
  line-height: 1.6;
  text-align: center;
  margin: 0 0 var(--space-6);
}

.theme-200-phone {
  color: var(--gold-dark);
  text-decoration: underline;
  text-underline-offset: 3px;
  font-weight: 600;
}

.theme-200-form-fields .t200-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.theme-200-form-fields .t200-row:has(textarea),
.theme-200-form-fields .t200-row:has(input[type="number"]:only-child) {
  grid-template-columns: 1fr;
}

.theme-200-form-fields input,
.theme-200-form-fields select,
.theme-200-form-fields textarea {
  width: 100%;
  background: var(--cream);
  color: var(--navy);
  border: 1px solid var(--cream-dark);
  border-radius: var(--radius-md, 8px);
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-sans);
  font-size: var(--font-size-base);
  transition: border-color 0.2s ease, background 0.2s ease;
}

.theme-200-form-fields input::placeholder,
.theme-200-form-fields textarea::placeholder {
  color: var(--gray-500);
}

.theme-200-form-fields input:focus,
.theme-200-form-fields select:focus,
.theme-200-form-fields textarea:focus {
  outline: none;
  border-color: var(--gold, #C9A84C);
  background: var(--white);
}

.theme-200-form-fields textarea {
  resize: vertical;
  min-height: 96px;
}

.theme-200-form-fields .t200-submit {
  width: 100%;
  margin-top: var(--space-2);
}

.theme-200-form-fields .t200-success {
  text-align: center;
  color: var(--gold-dark);
  font-weight: 600;
  margin-top: var(--space-4);
}

@media (max-width: 640px) {
  .theme-200-form-fields .t200-row {
    grid-template-columns: 1fr;
  }
  .theme-200-form {
    padding: var(--space-6) var(--space-5);
  }
}
