/* ================================================================
   Redfox Homeschool — Theme inspired by claude.ai aesthetics
   Warm cream palette · Terracotta accents · Rounded minimal forms
   ================================================================ */

/* Gilroy is loaded via @font-face below — no external font CDN needed */

/* Gilroy font-face (brand book font) */
@font-face {
  font-family: 'Gilroy';
  src: url('font/Gilroy-Light.woff2') format('woff2');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Gilroy';
  src: url('font/Gilroy-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Gilroy';
  src: url('font/Gilroy-RegularItalic.woff2') format('woff2');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: 'Gilroy';
  src: url('font/Gilroy-Medium.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Gilroy';
  src: url('font/Gilroy-Semibold.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Gilroy';
  src: url('font/Gilroy-Bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Gilroy';
  src: url('font/Gilroy-Extrabold.woff2') format('woff2');
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Gilroy';
  src: url('font/Gilroy-Black.woff2') format('woff2');
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

/* ================================================================
   CSS CUSTOM PROPERTIES — claude.ai Color System
   ================================================================ */
:root {
  /* Core backgrounds — brand book */
  --bg-color: #ffffff;
  --bg-secondary: #f7faf9;
  --bg-tertiary: #eef5f3;

  /* Text — brand book */
  --text-color: #073c39;
  --text-muted: #4d938d;
  --text-subtle: #7ab5af;

  /* Cards */
  --card-bg: #ffffff;
  --card-border: #a7ddcc;
  --card-border-hover: #4d938d;

  /* Header */
  --header-bg: rgba(255, 255, 255, 0.92);

  /* Inputs */
  --input-bg: #ffffff;

  /* Accent — brand book orange (#f25e29) */
  --accent: #f25e29;
  --accent-warm: #f47a4d;
  --accent-light: rgba(242, 94, 41, 0.12);
  --accent-glow: rgba(242, 94, 41, 0.25);

  /* Elements — brand book */
  --element-green: #a7ddcc;
  --element-peach: #ffe3d8;

  /* Shadows — soft */
  --shadow: 0 2px 12px rgba(7, 60, 57, 0.06);
  --shadow-md: 0 4px 24px rgba(7, 60, 57, 0.08);
  --shadow-lg: 0 8px 40px rgba(7, 60, 57, 0.12);

  /* Dark section (roadmap, features) */
  --dark-bg: #073c39;
  --dark-surface: #0a4a46;
  --dark-surface-2: #0d5853;
  --dark-border: rgba(167, 221, 204, 0.15);
  --dark-text: #ffffff;
  --dark-text-muted: rgba(255, 255, 255, 0.6);

  /* Footer */
  --footer-bg: var(--bg-color);

  /* Nav */
  --nav-link: #073c39;

  /* Secondary button */
  --secondary-btn-border: #a7ddcc;
  --secondary-btn-text: #073c39;

  /* Radius system */
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 20px;
  --radius-pill: 999px;

  /* Transition */
  --ease: cubic-bezier(0.25, 0.1, 0.25, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ================================================================
   BASE RESET & TYPOGRAPHY
   ================================================================ */
body {
  font-family: 'Gilroy', sans-serif;
  background-color: var(--bg-color);
  color: var(--text-color);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Override Tailwind font classes — Gilroy only */
.font-fraunces {
  font-family: 'Gilroy', sans-serif;
}

.font-plus-jakarta {
  font-family: 'Gilroy', sans-serif;
}

/* Перевизначення Tailwind bg-white/5 для теплої палітри (замість !important-кістиля) */
.bg-white\/5 {
  background-color: var(--bg-secondary);
}

/* ================================================================
   SCROLLBAR — subtle warm tint
   ================================================================ */
::-webkit-scrollbar {
  width: 6px;
}

::-webkit-scrollbar-track {
  background: var(--bg-color);
}

::-webkit-scrollbar-thumb {
  background: var(--card-border);
  border-radius: var(--radius-pill);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--accent);
}

/* ================================================================
   READING PROGRESS BAR
   ================================================================ */
#reading-progress {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 2px;
  width: 0%;
  background: linear-gradient(90deg, var(--accent), var(--accent-warm));
  transition: width 0.1s linear;
  border-radius: 0 1px 1px 0;
  z-index: 10;
  pointer-events: none;
}

/* ================================================================
   HEADER
   ================================================================ */
.header-scrolled {
  background-color: var(--header-bg) !important;
  backdrop-filter: blur(20px) saturate(160%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(160%) !important;
  border-bottom: 1px solid var(--card-border) !important;
  box-shadow: 0 1px 0 rgba(180, 140, 100, 0.1), 0 4px 20px rgba(100, 70, 40, 0.06) !important;
  padding-top: 0.75rem !important;
  padding-bottom: 0.75rem !important;
}

/* ================================================================
   NAVIGATION
   ================================================================ */
.nav-link {
  color: var(--nav-link);
  transition: color 0.2s var(--ease);
  position: relative;
  font-weight: 500;
}

.nav-link:hover {
  color: var(--accent);
}

.nav-link.is-active {
  color: var(--accent);
}

.nav-link.is-active::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--accent);
  border-radius: 1px;
}

.nav-link:focus-visible,
.nav-dropdown-btn:focus-visible,
#burger-menu-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

/* Dropdown */
.nav-dropdown-wrap {
  position: relative;
}

.nav-dropdown-wrap::before {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  width: 190px;
  height: 80px;
}

.nav-dropdown-btn {
  background: none;
  border: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  padding: 0;
  font-family: inherit;
  font-weight: 500;
}

.nav-dropdown-arrow {
  transition: transform 0.2s var(--ease);
}

.nav-dropdown-wrap:hover .nav-dropdown-arrow {
  transform: rotate(180deg);
}

.nav-dropdown-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(-6px);
  background-color: var(--card-bg);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  border: 1px solid var(--card-border);
  border-radius: var(--radius-lg);
  padding: 6px;
  min-width: 180px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.18s var(--ease), transform 0.18s var(--ease), visibility 0.18s var(--ease);
  box-shadow: var(--shadow-md);
  z-index: 100;
}

.nav-dropdown-wrap:hover .nav-dropdown-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.nav-dropdown-item {
  display: block;
  padding: 9px 14px;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--nav-link);
  text-decoration: none;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  transition: background-color 0.15s var(--ease), color 0.15s var(--ease);
}

.nav-dropdown-item:hover {
  background-color: var(--accent-light);
  color: var(--accent);
}

/* Tooltip */
.nav-tooltip-wrap {
  position: relative;
}

.nav-tooltip {
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  background-color: var(--dark-bg);
  border: 1px solid var(--dark-border);
  color: var(--dark-text);
  font-size: 0.75rem;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.2s var(--ease), visibility 0.2s var(--ease);
  box-shadow: var(--shadow-md);
}

.nav-tooltip-wrap:hover .nav-tooltip {
  opacity: 1;
  visibility: visible;
}

/* ================================================================
   BUTTONS — claude.ai style
   ================================================================ */

/* Primary CTA — єдиний блок (дублікат видалено) */
.cta-button,
.gold-button,
.roadmap__cta {
  display: inline-block;
  padding: 0.75rem 1.75rem;
  font-family: 'Gilroy', sans-serif;
  font-size: 0.9375rem;
  font-weight: 600;
  color: #ffffff;
  background-color: var(--accent);
  border: none;
  border-radius: var(--radius-pill);
  text-decoration: none;
  cursor: pointer;
  box-shadow: none;
  transition: background-color 0.2s var(--ease), box-shadow 0.2s var(--ease), transform 0.15s var(--ease);
  letter-spacing: -0.01em;
}

.cta-button:hover,
.gold-button:hover,
.roadmap__cta:hover {
  background-color: var(--accent-warm);
  box-shadow: 0 4px 16px var(--accent-glow);
  transform: translateY(-1px);
  opacity: 1;
}

.secondary-button,
.team-toggle-btn {
  display: inline-block;
  padding: 0.875rem 2rem;
  background-color: var(--card-bg);
  border: 1.5px solid var(--secondary-btn-border);
  color: var(--secondary-btn-text);
  border-radius: var(--radius-pill);
  font-family: 'Gilroy', sans-serif;
  font-size: 0.9375rem;
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.2s var(--ease);
  text-align: center;
}

.secondary-button:hover,
.team-toggle-btn:hover {
  background-color: var(--accent-light);
  color: var(--accent);
  border-color: var(--accent);
  box-shadow: none;
}

.test-cta-button {
  display: inline-block;
  padding: 0.75rem 1.75rem;
  font-family: 'Gilroy', sans-serif;
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--text-color);
  background-color: var(--card-bg);
  border: 1.5px solid var(--card-border);
  border-radius: var(--radius-pill);
  text-decoration: none;
  cursor: pointer;
  transition: border-color 0.2s var(--ease), background-color 0.2s var(--ease), color 0.2s var(--ease), transform 0.15s var(--ease);
  letter-spacing: -0.01em;
}

.secondary-button:hover,
.team-toggle-btn:hover,
.test-cta-button:hover {
  border-color: var(--accent);
  color: var(--accent);
  background-color: var(--accent-light);
  transform: translateY(-1px);
}

/* ================================================================
   FORM INPUTS
   ================================================================ */
.form-input-group input,
.form-input-group select {
  border-color: var(--card-border);
  background-color: var(--input-bg);
  border-radius: var(--radius-md);
  color: var(--text-color);
  box-shadow: inset 0 1px 2px rgba(100, 70, 40, 0.04);
  font-family: 'Gilroy', sans-serif;
  transition: border-color 0.2s var(--ease), box-shadow 0.2s var(--ease);
}

.form-input-group input:focus,
.form-input-group select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-light);
  outline: none;
}

.form-input-group input.error,
.form-input-group select.error {
  border-color: #d64235;
  box-shadow: 0 0 0 3px rgba(214, 66, 53, 0.1);
}

/* Success-message: на висоту колонки (як data-lessons-grid) і притиснутий до низу */
[data-contact-section] {
  display: flex;
  flex-direction: column;
}

#success-message:not(.hidden) {
  flex: 1 1 auto;
  margin-top: auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.error-text {
  color: #d64235;
  font-size: 0.75rem;
  margin-top: 0.25rem;
  display: none;
}

.error-text.visible {
  display: block;
}

/* ================================================================
   TEAM SWIPER NAVIGATION
   ================================================================ */
.swiper-nav-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  color: var(--text-color);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: var(--shadow-md);
  transition: background 0.2s, border-color 0.2s, color 0.2s;
}

.swiper-nav-btn:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.team-swiper-prev {
  left: -22px;
}

.team-swiper-next {
  right: -22px;
}

@media (max-width: 640px) {
  .team-swiper-prev {
    left: 0;
  }

  .team-swiper-next {
    right: 0;
  }
}

/* ================================================================
   FOR WHO SECTION CARDS
   ================================================================ */
.for-who-card {
  box-shadow: 0 4px 24px rgba(7, 60, 57, 0.10);
  transition: box-shadow 0.3s var(--ease), transform 0.3s var(--ease);
}

.for-who-card:hover {
  box-shadow: 0 12px 40px rgba(7, 60, 57, 0.18);
  transform: translateY(-4px);
}

/* ================================================================
   CARDS — claude.ai card aesthetic
   ================================================================ */
.benefit-card {
  background-color: var(--card-bg);
  border: 1px solid var(--card-border);
  box-shadow: var(--shadow);
  border-radius: var(--radius-lg) !important;
  transition: box-shadow 0.3s var(--ease), border-color 0.3s var(--ease), transform 0.3s var(--ease);
  opacity: 0;
  transform: translateY(24px);
}

.benefit-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.benefit-card.gsap-visible:hover {
  transform: translateY(-4px);
  border-color: var(--card-border-hover);
  box-shadow: var(--shadow-md);
}

.benefit-card.feature-card {
  opacity: 0;
  transform: translateY(28px);
}

.benefit-card,
.team-card,
.lesson-card,
.tariff-card {
  box-shadow: var(--shadow) !important;
  border: 1px solid var(--card-border) !important;
  border-radius: var(--radius-lg) !important;
}

.benefit-card:hover,
.team-card:hover,
.lesson-card:hover,
.tariff-card:hover {
  box-shadow: var(--shadow-md) !important;
  border-color: var(--card-border-hover) !important;
  transform: translateY(-3px) !important;
}

/* Cards managed by GSAP: visible after animation, hover works */
.team-card.team-gsap-visible,
.tariff-card.tariff-gsap-visible,
.lesson-card.lesson-gsap-visible,
.feature-card.gsap-visible {
  opacity: 1;
}

/* Fallback: if GSAP fails to load, show all cards */
.no-gsap .team-card,
.no-gsap .tariff-card,
.no-gsap .lesson-card,
.no-gsap .feature-card,
.no-gsap .benefit-card {
  opacity: 1 !important;
  transform: none !important;
}


.benefit-icon-container {
  background-color: var(--accent-light);
  border: 1px solid rgba(255, 107, 0, 0.2);
  border-radius: var(--radius-md);
}

/* ================================================================
   LESSON CARDS
   ================================================================ */
.lesson-card {
  background-color: var(--card-bg);
  border: 1px solid var(--card-border);
  box-shadow: var(--shadow);
  border-radius: var(--radius-lg);
  transition: box-shadow 0.3s var(--ease), border-color 0.3s var(--ease), transform 0.3s var(--ease);
  opacity: 0;
  transform: translateY(36px);
}

.lesson-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.lesson-card:hover {
  border-color: var(--card-border-hover);
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

/* ================================================================
   TARIFF CARDS — refined claude.ai style
   ================================================================ */

/* Base card */
.tariff-card {
  background-color: var(--card-bg);
  border: 1px solid var(--card-border);
  box-shadow: var(--shadow);
  transition: box-shadow 0.4s var(--ease), border-color 0.4s var(--ease), transform 0.4s var(--ease);
  opacity: 0;
  transform: translateY(36px);
}

.tariff-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.tariff-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
  border-color: var(--card-border-hover);
}

/* Featured (Стандарт) — accent border */
.tariff-card--featured {
  background: var(--card-bg);
  border: 1.5px solid var(--accent) !important;
  box-shadow: 0 4px 32px rgba(242, 94, 41, 0.14), var(--shadow) !important;
}

.tariff-card--featured:hover {
  box-shadow: 0 8px 48px rgba(242, 94, 41, 0.2), var(--shadow-lg) !important;
}

/* Premium (VIP) — green border */
.tariff-card--premium {
  background: var(--card-bg);
  border: 1px solid var(--card-border-hover) !important;
}

/* Badge "Найпопулярніший" */
.tariff-badge {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background-color: var(--accent);
  color: #ffffff;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 4px 14px;
  border-radius: var(--radius-pill);
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 5px;
  box-shadow: 0 2px 10px var(--accent-glow);
}

/* Tier label */
.tariff-card__tier {
  font-family: 'Gilroy', sans-serif;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-bottom: 6px;
}

.tariff-card__tier--featured {
  color: var(--accent);
}

.tariff-card__tier--premium {
  color: var(--card-border-hover);
}

/* Price */
.tariff-price {
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin-bottom: 4px;
}

.tariff-price__amount {
  font-family: 'Gilroy', sans-serif;
  font-size: 2.5rem;
  font-weight: 400;
  color: var(--accent);
  line-height: 1;
  letter-spacing: -0.02em;
}

.tariff-price__unit {
  font-family: 'Gilroy', sans-serif;
  font-size: 0.875rem;
  color: var(--text-muted);
  font-weight: 400;
}

.tariff-price__annual {
  font-size: 0.75rem;
  color: var(--text-subtle);
  margin-bottom: 12px;
}

/* Description */
.tariff-card__desc {
  font-family: 'Gilroy', sans-serif;
  font-size: 0.875rem;
  color: var(--text-muted);
  font-style: italic;
  line-height: 1.5;
  padding: 10px 14px;
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  border-left: 2px solid var(--card-border-hover);
}

/* Feature list */
.tariff-features {
  list-style: none;
  padding: 0;
  margin: 0 0 24px 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
  font-family: 'Gilroy', sans-serif;
  font-size: 0.875rem;
  color: var(--text-muted);
}

.tariff-features li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding-left: 0;
}

.tariff-features li::before {
  content: '';
  display: block;
  width: 16px;
  height: 16px;
  min-width: 16px;
  margin-top: 1px;
  background-color: var(--accent-light);
  border-radius: 50%;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f25e29' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
  background-size: 11px;
  background-repeat: no-repeat;
  background-position: center;
}

/* Discounts */
.tariff-discounts {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 20px;
  padding: 12px 14px;
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  font-family: 'Gilroy', sans-serif;
  font-size: 0.8125rem;
  color: var(--text-muted);
}

.tariff-discounts span {
  display: flex;
  align-items: center;
  gap: 6px;
}

.tariff-discounts b {
  color: var(--accent);
  font-weight: 700;
}

/* CTA buttons */
.tariff-cta {
  display: block;
  width: 100%;
  padding: 13px 20px;
  text-align: center;
  font-family: 'Gilroy', sans-serif;
  font-size: 0.9375rem;
  font-weight: 600;
  border-radius: var(--radius-pill);
  text-decoration: none;
  transition: background-color 0.2s var(--ease), border-color 0.2s var(--ease), box-shadow 0.2s var(--ease), transform 0.15s var(--ease);
  cursor: pointer;
  letter-spacing: -0.01em;
}

.tariff-cta--solid {
  background-color: var(--accent);
  color: #ffffff;
  border: 1.5px solid var(--accent);
  box-shadow: 0 4px 16px var(--accent-glow);
}

.tariff-cta--solid:hover {
  background-color: var(--accent-warm);
  border-color: var(--accent-warm);
  box-shadow: 0 6px 24px var(--accent-glow);
  transform: translateY(-1px);
  color: #ffffff;
}

.tariff-cta--outline {
  background-color: transparent;
  color: var(--accent);
  border: 1.5px solid var(--card-border);
}

.tariff-cta--outline:hover {
  border-color: var(--accent);
  background-color: var(--accent-light);
  transform: translateY(-1px);
}

/* ================================================================
   REVIEW CARDS
   ================================================================ */
.reviews-track {
  scrollbar-width: none;
  -ms-overflow-style: none;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}

.reviews-track::-webkit-scrollbar {
  display: none;
}

#reviews-swiper .swiper-slide {
  height: auto;
}

.review-card {
  height: 100%;
  display: flex;
  flex-direction: column;
  background-color: var(--card-bg);
  border: 1px solid var(--card-border);
  box-shadow: var(--shadow);
  border-radius: var(--radius-lg);
}

@media (min-width: 768px) {
  .review-card {
    flex: 0 0 calc(50% - 15px);
    min-width: 280px;
  }
}

@media (min-width: 1024px) {
  .review-card {
    flex: 0 0 calc(33.333% - 20px);
    min-width: 300px;
  }
}

/* ================================================================
   NAVIGATION ARROWS & DOTS
   ================================================================ */
.nav-arrow {
  border: 1.5px solid var(--card-border);
  color: var(--text-color);
  border-radius: var(--radius-pill);
  transition: border-color 0.2s var(--ease), background-color 0.2s var(--ease), color 0.2s var(--ease);
}

.nav-arrow:hover {
  border-color: var(--accent);
  background-color: var(--accent-light);
  color: var(--accent);
}

.dot {
  width: 8px;
  height: 8px;
  background-color: var(--card-border);
  border-radius: var(--radius-pill);
  transition: all 0.3s var(--ease);
}

.dot.active {
  width: 24px;
  background-color: var(--accent);
}

/* ================================================================
   STATS SECTION
   ================================================================ */
#stats {
  background-color: var(--card-bg);
  border-top: 1px solid var(--card-border);
  border-bottom: 1px solid var(--card-border);
}

.stats-item {
  opacity: 0;
  transform: translateY(24px);
}

.stats-item.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.stats-label {
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.4s var(--ease), transform 0.4s var(--ease);
}

.stats-item.is-visible .stats-label {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 0.2s;
}

/* ================================================================
   CTA BANNER — light, airy, claude.ai inspired
   ================================================================ */
.cta-banner-container {
  background: #ffffff;
  border-radius: var(--radius-xl);
  border: 1px solid var(--card-border);
  box-shadow: var(--shadow-md);
  opacity: 0;
  transform: scale(0.97);
  transition: opacity 0.5s var(--ease), transform 0.5s var(--ease);
  position: relative;
  overflow: hidden;
}

/* Subtle warm glow top-left */
.cta-banner-container::before {
  content: '';
  position: absolute;
  top: -60px;
  left: -60px;
  width: 280px;
  height: 280px;
  background: radial-gradient(ellipse, rgba(255, 107, 0, 0.12) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

/* Subtle warm glow bottom-right */
.cta-banner-container::after {
  content: '';
  position: absolute;
  bottom: -40px;
  right: -40px;
  width: 200px;
  height: 200px;
  background: radial-gradient(ellipse, rgba(255, 107, 0, 0.07) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.cta-banner-container>* {
  position: relative;
  z-index: 1;
}

.cta-banner-container.is-visible {
  opacity: 1;
  transform: scale(1);
}

.cta-banner-container .section-heading__subtitle {
  color: var(--accent);
}

.cta-banner-container .section-heading__title,
.cta-banner-container h2 {
  color: var(--text-color);
}

.cta-banner-container .test-cta-button {
  background-color: var(--accent);
  color: #ffffff;
  border: none;
  border-radius: var(--radius-pill);
  font-weight: 600;
  box-shadow: 0 4px 20px var(--accent-glow);
  transition: background-color 0.2s var(--ease), box-shadow 0.2s var(--ease), transform 0.15s var(--ease);
}

.cta-banner-container .test-cta-button:hover {
  background-color: var(--accent-warm);
  color: #ffffff;
  transform: translateY(-2px);
  box-shadow: 0 6px 24px var(--accent-glow);
}

/* ================================================================
   FAQ
   ================================================================ */
.faq-section-reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.faq-section-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

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

.faq-item[open] .faq-icon {
  transform: rotate(180deg);
}

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

.faq-question {
  transition: color 0.2s var(--ease);
}

/* ================================================================
   LEAD FORM REVEALS
   ================================================================ */
.lead-form-reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.lead-form-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.reviews-section-reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.reviews-section-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ================================================================
   MOBILE MENU
   ================================================================ */
#mobile-menu-overlay {
  transition: opacity 0.3s var(--ease), visibility 0.3s var(--ease);
  flex-direction: column;
}

#mobile-menu-overlay.hidden {
  opacity: 0;
  visibility: hidden;
  display: flex;
}

#mobile-menu-overlay.active {
  opacity: 1;
  visibility: visible;
  display: flex;
}

.mobile-menu-inner {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 96px 1.5rem 2.5rem;
  background-color: var(--header-bg);
  backdrop-filter: blur(24px) saturate(160%);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
  overflow-y: auto;
}

.mobile-menu-nav {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.mobile-nav-link {
  display: block;
  padding: 14px 16px;
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--nav-link);
  text-decoration: none;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  transition: background-color 0.2s var(--ease), color 0.2s var(--ease), border-color 0.2s var(--ease);
}

.mobile-nav-link:hover {
  background-color: var(--accent-light);
  color: var(--accent);
  border-color: rgba(255, 107, 0, 0.2);
}

.mobile-nav-link:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.mobile-menu-footer {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding-top: 1.5rem;
  border-top: 1px solid var(--card-border);
}

.mobile-theme-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 4px;
}

.mobile-theme-label {
  font-size: 0.875rem;
  color: var(--text-muted);
}

.mobile-nav-group {
  margin-bottom: 4px;
}

.mobile-nav-group-label {
  display: block;
  padding: 8px 16px 4px;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  opacity: 0.8;
}

.mobile-nav-sub {
  padding-left: 28px !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  opacity: 0.9;
}

.mobile-nav-primary {
  font-size: 1.0625rem;
  font-weight: 700;
  margin-top: 2px;
}

/* ================================================================
   FOOTER
   ================================================================ */
.footer-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.footer-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Footer/contact icons */
.footer-icon,
.contact-icon {
  filter: none;
  opacity: 0.6;
  transition: opacity 0.2s var(--ease);
}

a:hover .footer-icon,
a:hover .contact-icon {
  opacity: 1;
}

/* ================================================================
   TEAM SECTION
   ================================================================ */
.team-filter-btn {
  display: inline-flex;
  align-items: center;
  padding: 6px 16px;
  font-size: 0.8125rem;
  font-weight: 600;
  font-family: 'Gilroy', sans-serif;
  border-radius: var(--radius-pill);
  border: 1.5px solid var(--card-border);
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  transition: all 0.2s var(--ease);
}

.team-filter-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
  background-color: var(--accent-light);
}

.team-filter-btn.active {
  background-color: var(--accent);
  border-color: var(--accent);
  color: #ffffff;
}

#team-grid .team-card.team-card--hidden {
  display: none;
}

.team-card__photo img {
  transition: transform 0.4s var(--ease);
}

.team-card:hover .team-card__photo img {
  transform: scale(1.03);
}

.team-toggle-btn {
  scroll-margin-bottom: 3rem;
}

.team-toggle-btn .hidden {
  display: none;
}

/* ================================================================
   THEME TOGGLE
   ================================================================ */
.theme-toggle-btn {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-pill);
  background: var(--card-bg);
  border: 1.5px solid var(--card-border);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: border-color 0.2s var(--ease), transform 0.2s var(--ease), background-color 0.2s var(--ease);
  font-size: 1.125rem;
  box-shadow: var(--shadow);
}

.theme-toggle-btn:hover {
  border-color: var(--accent);
  background-color: var(--accent-light);
  transform: scale(1.05);
}

.theme-toggle-btn .moon-icon {
  display: none;
}

.theme-toggle-btn .sun-icon {
  display: block;
}

/* ================================================================
   HERO
   ================================================================ */
.hero-line {
  overflow: hidden;
  display: block;
  line-height: 1.15;
}

.hero-line-inner {
  display: block;
  will-change: transform, opacity;
}

[data-hero-sub],
[data-hero-btns],
[data-hero-contacts],
[data-hero-card] {
  opacity: 0;
}

[data-hero-bg] {
  transform: scale(1.06);
}

.hero-anim-done [data-hero-title] .hero-line-inner {
  transform: translateY(0);
}

.hero-anim-done [data-hero-sub],
.hero-anim-done [data-hero-btns],
.hero-anim-done [data-hero-contacts],
.hero-anim-done [data-hero-card] {
  opacity: 1;
}

.hero-bg-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.12;
  z-index: 0;
  pointer-events: none;
}

.hero-video-overlay {
  background: linear-gradient(to bottom,
      var(--bg-color) 0%,
      transparent 18%,
      transparent 70%,
      var(--bg-color) 100%);
  z-index: 1;
}

/* ================================================================
   HEADER ENTRANCE ANIMATION
   ================================================================ */
[data-header-logo] {
  opacity: 1;
}

[data-logo-icon] {
  opacity: 0;
}

[data-logo-text] {
  opacity: 1;
}

[data-header-actions],
#burger-menu-btn {
  opacity: 0;
}

[data-header-nav]>* {
  opacity: 0;
}

.header-anim-done [data-logo-icon],
.header-anim-done [data-logo-text] .char,
.header-anim-done [data-header-actions],
.header-anim-done #burger-menu-btn,
.header-anim-done [data-header-nav]>* {
  opacity: 1;
  transform: none;
}

[data-logo-text] .char {
  display: inline-block;
  will-change: transform, opacity;
  opacity: 0;
  transform: translateY(6px);
}

/* ================================================================
   SECTION HEADINGS
   ================================================================ */
.section-heading {
  text-align: center;
}

.section-heading__subtitle {
  font-family: 'Gilroy', sans-serif;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 0.75rem;
}

.section-heading__title {
  font-family: 'Gilroy', sans-serif;
  font-size: clamp(1.875rem, 4vw, 2.5rem);
  font-weight: 400;
  color: var(--text-color);
  letter-spacing: -0.02em;
}

.cta-banner-container .section-heading__subtitle--on-orange {
  color: var(--accent);
}

/* ================================================================
   ADVANTAGE SLIDER
   ================================================================ */
.adv-slide {
  min-width: 100%;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 24px;
}

@media (min-width: 768px) {
  .adv-slide {
    gap: 40px;
  }
}

.adv-illustration {
  flex-shrink: 0;
  display: none;
  opacity: 0.92;
}

@media (min-width: 640px) {
  .adv-illustration {
    display: block;
    width: 160px;
    height: 160px;
    margin-left: auto;
  }
}

@media (min-width: 1024px) {
  .adv-illustration {
    width: 200px;
    height: 200px;
  }
}

.adv-num {
  font-family: 'Gilroy', sans-serif;
  font-size: 3rem;
  font-weight: 400;
  line-height: 1;
  color: rgba(100, 70, 40, 0.08);
  min-width: 60px;
  padding-top: 4px;
}

@media (min-width: 768px) {
  .adv-num {
    font-size: 4rem;
    min-width: 80px;
  }
}

.adv-btn {
  width: 44px;
  height: 44px;
  border: 1.5px solid var(--card-border);
  border-radius: var(--radius-pill);
  background: var(--card-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-color);
  transition: all 0.2s var(--ease);
  cursor: pointer;
  flex-shrink: 0;
}

.adv-btn:hover:not(:disabled) {
  background: var(--accent-light);
  border-color: var(--accent);
  color: var(--accent);
}

.adv-btn:disabled {
  opacity: 0.35;
  cursor: default;
}

.adv-dots {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-right: 1rem;
}

.adv-dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-pill);
  background: var(--card-border);
  transition: all 0.3s var(--ease);
  cursor: pointer;
  border: none;
  padding: 0;
}

.adv-dot.active {
  background: var(--accent);
  width: 24px;
  border-radius: 4px;
}

.adv-progress-track {
  flex: 1;
  height: 2px;
  background: var(--card-border);
  position: relative;
  border-radius: 2px;
  overflow: hidden;
}

.adv-progress-fill {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  background: var(--accent);
  transition: width 0.3s var(--ease);
}

/* ================================================================
   ROADMAP — dark section, claude.ai dark surface
   ================================================================ */
.roadmap {
  background-color: var(--bg-color);
  padding: 5rem 1rem;
  position: relative;
  z-index: 10;
  scroll-margin-top: 6rem;
}

.roadmap__container {
  max-width: 72rem;
  margin: 0 auto;
  padding: 0 1rem;
}

.roadmap__title {
  font-family: 'Gilroy', sans-serif;
  font-size: clamp(1.875rem, 4vw, 2.5rem);
  font-weight: 400;
  color: var(--text-color);
  text-align: center;
  margin: 0 0 0.5rem;
  letter-spacing: -0.02em;
}

.roadmap__subtitle {
  font-family: 'Gilroy', sans-serif;
  font-size: 1rem;
  color: var(--text-muted);
  text-align: center;
  margin: 0 auto 4rem;
  max-width: 42rem;
  line-height: 1.6;
}

.roadmap__timeline {
  position: relative;
  display: grid;
  grid-template-columns: 28px 1fr 1fr;
  grid-template-rows: repeat(4, minmax(3rem, auto));
  gap: 1.25rem 0.5rem;
  align-content: center;
}

.roadmap__col {
  display: contents;
}

.roadmap__col--right {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1.25rem;
}

.roadmap__dots {
  display: contents;
}

@media (max-width: 767px) {
  .roadmap {
    padding: 2rem 1rem;
  }

  .roadmap__subtitle {
    margin-bottom: 2rem;
  }

  .roadmap__timeline {
    grid-template-columns: 28px 1fr 1fr;
    grid-template-rows: repeat(4, auto);
    gap: 1.25rem 0.5rem;
  }

  .roadmap__col--left .roadmap__step {
    justify-self: end;
  }

  .roadmap__col--left .roadmap__step:nth-child(1) {
    grid-area: 1 / 2;
  }

  .roadmap__col--left .roadmap__step:nth-child(2) {
    grid-area: 2 / 2;
  }

  .roadmap__col--left .roadmap__step:nth-child(3) {
    grid-area: 3 / 2;
  }

  .roadmap__col--left .roadmap__step:nth-child(4) {
    grid-area: 4 / 2;
  }

  .roadmap__col--right {
    grid-area: 1 / 3 / -1 / 4;
  }

  .roadmap__col--center .roadmap__line {
    grid-column: 1;
    grid-row: 1 / -1;
  }

  .roadmap__col--center .roadmap__dots .roadmap__dot:nth-child(1) {
    grid-area: 1 / 1;
  }

  .roadmap__col--center .roadmap__dots .roadmap__dot:nth-child(2) {
    grid-area: 2 / 1;
  }

  .roadmap__col--center .roadmap__dots .roadmap__dot:nth-child(3) {
    grid-area: 3 / 1;
  }

  .roadmap__col--center .roadmap__dots .roadmap__dot:nth-child(4) {
    grid-area: 4 / 1;
  }

  .roadmap__card {
    padding: 0.375rem 0.75rem;
  }

  .roadmap__num {
    margin-bottom: 0.125rem;
  }

  .roadmap__card-title {
    font-size: 0.8125rem;
    line-height: 1.35;
  }

  .roadmap__col--right .roadmap__step {
    position: relative;
  }

  .roadmap__col--right .roadmap__step::before {
    content: '';
    position: absolute;
    left: calc(-100% - 0.5rem - 14px);
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
  }
}

@media (min-width: 768px) {
  .roadmap__timeline {
    grid-template-columns: 1fr 14px 1fr;
    grid-template-rows: repeat(4, minmax(4rem, auto));
    gap: 1.25rem 1.5rem;
    align-content: center;
  }

  .roadmap__col--left .roadmap__step:nth-child(1) {
    grid-area: 1 / 1;
  }

  .roadmap__col--left .roadmap__step:nth-child(2) {
    grid-area: 2 / 1;
  }

  .roadmap__col--left .roadmap__step:nth-child(3) {
    grid-area: 3 / 1;
  }

  .roadmap__col--left .roadmap__step:nth-child(4) {
    grid-area: 4 / 1;
  }

  .roadmap__col--right {
    grid-area: 1 / 3 / -1 / 4;
  }

  .roadmap__col--center .roadmap__line {
    grid-column: 2;
    grid-row: 1 / -1;
  }

  .roadmap__col--center .roadmap__dots .roadmap__dot:nth-child(1) {
    grid-area: 1 / 2;
  }

  .roadmap__col--center .roadmap__dots .roadmap__dot:nth-child(2) {
    grid-area: 2 / 2;
  }

  .roadmap__col--center .roadmap__dots .roadmap__dot:nth-child(3) {
    grid-area: 3 / 2;
  }

  .roadmap__col--center .roadmap__dots .roadmap__dot:nth-child(4) {
    grid-area: 4 / 2;
  }
}

.roadmap__line {
  width: 2px;
  background: linear-gradient(to bottom, var(--accent), rgba(255, 107, 0, 0.3));
  z-index: 0;
  align-self: stretch;
  justify-self: center;
}

.roadmap__step {
  display: flex;
  align-items: center;
  position: relative;
  z-index: 1;
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.5s var(--ease), transform 0.5s var(--ease);
}

.roadmap__step.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.roadmap__col--left .roadmap__step:nth-child(1) {
  transition-delay: 0s;
}

.roadmap__col--right .roadmap__step:nth-child(1) {
  transition-delay: 0.04s;
}

.roadmap__col--left .roadmap__step:nth-child(2) {
  transition-delay: 0.08s;
}

.roadmap__col--right .roadmap__step:nth-child(2) {
  transition-delay: 0.12s;
}

.roadmap__col--left .roadmap__step:nth-child(3) {
  transition-delay: 0.16s;
}

.roadmap__col--right .roadmap__step:nth-child(3) {
  transition-delay: 0.2s;
}

.roadmap__col--left .roadmap__step:nth-child(4) {
  transition-delay: 0.24s;
}

@media (min-width: 768px) {
  .roadmap__col--left .roadmap__step {
    justify-self: end;
  }

  .roadmap__col--left .roadmap__step .roadmap__content {
    justify-content: flex-end;
  }

  .roadmap__col--right .roadmap__step .roadmap__content {
    justify-content: flex-start;
  }

  .roadmap__col--right .roadmap__step {
    position: relative;
  }

  .roadmap__col--right .roadmap__step::before {
    content: '';
    position: absolute;
    left: calc(-1.5rem - 7px);
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
  }
}

.roadmap__dot,
.roadmap__col--right .roadmap__step::before {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background-color: var(--accent);
  border: 3px solid var(--bg-color);
  box-shadow: 0 0 0 2px rgba(255, 107, 0, 0.3);
  box-sizing: border-box;
}

.roadmap__col--right .roadmap__step::before {
  content: '';
  display: block;
  position: absolute;
}

.roadmap__dot {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
  align-self: center;
  justify-self: center;
}

.roadmap__content {
  min-width: 0;
  display: flex;
}

.roadmap__card {
  background-color: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: var(--radius-lg);
  padding: 1rem;
  font-family: 'Gilroy', sans-serif;
  transition: border-color 0.2s var(--ease), box-shadow 0.2s var(--ease);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.roadmap__card:hover {
  border-color: rgba(255, 107, 0, 0.35);
  box-shadow: var(--shadow-md);
}

.roadmap__num {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--accent);
}

.roadmap__card-title {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-color);
  margin: 0;
  line-height: 1.4;
}

.roadmap__card-desc {
  font-family: 'Gilroy', sans-serif;
  font-size: 0.8125rem;
  line-height: 1.5;
  color: var(--text-muted);
  margin-top: 2px;
}

@media (min-width: 768px) {
  .roadmap__card {
    padding: 0.625rem 1rem;
    width: 320px;
    min-height: 100%;
    flex: 1;
    display: flex;
    flex-direction: column;
  }

  .roadmap__card-title {
    font-size: 1rem;
    flex: 1;
  }
}

.roadmap__cta-wrap {
  text-align: center;
  margin-top: 3rem;
}

/* ================================================================
   BENTO FEATURES — dark section
   ================================================================ */
.bento-features {
  background-color: var(--bg-color);
}

.bento-features__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

/* Two-column layout: photo left, grid right */
.bento-features__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 2.5fr);
  gap: 3rem;
  align-items: stretch;
}

.bento-features__photo-col {
  position: relative;
  min-width: 0;
  display: flex;
  align-items: center;
}

.bento-features__sticky-group {
  position: sticky;
  top: calc(50vh - 50%);
  width: 100%;
}

.bento-features__photo-wrap {
  border-radius: var(--radius-2xl, 24px);
  overflow: hidden;
  aspect-ratio: 1 / 1;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.08);
  transition: transform 0.6s var(--ease), box-shadow 0.6s var(--ease);
  background: var(--card-bg);
}

.bento-features__photo-wrap:hover {
  transform: scale(1.025);
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.12);
}

.bento-features__photo-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.8s var(--ease);
}

.bento-features__photo-wrap:hover img {
  transform: scale(1.05);
}

.bento-features__content-col {
  min-width: 0;
}

.bento-features__heading {
  text-align: left;
  position: relative;
  margin-bottom: 1.5rem;
  max-width: 100%;
}

.bento-features__heading::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 200px;
  height: 120px;
  background: radial-gradient(ellipse, rgba(255, 107, 0, 0.2) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.bento-features__eyebrow {
  font-family: 'Gilroy', sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  margin: 0 0 0.5rem;
  position: relative;
  z-index: 1;
}

.bento-features__title {
  font-family: 'Gilroy', sans-serif;
  font-size: 40px;
  font-weight: 400;
  color: var(--text-color);
  margin: 0;
  position: relative;
  z-index: 1;
  letter-spacing: -0.02em;
}

/* Bento Grid: dynamic layout with varied card sizes */
.bento-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: minmax(100px, auto);
  gap: 1rem;
  align-items: stretch;
  margin-top: 1.5rem;
}

/* Card 1: МОН — wide hero card, spans 4 cols x 2 rows */
.bento-grid .bento-card:nth-child(1) {
  grid-column: 1 / 5;
  grid-row: 1 / 3;
}

/* Card 2: З будь-якої країни — tall right, 2 cols x 2 rows */
.bento-grid .bento-card:nth-child(2) {
  grid-column: 5 / 7;
  grid-row: 1 / 3;
}

/* Card 3: Індивідуальний підхід — 3 cols */
.bento-grid .bento-card:nth-child(3) {
  grid-column: 1 / 4;
  grid-row: 3 / 4;
}

/* Card 4: 24/7 — 3 cols */
.bento-grid .bento-card:nth-child(4) {
  grid-column: 4 / 7;
  grid-row: 3 / 4;
}

/* Card 5: НМТ/ЗНО — 2 cols */
.bento-grid .bento-card:nth-child(5) {
  grid-column: 1 / 3;
  grid-row: 4 / 5;
}

/* Card 6: Гнучкий графік — 4 cols */
.bento-grid .bento-card:nth-child(6) {
  grid-column: 3 / 7;
  grid-row: 4 / 5;
}

/* Card 7: Будь-який місяць — 3 cols */
.bento-grid .bento-card:nth-child(7) {
  grid-column: 1 / 4;
  grid-row: 5 / 6;
}

/* Card 8: Онлайн-консультації — 3 cols */
.bento-grid .bento-card:nth-child(8) {
  grid-column: 4 / 7;
  grid-row: 5 / 6;
}

.bento-card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: var(--radius-xl);
  padding: 20px;
  display: flex;
  flex-direction: column;
  transition: border-color 0.3s var(--ease), transform 0.3s var(--ease), box-shadow 0.3s var(--ease);
  opacity: 0;
  transform: translateY(20px);
}

.bento-card.gsap-visible {
  opacity: 1;
  transform: translateY(0);
}

.bento-card:hover {
  border-color: rgba(255, 107, 0, 0.3);
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}



/* === Bento card individual backgrounds — all white === */
.bento-grid .bento-card:nth-child(1),
.bento-grid .bento-card:nth-child(2),
.bento-grid .bento-card:nth-child(3),
.bento-grid .bento-card:nth-child(4),
.bento-grid .bento-card:nth-child(5),
.bento-grid .bento-card:nth-child(6),
.bento-grid .bento-card:nth-child(7),
.bento-grid .bento-card:nth-child(8) {
  background: #ffffff;
  border-color: var(--card-border);
}

/* First card: hero-scale typography */
.bento-grid .bento-card:nth-child(1) {
  padding: 28px;
}

.bento-grid .bento-card:nth-child(1) .bento-card__stat {
  font-size: 36px;
  margin-bottom: 0.5rem;
}

.bento-grid .bento-card:nth-child(1) .bento-card__title {
  font-size: 1.4rem;
  margin-bottom: 0.5rem;
}

.bento-grid .bento-card:nth-child(1) .bento-card__desc {
  font-size: 0.9rem;
}

.bento-grid .bento-card:nth-child(1) .bento-card__icon {
  width: 56px;
  height: 56px;
  margin-bottom: 1.25rem;
}

.bento-grid .bento-card:nth-child(1) .bento-card__icon svg {
  width: 32px;
  height: 32px;
}

/* Second card: tall, slightly larger stat */
.bento-grid .bento-card:nth-child(2) .bento-card__stat {
  font-size: 28px;
}

/* Cards 3,4: medium emphasis */
.bento-grid .bento-card:nth-child(3) .bento-card__title,
.bento-grid .bento-card:nth-child(4) .bento-card__title {
  font-size: 1.1rem;
}

.bento-card--hero {
  grid-column: 1 / 3;
  grid-row: 1 / 3;
  background: var(--card-bg);
  padding: 28px 32px;
  position: relative;
}

.bento-card--hero .bento-card__icon--large {
  width: 64px;
  height: 64px;
  margin-bottom: 1rem;
}

.bento-card--hero .bento-card__icon--large svg {
  width: 36px;
  height: 36px;
}

.bento-card__stat,
.bento-card__stat--oversized {
  font-family: 'Gilroy', sans-serif;
  font-weight: 400;
  font-size: 20px;
  color: var(--accent);
  line-height: 1.1;
  margin-bottom: 0.25rem;
}

.bento-card__title {
  font-family: 'Gilroy', sans-serif;
  font-weight: 400;
  font-size: 1rem;
  color: var(--text-color);
  margin: 0 0 0.25rem;
  letter-spacing: -0.01em;
}

.bento-card__desc {
  font-family: 'Gilroy', sans-serif;
  font-size: 0.8125rem;
  font-weight: 400;
  color: var(--text-muted);
  line-height: 1.5;
  margin: 0;
  flex: 1;
}

.bento-card__icon {
  width: 40px;
  height: 40px;
  margin-bottom: 0.75rem;
}

.bento-card__icon svg {
  width: 24px;
  height: 24px;
}

.bento-card--photo {
  grid-column: 1 / -1;
  grid-row: span 1;
  padding: 0;
  overflow: hidden;
  min-height: 280px;
}

.bento-card--photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s var(--ease);
}

.bento-card__icon svg {
  width: 24px;
  height: 24px;
}

.bento-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  background: rgba(255, 107, 0, 0.1);
  color: var(--accent);
  transition: transform 0.35s var(--ease-spring), background-color 0.3s var(--ease);
}

.bento-card.gsap-visible:hover .bento-card__icon {
  transform: scale(1.08);
  background-color: rgba(255, 107, 0, 0.18);
}

@keyframes bento-progress-pulse {

  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: 0.85;
  }
}

@media (max-width: 1023px) {
  .bento-features__layout {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .bento-features__photo-col {
    position: static;
  }

  .bento-features__photo-wrap {
    aspect-ratio: 16 / 9;
  }

  .bento-features__heading {
    text-align: left;
  }

  .bento-grid {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: auto;
    gap: 1rem;
    align-items: stretch; /* Changed from start to stretch for equal card heights */
  }

  /* Скидаємо всі явні розміщення карток для 2-колонкової сітки */
  .bento-grid .bento-card:nth-child(1),
  .bento-grid .bento-card:nth-child(2),
  .bento-grid .bento-card:nth-child(3),
  .bento-grid .bento-card:nth-child(4),
  .bento-grid .bento-card:nth-child(5),
  .bento-grid .bento-card:nth-child(6),
  .bento-grid .bento-card:nth-child(7),
  .bento-grid .bento-card:nth-child(8) {
    grid-column: auto;
    grid-row: auto;
  }

  .bento-features__title {
    font-size: 28px;
  }

  .bento-card {
    padding: 20px;
  }
}

/* ================================================================
   FEATURE CARDS (small bento) — light section
   ================================================================ */
.feature-card {
  transition: border-color 0.3s var(--ease), transform 0.3s var(--ease), box-shadow 0.3s var(--ease);
}

.feature-card.gsap-visible:hover {
  transform: translateY(-4px) !important;
  border-color: var(--card-border-hover) !important;
  box-shadow: var(--shadow-md) !important;
}

.feature-icon {
  transition: transform 0.35s var(--ease-spring), background-color 0.3s var(--ease);
}

.feature-card.gsap-visible:hover .feature-icon {
  transform: scale(1.08);
  background-color: var(--accent-light);
}

/* ================================================================
   DIRECTOR VIDEO
   ================================================================ */
.director-video-wrapper {
  position: relative;
  aspect-ratio: 16 / 9;
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.director-video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: var(--dark-bg);
}

.director-play-overlay {
  background: linear-gradient(to top,
      rgba(28, 22, 18, 0.75) 0%,
      rgba(28, 22, 18, 0.2) 60%,
      transparent 100%);
  transition: opacity 0.3s var(--ease);
}

.director-play-overlay.hidden-overlay {
  opacity: 0;
  pointer-events: none;
}

.director-video-fallback {
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
}

.director-video-fallback.hidden {
  display: none;
}

.director-video-controls.director-controls-visible {
  opacity: 1;
  pointer-events: auto;
}

.director-video-controls {
  z-index: 2;
}

.director-video-btn {
  color: white;
}

.director-seek-bar {
  width: 100%;
  cursor: pointer;
}

.director-seek-track {
  position: relative;
  height: 4px;
  background-color: rgba(255, 240, 220, 0.15);
  border-radius: 2px;
  overflow: visible;
}

.director-seek-track:hover {
  height: 6px;
  background-color: rgba(255, 240, 220, 0.2);
}

.director-seek-progress {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 0%;
  background-color: var(--accent);
  border-radius: 2px;
  transition: width 0.05s linear;
}

.director-seek-thumb {
  position: absolute;
  top: 50%;
  left: 0%;
  width: 12px;
  height: 12px;
  margin-left: -6px;
  margin-top: -6px;
  background-color: var(--accent);
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(255, 245, 235, 0.25);
  transition: left 0.05s linear, transform 0.15s var(--ease);
  pointer-events: none;
}

.director-seek-bar:hover .director-seek-thumb {
  transform: scale(1.3);
}

/* ================================================================
   TEXT HELPERS
   ================================================================ */
.text-custom-muted {
  color: var(--text-muted);
}

/* Advantage item description line-height */
.online-advantage-item>div {
  line-height: 1.4;
}

/* ================================================================
   ANIMATIONS — ENTRY STATES (GSAP controlled)
   ================================================================ */

/* Floating */
@keyframes float {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-16px);
  }
}

.animate-float {
  animation: float 5s ease-in-out infinite;
  will-change: transform;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(18px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.reveal {
  opacity: 0;
  animation: fadeInUp 0.7s ease-out forwards;
}

.delay-1 {
  animation-delay: 0.2s;
}

.delay-2 {
  animation-delay: 0.4s;
}

.delay-3 {
  animation-delay: 0.6s;
}

/* Stats */
.stats-item {
  opacity: 0;
  transform: translateY(24px);
}

.stats-item.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* GSAP section initial states */
[data-features-heading] {
  opacity: 0;
  transform: translateY(22px);
}

[data-features-heading].is-visible {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.6s var(--ease), transform 0.6s var(--ease);
}

[data-team-title],
[data-team-subtitle],
[data-team-toggle-wrap] {
  opacity: 0;
  transform: translateY(18px);
}

/* Team cards в Swiper — opacity керується через team-anim-done або gsap-visible */
.team-card {
  opacity: 0;
  transform: translateY(24px);
  transition: box-shadow 0.3s var(--ease), border-color 0.3s var(--ease);
}

/* Swiper — однакова висота всіх карток */
.team-swiper {
  height: auto;
}

.team-swiper .swiper-wrapper {
  align-items: stretch;
}

.team-swiper .swiper-slide {
  height: auto;
  display: flex;
}

.team-swiper .team-card {
  opacity: 1 !important;
  transform: none !important;
  flex: 1;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.team-swiper .team-card__photo {
  aspect-ratio: 3 / 4;
  height: auto;
  flex-shrink: 0;
}

.team-swiper .team-card__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

.team-swiper .team-card>div:last-child {
  flex: 1;
}

.team-card.team-gsap-visible {
  transition: box-shadow 0.3s var(--ease), border-color 0.3s var(--ease), transform 0.3s var(--ease) !important;
}

.team-card.team-gsap-visible:hover .team-card__photo img {
  transform: scale(1.05);
}

.team-anim-done [data-team-title],
.team-anim-done [data-team-subtitle],
.team-anim-done [data-team-toggle-wrap] {
  opacity: 1;
  transform: none;
}

.team-anim-done .team-card:not(.team-card--hidden) {
  opacity: 1 !important;
  transform: none !important;
}

[data-lessons-title] {
  opacity: 0;
  transform: translateY(20px);
}

[data-lessons-grid] .lesson-card {
  opacity: 0;
  transform: translateY(32px) scale(0.97);
  transition: border-color 0.4s var(--ease), box-shadow 0.4s var(--ease);
}

[data-lessons-grid] .lesson-card.lesson-gsap-visible {
  transition: border-color 0.4s var(--ease), box-shadow 0.4s var(--ease), transform 0.4s var(--ease);
}

[data-lessons-grid] .lesson-card.lesson-gsap-visible:hover {
  transform: translateY(-5px) !important;
}

[data-lessons-cta] {
  opacity: 0;
  transform: translateY(22px);
}

[data-lessons-cta].lesson-gsap-visible {
  transition: background-color 0.3s var(--ease), color 0.3s var(--ease), box-shadow 0.3s var(--ease), transform 0.3s var(--ease);
}

[data-lessons-grid] .lesson-card svg {
  opacity: 0;
  transform: scale(0) rotate(-20deg);
}

.lessons-anim-done [data-lessons-title] {
  opacity: 1;
  transform: none;
}

.lessons-anim-done [data-lessons-grid] .lesson-card,
.lessons-anim-done [data-lessons-cta] {
  opacity: 1;
  transform: none;
}

.lessons-anim-done [data-lessons-grid] .lesson-card svg {
  opacity: 1;
  transform: none;
}

[data-advantages-title] {
  opacity: 0;
  transform: translateY(20px);
}

[data-advantages-section] .online-advantage-item {
  opacity: 0;
  transform: translateX(-24px);
  transition: color 0.3s var(--ease);
}

[data-advantages-section] .online-advantage-item.adv-gsap-visible {
  transition: color 0.3s var(--ease), transform 0.3s var(--ease);
}

[data-advantages-section] .online-advantage-item.adv-gsap-visible:hover {
  color: var(--text-color);
  transform: translateX(6px) !important;
}

[data-advantages-section] .checkmark-circle {
  opacity: 0;
  transform: scale(0);
}

.advantages-anim-done [data-advantages-title],
.advantages-anim-done .online-advantage-item,
.advantages-anim-done .checkmark-circle {
  opacity: 1;
  transform: none;
}

[data-tariffs-title],
[data-tariffs-subtitle] {
  opacity: 0;
  transform: translateY(20px);
}

[data-tariffs-grid] .tariff-card {
  opacity: 0;
  transform: translateY(36px) scale(0.97);
  transition: box-shadow 0.4s var(--ease), border-color 0.4s var(--ease);
}

[data-tariffs-grid] .tariff-card.tariff-gsap-visible {
  transition: box-shadow 0.4s var(--ease), border-color 0.4s var(--ease), transform 0.4s var(--ease);
}

[data-tariffs-grid] .tariff-card.tariff-gsap-visible:hover {
  transform: translateY(-10px) !important;
}

[data-tariffs-grid] .tariff-card.tariff-gsap-visible.lg\:scale-105 {
  transform: scale(1.05) !important;
}

[data-tariffs-grid] .tariff-card.tariff-gsap-visible.lg\:scale-105:hover {
  transform: scale(1.05) translateY(-10px) !important;
}

[data-tariffs-discounts] .benefit-card {
  opacity: 0;
  transform: translateY(22px);
}

.tariffs-anim-done [data-tariffs-title],
.tariffs-anim-done [data-tariffs-subtitle] {
  opacity: 1;
  transform: none;
}

.tariffs-anim-done [data-tariffs-grid] .tariff-card,
.tariffs-anim-done [data-tariffs-discounts] .benefit-card {
  opacity: 1;
  transform: none;
}

[data-reviews-title],
[data-reviews-arrows],
[data-reviews-dots] {
  opacity: 0;
}

[data-reviews-title] {
  transform: translateY(20px);
}

[data-reviews-arrows] {
  transform: translateY(-10px);
}

[data-reviews-dots] {
  transform: translateY(10px);
}

[data-reviews-track] .review-card {
  opacity: 0;
  transform: translateY(24px);
}

.reviews-anim-done [data-reviews-title],
.reviews-anim-done [data-reviews-arrows],
.reviews-anim-done [data-reviews-dots] {
  opacity: 1;
  transform: none;
}

.reviews-anim-done [data-reviews-track] .review-card {
  opacity: 1;
  transform: none;
}

[data-testcta-banner] {
  opacity: 0;
  transform: scale(0.96);
  transition: box-shadow 0.3s var(--ease);
}

[data-testcta-title] {
  opacity: 0;
  transform: translateY(18px);
}

[data-testcta-btn] {
  opacity: 0;
  transform: scale(0.88);
}

.testcta-anim-done [data-testcta-banner] {
  opacity: 1;
  transform: scale(1);
}

.testcta-anim-done [data-testcta-title] {
  opacity: 1;
  transform: none;
}

.testcta-anim-done [data-testcta-btn] {
  opacity: 1;
  transform: scale(1);
}

[data-contact-title] {
  opacity: 0;
  transform: translateY(20px);
}

[data-contact-card] {
  opacity: 0;
  transform: translateY(28px) scale(0.98);
}

[data-contact-card] .form-input-group {
  opacity: 0;
  transform: translateX(-14px);
}

[data-contact-card] button[type="submit"] {
  opacity: 0;
  transform: translateY(10px);
}

.contact-anim-done [data-contact-title] {
  opacity: 1;
  transform: none;
}

.contact-anim-done [data-contact-card] {
  opacity: 1;
  transform: none;
}

.contact-anim-done [data-contact-card] .form-input-group,
.contact-anim-done [data-contact-card] button[type="submit"] {
  opacity: 1;
  transform: none;
}

[data-footer-grid]>div {
  opacity: 0;
  transform: translateY(24px);
}

[data-footer-copy] {
  opacity: 0;
  transform: translateY(10px);
}

.footer-anim-done [data-footer-grid]>div,
.footer-anim-done [data-footer-copy] {
  opacity: 1;
  transform: none;
}

[data-faq-title],
[data-faq-cta] {
  opacity: 0;
  transform: translateY(18px);
}

[data-faq-list] .faq-item {
  opacity: 0;
  transform: translateX(-20px);
}

.faq-anim-done [data-faq-title],
.faq-anim-done [data-faq-cta] {
  opacity: 1;
  transform: none;
}

.faq-anim-done [data-faq-list] .faq-item {
  opacity: 1;
  transform: none;
}

/* ── FOR-WHO — animation initial states ── */
[data-forwho-section] .section-heading {
  opacity: 0;
  transform: translateY(20px);
}

[data-forwho-section] .for-who-card {
  opacity: 0;
  transform: translateY(32px) scale(0.97);
}

[data-forwho-section] [data-forwho-cta] {
  opacity: 0;
  transform: translateY(22px);
}

.forwho-anim-done .section-heading,
.forwho-anim-done .for-who-card,
.forwho-anim-done [data-forwho-cta] {
  opacity: 1;
  transform: none;
}

/* ── TEACHER-CONTROL — animation initial states ── */
[data-teacher-section] .section-heading {
  opacity: 0;
  transform: translateY(20px);
}

[data-teacher-section] [data-teacher-desc] {
  opacity: 0;
  transform: translateY(14px);
}

[data-teacher-section] [data-teacher-checks] .flex.items-center {
  opacity: 0;
  transform: translateX(-18px);
}

[data-teacher-section] [data-teacher-cta] {
  opacity: 0;
  transform: translateY(14px);
}

[data-teacher-section] [data-teacher-image] {
  opacity: 0;
  transform: translateX(36px);
}

.teacher-anim-done .section-heading,
.teacher-anim-done [data-teacher-desc],
.teacher-anim-done [data-teacher-checks] .flex.items-center,
.teacher-anim-done [data-teacher-cta],
.teacher-anim-done [data-teacher-image] {
  opacity: 1;
  transform: none;
}

/* ── EXTRACURRICULAR — animation initial states ── */
[data-extracurr-section] [data-extracurr-badge] {
  opacity: 0;
  transform: translateY(14px);
}

[data-extracurr-section] [data-extracurr-title] {
  opacity: 0;
  transform: translateY(24px);
}

[data-extracurr-section] .extracurr-item {
  opacity: 0;
  transform: translateX(28px);
  width: 100%; /* Ensure cards fill the space on desktop */
  max-width: 600px; /* Consistent width for a neat look */
}

.extracurr-anim-done [data-extracurr-badge],
.extracurr-anim-done [data-extracurr-title],
.extracurr-anim-done .extracurr-item {
  opacity: 1;
  transform: none;
}

/* ── INFO-DOCUMENTS — animation initial states ── */
[data-docs-section] .section-heading {
  opacity: 0;
  transform: translateY(20px);
}

[data-docs-section] [data-docs-grid]>a {
  opacity: 0;
  transform: translateY(22px);
}

.docs-anim-done .section-heading,
.docs-anim-done [data-docs-grid]>a {
  opacity: 1;
  transform: none;
}

/* Гарантований фінальний стан після завершення анімації елемента:
   перебиває inline-стилі GSAP, якщо твін перервався на півдорозі */
[data-faq-list] .faq-item.anim-done,
.extracurr-item.anim-done,
[data-docs-grid]>a.anim-done {
  opacity: 1 !important;
  transform: none !important;
}

/* Ширини карток документів (flex замість grid, щоб останній
   неповний рядок центрувався через justify-content: center) */
[data-docs-grid]>a {
  width: 100%;
}

@media (min-width: 640px) {
  [data-docs-grid]>a {
    width: calc((100% - 1rem) / 2);
  }
}

@media (min-width: 1024px) {
  [data-docs-grid]>a {
    width: calc((100% - 2rem) / 3);
  }
}

@media (min-width: 1280px) {
  [data-docs-grid]>a {
    width: calc((100% - 3rem) / 4);
  }
}

/* ── HOW IT WORKS — animation initial states ── */
[data-roadmap-section] h2 {
  opacity: 0;
  transform: translateY(28px);
}

[data-roadmap-section] p.font-inter,
[data-roadmap-section] #hiw-label,
[data-roadmap-section] .hiw-progress-track,
[data-roadmap-section] .flex.gap-3,
[data-roadmap-section] .roadmap__cta {
  opacity: 0;
}

/* Cards are always visible — opacity set by .hiw-card / .hiw-card--active.
   GSAP animates from x:28,opacity:0 → final opacity via inline style.
   Fallback: if JS never runs, cards show normally via .hiw-card CSS. */

/* Done states */
.roadmap-anim-done [data-roadmap-section] h2,
.roadmap-anim-done [data-roadmap-section] p.font-inter,
.roadmap-anim-done [data-roadmap-section] #hiw-label,
.roadmap-anim-done [data-roadmap-section] .hiw-progress-track,
.roadmap-anim-done [data-roadmap-section] .flex.gap-3,
.roadmap-anim-done [data-roadmap-section] .roadmap__cta {
  opacity: 1;
  transform: none;
}

/* Director section */
[data-director-title],
[data-director-sub],
[data-director-name],
[data-director-cta],
[data-director-video] {
  opacity: 0;
}

[data-director-title] {
  transform: translateY(20px);
}

[data-director-sub] {
  transform: translateY(14px);
}

[data-director-name] {
  transform: translateY(12px);
}

[data-director-cta] {
  transform: translateY(10px);
}

[data-director-video] {
  transform: translateX(44px);
}

.director-anim-done [data-director-title],
.director-anim-done [data-director-sub],
.director-anim-done [data-director-name],
.director-anim-done [data-director-cta],
.director-anim-done [data-director-video] {
  opacity: 1;
  transform: none;
}

/* ================================================================
   CARD GLOBAL OVERRIDES — ensure consistency across all card types
   ================================================================ */
.benefit-card,
.team-card,
.lesson-card,
.tariff-card {
  box-shadow: var(--shadow) !important;
  border: 1px solid var(--card-border) !important;
  border-radius: var(--radius-lg) !important;
}

.benefit-card:hover,
.team-card:hover,
.lesson-card:hover,
.tariff-card:hover {
  box-shadow: var(--shadow-md) !important;
  border-color: var(--card-border-hover) !important;
  transform: translateY(-3px) !important;
}

/* ================================================================
   GSAP LOAD FAILURE FALLBACK
   When GSAP/ScrollTrigger fails to load (no internet, CDN blocked),
   all initially-hidden elements animate in via pure CSS after 0.5s.
   ================================================================ */
@keyframes gsap-fallback-show {
  to {
    opacity: 1;
    transform: none;
  }
}

.no-gsap [data-hero-sub],
.no-gsap [data-hero-btns],
.no-gsap [data-hero-contacts],
.no-gsap [data-hero-card],
.no-gsap [data-header-actions],
.no-gsap #burger-menu-btn,
.no-gsap [data-header-nav]>*,
.no-gsap [data-logo-icon],
.no-gsap [data-features-heading],
.no-gsap [data-team-title],
.no-gsap [data-team-subtitle],
.no-gsap [data-team-toggle-wrap],
.no-gsap .team-card,
.no-gsap [data-lessons-title],
.no-gsap [data-lessons-grid] .lesson-card,
.no-gsap [data-lessons-grid] .lesson-card svg,
.no-gsap [data-lessons-cta],
.no-gsap [data-advantages-title],
.no-gsap [data-advantages-section] .online-advantage-item,
.no-gsap [data-advantages-section] .checkmark-circle,
.no-gsap [data-tariffs-title],
.no-gsap [data-tariffs-subtitle],
.no-gsap [data-tariffs-grid] .tariff-card,
.no-gsap [data-tariffs-discounts] .benefit-card,
.no-gsap [data-reviews-title],
.no-gsap [data-reviews-arrows],
.no-gsap [data-reviews-dots],
.no-gsap [data-reviews-track] .review-card,
.no-gsap [data-testcta-banner],
.no-gsap [data-testcta-title],
.no-gsap [data-testcta-btn],
.no-gsap [data-contact-title],
.no-gsap [data-contact-card],
.no-gsap [data-contact-card] .form-input-group,
.no-gsap [data-contact-card] button[type="submit"],
.no-gsap [data-footer-grid]>div,
.no-gsap [data-footer-copy],
.no-gsap [data-faq-title],
.no-gsap [data-faq-cta],
.no-gsap [data-faq-list] .faq-item,
.no-gsap [data-roadmap-section] h2,
.no-gsap [data-roadmap-section] p.font-inter,
.no-gsap [data-roadmap-section] #hiw-label,
.no-gsap [data-roadmap-section] .hiw-progress-track,
.no-gsap [data-roadmap-section] .flex.gap-3,
.no-gsap [data-roadmap-section] .roadmap__cta,
.no-gsap [data-director-title],
.no-gsap [data-director-sub],
.no-gsap [data-director-name],
.no-gsap [data-director-cta],
.no-gsap [data-director-video],
.no-gsap .stats-item,
.no-gsap .benefit-card,
.no-gsap .bento-card,
.no-gsap [data-logo-text] .char {
  animation: gsap-fallback-show 0.01s 0.5s forwards;
}

.no-gsap [data-roadmap-section] .hiw-card {
  opacity: 1 !important;
  transform: none !important;
}

/* ============================================
   STEPPER (how-it-works)
   ============================================ */
.stepper {
  position: relative;
  padding: 2rem 0;
}

.stepper__steps {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0;
  position: relative;
}

.stepper__steps::before {
  content: '';
  position: absolute;
  top: 22px;
  left: calc(100% / 14);
  right: calc(100% / 14);
  height: 2px;
  background: var(--accent);
  opacity: 0.2;
  z-index: 0;
}

.stepper__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  z-index: 1;
  padding: 0 8px;
}

.stepper__dot {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--bg-color);
  border: 2px solid var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  flex-shrink: 0;
}

.stepper__dot span {
  font-family: 'Gilroy', sans-serif;
  font-weight: 700;
  font-size: 14px;
  color: var(--accent);
}

.stepper__dot--accent {
  background: var(--accent);
}

.stepper__dot--accent span {
  color: #fff;
}

.stepper__title {
  font-family: 'Gilroy', sans-serif;
  font-weight: 700;
  font-size: 13px;
  line-height: 1.3;
  margin-bottom: 6px;
}

.stepper__desc {
  font-family: 'Gilroy', sans-serif;
  font-size: 11px;
  line-height: 1.5;
  color: #4d938d;
}

@media (max-width: 900px) {
  .stepper__steps {
    grid-template-columns: 1fr;
  }

  .stepper__steps::before {
    top: 22px;
    bottom: 22px;
    left: 21px;
    right: auto;
    width: 2px;
    height: auto;
  }

  .stepper__item {
    flex-direction: row;
    text-align: left;
    align-items: flex-start;
    padding: 0 0 32px 0;
    gap: 16px;
  }

  .stepper__item:last-child {
    padding-bottom: 0;
  }

  .stepper__dot {
    margin-bottom: 0;
    flex-shrink: 0;
  }

  .stepper__body {
    padding-top: 8px;
  }

  .stepper__title {
    font-size: 15px;
  }

  .stepper__desc {
    font-size: 13px;
  }
}

/* ============================================
   HOW IT WORKS — two-column (В layout)
   ============================================ */
.hiw-step {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 16px;
  align-items: start;
  background: var(--benefit-card-bg, #fff);
  border: 1px solid var(--benefit-card-border, rgba(0, 0, 0, .07));
  border-radius: 12px;
  padding: 20px;
  transition: border-color .2s;
}

.hiw-step:hover {
  border-color: var(--accent);
}

.hiw-step__num {
  font-family: 'Gilroy', sans-serif;
  font-weight: 700;
  font-size: 22px;
  color: var(--accent);
  opacity: .35;
  line-height: 1;
  padding-top: 2px;
}

.hiw-step__num--accent {
  opacity: 1;
}

.hiw-step__title {
  font-family: 'Gilroy', sans-serif;
  font-weight: 700;
  font-size: 15px;
  margin-bottom: 4px;
  color: var(--text-color);
}

.hiw-step__desc {
  font-family: 'Gilroy', sans-serif;
  font-size: 13px;
  line-height: 1.6;
  color: #4d938d;
}

.hiw-step--last {
  border-color: var(--accent);
}

/* HOW IT WORKS — overrides */
.hiw-step {
  padding: 14px 18px;
  gap: 14px;
  border-radius: 10px;
}

.hiw-step__num {
  font-size: 18px;
  padding-top: 1px;
}

.hiw-step__title {
  font-size: 14px;
  margin-bottom: 2px;
}

.hiw-step__desc {
  font-size: 12px;
}

/* ============================================
   HOW IT WORKS — connected timeline
   ============================================ */
.hiw-list {
  display: flex;
  flex-direction: column;
}

.hiw-item {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 20px;
}

.hiw-item__left {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.hiw-item__dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 2px solid var(--accent);
  background: var(--bg-color);
  flex-shrink: 0;
  margin-top: 4px;
}

.hiw-item__dot--accent {
  background: var(--accent);
}

.hiw-item__line {
  width: 2px;
  flex: 1;
  background: var(--accent);
  opacity: 0.15;
  margin: 6px 0;
  min-height: 24px;
}

.hiw-item__body {
  padding-bottom: 28px;
}

.hiw-item--last .hiw-item__body {
  padding-bottom: 0;
}

.hiw-item__num {
  display: block;
  font-family: 'Gilroy', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--accent);
  opacity: 0.5;
  margin-bottom: 4px;
}

.hiw-item__num--accent {
  opacity: 1;
}

.hiw-item__title {
  font-family: 'Gilroy', sans-serif;
  font-weight: 700;
  font-size: 15px;
  margin-bottom: 4px;
  color: var(--text-color);
}

.hiw-item__desc {
  font-family: 'Gilroy', sans-serif;
  font-size: 13px;
  line-height: 1.6;
  color: #4d938d;
}

/* ============================================
   HOW IT WORKS — scroll-driven
   ============================================ */
.hiw-steps-list {
  display: flex;
  flex-direction: column;
}

.hiw-row {
  display: grid;
  grid-template-columns: 4px 52px 1fr;
  gap: 0 20px;
  align-items: stretch;
  padding: 28px 28px 28px 0;
  border-bottom: 1px solid var(--border-color, rgba(0, 0, 0, .06));
  transition: background .3s;
  cursor: default;
}

.hiw-row--last {
  border-bottom: none;
}

.hiw-row__indicator {
  width: 4px;
  border-radius: 2px;
  background: transparent;
  transition: background .3s;
  align-self: stretch;
}

.hiw-row__num {
  font-family: 'Gilroy', sans-serif;
  font-weight: 700;
  font-size: 20px;
  color: var(--accent);
  opacity: .2;
  transition: opacity .3s;
  padding-top: 2px;
  line-height: 1;
}

.hiw-row__title {
  font-family: 'Gilroy', sans-serif;
  font-weight: 700;
  font-size: 15px;
  margin-bottom: 5px;
  color: var(--text-color);
  transition: color .3s;
}

.hiw-row__desc {
  font-family: 'Gilroy', sans-serif;
  font-size: 13px;
  line-height: 1.6;
  color: #7ab5af;
  transition: color .3s;
}

/* Active state */
.hiw-row--active {
  background: rgba(193, 95, 60, .04);
}

.hiw-row--active .hiw-row__indicator {
  background: var(--accent);
}

.hiw-row--active .hiw-row__num {
  opacity: 1;
}

.hiw-row--active .hiw-row__desc {
  color: #4d938d;
}

/* Progress bar */
.hiw-progress__track {
  height: 3px;
  background: rgba(0, 0, 0, .08);
  border-radius: 2px;
  overflow: hidden;
}

.hiw-progress__fill {
  height: 100%;
  background: var(--accent);
  border-radius: 2px;
  transition: width .4s ease;
}

@media (max-width: 1023px) {
  .hiw-progress {
    display: none;
  }

  .hiw-row {
    grid-template-columns: 4px 44px 1fr;
    padding: 20px 0;
  }

  .hiw-row--active {
    background: none;
  }

  .hiw-row__num {
    opacity: .35;
    font-size: 16px;
  }

  .hiw-row--active .hiw-row__num {
    opacity: 1;
  }
}

/* ============================================
   HOW IT WORKS — vertical carousel
   ============================================ */
/* hiw-carousel-wrap — legacy, unused */
.hiw-carousel-wrap {
  display: contents;
}

.hiw-carousel-track {
  display: contents;
}

/* hiw-card base styles — see static list section below */

.hiw-card__num {
  font-family: 'Gilroy', sans-serif;
  font-weight: 700;
  font-size: 22px;
  color: var(--accent);
  opacity: .3;
  line-height: 1;
  min-width: 40px;
  transition: opacity .35s;
}

.hiw-card--active .hiw-card__num {
  opacity: 1;
}

.hiw-card__title {
  font-family: 'Gilroy', sans-serif;
  font-weight: 700;
  font-size: 15px;
  margin-bottom: 5px;
  color: var(--text-color);
}

.hiw-card__desc {
  font-family: 'Gilroy', sans-serif;
  font-size: 13px;
  line-height: 1.6;
  color: #4d938d;
  display: none;
}

.hiw-card--active .hiw-card__desc {
  display: block;
}

/* Progress */
.hiw-progress-track {
  height: 3px;
  background: rgba(0, 0, 0, .08);
  border-radius: 2px;
  overflow: hidden;
}

.hiw-progress-fill {
  height: 100%;
  background: var(--accent);
  border-radius: 2px;
  transition: width .4s ease;
}

/* Nav buttons */
.hiw-nav-btn {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1.5px solid rgba(0, 0, 0, .12);
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--text-color);
  transition: border-color .2s, color .2s;
}

.hiw-nav-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.hiw-nav-btn:disabled {
  opacity: .3;
  cursor: default;
}

/* hiw-carousel-wrap/track — legacy removed */

/* ============================================
   HOW IT WORKS — redesigned layout & cards
   ============================================ */
.hiw-scroll-outer {
  display: none;
}

/* Two-column layout */
.hiw-layout {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 64px;
  align-items: start;
}

/* Left sticky panel */
.hiw-left {
  position: sticky;
  top: 96px;
  align-self: center;
}

/* Cards list */
.hiw-cards-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* Card base */
.hiw-card {
  display: grid;
  grid-template-columns: 56px 1fr;
  padding: 20px 20px 20px 0;
  border-radius: 16px;
  border: 1.5px solid transparent;
  background: transparent;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: border-color 0.35s var(--ease), box-shadow 0.35s var(--ease);
}

.hiw-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--card-bg);
  border-radius: 16px;
  opacity: 0;
  transition: opacity 0.35s var(--ease);
}

.hiw-card:hover::before {
  opacity: 0.6;
}

.hiw-card--active::before {
  opacity: 1;
}

.hiw-card--active {
  border-color: var(--accent);
  box-shadow: 0 4px 24px rgba(204, 120, 92, 0.14);
}

/* Number column */
.hiw-num-col {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 2px;
}

.hiw-card__num {
  font-family: 'Gilroy', sans-serif;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.02em;
  color: var(--accent);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1.5px solid var(--card-border);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: transparent;
  opacity: 0.4;
  transition: all 0.35s var(--ease);
}

.hiw-card--active .hiw-card__num {
  opacity: 1;
  border-color: var(--accent);
  background: var(--accent);
  color: #fff;
}

/* Connector line */
.hiw-connector {
  width: 1.5px;
  flex: 1;
  min-height: 12px;
  background: var(--card-border);
  margin: 5px 0;
  border-radius: 1px;
  transition: background 0.35s var(--ease);
}

.hiw-card--active .hiw-connector,
.hiw-card--done .hiw-connector {
  background: var(--accent);
}

.hiw-card:last-child .hiw-connector {
  display: none;
}

/* Body */
.hiw-card__body {
  position: relative;
  z-index: 1;
  padding-top: 2px;
}

/* Faint decorative large number */
.hiw-bg-num {
  position: absolute;
  right: -8px;
  top: -14px;
  font-family: 'Gilroy', sans-serif;
  font-size: 110px;
  font-weight: 700;
  color: var(--accent);
  opacity: 0;
  line-height: 1;
  pointer-events: none;
  transition: opacity 0.5s var(--ease), transform 0.5s var(--ease);
  transform: translateY(8px);
  z-index: 0;
}

.hiw-card--active .hiw-bg-num {
  opacity: 0.06;
  transform: translateY(0);
}

.hiw-card__title {
  font-family: 'Gilroy', sans-serif;
  font-weight: 700;
  font-size: 15px;
  color: var(--text-color);
  line-height: 1.3;
  opacity: 0.4;
  transition: opacity 0.35s var(--ease), font-size 0.35s var(--ease);
  position: relative;
  z-index: 1;
}

.hiw-card--active .hiw-card__title {
  opacity: 1;
  font-size: 16px;
}

.hiw-card__desc {
  font-family: 'Gilroy', sans-serif;
  font-size: 13.5px;
  line-height: 1.65;
  color: var(--text-muted);
  margin-top: 0;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.4s var(--ease), opacity 0.35s var(--ease), margin-top 0.3s var(--ease);
  position: relative;
  z-index: 1;
}

.hiw-card--active .hiw-card__desc {
  max-height: 120px;
  opacity: 1;
  margin-top: 7px;
}

/* Context tag chip */
.hiw-tag {
  display: inline-flex;
  align-items: center;
  margin-top: 0;
  padding: 3px 10px;
  border-radius: 999px;
  background: var(--accent-light);
  color: var(--accent);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.4s var(--ease) 0.06s, opacity 0.3s var(--ease) 0.1s, margin-top 0.3s var(--ease);
  position: relative;
  z-index: 1;
}

.hiw-card--active .hiw-tag {
  max-height: 40px;
  opacity: 1;
  margin-top: 12px;
}

/* Mobile responsive */
@media (max-width: 1023px) {
  .hiw-layout {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .hiw-left {
    position: static;
  }
}

/* Back to top */
.back-to-top {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 40;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--accent);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity 0.3s, visibility 0.3s, transform 0.3s;
  box-shadow: 0 4px 12px rgba(193, 95, 60, 0.35);
}

.back-to-top.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.back-to-top:hover {
  background: color-mix(in srgb, var(--accent) 90%, black);
  color: white;
}

/* ================================================================
   MOBILE IMPROVEMENTS — адаптація для малих екранів
   ================================================================ */

/* ── Hero Section ── */
/* Fix: data-hero-title не налазить на main-header на mobile S, M, L */
@media (max-width: 1023px) {
  #hero {
    padding-top: 8rem !important;
    /* pt-32 — більше відступу від fixed header */
  }
}

@media (max-width: 767px) {

  /* Hero text */
  #hero h1.font-lora {
    font-size: 2.5rem !important;
    line-height: 1.1 !important;
  }

  #hero p[data-hero-sub] {
    font-size: 1rem !important;
  }

  /* Hero CTA buttons – stack, full width */
  #hero [data-hero-btns] {
    flex-direction: column !important;
  }

  #hero [data-hero-btns] a {
    width: 100% !important;
    text-align: center !important;
  }

  /* Hero stats – tighter gap */
  [data-stats-grid] {
    gap: 1.25rem !important;
    margin-top: 2.5rem !important;
    padding-top: 2rem !important;
  }
}

/* ── Header ── */
@media (max-width: 767px) {
  #main-header {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }

  /* Show burger on md too (md:hidden stops at 768) */
  #burger-menu-btn {
    opacity: 1 !important;
  }

  /* Hide desktop CTA on small screens */
  [data-header-actions] {
    display: none !important;
  }
}

/* ── Sections – reduce vertical padding ── */
@media (max-width: 767px) {

  section,
  .roadmap,
  .bento-features {
    padding-top: 3.5rem !important;
    padding-bottom: 3.5rem !important;
  }

  /* Section headings */
  .section-heading__title,
  .bento-features__title,
  .roadmap__title {
    font-size: clamp(1.5rem, 6vw, 2rem) !important;
  }
}

/* ── Tariff Slider — мобільний слайдер ── */
@media (max-width: 1023px) {
  #tariffs {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }

  #tariffs>.max-w-7xl {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  #tariffs .section-heading,
  #tariffs [data-tariffs-subtitle] {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }

  #tariffs [data-tariffs-subtitle] {
    margin-bottom: 1.5rem !important;
  }

  .tariff-slider-wrap {
    overflow: hidden !important;
    position: relative !important;
  }

  [data-tariffs-grid] {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 0 !important;
    padding: 3.5rem 0 !important;
    /* Increased padding to increase overall grid height */
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
    will-change: transform !important;
    align-items: stretch !important;
  }

  [data-tariffs-grid] .tariff-card {
    flex-shrink: 0 !important;
    /* Removed width and margin overrides so Swiper can center cards correctly */
    transform: none !important;
    opacity: 1 !important;
    height: auto !important;
  }


  [data-tariffs-grid] .tariff-card.lg\:scale-105,
  [data-tariffs-grid] .tariff-card.tariff-gsap-visible.lg\:scale-105 {
    transform: none !important;
  }

  .tariff-price__amount {
    font-size: 2rem !important;
  }

  .tariff-slider-controls {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 2rem !important;
    /* More space to prevent overlap */
    margin-top: 1.25rem !important;
    padding: 0 1rem !important;
  }

  .tariff-dots {
    display: flex !important;
    gap: 10px !important;
    /* Slightly more space */
    align-items: center !important;
    justify-content: center !important;
    height: 44px !important;
    position: static !important;
    width: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    /* Clean overrides for Swiper's injection */
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
  }

  /* Target Swiper's native bullets directly to ensure they are styled correctly */
  .tariff-dots .swiper-pagination-bullet {
    width: 10px !important;
    height: 10px !important;
    border-radius: var(--radius-pill) !important;
    background: var(--card-border) !important;
    opacity: 1 !important;
    margin: 0 !important;
    /* Critical to avoid asymmetrical gaps */
    border: none !important;
    padding: 0 !important;
    cursor: pointer !important;
    transition: all 0.3s var(--ease) !important;
    flex-shrink: 0 !important;
  }

  .tariff-dots .swiper-pagination-bullet-active {
    width: 28px !important;
    background: var(--accent) !important;
    border-radius: 6px !important;
  }

  .tariff-nav-btn {
    width: 44px !important;
    height: 44px !important;
    border-radius: 50% !important;
    border: 1.5px solid var(--card-border) !important;
    background: var(--card-bg) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    color: var(--text-color) !important;
    transition: border-color 0.2s, color 0.2s !important;
    flex-shrink: 0 !important;
  }

  .tariff-nav-btn:hover:not(:disabled) {
    border-color: var(--accent) !important;
    color: var(--accent) !important;
  }

  .tariff-nav-btn:disabled {
    opacity: 0.3 !important;
    cursor: default !important;
  }
}

@media (min-width: 1024px) {
  .tariff-slider-wrap {
    display: contents !important;
  }

  .tariff-slider-controls {
    display: none !important;
  }
}

/* ── Team Grid — горизонтальний макет на мобільному ── */
@media (max-width: 639px) {

  /* Секція */
  #team {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }

  /* Одна колонка */
  #team-grid {
    grid-template-columns: 1fr !important;
    gap: 0.75rem !important;
  }

  /* Картка — горизонтальна */
  #team-grid .team-card {
    flex-direction: row !important;
    align-items: center !important;
    border-radius: 14px !important;
    overflow: hidden !important;
  }

  /* Фото — квадрат фіксованого розміру зліва */
  #team-grid .team-card__photo {
    width: 90px !important;
    min-width: 90px !important;
    height: 90px !important;
    aspect-ratio: unset !important;
    flex-shrink: 0 !important;
    border-radius: 0 !important;
  }

  #team-grid .team-card__photo img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: top center !important;
  }

  /* Текст — справа */
  #team-grid .team-card>.p-4 {
    padding: 0.75rem 0.875rem !important;
    flex: 1 !important;
    min-width: 0 !important;
  }

  #team-grid .team-card h3 {
    font-size: 0.875rem !important;
    line-height: 1.3 !important;
    margin-bottom: 0.2rem !important;
  }

  #team-grid .team-card .font-inter.text-sm {
    font-size: 0.75rem !important;
    line-height: 1.4 !important;
  }

  /* Прибрати hover-transform (заважає рядковому макету) */
  #team-grid .team-card:hover {
    transform: none !important;
  }
}

@media (min-width: 640px) and (max-width: 767px) {
  #team-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  /* На sm — зменшити aspect щоб фото не займало весь екран */
  #team-grid .team-card__photo {
    aspect-ratio: 1 / 1 !important;
  }
}

/* ── Reviews / Slider ── */
@media (max-width: 767px) {
  .review-card {
    flex: 0 0 90% !important;
    min-width: 0 !important;
  }
}

/* ── HIW — мобільна адаптація ── */
@media (max-width: 767px) {

  /* Скасовуємо початкові стани анімації — на мобільному GSAP не запускається */
  [data-roadmap-section] h2,
  [data-roadmap-section] p.font-inter,
  [data-roadmap-section] #hiw-label,
  [data-roadmap-section] .hiw-progress-track,
  [data-roadmap-section] .flex.gap-3,
  [data-roadmap-section] .roadmap__cta,
  [data-roadmap-section] .hiw-card {
    opacity: 1 !important;
    transform: none !important;
  }

  #how-it-works {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }

  [data-roadmap-section] .grid.lg\:grid-cols-\[1fr_1\.5fr\] {
    display: flex !important;
    flex-direction: column !important;
    gap: 1.5rem !important;
  }

  [data-roadmap-section] h2 {
    font-size: 2rem !important;
    line-height: 1.15 !important;
    margin-bottom: 0.5rem !important;
  }

  #hiw-prev,
  #hiw-next,
  #hiw-label,
  .hiw-progress-track {
    display: none !important;
  }

  .hiw-card {
    opacity: 1 !important;
    padding: 0.875rem 1rem !important;
  }

  .hiw-card__desc {
    display: block !important;
    font-size: 0.8125rem !important;
  }

  .hiw-card__num {
    font-size: 1.125rem !important;
    min-width: 28px !important;
  }

  .hiw-card__title {
    font-size: 0.9rem !important;
  }

  .hiw-card--active {
    border-color: var(--accent) !important;
  }

  .hiw-card--active .hiw-card__num {
    opacity: 1 !important;
  }

  .roadmap__cta {
    font-size: 0.9375rem !important;
    padding: 0.75rem 1.5rem !important;
  }
}

/* ── Contact Form ── */
@media (max-width: 767px) {

  /* Grid -> single column */
  [data-contact-card] .grid-cols-2 {
    grid-template-columns: 1fr !important;
  }
}

/* ── Footer — мобільна адаптація ── */
@media (max-width: 767px) {

  .site-footer {
    padding-top: 2rem !important;
    padding-bottom: 1.5rem !important;
  }

  /* Лого + опис — зліва, без центрування */
  .footer-col-brand {
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--card-border);
  }

  .footer-col-brand a {
    justify-content: flex-start !important;
  }

  /* Контакти — повна ширина під логотипом */
  .footer-col-contacts {
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--card-border);
  }

  /* .footer-col-info, .footer-col-partners handled by grid below */

  /* Перевизначаємо грід: лого, контакти — повна ширина,
     інфо + партнери — два стовпці */
  [data-footer-grid] {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-template-areas:
      "brand    brand"
      "contacts contacts"
      "info     partners" !important;
    gap: 1.25rem !important;
    margin-bottom: 1.25rem !important;
    text-align: left !important;
  }

  .footer-col-brand {
    grid-area: brand;
  }

  .footer-col-contacts {
    grid-area: contacts;
  }

  .footer-col-info {
    grid-area: info;
  }

  .footer-col-partners {
    grid-area: partners;
  }

  /* Заголовки колонок менші */
  .site-footer h4 {
    font-size: 0.6875rem !important;
    margin-bottom: 0.625rem !important;
  }

  /* Посилання компактніші */
  .site-footer ul li+li {
    margin-top: 0.5rem !important;
  }

  .site-footer .font-inter.text-sm {
    font-size: 0.8125rem !important;
  }

  /* Соцмережі — ліворуч */
  .footer-col-contacts .flex.gap-4 {
    justify-content: flex-start !important;
  }

  /* Копірайт — центр на мобільному */
  [data-footer-copy] {
    padding-top: 1rem !important;
  }

  [data-footer-copy] p {
    text-align: center !important;
    font-size: 0.75rem !important;
  }
}

/* ── Bento grid – prevent overflow ── */
@media (max-width: 767px) {

  .bento-card--tall:nth-of-type(2),
  .bento-card--tall:nth-of-type(3) {
    grid-column: span 1 !important;
    grid-row: span 1 !important;
  }
}

/* ── CTA banner ── */
@media (max-width: 767px) {
  .cta-banner-container {
    border-radius: var(--radius-lg) !important;
    padding: 2rem 1.25rem !important;
  }

  /* Stack CTA buttons */
  .cta-banner-container .flex.gap-4,
  .cta-banner-container .flex.flex-row {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .cta-banner-container a,
  .cta-banner-container button {
    width: 100% !important;
    text-align: center !important;
  }
}

/* ── Advantages slider — повна мобільна адаптація ── */
@media (max-width: 767px) {

  /* Секція: компактніший відступ */
  #online-advantages {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }

  /* Заголовок секції */
  #online-advantages .section-heading {
    margin-bottom: 2rem !important;
  }

  /* Обгортка слайдера — обрізає тільки горизонталь */
  #adv-slider-wrap {
    overflow: hidden !important;
    margin-bottom: 1.5rem !important;
  }

  /* Трек — горизонтальний flex, не переносить */
  #adv-track {
    display: flex !important;
    flex-wrap: nowrap !important;
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
  }

  /* Кожен слайд — точно 100% ширини контейнера, не стискується */
  .adv-slide {
    flex-direction: column !important;
    flex-shrink: 0 !important;
    min-width: 100% !important;
    width: 100% !important;
    gap: 0.75rem !important;
    padding: 0.25rem 0 !important;
    align-items: flex-start !important;
  }

  /* Велике декоративне число */
  .adv-num {
    font-size: 3.5rem !important;
    min-width: auto !important;
    line-height: 1 !important;
    padding-top: 0 !important;
    margin-bottom: 0.25rem !important;
  }

  /* Заголовок слайду */
  .adv-slide h3 {
    font-size: 1.25rem !important;
    margin-bottom: 0.5rem !important;
    line-height: 1.25 !important;
  }

  /* Опис слайду */
  .adv-slide p {
    font-size: 0.9375rem !important;
    line-height: 1.6 !important;
  }

  /* Панель керування: кнопки по краях, dots+counter посередині */
  #adv-controls {
    display: flex !important;
    align-items: center !important;
    gap: 0 !important;
    width: 100% !important;
  }

  /* Приховати progress-track на мобільному (dots достатньо) */
  .adv-progress-track {
    display: none !important;
  }

  /* Слайдер: об'єктивно Swiper вимагає position: relative для контейнера пагінації, 
     інакше Swiper.js ставить absolute і вони летять у кут */

  /* Dots — рівномірно між кнопками */
  #adv-dots {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    width: auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    margin: 0 0.5rem !important;
    flex: 1 !important;
  }

  /* Рестайлінг булетів Swiper під стиль сайту */
  .swiper-pagination-bullet {
    width: 8px !important;
    height: 8px !important;
    background: var(--text-subtle) !important;
    opacity: 0.3 !important;
    border-radius: var(--radius-pill) !important;
    transition: all 0.3s var(--ease) !important;
    margin: 0 !important;
    flex-shrink: 0;
  }

  .swiper-pagination-bullet-active {
    width: 24px !important;
    background: var(--accent) !important;
    opacity: 1 !important;
  }

  /* Counter: прибрати правий відступ */
  #adv-counter {
    margin-right: 0 !important;
    min-width: 3rem !important;
    text-align: right !important;
  }

  /* Кнопки: стабільний розмір */
  .adv-btn {
    flex-shrink: 0 !important;
    width: 44px !important;
    height: 44px !important;
  }
}

/* ── Touch targets – min 44px ── */
@media (max-width: 767px) {

  .nav-arrow,
  .adv-btn,
  .hiw-nav-btn {
    width: 48px !important;
    height: 48px !important;
  }

  .back-to-top {
    width: 48px !important;
    height: 48px !important;
    bottom: 1.25rem !important;
    right: 1.25rem !important;
  }
}

/* ── Prevent horizontal overflow ── */
@media (max-width: 767px) {
  body {
    overflow-x: hidden !important;
  }

  .max-w-7xl {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
}

/* ── FAQ items – comfortable spacing ── */
@media (max-width: 767px) {
  .faq-item summary {
    padding: 1.25rem 1rem !important;
  }

  .faq-answer {
    padding: 0 1rem 1.25rem !important;
  }
}

/* ── Roadmap – compact on mobile ── */
@media (max-width: 479px) {
  .roadmap__card-title {
    font-size: 0.75rem !important;
    line-height: 1.3 !important;
  }

  .roadmap__card {
    padding: 0.5rem !important;
  }
}

/* ================================================================
   LESSONS-STRUCTURE — desktop: заголовок зверху, грід по центру
   ================================================================ */
@media (min-width: 1024px) {
  #lessons-structure [data-lessons-grid] {
    margin-top: auto;
    margin-bottom: auto;
  }
}

/* ================================================================
   LESSONS-STRUCTURE — мобільна адаптація
   ================================================================ */
@media (max-width: 1023px) {

  /* Зовнішній двоколонковий грід → одна колонка */
  #lessons-structure .grid.lg\:grid-cols-\[1\.2fr_1fr\] {
    display: flex !important;
    flex-direction: column !important;
    gap: 2.5rem !important;
  }
}

@media (max-width: 767px) {

  /* Секція: менше відступів */
  #lessons-structure {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }

  /* Заголовок секції — менший відступ знизу */
  #lessons-structure .section-heading {
    margin-bottom: 1.5rem !important;
  }

  /* Грід карток: 2 колонки на мобільному (компактно) */
  [data-lessons-grid] {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 0.75rem !important;
    margin-bottom: 0 !important;
  }

  /* Кожна картка — менші відступи */
  [data-lessons-grid] .lesson-card {
    padding: 1rem !important;
    gap: 0.5rem !important;
  }

  /* Третя картка — розтягується на 2 колонки */
  [data-lessons-grid] .lesson-card.sm\:col-span-2 {
    grid-column: 1 / -1 !important;
  }

  /* Іконка менша */
  [data-lessons-grid] .lesson-card svg {
    width: 1.5rem !important;
    height: 1.5rem !important;
  }

  /* Заголовок картки */
  [data-lessons-grid] .lesson-card h3 {
    font-size: 0.9375rem !important;
    margin: 0 !important;
  }

  /* Текст картки */
  [data-lessons-grid] .lesson-card p {
    font-size: 0.8125rem !important;
    line-height: 1.5 !important;
  }

  /* Простір між елементами всередині картки */
  [data-lessons-grid] .lesson-card.space-y-4>*+* {
    margin-top: 0.5rem !important;
  }

  /* Форма контакту — без зайвого відступу зверху */
  #contact {
    padding-top: 0 !important;
  }

  /* Заголовок форми — компактніший */
  #contact .section-heading {
    margin-bottom: 1rem !important;
  }

  #contact [data-contact-title] {
    font-size: 1.375rem !important;
    line-height: 1.3 !important;
  }

  /* Форма: менші внутрішні відступи */
  #form-container {
    padding: 1.25rem !important;
  }

  /* Поля форми щільніші */
  #lead-form .space-y-5>*+* {
    margin-top: 0.875rem !important;
  }

  #lead-form input,
  #lead-form select {
    padding-top: 0.625rem !important;
    padding-bottom: 0.625rem !important;
    font-size: 0.9375rem !important;
  }

  /* Кнопка submit */
  #lead-form button[type="submit"] {
    padding-top: 0.875rem !important;
    padding-bottom: 0.875rem !important;
    font-size: 1rem !important;
  }
}

/* ================================================================
   FOOTER — повна ширина, злитий зі сторінкою
   ================================================================ */
.site-footer {
  display: block;
  width: 100%;
  background-color: var(--bg-color);
  border-top: 1px solid var(--card-border);
  box-sizing: border-box;
  margin: 0;
}

html {
  overflow-x: hidden;
}

body {
  width: 100%;
  overflow-x: hidden;
}

/* ================================================================
   SCROLL ANCHORS — компенсація висоти fixed header (~72px)
   ================================================================ */
#how-it-works,
#features,
#team,
#online-advantages,
#tariffs,
#reviews,
#lessons-structure,
#contact,
#faq {
  scroll-margin-top: 80px;
}

/* Prevent background scrolling */
html.no-scroll,
body.no-scroll {
  overflow: hidden !important;
  height: 100% !important;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: none !important;
}

/* Hide header during popups/lightbox for better focus */
html.no-scroll #main-header {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* Documents popup */
/* ── Consultation modal (форма заявки у попапі) ── */
.consult-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 110;
  background: rgba(26, 22, 17, 0.6);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 1.5rem;
  overflow-y: auto;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s, visibility 0.3s;
}

.consult-modal-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.consult-modal {
  position: relative;
  background: var(--card-bg);
  border-radius: 20px;
  width: 100%;
  max-width: 540px;
  margin: auto;
  box-shadow: 0 24px 80px rgba(26, 22, 17, 0.25);
  transform: scale(0.96);
  transition: transform 0.3s;
}

.consult-modal-overlay.is-open .consult-modal {
  transform: scale(1);
}

.consult-modal-body {
  padding: 2rem 1.75rem 2.25rem;
}

/* Усередині попапа прибираємо зовнішні рамки/тінь картки — їх дає сам попап */
.consult-modal-body [data-contact-card] {
  box-shadow: none !important;
  border: none !important;
  padding: 0 !important;
}

.consult-modal-body .section-heading {
  margin-bottom: 1.25rem !important;
}

.consult-modal-close {
  position: absolute;
  top: 0.85rem;
  right: 0.85rem;
  z-index: 2;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.06);
  color: var(--text-color);
  transition: background 0.2s, color 0.2s;
}

.consult-modal-close:hover {
  background: var(--accent-light);
  color: var(--accent);
}

.documents-popup-overlay {
  touch-action: none; /* Prevent touch gestures from reaching the background */
  position: fixed;
  inset: 0;
  z-index: 100;
  background: rgba(26, 22, 17, 0.6);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s, visibility 0.3s;
}

.documents-popup-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.documents-popup-overlay[aria-hidden="true"] {
  pointer-events: none;
}

.documents-popup-overlay[aria-hidden="false"] {
  pointer-events: auto;
}

.documents-popup {
  position: relative;
  background: var(--card-bg);
  border-radius: 20px;
  max-width: 900px;
  max-height: 90vh;
  width: 100%;
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(26, 22, 17, 0.25);
  transform: scale(0.95);
  transition: transform 0.3s;
}

.documents-popup-overlay.is-open .documents-popup {
  transform: scale(1);
}

.documents-popup-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 2;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.06);
  color: var(--text-color);
  transition: background 0.2s, color 0.2s;
}

.documents-popup-close:hover {
  background: var(--accent-light);
  color: var(--accent);
}

.documents-popup-content {
  padding: 2rem 2rem 2.5rem;
  overflow-y: auto;
  max-height: 85vh;
}

.documents-thumb-img {
  max-width: 140px;
  max-height: 180px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid var(--card-border);
  transition: border-color 0.2s;
}

.documents-thumb-img:hover {
  border-color: var(--accent);
}

.documents-thumb-img--statut {
  max-width: 100px;
  max-height: 140px;
}

.doc-zoom-img {
  cursor: pointer;
}

/* Image lightbox */
.doc-lightbox-overlay {
  touch-action: none;
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(26, 22, 17, 0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s, visibility 0.3s;
}

.doc-lightbox-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.doc-lightbox-overlay[aria-hidden="true"] {
  pointer-events: none;
}

.doc-lightbox-overlay[aria-hidden="false"] {
  pointer-events: auto;
}

.doc-lightbox-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 3;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.15);
  color: white;
  transition: background 0.2s;
}

.doc-lightbox-close:hover {
  background: var(--accent);
}

.doc-lightbox-prev,
.doc-lightbox-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10; /* Above the image */
  width: 54px; /* Slightly larger for mobile tap targets */
  height: 54px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(26, 22, 17, 0.4); /* Darker for better contrast */
  color: white;
  transition: background 0.2s, opacity 0.2s, transform 0.2s;
  backdrop-filter: blur(4px);
}

.doc-lightbox-prev:hover,
.doc-lightbox-next:hover {
  background: var(--accent);
}

.doc-lightbox-prev {
  left: 0.5rem;
}
.doc-lightbox-next {
  right: 0.5rem;
}

@media (min-width: 1024px) {
  .doc-lightbox-prev { left: 2rem; }
  .doc-lightbox-next { right: 2rem; }
}

.doc-lightbox-prev.is-hidden,
.doc-lightbox-next.is-hidden {
  opacity: 0;
  pointer-events: none;
}

.doc-lightbox-img {
  max-width: 95vw;
  max-height: 90vh;
  object-fit: contain;
  border-radius: 8px;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.4);
}

/* ================================================================
   ANIMATIONS.JS SUPPORT STYLES
   ================================================================ */

/* FAQ Accordion — GSAP controls height; overflow:hidden enables animation */
.faq-answer {
  overflow: hidden;
}

/* Remove native <details> disclosure triangle */
.faq-item>summary {
  list-style: none;
}

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

/* Teacher photos: GPU-accelerate scale hover (GSAP) */
.team-card__photo img {
  transform-origin: center center;
  will-change: transform;
}


/* Lenis: disable CSS scroll-behavior to let Lenis handle it */
html {
  scroll-behavior: auto !important;
}

/* ── SWIPER CUSTOM PAGINATION ── */
.swiper-pagination-bullet {
  background: var(--text-subtle) !important;
  opacity: 0.3 !important;
  transition: all 0.3s var(--ease) !important;
}

.swiper-pagination-bullet-active {
  background: var(--accent) !important;
  opacity: 1 !important;
  width: 28px !important;
  border-radius: var(--radius-pill) !important;
}

/* Fix positioning for out-of-container pagination */
.swiper-pagination-lock {
  display: none !important;
}

#reviews-dots,
[data-reviews-dots] {
  position: relative !important;
  bottom: auto !important;
  left: auto !important;
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 8px !important;
  margin-top: 3rem !important;
}

#adv-dots {
  position: relative !important;
  bottom: auto !important;
  left: auto !important;
  width: auto !important;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}

/* Desktop sizing for bullets */
@media (min-width: 768px) {
  .swiper-pagination-bullet {
    width: 10px !important;
    height: 10px !important;
  }

  .swiper-pagination-bullet-active {
    width: 32px !important;
  }
}

/* ================================================================
   RESPONSIVE — Mobile S (≤ 374px)
   ================================================================ */
@media (max-width: 374px) {

  /* Header: зменшити лого-текст */
  [data-header-logo] {
    font-size: 0.875rem !important;
    gap: 0.375rem !important;
  }

  [data-logo-icon] {
    width: 32px !important;
  }

  /* Hero: зменшити заголовок */
  h1.font-fraunces {
    font-size: clamp(1.5rem, 8vw, 2rem) !important;
  }

  /* Bento grid → 1 колонка, скидаємо всі розміщення карток */
  .bento-grid {
    grid-template-columns: 1fr !important;
    grid-auto-rows: auto !important;
    gap: 0.75rem !important;
  }

  .bento-grid .bento-card:nth-child(1),
  .bento-grid .bento-card:nth-child(2),
  .bento-grid .bento-card:nth-child(3),
  .bento-grid .bento-card:nth-child(4),
  .bento-grid .bento-card:nth-child(5),
  .bento-grid .bento-card:nth-child(6),
  .bento-grid .bento-card:nth-child(7),
  .bento-grid .bento-card:nth-child(8) {
    grid-column: 1 / -1 !important;
    grid-row: auto !important;
  }

  /* Feature cards → 1 колонка */
  .benefit-card.feature-card {
    padding: 1rem !important;
  }

  /* Секції: менші відступи */
  section,
  .roadmap,
  .bento-features {
    padding-top: 2.5rem !important;
    padding-bottom: 2.5rem !important;
  }

  /* Зменшити padding контейнерів */
  .max-w-7xl {
    padding-left: 0.75rem !important;
    padding-right: 0.75rem !important;
  }

  /* Позакласні заняття — менший шрифт */
  .extras-section h2 {
    font-size: 1.75rem !important;
  }

  /* Тарифи — вужчі картки */
  [data-tariffs-grid] .tariff-card {
    width: 85vw !important;
    margin: 0 0.375rem !important;
  }

  /* Footer — одна колонка */
  [data-footer-grid] {
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "brand"
      "contacts"
      "info"
      "partners" !important;
  }
}

/* ================================================================
   RESPONSIVE — Mobile M (375–479px)
   ================================================================ */
@media (min-width: 375px) and (max-width: 479px) {

  /* Header: коректний розмір */
  [data-header-logo] {
    font-size: 1rem !important;
    gap: 0.5rem !important;
  }

  /* Bento grid — 2 колонки, але менший gap */
  .bento-grid {
    gap: 0.75rem !important;
  }

  .bento-card {
    padding: 1rem !important;
  }
}

/* ================================================================
   RESPONSIVE — Mobile L (480–639px)
   ================================================================ */
@media (min-width: 480px) and (max-width: 639px) {

  /* Bento grid — 2 колонки з нормальним gap */
  .bento-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 1rem !important;
  }
}

/* ================================================================
   RESPONSIVE — Tablet (768–1023px)
   ================================================================ */
@media (min-width: 768px) and (max-width: 1023px) {

  /* Header: CTA кнопка — менший розмір */
  [data-header-actions] .cta-button {
    font-size: 0.75rem !important;
    padding: 0.5rem 1rem !important;
    white-space: nowrap !important;
  }

  /* Footer — 2 колонки з правильним розподілом */
  [data-footer-grid] {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-template-areas:
      "brand    contacts"
      "info     partners" !important;
    gap: 1.5rem !important;
  }

  .footer-col-brand {
    grid-area: brand;
  }

  .footer-col-contacts {
    grid-area: contacts;
  }

  .footer-col-info {
    grid-area: info;
  }

  .footer-col-partners {
    grid-area: partners;
  }

  /* Bento features layout — 1 col */
  .bento-features__layout {
    grid-template-columns: 1fr !important;
  }

  /* Bento grid — 2 колонки, як на телефонах */
  .bento-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  /* Фото в bento та "Учитель завжди поруч" — обмежити розмір */
  .bento-features__photo-wrap {
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
  }

  [data-teacher-section] img[data-teacher-image] {
    max-width: 480px;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    margin-left: auto;
    margin-right: auto;
  }

  /* Team grid — 2 колонки */
  #team-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* ================================================================
   RESPONSIVE — Laptop (1024–1279px)
   ================================================================ */
@media (min-width: 1024px) and (max-width: 1279px) {

  /* Footer — 4 колонки з меншими gap */
  [data-footer-grid] {
    grid-template-columns: 1.5fr 1fr 1fr 1fr !important;
    gap: 1.25rem !important;
  }

  /* Навігація — менший spacing */
  [data-header-nav] {
    gap: 1rem !important;
  }

  .nav-link {
    font-size: 0.8125rem !important;
  }
}

/* ================================================================
   DISABLE HOVER JUMPS & ANIMATIONS ON MOBILE (S, M, L)
   ================================================================ */
@media (max-width: 1023px) {

  /* Вимкнення анімацій при натисканні (tap/click) — ПОВНЕ ЗАБОРОНА РУХУ */
  .faq-question,
  .faq-question *,
  .faq-question::before,
  .faq-question::after,
  .extracurr-item,
  .extracurr-item *,
  .extracurr-item::before,
  .extracurr-item::after,
  .benefit-card,
  .benefit-card *,
  .benefit-card::before,
  .benefit-card::after {

    transform: none !important;
  }

  /* Для FAQ дозволяємо лише миттєвий поворот іконки без анімації */
  .faq-item[open] .faq-icon {
    transform: rotate(180deg) !important;
  }
}