@font-face {
    font-family: 'Brutal Type';
    src: url('./fonts/BrutalType-Black.woff2') format('woff2'),
        url('./fonts/BrutalType-Black.woff') format('woff');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Brutal Type';
    src: url('./fonts/BrutalType-ExtraBold.woff2') format('woff2'),
        url('./fonts/BrutalType-ExtraBold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Brutal Type';
    src: url('./fonts/BrutalType-Bold.woff2') format('woff2'),
        url('./fonts/BrutalType-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Brutal Type';
    src: url('./fonts/BrutalType-Medium.woff2') format('woff2'),
        url('./fonts/BrutalType-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}


:root {
    --slide-count: 6;
    --gray:    	#D3D3D3;
    --surface:     #041e3a;
    --border:      rgba(255, 255, 255, 0.08);
    --accent-dim:  rgba(245, 200, 0, 0.12);
    --text:        #ffffff;
    --navy:     #1A1854;
    --surface1: #1C1A5A;
    --surface2: #2D308F;

}

html{ scroll-behavior: smooth; }

body {
  font-optical-sizing: auto;
  font-style: normal;
  background-color: var(--bg);
  color: var(--text);
  /* background-color: #1a1a1a; */
}

/* .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
} */

body.menu-open {
    overflow: hidden;
}

.logo-ukrnafta{
    width: 230px;
}

.logo-ukrnafta img {
   width: 100%;
}

.nav-desktop {
    display: flex;
    gap: 30px;
    list-style: none;
}

.nav-desktop a {
    text-decoration: none;
    color: #ffffff;
    transition: 0.3s;
}

.nav-desktop a:hover {
    opacity: 0.7;
}

.burger {
    display: none;
    flex-direction: column;
    gap: 6px;
    background: none;
    border: none;
    cursor: pointer;
}

.burger span {
    width: 28px;
    height: 2px;
    background: #fff;
    transition: 0.4s;
}

.burger.active span:nth-child(1) {
    transform: rotate(45deg) translateY(5px);
}
.burger.active span:nth-child(2) {
    transform: rotate(-45deg) translateY(-5px);
}

.mobile-menu {
  display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.95);
    
    justify-content: center;
    align-items: center;
    opacity: 0;
    visibility: hidden;
    transition: 0.4s ease;
    z-index: 999;
}

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

.mobile-menu ul {
    list-style: none;
    text-align: center;
}

.mobile-menu li {
    margin: 25px 0;
    transform: translateY(30px);
    opacity: 0;
    transition: 0.4s ease;
}

.mobile-menu.active li {
    transform: translateY(0);
    opacity: 1;
}

.mobile-menu a {
    text-decoration: none;
    font-size: 28px;
    color: #ffffff;
    font-weight: bold;
    transition: 0.3s;
}

.mobile-menu a:hover {
    color: #f9de31;
}

.close-menu {
    position: absolute;
    top: 30px;
    right: 30px;
    font-size: 28px;
    background: none;
    border: none;
    color: #ffffff;
    cursor: pointer;
}

.mobile-menu .social-links{
  position: absolute;
  bottom: 50px;
}

@media (max-width: 992px) {

    .nav-desktop {
        display: none;
    }

    .burger {
        display: flex;
    }
}


.main-section {
    position: relative;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    overflow: hidden;
    background-color: var(--bg);

}

/* .main .container {
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    padding-top: clamp(1.5rem, 3vh, 3rem);
    padding-bottom: clamp(1rem, 2vh, 2rem);
} */

.hero-logos {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-shrink: 0;
}

.hero-logo-ukrnafta{
    padding: 0 20px;
}

.hero-logo-ukrnafta img {
    display: block;
    width: 100%;
    /*height: clamp(28px, 4vw, 56px);*/
    /*width: auto;*/
    /*object-fit: contain;*/
}

.hero-stage {
    /*align-content: center;*/
    min-height: 600px;
    width: 100%;
    background-image: url(../img/hero-banner.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}

.hero-chef {
    position: relative;
    z-index: 2;

    display: flex;
    flex-direction: column;

}

/*.hero-chef img {*/
/*    display: block;*/
/*}*/

/*.hero-chef .name {*/

/*    font-size: clamp(9px, 1.1vw, 16px);*/
/*    font-weight: bold;*/
/*    letter-spacing: 0.12em;*/
/*    text-transform: uppercase;*/
/*    color: var(--white);*/
/*    background: var(--bg);*/
/*    border-radius: 8px;*/
/*    padding: 6px 10px;*/
/*    white-space: nowrap;*/
/*    position: absolute;*/
/*    bottom: 150px;*/
/*    z-index: 3;*/
/*}*/
/*.hero-chef .name sup {*/
/*    font-size: 0.55em;*/
/*    vertical-align: super;*/
/*    letter-spacing: 0;*/
/*}*/

.hero-dish {
    align-self: center;
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 400px;
}
.hero-dish img {
    display: block;
}

.hero-badge {
    align-self: center;
    display: flex;
    align-items: center;
    justify-content: flex-start;
}
.hero-badge img {
    display: block;
    /*width: 100%;*/
}

.dishes-section {
    position: relative;
    padding: 80px 0;
    scroll-margin-top: calc(var(--header-h) + 20px);
}

.dishes-section .container{
  position: relative;
  background-color: #1a1854d2;
  z-index: 11;
}

.dishes-section .dishes-title {
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: bold;
  text-transform: uppercase;
  margin-bottom: 60px;
  text-align: center;
  letter-spacing: -1px;
}

.dishes-section .highlight {
  color: #ffdd00;
  display: block;
}

.dishes-section .content-grid {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.dishes-section .info-block {
  border-left: 4px solid #ffdd00;
  padding-left: 30px;
  max-width: 800px;
}

.dishes-section .description {
  font-size: 1.4rem;
  line-height: 1.3;
  opacity: 0.9;

}

.dishes-section .brand-tag {
  color: #ffdd00;
  font-weight: bold;
}

.dishes-section .mission-block {
  background: rgba(255, 255, 255, 0.05);
  padding: 40px 40px 40px 120px;
  border-radius: 24px;
  position: relative;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.dishes-section .mission-icon{
  position: absolute;
  top: 40px;
  left: 40px;
}

.dishes-section .mission-text {
  font-size: 1.4rem;
  margin: 0;
  color: #f0f0f0;
  margin-bottom: 30px;
}
.dishes-section .mission-text-second{
  display: block;
}


@media (max-width: 768px) {
  .dishes-section .mission-block {
    flex-direction: column;
  }
   .dishes-section .mission-text {
    font-size: 1.1rem;
  }
}


.slider-section {
    position: relative;
    scroll-margin-top: calc(var(--header-h) + 40px);
}

.slider-sticky {
    display: flex;
    flex-direction: column;
}

.slides-viewport {
    position: relative;
    overflow: hidden;
}

.slides-wrapper {
    display: flex;
    width: calc(var(--slide-count) * 100%);
    will-change: transform;
    transition: transform 0.72s cubic-bezier(0.77, 0, 0.18, 1);
}

.slide {
    width: calc(100% / var(--slide-count));
    display: flex;
    flex-direction: row;
    opacity: 0;
    transform: translateX(30px);
    transition: opacity 0.55s ease, transform 0.55s ease;
}
.slide.active {
    opacity: 1;
    transform: translateX(0);
}
.slide.prev {
    opacity: 0.3;
    transform: translateX(-30px);
}

.slide-img {
    width: 50%;
    overflow: hidden;
    position: relative;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 320px;
}

.slide-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transform: scale(1.05);
    transition: transform 0.72s cubic-bezier(0.77, 0, 0.18, 1);
}
.slide.active .slide-img img { transform: scale(0.95); }

.slide-text {
    width: 50%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(2rem, 5vw, 5rem) clamp(1.5rem, 4vw, 4rem);
    position: relative;
    overflow: hidden;
}

.slide-tag {
    font-size: .7rem;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 1rem;
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 0.4s .15s ease, transform 0.4s .15s ease;
}
.slide.active .slide-tag { opacity: 1; transform: none; }

.slide-text h3,
.slide-text h4 {
    font-size: clamp(1.4rem, 2.8vw, 2.8rem);
    font-weight: bold;
    line-height: 1.15;
    margin-bottom: 1rem;
    color: var(--text);
    opacity: 0;
    transform: translateY(16px);
    transition: opacity 0.45s .22s ease, transform 0.45s .22s ease;
}
.slide.active .slide-text h3,
.slide.active .slide-text h4 { opacity: 1; transform: none; }

.slide-text p {
    font-size: clamp(.85rem, 1.2vw, 1rem);
    line-height: 1.75;
    color: var(--muted);
    max-width: 38ch;
    margin-bottom: 2rem;
    opacity: 0;
    transform: translateY(14px);
    transition: opacity 0.45s .30s ease, transform 0.45s .30s ease;
}
.slide.active .slide-text p { opacity: 1; transform: none; }

.slide-btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .7rem 1.6rem;
    border: 1px solid var(--accent);
    background: transparent;
    color: var(--accent);
    font-size: .8rem;
    letter-spacing: .1em;
    text-transform: uppercase;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    align-self: flex-start;
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 0.4s .38s ease, transform 0.4s .38s ease, color .3s;
}
.slide.active .slide-btn { opacity: 1; transform: none; }
.slide-btn::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--accent);
    transform: translateX(-101%);
    transition: transform .35s cubic-bezier(0.77, 0, 0.18, 1);
}
.slide-btn:hover { color: var(--bg); }
.slide-btn:hover::before { transform: translateX(0); }
.slide-btn span { position: relative; z-index: 1; }

.slider-ui {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem 0;
    background: transparent;
    border-top: none;
    gap: 0;
    height: auto;
}

.slider-ui .slider-arrows {
    display: none;
}

.slide-counter {
    display: none;
}

.slider-bullets {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .6rem;
    flex: none;
}

.bullet {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255,255,255,.25);
    cursor: pointer;
    flex: none;
    transition: background .3s, transform .3s;
}
.bullet.active {
    background: var(--accent);
    transform: scale(1.4);
}
.bullet:hover {
    background: rgba(245,200,0,.5);
}
.bullet-fill { display: none; }

.slides-viewport {
    position: relative;
}

.slider-arrow-left,
.slider-arrow-right {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 56px;
    height: 56px;
    border: 2px solid rgba(255,255,255,.25);
    background: rgba(0,0,0,.45);
    backdrop-filter: blur(6px);
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: border-color .25s, background .25s, transform .25s;
}
.slider-arrow-left  { left: 1rem; }
.slider-arrow-right { right: 1rem; }

.slider-arrow-left:hover,
.slider-arrow-right:hover {
    border-color: var(--accent);
    background: rgba(0,0,0,.7);
    transform: translateY(-50%) scale(1.1);
}
.slider-arrow-left:disabled,
.slider-arrow-right:disabled {
    opacity: .25;
    cursor: default;
    transform: translateY(-50%) scale(1);
}
.slider-arrow-left svg,
.slider-arrow-right svg {
    width: 22px; height: 22px;
    fill: none; stroke: currentColor;
    stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round;
}

@media (max-width: 767px) {
    .slider-arrow-left  { left: .5rem; width: 44px; height: 44px; top: 41%;}
    .slider-arrow-right { right: .5rem; width: 44px; height: 44px; top: 41%;}
}

.touch-hint {
    display: none;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    align-items: center;
    gap: .5rem;
    font-size: .7rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--muted);
    white-space: nowrap;
    pointer-events: none;
    animation: fadeHint 3s ease 1s forwards;
}
@keyframes fadeHint { 0%,60%{opacity:1} 100%{opacity:0} }

@media (max-width: 767px) {
    .slide {
        flex-direction: column;
    }
    .slide-img,
    .slide-text {
        width: 100%;
    }
    .slide-img {
        min-height: 220px;
    }
    .touch-hint { display: flex; }
}


.popup-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.75);
    backdrop-filter: blur(8px);
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s;
}
.popup-overlay.open {
    opacity: 1;
    pointer-events: all;
}

.popup {
    background: var(--surface);
    border: 1px solid var(--border);
    max-width: 540px;
    width: 100%;
    max-height: 88vh;
    overflow-y: auto;
    position: relative;
    transform: translateY(24px) scale(0.97);
    transition: transform .35s cubic-bezier(0.77,0,.18,1);
}
.popup-overlay.open .popup { transform: none; }

.popup-img {
    width: 100%;
    object-fit: cover;
    display: block;
    padding: 20px;
}

.popup-body { padding: 1.8rem; }

/* .popup-body .divider-line{
    display: block;
    width: 100%;
    margin: 15px 0;
    height: 1px;
} */

.popup-body ul{
  padding-left: 35px;
}

.popup-tag {
    font-size: .65rem;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: .7rem;
}

.popup h3 {
    font-size: clamp(1.3rem, 2.5vw, 2rem);
    font-weight: bold;
    line-height: 1.2;
    margin-bottom: .9rem;
    color: var(--text);
}
.popup p {
    font-size: .9rem;
    line-height: 1.8;
    color: var(--muted);
    white-space: pre-line;
    padding: 0 15px;
}

.popup-close {
    position: absolute;
    top: .9rem; right: .9rem;
    width: 34px; height: 34px;
    border: 1px solid var(--border);
    background: var(--bg);
    color: var(--text);
    cursor: pointer;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    transition: border-color .25s, transform .25s;
    z-index: 2;
}
.popup-close:hover { border-color: var(--accent); transform: rotate(90deg); }
.popup-close svg { width: 13px; height: 13px; stroke: currentColor; stroke-width: 2; fill: none; }



.video-section{
    position:relative;
    height:calc(100% - 81px);
    z-index: 2;
}
@media (max-width: 768px) {
    .video-section {
        width: 100vw;
        height: 35vh; 
        min-height: 250px;
        margin-left: 50%;
        transform: translateX(-50%);
    }
}
.video-wrapper{
    @media (min-width: 767px) {
        position: relative;
        height: calc(100vh - 81px);
    }
    @media (max-width: 768px) {
        width: 100vw;
        height: 35vh;
        min-height: 250px;
        margin-left: 50%;
        transform: translateX(-50%);
    }
}

.video-wrapper video {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    object-fit: contain;
}
.video-wrapper iframe {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.sound-btn{
    position:absolute;
    bottom:30px;
    right:10%;
    z-index:10;
    height: 65px;
    width: 65px;
    border-color: #fff;
    backdrop-filter: blur(12px);
    background-color: transparent;
    border-radius: 20px;
    cursor:pointer;

    @media (max-width: 768px) {
        bottom:20%;
        right:5%;
    }
}

@media (min-width: 1024px) {

    .hero-logo-chef {
        animation: fadeDown .5s .1s both;
    }

    .hero-logo-ukrnafta {
        animation: fadeDown .5s .2s both;
    }

    .hero-chef {
        animation: fadeUp .6s .35s both;
    }

    .hero-dish {
        animation: scaleIn .6s .5s both;
    }

    .hero-badge {
        animation: slideIn .55s .6s both;
    }

    .hero-chef .name {
        animation: fadeUp .5s .75s both;
    }

    @keyframes fadeDown {
        from {
            opacity: 0;
            transform: translateY(-12px)
        }
        to {
            opacity: 1;
            transform: none
        }
    }
    @keyframes fadeUp {
        from {
            opacity: 0;
            transform: translateY(14px)
        }
        to {
            opacity: 1;
            transform: none
        }
    }
    @keyframes scaleIn {
        from {
            opacity: 0;
            transform: scale(.9)
        }
        to {
            opacity: 1;
            transform: none
        }
    }
    @keyframes slideIn {
        from {
            opacity: 0;
            transform: translateX(20px)
        }
        to {
            opacity: 1;
            transform: none
        }
    }
}


@media (max-width: 1024px) {
    .slide-text h4 { font-size: clamp(1.3rem, 3vw, 2rem); }
    .slide-text p  { max-width: none; }
}


@media (max-width: 768px) {
  
    .main-section {
        background-size: 100% auto;
        background-position: center bottom;
        min-height: auto;
    }

    .main-section .container{
      width: 100%;
      margin-left: 0;
      margin-right: 0;
    }

    .hero-logos{
      justify-content: space-around;
    }

    .hero-stage {
      min-height: 200px;
      background-size: contain;
      background-repeat: no-repeat;
      background-position: center;

      background-image: -webkit-image-set(
        /*url("../img/hero-banner-mobile.webp") type("image/webp"),*/
        url("../img/hero-banner-mobile.png") type("image/png")
      );
      background-image: image-set(
        /*url("../img/hero-banner-mobile.webp") type("image/webp"),*/
        url("../img/hero-banner-mobile.png") type("image/png")
      );
    }

    .hero-stage .hero-chef,
    .hero-stage .hero-dish,
    .hero-stage .hero-badge{
      display: none;
    }

    /* .hero-stage {
        grid-template-columns: 45% 55%;
        grid-template-rows: 1fr auto;
    }
    .hero-chef  { grid-column: 1; grid-row: 1; }
    .hero-dish  { grid-column: 2; grid-row: 1; padding: 0 1%; }
    .hero-badge {
        grid-column: 1 / -1;
        grid-row: 2;
        justify-content: center;
        padding: 0.5rem 0 0;
    }
    .hero-badge img { max-width: clamp(120px, 40vw, 220px); }

    .hero-chef img { max-height: clamp(200px, 38vh, 380px); }
    .hero-dish img { max-height: clamp(180px, 34vh, 340px); }

    .hero-chef .name { font-size: clamp(8px, 2vw, 13px); } */

    .slide { flex-direction: column; }
    .slide-img { width: 100%; height: 60%; }
    .slide-img img{width: 100%;}
    .slide-text {
        width: 100%;
        height: 40%;
        padding: 1.2rem 1.5rem;
        justify-content: flex-start;
        padding-top: 1.5rem;
    }
    .slide-number { font-size: 3.5rem; }
    .slide-text h4 { font-size: clamp(1.1rem, 4vw, 1.6rem); margin-bottom: .6rem; }
    .slide-text p  { font-size: .82rem; margin-bottom: 1rem; }
    .slider-bullets .bullet { max-width: none; }
    .bullet.active { max-width: none; }
}


@media (max-width: 480px) {

    .main-section {
        background-size: 100% auto;
        background-position: center bottom;
    }

    .main-section .container {
        padding-top: 1rem;
        padding-bottom: 1rem;
  
    }

    /* .hero-logo-chef img,
    .hero-logo-ukrnafta img { height: clamp(18px, 5.5vw, 28px); } */

    /* .hero-stage {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 0;
        flex: 1;
    }

    .hero-dish  { order: 2; width: 100%; padding: 0; }
    .hero-chef  { order: 1; width: 100%; }
    .hero-badge { order: 3; width: 100%; justify-content: center; padding: 0.5rem 0 0; }

    .hero-chef img  { max-height: clamp(160px, 30vh, 260px); }
    .hero-dish img  { max-height: clamp(140px, 26vh, 230px); }
    .hero-badge img { max-width: clamp(130px, 55vw, 200px); }

    .hero-chef .name { font-size: clamp(8px, 3vw, 12px); } */

    /* .slide-img { height: 65%; }
    .slide-text { height: 40%; } */
    .slide-counter { display: none; }
    .slide-text p { font-size: .8rem; }
}

@media (pointer: coarse) {
    .slider-section {
        height: auto;
    }
    .slider-sticky {
        position: relative;
        top: 0;
        height: calc(100svh - var(--header-h));
    }
}

  .tastes-section {
    position: relative;
    padding: 100px 60px;
    max-width: 1300px;
    margin: 0 auto;
    width: 100%;
    scroll-margin-top: calc(var(--header-h) + 10px);
  }

  .reveal {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity 0.7s cubic-bezier(.22,1,.36,1),
                transform 0.7s cubic-bezier(.22,1,.36,1);
  }
  .reveal.visible { opacity: 1; transform: translateY(0); }
  .d1 { transition-delay: 0.08s; }
  .d2 { transition-delay: 0.16s; }
  .d3 { transition-delay: 0.24s; }
  .d4 { transition-delay: 0.32s; }
  .d5 { transition-delay: 0.40s; }

  .tastes-inner {
    position: relative; z-index: 1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 96px;
    align-items: center;
  }

  .tastes-label {
    font-size: 12px;
    letter-spacing: 5px;
    color: var(--yellow);
    text-transform: uppercase;
    margin-bottom: 22px;
    display: flex; align-items: center; gap: 12px;
  }
  .tastes-label::before {
    content: '';
    display: block;
    width: 28px; height: 2px;
    background: var(--yellow);
  }

  .tastes-title {
    font-size: clamp(2.25rem, 5vw, 46px);
    font-weight: bold;
    line-height: 1.2;
    text-transform: uppercase;
    margin-bottom: 48px;
    
  }
  .tastes-title .accent { color: var(--yellow); }

  .tastes-stat {
    display: flex;
    align-items: flex-end;
    gap: 12px;
  }
  .stat-num {
    font-size: 110px;
    line-height: 1;
    color: var(--yellow);
    animation: pulseStat 3s 2s ease-in-out infinite;
  }
  @keyframes pulseStat {
    0%,100% { text-shadow: 0 0 0px rgba(249,237,47,0); }
    50%     { text-shadow: 0 0 40px rgba(249,237,47,0.3); }
  }
  .stat-meta {
    display: flex; flex-direction: column;
    padding-bottom: 14px; gap: 4px;
  }
  .stat-plus {
    font-size: 36px; color: var(--yellow); line-height: 1;
  }
  .stat-label {
    font-size: 11px; font-weight: bold;
    letter-spacing: 2px; text-transform: uppercase;
    color: #c5c4c4; line-height: 1.4;
  }

  .map-dots {
    margin-top: 40px;
    display: flex; gap: 6px; flex-wrap: wrap;
    max-width: 260px;
  }
  .map-dot {
    width: 7px; height: 7px;
    border-radius: 50%;
    background: var(--yellow);
    opacity: 0.15;
    animation: dotAppear 0.05s ease both;
  }
  .map-dot.lit { opacity: 0.9; }
  .map-dot.mid { opacity: 0.4; }

  .tastes-list {
    display: flex; flex-direction: column;
  }

  .taste-item {
    display: grid;
    grid-template-columns: 32px 1fr;
    gap: 18px;
    align-items: start;
    padding: 28px 0;
    border-bottom: 1px solid rgba(255,255,255,0.07);
    position: relative;
    transition: padding-left 0.35s cubic-bezier(.22,1,.36,1);
    cursor: default;
  }
  .taste-item:first-child { border-top: 1px solid rgba(255,255,255,0.07); }

  .taste-item:hover { padding-left: 12px; }

  .taste-item::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 2px;
    background: var(--yellow);
    transform: scaleY(0);
    transform-origin: top;
    transition: transform 0.35s cubic-bezier(.22,1,.36,1);
  }
  .taste-item:hover::before { transform: scaleY(1); }

  .taste-index {
    font-size: 13px; letter-spacing: 1px;
    color: var(--yellow); opacity: 0.4;
    padding-top: 2px;
    transition: opacity 0.3s;
  }
  .taste-item:hover .taste-index { opacity: 1; }

  .taste-text {
    font-size: 15px; font-weight: bold;
    line-height: 1.55; color: var(--white);
    transition: color 0.3s;
  }
  .taste-item:hover .taste-text { color: var(--yellow); }

  .taste-chip {
    display: inline-block;
    margin-top: 8px;
    background: rgba(249,237,47,0.1);
    border: 1px solid rgba(249,237,47,0.22);
    color: var(--yellow);
    font-size: 10px; font-weight: bold;
    letter-spacing: 2px; text-transform: uppercase;
    padding: 3px 10px; border-radius: 100px;
  }

  @media (max-width: 900px) {
    .tastes-section { padding: 70px 28px; }
    .tastes-inner { grid-template-columns: 1fr; gap: 52px; }
    .stat-num { font-size: 80px; }
    .map-dots { display: none; }
  }
  @media (max-width: 540px) {
    .taste-text { font-size: 14px; }
  }

  .promo-section {
    position: relative;
    padding: 90px 60px 100px;
    max-width: 1300px;
    margin: 0 auto;
    scroll-margin-top: var(--header-h)
  }

  .orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(90px);
    pointer-events: none;
    animation: drift 12s ease-in-out infinite alternate;
  }
  .orb-1 {
    width: 500px; height: 500px;
    background: var(--surface2);
    opacity: 0.5;
    top: -120px; left: -160px;
  }
  .orb-2 {
    width: 360px; height: 360px;
    background: var(--yellow);
    opacity: 0.12;
    top: 20px; right: -80px;
    animation-delay: -4s;
  }
  .orb-3 {
    width: 280px; height: 280px;
    background: var(--surface2);
    opacity: 0.45;
    bottom: 80px; right: 180px;
    animation-delay: -8s;
  }
  @keyframes drift {
    from { transform: translate(0,0) scale(1); }
    to   { transform: translate(28px, 18px) scale(1.07); }
  }

  .reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.7s cubic-bezier(.22,1,.36,1),
                transform 0.7s cubic-bezier(.22,1,.36,1);
  }
  .reveal.visible { opacity: 1; transform: translateY(0); }
  .d1 { transition-delay: 0.08s; }
  .d2 { transition-delay: 0.18s; }
  .d3 { transition-delay: 0.28s; }
  .d4 { transition-delay: 0.38s; }
  .d5 { transition-delay: 0.48s; }

  .promo-header {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 48px;
    align-items: end;
    margin-bottom: 64px;
    position: relative; z-index: 1;
  }

  .promo-label {
    font-size: 13px;
    letter-spacing: 5px;
    color: var(--yellow);
    text-transform: uppercase;
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    gap: 10px;
  }
  .promo-label::after {
    content: '';
    display: block;
    width: 28px; height: 2px;
    background: var(--yellow);
    animation: growLine 0.9s 0.5s ease both;
  }
  @keyframes growLine {
    from { width: 0; opacity: 0; }
    to   { width: 28px; opacity: 1; }
  }

  .promo-title {
    font-size: clamp(60px, 7.5vw, 104px);
    line-height: 0.9;
    text-transform: uppercase;
  }
  .promo-title .accent { color: var(--yellow); }

  .promo-subtitle {
    font-size: 15px;
    color: var(--muted);
    line-height: 1.65;
    max-width: 400px;
    align-self: end;
    padding-bottom: 4px;
  }

  .highlight-card {
    background: var(--yellow);
    color: var(--navy);
    border-radius: 8px;
    padding: 52px 60px;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 40px;
    align-items: center;
    margin-bottom: 20px;
    position: relative;
    overflow: hidden;
    z-index: 1;
  }

  .highlight-card::before {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(120deg,
      transparent 30%,
      rgba(255,255,255,0.38) 50%,
      transparent 70%);
    transform: translateX(-100%);
    animation: shimmer 3.8s 1.4s ease-in-out infinite;
  }
  @keyframes shimmer {
    0%  { transform: translateX(-100%); }
    55% { transform: translateX(210%); }
    100%{ transform: translateX(210%); }
  }

  .highlight-card .deco-a {
    position: absolute;
    right: -50px; bottom: -50px;
    width: 200px; height: 200px;
    border-radius: 50%;
    background: rgba(26,24,84,0.09);
    pointer-events: none;
  }
  .highlight-card .deco-b {
    position: absolute;
    right: 110px; top: -65px;
    width: 140px; height: 140px;
    border-radius: 50%;
    background: rgba(26,24,84,0.06);
    pointer-events: none;
  }

  .highlight-text { position: relative; z-index: 1; }
  .highlight-eyebrow {
    font-size: 24px; font-weight: bold;
    text-transform: uppercase;
     margin-bottom: 12px;
  }
  .highlight-body {
    font-size: 18px; font-weight: bold; line-height: 1.55;
    max-width: 560px;
  }

  .highlight-body .text-body{
  
    opacity: 0.9;
  }

 .highlight-body p{
  margin-bottom: 30px;
 }

  .highlight-body h4{
    font-size: 21px;
  }
  .highlight-body ul{
    padding-left: 30px;
    margin-bottom: 30px;
  }
    .highlight-body ul li{
      font-size: 18px;
      opacity: .8;
    }

  .highlight-link{
    font-size: 12px;
    color: #767676;
  }
  .highlight-link a{
        color: #767676;
      }

  .highlight-body strong { font-weight: 900; }

  .discount-badge {
    position: relative; z-index: 1;
    display: flex; 
    flex-direction: row;
    align-items: center; 
    justify-content: center;
    background: var(--navy);
    color: var(--yellow);
    border-radius: 8px;
    width: 200px; height: 150px;
    flex-shrink: 0;
    animation: pulseBadge 2.8s 1.6s ease-in-out infinite;
  }
  @keyframes pulseBadge {
    0%,100% { box-shadow: 0 0 0 0 rgba(249,237,47,0); }
    50%     { box-shadow: 0 0 0 16px rgba(249,237,47,0.15); }
  }

  
  .discount-num {
    background-image: url(../img/discount.jpg);
    height: 160px;
    width: 240px;
    margin: 0 auto;
  }

  .discount-unit {
    margin-top:10px; 
    border-top:2px solid #F9ED2F; 
    padding-top:10px;
  }
    .discount-unit p{
      margin:0; 
      font-size:11px; 
      font-weight:700; 
      color:#F9ED2F; 
      letter-spacing:0.5px; 
      text-transform:uppercase; 
      line-height:1.4;
    }

  .challenge-card {
    background: var(--surface1);
    border-radius: 8px;
    padding: 40px 56px;
    margin-bottom: 44px;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 32px;
    align-items: center;
    border-left: 5px solid var(--yellow);
    position: relative; z-index: 1;
    transition: border-color 0.35s, background 0.35s;
  }
  .challenge-card:hover {
    background: var(--surface2);
    border-color: var(--white);
  }

  .challenge-text {
    font-size: 24px; font-weight: bold; line-height: 1.6;
  }
  .challenge-text strong { color: var(--yellow); }

  .challenge-second-text { font-size: 16px; font-weight: bold; line-height: 1.6;margin-top: 30px;}

  .steps-row {
    display: flex; align-items: center; gap: 8px;
    margin-top: 20px;
  }
  .step-dot {
    width: 9px; height: 9px; border-radius: 50%;
    background: var(--yellow); opacity: 0.25;
    animation: dotPulse 1.6s ease-in-out infinite;
  }
  .step-dot.on { opacity: 1; animation: none; }
  .step-dot:nth-child(2){ animation-delay:.18s }
  .step-dot:nth-child(3){ animation-delay:.36s }
  .step-dot:nth-child(4){ animation-delay:.54s }
  .step-dot:nth-child(5){ animation-delay:.72s }
  @keyframes dotPulse {
    0%,100%{ opacity:.25; transform:scale(1); }
    50%    { opacity:1;   transform:scale(1.4); }
  }
  .step-label {
    font-size: 11px; font-weight: bold;
    letter-spacing: 2px; text-transform: uppercase;
    color: var(--muted); margin-left: 6px;
  }

  .challenge-icon {
    font-size: 60px; opacity: 0.1; flex-shrink: 0;
    animation: floatIcon 4s ease-in-out infinite alternate;
  }
  @keyframes floatIcon {
    from { transform: translateY(0); }
    to   { transform: translateY(-12px); }
  }

  .prizes-header-row {
    display: flex; align-items: center; gap: 18px;
    margin-bottom: 22px;
    position: relative; z-index: 1;
  }
  .divider-line {
    height: 3px; width: 44px;
    background: var(--yellow); border-radius: 2px;
  }
  .prizes-title {
    font-size: 34px; letter-spacing: 3px; text-transform: uppercase;
  }

  .prizes-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    position: relative; z-index: 1;
  }

  .prize-card {
    background: var(--surface1);
    border-radius: 8px;
    padding: 36px 28px;
    position: relative; overflow: hidden;
    transition: transform 0.35s cubic-bezier(.22,1,.36,1),
                box-shadow 0.35s ease,
                background 0.35s ease;
  }
  .prize-card:hover {
    transform: translateY(-7px) scale(1.025);
    box-shadow: 0 28px 52px rgba(0,0,0,0.4);
    background: var(--surface2);
  }

  .prize-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; height: 4px;
    background: var(--yellow);
    transform: scaleX(0); transform-origin: left;
    transition: transform 0.4s cubic-bezier(.22,1,.36,1);
  }
  .prize-card:hover::before { transform: scaleX(1); }

  .prize-card::after {
    content: '';
    position: absolute; inset: 0;
    border-radius: 8px;
    box-shadow: inset 0 0 0 1px rgba(249,237,47,0);
    transition: box-shadow 0.35s ease;
  }
  .prize-card:hover::after {
    box-shadow: inset 0 0 0 1px rgba(249,237,47,0.3);
  }

  .prize-qty {
    font-size: 64px; line-height: 1;
    color: var(--yellow); margin-bottom: 2px;
    transition: transform 0.3s ease;
    display: inline-block;
  }
  .prize-card:hover .prize-qty { transform: scale(1.1); transform-origin: left; }

  .prize-unit {
    font-size: 11px; font-weight: bold;
    letter-spacing: 2.5px; text-transform: uppercase;
    color: var(--muted); margin-bottom: 14px;
  }
  .prize-desc { font-size: 13px; font-weight: bold; line-height: 1.5; }
  .prize-sub  { font-size: 11px; color: var(--muted); margin-top: 6px; line-height: 1.45; }

  .prize-bg-icon {
    position: absolute;
    bottom: 14px; right: 16px;
    font-size: 40px; opacity: 0.07;
    transition: opacity 0.3s;
  }
  .prize-card:hover .prize-bg-icon { opacity: 0.18; }

  .winners-text{
    color: var(--gray);
    font-size: 12px;
    margin-top: 30px;
  }

  @media (max-width: 960px) {
    .promo-section { padding: 60px 0 80px; }
    .promo-header { grid-template-columns: 1fr; gap: 20px; }
    .highlight-card { grid-template-columns: 1fr; padding: 40px 36px; }
    .challenge-card { grid-template-columns: 1fr; padding: 36px; }
    .challenge-icon { display: none; }
    .prizes-title {font-size: 24px;}
    .prizes-grid { grid-template-columns: repeat(2,1fr); }
    .tastes-section { padding: 60px 28px 80px; }
    .tastes-inner { grid-template-columns: 1fr; gap: 48px; }
  }
  @media (max-width: 560px) {
    .prizes-grid { grid-template-columns: 1fr; }
    .discount-badge { display: none; }
    .highlight-card { padding: 32px 28px; }
    .stat-num { font-size: 72px; }
  }

   .app-section {
      width: 100%;
      padding: 100px 0 80px;
      /* background: var(--navy); */
      position: relative;
      overflow: hidden;
      background-color: var(--bg);
       background-position: bottom right;
       background-repeat: no-repeat;
       background-size: contain;
      background-image: -webkit-image-set(
        /*url("../img/bg-pattern-navy.webp") type("image/webp"),*/
        url("../img/bg-pattern-navy.png") type("image/png")
      );
      background-image: image-set(
        /*url("../img/bg-pattern-navy.webp") type("image/webp"),*/
        url("../img/bg-pattern-navy.png") type("image/png")
      );
    }

    /* .app-section::before {
      content: '';
      position: absolute;
      inset: 0;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='104'%3E%3Cpolygon points='60,4 116,100 4,100' fill='none' stroke='rgba(255,255,255,0.04)' stroke-width='1'/%3E%3C/svg%3E");
      background-size: 160px 140px;
      pointer-events: none;
    } */


    .section-eyebrow {
      font-size: 11px;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: var(--yellow);
      margin-bottom: 14px;
    }

    .section-title {
      font-size: clamp(36px, 5vw, 64px);
      font-weight: 900;
      line-height: 0.95;
      text-transform: uppercase;
      margin-bottom: 56px;
    }

    .desktop-layout {
      display: grid;
      grid-template-columns: 1fr 1fr 200px;
      gap: 28px;
      align-items: end;
    }

    .phone-block {
      display: flex;
      flex-direction: column;
      gap: 18px;
    }

    .phone-img-wrap {
      width: 100%;
      aspect-ratio: 9 / 16;
      max-height: 500px;
      overflow: hidden;
      background: var(--navy2);
    }

    .phone-img-wrap img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center top;
      display: block;
    }

    .store-btn {
      display: flex;
      align-items: center;
      gap: 14px;
      padding: 14px 20px;
      border: 1px solid rgba(255,255,255,0.18);
      background: rgba(255,255,255,0.04);
      color: var(--white);
      text-decoration: none;
      transition: background 0.2s, border-color 0.2s;
    }

    .store-btn:hover {
      background: rgba(255,255,255,0.09);
      border-color: rgba(255,255,255,0.4);
    }

    .store-btn svg {
      flex-shrink: 0;
      width: 22px;
      height: 22px;
      fill: var(--white);
    }

    .store-btn-text small {
      display: block;
      font-size: 10px;
      color: var(--gray);
      letter-spacing: 0.07em;
      text-transform: uppercase;
      margin-bottom: 2px;
    }

    .store-btn-text strong {
      font-size: 15px;
    }

    /* ── QR BLOCK ── */
    .qr-block {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 16px;
      padding: 28px 20px;
      border: 1px solid rgba(255,255,255,0.10);
      background: rgba(255,255,255,0.03);
      align-self: end;
    }

    .qr-placeholder {
      width: 148px;
      height: 148px;
      background: #fff;
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
    }

    .qr-placeholder::before,
    .qr-placeholder::after {
      content: '';
      position: absolute;
      width: 28px;
      height: 28px;
      border: 3px solid #0b1f3a;
    }
    .qr-placeholder::before { top: 8px; left: 8px; border-right: none; border-bottom: none; }
    .qr-placeholder::after  { bottom: 8px; right: 8px; border-left: none; border-top: none; }

    .qr-corner-tr {
      position: absolute;
      width: 28px; height: 28px;
      border: 3px solid #0b1f3a;
      top: 8px; right: 8px;
      border-left: none; border-bottom: none;
    }
    .qr-corner-bl {
      position: absolute;
      width: 28px; height: 28px;
      border: 3px solid #0b1f3a;
      bottom: 8px; left: 8px;
      border-right: none; border-top: none;
    }

    .qr-center {
      font-size: 9px;
      color: #aaa;
      text-align: center;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      line-height: 1.6;
      max-width: 90px;
    }

     .qr-center img{
      width: 100%;
     }

    .qr-label {
      font-size: 11px;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gray);
      text-align: center;
      line-height: 1.5;
    }

    .mobile-layout { display: none; }

    .mobile-store-btn {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 14px;
      padding: 18px 24px;
      width: 100%;
      border: 1px solid rgba(255,255,255,0.22);
      background: rgba(255,255,255,0.05);
      color: var(--white);
      text-decoration: none;
      font-size: 16px;
      transition: background 0.2s;
    }

    .mobile-store-btn:hover { background: rgba(255,255,255,0.10); }

    .mobile-store-btn svg {
      width: 26px; height: 26px;
      fill: var(--white);
      flex-shrink: 0;
    }

    @media (max-width: 900px) {
      .app-section   { padding: 64px 0 56px; }
      .container     { padding: 0 24px; }
      .section-title { font-size: 36px; margin-bottom: 40px; }
      .desktop-layout { display: none; }
      .mobile-layout  { display: block; }
    }

    footer {
    background-color: #002446;
    padding: 40px 0 24px;
}


.footer-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    padding-bottom: 32px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    flex-wrap: wrap;
}

.logotype {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.footer-contacts {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.footer-contacts p,
.footer-contacts a {
    color: #fff;
    font-size: 14px;
    line-height: 1.5;
    text-decoration: none;
    opacity: 0.85;
    transition: opacity 0.2s;
}
.footer-contacts p svg,
.footer-contacts a svg{
  margin-right: 6px;
}

.footer-contacts a:hover {
    opacity: 1;
}

.social-links {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.social-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s, opacity 0.2s;
    opacity: 0.9;
}

.social-icon:hover {
    transform: translateY(-2px);
    opacity: 1;
}

.footer-copy {
    display: flex;
    justify-content: space-between;
    margin-top: 20px;
    color: #fff;
    font-size: 13px;
}

.footer-copy a{
  color: #fff;
  text-decoration: none;
}
.footer-copy a:hover{
  color: gray;
}

@media (max-width: 768px) {
    .footer-inner {
        flex-direction: column;
        align-items: flex-start;
        gap: 24px;
    }
    .footer-copy {
      flex-direction: column;
    }
    .footer-copy p:first-child{
      margin-bottom: 20px;
    }
}

.sticker-layer {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 1;
}

.stk {
    position: absolute;
    width: 160px;
    height: 180px;
    will-change: transform;
    pointer-events: none;
}

.stk img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    filter: drop-shadow(0 8px 24px rgba(0,0,0,0.35));
    transition: filter 0.3s;
}

@media (max-width: 768px) {
    .stk { width: 90px; height: 100px; }
    .stk.hide-mobile { display: none; }
    .sticker-layer { display: none; }
}


/** maps **/

#map .maplibregl-popup-content {
  background:#002446;
  border-radius: 10px;
}

.maplibregl-popup-content {
  padding: 0;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
  overflow: hidden;
  min-width: 300px;
}

.azk-popup {
  position: relative;
  padding: 20px 20px 16px;
  cursor: auto;
}

.azk-popup__close {
  position: absolute;
  top: 0;
  right: 10px;
  background: none;
  border: none;
  font-size: 20px;
  color: #fff;
  cursor: pointer;
  line-height: 1;
  padding: 0;
}

.azk-popup__close:hover {
  color: #333;
}

.azk-popup__badge {
  display: inline-block;
  background: #ffd700;
  color: #333;
  font-size: 11px;
  font-weight: bold;
  padding: 2px 8px;
  border-radius: 20px;
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.azk-popup__rytm {
  color: var(--yellow);
  font-weight: bold;
  font-size: 18px;
  margin-bottom: 10px;
  letter-spacing: 0.8px;
}

.azk-popup__title {
  margin: 0 0 6px;
  font-size: 16px;
  font-weight: bold;
  color: #0057b7;
}

.azk-popup__address {
  margin: 0;
  font-size: 13px;
  color: #fff;
  line-height: 1.4;
}

.azk-popup__route {
  display: inline-block;
  margin-top: 10px;
  padding: 8px 14px;
  background: #030405;
  color: #f5c800;
  border-radius: 8px;
  text-decoration: none;
  font-size: 13px;
  font-weight: bold;
}
.azk-popup__route:hover {
  background: #003a6e;
}
