
/* Fonts (Golos UI) */
    @font-face {
      font-family: "Golos UI";
      src:
        url("../fonts/golos-ui_regular.woff2") format("woff2"),
        url("../fonts/golos-ui_regular.woff") format("woff");
      font-weight: 400;
      font-style: normal;
      font-display: swap;
    }
    @font-face {
      font-family: "Golos UI";
      src:
        url("../fonts/golos-ui_medium.woff2") format("woff2"),
        url("../fonts/golos-ui_medium.woff") format("woff");
      font-weight: 500;
      font-style: normal;
      font-display: swap;
    }
    @font-face {
      font-family: "Golos UI";
      src:
        url("../fonts/golos-ui_bold.woff2") format("woff2"),
        url("../fonts/golos-ui_bold.woff") format("woff");
      font-weight: 700;
      font-style: normal;
      font-display: swap;
    }

    :root{
  /* Theme colors */
  --color-primary: #003087;
  --color-secondary: #8B1F51;
  --color-body: #FAFAFA;
  --color-white: #ffffff;
  --color-black: #000000;
  --color-gray: #424242;
  --color-blue: #3b82f6;
  --menu-overlay: var(--color-black);
  /* Brand gradient is pre-mixed with the page background color to match the intended 85% opacity look on #FAFAFA */
  --brand-gradient: linear-gradient(180deg, #194492 0%, #963562 100%);

  /* Base tokens */
  --text: var(--color-black);
  --bg-gray: #E7E7E7;
  --space-16: 16px;
  --space-18: 18px;
  --space-24: 24px;
  --space-25: 25px;
  --space-40: 40px;

  /* Transitions */
  --transition-duration: 200ms;

  /* Z-index tokens */
  --z-1: 1;
  --z-2: 2;
  --z-5: 5;
  --z-40: 40;
  --z-50: 50;
  --z-60: 60;

  /* Font sizes */
  --fs-large: 42px;
  --fs-big: 36px;
  --fs-32: 32px;
  --fs-28: 28px;
  --fs-24: 24px;
  --fs-medium: 20px;
  --fs-default: 15px;
  --fs-16-mob: 16px;
  --fs-14-mob: 14px;

  /* Font weights */
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-bold: 700;

  /* Radii */
  --radius-lg: 35px;
  --radius-md: 20px;
  --radius-sm: 16px;
  --radius-pill: 152px;

  /* Shadows */
  --shadow-default:
    0 8px 16px 0 rgba(0, 0, 0, 0.08),
    0 0 4px 0 rgba(0, 0, 0, 0.04);
}

    @supports (background: color-mix(in srgb, white 50%, black)) {
      :root{
        --brand-gradient: linear-gradient(
          180deg,
          color-mix(in srgb, var(--color-primary) 90%, var(--color-body)) 0%,
          color-mix(in srgb, var(--color-secondary) 90%, var(--color-body)) 100%
        );
        --shadow-default:
          0 8px 16px 0 color-mix(in srgb, var(--color-black) 8%, transparent),
          0 0 4px 0 color-mix(in srgb, var(--color-black) 4%, transparent);
      }
    }


    /* Typography utilities */
    .fs-default{ font-size: var(--fs-default); }
    .fs-medium{ font-size: var(--fs-medium); }
    .fs-big{ font-size: var(--fs-big); }
    .fs-large{ font-size: var(--fs-large); }
    html, body { height: 100%; }
    body{
      font-family: "Golos UI", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      background: var(--color-body);
      color: var(--text);
      font-weight: var(--fw-regular);
      font-size: var(--fs-default);
      line-height: 1.35;
    }

    input,
    textarea,
    select{
      background: var(--bg-gray);
      color: var(--text);
      transition: box-shadow var(--transition-duration) ease;
    }

input:focus,
    textarea:focus,
    select:focus,
    input:focus-visible,
    textarea:focus-visible,
    select:focus-visible{
      outline: none;
      background-color: var(--color-white);
      box-shadow:
        var(--shadow-default),
        0 0 0 2px rgba(0, 48, 135, 0.45);
    }

    @supports (background: color-mix(in srgb, white 50%, black)) {
      input:focus,
      textarea:focus,
      select:focus,
      input:focus-visible,
      textarea:focus-visible,
      select:focus-visible{
        box-shadow:
          var(--shadow-default),
          0 0 0 2px color-mix(in srgb, var(--color-primary) 45%, transparent);
      }
    }

    a:hover{ text-decoration: none; }

    a[class]:focus-visible,
    button:focus-visible {
      outline: 2px solid var(--color-blue);
      outline-offset: 2px;
      box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.2);
    }

    /* Screen reader text (WP canonical). Keeps skip-link available but hidden until focus. */
    .screen-reader-text{
      border: 0;
      clip: rect(1px, 1px, 1px, 1px);
      clip-path: inset(50%);
      height: 1px;
      margin: -1px;
      overflow: hidden;
      padding: 0;
      position: absolute;
      width: 1px;
      white-space: nowrap;
    }
    .screen-reader-text:focus{
      clip: auto !important;
      clip-path: none;
      height: auto;
      width: auto;
      margin: 0;
      overflow: visible;
      left: 12px;
      top: 12px;
      padding: 10px 14px;
      border-radius: 10px;
      background: var(--color-white);
      color: var(--text);
      text-decoration: none;
      z-index: var(--z-60, 9999);
    }

    /* Header (desktop base) */
    .site-header{
      background: var(--color-white);
      box-shadow: var(--shadow-default);
      position: relative;
      z-index: var(--z-60);
    }

.site-header::after{
  content:"";
  position:absolute;
  inset:0;
  background: var(--menu-overlay);
  opacity: 0;
  transition: opacity var(--transition-duration) ease;
  pointer-events: none;
}
body.desktop-menu-open .site-header::after{ opacity: 0.5; }

    .header-inner{
      padding-top: 38px;
      padding-bottom: 28px;
    }

    .header-left{ display:flex; align-items:center; }
    .brand-logos{ display:flex; align-items:center; gap: 28px; text-decoration: none; }
    .brand-logos img{ display:block; height: 54px; width:auto; }

    .header-right{ display:flex; flex-direction:column; justify-content:center; gap: 22px; }
    .header-right-top{
      display:grid;
      grid-template-columns: 3fr 2fr 2fr;
      column-gap: 32px;
      align-items:center;
    }

    .header-search{ position: relative; }
    .header-search input{
      display:block;
      height: 40px;
      border-radius: 999px;
      border: 0;
      padding-left: 58px;
      padding-right: 58px;
      text-align: center;
      font-size: inherit;
}
    .header-search input::placeholder{ color: var(--color-gray); }
    .header-search .icon{
      position:absolute;
      left: 20px;
      top: 50%;
      transform: translateY(-50%);
      width: 16px;
      height: 16px;
      color: var(--color-gray);
      pointer-events:none;
    }

    .contact-link{
      color: var(--color-primary);
      text-decoration: none;
      line-height: 1.15;
      white-space: nowrap;
      justify-self: end;
    }

    .top-nav{  padding-top: 5px;

      display:flex;
      align-items:center;
      justify-content: space-between;
      gap: 36px;
      flex-wrap: nowrap;
    }
    .top-nav-btn{
      border: 0;
      background: transparent;
      padding: 0;
      color: var(--color-gray);
      text-decoration: none;
      font-size: var(--fs-medium);
      font-weight: var(--fw-medium);
      line-height: 1.15;
      white-space: nowrap;
      cursor: pointer;
    }

    /* Desktop submenu overlay */
    .desktop-menu-overlay{
      position: fixed;
      inset: 0;
      background: var(--menu-overlay);
      opacity: 0;
      transition: opacity var(--transition-duration) ease;
      z-index: var(--z-40);
    }
    .desktop-menu-overlay.is-visible{ opacity: 0.5; }

    .desktop-submenu{
      position: fixed;
      z-index: var(--z-50);
      background: linear-gradient(var(--color-white), var(--color-white)) padding-box,
      var(--brand-gradient) border-box;
      border: 1px solid transparent;

      box-shadow: var(--shadow-default);
      border-radius: 0 var(--radius-lg) var(--radius-lg) var(--radius-lg);
      padding: 32px;
      width: auto;
      max-width: calc(100vw - 48px);
      left: var(--desktop-submenu-left, 50%);
      opacity: 0;
      transform: translate(var(--desktop-submenu-shift, -50%), -6px);
      transition: opacity var(--transition-duration) ease, transform var(--transition-duration) ease;
    }
    .desktop-submenu.is-open{
      opacity: 1;
      transform: translate(var(--desktop-submenu-shift, -50%), 0);
    }


    .desktop-submenu-list{
      list-style: none;
      margin: 0;
      padding: 0;
    }
    .desktop-submenu-item{ margin: 0; padding: 0; }
    .desktop-submenu-link{
      display: block;
      font-size: var(--fs-medium);
      font-weight: var(--fw-regular);
      line-height: 1.25;
      color: var(--text);
      text-decoration: none;
      padding: 10px 0;
    }
    .desktop-submenu-link:hover{ color: var(--color-primary); }

    @media (max-width: 1199.98px){
      .desktop-menu-overlay,
      .desktop-submenu{ display: none !important; }
    }

    /* Mobile header + mobile menu (375px) */
    @media (max-width: 1199.98px){
      .mobile-header{
        padding-top: var(--space-18);
        padding-bottom: var(--space-18);
      }

      .mobile-header-row{ min-height: 72px; }

      .mobile-logo-group{
        display: flex;
        align-items: center;
        gap: 12px;
        width: 100%;
        text-decoration: none;
      }
      .mobile-logo{ display:block; width: 100%; }
      .mobile-logo img{
        display:block;
        width: 100%;
        height: 44px;
        max-width: 100%;
        object-fit: contain;
        object-position: center;
      }

      .mobile-menu-btn{
        border: 0;
        background: transparent;
        padding: 0;
        cursor: pointer;
        display: inline-flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 8px;
      }

      /* Иконка меню: 32×18 */
      .mobile-burger{
        width: 32px;
        height: 18px;          
        display: inline-flex;
        flex-direction: column;
        align-items: center;
        justify-content: space-between; /* ровно распределим 3 линии по высоте 18 */
      }
      .mobile-burger span{
        display:block;
        width: 32px;
        height: 3px;
        background: var(--color-primary);
        border-radius: 999px;
        transition: transform var(--transition-duration) ease, opacity var(--transition-duration) ease;
        transform-origin: center;
      }

      /* X состояние: центрируем линии внутри 18px высоты */
      .mobile-menu-btn.is-open .mobile-burger span:nth-child(1){
        transform: translateY(7.5px) rotate(45deg);
      }
      .mobile-menu-btn.is-open .mobile-burger span:nth-child(2){
        opacity: 0;
      }
      .mobile-menu-btn.is-open .mobile-burger span:nth-child(3){
        transform: translateY(-7.5px) rotate(-45deg);
      }

      /* "Меню" 14px */
      .mobile-menu-text{
        font-size: var(--fs-14-mob);       
        line-height: 1;
        font-weight: var(--fw-medium);
        color: var(--color-primary);
        user-select: none;
      }

      .mobile-menu-wrapper{
        padding-left: var(--space-24);
        padding-right: var(--space-24);
      }
      .mobile-menu-wrapper .collapse{ margin-top: 0; }

/* Mobile menu panel transition */
.mobile-menu-collapse .mobile-menu-panel{
  opacity: 0;
  transform: translateY(-8px);
  transition: opacity var(--transition-duration) ease, transform var(--transition-duration) ease;
}
.mobile-menu-collapse.show .mobile-menu-panel,
.mobile-menu-collapse.collapsing .mobile-menu-panel{
  opacity: 1;
  transform: translateY(0);
}

      /* сверху без скруглений */
      .mobile-menu-panel{
        background: var(--color-white);
        border-radius: 0 0 56px 56px;
        box-shadow: var(--shadow-default);
        width: 100%;
        margin: 0;
        margin-bottom: 24px;
        padding: 36px 28px 44px;
      }

      .mm-grid{
        display: grid;
        grid-template-columns: 1fr 1fr;
        column-gap: 32px;
        align-items: start;
        padding-bottom: 60px;
      }

      /* Все пункты меню: 16px, жирность дефолтная */
      .mm-item,
      .mm-acc-btn{
        font-size: var(--fs-16-mob);
        line-height: 1.25;
        font-weight: var(--fw-regular);
        color: var(--color-black);
      }

      .mm-item{
        display: block;
        text-decoration: none;
        margin: 0;
        padding: 0;
        padding-bottom: 20px;
      }

      .mm-item.mm-search-trigger{
        width: 100%;
        border: 0;
        background: transparent;
        text-align: left;
        cursor: pointer;
      }

      .mm-acc-btn{
        width: 100%;
        border: 0;
        background: transparent;
        padding: 0 0 10px 0;
        display:flex;
        align-items:center;
        justify-content: space-between;
        gap: 10px;
        cursor: pointer;
        margin: 0;
      }

      /* When the accordion section is closed, keep spacing consistent with .mm-item */
      .mm-acc-btn[aria-expanded="false"]{ padding-bottom: 20px; }

      .mm-caret{
        width: 10px;
        height: 10px;
        display: inline-block;
        border-right: 1.6px solid var(--color-gray);
        border-bottom: 1.6px solid var(--color-gray);
        transform: rotate(45deg);
        transition: transform var(--transition-duration) ease;
        flex: 0 0 auto;
        margin-top: 1px;
      }

      .mm-acc-btn[aria-expanded="true"] .mm-caret{ transform: rotate(225deg); }


      
      .mm-sub{ margin-top: 10px; }
      .mm-sub a{
        display:block;
        text-decoration:none;
        font-size: var(--fs-14-mob);
        line-height: 1.25;
        font-weight: var(--fw-regular);
        color: var(--color-gray);
        margin: 14px 0;
        max-width: 160px;
        hyphens: auto;
      }
      /* Телефон и почта: 14px */
      .mm-contacts{ margin-top: 14px; }
      .mm-contact{
        display:inline-block;
        width: fit-content;
        font-size: var(--fs-14-mob);
        line-height: 1.25;
        font-weight: var(--fw-regular);
        color: var(--color-primary);
        text-decoration: none;
        margin: 14px 0;
        white-space: nowrap;
      }

      /* нижние пункты: 16px weight 400 */
}
    /* Footer (как было) */
    .site-footer{
      position: relative;
      padding-bottom: 50px;
      overflow: hidden;
      color: var(--color-white);
      margin-top: 64px;
      background: var(--brand-gradient);
    }
    .site-footer::before {
      content: "";
      position: absolute;
      top: 64px;
      right: 0;
      bottom: 0;
      width: 46%;
      background: url("../images/hat.svg") right center / contain no-repeat;
      opacity: .55;
      pointer-events: none;
    }
    .site-footer > .container-xxl{ position: relative; z-index: var(--z-1); }

    .site-footer a,
    .site-footer a:visited{
      color: inherit;
      text-decoration: none;
    }

    .footer-inner{ padding-top: 52px; padding-bottom: 10px; }

    .footer-brand{
      display:flex;
      align-items:center;
      gap: 26px;
      margin-bottom: 34px;
    }
    .footer-brand img{ display:block; height: 40px; width:auto; }

    .footer-contact{ margin: 0; font-size: var(--fs-28); }
    .footer-contact + .footer-contact{ margin-top: 16px; }
    .footer-contact a{ color: var(--color-white); }

    .footer-social{
      display:flex;
      align-items:center;
      gap: 34px;
      margin-top: 22px;
      margin-bottom: 44px;
    }
    .footer-social img{ display:block; width:auto; height: 24px; }

    .footer-social__list{
      list-style:none;
      padding:0;
      margin:0;
      display:flex;
      align-items:center;
      gap: 34px;
    }
    .footer-social__item{
      display:block;
      margin:0;
      padding:0;
    }

    .footer-address{ color: var(--color-white); }

    .footer-h{ margin: 0 0 14px 0; color: var(--color-white); line-height: 1.2; }

    .footer-links{
      list-style:none;
      padding:0;
      margin:0;
      display:flex;
      flex-direction:column;
      gap: 8px;
    }
    .footer-links a{ color: var(--color-white); text-decoration: none; }

    .footer-cta{
      display:flex;
      flex-direction:column;
      gap: 16px;
    }
    .footer-cta a{ color: var(--color-white); text-decoration:none; font-weight: var(--fw-medium); }

    .footer-bottom{

      /* прижимаем копирайт к нижнему краю футера */
      margin-top: auto;
      padding: var(--space-18) 0 0; /* отступ сверху оставляем, снизу — 0 */
      color: var(--color-white);
  line-height: 1.25;
display:flex;
      align-items:flex-end;
    
}
    .footer-bottom-text{ display:block; text-align: left; margin: 0; font-size: var(--fs-default); }
  
main{ margin-top: 80px; }

/* Главная страница: без верхнего отступа у main */
.home main,
.front-page main{
  margin-top: 0;
}

.breadcrumbs{
  margin: 0 0 44px;
  color: var(--color-gray);
  font-size: var(--fs-medium);
  font-weight: var(--fw-medium);
}

.breadcrumbs__list{
  display:block;
  margin:0;
  padding:0;
  list-style:none;
}

/*
  Separator is attached to the previous crumb.
  This prevents the dash from jumping to the next line when breadcrumbs wrap.
*/
.breadcrumbs__list li{
  display:inline;
}

.breadcrumbs__list li:not(:last-child)::after{
  content:"\00a0—\00a0";
  opacity:0.6;
}

.breadcrumbs a{
  color:inherit;
  text-decoration:none;
}

.breadcrumbs-current{
  cursor:default;
}

.page-title{
  color: var(--color-primary);
}

.page-content{
  margin-top: 32px;
}

/* 404 page */
.page-404{
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.page-404__title{
  color: var(--color-primary);
  margin: 0 0 16px;
}

.page-404__lead{
  color: var(--color-gray);
  margin: 0 0 10px;
}

.page-404__hint{
  color: var(--color-gray);
  margin: 0 0 28px;
}

.page-404__btn{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 360px;
  text-decoration: none;
}

/* About page */
.about-why-list{
  display: flex;
  flex-direction: column;
  gap: var(--space-25);
  margin: var(--space-25) 0;
}

.about-why-item{
  display: flex;
  align-items: stretch;
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-default);
  overflow: hidden;
}

.about-why-item.is-reverse{ flex-direction: row-reverse; }

.about-why-pill{
  flex: 0 0 30%;
  display: flex;
  align-items: center;
  padding: calc(var(--space-25) * 2);
  color: var(--color-white);
  border-radius: var(--radius-lg);
}

.about-why-pill--primary{ background: rgba(0, 48, 135, 0.8); background: color-mix(in srgb, var(--color-primary) 80%, transparent); }
.about-why-pill--secondary{ background: rgba(139, 31, 81, 0.8); background: color-mix(in srgb, var(--color-secondary) 80%, transparent); }

.about-why-pill__title{ font-size: var(--fs-28); line-height: 1.1; }

.about-page h2.page-title{
  font-size: var(--fs-large);
  font-weight: var(--fw-bold);
  line-height: 1.15;

}

.about-why-body{
  flex: 1;
  padding: calc(var(--space-25) * 2);
}

.about-achievements{ margin-top: var(--space-25); }

.about-achievements .faq-question{
  display: flex;
  align-items: center;
  gap: var(--space-25);
  line-height: 1.25;

}

.about-achievement-num{
  color: var(--color-secondary);
  font-size: var(--fs-large);
  font-weight: var(--fw-bold);
}

.about-achievement-title{
  font-size: var(--fs-medium);
}

.about-award-img{
  width: 100%;
  height: auto;
  display: block;
  border-radius: 0;
  box-shadow: var(--shadow-default);
}

@media (max-width: 991.98px){
  .about-why-item,
  .about-why-item.is-reverse{ flex-direction: column; }

  .about-why-pill{ flex-basis: auto; }
}

    
/* FAQ */
.faq-list{
  display:flex;
  flex-direction:column;
  gap: 20px;
  margin-top: 32px;
}

.faq-item{
  /* Визуально вопрос (верх) и ответ (низ) как два слоя:
     ответ «выезжает» из‑под вопроса, не меняя верстку */
  background: transparent;
  border-radius: var(--radius-lg);
  box-shadow: none;
  overflow: visible;
  position: relative;
}

.faq-toggle{
  width: 100%;
  display:flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-24);
  padding: var(--space-24) 48px;
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-default);
  position: relative;
  z-index: var(--z-2);
  border: 0;
  text-align: left;
  cursor: pointer;
  color: inherit;
  text-decoration: none;
}

.faq-question{
  color: var(--color-primary);
  line-height: 1.2;
  font-weight: var(--fw-bold);
}

.faq-action,
.achievements-action{
  color: var(--color-gray);
  white-space: nowrap;
}

.about-achievements .achievements-action{
  text-decoration: underline;
}

.faq-content{
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--transition-duration) ease;
}

.faq-item.is-open .faq-content{
  grid-template-rows: 1fr;
}

.faq-content-inner{
  overflow: hidden;
  /* Подложка под вопросом: лёгкое перекрытие и тот же радиус снизу */
  margin-top: calc(var(--radius-md) * -1);
  padding: 48px;
  background: var(--color-white);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  box-shadow: var(--shadow-default);
  opacity: 0;
  transform: translateY(calc(var(--radius-md) * -1));
  transition: opacity var(--transition-duration) ease, transform var(--transition-duration) ease;
}

.faq-item.is-open .faq-content-inner{
  opacity: 1;
  transform: translateY(0);
}

.faq-text{
  margin: 0;
  color: var(--color-black);
  line-height: 1.5;

}

/* Shared utilities / shared controls */
/* Hover interactions */
    .top-nav .top-nav-btn{ transition: color var(--transition-duration) ease; }
    .top-nav .top-nav-btn:hover{ color: var(--color-primary); }

    /* Shared underline utility */
    .link-underline{
      position: relative;
      text-decoration: none;
    }
    .link-underline::after{
      content:"";
      position:absolute;
      left:0;
      bottom:-3px;
      width:100%;
      height:1px;
      background-color: currentColor;
      transform: scaleX(0);
      transform-origin: left;
      transition: transform var(--transition-duration) ease;
    }
    .link-underline:hover::after{ transform: scaleX(1); }

    /* Footer links: prevent underline stretching across empty space */
    .site-footer .link-underline{
      display: inline-block;
      width: fit-content;
      max-width: 100%;
    }

    /* Mobile menu hover to primary */
    @media (max-width: 991.98px){
      .mm-item,
      .mm-acc-btn,
      .mm-sub a,
      .mm-contact{
        transition: color var(--transition-duration) ease;
      }
      .mm-item:hover,
      .mm-sub a:hover,
      .mm-contact:hover{
        color: var(--color-primary);
      }
      .mm-acc-btn:hover{ color: var(--color-primary); }
    }
    
    .footer-contact-line{  line-height: 1.15;
margin: 0; }
    .footer-contact-line + .footer-contact-line{ margin-top: 16px; }
    .footer-contact-link{ color: var(--color-white); text-decoration: none; }
.footer-h--spaced{ margin-top: 28px; }

.pagination{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-top: 48px;
  margin-bottom: 34px;
}

.arrow{
  width: 40px;
  height: 40px;
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border: 0;
  cursor: pointer;
  font: inherit;
  background: transparent;
  transition: background var(--transition-duration) ease;
  --arrow-fill: var(--color-gray);
}

/* Buttons: reset UA defaults for arrow controls */
button.arrow{
  background: none;
  border: 0;
  padding: 0;
  font: inherit;
  color: inherit;
  -webkit-appearance: none;
  appearance: none;
}


.arrow svg{
  color: var(--arrow-fill);
  transition: color var(--transition-duration) ease;
}

.arrow svg path{
  fill: var(--arrow-fill);
  transition: fill var(--transition-duration) ease;
}

.arrow:hover{
  background: transparent;
  --arrow-fill: var(--color-primary);
}

/* Disabled state for pagination arrows/numbers (used by JS) */
.arrow.is-disabled,
.arrow:disabled,
.arrow[aria-disabled="true"]{
  opacity: 0.45;
  pointer-events: none;
  cursor: default;
}

/* Pagination numbers (shared) */
.page-number{
  font-size: var(--fs-medium);

  height: 45px;
  padding: 0 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-pill);
  background: var(--bg-gray);
  color: var(--color-black);
  text-decoration: none;
  font-weight: var(--fw-medium);
  transition: background var(--transition-duration) ease, color var(--transition-duration) ease;

  /* make buttons look like links */
  border: 0;
  cursor: pointer;
  font-family: inherit;
}

.page-number.is-current,
.page-number.page-dots{
  cursor: default;
}

.page-number.page-dots{
  pointer-events: none;
}

a.page-number:hover{
  background: rgb(from var(--color-primary) r g b / 0.12);
  color: var(--color-primary);
}

.page-number.is-active{
  background: var(--color-primary);
  color: var(--color-white);
}

@media (max-width: 767.98px){
  .pagination{
    flex-wrap: wrap;
    gap: 12px 10px;
    margin-top: 32px;
  }

  .arrow{
    width: 32px;
    height: 32px;
    flex: 0 0 32px;
  }

  .page-number{
    min-width: 44px;
    height: 44px;
    padding: 0 14px;
    flex: 0 0 auto;
  }
}


/* Teachers grid */
    .teacher-card{
      background: var(--color-white);
      border-radius: var(--radius-lg);
      box-shadow: var(--shadow-default);
      padding: 26px 28px;
      display: flex;
      gap: 28px;
      align-items: flex-start;
      min-height: 105px;
    }

    .teacher-photo-wrap{
      flex: 0 0 auto;
      width: 200px;
      height: 200px;
      border-radius: var(--radius-md);
      overflow: hidden;
    }

    .teacher-photo{
      width: 200px;
      height: 200px;
      object-fit: cover;
      border-radius: var(--radius-md);
      display: block;
    }
    .teacher-meta{ min-width: 0; }

.teacher-name{
      font-size: var(--fs-medium); /* 20px */
      font-weight: var(--fw-bold);
      color: var(--color-primary);
      margin: 6px 0 12px;
  line-height: 1.25;
display: block;
      text-decoration: none;
    }

    .teacher-name a{
      color: inherit;
      text-decoration: none;
    }

    .teacher-photo-wrap a{ display:block; text-decoration:none; }

    .teacher-role{
      font-weight: var(--fw-regular);
      color: var(--color-black);
    
  font-size: var(--fs-medium);
}

    @media (max-width: 991.98px){
      .teacher-card{
        padding: 22px;
        gap: var(--space-24);
      }
      .teacher-photo-wrap,
      .course-page .teacher-photo-wrap,
      .course-page .teacher-photo,
      .teacher-photo{
        width: 160px;
        height: 160px;
      }
      .teacher-role{ max-width: none; }
    }

    @media (max-width: 575.98px){
      .teacher-card{
        flex-direction: column;
      }

      .teacher-photo-wrap,
      .course-page .teacher-photo-wrap,
      .course-page .teacher-photo,
      .teacher-photo{
        width: 100%;
        height: auto;
      }
    }

/* Teacher page */
.teacher-page .teacher-profile-card{
  margin-top: var(--space-25);
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-default);
  padding: calc(var(--space-25) * 2);
}

.teacher-page .teacher-profile-grid{
  display: grid;
  grid-template-columns: auto 1fr;
  gap: calc(var(--space-25) * 2);
  align-items: start;
}

.teacher-page .teacher-profile-photo{
  flex: 0 0 auto;
  width: calc(var(--space-25) * 12);
  max-width: 100%;
}

.teacher-page .teacher-profile-img{
  width: 100%;
  max-width: 100%;
  aspect-ratio: 1 / 1;
  height: auto;
  object-fit: cover;
  display: block;
  border-radius: var(--radius-md);
}

.teacher-page .teacher-profile-body{
  font-size: var(--fs-medium);
}

.teacher-page .teacher-profile-role{
  font-size: inherit;
  font-weight: var(--fw-regular);
  line-height: 1.35;
  margin: 0 0 calc(var(--space-25) * 0.8);
}

.teacher-page .teacher-profile-text{
  font-weight: var(--fw-regular);
}

.teacher-page .teacher-profile-text p{
  margin: 0 0 calc(var(--space-25) * 0.8);
  line-height: 1.5;

}
.teacher-page .teacher-profile-text p:last-child{ margin-bottom: 0; }

.teacher-page .teacher-edu{
  margin-top: calc(var(--space-25) * 1.2);
  display: flex;
  flex-direction: column;
  gap: calc(var(--space-25) * 0.8);
}

.teacher-page .teacher-edu-title{
  font-size: inherit;
  font-weight: var(--fw-bold);
  color: var(--color-black);
}

.teacher-page .teacher-edu-items{
  display: flex;
  flex-wrap: wrap;
  gap: calc(var(--space-25) * 1.2);
}

.teacher-page .teacher-edu-item{
  display: flex;
  gap: 10px;
  align-items: flex-start;
}

.teacher-page .teacher-edu-icon{
  width: 24px;
  height: 24px;
  color: var(--color-secondary);
  flex: 0 0 auto;
}

.teacher-page .teacher-edu-icon svg{ display: block; width: 100%; height: 100%; }

.teacher-page .teacher-edu-line{
  font-size: inherit;
  line-height: 1.25;
}

.teacher-page .teacher-courses-title{ margin-top: calc(var(--space-25) * 2); }
.teacher-page .courses-grid{
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (max-width: 991.98px){
  .teacher-page .teacher-profile-card{ padding: 22px; }
  .teacher-page .teacher-profile-grid{ grid-template-columns: 1fr; }
  .teacher-page .teacher-profile-photo{
    width: 100%;
    max-width: none;
    margin-inline: 0;
  }
  .teacher-page .teacher-profile-img{
    width: 100%;
    max-width: none;
  }
  .teacher-page .courses-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 575.98px){
  .teacher-page .courses-grid{ grid-template-columns: 1fr; }
}

@media (min-width: 1400px){
  .container-xxl{
    --bs-gutter-x: 3rem; /* 48px суммарно, т.е. по 24px слева/справа */
  }
}

.mm-item:last-child{
  padding-bottom: 0;
}

/* News page */
.news-grid{
  margin-top: 28px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-24);
}

.news-card{
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-default);
  padding: var(--space-24);
  min-height: 420px;
  display: flex;
  flex-direction: column;
  position: relative;
}

.news-card__image{
  display: block;
  height: 275px;
  aspect-ratio: 580 / 275;
  border-radius: calc(var(--radius-md) - 4px);
  overflow: hidden;
  background: var(--bg-gray);
  margin-bottom: var(--space-18);
}

.news-card__image img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
}

.news-card__title{
  font-size: 18px;
  font-weight: var(--fw-bold);
  margin: 0 0 10px;
  line-height: 1.15;
}

.news-card__title a{
  color: inherit;
  text-decoration: none;
}

.news-card__excerpt{
  margin: 0 0 16px;
  color: var(--color-black);
  font-size: var(--fs-default);
  font-weight: var(--fw-medium);
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Ensure date block can stick to bottom even when wrapped in meta container */
.news-card__meta{
  margin-top: auto;
}

.news-card__date{
  margin-top: auto;
  font-size: var(--fs-default);
  color: var(--color-black);
}

.news-card--featured{
  background: rgb(from var(--color-primary) r g b / 0.8);
  color: var(--color-white);
  padding: 28px;
}

.news-card--featured .news-card__excerpt{
  color: var(--color-white);
}

.news-card--featured .news-card__date{
  color: var(--color-white);
}

.news-card--featured .news-card__title{
  color: var(--color-white);
}

@media (max-width: 991.98px){
  .news-grid{ grid-template-columns: 1fr; }
  .news-card{ min-height: auto; }
}

@media (max-width: 575.98px){
  .news-card__image{
    height: auto;
    aspect-ratio: 16 / 10;
  }
}

/* News detail page */

.news-detail-page{ padding-bottom: 80px; }

.news-detail-title{
  margin: 16px 0 12px;
  line-height: 1.15;
color: var(--color-primary);
}

.news-detail-date{
  color: var(--color-gray);
  display: block;
  font-size: var(--fs-medium);
  font-weight: var(--fw-medium);
  margin: var(--space-25) 0;
}

.news-detail-content{
  font-size: var(--fs-medium);
  font-weight: var(--fw-regular);
  line-height: 1.5;

}

.news-detail-content p{
  font-weight: var(--fw-medium);
  margin: 0 0 var(--space-18);
}

.news-detail-content.about-lead p{
  font-weight: var(--fw-regular);
}

.achievements-content{
  font-size: var(--fs-medium);
  font-weight: var(--fw-regular);
  line-height: 1.5;

}

.achievements-content p{ margin: 0 0 var(--space-18); }

.achievements-content.about-lead p{ font-weight: var(--fw-regular); }

.news-detail-quote{
  margin: 22px 0;
  padding: var(--space-24);
  border-radius: var(--radius-lg);
  background: var(--color-white);
  box-shadow: var(--shadow-default);
}

.news-detail-quote p{ margin: 0; }

.news-detail-quote footer{
  margin-top: 14px;
  color: var(--color-gray);
  font-size: var(--fs-default);
  font-weight: var(--fw-medium);
}



/* Documents page */

.documents-page{ padding-bottom: 80px; }

.documents-subtitle{
  margin: 30px 0 40px;
  color: var(--color-secondary);
}

.documents-list{
  display: flex;
  flex-direction: column;
  gap: var(--space-18);
}

.document-card{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-24);
  padding: 20px var(--space-24);
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-default);
}

.document-card__title{
  margin: 0;
  color: var(--color-black);
  line-height: 1.25;
  padding-left: 20px;

  flex: 1 1 auto;
  min-width: 0;

}

.document-card__actions{
  display: flex;
  align-items: center;
  gap: var(--space-18);
  flex: 0 0 auto;
  flex-shrink: 0;
}

.document-card__download{
  color: var(--color-primary);
  white-space: nowrap;
  flex: 0 0 auto;
}

.document-card__download:hover{ text-decoration: underline; }

@media (max-width: 991.98px){
  .document-card{ flex-direction: column; align-items: flex-start; }
  .document-card__actions{ width: 100%; justify-content: flex-end; }
  .document-card__title{ padding-left: 0; }
}

/* HOME PAGE */
.home-page{ padding-bottom: 0; }

.home-hero{
  margin-top: 0;
  border-radius: 0;
  overflow: hidden;
  background: var(--brand-gradient);
  box-shadow: none;
}
.home-hero__inner{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-24);
  min-height: 320px;
}
.home-hero__content{
  padding: 56px 0;
  color: var(--color-white);
}
.home-hero__title{
  margin: 0 0 16px;
  font-size: 52px;
  font-weight: var(--fw-bold);
  line-height: 1.25;

}
.home-hero__lead{
  margin: 5px 0 var(--space-24);
  font-size: 28px;
  font-weight: var(--fw-regular);
  line-height: 1.25;

}
.home-hero__cta{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 54px;
  padding: 0 36px;
  border-radius: var(--radius-pill);
  background: var(--color-white);
  color: var(--color-primary);
  font-size: var(--fs-medium);
  font-weight: var(--fw-medium);
  text-decoration: none;
  margin: 20px 0;
}
.home-hero__stats{
  display: flex;
  flex-wrap: nowrap;
  gap: var(--space-18);
  margin-top: 32px;
}
.home-stat__value{
  font-size: var(--fs-large);
  font-weight: var(--fw-bold);
  line-height: 1.15;

}
.home-stat__label{
  font-size: var(--fs-medium);
  font-weight: var(--fw-regular);
}

@media (max-width: 575.98px){
  .home-stat__value{
    font-size: 28px;
  }
}

.home-hero__art{
  position: relative;
  overflow: hidden;
}

.home-hero__art-img{
  position: absolute;
  right: 0;
  top: 60px;
  width: 100%;
  height: calc(100% - 60px);
  object-fit: contain;
}

@media (max-width: 991.98px){
  .home-hero__art-img{
    top: 0;
    height: auto;
  }
}

.home-section{  
  padding-top: 48px;
  padding-bottom: 0;
}


.home-section.home-partners{
  padding-top: 68px;
}

.home-section__head{
  display: flex;
  align-items: center;
  gap: 16px;
  

  margin-bottom: 50px;
}
.home-section__title{
  margin: 0;
  font-size: 42px;
  font-weight: var(--fw-bold);
  color: var(--color-primary);
}
.home-section__hint{
  font-size: 20px;
  font-weight: var(--fw-medium);
  color: var(--color-gray);
  flex: 1;
  text-align: right;
}
.home-section__head > .home-section__link,
.home-section__head > .home-partners__arrows{
  margin-left: auto;
}
.home-section__link{
  font-size: var(--fs-medium);
  font-weight: var(--fw-medium);
  color: var(--color-primary);
  text-decoration: none;
}
.home-section__link:hover{ text-decoration: underline; }

@media (max-width: 767.98px){
  .home-reviews .home-section__head{
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
    gap: 12px 16px;
    margin-bottom: 32px;
  }

  .home-reviews .home-section__title{
    grid-column: 1;
    grid-row: 1;
  }

  .home-reviews .home-reviews__arrows{
    grid-column: 2;
    grid-row: 1;
    justify-self: end;
    display: inline-flex;
    align-items: center;
    gap: 8px;
  }

  .home-reviews .home-section__hint{
    grid-column: 1 / -1;
    grid-row: 2;
    text-align: left;
    flex: none;
    font-size: 16px;
    line-height: 1.25;
  }
}

.home-tabs-row{
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 16px;
  align-items: center;
  margin-bottom: var(--space-25);
}
.home-tabs{
  grid-column: 1 / span 11;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 0;
}
.tab-tab{
  border: 0;
  background: #EDEDED;
  color: var(--color-gray);
  text-decoration: none;
  
  padding: 10px 16px;
  font-size: var(--fs-medium);
  font-weight: var(--fw-regular);

  border-radius: var(--radius-pill);
}
.tab-tab.is-active{
  background: var(--color-primary);
  color: var(--color-white);
}

.home-tabs-nav{
  grid-column: 12 / span 1;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  justify-self: end;
  width: fit-content;
}

.home-program-cards{
  overflow: hidden;
  padding-top: 10px;
  padding-left: var(--space-24);
  padding-right: var(--space-24);
  padding-bottom: 70px;
  box-sizing: border-box;
}
.home-program-cards__track{
  display: flex;
  gap: var(--space-18);
  will-change: transform;
  transition: transform 350ms ease;
}
.home-program-card{
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-default);
  padding: 40px;
  flex: 0 0 calc((100% - 54px) / 4);
  display: flex;
  flex-direction: column;
  min-height: 350px;
}
.home-program-card__type{
  font-size: var(--fs-medium);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: 10px;
}
.home-program-card__title{
  font-size: var(--fs-24);
  font-weight: var(--fw-bold);
  color: var(--color-primary);
  margin: 0 0 12px;
  line-height: 1.15;
}
.home-program-card__title a{ color: inherit; text-decoration: none; }
.home-program-card__title a:hover{ text-decoration: underline; }
.home-program-card__desc{
  font-size: var(--fs-default);
  font-weight: var(--fw-regular);
  color: var(--text);
  margin: 0 0 var(--space-18);
  flex: 1;
}
.home-program-card__more{
  font-size: var(--fs-medium);
  font-weight: var(--fw-bold);
  color: var(--color-gray);white-space: nowrap;
}
.home-program-card__more:hover{ text-decoration: underline; }

.home-corporate{ background: rgb(from var(--color-primary) r g b / 0.8); padding: 0; }

.home-corporate__panel{
  overflow: hidden;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 0;
}
.home-corporate__content{
  grid-column: 1 / span 6;
  padding: 55px 0;
}

.home-corporate__title{
  margin: 0 0 6px;
  font-size: 42px;
  font-weight: var(--fw-bold);
  color: var(--color-white);
}
.home-corporate__subtitle{
  font-size: var(--fs-medium);
  font-weight: var(--fw-bold);
  color: var(--color-white);
  margin-bottom: 70px;
}
.home-corporate__pills{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: var(--space-18);
}
.home-corporate__pill{
  border: 1px solid rgba(255, 255, 255, 0.65);
  border: 1px solid color-mix(in srgb, var(--color-white) 65%, transparent);
  border-radius: var(--radius-md);
  padding: 8px 16px;
  font-size: var(--fs-medium);
  font-weight: var(--fw-regular);
  color: var(--color-white);
}
.home-corporate__more{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: auto;
  padding: 15px 35px;
  border-radius: var(--radius-pill);
  background: var(--color-white);
  color: var(--color-primary);
  font-size: var(--fs-medium);
  font-weight: var(--fw-bold);
  text-decoration: none;
  margin-top: 60px;
}

.home-program-card__footer{
  margin-top: auto;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
}
.home-corporate__illu{
  grid-column: 7 / -1;
  width: 515px;
  height: auto;
  display: block;
  justify-self: center;
  margin-top: 55px;
  margin-left: 0;
}

.home-logos{
  --gap: var(--space-18);
  overflow-x: hidden;
  overflow-y: visible;
  position: relative;
  box-sizing: border-box;
  cursor: grab;
  touch-action: pan-y;
  padding-top: 34px;
  padding-bottom: 34px;
}
.home-logos.is-dragging{ cursor: grabbing; }

/* Soft fade edges (like reviews) */
.home-logos::after{
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: var(--z-2);
  background:
    linear-gradient(to right, var(--color-white) 0%, rgb(from var(--color-white) r g b / 0) 100%) left / clamp(24px, 5vw, 84px) 100% no-repeat,
    linear-gradient(to left, var(--color-white) 0%, rgb(from var(--color-white) r g b / 0) 100%) right / clamp(24px, 5vw, 84px) 100% no-repeat;
}

.home-logos .swiper-wrapper{
  display: flex;
  align-items: center;
  gap: var(--gap);
  will-change: transform;
}
.home-logos .swiper-slide{
  width: auto;
  flex: 0 0 auto;
}

.partners-logo-item{
  flex: 0 0 auto;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.partners-logo-item:hover,
.partners-logo-item:focus-within{
  z-index: var(--z-60);
}

.home-logos.is-dragging .partners-logo-item::after{
  opacity: 0;
  transform: translate(-50%, -100%);
}
.partners-logo-item::after{
  content: attr(data-name);
  position: absolute;
  left: 50%;
  top: 7px;
  transform: translate(-50%, -100%);
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--color-primary);
  color: var(--color-white);
  font-size: var(--fs-14-mob);
  line-height: 1;
  white-space: nowrap;
  opacity: 0;
  z-index: var(--z-5);
  pointer-events: none;
  transition: opacity var(--transition-duration) ease, transform var(--transition-duration) ease;
}
.partners-logo-item:hover::after{
  opacity: 1;
  transform: translate(-50%, -120%);
}

.home-partners .partners-logo{
  width: 275px;
  height: 155px;
  object-fit: contain;
  display: block;
}

.home-review__program-link{
  color: inherit;
  text-decoration: none;
}
.home-review__program-link:hover{
  text-decoration: underline;
}

.home-news-grid{
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: var(--space-18);
}
.home-news-card{
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-default);
  overflow: hidden;
  display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  min-height: 190px;

  border: 2px solid transparent;
  background-image: linear-gradient(var(--color-white), var(--color-white)), var(--brand-gradient);
  background-origin: border-box;
  background-clip: padding-box, border-box;
  position: relative;
}

.home-news-card--featured{
  grid-column: 1 / span 4;
  grid-row: 1 / 3;
  grid-template-columns: 1fr;
  background: rgb(from var(--color-primary) r g b / 0.8);
  min-height: 550px;

  border: none;
  background-image: none;
  background-origin: initial;
  background-clip: initial;
}

.home-news-card:not(.home-news-card--featured){
  grid-column: 5 / span 8;
}

.home-news-card__img{
  display: block;
  text-decoration: none;
  height: auto;
  align-self: start;
  min-width: 0;

  padding: var(--space-25);
  box-sizing: border-box;
}
.home-news-card__img img{
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border-radius: var(--radius-sm);
  display: block;
}
.home-news-card__img.is-right{
  order: 2;
}
.home-news-card__body{
  padding: 20px;
  display: flex;
  flex-direction: column;
}
.home-news-card__date{
  font-size: var(--fs-default);
  font-weight: var(--fw-regular);
  color: var(--color-black);
  order: 3;
  margin-top: auto;
  margin-bottom: 0;
}
.home-news-card__title{
  margin: 0 0 25px;
  font-size: var(--fs-medium);
  font-weight: var(--fw-bold);
  color: var(--color-primary);
  line-height: 1.15;
}

.home-news-card__title a{
  color: inherit;
  text-decoration: none;
}

.home-news .home-section__link{
  color: var(--color-gray);
  text-decoration: underline;
}

/* Search page sections */
.search-section__head{
  display: flex;
  align-items: baseline;
  gap: 16px;
}
.search-section__title{
  margin: 0;
}
.search-section__head > .home-section__link{
  margin-left: auto;
}
.search-section__head .home-section__link{
  color: var(--color-gray);
  text-decoration: underline;
}
.search-filters{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.search-filter-tab{
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.search-filter-tab__count{
  color: inherit;
}
.search-results-list{
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.search-result-card__type{
  margin: 0;
  font-size: var(--fs-default);
  font-weight: var(--fw-medium);
  color: var(--color-gray);
  line-height: 1.35;
}
.search-result-card__title{
  margin: 0;
  font-size: var(--fs-24);
  font-weight: var(--fw-bold);
  line-height: 1.15;
}
.search-result-card__title-link{
  color: var(--color-primary);
  text-decoration: none;
}
.search-result-card__title-link:hover{
  text-decoration: underline;
}
.search-result-card__text{
  margin: 0;
  font-size: var(--fs-default);
  font-weight: var(--fw-regular);
  color: var(--color-black);
  line-height: 1.45;
}
.search-result-card__meta{
  font-size: var(--fs-default);
  font-weight: var(--fw-regular);
  color: var(--color-gray);
  line-height: 1.35;
}
.home-news-card__text{
  margin: 0 0 12px;
  font-size: var(--fs-default);
  font-weight: var(--fw-regular);
  color: var(--color-black);
  line-height: 1.35;
}
.home-news-card--featured .home-news-card__body{
  padding: 0 20px 20px;
}
.home-news-card--featured .home-news-card__date,
.home-news-card--featured .home-news-card__title,
.home-news-card--featured .home-news-card__text{
  color: var(--color-white);
}

.home-reviews-row{
  width: 100%;
}

.home-reviews-row + .home-reviews-row{
  margin-top: var(--space-24);
}

.home-reviews-viewport{
  --gap: var(--space-24);
  --cardsPerRow: 3;
  position: relative;
  overflow-x: hidden;
  overflow-y: visible;
  padding: 16px var(--space-24);
  cursor: grab;
  touch-action: pan-y;
}

@media (max-width: 1023.98px){
  .home-reviews-viewport{ --cardsPerRow: 2; }
}

@media (max-width: 767.98px){
  .home-reviews-viewport{ --cardsPerRow: 1; }
}

.home-reviews-viewport.is-dragging{ cursor: grabbing; }

.home-reviews-viewport::before,
.home-reviews-viewport::after{
  content:"";
  position: absolute;
  top: 0;
  bottom: 0;
  width: clamp(24px, 5vw, 84px);
  pointer-events: none;
  z-index: 2;
}

.home-reviews-viewport::before{
  left: 0;
  background: linear-gradient(to right, var(--color-white) 0%, rgb(from var(--color-white) r g b / 0) 100%);
}

.home-reviews-viewport::after{
  right: 0;
  background: linear-gradient(to left, var(--color-white) 0%, rgb(from var(--color-white) r g b / 0) 100%);
}

.home-reviews-track{
  display: flex;
  gap: var(--gap);
  will-change: transform;
  transform: translate3d(0, 0, 0);
}

.home-reviews-track > .home-review{
  width: auto;
  flex: 0 0 calc((100% - (var(--gap) * (var(--cardsPerRow) - 1))) / var(--cardsPerRow));
}

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration: 0s !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0s !important;
    scroll-behavior: auto !important;
  }

  .home-reviews-track{ will-change: auto; }

  .home-reviews-viewport{ scroll-snap-type: none; }
}

.home-review{
  width: 100%;
  background: var(--color-white);
  border-radius: 70px 70px 70px 0;
  box-shadow: var(--shadow-default);
  
  scroll-snap-align: start;

  padding: 40px;
}
.home-review__name{
  font-size: var(--fs-medium);
  font-weight: var(--fw-bold);
  color: var(--color-primary);
  

  margin-bottom: 25px;
}
.home-review__text{
  font-size: var(--fs-default);
  font-weight: var(--fw-regular);
  color: var(--color-gray);
  

  margin: 0 0 45px;
}
.home-review__program{
  font-size: var(--fs-default);
  font-weight: var(--fw-medium);
  color: var(--color-gray);
}

@media (max-width: 991.98px){
  .home-hero__inner{ grid-template-columns: 1fr; }
  .home-hero__art{ min-height: 160px; }
  .home-program-card{ flex: 0 0 100%; }
  .home-corporate__panel{ grid-template-columns: 1fr; }
  .home-corporate__content{ grid-column: 1 / -1; }
  .home-corporate__illu{ grid-column: 1 / -1; width: min(100%, 515px); }

.home-news-grid{ grid-template-columns: 1fr; }
  .home-news-card,
  .home-news-card--featured,
  .home-news-card:not(.home-news-card--featured){
    grid-column: auto;
  }
  .home-news-card{ display: flex; flex-direction: column; }
  .home-news-card__img{ order: -1; }
  .home-news-card__img.is-right{ order: -1; }

  
}
/* Course page */
.course-page{ overflow-x: hidden; }

/* Course page teacher card overrides */
.course-page .teacher-name{
  font-size: var(--fs-32);
}

.course-page .teacher-role{
  font-size: var(--fs-medium);
}

.course-page .teacher-photo{
  width: 250px;
  height: 250px;
}

.course-page .teacher-photo-wrap{
  width: 250px;
  height: 250px;
}

@media (max-width: 991.98px){
  .course-page .teacher-photo-wrap,
  .course-page .teacher-photo{
    width: 160px;
    height: 160px;
  }
}

@media (max-width: 575.98px){
  .course-page .teacher-photo-wrap,
  .course-page .teacher-photo{
    width: 100%;
    height: auto;
  }
}

.course-hero{
  position: relative;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-default);
  overflow: hidden;
  color: var(--color-white);
  font-size: var(--fs-medium);
  margin-bottom: var(--space-24);
}

/* Inside hero everything is 20px, except title + price */
.course-hero .fs-default,
.course-hero .fs-medium,
.course-hero .fs-big{
  font-size: var(--fs-medium);
}

.course-hero::before{
  content:"";
  position:absolute;
  inset:0;
	  background: var(--course-hero-bg, url("../images/default-course-thumbnail.jpg")) center / cover no-repeat;
  }

.course-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.68) 100%);
}

.course-hero__inner{
  position: relative;
  z-index: var(--z-1);
  padding: 45px 60px;
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto 1fr auto;
  gap: var(--space-18) var(--space-24);

  min-height: 486px;
}

.course-hero__top{
  grid-column: 1 / span 2;
  display:flex;
  align-items:center;
  justify-content: space-between;

  padding-top: 5px;
}

.course-hero__type,
.course-hero__dir{
  font-weight: var(--fw-regular);
}

.course-hero__title{
  grid-column: 1 / span 2;
  
  font-size: var(--fs-large);
  line-height: 1.15;
  font-weight: var(--fw-bold);

  margin: 15px 0 20px;
}

.course-hero__meta{
  display: flex;
  gap: var(--space-18);
  align-items: flex-start;
  grid-column: 1 / span 2;
  grid-row: 3;
}

.course-hero__meta-item{
  min-width: 0;
  flex: 1 1 auto;
}

.course-hero__meta-item--document{
  flex-grow: 1.2;
}

.course-hero__meta-k{
  font-size: var(--fs-medium);
  font-weight: var(--fw-medium);

}

.course-hero__meta-v{
  font-size: var(--fs-medium);
  font-weight: var(--fw-regular);
  line-height: 1.25;
}

.course-doc__trigger{
  display: inline;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
text-align: left;
  cursor: zoom-in !important;
  text-decoration: none;
}

.course-doc-overlay{
  position: fixed;
  inset: 0;
  z-index: 1060;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-duration) ease;
}

.course-doc-overlay.is-open{
  opacity: 1;
  pointer-events: auto;
}

.course-doc-overlay__backdrop{
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(0, 0, 0, 0.6);
  cursor: pointer;
}

.course-doc-overlay__dialog{
  position: relative;
  width: min(80vw, 980px);
  max-height: 80vh;
  z-index: 1;
}

.course-doc-overlay__img{
  display: block;
  width: 100%;
  height: auto;
  max-height: 80vh;
  object-fit: contain;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-default);
  background: var(--color-white);
}

.course-doc-overlay__close{
  position: absolute;
  top: -12px;
  right: -12px;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 0;
  background: var(--color-white);
  box-shadow: var(--shadow-default);
  color: var(--color-gray);
  font-size: 26px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: color var(--transition-duration) ease;
}

.course-doc-overlay__close:hover{
  color: var(--color-secondary);
}

body.is-doc-overlay-open{ overflow: hidden; }

.course-hero__cta{
  display:flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-18);
  grid-column: 1 / span 2;
  grid-row: 4;
}

.course-hero__actions{
  display:flex;
  flex-wrap: wrap;
  align-items:center;
  gap: 12px;
  min-width: 0;
}

.course-hero__btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  
  
  background: var(--color-white);
  color: var(--color-primary);
  transition: color var(--transition-duration) ease;
  text-decoration: none;
  font-weight: var(--fw-bold);

  border-radius: var(--radius-pill);
  padding: 28px;
}

.course-hero__btn:hover{  
  text-decoration: none;
  color: var(--color-secondary);
}

.course-hero__price{
  font-size: var(--fs-large);
  font-weight: var(--fw-medium);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
  min-width: 0;
}

.course-tabs-row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  

  

  margin: 68px 0 68px;
}

.course-tabs{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}


.course-panels{ margin-bottom: 36px; }
.course-panel{ margin: 0; }
/* About tab */
#course-tabpanel-about{
  font-size: var(--fs-medium);
  font-weight: var(--fw-regular);
}

.course-about__text{ margin: 0 0 var(--space-25) 0; }
.course-about__text > :last-child{ margin-bottom: 0; }

.course-about__section{ margin: 0 0 var(--space-25) 0; }
.course-about__section:last-child{ margin-bottom: 0; }

.course-about__title{
  margin: 0 0 calc(var(--space-25) * 0.4) 0;
  font-size: var(--fs-medium);
  font-weight: var(--fw-medium);
  color: var(--color-secondary);
}

.course-about__p{ margin: 0; }

.course-about__list{
  margin: 0;
  padding-left: var(--space-25);
  list-style: disc;
}

.course-about__list li{ margin: 0 0 calc(var(--space-25) * 0.2) 0; }
.course-about__list li:last-child{ margin-bottom: 0; }

/* Plan accordion */
.course-plan{
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.course-plan-item{
  /* Визуально как два слоя: ответ «выезжает» из‑под вопроса */
  background: transparent;
  border-radius: var(--radius-lg);
  box-shadow: none;
  overflow: visible;
  position: relative;
}

.course-plan-heading{
  margin: 0;
  padding: 0;
  font: inherit;
}

.course-plan-toggle{
  width: 100%;
  border: 0;
  background: var(--color-primary);
  color: var(--color-white);
  padding: var(--space-24) 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  text-align: left;
  cursor: pointer;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-default);
  position: relative;
  z-index: var(--z-2);
}

/* Only expandable plan items are rendered as <button>. */
button.course-plan-toggle{ background: var(--color-secondary); }

.course-plan-title{ font-size: var(--fs-medium); }

.course-plan-action{ text-decoration: underline; }

.course-plan-body{
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--transition-duration) ease;
}

.course-plan-item.is-open .course-plan-body{
  grid-template-rows: 1fr;
}

.course-plan-body-inner{
  overflow: hidden;
  margin-top: calc(var(--radius-md) * -1);
  background: var(--color-white);
  color: var(--color-black);
  padding: 48px;
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  box-shadow: var(--shadow-default);
  opacity: 0;
  transform: translateY(calc(var(--radius-md) * -1));
  transition: opacity var(--transition-duration) ease, transform var(--transition-duration) ease;
}

.course-plan-item.is-open .course-plan-body-inner{
  opacity: 1;
  transform: translateY(0);
}

.course-plan-list{
  margin: 0;
  padding-left: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Teachers */
.course-teachers{
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.course-teacher-label{
  color: var(--color-black);
  
  font-size: var(--fs-medium);
}

/* Reviews */
.course-reviews-title{ margin-bottom: var(--space-24); }

.course-reviews{
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-left: 0;
  padding-right: 0;
  overflow-x: clip;
}

.course-reviews-layout .course-review-form.ff-form{
  max-width: none;
  margin: 0;
}

/* Review form: 2 columns (right column = textarea) */
.course-review-form__grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: start;
}
.course-review-form__col{
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* In this form we control spacing via grid, so remove extra margins */
.course-review-form .ff-field__input{ margin-bottom: 0; }

.course-review-form__col--comment textarea.ff-field__input{
  border-radius: 36px;
  height: 100%;
  min-height: 160px;
resize: vertical;
  padding: 14px 28px;

}

@media (max-width: 991.98px){
  .course-review-form__grid{ grid-template-columns: 1fr; }
}


.course-reviews-thread{
  display: grid;
  row-gap: 24px;
  margin-bottom: 40px;
}

.course-reviews-thread__item{
  width: 75%;
}

.course-reviews-thread__item + .course-reviews-thread__item{
  margin-top: 24px;
}

.course-reviews-thread__item .home-review{
  width: 100%;
  max-width: none;
}

.course-reviews-thread__item .home-review__text{
  margin: 0;
}

.course-reviews-thread__item:nth-child(even){
  margin-left: auto;
}

.course-reviews-thread__item:nth-child(even) .home-review{
  border-radius: 70px 70px 0 70px;
}

.course-reviews-thread__item:nth-child(odd){
  margin-right: auto;
}

.course-reviews-thread__item:nth-child(odd) .home-review{
  border-radius: 70px 70px 70px 0;
}

@media (max-width: 991.98px){
  .course-reviews-thread__item{
    width: 100%;
  }
}

/* Enroll */
.course-enroll{ padding: 32px 0 64px; }
.course-enroll__title{ color: var(--color-primary); margin: 0 0 60px; font-size: var(--fs-large); font-weight: var(--fw-bold); }

.ff-form{
  max-width: 878px;
  margin: 0 auto;
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-default);
  padding: 45px 85px;
}

.ff-form__caption{color: var(--color-gray); font-size: var(--fs-medium); }

.ff-form__name{  font-size: var(--fs-big); 
  margin: var(--space-24) 0 24px;
  font-weight: var(--fw-bold);
}

.ff-form__form{
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.ff-field{ display: flex; flex-direction: column; gap: 6px; }
.ff-field__label{ color: var(--color-black); font-size: var(--fs-medium); 
  padding-bottom: 10px;
}
.ff-form__form .ff-field:nth-of-type(3) .ff-field__input{
  margin-bottom: 0;
}
.ff-field__input{
  border: 0;
  border-radius: 105px;
  padding: 14px 28px;

  margin-bottom: 16px;
}

.ff-form__form input.invalid,
.ff-form__form textarea.invalid,
.ff-form__form select.invalid{
  outline: none;
  background-color: var(--color-white);
  box-shadow:
    var(--shadow-default),
    0 0 0 2px rgba(220, 38, 38, 0.45);
}

@supports (background: color-mix(in srgb, white 50%, black)) {
  .ff-form__form input.invalid,
  .ff-form__form textarea.invalid,
  .ff-form__form select.invalid{
    box-shadow:
      var(--shadow-default),
      0 0 0 2px color-mix(in srgb, #dc2626 45%, transparent);
  }
}

.ff-consent{
  display: flex;
  gap: 10px;
  align-items: flex-start;

  padding-block: var(--space-16);

}

.ff-consent__check{ margin-top: 4px; 
  width: 24px;
  height: 24px;
accent-color: var(--color-primary);
}
.ff-consent__text{ font-size: var(--fs-medium); }
.ff-consent__text a{ color: inherit; }
.ff-consent__text a:hover{ text-decoration: underline; }

.course-review-form .ff-consent,
.contacts-feedback__card .ff-consent{
  align-items: center;
}

.course-review-form .ff-consent__check,
.contacts-feedback__card .ff-consent__check{
  margin-top: 0;
  flex: 0 0 auto;
}

.ff-submit{
  border: 0;
  
  border-radius: var(--radius-pill);
  background: var(--color-primary);
  color: var(--color-white);
  font-size: 36px;
  font-weight: var(--fw-bold);

  height: 70px;

  text-decoration: none;
}

/* Contacts feedback: increase space between fields and submit */
.contacts-feedback__card .ff-submit{
  margin-top: 40px;
}

.ff-contacts{
  
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-size: var(--fs-big);

  margin-top: 35px;
}

.ff-contacts__row{
  display: flex;
  justify-content: space-between;
  gap: var(--space-18);
  flex-wrap: wrap;
}

.ff-contacts__row a{ color: inherit; text-decoration: none; }

@media (max-width: 991.98px){
  .course-hero__inner{ grid-template-columns: 1fr; }
  .course-hero__top,
  .course-hero__title{ grid-column: 1; }
  .course-hero__meta{ display: grid; grid-template-columns: 1fr 1fr; }
  .course-hero__meta-item,
  .course-hero__meta-item--document,
  .course-hero__meta-item:not(.course-hero__meta-item--document){ flex: initial; }
  .course-hero__cta{ align-items: flex-start; }
}

@media (max-width: 991.98px){
  .course-reviews > .container-xxl{
    padding-left: var(--space-24);
    padding-right: var(--space-24);
  }
}

@media (max-width: 575.98px){
  .course-hero__meta{ grid-template-columns: 1fr; }
  .course-hero__cta{ flex-wrap: wrap; }
  .course-hero__actions{ width: 100%; }
  .course-hero__btn,
  .course-hero__price{ width: 100%; }
  .course-hero__inner{ padding: var(--space-24) var(--space-18); min-height: 0; }
  .ff-form{ padding: var(--space-24) var(--space-18); }

  .contacts-feedback__card{ padding: var(--space-24) var(--space-18); }
  .contacts-feedback__card .ff-submit{
    width: 100%;
    height: auto;
    min-height: 70px;
    padding: 16px 24px;
    font-size: 24px;
    line-height: 1.15;
  }
}

/* Contacts page */
.contacts-page .page-title{ margin-bottom: var(--space-24); }

.contacts-hero{
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 32px;
  padding: 28px;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-default);
  background: var(--brand-gradient);
  margin-top: var(--space-24);
}

.contacts-hero__media{
  overflow: hidden;
  border-radius: var(--radius-lg);
  grid-column: span 5;
}

.contacts-hero__img{
  width: 100%;
  height: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  display: block;
}

.contacts-hero__body{ grid-column: span 7; }

.contacts-hero__title{ color: var(--color-white); margin-bottom: 38px; line-height: 1.15; }

.contacts-hero__list{
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
  color: var(--color-white);
  font-size: var(--fs-medium);
}

.contacts-hero__item{ display: flex; align-items: flex-start; gap: 12px; flex-wrap: wrap; }

.contacts-hero__item--address{ flex-wrap: nowrap; }
.contacts-hero__item--address .contacts-hero__text{ min-width: 0; }

.contacts-hero__icon{
  width: 24px;
  height: 24px;
  display: inline-flex;
  flex: 0 0 24px;
  color: var(--color-white);
  margin-top: 2px;
}

.contacts-hero__icon svg{ width: 24px; height: 24px; display:block; }
.contacts-hero__icon img{ width: 24px; height: 24px; display:block; }

.contacts-hero__link{
  color: var(--color-white);
  text-decoration: none;
}

.contacts-hero__link:hover{ text-decoration: underline; }

.contacts-people{ margin-top: 26px; }

.contact-person-card{
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-default);
  padding: 20px 22px;
  height: 100%;
}

.contact-person-card__img{
  overflow: hidden;
  border-radius: var(--radius-sm);
  margin-bottom: 14px;
}

.contact-person-card__img img{
  width: 100%;
  height: auto;
  display: block;
}

.contact-person-card__name{
  font-size: var(--fs-medium);
  font-weight: var(--fw-bold);
  color: var(--color-primary);
  line-height: 1.25;
margin: 0 0 6px;
  text-decoration: none;
}
.contact-person-card__name:hover,
.contact-person-card__name:focus{
  text-decoration: none;
}

.contact-person-card__role{
  font-size: var(--fs-default);
  font-weight: var(--fw-regular);
  color: var(--color-black);
  margin: 0 0 10px;
}

.contact-person-card__line{
  margin: 6px 0;
  font-size: var(--fs-medium);
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.contact-person-card__line a{ color: var(--color-black); text-decoration: none; }
/* hover underline handled by .link-underline */

.contact-person-card__icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  color: var(--color-primary);
}

.contacts-feedback{ margin-top: 48px; }
.contacts-feedback__title{ color: var(--color-primary); margin: 0 0 var(--space-18); }
.contacts-feedback__card{ max-width: 100%; padding: 36px 115px; }
.contacts-feedback__form{ gap: 0; }
.contacts-feedback__grid{
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 32px;
  align-items: start;
}
.contacts-feedback__col{
  display: flex;
  flex-direction: column;
}
.contacts-feedback__col--left{ gap: 16px; }
.contacts-feedback__col--left .ff-field{ flex: 1 1 auto; }
.contacts-feedback__col--left .ff-field .ff-field__input{ margin-bottom: 0; }
.contacts-feedback__field--message{ height: 100%; }
.contacts-feedback__field--message .contacts-textarea{
  height: 100%;
  min-height: 160px;
}

.contacts-textarea{
  border: 0;
  border-radius: var(--radius-lg);
  padding: 22px 28px;
  min-height: 210px;
  resize: vertical;
  background: var(--bg-gray);
}

.contacts-map{
  margin-top: 52px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-default);
}

.contacts-map iframe{ width: 100%; height: 420px; border: 0; display:block; }

@media (max-width: 991.98px){
  .contacts-hero{ grid-template-columns: 1fr; }
  .contacts-hero__media,
  .contacts-hero__body{ grid-column: auto; }
  .contacts-feedback__card{ padding: var(--space-24) var(--space-18); }
  .contacts-feedback__grid{ grid-template-columns: 1fr; gap: 16px; }
}

/* Courses catalog */
.courses-page .courses-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: var(--space-24);
  flex-wrap:wrap;
}
.courses-page .courses-head .page-title{
  flex: 1 1 auto;
  min-width: 0;
  margin-bottom: 0;
}
.courses-page .courses-search{
  display:flex;
  flex-direction:column;
  gap: 10px;
  flex: 0 0 auto;
  width: auto;
  max-width: 100%;
  min-width: 0;
}

.courses-search__form{
  width: 420px;
  max-width: 100%;
  min-width: 0;
}
.courses-search__form input{ width: 100%; max-width: 100%; box-sizing: border-box; min-width: 0; }

@media (max-width: 767.98px){
  .courses-page .courses-head{
    gap: 16px;
  }

  .courses-page .courses-head .page-title{
    flex: 0 0 100%;
    margin-bottom: 0;
  }

  .courses-page .courses-search,
  .courses-search__form,
  .courses-search__form.header-search{
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .courses-search__form input{
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }
}
.courses-filters{
  margin-top: var(--space-24);
  display:flex;
  flex-direction:column;
  gap: var(--space-24);
}
.courses-filter__tabs{
  display:flex;
  flex-wrap:wrap;
  gap: 12px;
  margin-top: 12px;
}
.courses-filter__title{
  font-size: var(--fs-big);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
}
.courses-grid{
  margin-top: 32px;
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-18);
}

/* Courses catalogue (archive + tax) + search results: 3 cards per row on desktop */
.courses-page .courses-grid,
body.search .courses-grid{
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.courses-grid__state{
  grid-column: 1 / -1;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap: 10px;
  padding: 32px;
  border-radius: var(--radius-lg);
  background: var(--color-white);
  box-shadow: var(--shadow-default);
}
.courses-grid__state-title{
  margin: 0;
  font-size: var(--fs-24);
  font-weight: var(--fw-bold);
  color: var(--color-primary);
}
.courses-grid__state-text{
  margin: 0;
  font-size: var(--fs-medium);
  color: var(--color-gray);
}
.courses-grid__state--error .courses-grid__state-title{
  color: var(--color-secondary);
}
.courses-card{
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-default);
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.courses-card__img{
  padding: var(--space-16) var(--space-16) 0;
}

.courses-card__img img{
  width:100%;
  aspect-ratio: 4 / 3;
  height:auto;
  object-fit:cover;
  display:block;
  border-radius: var(--radius-md);
}
.courses-card__body{
  padding: 40px;
  display:flex;
  flex-direction:column;
  flex: 1;
}
.courses-card__type{
  font-size: var(--fs-medium);
  font-weight: var(--fw-bold);
  color: var(--color-gray);
  margin-bottom: 10px;
}
.courses-card__title{
  font-size: var(--fs-24);
  font-weight: var(--fw-bold);
  color: var(--color-primary);
  line-height: 1.15;
  margin: 0 0 12px;
}
.courses-card__title a{
  color: inherit;
  text-decoration: none;
}
.courses-card__title a:hover,
.courses-card__title a:focus-visible{
  text-decoration: none;
}
.courses-card__desc{
  margin: 0 0 var(--space-18);
  font-size: var(--fs-default);
}
.courses-card__bottom{
  margin-top:auto;
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap: var(--space-18);
}
.courses-card__meta{
  display:flex;
  flex-direction:column;
  gap: 6px;
  font-size: var(--fs-24);
  font-weight: var(--fw-bold);
  color: var(--color-primary);
}
.courses-card__link{
  text-align:right;
  font-size: var(--fs-medium);
  font-weight: var(--fw-bold);
  color: var(--color-primary);
}


.courses-card__link:hover{ text-decoration: underline; }

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

  .courses-page .courses-grid,
  body.search .courses-grid{
    grid-template-columns: 1fr;
  }
  .courses-card__body{
    padding: var(--space-24);
  }
}

/* Mobile search modal (overlay input) */
.mobile-search-modal .modal-dialog{ max-width: 560px; }
.mobile-search-modal .modal-content{
  background: transparent;
  border: 0;
  box-shadow: none;
}
.mobile-search-modal .modal-body{ padding: 0 20px; }
.mobile-search-modal .mobile-search-bar{
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--color-white);
  border-radius: 999px;
  padding: 14px 16px;
  box-shadow: 0 10px 40px rgb(0 0 0 / 0.25);
}
.mobile-search-modal .mobile-search-bar .icon{
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
  color: var(--color-gray);
}
.mobile-search-modal .mobile-search-bar input{
  width: 100%;
  min-width: 0;
  border: 0;
  outline: 0;
  background: transparent;
  font-size: var(--fs-16-mob);
  color: var(--color-black);
  padding: 0;
}
.mobile-search-modal .mobile-search-bar input::placeholder{
  color: rgba(66, 66, 66, 0.7);
  color: color-mix(in srgb, var(--color-gray) 70%, transparent);
}
.mobile-search-modal .mobile-search-bar .btn-close{
  flex: 0 0 auto;
}

/* Cookie notice */
.cookie-banner{
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 16px 0;
  z-index: 1040; /* below Bootstrap modal backdrop (1050) */
  transform: translateY(120%);
  opacity: 0;
  transition: transform var(--transition-duration) ease, opacity var(--transition-duration) ease;
}

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

.cookie-banner__card{
  background: var(--color-primary);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-default);
  padding: 36px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 18px;
  color: var(--color-white);
}

.cookie-banner__content{
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.cookie-banner__title{
  font-size: var(--fs-big);
  font-weight: var(--fw-medium);
  line-height: 1.15;

}

.cookie-banner__text{
  font-size: var(--fs-medium);
  font-weight: var(--fw-regular);
  color: var(--color-white);
}

.cookie-banner__actions{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
}

.cookie-banner__btn{
  border: 1px solid var(--color-white);
  border-radius: var(--radius-pill);
  background: transparent;
  color: var(--color-white);
  font-weight: var(--fw-regular);
  font-size: var(--fs-default);
  padding: 0 22px;
  height: 44px;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: background-color var(--transition-duration) ease, color var(--transition-duration) ease, border-color var(--transition-duration) ease;
}

.cookie-banner__btn:hover{
  background: var(--color-white);
  color: var(--color-primary);
}

@media (max-width: 991.98px){
  .cookie-banner__card{
    flex-direction: column;
    align-items: stretch;
  }
  .cookie-banner__actions{
    flex-direction: column;
  }
  .cookie-banner__btn{ width: 100%; }
}

/* Overrides / hotfixes */
.comment-text-justify {
  text-align: justify;
}

.ff-form__message {
  font-size: 20px !important;
  line-height: 1.5;

}

.ff-form__message::before {
  content: "";
}

.ff-form__message.is-success {
  display: flex;
  align-items: center;
  gap: 8px;
}

.ff-form__message.is-success::before {
  content: "✔";
  color: var(--color-primary);
  flex: 0 0 auto;
}
