/*
 * Site-wide shared CSS — loaded on every route (`head.php`) before page bundles.
 * Inner-route primitives (hero strip, cards, grids), `[data-reveal]`, and `layout/footer.css`.
 * Homepage source bundle: `pages/home.css` (served as `home.min.css`).
 */
@import url("layout/footer.css");

.hero {
  background: radial-gradient(circle at 80% 0%, #f6f0ff, #ffffff 42%);
  padding: var(--hero-y) 0 calc(var(--hero-y) * 0.72);
}
.kicker { color: var(--brand-red); font-weight: 700; letter-spacing: 0.06em; font-size: var(--text-xs); }
.hero h1 { max-width: 680px; font-size: var(--text-heading-hero); line-height: 1.05; margin-bottom: 14px; }
.hero h1 span { display: block; }
.hero p { max-width: 620px; }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: var(--btn-min-h);
  padding: 12px 22px;
  background: var(--brand-red);
  color: #fff;
  text-decoration: none;
  border: 2px solid var(--brand-red);
  border-radius: var(--radius);
  font-weight: 700;
  font-size: var(--text-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  transition:
    transform 0.28s cubic-bezier(0.19, 1, 0.22, 1),
    box-shadow 0.28s cubic-bezier(0.19, 1, 0.22, 1),
    background 0.2s ease,
    border-color 0.2s ease,
    color 0.2s ease;
}
.btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(225, 0, 35, 0.28);
  background: #c90b28;
  border-color: #c90b28;
}
.btn:focus-visible {
  outline: 2px solid var(--brand-navy);
  outline-offset: 3px;
}
.btn--ghost {
  background: transparent;
  color: var(--brand-red);
  border-color: rgba(225, 0, 35, 0.45);
}
.btn--ghost:hover {
  background: rgba(225, 0, 35, 0.06);
  border-color: var(--brand-red);
  box-shadow: none;
}

.section-head { margin-bottom: clamp(14px, 2vw, 22px); }
.section-head h2 { font-size: var(--text-heading-page); line-height: 1.15; }
.classes-section,
.bonuses-section,
.membership-section,
.locations-section {
  padding: var(--section-y) 0;
}

.class-collection { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.class-detail, .bonus-card, .membership-card, .location-card {
  background: #fff;
  border: 1px solid #ececf4;
  border-radius: var(--radius);
  padding: 14px;
  transition: transform .28s cubic-bezier(.19,1,.22,1), box-shadow .28s cubic-bezier(.19,1,.22,1), border-color .28s ease;
}
.class-detail:hover, .bonus-card:hover, .membership-card:hover, .location-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 26px rgba(40, 46, 112, 0.12);
  border-color: #dbdeef;
}
.class-detail h3 {
  margin-bottom: 8px;
  font-size: var(--text-xl);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.class-detail p { margin-bottom: 6px; font-size: var(--text-xs); }

.stats {
  padding: calc(var(--section-y) * 0.65) 0;
}
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.stats-grid article { background: #fff; border-radius: var(--radius); padding: 14px; text-align: center; }
.stats-grid h3 { color: var(--brand-navy); font-size: var(--text-4xl); margin-bottom: 6px; }

.stats-marquee {
  border-top: 1px solid #ececf4;
  border-bottom: 1px solid #ececf4;
  background: #fff;
  overflow: hidden;
  padding: 8px 0;
}
.marquee-track {
  display: flex;
  width: max-content;
  gap: 26px;
  animation: marquee 24s linear infinite;
}
.marquee-track span {
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: var(--text-xs);
  color: var(--brand-navy);
}
@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

.bonuses-grid, .membership-grid, .locations-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.bonus-card span { color: var(--brand-red); font-weight: 700; font-size: var(--text-2xl); }
.membership-card strong { color: var(--brand-red); font-size: var(--text-2xl); display: block; margin-top: 8px; }
.bonus-card h3, .membership-card h3, .location-card h3 {
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: var(--text-xl);
}
.inline-link {
  display: inline-block;
  margin-top: 8px;
  font-weight: 700;
  text-decoration: none;
  color: var(--brand-navy);
  text-transform: uppercase;
  font-size: var(--text-2xs);
  letter-spacing: .05em;
}
.location-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}
.location-tab {
  background: #fff;
  border: 1px solid #e3e5ef;
  border-radius: 999px;
  padding: 8px 14px;
  font: inherit;
  font-weight: 600;
  color: var(--brand-navy);
  cursor: pointer;
}
.location-tab.is-active {
  background: var(--brand-navy);
  color: #fff;
  border-color: var(--brand-navy);
}
.location-card { display: none; }
.location-card.is-active { display: block; }

.page {
  padding: var(--section-y) 0 calc(var(--section-y) * 1.1);
}
.cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.card { background: #fff; border-radius: var(--radius); padding: 14px; border: 1px solid #ececf4; }
.about-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-bottom: 14px; }
.timeline ol { margin: 0; padding-left: 18px; display: grid; gap: 8px; }
.service-membership { margin-top: 14px; }
.contacts-layout { display: grid; grid-template-columns: 1fr 1.2fr; gap: 12px; }
.contact-form { display: grid; gap: 10px; max-width: 560px; }
.contact-form .ng-field label { font-weight: 600; }
.contact-form input,
.contact-form textarea {
  border: 1px solid #d8dbe7;
  border-radius: 8px;
  padding: 10px;
  font: inherit;
  transition: border-color 0.2s ease;
}
.contact-form .ng-field.ng-has-error input,
.contact-form .ng-field.ng-has-error textarea {
  border-color: var(--brand-red);
}

.cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 4px;
}

[data-reveal] {
  opacity: 0;
  transform: translateY(18px) scale(.985);
  transition: opacity .75s cubic-bezier(.19,1,.22,1), transform .75s cubic-bezier(.19,1,.22,1);
  transition-delay: var(--reveal-delay, 0ms);
}
[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* Random-order character reveal: set data-char-reveal on a node; see home.js (single init). */
[data-char-reveal] {
  min-height: 1em;
}
[data-char-reveal] .char-reveal__char {
  display: inline-block;
  font: inherit;
  color: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  line-height: inherit;
  vertical-align: baseline;
  opacity: 0;
  transform: translate3d(0, 0.18em, 0);
}
[data-char-reveal] .char-reveal__word {
  display: inline-block;
  white-space: nowrap;
}
[data-char-reveal].is-chars-on .char-reveal__char {
  animation: charRevealIn 0.75s cubic-bezier(0.19, 1, 0.22, 1) both;
  animation-delay: var(--char-d, 0ms);
}
@keyframes charRevealIn {
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
@media (prefers-reduced-motion: reduce) {
  [data-char-reveal] .char-reveal__char {
    animation: none;
    opacity: 1;
    transform: none;
  }
}

@media (max-width: 860px) {
  .class-collection, .stats-grid, .bonuses-grid, .membership-grid, .locations-grid, .cards, .about-grid, .contacts-layout { grid-template-columns: 1fr; }
}
