/* Переменные: часто повторяющиеся цвета, радиусы, брейкпоинты, анимации и типографика */
:root {
  --color-text: rgb(33, 50, 71);
  --color-text-inverse: rgb(255, 255, 255);
  --color-body-bg: rgb(250, 250, 250);
  --color-black: rgb(0, 0, 0);
  --color-gold: rgb(204, 168, 98);
  --color-gold-muted: rgb(203, 168, 98);
  --color-gold-active: rgb(204, 168, 98);
  --color-surface: rgb(255, 255, 255);
  --color-surface-muted: rgb(238, 240, 242);
  --color-card-glass: rgba(109, 126, 123, 0.55);
  --color-panel-tint: rgb(109, 126, 123, 0.5);
  --color-shadow-card: rgba(166, 171, 189, 0.1);
  --color-banner-cream: rgb(251, 235, 199);
  --color-caption-muted: rgb(160, 168, 182);
  --color-parallax-dark: rgb(31, 44, 60);

  --gradient-scroll-line: linear-gradient(to top, #bed5f7, #8cbdff, #4892f1, #3b7cd8, #bed5f7);
  --gradient-mobile-link: linear-gradient(
    90deg,
    #15a6e1 0%,
    #00caf4 15%,
    #00caf4 31%,
    #6789e0 50%,
    #ef786f 71%,
    #eb5c54 81%,
    #e8423b 100%
  );
  --gradient-guide-button: linear-gradient(135.37deg, #1b6cab 4.29%, #6cbaf7 95.6%);
  --color-accent-blue: rgb(99, 161, 246);
  --color-scroll-node: rgb(190, 213, 247);

  --radius-hero: 40px;
  --radius-lg: 24px;
  --radius-photo: 25px;
  --radius-tile: 15px;
  --radius-pill: 100px;
  --radius-guide-card: 35px;

  --layout-max: 1326px;
  --space-gutter: 16px;
  /* --bp-layout: 1326px; */
  /* --bp-sm: 666px; */
  /* --bp-md: 1000px; */

  --ease-default: 0.3s ease all;
  --ease-accordion: 0.3s;

  --z-header: 300;
  --z-scroll-dot: 100;

  --fw-family: 'DINPro', system-ui, sans-serif;
  --fw-regular: 400;
  --fw-medium: 600;
  --fw-bold: 700;
  --fsz-little: 16px;
  --fsz-little-plus: 18px;
  --fsz-medium: 32px;
  --bg-color-1: var(--color-surface-muted);
}

/* Стили */

* {
  box-sizing: border-box;
}
body {
  background: var(--color-body-bg);
  font-family: var(--fw-family);
  font-weight: var(--fw-medium);
  scroll-behavior: smooth;
  margin: 0px;
  color: var(--color-text);
}

p {
  margin: 0px;
  padding: 0px;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0px;
}

.box-center,
.box-center-banner {
  max-width: var(--layout-max);
  margin: 0px auto;
}
.section-map {
  padding: 20px 0px 0px 0px;
}

.section {
  padding: 80px 0px 0px 0px;
}

.map-container {
  width: 100%;
  aspect-ratio: 5 / 3;

  background: url('/Landings/VilaviGo2026/images/map.webp');
  background-size: cover;
  background-position: right center;
  background-repeat: no-repeat;
  border-radius: var(--radius-lg);
}

@media (max-width: 1326px) {
  .box-center {
    max-width: var(--layout-max);
    margin: 0px;
    padding: 0 var(--space-gutter);
  }
}

ul {
  margin: 0px;
  list-style-type: none;
}

a {
  text-decoration: none;
}

h1,
h3 {
  margin: 0px;
}

.text-nowrap {
  white-space: nowrap;
}

/*
  Шрифты DINPro (@font-face):
  - В src перечислены кандидаты; браузер берёт первый ресурс, который смог распарсить и загрузить.
  - format() — подсказка типа файла (аналог MIME). Для TTF в CSS Fonts Level 3/4 указано format('truetype'),
    не 'ttf'; без корректного значения движок может игнорировать слот или хуже упорядочивать fallback.
  - WOFF обычно легче TTF — разумно объявлять его первым, TTF оставить как запасной вариант.
*/
@font-face {
  font-family: 'DINPro';
  src:
    url('/fonts/DINPro/DINPro-Light.woff') format('woff'),
    url('/fonts/DINPro/DINPro-Light.ttf') format('truetype');
  font-weight: 200;
}

@font-face {
  font-family: 'DINPro';
  src:
    url('/fonts/DINPro/DINPro.woff') format('woff'),
    url('/fonts/DINPro/DINPro.ttf') format('truetype');
  font-weight: 400;
}

@font-face {
  font-family: 'DINPro';
  src:
    url('/fonts/DINPro/DINPro-Medium.woff') format('woff'),
    url('/fonts/DINPro/DINPro-Medium.ttf') format('truetype');
  font-weight: 600;
}

@font-face {
  font-family: 'DINPro';
  src:
    url('/fonts/DINPro/DINPro-Bold.woff') format('woff'),
    url('/fonts/DINPro/DINPro-Bold.ttf') format('truetype');
  font-weight: 700;
}

@font-face {
  font-family: 'DINPro';
  src:
    url('/fonts/DINPro/DINPro-Black.woff') format('woff'),
    url('/fonts/DINPro/DINPro-Black.ttf') format('truetype');
  font-weight: 800;
}

/* 01-header */
header {
    width: 100%;
    background: var(--color-text-inverse);
    position: fixed;
    overflow: hidden;
    top: 0px;
    z-index: var(--z-header);
}

.desktop-header__container {
    padding: 14px 0px;
}

.header-flex__container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.header-logo {
    display: block;
}

.header-menu-flex__container {
    display: flex;
    gap: 24px;
    width: max-content;
}

.list-item a {
    color: var(--color-black);
    font-weight: 600;
}

.mobile-disactive {
    transform: translateX(800px);
}

.mobile-active {
    transform: translateX(0px);
}

.mobile-menu {
    display: none;
}

.burger-menu {
    display: none;
}

.burger-close {
    display: none;
}

/* Шапка для мобильных */

@media (max-width: 666px) {
    .header-flex__container {
        padding: 16px;
    }

    .burger-close {
        display: block;
        cursor: pointer;
    }

    .burger-menu {
        display: block;
        cursor: pointer;
    }

    .desktop-header__container {
        padding: 0px 0px;
    }

    .header-mobile-menu__container {
        display: flex;
        flex-direction: column;
        gap: 15px;
    }

    .header-logo {
        display: block;
        width: 50px;
    }

    .header-menu-flex__container {
        display: none;
    }

    .mobile-menu {
        position: fixed;
        width: 100%;
        height: 95%;
        background: var(--color-text-inverse);
        padding: 0 var(--space-gutter);
        left: 0px;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        transition: var(--ease-default);
    }

    .mobile-gradient-link {
        width: max-content;
        font-weight: 700;
        display: block;
        background: var(--gradient-mobile-link);
        background-clip: text;
        color: transparent;
        margin: 0px 0px 30px 0px;
    }

    .mobile-icons__container {
        padding: 0px 0px 30px 0px;
    }

    .burger-close {
        cursor: pointer;
    }

    .disactive {
        display: none;
    }
}
/* 02-banner */
.banner-section__container {
    background: url('/Landings/VilaviGo2026/images/main-banner.webp');
    width: 100%;
    height: 667px;
    background-repeat: no-repeat;
    background-size: cover;
    margin: 100px 0px 0px 0px;
    border-radius: var(--radius-lg);
    display: flex;
    justify-content: center;
    align-items: flex-end;
}

.banner-info-container {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    color: var(--color-text-inverse);
    width: max-content;
}

.flex-info__container {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.banner-title {
    font-size: 63px;
    font-weight: 700;
    padding: 0px 0px 16px 0px;
}

.banner-text {
    font-size: 32px;
    text-align: center;
}

    .banner-text p:nth-child(1) {
        padding: 0px 0px 8px 0px;
    }

.banner-info-container p {
    padding: 0px 0px 57px 0px;
    font-size: 32px;
}

.arrows-down {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%) translateY(0);
    animation: arrows-down-bounce 2s ease-in-out infinite;
}

h1.banner-title {
    color: var(--color-banner-cream);
}

@keyframes arrows-down-bounce {
    0% {
        transform: translateX(-50%) translateY(0);
    }

    12.5% {
        transform: translateX(-50%) translateY(5px);
    }

    25% {
        transform: translateX(-50%) translateY(0);
    }

    37.5% {
        transform: translateX(-50%) translateY(5px);
    }

    50% {
        transform: translateX(-50%) translateY(0);
    }

    100% {
        transform: translateX(-50%) translateY(0);
    }
}

@media (max-width: 1326px) {
    .box-center-banner {
        max-width: var(--layout-max);
        margin: 0px;
        padding: 0 var(--space-gutter);
    }
}

@media (max-width: 1250px) {
    .banner-section__container {
        background-repeat: no-repeat;
        background-size: cover;
    }
}

@media (max-width: 800px) {
    .banner-section__container {
        margin: 0px;
        border-radius: var(--radius-lg);
    }
}

@media (max-width: 666px) {
    .section-banner {
        margin: 75px 0px 0px 0px;
    }

    .banner-info-container {
        height: 100%;
        justify-content: space-between;
    }

    .flex-info__container {
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    .banner-title {
        font-size: 40px;
        padding: 32px 0px 16px 0px;
    }

    .banner-text {
        font-size: 32px;
        text-align: center;
    }

    .banner-info-container p {
        max-width: 311px;
        text-align: center;
        padding: 0px 0px 53px 0px;
        font-size: 24px;
    }
}
/* 03-about-event */
.section-about-event {
    margin: 20px 0px 0px 0px;
}

.about-event-flexbox__container {
    width: 100%;
    display: flex;
    gap: 20px;
}

.about-event-box {
    width: 50%;
    display: flex;
    gap: 20px;
    flex-direction: column;
    justify-content: space-between;
}

.description__container {
    background: var(--color-text-inverse);
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 30px;
    border-radius: var(--radius-hero);
}

.about-event-img-box {
    width: 50%;
}

    .about-event-img-box img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        background-position: center;
        border-radius: var(--radius-lg);
    }

.mob-about-event-img-box {
    display: none;
}

    .mob-about-event-img-box img {
        display: none;
    }

.about-event-title {
    font-weight: 700;
    font-size: 50px;
    color: var(--color-text);
}

.about-event-text__container {
    max-width: 539px;
    display: flex;
    flex-direction: column;
    gap: 23px;
}

.about-event-text {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text);
}

    .about-event-text .name {
        font-size: 20px;
        font-weight: 700;
        color: var(--color-text-inverse);
    }

    .about-event-text .president {
        font-size: 16px;
        font-weight: 700;
        color: var(--color-text-inverse);
    }

    .about-event-text .name {
        font-weight: 700;
        font-size: 20px;
    }

    .about-event-text span {
        font-weight: 700;
        font-size: 16px;
    }

.about-color__container {
    display: flex;
    flex-direction: column;
    gap: 20px;
    background: var(--color-text);
    padding: 20px;
    border-radius: var(--radius-lg);
}

.about-color-text__container {
    color: var(--color-text-inverse);
    font-size: 16px;
}

@media (max-width: 1100px) {
    .about-event-title {
        font-size: 40px;
    }

    .about-event-text-gradient {
        font-size: 24px;
    }
}

@media (max-width: 1000px) {
    .about-event-flexbox__container {
        flex-direction: column;
    }

    .about-event-box {
        width: 100%;
    }

    .about-event-img-box {
        width: 100%;
    }
}

@media (max-width: 800px) {
    .about-event-img-box {
        height: 350px;
    }

    .icon-decor-container img {
        width: 42px;
        height: 42px;
    }

    .about-event-title,
    .about-event-text-gradient {
        font-size: 22px;
    }

    .description__container,
    .about-pink__container {
        padding: 15px;
    }

    .description__container {
        margin: 0px 0px 15px 0px;
        border-radius: var(--radius-tile);
    }

    .about-pink__container {
        border-radius: var(--radius-tile);
    }

    .about-event-img-box img {
        border-radius: var(--radius-tile);
    }
}

@media (max-width: 666px) {
    .about-event-img-box {
        display: none;
    }

        .about-event-img-box img {
            display: none;
        }

    .about-color__container {
        border-radius: var(--radius-tile);
    }

    .mob-about-event-img-box {
        width: 100%;
        height: 343px;
        display: block;
        border-radius: var(--radius-tile);
    }

        .mob-about-event-img-box img {
            width: 100%;
            height: 343px;
            object-fit: cover;
            display: block;
            border-radius: var(--radius-tile);
        }

    .about-event-flexbox__container {
        gap: 16px;
    }

    .description__container {
        margin: 0px 0px 0px 0px;
        gap: 16px;
        border-radius: var(--radius-tile);
    }

    .about-event-box {
        gap: 16px;
    }
}
/* 04-section-artists */
.section-artists {
    margin: 20px 0px 0px 0px;
}

.section-artists--mobile {
    display: none;
}

.artists__container {
    position: relative;
    background: url('/Landings/VilaviGo2026/images/artists.webp');
    width: 100%;
    height: 793px;
    background-size: cover;
    background-position-y: center;
    background-position-x: center;
    border-radius: var(--radius-lg);
}

.artists--mobile {
    display: none;
}

.line-scroll--mobile-artists,
.line-scroll--mobile {
    display: none;
}

.circle-scroll--mobile {
    display: none;
}

.title-container__title {
    font-size: 50px;
    color: var(--color-text-inverse);
    font-weight: 700;
    text-align: center;
    padding: 80px 0px 0px 0px;
}

.artists__description-flexbox {
    display: flex;
    container-type: inline-size;
    justify-content: flex-end;
    padding-top: 226px;
}

.artists__text {
    background: var(--color-panel-tint);
    backdrop-filter: blur(10px);
    width: 400px;
    height: max-content;
    padding: 20px;
    gap: 20px;
    font-size: var(--fsz-little-plus);
    display: flex;
    border-radius: var(--radius-lg);
    flex-direction: column;
    font-weight: var(--fw-medium);
    font-family: var(--fw-family);
    margin-right: 12%;
}

@media (max-width: 1200px) {
    .artists__text {
        margin-right: 6%;
    }
}

@media (max-width: 1050px) {
    .artists__text {
        margin-right: 20px;
    }
}

.artists__text p {
    color: var(--color-text-inverse);
}

.second-elem {
    height: max-content;
}

.line-scroll--artists {
    position: absolute;
    top: 223px;
    width: 5px;
    height: 388px;
    background: var(--gradient-scroll-line);
    left: calc(100% / 2);
}

/* Desktop: sticky-точка SVG и мини-круги на линии — общие для артистов, golden и vilavi-go */
.circle-scroll {
    width: 50px;
    height: 50px;
    position: sticky;
    top: calc(100% / 2);
    transform: translateX(-22px);
    z-index: var(--z-scroll-dot);
    fill: var(--color-accent-blue);
    transition: var(--ease-default);
}

.circle-mini {
    position: absolute;
    background: var(--color-scroll-node);
    width: 25px;
    height: 25px;
    border-radius: var(--radius-pill);
}

.--one,
.--two,
.--three {
    right: -10px;
}

.--one {
    top: 0px;
}

.--two {
    top: calc(680px / 2);
}

.--three {
    top: 97%;
}

@media (max-width: 1000px) {
    .artists__description-flexbox {
        display: flex;
        justify-content: space-between;
        flex-direction: column;
    }

    .line-scroll--artists {
        left: 50px;
        top: 201px;
    }

    .artists__description-flexbox {
        display: flex;
        flex-direction: column;
        align-items: center;
        margin: 20px 0px 0px 0px;
        gap: 50px;
    }

    .first-elem {
        height: 412px;
        margin: 0px;
    }

    .artists__text {
        width: 472px;
        margin-left: auto;
        margin-right: auto;
    }
}

@media (max-width: 666px) {
    .section-artists {
        display: none;
    }

    .section-artists--mobile {
        display: block;
    }

    .title-container__title {
        font-size: 22px;
        font-weight: 700;
        margin: 0px;
        text-align: center;
        color: var(--color-text);
    }

    .artists__img-container--mobile .center {
        padding: 0px 30px 0px 0px;
    }

    .artists__flex-container {
        display: flex;
        justify-content: space-between;
        margin: 0px 0px 0px 0px;
    }

    .flex-left {
        width: 70px;
        position: relative;
    }

    .flex-rigth {
        width: 86%;
        padding: 72px 0px 0px 0px;
    }

    .artists__section {
        display: none;
    }

    .line-scroll--artists {
        display: none;
    }

    .circle-scroll {
        display: none;
    }

    .artists__description-flexbox {
        padding-top: 0px;
        margin: 0px 0px 0px 0px;
        gap: 16px;
    }

    .artists__img-container--mobile {
        position: relative;
    }

    .artists--mobile {
        display: block;
    }

    .artists__text {
        background: var(--color-panel-tint);
        backdrop-filter: blur(10px);
        width: 100%;
        height: max-content;
        padding: 16px;
        gap: 16px;
        font-size: var(--fsz-little-plus);
        display: flex;
        border-radius: var(--radius-lg);
        flex-direction: column;
        font-weight: var(--fw-medium);
        font-family: var(--fw-family);
    }

        .artists__text p {
            color: black;
            font-size: var(--fsz-little-plus);
        }

    .artists__description-flexbox img {
        display: block;
        border-radius: var(--radius-photo);
        object-fit: cover;
        width: 100%;
        height: 323px;
    }

    .second-elem {
        height: auto;
    }

    .first-elem {
        height: auto;
    }

    .line-scroll--mobile-artists {
        display: block;
        position: relative;
        width: 2px;
        height: 100%;
        background: var(--gradient-scroll-line);
        left: 25px;
        top: 0px;
    }

    .--one,
    .--two {
        position: absolute;
        right: -6px;
    }

    .--one {
        top: 0px;
    }

    .--two {
        top: 38px;
    }
}
/* 05-format-event */
.format-event-title__container {
    padding: 80px 0px 24px 0px;
}

    .format-event-title__container h2 {
        text-align: center;
        font-size: 32px;
        font-weight: 700;
        color: var(--color-text);
    }

.format-event-flexbox__container {
    display: flex;
    align-items: center;
    flex-direction: column;
    gap: 32px;
}

.event-light-box {
    display: flex;
    justify-content: center;
    gap: 32px;
}

.description-light-box__element {
    display: flex;
    max-width: 345px;
    background: var(--color-text-inverse);
    padding: 35px 24px;
    border-radius: var(--radius-lg);
    font-size: 14px;
    color: var(--color-text);
    box-shadow: 5px 5px 10px 0px var(--color-shadow-card);
    text-align: center;
    align-items: center;
    justify-content: center;
}

.event-dark-box {
    display: flex;
    justify-content: center;
    gap: 32px;
}

.description-dark-box__element {
    max-width: 345px;
    background: var(--color-card-glass);
    padding: 20px;
    border-radius: var(--radius-lg);
    font-size: 18px;
    color: var(--color-text-inverse);
}

    .description-dark-box__element span {
        display: block;
        padding: 20px 0px 0px 0px;
    }

.format-event__second-container {
    gap: 16px;
}

.format-event-description {
    display: flex;
    flex-direction: column;
    gap: 16px;
    text-align: center;
    max-width: 533px;
}

    .format-event-description div {
        color: var(--color-text);
        font-size: 16px;
    }

    .format-event-description span {
        font-size: 16px;
        color: var(--color-caption-muted);
    }

    .format-event-description a {
        font-size: 16px;
        color: var(--color-gold-muted);
        text-decoration: underline;
    }

@media (max-width: 666px) {
    .format-event-title__container h2 {
        font-size: 22px;
    }

    .format-event-flexbox__container {
        gap: 16px;
    }

    .event-light-box {
        flex-direction: column;
        gap: 16px;
    }

    .description-light-box__element {
        max-width: 100%;
    }

    .event-dark-box {
        flex-direction: column;
        gap: 16px;
    }

    .description-dark-box__element {
        max-width: 100%;
        padding: 16px;
        font-size: 16px;
    }

        .description-dark-box__element span {
            padding: 16px 0px 0px 0px;
        }
}
/* 06-parallax */
.wrapper {
    position: relative;
    height: 1200px;
    padding: 90px 0px 90px 0px;
}

.section-parallax__parallax {
    width: 100%;
    position: absolute;
    top: 0px;
}

.section-parallax__img-1 {
    position: sticky;
    background-position: center;
    top: 90px;
    width: 100%;
    height: 605px;
    display: block;
    object-fit: cover;
    border-radius: var(--radius-lg);
    transform: scaleX(-1);
}

.section-parallax__description-container {
    display: flex;
    flex-direction: column;
    gap: 20px;
    width: 402px;
    border-radius: var(--radius-lg);
    background: var(--color-panel-tint);
    backdrop-filter: blur(10px);
    padding: 20px;
    position: absolute;
    top: 180px;
    left: 15%;
    z-index: 200;
    font-size: 18px;
    color: var(--color-text-inverse);
}

.section-parallax__img-2 {
    background: url('/Landings/VilaviGo2026/images/kaliningrad-banner-2.webp');
    background-position: center;
    position: sticky;
    top: 0;
    width: 100%;
    height: 605px;
    background-repeat: no-repeat;
    background-size: cover;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    z-index: var(--z-scroll-dot);
    gap: 25px;
    border-radius: var(--radius-lg);
}

.img-text {
    display: flex;
    flex-direction: column;
    gap: 20px;
    width: 402px;
    border-radius: var(--radius-lg);
    background: var(--color-panel-tint);
    backdrop-filter: blur(10px);
    padding: 20px;
    position: absolute;
    bottom: 78px;
    right: 168px;
    z-index: 200;
    font-size: 18px;
    color: var(--color-text-inverse);
}

.section-parallax__title {
    color: var(--color-text);
    font-size: 50px;
    font-weight: 700;
    text-align: center;
    padding: 80px 0px 20px 0px;
}

.section-parallax__container {
    align-items: flex-start !important;
    color: var(--color-text-inverse);
}

.section-parallax__text {
    text-align: left;
}

@media (max-width: 1200px) {
    .section-parallax__description-container {
        left: 10%;
    }

    .img-text {
        right: 10%;
    }
}

@media (max-width: 1050px) {
    .section-parallax__description-container {
        left: 5%;
    }

    .img-text {
        right: 5%;
    }
}

@media (max-width: 950px) {
    .section-parallax {
        height: 1373px;
    }

    .wrapper {
        height: auto;
        padding: 0px 0px 0px 0px;
    }

    .section-parallax__img-1 {
        position: relative;
        top: 0px;
        border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    }

    .section-parallax__img-2 {
        position: relative;
        border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    }

    .section-parallax__description-container {
        position: relative;
        top: 155px;
    }
}

@media (max-width: 767px) {
    .section-parallax {
        height: 1425px;
    }
}

@media (max-width: 666px) {
    .section-parallax__title {
        font-weight: 700;
        font-style: Bold;
        font-size: 22px;
        text-align: center;
    }

    .section-parallax__description-container {
        position: relative;
        top: 130px;
        width: 90%;
        font-size: 16px;
    }

    .section-parallax__img-2 {
        justify-content: flex-start;
    }

    .img-text {
        position: relative;
        top: 70px;
        width: 90%;
        right: 0%;
        font-size: 16px;
    }
}
/* 07-golden-section-data */
.section-golden-section-dates {
    padding: 30px 0px 0px 0px;
}

.golden-section-dates__container {
    position: relative;
    background: var(--color-parallax-dark);
    width: 100%;
    height: 1183px;
    isolation: isolate;
    border-radius: var(--radius-lg);
}

.golden-section-dates__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
    border-radius: inherit;
}

.golden-section-dates__bg-video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.golden-section-dates__container > .title-container,
.golden-section-dates__container > .box-center {
    position: relative;
    z-index: 1;
}

.golden-section-dates__container > .line-scroll {
    z-index: 2;
}

.golden-section-title {
    max-width: 959px;
    color: var(--color-text-inverse);
    line-height: 70px;
    margin: 0px auto;
}

.golden-section-dates--mobile {
    display: none;
}

.golden-section__description-flexbox {
    display: flex;
    justify-content: center;
    margin: 374px 0px 0px 0px;
    gap: 153px;
}

.golden-section__text {
    background: var(--color-panel-tint);
    backdrop-filter: blur(10px);
    width: 342px;
    max-height: 664px;
    padding: 20px;
    gap: 20px;
    font-size: 18px;
    display: flex;
    border-radius: var(--radius-lg);
    flex-direction: column;
    font-weight: var(--fw-medium);
    font-family: var(--fw-family);
}

    .golden-section__text p {
        color: var(--color-text-inverse);
    }

.first-elem {
    height: max-content;
    margin: 300px 0px 0px 0px;
}

.second-elem {
    height: max-content;
}

/* Вертикальная линия golden / vilavi: общая геометрия (точка sticky и мини-круги — см. блок артистов выше) */
.golden-section-dates__container > .line-scroll,
.vilavi-go-dates__container > .line-scroll {
    position: absolute;
    top: 286px;
    width: 5px;
    height: 690px;
    background: var(--gradient-scroll-line);
    left: calc(100% / 2);
}

.stars_rating {
    display: inline-block;
}

@media (max-width: 1000px) {
    .golden-section__description-flexbox {
        display: flex;
        justify-content: space-between;
        flex-direction: column;
    }

    .golden-section-dates__container > .line-scroll,
    .vilavi-go-dates__container > .line-scroll {
        left: 50px;
        top: 295px;
    }

    .golden-section__description-flexbox {
        display: flex;
        flex-direction: column;
        align-items: center;
        margin: 140px 0px 0px 0px;
        gap: 50px;
    }

    .first-elem {
        height: 412px;
        margin: 0px;
    }

    .golden-section__text {
        width: 472px;
        height: max-content;
    }
}

@media (max-width: 666px) {
    .turkey-title__container .title__container {
        margin: 60px 0px 60px 0px;
    }

    .golden-section-dates--mobile .title-container {
        padding: 0px 0px 0px 0px;
    }

    .golden-section-title {
        padding: 0px 0px 0px 0px;
        max-width: 200px;
        font-weight: 700;
        font-size: 22px;
        color: var(--color-text);
        line-height: 100%;
        text-align: center;
    }

    .golden-section__img-container--mobile .box-center {
        padding: 0px 30px 0px 0px;
    }

    .golden-section-dates__flex-container {
        display: flex;
        justify-content: space-between;
        margin: 0px 0px 0px 0px;
    }

    .flex-left {
        width: 70px;
        position: relative;
    }

    .flex-rigth {
        width: 86%;
    }

    .section-golden-section-dates {
        display: none;
    }

    .section-golden-section-dates .line-scroll,
    .section-vilavi-go-dates .line-scroll {
        display: none;
    }

    .golden-section__description-flexbox {
        margin: 0px 0px 0px 0px;
        gap: 32px;
    }

    .golden-section__img-container--mobile {
        position: relative;
    }

    .golden-section-dates--mobile {
        display: block;
    }

    .golden-section__text {
        max-height: none;
        background: rgba(255, 255, 255, 0.5);
        backdrop-filter: none;
        padding: 0px;
        gap: 16px;
        width: 100%;
    }

        .golden-section__text.second-elem p,
        .golden-section__text.first-elem {
            color: var(--color-text-inverse);
            font-size: 16px;
            background: var(--color-card-glass);
            padding: 16px;
            border-radius: var(--radius-lg);
        }

        .golden-section__text img,
        .golden-section__text video {
            display: block;
            border-radius: var(--radius-photo);
            object-fit: cover;
            height: 345px;
        }

    .second-elem {
        height: auto;
    }

    .first-elem {
        height: auto;
    }

    .line-scroll--mobile {
        display: block;
        position: relative;
        width: 2px;
        height: 100%;
        background: var(--gradient-scroll-line);
        left: 50px;
        top: 0px;
    }

    .--one,
    .--two,
    .--three {
        position: absolute;
        right: -6px;
    }

    .--one {
        top: 0px;
    }

    .--two {
        top: calc(1185px / 2);
    }
}

@media (max-width: 545px) {
    .line-scroll--mobile {
        left: 25px;
    }
}

@media (max-width: 500px) {
    .flex-left {
        width: 30px;
        position: relative;
    }

    .line-scroll--mobile {
        top: 15px;
    }

    .golden-section__text img,
    .golden-section__text video {
        display: block;
        border-radius: var(--radius-photo);
        object-fit: cover;
        height: 307px;
    }

    .golden-section__description-flexbox {
        margin: 0px 0px 0px 0px;
    }

    .--one {
        top: 0px;
    }

    .--two {
        top: calc(150px / 2);
    }

    .--three {
        top: calc(1200px / 2);
    }
}
/* 08-vilavi-go-dates */
.section-vilavi-go-dates {
    padding: 30px 0px 0px 0px;
}

.vilavi-go-dates__container {
    position: relative;
    background: url('/Landings/VilaviGo2026/images/vilavi-go.webp');
    width: 100%;
    height: 1271px;
    background-position-x: center;
    background-repeat: no-repeat;
    background-size: cover;
    border-radius: var(--radius-lg);
}

.vilavi-go-dates-title {
    max-width: 959px;
    font-weight: 700;
    font-style: Bold;
    font-size: 50px;
    line-height: 100%;
    letter-spacing: 0%;
    text-align: center;
    color: var(--color-text-inverse);
    margin: 0px auto;
}

.vilavi-go-dates--mobile {
    display: none;
}

.vilavi-go-dates__description-flexbox {
    display: flex;
    justify-content: center;
    margin: 374px 0px 0px 0px;
    gap: 153px;
}

.vilavi-go-dates__text {
    background: var(--color-panel-tint);
    backdrop-filter: blur(10px);
    max-width: 402px;
    max-height: 664px;
    padding: 20px;
    gap: 20px;
    font-size: 18px;
    display: flex;
    border-radius: var(--radius-lg);
    flex-direction: column;
    font-weight: var(--fw-medium);
    font-family: var(--fw-family);
}

    .vilavi-go-dates__text p {
        color: var(--color-text-inverse);
    }

    .vilavi-go-dates__text.first-elem {
        height: max-content;
        margin: 280px 0px 0px 0px;
    }

.second-elem {
    height: max-content;
}

@media (max-width: 1000px) {
    .vilavi-go-dates__description-flexbox {
        display: flex;
        justify-content: space-between;
        flex-direction: column;
    }

    .vilavi-go-dates__description-flexbox {
        display: flex;
        flex-direction: column;
        align-items: center;
        margin: 140px 0px 0px 0px;
        gap: 50px;
    }

    .vilavi-go-dates__text.first-elem {
        height: max-content;
        margin: 0px;
    }

    .vilavi-go-dates__text {
        width: 472px;
        height: max-content;
    }
}

@media (max-width: 666px) {
    .turkey-title__container .title__container {
        margin: 60px 0px 60px 0px;
    }

    .vilavi-go-dates--mobile .title-container {
        padding: 80px 0px 0px 0px;
    }

    .vilavi-go-dates-title {
        padding: 0px 0px 0px 0px;
        max-width: 200px;
        font-weight: 700;
        font-size: 22px;
        color: var(--color-text);
        line-height: 100%;
        text-align: center;
    }

    .vilavi-go-dates__img-container--mobile .box-center {
        padding: 0px 30px 0px 0px;
    }

    .vilavi-go-dates__flex-container {
        display: flex;
        justify-content: space-between;
        margin: 0px 0px 0px 0px;
    }

    .flex-left {
        width: 70px;
        position: relative;
    }

    .flex-rigth {
        width: 86%;
    }

    .section-vilavi-go-dates {
        display: none;
    }

    .vilavi-go-dates__description-flexbox {
        margin: 0px 0px 0px 0px;
        gap: 32px;
    }

    .vilavi-go-dates__img-container--mobile {
        position: relative;
    }

    .vilavi-go-dates--mobile {
        display: block;
    }

    .vilavi-go-dates__text {
        max-height: none;
        background: rgba(255, 255, 255, 0.5);
        backdrop-filter: none;
        padding: 0px;
        gap: 16px;
        width: 100%;
    }

        .vilavi-go-dates__text.second-elem p,
        .vilavi-go-dates__text.first-elem {
            color: var(--color-text-inverse);
            font-size: 16px;
            background: var(--color-card-glass);
            padding: 16px;
            border-radius: var(--radius-lg);
        }

        .vilavi-go-dates__text img {
            display: block;
            border-radius: var(--radius-photo);
            object-fit: cover;
            height: 345px;
        }

    .second-elem {
        height: auto;
    }

    .first-elem {
        height: auto;
    }

    .line-scroll--mobile {
        display: block;
        position: relative;
        width: 2px;
        height: 100%;
        background: var(--gradient-scroll-line);
        left: 50px;
        top: 0px;
    }

    .--one,
    .--two,
    .--three {
        position: absolute;
        right: -6px;
    }

    .--one {
        top: 0px;
    }

    .--two {
        top: calc(1185px / 2);
    }
}

@media (max-width: 545px) {
    .line-scroll--mobile {
        left: 25px;
    }
}

@media (max-width: 500px) {
    .flex-left {
        width: 30px;
        position: relative;
    }

    .line-scroll--mobile {
        top: 15px;
    }

    .vilavi-go-dates__text img {
        display: block;
        border-radius: var(--radius-photo);
        object-fit: cover;
        height: 307px;
    }

    .vilavi-go-dates__description-flexbox {
        margin: 0px 0px 0px 0px;
    }

    .--one {
        top: 0px;
    }

    .--two {
        top: calc(150px / 2);
    }

    .--three {
        top: calc(1200px / 2);
    }
}

/* Мобильная sticky-точка и мини-круги на линии — одинаковые в секциях артистов / golden / vilavi-go */
@media (max-width: 666px) {
    .circle-scroll--mobile {
        display: block;
        width: 25px;
        height: 25px;
        position: sticky;
        z-index: var(--z-scroll-dot);
        top: calc(100% / 2);
        transform: translateX(-11px);
        fill: var(--color-accent-blue);
        transition: var(--ease-default);
    }

    .circle-mini-mobile {
        width: 14px;
        height: 14px;
        background: var(--color-scroll-node);
        border-radius: var(--radius-pill);
    }
}

/* 09-guide */
.guide-info__flexbox {
    display: flex;
    align-items: flex-start;
    gap: 30px;
    margin: 80px 0px 0px 0px;
}

.guide-title {
    color: var(--color-text);
    font-weight: 700;
    font-size: 50px;
    line-height: 100%;
    text-align: center;
}

.guide-title-text {
    font-size: 18px;
    line-height: 100%;
    text-align: center;
    padding: 16px 0px 0px;
}

.event-text-container {
    margin-top: 32px;
}

.speaker-container{
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 16px;
}
.speaker-text{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    flex-direction: column;
    max-width: 317px;
}

.speaker-title{
font-weight: 700;
leading-trim: NONE;
    font-style: Bold;
    font-size: 24px;
    line-height: 100%;
    letter-spacing: 0%;
    text-align: center;
    vertical-align: middle;
}

.speaker-description {
    font-style: Bold;
    font-size: 18px;
    line-height: 100%;
    letter-spacing: 0%;
    text-align: center;
    vertical-align: middle;
}

.speaker-description-min {
    font-style: Bold;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0%;
    text-align: center;
    color: rgba(160, 168, 182, 1);
}

.title-container-speak {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.max-width-784 {
    max-width: 784px;
    padding: 0 56px;
    text-align: center;
}

.event-title-text {
    max-width: 593px;
    font-size: 16px;
    line-height: 100%;
    text-align: center;
    padding: 16px 0px 0px;
}

.event-text-container{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  column-gap: 76px;
  row-gap: 40px;
}

.guide-important-info-container {
    padding: 20px 0px 0px 0px;
    display: flex;
    justify-content: center;
    align-items: stretch;
    gap: 32px;
}

.guide-important-info-item {
    width: 343px;
    padding: 24px 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
    box-shadow: 5px 5px 10px 0px var(--color-shadow-card);
    background: var(--color-text-inverse);
    border-radius: var(--radius-lg);
}

.guide-important-info-item-title {
    font-size: 24px;
    line-height: 100%;
    text-align: center;
}

.guide-important-info-item-batton {
    width: 100%;
    background: var(--gradient-guide-button);
    padding: 8px 0px 12px 0px;
    color: var(--color-text-inverse);
    font-size: 16px;
    display: flex;
    justify-content: center;
    border-radius: var(--radius-pill);
}

.guide-important-info-item-text {
    font-weight: 500;
    font-size: 18px;
    line-height: 100%;
    text-align: center;
}

.accordion {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 0px 70px 0px 70px;
}

    .accordion ul {
        list-style-type: disc;
    }

.accordion-item {
    position: relative;
    padding: 30px 74px 30px 30px;
    background: var(--color-surface-muted);
    border-radius: var(--radius-lg);
}

.accordion-header {
    cursor: pointer;
    position: relative;
    padding: 0px 0px 0px 0px;
    font-weight: 600;
    font-size: 22px;
    line-height: 100%;
}

.accordion-collapse {
    overflow: hidden;
    max-height: 0;
    /* Скрываем контент */
    transition: var(--ease-accordion);
}

.accordion-body {
    padding: 20px 0px 0px 0px;
    font-size: 16px;
    line-height: 100%;
}

    .accordion-body.accordion-body-title {
        font-weight: 700;
        font-size: 16px;
        line-height: 100%;
    }

    .accordion-body a {
        padding: 20px 0px 0px 0px;
        font-size: 16px;
        line-height: 100%;
        color: var(--color-gold);
        text-decoration: underline;
    }

    .accordion-body p {
        margin: 0px 0px 10px 0px;
    }

.accordion-header::after {
    position: absolute;
    content: '';
    top: 0;
    right: -20px;
    width: 20px;
    height: 20px;
    background-color: var(--color-text); /* тёмный цвет по умолчанию */
    mask: url('/Landings/VilaviGo2026/images/arr-accordeon-mask.svg') no-repeat center;
    mask-size: contain;
    transition: var(--ease-default);
    transform-origin: center center;
}

.accordion-header.active::after {
    background-color: var(--color-gold-active); /* золотой цвет при активации */
    transform: rotate(180deg);
}


.guide-contacts__section {
    width: 402px;
    padding: 50px;
    background: var(--bg-color-1);
    border-radius: var(--radius-guide-card);
}

.guide-contacts__title {
    font-family: var(--fw-family);
    font-size: var(--fsz-medium);
    font-weight: var(--fw-medium);
    margin: 0px 0px 50px 0px;
}

.guide-contacts__text {
    font-family: var(--fw-family);
    font-size: var(--fsz-little);
    font-weight: var(--fw-regular);
    margin: 0px 0px 25px 0px;
}

    .guide-contacts__text .guide-phone {
        text-decoration: none;
    }

    .guide-contacts__text a,
    .guide-contacts__text p {
        color: black;
        font-family: var(--fw-family);
        font-size: var(--fsz-little);
        font-weight: var(--fw-bold);
    }

    .guide-contacts__text a {
        text-decoration: underline;
    }

    .guide-contacts__text:last-child {
        margin: 0px;
    }

@media (max-width: 1300px) {
    .guide-info__flexbox {
        display: flex;
        align-items: flex-start;
        gap: 30px;
        flex-direction: column;
    }

    .accordion {
        width: auto;
    }

    .guide-contacts__section {
        width: 689px;
    }
}

@media (max-width: 1000px) {
    .guide-important-info-container {
        flex-wrap: wrap;
    }
}

@media (max-width: 745px) {
    .guide-contacts__section {
        width: 100%;
    }
}

@media (max-width: 690px) {
    .guide__section .title-text__container {
        margin: 0px 0px 45px 0px;
    }

    .accordion {
        padding: 30px;
    }

    .guide__section .box-center {
        margin: 0px;
        padding: 0px;
    }

    .accordion-header {
        font-size: 20px;
    }

        .accordion-header::after {
            content: url('/Landings/VilaviGo2026/images/arr-mini-accordeon.svg');
            top: -4px;
            right: -20px;
        }

    .accordion-body {
        font-size: var(--fsz-little-plus);
    }

    .guide-contacts__text a,
    .guide-contacts__text {
        font-size: var(--fsz-little-plus);
    }
}

@media (max-width: 666px) {
    .guide-title {
        font-size: 22px;
    }
}

@media (max-width: 550px) {
    .guide-info__flexbox {
        margin: 35px 0px 0px 0px;
    }
}
/* 10-footer */
footer {
    padding: 80px 0px 0px 0px;
}

.footer-container {
    width: 100%;
    background: var(--color-text);
    padding: 32px 0px 24px 0px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 32px;
    border-radius: var(--radius-lg);
}

.footer-logo {
    display: block;
    object-fit: cover;
    width: 132px;
    height: auto;
}

.footer-text {
    font-size: 18px;
    line-height: 100%;
    color: var(--color-text-inverse);
}

@media (max-width: 666px) {
    .footer-container {
        gap: 80px;
    }
}

.title-text {
    margin: 0 1rem;
}