/* ============================================================
   Proven Coaches & Schools page — layout styles
   Depends on colors_and_type.css + homepage.css
   ============================================================ */

/* ============================================================
   PAGE TAB STRIP
   ============================================================ */

.page-tabs {
  background: var(--brand-dark-blue);
  border-bottom: 1px solid rgba(255,255,255,0.12);
  position: sticky;
  top: 117px; /* nav 72px + subnav 45px */
  z-index: 18;
}
.page-tabs .inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 32px;
  display: flex;
}
.tab-btn {
  padding: 0 28px;
  border: none;
  border-bottom: 3px solid transparent;
  background: transparent;
  font-family: var(--font-display);
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(255,255,255,0.45);
  cursor: pointer;
  min-height: 48px;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  transition: color .15s, border-color .15s;
}
.tab-btn.active {
  color: #fff;
  border-bottom-color: var(--brand-orange);
}
.tab-btn:hover:not(.active) { color: rgba(255,255,255,0.7); }

/* Tab content visibility */
body[data-tab="coach"] .tab-ad   { display: none; }
body[data-tab="ad"]   .tab-coach { display: none; }

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

.coaches-hero {
  position: relative;
  background: var(--brand-dark-blue);
  color: #fff;
  overflow: hidden;
  padding: 48px 0 56px;
}

/* Background photo + gradient overlay */
.coaches-hero::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(105deg, rgba(25,34,77,0.94) 0%, rgba(25,34,77,0.75) 45%, rgba(246,138,50,0.80) 100%),
    url("../assets/hero-bg-coaches.jpg");
  background-size: cover;
  background-position: top right;
  pointer-events: none;
}

/* Dot-grid overlay */
.coaches-hero::after {
  content: "";
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(246,138,50,0.25) 1.2px, transparent 1.2px);
  background-size: 18px 18px;
  pointer-events: none;
}

.coaches-hero .inner {
  position: relative;
  z-index: 1;
  max-width: 1280px;
  margin: 0 auto;
  padding: 80px 32px;
  width: 100%;
}

.ch-copy .eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-size: 11px;
  color: var(--brand-light-blue);
  margin-bottom: 20px;
}
.ch-copy .eyebrow::before {
  content: "▸▸";
  color: var(--brand-orange);
  letter-spacing: -2px;
  font-size: 9px;
}

.ch-copy h1 {
  font-family: var(--font-display);
  font-weight: 900;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  font-size: clamp(44px, 5.5vw, 80px);
  line-height: 0.95;
  margin: 0 0 16px;
  overflow-wrap: break-word;
}
.ch-copy h1 .accent { color: var(--brand-orange); }

.ch-copy .lede {
  font-size: 17px;
  color: rgba(255,255,255,0.78);
  max-width: 520px;
  margin: 0 0 20px;
  line-height: 1.5;
}

.ch-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 12px;
}

.ch-copy .trust {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 10px;
  color: rgba(255,255,255,0.45);
}

/* ============================================================
   SHARED SECTION HEADING STYLES
   ============================================================ */

.sec-head { margin-bottom: 56px; }

.sec-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-size: 11px;
  color: var(--brand-orange);
  margin-bottom: 16px;
}

.sec-title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(32px, 4vw, 52px);
  letter-spacing: 0.01em;
  text-transform: uppercase;
  line-height: 1.0;
  margin: 0;
  color: var(--brand-dark-blue);
}
.sec-title .accent { color: var(--brand-orange); }

.sec-lede {
  font-size: 18px;
  color: var(--fg2);
  max-width: 620px;
  margin: 16px 0 0;
  line-height: 1.55;
}

/* ============================================================
   PAIN POINTS
   ============================================================ */

.pain-section { background: var(--surface, #F5F5F3); }

.pain-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

.pain-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 32px 28px;
}
.pain-num {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--brand-orange);
  margin-bottom: 16px;
}
.pain-card h4 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--brand-dark-blue);
  margin: 0 0 12px;
  line-height: 1.2;
}
.pain-card p {
  font-size: 15px;
  color: var(--fg2);
  margin: 0;
  line-height: 1.55;
}

/* ============================================================
   12 PILLARS (Coach tab)
   ============================================================ */

.pillars-section { background: #fff; }

.pillar-cluster-label {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--brand-orange);
  border-top: 2px solid var(--brand-orange);
  padding-top: 16px;
  margin: 40px 0 20px;
}
.pillar-cluster-label:first-of-type { margin-top: 56px; }

.pillars-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 8px;
}

.pillar-card {
  background: var(--surface, #F5F5F3);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 24px 20px;
}
.pillar-num {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 28px;
  color: rgba(25,34,77,0.12);
  line-height: 1;
  margin-bottom: 12px;
}
.pillar-card h4 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--brand-dark-blue);
  margin: 0 0 8px;
  line-height: 1.3;
}
.pillar-card p {
  font-size: 14px;
  color: var(--fg2);
  margin: 0;
  line-height: 1.5;
}

/* ============================================================
   AD VALUE CATEGORIES (AD tab)
   ============================================================ */

.ad-features-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
  margin-top: 56px;
}

.ad-feature {
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 40px 36px;
  background: #fff;
}
.ad-feature-num {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--brand-orange);
  margin-bottom: 16px;
}
.ad-feature h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 20px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--brand-dark-blue);
  margin: 0 0 16px;
  line-height: 1.2;
}
.ad-feature p {
  font-size: 16px;
  color: var(--fg2);
  margin: 0 0 20px;
  line-height: 1.55;
}
.ad-feature ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ad-feature ul li {
  font-size: 14px;
  color: var(--fg1);
  padding-left: 18px;
  position: relative;
}
.ad-feature ul li::before {
  content: "▸";
  position: absolute;
  left: 0;
  color: var(--brand-orange);
  font-size: 10px;
  top: 2px;
}

/* ============================================================
   PROVEN SCHOOL + ELITE CALLOUT (shared)
   ============================================================ */

.callout-section {
  background: var(--brand-dark-blue);
  color: #fff;
  padding: 96px 0;
}

.callout-grid {
  display: grid;
  grid-template-columns: 1fr 1px 1fr;
  gap: 64px;
  align-items: start;
}

.callout-divider { background: rgba(255,255,255,0.12); }

.callout-label {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--brand-light-blue);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.callout-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  background: var(--brand-orange);
  border-radius: 2px;
  color: #fff;
  font-size: 9px;
  font-weight: 900;
  flex-shrink: 0;
}

.callout-block h3 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(24px, 3vw, 36px);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  line-height: 1.05;
  margin: 0 0 16px;
  color: #fff;
}

.callout-block p {
  font-size: 16px;
  color: rgba(255,255,255,0.65);
  margin: 0 0 24px;
  line-height: 1.6;
}

.callout-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brand-orange);
  text-decoration: none;
  transition: gap .15s;
}
.callout-link:hover { gap: 10px; }
.callout-link .arr { font-size: 14px; }

/* ============================================================
   CTA BAND — coaches page overrides
   ============================================================ */

/* Override base grid so the single tab div fills full width */
.coaches-cta .inner {
  display: block;
}
.coaches-cta .inner > .tab-coach,
.coaches-cta .inner > .tab-ad {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap;
  width: 100%;
}
/* Re-apply hide rules with higher specificity to beat display:flex above */
body[data-tab="coach"] .coaches-cta .inner > .tab-ad  { display: none; }
body[data-tab="ad"]    .coaches-cta .inner > .tab-coach { display: none; }

/* ============================================================
   TABLET (≤1040px)
   ============================================================ */

@media (max-width: 1040px) {
  .page-tabs { top: 113px; } /* nav 68 + subnav 45 */
  .coaches-hero { padding: 64px 0 80px; }
  .coaches-hero .inner { padding: 0 24px; }
  .pain-grid { grid-template-columns: repeat(2, 1fr); }
  .pillars-grid { grid-template-columns: repeat(2, 1fr); }
  .ad-features-grid { grid-template-columns: 1fr; gap: 24px; }
  .callout-grid { grid-template-columns: 1fr; gap: 48px; }
  .callout-divider { display: none; }
}

/* ============================================================
   MOBILE (≤720px)
   ============================================================ */

@media (max-width: 720px) {
  .page-tabs { top: 149px; } /* nav 104 + subnav 45 */
  .page-tabs .inner { padding: 0 16px; }
  .tab-btn { padding: 0 20px; font-size: 11px; flex: 1; justify-content: center; }

  .coaches-hero {
    padding: 56px 0 72px;
  }
  .coaches-hero .inner { padding: 0 16px; }
  .ch-copy h1 { font-size: clamp(52px, 14vw, 72px); }
  .ch-copy .lede { font-size: 17px; }
  .ch-actions { flex-direction: column; }
  .ch-actions .btn { width: 100%; justify-content: center; }

  .sec-head { margin-bottom: 36px; }
  .pain-grid { grid-template-columns: 1fr; gap: 16px; }
  .pain-card { padding: 24px 20px; }

  .pillar-cluster-label { margin-top: 32px; }
  .pillar-cluster-label:first-of-type { margin-top: 36px; }
  .pillars-grid { grid-template-columns: 1fr; gap: 12px; }
  .pillar-card { padding: 20px 16px; }

  .ad-feature { padding: 28px 24px; }

  .callout-section { padding: 64px 0; }
  .callout-block h3 { font-size: clamp(22px, 6vw, 32px); }

  .coaches-cta .inner > .tab-coach,
  .coaches-cta .inner > .tab-ad {
    flex-direction: column;
    align-items: flex-start;
    gap: 24px;
  }
  .coaches-cta .inner > .tab-coach > div:last-child,
  .coaches-cta .inner > .tab-ad > div:last-child {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: 10px;
  }
  .coaches-cta .btn { width: 100%; justify-content: center; }
}

/* Safe area insets */
@supports (padding: env(safe-area-inset-bottom)) {
  .page-tabs {
    padding-left: env(safe-area-inset-left);
    padding-right: env(safe-area-inset-right);
  }
}

/* ============================================================
   TYPOGRAPHY POLISH — no widows/orphans
   balance: headlines/short text · pretty: longer body copy.
   Degrades to normal wrapping on unsupporting browsers.
   ============================================================ */
.coaches-hero h1, .sec-title, .sec-eyebrow, .pain-card h4,
.pillar-card h4, .pillar-cluster-label, .ad-feature h3,
.callout-block h3, .coaches-cta h2 {
  text-wrap: balance;
}
.coaches-hero .lede, .sec-lede, .pain-card p, .pillar-card p,
.ad-feature p, .ad-feature li, .callout-block p, .coaches-cta p {
  text-wrap: pretty;
}
