/*
Theme Name: GST Modern
Theme URI: https://www.gaysportingtilburg.nl/
Author: Gay Sporting Tilburg
Description: Modern, toegankelijk thema voor Gay Sporting Tilburg.
Version: 1.2.4
Text Domain: gst-modern
*/

:root {
  --ink: #161337;
  --purple: #43318f;
  --purple-dark: #271961;
  --pink: #ec287c;
  --orange: #ff8058;
  --yellow: #ffd84d;
  --green: #16b98a;
  --blue: #169bd5;
  --cream: #f7f5fb;
  --white: #fff;
  --muted: #66627a;
  --radius: 24px;
  --shadow: 0 24px 60px rgba(39, 25, 97, .13);
  --rainbow: linear-gradient(90deg, var(--pink), var(--orange), var(--yellow), var(--green), var(--blue), var(--purple));
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--white);
  font-family: Inter, "Segoe UI", Arial, sans-serif;
  font-size: 17px;
  line-height: 1.65;
}
img { display: block; max-width: 100%; }
a { color: inherit; }
.wrap { width: min(1180px, calc(100% - 40px)); margin-inline: auto; }
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 18px;
  color: var(--purple);
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.eyebrow::before {
  width: 34px;
  height: 4px;
  border-radius: 999px;
  background: var(--rainbow);
  content: "";
}
h1, h2, h3 {
  margin-top: 0;
  font-family: "Arial Black", Inter, sans-serif;
  line-height: 1.05;
  letter-spacing: -.04em;
}
h1 { font-size: clamp(3rem, 7vw, 6.8rem); }
h2 { font-size: clamp(2.2rem, 4vw, 4rem); }
h3 { font-size: 1.45rem; }
p { margin-top: 0; }
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 0 24px;
  border: 2px solid transparent;
  border-radius: 999px;
  background: var(--pink);
  color: var(--white);
  font-size: .92rem;
  font-weight: 800;
  text-decoration: none;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.button:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 30px rgba(236, 40, 124, .3);
}
.button.secondary {
  border-color: rgba(255,255,255,.5);
  background: transparent;
}
.button.light { background: var(--white); color: var(--purple-dark); }

.site-header {
  position: absolute;
  z-index: 20;
  top: 0;
  left: 0;
  width: 100%;
  color: var(--white);
}
.rainbow-line { height: 6px; background: var(--rainbow); }
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 92px;
  gap: 30px;
}
.brand {
  display: flex;
  align-items: center;
  color: var(--white);
  text-decoration: none;
}
.brand img { width: 235px; height: 84px; object-fit: contain; object-position: left center; }
.site-footer .brand img { width: 215px; height: auto; }
.site-nav { display: flex; align-items: center; gap: 28px; }
.site-nav a {
  color: var(--white);
  font-size: .88rem;
  font-weight: 750;
  text-decoration: none;
}
.site-nav a:hover { color: var(--yellow); }
.nav-cta { padding: 10px 18px; border: 1px solid rgba(255,255,255,.55); border-radius: 999px; }
.site-nav .orv-nav-link {
  padding: 7px 13px;
  border: 1px solid currentColor;
  border-radius: 999px;
  color: var(--yellow);
  letter-spacing: .05em;
}
.site-nav .orv-nav-link:hover { border-color: var(--pink); color: var(--pink); }
.language-toggle { display: inline-flex; align-items: center; gap: 5px; color: rgba(255,255,255,.55); font-size: .75rem; }
.language-toggle a { color: rgba(255,255,255,.62); font-size: .75rem; }
.language-toggle a.active { color: var(--yellow); }
body:not(.home) .site-header { color: var(--ink); }
body:not(.home) .site-nav a { color: var(--ink); }
body:not(.home) .site-nav a:hover { color: var(--pink); }
body:not(.home) .site-nav .orv-nav-link { color: var(--purple); }
body:not(.home) .nav-cta { border-color: rgba(67, 49, 143, .28); }
body:not(.home) .language-toggle { color: rgba(22, 19, 55, .42); }
body:not(.home) .language-toggle a { color: rgba(22, 19, 55, .62); }
body:not(.home) .language-toggle a.active { color: var(--purple); }

.hero {
  position: relative;
  display: grid;
  min-height: min(900px, 94vh);
  align-items: end;
  overflow: hidden;
  background: var(--purple-dark);
  color: var(--white);
}
.hero::before {
  position: absolute;
  inset: -18px;
  background:
    linear-gradient(90deg, rgba(21, 12, 62, .96) 0%, rgba(29, 17, 76, .82) 44%, rgba(29, 17, 76, .3) 100%),
    url("assets/hero.png") left center/cover no-repeat;
  content: "";
  filter: blur(9px) saturate(.7);
  transform: scale(1.025);
}
.hero::after {
  position: absolute;
  right: -12vw;
  bottom: -25vw;
  width: 55vw;
  height: 55vw;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 50%;
  box-shadow: 0 0 0 8vw rgba(255,255,255,.035), 0 0 0 16vw rgba(255,255,255,.025);
  content: "";
}
.hero-content {
  position: relative;
  z-index: 2;
  max-width: 820px;
  padding-top: 180px;
  padding-bottom: clamp(80px, 11vw, 140px);
}
.hero .eyebrow { color: var(--white); }
.hero .hero-eyebrow {
  font-size: clamp(1.15rem, 2vw, 1.6rem);
  letter-spacing: .08em;
}
.hero h1 { max-width: 760px; margin-bottom: 24px; }
.hero h1 span {
  background: var(--rainbow);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero-intro {
  max-width: 650px;
  margin-bottom: 34px;
  color: rgba(255,255,255,.84);
  font-size: clamp(1.05rem, 2vw, 1.3rem);
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; }
.hero-facts {
  position: absolute;
  z-index: 3;
  right: max(20px, calc((100vw - 1180px) / 2));
  bottom: 42px;
  display: flex;
  gap: 10px;
}
.fact {
  min-width: 120px;
  padding: 16px 18px;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 18px;
  background: rgba(30, 18, 76, .58);
  backdrop-filter: blur(12px);
}
.fact strong { display: block; font-size: 1.2rem; }
.fact span { color: rgba(255,255,255,.65); font-size: .75rem; }

.section { padding: clamp(80px, 10vw, 130px) 0; }
.intro-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(280px, .75fr);
  gap: clamp(50px, 8vw, 120px);
  align-items: end;
}
.intro-copy p { max-width: 680px; color: var(--muted); font-size: 1.12rem; }
.intro-quote {
  padding: 36px;
  border-radius: var(--radius);
  background: var(--cream);
}
.intro-quote strong { display: block; margin-bottom: 12px; color: var(--purple); font-size: 1.5rem; line-height: 1.2; }

.sports {
  padding-top: 90px;
  padding-bottom: 90px;
  background: var(--cream);
}
.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 30px;
  margin-bottom: 34px;
}
.section-head h2 { max-width: 650px; margin-bottom: 0; }
.text-link { color: var(--purple); font-weight: 800; text-underline-offset: 5px; }
.sport-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
}
.sport-card {
  position: relative;
  display: flex;
  grid-column: span 4;
  min-height: 290px;
  align-items: end;
  overflow: hidden;
  border-radius: var(--radius);
  background: var(--purple);
  color: var(--white);
  text-decoration: none;
  box-shadow: var(--shadow);
}
.sport-card:nth-child(1), .sport-card:nth-child(2) { grid-column: span 6; min-height: 340px; }
.sport-card::before {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(20, 12, 55, .9), rgba(20, 12, 55, .04) 70%);
  content: "";
}
.sport-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: left center;
  filter: grayscale(100%);
  transition: filter .35s ease, transform .5s ease;
}
.sport-card:hover img { filter: grayscale(20%); transform: scale(1.035); }
.sport-info { position: absolute; z-index: 2; inset: auto 28px 25px; }
.sport-info h3 { margin-bottom: 7px; }
.sport-info span { color: rgba(255,255,255,.72); font-size: .86rem; }
.sport-arrow {
  position: absolute;
  z-index: 3;
  right: 24px;
  top: 24px;
  display: grid;
  width: 48px;
  height: 48px;
  place-items: center;
  border-radius: 50%;
  background: rgba(255,255,255,.9);
  color: var(--purple);
  font-size: 1.3rem;
}

.news-section { background: var(--white); }
.news-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.news-card {
  overflow: hidden;
  border: 1px solid #ebe8f0;
  border-radius: var(--radius);
  background: var(--white);
  box-shadow: 0 14px 40px rgba(39, 25, 97, .08);
  transition: transform .25s ease, box-shadow .25s ease;
}
.news-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow);
}
.news-image {
  display: block;
  height: 230px;
  overflow: hidden;
  background: var(--purple-dark);
}
.news-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .45s ease;
}
.news-card:hover .news-image img { transform: scale(1.04); }
.news-placeholder {
  display: grid;
  width: 100%;
  height: 100%;
  place-items: center;
  background:
    radial-gradient(circle at 25% 30%, rgba(236,40,124,.8), transparent 25%),
    radial-gradient(circle at 75% 70%, rgba(22,185,138,.7), transparent 28%),
    var(--purple-dark);
}
.news-placeholder span {
  display: grid;
  width: 88px;
  height: 88px;
  place-items: center;
  border: 3px solid rgba(255,255,255,.8);
  border-radius: 50%;
  color: var(--white);
  font-weight: 900;
  letter-spacing: .08em;
}
.news-content { padding: 26px; }
.news-content time {
  display: block;
  margin-bottom: 12px;
  color: var(--purple);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .09em;
  text-transform: uppercase;
}
.news-content h3 { margin-bottom: 12px; }
.news-content h3 a { text-decoration: none; }
.news-content p { color: var(--muted); font-size: .92rem; }
.news-link { color: var(--pink); font-size: .84rem; font-weight: 800; text-decoration: none; }
.news-empty {
  padding: 42px;
  border: 2px dashed #d9d5e3;
  border-radius: var(--radius);
  background: var(--cream);
  text-align: center;
}
.news-empty strong { display: block; margin-bottom: 7px; font-size: 1.25rem; }
.news-empty p { margin-bottom: 0; color: var(--muted); }

.instagram-promo {
  position: relative;
  overflow: hidden;
  padding: 68px 0;
  background:
    radial-gradient(circle at 8% 15%, rgba(255,255,255,.25), transparent 24%),
    radial-gradient(circle at 88% 90%, rgba(255,211,64,.35), transparent 28%),
    linear-gradient(120deg, #43318f 0%, #bb2687 48%, #ec287c 72%, #ef7f32 100%);
  color: var(--white);
}
.instagram-promo::after {
  position: absolute;
  right: -90px;
  top: -130px;
  width: 360px;
  height: 360px;
  border: 2px solid rgba(255,255,255,.15);
  border-radius: 38%;
  transform: rotate(20deg);
  content: "";
}
.instagram-promo-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: clamp(24px, 4vw, 48px);
  align-items: center;
}
.instagram-icon {
  display: grid;
  width: clamp(82px, 10vw, 118px);
  height: clamp(82px, 10vw, 118px);
  place-items: center;
  border: 1px solid rgba(255,255,255,.38);
  border-radius: 30px;
  background: rgba(255,255,255,.13);
  box-shadow: 0 20px 55px rgba(39,25,97,.25);
  backdrop-filter: blur(8px);
}
.instagram-icon svg {
  width: 56%;
  height: 56%;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
}
.instagram-icon .instagram-icon-dot { fill: currentColor; stroke: none; }
.instagram-promo .eyebrow { color: #ffe681; }
.instagram-promo h2 { max-width: 700px; margin: 0 0 10px; color: var(--white); font-size: clamp(2rem, 4vw, 3.2rem); }
.instagram-promo-copy > p:last-child { max-width: 680px; margin: 0; color: rgba(255,255,255,.8); }
.instagram-promo-action { display: flex; flex-direction: column; gap: 13px; align-items: flex-start; }
.instagram-promo-action strong { color: var(--white); font-size: 1.05rem; }
.instagram-promo-action .button { white-space: nowrap; }

.cta-band {
  position: relative;
  overflow: hidden;
  background: var(--purple-dark);
  color: var(--white);
}
.cta-band::before {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 90% 20%, rgba(22,185,138,.27), transparent 32%),
    radial-gradient(circle at 10% 90%, rgba(236,40,124,.3), transparent 32%);
  content: "";
}
.cta-inner {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 50px;
  align-items: center;
  padding: 85px 0;
}
.cta-inner h2 { max-width: 780px; margin-bottom: 14px; }
.cta-inner p { max-width: 650px; margin-bottom: 0; color: rgba(255,255,255,.72); }

.site-footer { padding: 70px 0 35px; background: #121026; color: var(--white); }
.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr repeat(2, 1fr);
  gap: 50px;
  padding-bottom: 55px;
}
.footer-grid h3 { margin-bottom: 18px; font-size: 1rem; letter-spacing: 0; }
.footer-grid p, .footer-grid a { color: rgba(255,255,255,.65); }
.footer-grid a { display: block; margin-bottom: 8px; text-decoration: none; }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  padding-top: 25px;
  border-top: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.45);
  font-size: .78rem;
}

.page-main { padding: 150px 0 90px; }
.page-main .entry-content { max-width: 820px; }
.breadcrumbs {
  margin: 0 0 28px;
  color: var(--muted);
  font-size: .9rem;
  font-weight: 700;
}
.breadcrumbs ol {
  display: flex;
  align-items: center;
  gap: 9px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.breadcrumbs li {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-width: 0;
}
.breadcrumbs li:not(:last-child)::after {
  color: var(--pink);
  content: "/";
}
.breadcrumbs a {
  color: var(--purple);
  text-decoration: underline;
  text-decoration-color: rgba(67, 49, 143, .3);
  text-underline-offset: 3px;
}
.breadcrumbs a:hover,
.breadcrumbs a:focus-visible {
  color: var(--pink);
  text-decoration-color: currentColor;
}
.breadcrumbs [aria-current="page"] {
  color: var(--ink);
}
.page-banner {
  width: min(100%, 1050px);
  height: clamp(260px, 38vw, 450px);
  margin: 35px 0 48px;
  overflow: hidden;
  border-radius: var(--radius);
  background: var(--purple-dark);
  box-shadow: var(--shadow);
}
.page-banner img { width: 100%; height: 100%; object-fit: cover; object-position: left center; }
.contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .8fr);
  gap: clamp(45px, 8vw, 100px);
  align-items: start;
}
.membership-layout {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
  gap: clamp(38px, 5vw, 64px);
  align-items: start;
}
.membership-content { min-width: 0; }
.membership-content h1 {
  max-width: 100%;
  font-size: clamp(3rem, 4.5vw, 4rem);
  overflow-wrap: normal;
  word-break: normal;
}
.membership-layout .contact-form-card { min-width: 0; }
.membership-options { margin: 0; padding: 0; border: 0; }
.membership-checks { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 7px; }
.entry-content h2, .entry-content h3 { margin-top: 38px; letter-spacing: -.025em; }
.entry-content h2 { font-size: 1.85rem; }
.entry-content h3 { color: var(--purple); font-size: 1.2rem; }
.entry-content table { width: 100%; margin: 25px 0; border-collapse: collapse; }
.entry-content th, .entry-content td { padding: 13px; border: 1px solid #e2deea; text-align: left; }
.entry-content th { background: var(--purple); color: var(--white); }
.entry-content .content-note { padding: 18px 20px; border-left: 5px solid var(--yellow); border-radius: 0 14px 14px 0; background: var(--cream); }
.board-section { margin-top: 72px; }
.board-section > h2 { max-width: 760px; margin: 0 0 14px; font-size: clamp(2.2rem, 4vw, 3.4rem); }
.board-intro { max-width: 760px; margin: 0 0 30px; color: var(--muted); font-size: 1.05rem; }
.board-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.board-card {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
  padding: 25px;
  border: 1px solid #e6e1ec;
  border-radius: 22px;
  background: var(--white);
  box-shadow: 0 14px 38px rgba(39, 25, 97, .08);
}
.board-card-mark {
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  border-radius: 18px;
  background: linear-gradient(145deg, var(--purple), var(--pink));
  color: var(--white);
  font-family: "Arial Black", Inter, sans-serif;
  font-size: 1.35rem;
}
.board-role { margin: 0 0 4px; color: var(--pink); font-size: .74rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.board-card h3 { margin: 0 0 8px; color: var(--ink); font-size: 1.25rem; }
.board-card div > p:last-child { margin: 0; color: var(--muted); font-size: .92rem; }
.board-contact {
  display: flex;
  gap: 30px;
  align-items: center;
  justify-content: space-between;
  margin-top: 22px;
  padding: 27px 30px;
  border-radius: 22px;
  background: var(--purple-dark);
  color: var(--white);
}
.board-contact h3 { margin: 0 0 5px; color: var(--white); }
.board-contact p { max-width: 720px; margin: 0; color: rgba(255,255,255,.78); }
.board-contact .button { flex: 0 0 auto; }
.confidential-contact {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 30px;
  align-items: center;
  margin-top: 22px;
  padding: 27px 30px;
  border: 1px solid rgba(67, 49, 143, .14);
  border-left: 5px solid var(--yellow);
  border-radius: 0 22px 22px 0;
  background: var(--cream);
}
.confidential-contact h3 { margin: 0 0 7px; color: var(--ink); }
.confidential-contact p:not(.eyebrow) { margin: 0; color: var(--muted); }
.confidential-details { display: flex; flex-direction: column; gap: 4px; text-align: right; }
.confidential-details a { color: var(--purple); font-weight: 800; }
.no-training-notice {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
  margin-top: 34px;
  padding: 24px 27px;
  border: 1px solid rgba(236, 40, 124, .2);
  border-left: 5px solid var(--pink);
  border-radius: 0 22px 22px 0;
  background: #fff5f8;
}
.no-training-icon {
  display: grid;
  place-items: center;
  width: 54px;
  height: 54px;
  border-radius: 17px;
  background: var(--pink);
  color: var(--white);
  font-family: "Arial Black", Inter, sans-serif;
  font-size: 1.4rem;
}
.no-training-notice h2 { margin: 0 0 9px; color: var(--ink); font-size: 1.45rem; }
.no-training-notice ul { margin: 0; padding-left: 20px; color: var(--ink); }
.no-training-notice li + li { margin-top: 5px; }
.sport-links { margin-top: 70px; }
.sport-links > h2 { max-width: 720px; margin-bottom: 28px; font-size: clamp(2rem, 4vw, 3.3rem); }
.sport-link-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.sport-link-card {
  display: grid;
  grid-template-columns: 170px minmax(0, 1fr);
  min-height: 190px;
  overflow: hidden;
  border: 1px solid #e6e1ec;
  border-radius: 22px;
  background: var(--white);
  text-decoration: none;
  box-shadow: 0 14px 38px rgba(39, 25, 97, .09);
  transition: transform .2s ease, box-shadow .2s ease;
}
.sport-link-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 20px 45px rgba(39, 25, 97, .15);
}
.sport-link-card img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.75); }
.sport-link-copy { display: flex; flex-direction: column; align-items: flex-start; padding: 24px; }
.sport-link-copy > strong { margin-bottom: 8px; color: var(--ink); font-family: "Arial Black", Inter, sans-serif; font-size: 1.25rem; }
.sport-link-copy > span:not(.sport-link-action) { color: var(--muted); font-size: .9rem; }
.sport-link-action { margin-top: auto; padding-top: 15px; color: var(--purple); font-size: .82rem; font-weight: 800; }
.sport-link-card:last-child { grid-column: 1 / -1; }
.pricing-intro { max-width: 650px; color: var(--muted); font-size: 1.04rem; }
.pricing-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin: 24px 0 18px;
}
.pricing-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding: 25px;
  overflow: hidden;
  border: 1px solid #e5dfeb;
  border-radius: 22px;
  background: var(--white);
  box-shadow: 0 12px 35px rgba(50, 27, 72, .08);
}
.pricing-card::before {
  position: absolute;
  inset: 0 0 auto;
  height: 5px;
  background: linear-gradient(90deg, var(--pink), var(--yellow));
  content: "";
}
.pricing-card.featured {
  border-color: rgba(228, 46, 122, .3);
  background: linear-gradient(155deg, #fff 45%, #fff6fa);
}
.pricing-label {
  margin-bottom: 8px;
  color: var(--purple);
  font-size: .76rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.pricing-card h3 { margin: 0 0 7px; color: var(--ink); font-size: 1.25rem; }
.pricing-card > p { max-width: 540px; margin: 0 0 20px; color: var(--muted); font-size: .95rem; }
.pricing-price { display: flex; align-items: baseline; gap: 7px; margin: 0 0 18px; }
.pricing-price strong { color: var(--purple); font-size: 2.25rem; line-height: 1; letter-spacing: -.04em; }
.pricing-price span { color: var(--muted); font-size: .78rem; }
.pricing-breakdown { display: grid; gap: 8px; padding-top: 16px; border-top: 1px solid #ebe6ef; }
.pricing-breakdown div { display: flex; justify-content: space-between; gap: 20px; font-size: .9rem; }
.pricing-breakdown span { color: var(--muted); }
.pricing-breakdown strong { color: var(--ink); text-align: right; }
.pricing-footnote { margin: 0 0 24px; color: var(--muted); font-size: .82rem; }
.privacy-summary {
  margin: 28px 0;
  padding: 24px;
  border: 1px solid rgba(67, 49, 143, .14);
  border-radius: 20px;
  background: linear-gradient(145deg, #f8f6fc, #fff);
}
.privacy-summary h2 { margin: 0 0 10px; font-size: 1.45rem; }
.privacy-summary p { margin-bottom: 12px; color: var(--muted); }
.privacy-summary ul { margin: 0 0 18px; padding-left: 20px; }
.privacy-summary li { margin-bottom: 6px; }
.privacy-summary a:not(.button), .consent a { color: var(--purple); font-weight: 800; }
.orv-hosted-note {
  display: flex;
  gap: 10px 18px;
  align-items: center;
  margin: 0 0 32px;
  padding: 18px 22px;
  border-left: 5px solid var(--pink);
  border-radius: 0 16px 16px 0;
  background: var(--cream);
}
.orv-hosted-note span { color: var(--muted); }
.orv-section { margin-top: 75px; }
.orv-table-wrap { overflow-x: auto; border: 1px solid #e5dfeb; border-radius: 20px; box-shadow: 0 14px 40px rgba(39,25,97,.08); }
.orv-table { width: 100%; border-collapse: collapse; background: var(--white); }
.orv-table th { padding: 17px 20px; background: var(--purple-dark); color: var(--white); text-align: left; font-size: .78rem; letter-spacing: .06em; text-transform: uppercase; }
.orv-table td { padding: 19px 20px; border-top: 1px solid #ece8f0; vertical-align: top; }
.orv-table td:first-child { width: 175px; }
.orv-table td:last-child { width: 260px; }
.orv-table td span { display: block; color: var(--muted); font-size: .8rem; }
.orv-table .orv-versus { display: inline; margin: 0 6px; }
.orv-score { color: var(--purple); font-size: 1.35rem; }
.orv-cta { margin-top: 80px; border-radius: var(--radius); overflow: hidden; }
.orv-cta .cta-inner { padding-inline: clamp(25px, 5vw, 65px); }
.contact-intro { max-width: 650px; }
.contact-intro > p { color: var(--muted); font-size: 1.08rem; }
.contact-details {
  display: grid;
  gap: 14px;
  margin-top: 38px;
}
.contact-detail {
  padding: 20px 22px;
  border-radius: 18px;
  background: var(--cream);
}
.contact-detail strong { display: block; margin-bottom: 3px; color: var(--purple); }
.contact-detail a { color: var(--ink); font-weight: 700; text-decoration: none; }
.contact-form-card {
  padding: clamp(25px, 4vw, 42px);
  border-radius: var(--radius);
  background: var(--cream);
  box-shadow: var(--shadow);
}
.contact-form-card h2 { margin-bottom: 10px; font-size: clamp(1.8rem, 3vw, 2.5rem); }
.contact-form-card > p { margin-bottom: 28px; color: var(--muted); }
.gst-form { display: grid; gap: 18px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-field { display: grid; gap: 7px; }
.form-field label, .form-legend { font-size: .85rem; font-weight: 800; }
.form-field input,
.form-field select,
.form-field textarea {
  width: 100%;
  min-height: 52px;
  padding: 12px 15px;
  border: 1px solid #d9d5e3;
  border-radius: 13px;
  outline: none;
  background: var(--white);
  color: var(--ink);
  font: inherit;
}
.form-field textarea { min-height: 150px; resize: vertical; }
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  border-color: var(--purple);
  box-shadow: 0 0 0 3px rgba(67, 49, 143, .12);
}
.form-options { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.form-option {
  position: relative;
  display: flex;
  min-height: 58px;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid #d9d5e3;
  border-radius: 13px;
  background: var(--white);
  cursor: pointer;
  font-weight: 750;
}
.form-option:has(input:checked) { border-color: var(--pink); box-shadow: 0 0 0 2px rgba(236,40,124,.12); }
.form-option input { accent-color: var(--pink); }
.consent {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: start;
  color: var(--muted);
  font-size: .78rem;
}
.consent input { margin-top: 5px; accent-color: var(--purple); }
.honeypot { position: absolute !important; left: -10000px !important; }
.form-notice {
  margin-bottom: 24px;
  padding: 15px 18px;
  border-radius: 13px;
  font-weight: 700;
}
.form-notice.success { background: #def7ed; color: #096c52; }
.form-notice.error { background: #ffe5eb; color: #9e164b; }
.sport-field[hidden] { display: none; }

@media (max-width: 900px) {
  .header-inner {
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    padding-bottom: 18px;
  }
  .site-nav {
    display: grid;
    width: 100%;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 7px;
  }
  .site-nav > a,
  body:not(.home) .site-nav > a {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 8px 9px;
    border: 1px solid rgba(255,255,255,.5);
    border-radius: 11px;
    background: rgba(24, 16, 62, .26);
    color: var(--white);
    font-size: .82rem;
    text-align: center;
  }
  body:not(.home) .site-nav > a {
    border-color: rgba(67, 49, 143, .18);
    background: var(--white);
    color: var(--ink);
  }
  .site-nav .orv-nav-link,
  body:not(.home) .site-nav .orv-nav-link {
    padding: 8px 9px;
    border-color: var(--yellow);
    color: var(--yellow);
  }
  body:not(.home) .site-nav .orv-nav-link {
    border-color: rgba(67, 49, 143, .3);
    color: var(--purple);
  }
  .site-nav .language-toggle {
    justify-content: center;
    min-height: 42px;
    padding: 8px;
    border-radius: 11px;
    background: rgba(24, 16, 62, .26);
    color: rgba(255,255,255,.55);
  }
  body:not(.home) .site-nav .language-toggle {
    background: var(--cream);
    color: var(--muted);
  }
  .site-nav .language-toggle a,
  body:not(.home) .site-nav .language-toggle a { color: inherit; }
  .site-nav .language-toggle a.active,
  body:not(.home) .site-nav .language-toggle a.active { color: var(--pink); }
  .site-nav .nav-cta,
  body:not(.home) .site-nav .nav-cta {
    border: 0;
    background: var(--pink);
    color: var(--white);
    text-align: center;
  }
  .page-main { padding-top: 250px; }
  .hero-content { padding-top: 245px; }
  .hero-facts { display: none; }
  .intro-grid, .cta-inner { grid-template-columns: 1fr; }
  .instagram-promo-inner { grid-template-columns: auto minmax(0, 1fr); }
  .instagram-promo-action { grid-column: 2; }
  .sports.section { padding-top: 72px; padding-bottom: 72px; }
  .sport-card, .sport-card:nth-child(1), .sport-card:nth-child(2) { grid-column: span 6; min-height: 280px; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid > :first-child { grid-column: 1 / -1; }
  .contact-layout { grid-template-columns: 1fr; }
  .membership-layout { grid-template-columns: 1fr; }
  .sport-link-card { grid-template-columns: 140px minmax(0, 1fr); }
  .news-grid { grid-template-columns: 1fr 1fr; }
  .news-card:last-child { display: none; }
}
@media (max-width: 620px) {
  body { font-size: 16px; }
  .wrap { width: min(100% - 28px, 1180px); }
  .brand img { width: 145px; height: 54px; }
  .header-inner {
    min-height: 68px;
    padding-bottom: 12px;
  }
  .site-nav {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 5px;
  }
  .site-nav > a,
  body:not(.home) .site-nav > a {
    min-height: 34px;
    padding: 5px 4px;
    border-radius: 9px;
    font-size: .67rem;
    line-height: 1.1;
  }
  .site-nav .language-toggle {
    min-height: 34px;
    padding: 5px 3px;
    border-radius: 9px;
    font-size: .67rem;
  }
  .site-nav .language-toggle a { font-size: .67rem; }
  .site-nav .nav-cta {
    grid-column: span 2;
  }
  .page-main { padding-top: 205px; }
  .breadcrumbs {
    width: 100%;
    margin-bottom: 22px;
    overflow-x: auto;
    padding: 4px 0 8px;
    scrollbar-width: thin;
  }
  .breadcrumbs ol {
    width: max-content;
    max-width: none;
    white-space: nowrap;
  }
  .breadcrumbs [aria-current="page"] {
    display: inline-block;
    max-width: 190px;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .site-nav .nav-cta { display: flex !important; }
  .hero { min-height: 790px; }
  .hero::before { background-position: left center; }
  .hero-content { padding-top: 205px; }
  .section-head { display: block; }
  .section-head .text-link { display: inline-block; margin-top: 20px; }
  .sport-grid { display: block; }
  .sports.section { padding-top: 58px; padding-bottom: 58px; }
  .sport-card, .sport-card:nth-child(1), .sport-card:nth-child(2) {
    min-height: 230px;
    margin-bottom: 12px;
  }
  .sport-info { inset: auto 20px 18px; }
  .sport-link-grid { grid-template-columns: 1fr; }
  .sport-link-card, .sport-link-card:last-child { grid-column: auto; grid-template-columns: 115px minmax(0, 1fr); min-height: 165px; }
  .sport-link-copy { padding: 19px; }
  .cta-inner { padding: 70px 0; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-grid > :first-child { grid-column: auto; }
  .footer-bottom { display: block; }
  .form-row, .form-options { grid-template-columns: 1fr; }
  .membership-checks { grid-template-columns: 1fr; }
  .board-grid { grid-template-columns: 1fr; }
  .board-contact { display: block; }
  .board-contact .button { margin-top: 20px; }
  .confidential-contact { grid-template-columns: 1fr; }
  .confidential-details { text-align: left; }
  .orv-hosted-note { display: block; }
  .orv-hosted-note strong { display: block; margin-bottom: 5px; }
  .orv-table thead { display: none; }
  .orv-table, .orv-table tbody, .orv-table tr, .orv-table td { display: block; width: 100%; }
  .orv-table tr { padding: 14px 18px; border-top: 1px solid #ece8f0; }
  .orv-table tr:first-child { border-top: 0; }
  .orv-table td, .orv-table td:first-child, .orv-table td:last-child { width: 100%; padding: 6px 0; border: 0; }
  .orv-table td::before { display: block; color: var(--muted); font-size: .7rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; content: attr(data-label); }
  .news-grid { grid-template-columns: 1fr; }
  .news-card:last-child { display: block; }
  .instagram-promo { padding: 55px 0; }
  .instagram-promo-inner { grid-template-columns: 1fr; }
  .instagram-icon { width: 78px; height: 78px; border-radius: 23px; }
  .instagram-promo-action { grid-column: auto; }
}
