/* =====================================================
   WHITE LOTUS — Глобальный CSS для Tilda
   Настройки сайта → Добавление CSS-кода
   ===================================================== */

/* ---------- ШРИФТЫ ---------- */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300;1,400&family=Jost:wght@300;400;500;600&display=swap');

/* ---------- ОБЩИЕ КНОПКИ ---------- */
.wl-btn-gold {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-family: 'Jost', sans-serif !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: .22em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  color: #1a0e08 !important;
  background: linear-gradient(135deg, #c9a87c, #b3895a) !important;
  border: none !important;
  border-radius: 12px !important;
  padding: 15px 32px !important;
  cursor: pointer !important;
  transition: opacity .18s !important;
}
.wl-btn-gold:hover { opacity: .88 !important; }

.wl-btn-outline {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-family: 'Jost', sans-serif !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: .22em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  color: rgba(255,255,255,.6) !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  background: transparent !important;
  border-radius: 12px !important;
  padding: 15px 28px !important;
  cursor: pointer !important;
  transition: color .18s, border-color .18s !important;
}
.wl-btn-outline:hover {
  color: rgba(255,255,255,.9) !important;
  border-color: rgba(255,255,255,.4) !important;
}

/* ---------- ПОПАП — запись на курс ---------- */
/* Используется в hero-блоках всех курсов */
.wl-popup {
  display: none;
  position: fixed !important;
  inset: 0 !important;
  z-index: 99999 !important;
  background: rgba(10,8,6,.6) !important;
  backdrop-filter: blur(8px) !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px !important;
}
.wl-popup.open { display: flex !important; }

.wl-popup-box {
  background: #fff !important;
  border-radius: 28px !important;
  width: 100% !important;
  max-width: 552px !important;
  position: relative !important;
  font-family: 'Jost', sans-serif !important;
  overflow: hidden !important;
  box-shadow: 0 40px 100px rgba(10,8,6,.25) !important;
}

.wl-popup-head {
  background: #FFF4EC !important;
  padding: 32px 36px 26px !important;
  position: relative !important;
  border-bottom: 1px solid rgba(201,168,124,.2) !important;
  overflow: hidden !important;
}
.wl-popup-head::before {
  content: '' !important;
  position: absolute !important;
  top: -40px !important; right: -40px !important;
  width: 160px !important; height: 160px !important;
  border-radius: 50% !important;
  background: rgba(201,168,124,.15) !important;
  pointer-events: none !important;
}

.wl-popup-x {
  position: absolute !important;
  top: 16px !important; right: 16px !important;
  width: 32px !important; height: 32px !important;
  background: rgba(26,10,4,.07) !important;
  border: none !important;
  border-radius: 50% !important;
  color: rgba(26,10,4,.4) !important;
  font-size: 16px !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  padding: 0 !important;
}
.wl-popup-x:hover { background: rgba(26,10,4,.12) !important; }

.wl-popup-label {
  font-size: 10px !important;
  letter-spacing: .26em !important;
  text-transform: uppercase !important;
  color: #c4745a !important;
  margin-bottom: 10px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}
.wl-popup-label::before {
  content: '' !important;
  width: 16px !important; height: 1px !important;
  background: #c9a87c !important;
  display: block !important;
}

.wl-popup-title {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 30px !important;
  font-weight: 300 !important;
  color: #1a0a04 !important;
  line-height: 1.15 !important;
  margin: 0 !important;
}

.wl-popup-body {
  padding: 28px 36px 36px !important;
  background: #fff !important;
}

.wl-popup input {
  display: block !important;
  width: 100% !important;
  background: #F8F5F1 !important;
  border: 1.5px solid #E5DDD5 !important;
  border-radius: 14px !important;
  padding: 14px 18px !important;
  color: #1a0a04 !important;
  font-size: 15px !important;
  font-family: 'Jost', sans-serif !important;
  outline: none !important;
  margin-bottom: 12px !important;
  box-sizing: border-box !important;
  transition: border-color .2s !important;
}
.wl-popup input:focus { border-color: #c9a87c !important; background: #fff !important; }
.wl-popup input::placeholder { color: rgba(26,10,4,.3) !important; }

.wl-popup-send {
  display: block !important;
  width: 100% !important;
  background: linear-gradient(135deg, #c9a87c, #b3895a) !important;
  color: #1a0e08 !important;
  border: none !important;
  border-radius: 14px !important;
  padding: 16px !important;
  font-family: 'Jost', sans-serif !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: .2em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  margin-bottom: 14px !important;
  box-shadow: 0 6px 20px rgba(175,135,55,.28) !important;
  box-sizing: border-box !important;
}
.wl-popup-send:hover { opacity: .9 !important; }

.wl-popup-priv {
  display: block !important;
  text-align: center !important;
  font-size: 11px !important;
  color: rgba(26,10,4,.3) !important;
  line-height: 1.5 !important;
  margin: 0 !important;
}
.wl-popup-priv a { color: #c4745a !important; text-decoration: none !important; }

/* ---------- КАРТОЧКИ РАСПИСАНИЯ ---------- */
.wl-scard {
  display: flex !important;
  align-items: stretch !important;
  background: #FDF7F0 !important;
  border-radius: 16px !important;
  overflow: hidden !important;
}
.wl-scard-left {
  min-width: 220px !important; max-width: 220px !important;
  padding: 22px 20px !important;
  background: #FDF7F0 !important;
  border-right: 1px solid rgba(201,168,124,.15) !important;
  display: flex !important; flex-direction: column !important;
  justify-content: center !important; gap: 12px !important;
}
.wl-scard-mid {
  flex: 1 !important; min-width: 0 !important;
  padding: 22px 28px !important;
  display: flex !important; flex-direction: column !important;
  justify-content: center !important; gap: 10px !important;
}
.wl-scard-right {
  min-width: 230px !important; max-width: 230px !important;
  padding: 22px !important;
  background: #FDF7F0 !important;
  border-left: 1px solid rgba(201,168,124,.15) !important;
  display: flex !important; flex-direction: column !important;
  justify-content: center !important; gap: 12px !important;
}
.wl-scard-right button { width: 100% !important; box-sizing: border-box !important; }

/* ---------- СРАВНИТЕЛЬНЫЕ КАРТОЧКИ КУРСОВ ---------- */
.wl-cat-card {
  flex: 1 !important;
  border-radius: 20px !important;
  padding: 32px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 20px !important;
  box-sizing: border-box !important;
  transition: box-shadow .3s, border-color .3s, transform .3s !important;
}
.wl-cat-card-light {
  background: rgba(255,255,255,.04) !important;
  border: 1px solid rgba(201,168,124,.12) !important;
}
.wl-cat-card-light:hover {
  border-color: rgba(201,168,124,.35) !important;
  box-shadow: 0 16px 48px rgba(0,0,0,.35) !important;
  transform: translateY(-3px) !important;
}
.wl-cat-card-dark {
  background: linear-gradient(145deg,#1a0a04,#2e1507) !important;
  border: 1px solid rgba(201,168,124,.38) !important;
  position: relative !important;
  overflow: hidden !important;
}
.wl-cat-card-dark:hover {
  border-color: rgba(201,168,124,.7) !important;
  box-shadow: 0 20px 56px rgba(201,168,124,.15) !important;
  transform: translateY(-3px) !important;
}
.wl-cat-card-dark::before {
  content: '' !important;
  position: absolute !important;
  left: 0 !important; top: 0 !important; bottom: 0 !important;
  width: 4px !important;
  background: linear-gradient(180deg, #c9a87c, #b3895a) !important;
  border-radius: 20px 0 0 20px !important;
}
.wl-cat-btn-ghost {
  display: block !important; text-align: center !important;
  font-family: 'Jost', sans-serif !important; font-size: 12px !important;
  font-weight: 500 !important; letter-spacing: .18em !important;
  text-transform: uppercase !important; text-decoration: none !important;
  color: rgba(201,168,124,.7) !important;
  background: transparent !important;
  border: 1.5px solid rgba(201,168,124,.25) !important;
  border-radius: 12px !important; padding: 14px !important;
  margin-top: auto !important;
  transition: border-color .2s, color .2s, transform .2s !important;
}
.wl-cat-btn-ghost:hover {
  border-color: rgba(201,168,124,.6) !important;
  color: #c9a87c !important;
  transform: translateY(-2px) !important;
}
.wl-cat-btn-gold {
  display: block !important; text-align: center !important;
  font-family: 'Jost', sans-serif !important; font-size: 12px !important;
  font-weight: 500 !important; letter-spacing: .18em !important;
  text-transform: uppercase !important; text-decoration: none !important;
  color: #1a0e08 !important;
  background: linear-gradient(135deg,#c9a87c,#b3895a) !important;
  border: none !important; border-radius: 12px !important; padding: 14px !important;
  margin-top: auto !important; position: relative !important; z-index: 1 !important;
  box-shadow: 0 4px 16px rgba(175,135,55,.3) !important;
  transition: opacity .2s, transform .2s, box-shadow .2s !important;
}
.wl-cat-btn-gold:hover {
  opacity: .88 !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(175,135,55,.45) !important;
}

/* ---------- EYEBROW (надзаголовок) ---------- */
.wl-eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 9px !important;
  font-size: 11px !important;
  letter-spacing: .28em !important;
  text-transform: uppercase !important;
  color: #c9a87c !important;
  margin-bottom: 10px !important;
  font-family: 'Jost', sans-serif !important;
}
.wl-eyebrow::before {
  content: '' !important;
  width: 18px !important; height: 1px !important;
  background: #c9a87c !important;
  display: block !important;
}

/* ---------- СПИННЕР ЗАГРУЗКИ ---------- */
@keyframes wlSpin { to { transform: rotate(360deg); } }
.wl-spinner {
  width: 36px !important; height: 36px !important;
  border-radius: 50% !important;
  border: 2px solid rgba(201,168,124,.2) !important;
  border-top-color: #c9a87c !important;
  animation: wlSpin .7s linear infinite !important;
  margin: 0 auto 14px !important;
}

/* ---------- АДАПТИВ — карточки расписания ---------- */
@media (max-width: 700px) {
  .wl-scard { flex-direction: column !important; }
  .wl-scard-left {
    min-width: 0 !important; max-width: 100% !important; width: 100% !important;
    border-right: none !important;
    border-bottom: 1px solid rgba(201,168,124,.15) !important;
    box-sizing: border-box !important;
  }
  .wl-scard-mid {
    min-width: 0 !important; max-width: 100% !important; width: 100% !important;
    padding: 16px 18px !important; box-sizing: border-box !important;
  }
  .wl-scard-right {
    min-width: 0 !important; max-width: 100% !important; width: 100% !important;
    border-left: none !important;
    border-top: 1px solid rgba(201,168,124,.15) !important;
    box-sizing: border-box !important;
  }
}

/* ---------- АДАПТИВ — сравнительные карточки ---------- */
@media (max-width: 700px) {
  .wl-cat-card { width: 100% !important; min-width: 0 !important; }
}

/* ---------- АДАПТИВ — попап ---------- */
@media (max-width: 480px) {
  .wl-popup-box { border-radius: 20px !important; }
  .wl-popup-head { padding: 24px 20px 18px !important; }
  .wl-popup-title { font-size: 24px !important; }
  .wl-popup-body { padding: 20px 20px 28px !important; }
}


/* =====================================================
   HERO-БЛОКИ КУРСОВ — общие стили
   Используется на всех страницах /courses/*
   Секция получает классы: class="wl-hero"
   ID остаётся уникальным для каждой страницы
   ===================================================== */

.wl-hero *, .wl-hero *::before, .wl-hero *::after { box-sizing: border-box !important; margin: 0 !important; padding: 0 !important; }
.wl-hero { width: 100% !important; background-color: #0c0a07 !important; font-family: 'Jost', sans-serif !important; position: relative !important; overflow: visible !important; }
.wl-hero::before { content: '' !important; position: absolute !important; inset: 0 !important; background: linear-gradient(100deg, rgba(12,10,7,.92) 45%, rgba(12,10,7,.6) 100%) !important; z-index: 0 !important; }
.wl-hero::after { content: '' !important; position: absolute !important; bottom: 0 !important; left: 0 !important; right: 0 !important; height: 1px !important; background: linear-gradient(90deg, transparent, rgba(201,168,124,.3) 30%, rgba(201,168,124,.3) 70%, transparent) !important; }

.wl-hero .inner { max-width: 1340px !important; width: 100% !important; margin: 0 auto !important; padding: 72px 52px 80px !important; position: relative !important; z-index: 1 !important; }
.wl-hero .layout { display: grid !important; grid-template-columns: 1fr 380px !important; gap: 60px !important; align-items: start !important; }

/* Eyebrow */
.wl-hero .eyebrow { display: inline-flex !important; align-items: center !important; gap: 9px !important; font-size: 11px !important; letter-spacing: .28em !important; text-transform: uppercase !important; color: #c9a87c !important; margin-bottom: 20px !important; }
.wl-hero .eyebrow::before { content: '' !important; width: 18px !important; height: 1px !important; background: #c9a87c !important; display: block !important; }

/* Заголовок */
.wl-hero h1 { font-family: 'Cormorant Garamond', serif !important; font-size: clamp(42px, 5.5vw, 72px) !important; font-weight: 300 !important; line-height: 1.0 !important; letter-spacing: -.03em !important; color: #fff !important; margin-bottom: 24px !important; max-width: 9em !important; }
.wl-hero h1 em { font-style: italic !important; color: #c9a87c !important; }

/* Лид */
.wl-hero .lead { font-size: 17px !important; font-weight: 300 !important; line-height: 1.8 !important; color: rgba(255,255,255,.55) !important; margin-bottom: 40px !important; }

/* Факты */
.wl-hero .facts { display: flex !important; flex-wrap: wrap !important; gap: 10px !important; margin-bottom: 40px !important; }
.wl-hero .fact { display: flex !important; align-items: center !important; gap: 8px !important; background: rgba(255,255,255,.06) !important; border: 1px solid rgba(201,168,124,.15) !important; border-radius: 10px !important; padding: 10px 14px !important; }
.wl-hero .fact-icon { color: #c9a87c !important; flex-shrink: 0 !important; }
.wl-hero .fact-label { font-size: 9px !important; letter-spacing: .18em !important; text-transform: uppercase !important; color: rgba(255,255,255,.3) !important; display: block !important; margin-bottom: 1px !important; }
.wl-hero .fact-val { font-size: 13px !important; font-weight: 500 !important; color: rgba(255,255,255,.85) !important; }

/* Кнопки слева */
.wl-hero .btns { display: flex !important; gap: 12px !important; flex-wrap: wrap !important; }
.wl-hero .btn-gold { display: inline-flex !important; align-items: center !important; font-size: 11px !important; font-weight: 500 !important; letter-spacing: .22em !important; text-transform: uppercase !important; text-decoration: none !important; color: #1a0e08 !important; background: linear-gradient(135deg, #c9a87c, #b3895a) !important; padding: 15px 32px !important; border-radius: 12px !important; border: none !important; cursor: pointer !important; transition: opacity .18s !important; }
.wl-hero .btn-gold:hover { opacity: .88 !important; }
.wl-hero .btn-outline { display: inline-flex !important; align-items: center !important; font-size: 11px !important; font-weight: 500 !important; letter-spacing: .22em !important; text-transform: uppercase !important; text-decoration: none !important; color: rgba(255,255,255,.6) !important; border: 1px solid rgba(255,255,255,.18) !important; background: transparent !important; padding: 15px 28px !important; border-radius: 12px !important; cursor: pointer !important; transition: border-color .18s, color .18s !important; }
.wl-hero .btn-outline:hover { color: rgba(255,255,255,.9) !important; border-color: rgba(255,255,255,.4) !important; }

/* Карточка справа */
.wl-hero .card { background: rgba(255,255,255,.04) !important; border: 1px solid rgba(201,168,124,.18) !important; border-radius: 24px !important; overflow: visible !important; width: 100% !important; }
.wl-hero .card-photo { height: 52px !important; background: rgba(255,255,255,.03) !important; border-bottom: 1px solid rgba(201,168,124,.15) !important; display: flex !important; align-items: center !important; padding: 0 20px !important; border-radius: 24px 24px 0 0 !important; }
.wl-hero .card-photo-label { font-size: 9px !important; font-weight: 500 !important; letter-spacing: .2em !important; text-transform: uppercase !important; color: #c9a87c !important; }
.wl-hero .card-body { padding: 24px !important; }

/* Цена */
.wl-hero .price-main { font-family: 'Cormorant Garamond', serif !important; font-size: 52px !important; font-weight: 400 !important; color: #fff !important; letter-spacing: -.02em !important; line-height: 1 !important; margin-bottom: 12px !important; text-align: center !important; }
.wl-hero .price-inst { display: flex !important; align-items: center !important; gap: 8px !important; background: rgba(196,116,90,.1) !important; border-radius: 8px !important; padding: 10px 14px !important; margin-bottom: 20px !important; }
.wl-hero .price-inst-icon { color: #c4745a !important; flex-shrink: 0 !important; }
.wl-hero .price-inst-text { font-size: 13px !important; font-weight: 500 !important; color: #c4745a !important; }

/* Разделитель и фичи */
.wl-hero .card-divider { height: 1px !important; background: rgba(201,168,124,.12) !important; margin: 0 0 20px !important; }
.wl-hero .card-features { display: flex !important; flex-direction: column !important; gap: 10px !important; margin-bottom: 20px !important; }
.wl-hero .card-feat { display: flex !important; align-items: center !important; gap: 10px !important; font-size: 13px !important; color: rgba(255,255,255,.65) !important; }
.wl-hero .card-feat-ico { width: 22px !important; height: 22px !important; border-radius: 50% !important; flex-shrink: 0 !important; background: rgba(201,168,124,.12) !important; display: flex !important; align-items: center !important; justify-content: center !important; color: #c9a87c !important; }

/* Кнопки в карточке */
.wl-hero .card-btns { display: flex !important; flex-direction: column !important; align-items: center !important; gap: 10px !important; }
.wl-hero .card-btn { display: flex !important; align-items: center !important; justify-content: center !important; width: 296px !important; height: 58px !important; font-size: 11px !important; font-weight: 500 !important; letter-spacing: .22em !important; text-transform: uppercase !important; color: #1a0e08 !important; background: linear-gradient(135deg, #c9a87c, #b3895a) !important; border: none !important; border-radius: 10px !important; padding: 0 14px !important; cursor: pointer !important; font-family: 'Jost', sans-serif !important; transition: opacity .18s !important; }
.wl-hero .card-btn:hover { opacity: .88 !important; }
.wl-hero .tinkoff-wrap { display: flex !important; justify-content: center !important; width: 100% !important; position: relative !important; z-index: 9999 !important; }

/* Адаптив */
@media (max-width: 900px) {
  .wl-hero .inner { padding: 48px 20px 56px !important; }
  .wl-hero .layout { grid-template-columns: 1fr !important; gap: 32px !important; }
  .wl-hero .left { display: flex !important; flex-direction: column !important; align-items: center !important; text-align: center !important; }
  .wl-hero .eyebrow { justify-content: center !important; }
  .wl-hero h1 { max-width: 100% !important; }
  .wl-hero .facts { width: 100% !important; justify-content: center !important; }
  .wl-hero .fact { flex: 1 1 calc(50% - 5px) !important; max-width: calc(50% - 5px) !important; min-width: 0 !important; flex-direction: column !important; align-items: center !important; text-align: center !important; }
  .wl-hero .fact div { width: 100% !important; text-align: center !important; }
  .wl-hero .fact-label { text-align: center !important; }
  .wl-hero .fact-val { text-align: center !important; display: block !important; }
  .wl-hero .fact-wide { flex: 1 1 100% !important; max-width: 100% !important; }
  .wl-hero .btns { width: 100% !important; flex-direction: column !important; }
  .wl-hero .btn-gold, .wl-hero .btn-outline { width: 100% !important; justify-content: center !important; }
  .wl-hero .right { width: 100% !important; }
}


/* =====================================================
   БЛОК "ДЛЯ КОГО" — общие стили
   Используется на страницах курсов
   ===================================================== */

.wl-who-card { background: #FFF4EC !important; border-radius: 16px !important; padding: 24px 28px !important; display: flex !important; gap: 20px !important; align-items: flex-start !important; box-shadow: 0 2px 12px rgba(26,10,4,.06) !important; }
.wl-who-icon { width: 40px !important; height: 40px !important; border-radius: 12px !important; background: linear-gradient(135deg,#c9a87c,#b3895a) !important; display: flex !important; align-items: center !important; justify-content: center !important; flex-shrink: 0 !important; }
.wl-who-title { font-size: 16px !important; font-weight: 600 !important; color: #1a0a04 !important; margin-bottom: 5px !important; }
.wl-who-text { font-size: 14px !important; color: rgba(26,10,4,.6) !important; line-height: 1.6 !important; }

.wl-who-doc { background: linear-gradient(145deg,#1a0a04,#2e1507) !important; border-radius: 20px !important; padding: 32px !important; color: #fff !important; position: relative !important; overflow: hidden !important; }
.wl-who-doc-icon { width: 36px !important; height: 36px !important; border-radius: 10px !important; background: linear-gradient(135deg,#c9a87c,#b3895a) !important; display: flex !important; align-items: center !important; justify-content: center !important; flex-shrink: 0 !important; }
.wl-who-doc-label { font-size: 11px !important; letter-spacing: .2em !important; text-transform: uppercase !important; color: rgba(201,168,124,.8) !important; }
.wl-who-doc-title { font-family: 'Cormorant Garamond', serif !important; font-size: 26px !important; font-weight: 300 !important; color: #fff !important; margin: 0 0 8px !important; line-height: 1.2 !important; }
.wl-who-doc-title em { font-style: italic !important; color: #c9a87c !important; }
.wl-who-doc-sub { font-size: 13px !important; color: rgba(255,255,255,.45) !important; margin-bottom: 22px !important; line-height: 1.6 !important; }
.wl-who-check { display: flex !important; gap: 12px !important; align-items: flex-start !important; }
.wl-who-check-dot { width: 18px !important; height: 18px !important; border-radius: 50% !important; background: rgba(201,168,124,.2) !important; border: 1px solid rgba(201,168,124,.4) !important; display: flex !important; align-items: center !important; justify-content: center !important; flex-shrink: 0 !important; margin-top: 1px !important; }
.wl-who-check-text { font-size: 13px !important; color: rgba(255,255,255,.75) !important; line-height: 1.5 !important; }
.wl-who-doc-divider { height: 1px !important; background: rgba(201,168,124,.2) !important; margin-bottom: 20px !important; }
.wl-who-doc-tip { background: rgba(201,168,124,.1) !important; border: 1px solid rgba(201,168,124,.25) !important; border-radius: 12px !important; padding: 14px 16px !important; }
.wl-who-doc-tip-label { font-size: 11px !important; letter-spacing: .15em !important; text-transform: uppercase !important; color: #c9a87c !important; margin-bottom: 6px !important; }
.wl-who-doc-tip-text { font-size: 13px !important; color: rgba(255,255,255,.65) !important; line-height: 1.6 !important; }
.wl-who-doc-tip-text a { color: #c9a87c !important; text-decoration: none !important; border-bottom: 1px solid rgba(201,168,124,.4) !important; }

/* Оставшиеся стили блока "Для кого" */
.wl-who-eyebrow-wrap { display: flex !important; align-items: center !important; gap: 10px !important; margin-bottom: 10px !important; }
.wl-who-eyebrow-line { width: 20px !important; height: 1px !important; background: #c4745a !important; }
.wl-who-eyebrow-text { font-size: 11px !important; letter-spacing: .28em !important; text-transform: uppercase !important; color: #c4745a !important; font-family: 'Jost', sans-serif !important; }
.wl-who-h2 { font-family: 'Cormorant Garamond', serif !important; font-size: 48px !important; font-weight: 300 !important; line-height: 1.05 !important; letter-spacing: -.03em !important; color: #1a0a04 !important; margin-bottom: 52px !important; margin-top: 0 !important; max-width: 8em !important; }
.wl-who-h2 em { font-style: italic !important; color: #c4745a !important; }
.wl-who-doc-orb1 { position: absolute !important; top: -40px !important; right: -40px !important; width: 160px !important; height: 160px !important; border-radius: 50% !important; background: rgba(201,168,124,.1) !important; }
.wl-who-doc-orb2 { position: absolute !important; bottom: -20px !important; left: -20px !important; width: 100px !important; height: 100px !important; border-radius: 50% !important; background: rgba(201,168,124,.06) !important; }
.wl-who-doc-inner { position: relative !important; z-index: 1 !important; }
.wl-who-doc-head { display: flex !important; align-items: center !important; gap: 10px !important; margin-bottom: 20px !important; }
.wl-who-checks { display: flex !important; flex-direction: column !important; gap: 12px !important; margin-bottom: 24px !important; }


/* =====================================================
   БЛОК СРАВНЕНИЯ КУРСОВ — общие стили
   Используется на всех страницах /courses/*
   ===================================================== */

/* Обёртка */
.wl-cat-wrap { width: 100% !important; padding: 72px 52px 80px !important; box-sizing: border-box !important; font-family: 'Jost', sans-serif !important; }
.wl-cat-wrap > div { max-width: 1100px !important; margin: 0 auto !important; }
.wl-cat-wrap-light { background: #FFF4EC !important; }
.wl-cat-wrap-dark  { background: #0c0a07 !important; }

/* Заголовочная часть */
.wl-cat-h2-light { font-family: 'Cormorant Garamond', serif !important; font-size: 48px !important; font-weight: 300 !important; line-height: 1.05 !important; letter-spacing: -.03em !important; color: #1a0a04 !important; margin-bottom: 12px !important; margin-top: 0 !important; max-width: 8em !important; }
.wl-cat-h2-dark  { font-family: 'Cormorant Garamond', serif !important; font-size: 48px !important; font-weight: 300 !important; line-height: 1.05 !important; letter-spacing: -.03em !important; color: #fff !important; margin-bottom: 12px !important; margin-top: 0 !important; }
.wl-cat-h2-light em { font-style: italic !important; color: #c4745a !important; }
.wl-cat-h2-dark em { font-style: italic !important; color: #c9a87c !important; }
.wl-cat-lead-light { font-size: 15px !important; color: rgba(26,10,4,.5) !important; margin: 0 0 48px !important; line-height: 1.6 !important; font-weight: 300 !important; }
.wl-cat-lead-dark  { font-size: 15px !important; color: rgba(255,255,255,.45) !important; margin: 0 0 48px !important; line-height: 1.6 !important; font-weight: 300 !important; }

/* Сетка */
.wl-cat-grid { display: flex !important; gap: 20px !important; align-items: stretch !important; }

/* Карточка — светлая (на светлом фоне) */
.wl-cat-card-l { flex: 1 !important; background: #fff !important; border: 1px solid rgba(201,168,124,.2) !important; border-radius: 20px !important; padding: 32px !important; display: flex !important; flex-direction: column !important; gap: 20px !important; box-sizing: border-box !important; transition: box-shadow .3s, border-color .3s, transform .3s !important; }
.wl-cat-card-l:hover { border-color: rgba(201,168,124,.45) !important; box-shadow: 0 16px 48px rgba(60,20,5,.1) !important; transform: translateY(-3px) !important; }

/* Карточка — тёмная (на тёмном фоне, стекло) */
.wl-cat-card-gl { flex: 1 !important; background: rgba(255,255,255,.04) !important; border: 1px solid rgba(201,168,124,.12) !important; border-radius: 20px !important; padding: 32px !important; display: flex !important; flex-direction: column !important; gap: 20px !important; box-sizing: border-box !important; transition: box-shadow .3s, border-color .3s, transform .3s !important; }
.wl-cat-card-gl:hover { border-color: rgba(201,168,124,.35) !important; box-shadow: 0 16px 48px rgba(0,0,0,.35) !important; transform: translateY(-3px) !important; }

/* Карточка — featured (тёмный градиент, везде) */
.wl-cat-card-featured { flex: 1 !important; background: linear-gradient(145deg,#1a0a04,#2e1507) !important; border: 1px solid rgba(201,168,124,.38) !important; border-radius: 20px !important; padding: 32px !important; display: flex !important; flex-direction: column !important; gap: 20px !important; box-sizing: border-box !important; position: relative !important; overflow: hidden !important; transition: box-shadow .3s, border-color .3s, transform .3s !important; }
.wl-cat-card-featured:hover { border-color: rgba(201,168,124,.7) !important; box-shadow: 0 20px 56px rgba(201,168,124,.15) !important; transform: translateY(-3px) !important; }
/* .wl-cat-card-featured::before — полоска убрана, используйте .wl-cat-card-featured-stripe если нужна */
.wl-cat-card-orb { position: absolute !important; top: -30px !important; right: -30px !important; width: 120px !important; height: 120px !important; border-radius: 50% !important; background: rgba(201,168,124,.08) !important; }
.wl-cat-card-inner { position: relative !important; z-index: 1 !important; }

/* Шапка карточки */
.wl-cat-badge { font-size: 11px !important; letter-spacing: .2em !important; text-transform: uppercase !important; margin-bottom: 8px !important; }
.wl-cat-badge-light { color: rgba(26,10,4,.35) !important; }
.wl-cat-badge-dark  { color: rgba(201,168,124,.5) !important; }
.wl-cat-badge-featured { display: inline-block !important; font-size: 10px !important; letter-spacing: .2em !important; text-transform: uppercase !important; color: #1a0e08 !important; background: linear-gradient(135deg,#c9a87c,#b3895a) !important; border-radius: 20px !important; padding: 4px 12px !important; margin-bottom: 10px !important; }
.wl-cat-name-light { font-family: 'Cormorant Garamond', serif !important; font-size: 30px !important; font-weight: 400 !important; color: #1a0a04 !important; line-height: 1.1 !important; }
.wl-cat-name-dark  { font-family: 'Cormorant Garamond', serif !important; font-size: 28px !important; font-weight: 400 !important; color: rgba(255,255,255,.85) !important; line-height: 1.1 !important; }
.wl-cat-name-featured { font-family: 'Cormorant Garamond', serif !important; font-size: 28px !important; font-weight: 400 !important; color: #fff !important; line-height: 1.1 !important; }

/* Строки таблицы */
.wl-cat-rows { display: flex !important; flex-direction: column !important; gap: 8px !important; }
.wl-cat-row { display: flex !important; justify-content: space-between !important; align-items: center !important; padding: 10px 0 !important; }
.wl-cat-row-light { border-bottom: 1px solid rgba(201,168,124,.12) !important; }
.wl-cat-row-dark  { border-bottom: 1px solid rgba(201,168,124,.1) !important; }
.wl-cat-row-featured { border-bottom: 1px solid rgba(255,255,255,.08) !important; }
.wl-cat-row-label-light { font-size: 14px !important; color: rgba(26,10,4,.55) !important; }
.wl-cat-row-label-dark  { font-size: 13px !important; color: rgba(255,255,255,.4) !important; }
.wl-cat-row-label-feat  { font-size: 13px !important; color: rgba(255,255,255,.45) !important; }
.wl-cat-row-val-light { font-size: 14px !important; font-weight: 600 !important; color: #1a0a04 !important; }
.wl-cat-row-val-dark  { font-size: 13px !important; font-weight: 600 !important; color: rgba(255,255,255,.85) !important; }
.wl-cat-row-val-feat  { font-size: 13px !important; font-weight: 600 !important; color: #fff !important; }
.wl-cat-row-val-gold  { font-size: 13px !important; font-weight: 600 !important; color: #c9a87c !important; }
.wl-cat-row-val-dim   { font-size: 14px !important; color: rgba(26,10,4,.25) !important; }
.wl-cat-row-val-dim-dark { font-size: 13px !important; color: rgba(255,255,255,.2) !important; }
.wl-cat-price-light { font-family: 'Cormorant Garamond', serif !important; font-size: 26px !important; font-weight: 400 !important; color: #1a0a04 !important; }
.wl-cat-price-dark  { font-family: 'Cormorant Garamond', serif !important; font-size: 26px !important; font-weight: 400 !important; color: rgba(255,255,255,.85) !important; }
.wl-cat-price-feat  { font-family: 'Cormorant Garamond', serif !important; font-size: 26px !important; font-weight: 400 !important; color: #fff !important; }

/* Кнопки */
.wl-cat-btn-ghost-l { display: block !important; text-align: center !important; font-family: 'Jost', sans-serif !important; font-size: 12px !important; font-weight: 500 !important; letter-spacing: .18em !important; text-transform: uppercase !important; color: rgba(26,10,4,.6) !important; background: transparent !important; border: 1.5px solid rgba(201,168,124,.4) !important; border-radius: 12px !important; padding: 14px !important; text-decoration: none !important; margin-top: auto !important; transition: border-color .2s, color .2s, transform .2s !important; }
.wl-cat-btn-ghost-l:hover { border-color: #c9a87c !important; color: #1a0a04 !important; transform: translateY(-2px) !important; }
.wl-cat-btn-ghost-d { display: block !important; text-align: center !important; font-family: 'Jost', sans-serif !important; font-size: 12px !important; font-weight: 500 !important; letter-spacing: .18em !important; text-transform: uppercase !important; color: rgba(201,168,124,.7) !important; background: transparent !important; border: 1.5px solid rgba(201,168,124,.25) !important; border-radius: 12px !important; padding: 14px !important; text-decoration: none !important; margin-top: auto !important; transition: border-color .2s, color .2s, transform .2s !important; }
.wl-cat-btn-ghost-d:hover { border-color: rgba(201,168,124,.6) !important; color: #c9a87c !important; transform: translateY(-2px) !important; }
.wl-cat-btn-gold-f { display: block !important; text-align: center !important; font-family: 'Jost', sans-serif !important; font-size: 12px !important; font-weight: 500 !important; letter-spacing: .18em !important; text-transform: uppercase !important; color: #1a0e08 !important; background: linear-gradient(135deg,#c9a87c,#b3895a) !important; border: none !important; border-radius: 12px !important; padding: 14px !important; text-decoration: none !important; margin-top: auto !important; position: relative !important; z-index: 1 !important; box-shadow: 0 4px 16px rgba(175,135,55,.3) !important; transition: opacity .2s, transform .2s, box-shadow .2s !important; }
.wl-cat-btn-gold-f:hover { opacity: .88 !important; transform: translateY(-2px) !important; box-shadow: 0 8px 24px rgba(175,135,55,.45) !important; }

/* Адаптив */
@media (max-width: 700px) {
  .wl-cat-wrap { padding: 48px 20px 56px !important; }
  .wl-cat-wrap > div { padding: 0 !important; }
  .wl-cat-grid { flex-direction: column !important; }
  .wl-cat-card-l, .wl-cat-card-gl, .wl-cat-card-featured { width: 100% !important; min-width: 0 !important; }
}

.wl-cat-eyebrow-text-light { color: #c4745a !important; }

/* Акцентный цвет на светлом фоне */
.wl-accent-light { color: #c4745a !important; }
/* Акцентный цвет на тёмном фоне */
.wl-accent-dark { color: #c9a87c !important; }


/* =====================================================
   БЛОК ПРОГРАММЫ КУРСА — общие стили
   Используется на всех страницах /courses/*
   ===================================================== */

.wl-prog *, .wl-prog *::before, .wl-prog *::after { box-sizing: border-box !important; margin: 0 !important; padding: 0 !important; }
.wl-prog { width: 100% !important; background: #FFF4EC !important; font-family: 'Jost', sans-serif !important; }
.wl-prog .inner { max-width: 1340px !important; margin: 0 auto !important; padding: 80px 52px 88px !important; }

.wl-prog .eyebrow { display: inline-flex !important; align-items: center !important; gap: 9px !important; font-size: 11px !important; letter-spacing: .28em !important; text-transform: uppercase !important; color: #c4745a !important; margin-bottom: 14px !important; }
.wl-prog .eyebrow::before { content: '' !important; width: 18px !important; height: 1px !important; background: #c9a87c !important; display: block !important; }
.wl-prog .title { font-family: 'Cormorant Garamond', serif !important; font-size: clamp(34px, 3.8vw, 54px) !important; font-weight: 300 !important; line-height: 1.05 !important; letter-spacing: -.03em !important; color: #1a0a04 !important; margin-bottom: 16px !important; }
.wl-prog .title em { font-style: italic !important; color: #c4745a !important; }
.wl-prog .subtitle { font-size: 16px !important; font-weight: 300 !important; line-height: 1.7 !important; color: rgba(26,10,4,.55) !important; max-width: 600px !important; margin-bottom: 52px !important; }

/* Сетка дней */
.wl-prog .days { display: grid !important; gap: 20px !important; margin-bottom: 52px !important; }
.wl-prog .day { background: #fff !important; border: 1.5px solid rgba(201,168,124,.3) !important; border-radius: 20px !important; overflow: hidden !important; box-shadow: 0 4px 20px rgba(201,168,124,.12) !important; }
.wl-prog .day-head { padding: 22px 24px 18px !important; border-bottom: 1px solid rgba(201,168,124,.2) !important; display: flex !important; align-items: center !important; gap: 14px !important; }
.wl-prog .day-num { width: 40px !important; height: 40px !important; border-radius: 50% !important; flex-shrink: 0 !important; background: linear-gradient(135deg, #c9a87c, #b3895a) !important; display: flex !important; align-items: center !important; justify-content: center !important; font-family: 'Cormorant Garamond', serif !important; font-size: 20px !important; font-weight: 400 !important; color: #fff !important; }
.wl-prog .day-label { font-size: 10px !important; font-weight: 500 !important; letter-spacing: .18em !important; text-transform: uppercase !important; color: rgba(26,10,4,.4) !important; margin-bottom: 2px !important; }
.wl-prog .day-title { font-size: 16px !important; font-weight: 600 !important; color: #1a0a04 !important; line-height: 1.2 !important; }
.wl-prog .day-items { padding: 18px 24px 22px !important; display: flex !important; flex-direction: column !important; gap: 10px !important; }
.wl-prog .day-item { display: flex !important; align-items: flex-start !important; gap: 10px !important; font-size: 14px !important; color: rgba(26,10,4,.7) !important; line-height: 1.5 !important; }
.wl-prog .day-dot { width: 6px !important; height: 6px !important; border-radius: 50% !important; background: #c9a87c !important; flex-shrink: 0 !important; margin-top: 6px !important; }
.wl-prog .day-badge { display: inline-flex !important; align-items: center !important; gap: 6px !important; font-size: 10px !important; font-weight: 500 !important; letter-spacing: .14em !important; text-transform: uppercase !important; color: #c4745a !important; background: rgba(196,116,90,.08) !important; border-radius: 6px !important; padding: 4px 10px !important; margin: 4px 24px 0 !important; width: fit-content !important; }

/* Блок результата */
.wl-prog .result { background: #1a0a04 !important; border-radius: 20px !important; padding: 36px 40px !important; display: flex !important; align-items: center !important; justify-content: space-between !important; gap: 32px !important; }
.wl-prog .result-left { flex: 1 !important; }
.wl-prog .result-eyebrow { font-size: 10px !important; letter-spacing: .22em !important; text-transform: uppercase !important; color: #c9a87c !important; margin-bottom: 10px !important; }
.wl-prog .result-title { font-family: 'Cormorant Garamond', serif !important; font-size: 28px !important; font-weight: 300 !important; color: #fff !important; line-height: 1.2 !important; margin-bottom: 16px !important; }
.wl-prog .result-items { display: flex !important; flex-direction: column !important; gap: 8px !important; }
.wl-prog .result-item { display: flex !important; align-items: center !important; gap: 10px !important; font-size: 14px !important; color: rgba(255,255,255,.65) !important; }
.wl-prog .result-ico { width: 20px !important; height: 20px !important; border-radius: 50% !important; background: rgba(201,168,124,.15) !important; display: flex !important; align-items: center !important; justify-content: center !important; color: #c9a87c !important; flex-shrink: 0 !important; }
.wl-prog .result-right { display: flex !important; flex-direction: column !important; align-items: center !important; gap: 12px !important; flex-shrink: 0 !important; }
.wl-prog .result-cert { background: rgba(201,168,124,.08) !important; border: 1px solid rgba(201,168,124,.25) !important; border-radius: 14px !important; padding: 20px 28px !important; text-align: center !important; }
.wl-prog .result-cert-icon { color: #c9a87c !important; margin-bottom: 8px !important; }
.wl-prog .result-cert-name { font-family: 'Cormorant Garamond', serif !important; font-size: 18px !important; font-style: italic !important; color: #fff !important; margin-bottom: 4px !important; }
.wl-prog .result-cert-sub { font-size: 11px !important; color: rgba(255,255,255,.35) !important; letter-spacing: .08em !important; }

/* Адаптив */
@media (max-width: 900px) {
  .wl-prog .inner { padding: 56px 20px 64px !important; }
  .wl-prog .days { grid-template-columns: 1fr !important; }
  .wl-prog .result { flex-direction: column !important; align-items: flex-start !important; padding: 28px 24px !important; }
  .wl-prog .result-right { align-items: flex-start !important; width: 100% !important; }
  .wl-prog .result-cert { width: 100% !important; }
}
@media (max-width: 480px) {
  .wl-prog .inner { padding: 40px 16px 48px !important; }
}


/* =====================================================
   БЛОК ОТЗЫВОВ — общие стили
   Используется на всех страницах сайта
   ===================================================== */

.wl-rev * { box-sizing: border-box !important; margin: 0 !important; padding: 0 !important; }
.wl-rev { background: #FFF4EC !important; padding: 80px 0 !important; width: 100% !important; overflow: hidden !important; }
.wl-rev .inner { max-width: 1280px !important; margin: 0 auto !important; padding: 0 64px !important; }

.wl-rev .rev-head { display: flex !important; align-items: flex-end !important; justify-content: space-between !important; margin-bottom: 48px !important; gap: 24px !important; }
.wl-rev .rev-eyebrow { font-family: 'Jost', sans-serif !important; font-size: 10px !important; font-weight: 400 !important; letter-spacing: .3em !important; text-transform: uppercase !important; color: #c4745a !important; margin-bottom: 14px !important; display: block !important; }
.wl-rev .rev-eyebrow::before { content: '' !important; display: inline-block !important; width: 18px !important; height: 1px !important; background: #c9a87c !important; vertical-align: middle !important; margin-right: 9px !important; }
.wl-rev .rev-title { font-family: 'Cormorant Garamond', serif !important; font-size: 48px !important; font-weight: 300 !important; color: #1a0a04 !important; line-height: 1.05 !important; }
.wl-rev .rev-title em { font-style: italic !important; color: #c4745a !important; }
.wl-rev .rev-rating { text-align: right !important; flex-shrink: 0 !important; }
.wl-rev .rev-stars { display: flex !important; gap: 5px !important; justify-content: flex-end !important; margin-bottom: 8px !important; }
.wl-rev .rev-stars span { color: #c9a87c !important; font-size: 20px !important; }
.wl-rev .rev-score { font-family: 'Cormorant Garamond', serif !important; font-size: 42px !important; font-weight: 300 !important; color: #1a0a04 !important; line-height: 1 !important; }
.wl-rev .rev-count { font-family: 'Jost', sans-serif !important; font-size: 12px !important; font-weight: 300 !important; color: rgba(26,10,4,.4) !important; margin-top: 4px !important; }

.wl-rev .slider-wrap { position: relative !important; }
.wl-rev .slider-track { display: flex !important; gap: 20px !important; transition: transform .5s cubic-bezier(.4,0,.2,1) !important; will-change: transform !important; }

.wl-rev .rev-card { flex: 0 0 calc(33.333% - 14px) !important; background: #fff !important; border: 1px solid rgba(201,168,124,.25) !important; border-radius: 16px !important; padding: 28px !important; display: flex !important; flex-direction: column !important; gap: 0 !important; transition: border-color .3s !important; box-shadow: 0 4px 20px rgba(201,168,124,.1) !important; }
.wl-rev .rev-card:hover { border-color: rgba(201,168,124,.5) !important; }
.wl-rev .card-top { display: flex !important; align-items: center !important; justify-content: space-between !important; margin-bottom: 16px !important; }
.wl-rev .card-stars { display: flex !important; gap: 3px !important; }
.wl-rev .card-stars span { color: #c9a87c !important; font-size: 14px !important; }
.wl-rev .card-src { font-family: 'Jost', sans-serif !important; font-size: 10px !important; font-weight: 300 !important; letter-spacing: .15em !important; text-transform: uppercase !important; color: rgba(26,10,4,.3) !important; }
.wl-rev .card-text { font-family: 'Jost', sans-serif !important; font-size: 14px !important; font-weight: 300 !important; line-height: 1.7 !important; color: rgba(26,10,4,.7) !important; flex: 1 !important; margin-bottom: 20px !important; display: -webkit-box !important; -webkit-line-clamp: 5 !important; -webkit-box-orient: vertical !important; overflow: hidden !important; }
.wl-rev .card-footer { display: flex !important; align-items: center !important; gap: 12px !important; border-top: 1px solid rgba(26,10,4,.08) !important; padding-top: 16px !important; }
.wl-rev .card-avatar { width: 36px !important; height: 36px !important; border-radius: 50% !important; background: linear-gradient(135deg,#c9a87c,#b3895a) !important; display: flex !important; align-items: center !important; justify-content: center !important; font-family: 'Cormorant Garamond', serif !important; font-size: 16px !important; font-weight: 400 !important; color: #1a0a04 !important; flex-shrink: 0 !important; }
.wl-rev .card-name { font-family: 'Jost', sans-serif !important; font-size: 13px !important; font-weight: 500 !important; color: #1a0a04 !important; margin-bottom: 2px !important; }
.wl-rev .card-date { font-family: 'Jost', sans-serif !important; font-size: 11px !important; font-weight: 300 !important; color: rgba(26,10,4,.3) !important; }

.wl-rev .rev-nav { display: flex !important; align-items: center !important; justify-content: space-between !important; margin-top: 36px !important; }
.wl-rev .rev-dots { display: flex !important; gap: 8px !important; }
.wl-rev .rev-dot { width: 6px !important; height: 6px !important; border-radius: 50% !important; background: rgba(26,10,4,.15) !important; cursor: pointer !important; transition: all .3s !important; border: none !important; }
.wl-rev .rev-dot.active { background: #c9a87c !important; width: 24px !important; border-radius: 3px !important; }
.wl-rev .rev-arrows { display: flex !important; gap: 12px !important; }
.wl-rev .rev-arr { width: 44px !important; height: 44px !important; border-radius: 50% !important; border: 1px solid rgba(201,168,124,.35) !important; background: transparent !important; color: rgba(26,10,4,.4) !important; font-size: 18px !important; cursor: pointer !important; display: flex !important; align-items: center !important; justify-content: center !important; transition: all .25s !important; }
.wl-rev .rev-arr:hover { border-color: #c9a87c !important; color: #c4745a !important; background: rgba(201,168,124,.08) !important; }
.wl-rev .rev-arr:disabled { opacity: .25 !important; cursor: default !important; }

.wl-rev .src-badges { display: inline-flex !important; align-items: center !important; gap: 10px !important; flex-wrap: wrap !important; }
.wl-rev .src-badge { display: inline-flex !important; align-items: center !important; gap: 8px !important; background: rgba(26,10,4,.04) !important; border: 1px solid rgba(26,10,4,.1) !important; border-radius: 8px !important; padding: 6px 12px !important; font-family: 'Jost', sans-serif !important; font-size: 11px !important; font-weight: 300 !important; color: rgba(26,10,4,.4) !important; text-decoration: none !important; transition: all .25s !important; }
.wl-rev .src-badge:hover { border-color: rgba(201,168,124,.4) !important; color: #c4745a !important; }

@media (max-width: 1024px) {
  .wl-rev .rev-card { flex: 0 0 calc(50% - 10px) !important; }
  .wl-rev .rev-title { font-size: 38px !important; }
}
@media (max-width: 768px) {
  .wl-rev { padding: 60px 0 !important; }
  .wl-rev .inner { padding: 0 20px !important; }
  .wl-rev .rev-card { flex: 0 0 100% !important; }
  .wl-rev .rev-head { flex-direction: column !important; align-items: flex-start !important; }
  .wl-rev .rev-rating { text-align: left !important; }
  .wl-rev .rev-stars { justify-content: flex-start !important; }
  .wl-rev .rev-title { font-size: 32px !important; }
  .wl-rev .rev-score { font-size: 32px !important; }
  .wl-rev .src-badges { flex-direction: column !important; align-items: flex-start !important; }
}


/* =====================================================
   БЛОК FAQ — общие стили
   Используется на всех страницах /courses/*
   ===================================================== */

.wl-faq *, .wl-faq *::before, .wl-faq *::after { box-sizing: border-box !important; margin: 0 !important; padding: 0 !important; }
.wl-faq { width: 100% !important; background: #FFF4EC !important; font-family: 'Jost', sans-serif !important; }
.wl-faq .inner { max-width: 1340px !important; margin: 0 auto !important; padding: 80px 52px 88px !important; }
.wl-faq .top { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 80px !important; align-items: start !important; }
.wl-faq .left-head { position: sticky !important; top: 32px !important; }

.wl-faq .eyebrow { display: inline-flex !important; align-items: center !important; gap: 9px !important; font-size: 11px !important; letter-spacing: .28em !important; text-transform: uppercase !important; color: #c4745a !important; margin-bottom: 14px !important; }
.wl-faq .eyebrow::before { content: '' !important; width: 18px !important; height: 1px !important; background: #c9a87c !important; display: block !important; }
.wl-faq .title { font-family: 'Cormorant Garamond', serif !important; font-size: clamp(34px, 3.8vw, 54px) !important; font-weight: 300 !important; line-height: 1.05 !important; letter-spacing: -.03em !important; color: #1a0a04 !important; margin-bottom: 24px !important; max-width: 7em !important; }
.wl-faq .title em { font-style: italic !important; color: #c4745a !important; }
.wl-faq .subtitle { font-size: 16px !important; font-weight: 400 !important; line-height: 1.7 !important; color: rgba(26,10,4,.65) !important; margin-bottom: 32px !important; }
.wl-faq .cta-link { display: inline-flex !important; align-items: center !important; gap: 8px !important; font-size: 12px !important; font-weight: 500 !important; letter-spacing: .18em !important; text-transform: uppercase !important; color: #c4745a !important; text-decoration: none !important; border-bottom: 1px solid rgba(201,168,124,.3) !important; padding-bottom: 4px !important; }

.wl-faq .faq-list { display: flex !important; flex-direction: column !important; gap: 0 !important; }
.wl-faq .faq-item { border-bottom: 1px solid rgba(201,168,124,.25) !important; }
.wl-faq .faq-item:first-child { border-top: 1px solid rgba(201,168,124,.25) !important; }
.wl-faq .faq-q { display: flex !important; align-items: center !important; justify-content: space-between !important; gap: 16px !important; padding: 22px 0 !important; cursor: pointer !important; list-style: none !important; font-size: 16px !important; font-weight: 500 !important; line-height: 1.4 !important; color: #1a0a04 !important; }
.wl-faq .faq-q::-webkit-details-marker { display: none !important; }
.wl-faq .faq-icon { width: 28px !important; height: 28px !important; flex-shrink: 0 !important; border-radius: 50% !important; border: 1px solid rgba(201,168,124,.45) !important; display: flex !important; align-items: center !important; justify-content: center !important; color: #c9a87c !important; transition: transform .25s !important; }
.wl-faq details[open] .faq-icon { transform: rotate(45deg) !important; }
.wl-faq details[open] .faq-q { color: #c4745a !important; }
.wl-faq .faq-a { font-size: 15px !important; font-weight: 400 !important; line-height: 1.8 !important; color: rgba(26,10,4,.8) !important; padding-bottom: 22px !important; padding-right: 44px !important; }
.wl-faq .faq-a a { color: #c9a87c !important; text-decoration: none !important; border-bottom: 1px solid rgba(201,168,124,.3) !important; }
.wl-faq .faq-tip { display: flex !important; align-items: flex-start !important; gap: 12px !important; background: rgba(201,168,124,.1) !important; border: 1px solid rgba(201,168,124,.25) !important; border-radius: 12px !important; padding: 14px 16px !important; margin-top: 12px !important; font-size: 14px !important; color: rgba(26,10,4,.75) !important; line-height: 1.6 !important; }
.wl-faq .faq-tip-icon { color: #c9a87c !important; flex-shrink: 0 !important; margin-top: 2px !important; }

@media (max-width: 900px) {
  .wl-faq .inner { padding: 56px 20px 64px !important; }
  .wl-faq .top { grid-template-columns: 1fr !important; gap: 40px !important; }
  .wl-faq .left-head { position: static !important; }
  .wl-faq .title { max-width: 100% !important; }
}
@media (max-width: 480px) {
  .wl-faq .inner { padding: 40px 16px 48px !important; }
  .wl-faq .faq-q { font-size: 15px !important; }
  .wl-faq .faq-a { padding-right: 0 !important; }
}


/* =====================================================
   ХЛЕБНЫЕ КРОШКИ — общие стили
   Используется на всех страницах курсов
   ===================================================== */

.wl-bread *, .wl-bread *::before, .wl-bread *::after { box-sizing: border-box !important; margin: 0 !important; padding: 0 !important; }
.wl-bread { width: 100% !important; background: #0c0a07 !important; position: relative !important; z-index: 10 !important; }
.wl-bread .bc-wrap { max-width: 1340px !important; margin: 0 auto !important; padding: 14px 52px !important; }
.wl-bread ol { list-style: none !important; display: flex !important; align-items: center !important; flex-wrap: wrap !important; }
.wl-bread li { display: inline-flex !important; align-items: center !important; }
.wl-bread a { font-family: 'Jost', sans-serif !important; font-size: 11px !important; font-weight: 300 !important; letter-spacing: .1em !important; color: rgba(255,255,255,.4) !important; text-decoration: none !important; white-space: nowrap !important; }
.wl-bread a:hover { color: #c9a87c !important; }
.wl-bread .bc-sep { font-size: 10px !important; color: rgba(255,255,255,.2) !important; margin: 0 10px !important; user-select: none !important; font-family: 'Jost', sans-serif !important; }
.wl-bread .bc-current { font-family: 'Jost', sans-serif !important; font-size: 11px !important; font-weight: 400 !important; letter-spacing: .1em !important; color: rgba(255,255,255,.65) !important; white-space: nowrap !important; }

@media (max-width: 900px) {
  .wl-bread .bc-wrap { padding: 12px 20px !important; }
}

/* Фоны секций */
.wl-bg-cream { background: #FFF4EC !important; } /* кремовый — расписание, программа, FAQ */
.wl-bg-light { background: #FFFDF9 !important; } /* почти белый — блок "для кого" */
.wl-bg-dark  { background: #0c0a07 !important; } /* тёмный — hero, сравнение курсов */


/* Блок с фото документа (диплом, удостоверение, сертификат) */
.wl-who-doc-img-wrap { border-radius: 16px !important; overflow: hidden !important; background: #FFF4EC !important; padding: 20px !important; display: flex !important; flex-direction: column !important; gap: 12px !important; }
.wl-who-doc-img-label { font-size: 12px !important; letter-spacing: .15em !important; text-transform: uppercase !important; color: rgba(26,10,4,.35) !important; }
.wl-who-doc-img img { width: 100% !important; border-radius: 10px !important; display: block !important; }
.wl-who-doc-img-caption { font-size: 12px !important; color: rgba(26,10,4,.4) !important; line-height: 1.5 !important; }


/* Лайтбокс для просмотра документов */
.wl-lightbox { display: none; position: fixed !important; inset: 0 !important; z-index: 999999 !important; background: rgba(10,8,6,.92) !important; align-items: center !important; justify-content: center !important; padding: 20px !important; cursor: zoom-out !important; backdrop-filter: blur(4px) !important; }
.wl-lightbox.open { display: flex !important; }
.wl-lightbox img { max-width: min(90vw, 720px) !important; max-height: 90vh !important; border-radius: 12px !important; box-shadow: 0 32px 80px rgba(0,0,0,.6) !important; object-fit: contain !important; }
.wl-lightbox-close { position: absolute !important; top: 20px !important; right: 20px !important; width: 40px !important; height: 40px !important; border-radius: 50% !important; background: rgba(255,255,255,.12) !important; border: none !important; color: #fff !important; font-size: 20px !important; cursor: pointer !important; display: flex !important; align-items: center !important; justify-content: center !important; transition: background .2s !important; }
.wl-lightbox-close:hover { background: rgba(255,255,255,.22) !important; }

/* Изображение документа — кликабельное */
.wl-who-doc-img-wrap img { cursor: zoom-in !important; transition: opacity .2s !important; }
.wl-who-doc-img-wrap img:hover { opacity: .88 !important; }

/* ══ Долями кнопка ══ */
.wl-dlm-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  width: 100% !important;
  padding: 13px 20px !important;
  margin-top: 10px !important;
  background: #1a1a2e !important;
  color: #fff !important;
  border: none !important;
  border-radius: 8px !important;
  font-family: 'Jost', sans-serif !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  letter-spacing: 0.04em !important;
  cursor: pointer !important;
  transition: opacity 0.2s !important;
  white-space: nowrap !important;
}
.wl-dlm-btn:hover { opacity: 0.85 !important; }
.wl-dlm-btn:disabled { opacity: 0.5 !important; cursor: default !important; }
.wl-dlm-logo {
  height: 16px !important;
  width: auto !important;
  display: inline-block !important;
  vertical-align: middle !important;
  margin: 0 !important;
}