:root {
  --ink: #171312;
  --paper: #f7f3ed;
  --cream: #eee7dd;
  --pink: #e94174;
  --orange: #ff7d39;
  --gold: #f1c24b;
  --violet: #7254dc;
  --line: rgba(23, 19, 18, 0.18);
  --max-width: 76rem;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: 'DM Sans', Arial, sans-serif; font-size: 16px; line-height: 1.5; }
a { color: inherit; text-decoration: none; }
:focus-visible { outline: 3px solid var(--violet); outline-offset: 4px; }
.site-header { height: 82px; padding: 0 max(5vw, 1.5rem); display: flex; align-items: center; justify-content: space-between; background: var(--ink); color: #fff; }
.brand, .footer-brand { font-weight: 700; font-size: .8rem; letter-spacing: .13em; }
.brand span, .footer-brand span { font-weight: 400; }
nav { display: flex; gap: 1.7rem; font-size: .8rem; font-weight: 600; }
nav a { opacity: .76; transition: opacity .2s ease; }
nav a:hover { opacity: 1; }
.header-cta, .button { font-size: .78rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; }
.header-cta { border-bottom: 1px solid var(--gold); padding-bottom: .22rem; }
.hero { min-height: 635px; display: grid; grid-template-columns: minmax(0, 1fr) minmax(460px, .95fr); background: var(--ink); color: #fff; }
.hero-copy { width: min(100%, 39rem); padding: 7.7rem 2rem 5rem max(5vw, 1.5rem); align-self: center; }
.hero-location, .section-number { margin: 0; font-size: .67rem; font-weight: 700; letter-spacing: .13em; }
.hero-location { color: var(--gold); }
h1, h2 { margin: 0; font-family: 'Playfair Display', Georgia, serif; font-weight: 600; line-height: .93; letter-spacing: -.055em; }
h1 { max-width: 650px; margin-top: 1.3rem; font-size: clamp(4.5rem, 8vw, 8.8rem); }
h1 em, h2 em { color: var(--pink); }
.hero-intro { max-width: 25rem; margin: 2rem 0 2.4rem; color: rgba(255, 255, 255, .8); font-size: 1.08rem; }
.button { display: inline-flex; gap: 1.1rem; align-items: center; justify-content: center; min-height: 3.4rem; padding: 0 1.3rem; transition: transform .2s ease, background .2s ease; }
.button:hover { transform: translateY(-3px); }
.button-light { background: #fff; color: var(--ink); }
.button-dark { background: var(--ink); color: #fff; }
.button span, .text-link span { font-size: 1.25rem; line-height: 0; }
.hero-image { min-height: 100%; background: url('pride-studio-hero.png') center / cover no-repeat; }
.offer-section { max-width: var(--max-width); margin: 0 auto; padding: 8.5rem max(5vw, 1.5rem); display: grid; grid-template-columns: .75fr 1.25fr; gap: 4.5rem; }
.section-intro h2, .membership-heading h2, .glow-content h2 { margin-top: 1rem; font-size: clamp(3.8rem, 6vw, 6.8rem); }
.offer-lead { max-width: 18rem; margin: 2rem 0 0; font-size: 1.1rem; }
.parade-panel { align-self: center; border-top: 3px solid var(--ink); }
.parade-panel-top { padding: 1rem 0 1.35rem; display: flex; justify-content: space-between; gap: 1rem; font-size: .9rem; }
.parade-panel-top p { margin: 0; font-weight: 600; }
.parade-panel-top span { color: rgba(23, 19, 18, .65); font-size: .72rem; text-transform: uppercase; letter-spacing: .1em; }
.tan-options { border-top: 1px solid var(--line); }
.tan-option { position: relative; min-height: 112px; padding: 1.35rem 7rem 1.3rem 0; display: grid; grid-template-columns: 1fr auto; align-content: center; border-bottom: 1px solid var(--line); transition: color .2s ease, padding .2s ease; }
.tan-option:hover { color: var(--pink); padding-left: .65rem; }
.tan-name { font-size: 1.25rem; font-weight: 600; }
.tan-option strong { grid-row: span 2; align-self: center; font-family: 'Playfair Display', Georgia, serif; font-size: 2.2rem; }
.tan-option small { color: rgba(23, 19, 18, .6); }
.tan-option b { position: absolute; right: 0; top: 50%; transform: translateY(-50%); font-size: .67rem; letter-spacing: .08em; text-transform: uppercase; }
.tan-option i { margin-left: .25rem; font-style: normal; font-size: 1rem; }
.fine-print { margin: 1rem 0 0; color: rgba(23, 19, 18, .58); font-size: .72rem; }
.glow-section { position: relative; overflow: hidden; padding: 8.5rem max(5vw, 1.5rem); display: grid; grid-template-columns: minmax(0, 1fr) minmax(18rem, .58fr); gap: 5rem; background: var(--pink); color: var(--ink); }
.glow-section::after { position: absolute; content: ''; width: 44vw; height: 44vw; min-width: 30rem; min-height: 30rem; right: -9vw; top: -16vw; border: 2px solid rgba(255,255,255,.46); border-radius: 50%; box-shadow: 0 0 0 3.8rem rgba(255, 175, 56, .45), 0 0 0 7.6rem rgba(114, 84, 220, .38); pointer-events: none; }
.glow-content { position: relative; z-index: 1; max-width: 43rem; }
.glow-content .section-number { color: rgba(23, 19, 18, .68); }
.glow-content h2 em { color: var(--ink); }
.glow-tagline { margin: 2rem 0 .5rem; font-size: 1.4rem; font-weight: 700; }
.glow-content > p:not(.section-number):not(.glow-tagline) { max-width: 33rem; margin: 0; font-size: 1.05rem; }
.benefits { margin: 2.2rem 0; padding: 0; list-style: none; font-weight: 600; }
.benefits li { padding: .55rem 0 .55rem 1.5rem; position: relative; }
.benefits li::before { position: absolute; content: '✦'; left: 0; color: #fff; }
.value-card { position: relative; z-index: 1; align-self: end; padding: 2rem; background: var(--cream); box-shadow: 14px 14px 0 var(--ink); }
.value-card p, .value-card span, .value-card small { margin: 0; display: block; font-size: .72rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.value-card strong { display: block; margin: .25rem 0; font-family: 'Playfair Display', Georgia, serif; font-size: clamp(5rem, 8vw, 8rem); line-height: .9; }
.value-card div { width: 100%; margin: 1.5rem 0; border-top: 1px solid var(--line); }
.value-card small { color: rgba(23,19,18,.66); letter-spacing: .04em; text-transform: none; }
.membership-section { max-width: var(--max-width); margin: 0 auto; padding: 8.5rem max(5vw, 1.5rem); display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; }
.membership-copy { max-width: 31rem; padding-top: 1rem; }
.membership-copy > p:not(.enrollment) { margin: 1.2rem 0 2rem; font-size: 1.1rem; }
.enrollment { margin: 0; color: var(--pink); font-size: 1.5rem; font-family: 'Playfair Display', Georgia, serif; }
.enrollment strong { color: var(--ink); font-style: italic; }
.membership-prices { margin: 0 0 2rem; border-top: 1px solid var(--line); }
.membership-prices div { padding: .85rem 0; display: flex; align-items: baseline; justify-content: space-between; border-bottom: 1px solid var(--line); }
.membership-prices dt { font-weight: 600; }
.membership-prices dd { margin: 0; font-family: 'Playfair Display', Georgia, serif; font-size: 1.8rem; }
.membership-prices small { color: rgba(23,19,18,.55); font-family: 'DM Sans', Arial, sans-serif; font-size: .7rem; }
.text-link { display: inline-flex; gap: 1rem; align-items: center; padding-bottom: .35rem; border-bottom: 2px solid var(--pink); font-size: .78rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; }
footer { padding: 3.2rem max(5vw, 1.5rem); display: grid; grid-template-columns: 1fr 1.2fr 1fr; gap: 2rem; background: var(--ink); color: #fff; font-size: .85rem; }
footer p, footer address { margin: 0; color: rgba(255,255,255,.7); font-style: normal; }

@media (max-width: 700px) {
  .site-header { height: 70px; padding: 0 1.25rem; }
  nav { display: none; }
  .header-cta { font-size: .68rem; }
  .hero { min-height: auto; grid-template-columns: 1fr; }
  .hero-copy { padding: 5.8rem 1.25rem 4.3rem; }
  h1 { font-size: clamp(4.2rem, 19vw, 6.1rem); }
  .hero-intro { font-size: 1rem; }
  .hero-image { min-height: 350px; background-position: 58% center; }
  .offer-section, .membership-section { padding: 5.5rem 1.25rem; grid-template-columns: 1fr; gap: 2.8rem; }
  .section-intro h2, .membership-heading h2, .glow-content h2 { font-size: clamp(3.7rem, 16vw, 5.4rem); }
  .parade-panel-top { display: block; }
  .parade-panel-top span { display: block; margin-top: .4rem; }
  .tan-option { min-height: 130px; padding-right: 0; }
  .tan-option b { position: static; grid-column: span 2; margin-top: .7rem; transform: none; }
  .glow-section { padding: 5.5rem 1.25rem; grid-template-columns: 1fr; gap: 3.2rem; }
  .glow-section::after { right: -18rem; top: -8rem; }
  .value-card { width: calc(100% - 14px); }
  footer { padding: 2.5rem 1.25rem; grid-template-columns: 1fr; gap: 1.2rem; }
}

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