@font-face{font-family:Manrope;src:url('../assets/fonts/Manrope-Regular.woff2');font-weight:400;font-style:normal}
@font-face{font-family:Manrope;src:url('../assets/fonts/Manrope-Medium.woff2');font-weight:500;font-style:normal}
@font-face{font-family:Manrope;src:url('../assets/fonts/Manrope-SemiBold.woff2');font-weight:600;font-style:normal}
@font-face{font-family:Manrope;src:url('../assets/fonts/Manrope-Bold.woff2');font-weight:700;font-style:normal}
@font-face{font-family:Prata;src:url('../assets/fonts/Prata-Regular.woff2');font-weight:400;font-style:normal}

:root{--blue:#0B1F3A;--gold:#D4A24C;--gold2:#F2C879;--light:#F5F7FA;--red:#E53935}
*{box-sizing:border-box}
body{margin:0;font-family:Manrope,Arial,sans-serif;color:var(--blue);background:#fff}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1280px;margin:auto;padding:0 40px}

/* HERO */
.hero{min-height:830px;background:url('../assets2/backgrounds/background1.webp') center/cover;position:relative;color:#fff}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.6),rgba(0,0,0,.3) 50%,rgba(0,0,0,.2))}
.nav,.hero__content,.hero__plate{position:relative;z-index:1}
.nav{display:flex;align-items:center;justify-content:space-between;padding-top:24px;gap:24px}
.logos{display:flex;align-items:center;gap:16px}
.logos img{max-height:42px;max-width:110px}
.menu{display:flex;gap:24px}
.menu a,.footer a{text-decoration:none}
.phone{font-weight:700}
.nav-callback{border:1px solid rgba(255,255,255,.55);background:rgba(255,255,255,.12);color:#fff;border-radius:999px;padding:11px 18px;font-weight:700;font-size:13px;line-height:1.2;cursor:pointer;white-space:nowrap}
.nav-callback:hover{background:linear-gradient(135deg,var(--gold),var(--gold2));border-color:transparent;color:var(--blue)}
.nav-callback--menu{display:none}
.burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.burger span{width:24px;height:2px;background:#fff;border-radius:2px}
.menu__close,.menu__backdrop{display:none}
.menu__close{width:44px;height:44px;border-radius:50%;color:#fff;font-size:2rem;line-height:1;background:none;border:none;cursor:pointer;margin-left:auto;margin-bottom:16px}
.menu__backdrop{position:fixed;inset:0;background:rgba(7,15,36,.48);opacity:0;visibility:hidden;transition:all .3s ease;z-index:140}
.menu__backdrop.active{opacity:1;visibility:visible}
.hero__content{display:grid;grid-template-columns:1fr 390px;gap:60px;align-items:center;padding-top:110px}
.hero h1{font-family:Prata,serif;font-size:clamp(42px,6vw,76px);line-height:1.05;margin:0}
.hero h1 span{font-size:.55em}
.lead{font-size:24px}
.benefits{display:flex;flex-wrap:wrap;gap:12px;margin:28px 0}
.benefits span{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);padding:10px 14px;border-radius:999px}

/* BUTTONS */
.btn{border:0;border-radius:999px;padding:17px 28px;font-weight:700;cursor:pointer;text-decoration:none;display:inline-flex;justify-content:center;align-items:center;gap:8px;text-transform:uppercase;font-size:15px}
.btn--primary{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--blue);box-shadow:0 10px 24px rgba(212,162,76,.25)}
.btn--primary:hover{transform:translateY(-2px);transition:.3s}
.btn--outline{background:transparent;border:1px solid var(--gold);color:var(--blue)}
.btn--outline.light{color:#fff;border-color:#fff}

/* FORMS */
.hero-form,.lead-form{background:rgba(255,255,255,.94);color:var(--blue);padding:30px;border-radius:24px;box-shadow:0 24px 70px rgba(0,0,0,.22)}
.lead-form input,.lead-form select,.quiz input,.quiz select{width:100%;padding:15px 16px;margin:8px 0;border:1px solid rgba(11,31,58,.15);border-radius:12px;font:inherit}
.lead-form label,.quiz label{display:block;margin:8px 0;font-size:14px;font-weight:500}
.consent{display:flex;align-items:flex-start;gap:8px;font-size:13px;margin:12px 0;cursor:pointer}
.consent input{width:auto;margin-top:3px;flex-shrink:0}
.hero__plate{margin-top:70px;background:rgba(11,31,58,.82);border:1px solid rgba(255,255,255,.18);border-radius:20px;padding:20px 28px;font-weight:700}
.hero__plate small{display:block;font-weight:400;opacity:.8;margin-top:6px}

/* TOURIST COUNTERS */
.form-tourists{margin:8px 0}
.tourist-row{display:flex;align-items:center;gap:12px;margin:6px 0;font-size:15px}
.tourist-row span:first-child{min-width:100px}
.counter__btn{width:36px;height:36px;border-radius:50%;border:1px solid rgba(11,31,58,.2);background:#fff;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center}
.counter__btn:hover{background:var(--light)}
.add-child-btn{background:none;border:1px dashed var(--gold);color:var(--gold);padding:8px 16px;border-radius:12px;cursor:pointer;font:inherit;font-size:14px;margin-top:4px}
.child-row{display:flex;align-items:center;gap:10px;margin:4px 0;padding:6px 0;border-top:1px solid #eee}
.child-row select{width:auto;padding:6px 10px;margin:0}
.child-row .child-remove{background:none;border:none;color:var(--red);cursor:pointer;font-size:18px;padding:4px 8px}

/* SECTIONS */
.section{padding:82px 40px}
.section h2,.liner h2{font-family:Prata,serif;text-align:center;font-size:clamp(32px,4vw,52px);font-weight:400;margin:0 0 34px}
.subtitle{text-align:center;font-size:20px;margin-top:-20px}

/* SLIDER / GALLERY */
.slider{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;padding:8px max(40px,calc((100vw - 1280px)/2 + 40px)) 18px;-webkit-overflow-scrolling:touch}
.photo-card{position:relative;min-width:280px;height:400px;border-radius:16px;overflow:hidden;scroll-snap-align:start;background:#ddd;box-shadow:0 18px 50px rgba(11,31,58,.14)}
.photo-card img{width:100%;height:100%;object-fit:cover}
.photo-card:after{content:"";position:absolute;inset:45% 0 0;background:linear-gradient(180deg,transparent,rgba(0,0,0,.78))}
.photo-card b,.photo-card span{position:absolute;left:20px;right:20px;z-index:1;color:#fff}
.photo-card b{bottom:45px;font-size:19px}
.photo-card span{bottom:20px}

/* ROUTES */
.routes{background:var(--light)}
.routes-grid{max-width:1120px;margin:32px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.route-card{min-height:440px;border-radius:18px;overflow:hidden;position:relative;color:#fff;display:flex;align-items:flex-end;background:#123}
.route-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.route-card:after{content:"";position:absolute;inset:15% 0 0;background:linear-gradient(180deg,transparent,rgba(0,0,0,.9))}
.badge{position:absolute;top:18px;left:18px;background:var(--gold);color:var(--blue);border-radius:999px;padding:7px 12px;font-weight:700;z-index:2}
.route-card__body{position:relative;z-index:1;padding:22px;width:100%}
.route-card h3{font-size:20px;margin:0 0 10px}
.route-card p{margin:6px 0}
.price{font-size:21px;font-weight:700;margin:14px 0}
.route-actions{display:flex;gap:10px;flex-wrap:wrap}

/* DARK SECTION */
.dark{background:var(--blue);color:#fff}
.icon-grid,.why-grid{max-width:1120px;margin:auto;display:grid;grid-template-columns:repeat(3,1fr);gap:40px 32px;text-align:center}
.icon-grid img{width:58px;height:58px;object-fit:contain;margin:0 auto 16px;filter:brightness(0) invert(1)}

/* WHY (ЭКРАН 5) — белый текст */
.why{background:url('../assets2/backgrounds/background5.webp') center/cover;color:#fff}
.why h2{color:#fff}
.why-grid img{width:172px;height:172px;object-fit:cover;border-radius:50%;margin:0 auto 20px}
.why-grid p{opacity:1;color:rgba(255,255,255,.92)}
.why-grid h3{color:#fff}

.center{text-align:center;margin-top:34px}

/* LINER */
.liner{background:linear-gradient(90deg,rgba(5,15,30,.88),rgba(5,15,30,.68) 40%,rgba(5,15,30,.22)),url('../assets2/backgrounds/background7.webp') center right/cover;color:#fff;padding:80px 0 60px}
.liner h2{text-align:left;font-size:clamp(58px,7vw,104px);line-height:.95;margin:8px 0}
.eyebrow,.liner h3{color:var(--gold);letter-spacing:.08em;font-weight:700}
.liner p{max-width:560px;font-size:18px;line-height:1.6}
.liner__buttons{display:flex;gap:20px;margin:28px 0}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;background:rgba(10,20,40,.62);backdrop-filter:blur(12px);border-radius:18px;padding:26px;margin:34px 0;border:1px solid rgba(255,255,255,.08)}
.liner-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
.liner-cards article{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:16px;overflow:hidden}
.liner-cards img{height:175px;width:100%;object-fit:cover}
.liner-cards h4,.liner-cards p{padding:0 14px}

/* ABOUT */
.about-grid{max-width:1120px;margin:auto;display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
.about-grid>img{border-radius:22px}
.about__subtitle{font-weight:700;font-size:18px;margin:12px 0 8px}
.about__partner{font-weight:600;border-bottom:2px solid var(--gold);display:inline-block;padding-bottom:4px;margin:12px 0 20px;font-size:16px}
.about-facts{display:flex;gap:16px;flex-wrap:wrap;margin:0 0 24px}
.about-fact{background:var(--light);border-radius:14px;padding:18px;flex:1;min-width:180px}
.about-fact b{display:block;font-size:28px;font-family:Prata,serif;color:var(--gold)}
.about-fact span{font-size:13px;color:rgba(11,31,58,.6);display:block;margin:2px 0 8px}
.about-fact p{margin:0;font-size:14px;line-height:1.5}

/* FAQ */
.faq{background:var(--light)}
.faq-list{max-width:920px;margin:auto}
.faq details{background:#fff;border:1px solid rgba(11,31,58,.08);border-radius:14px;margin:12px 0;padding:18px 22px}
.faq summary{font-weight:700;font-size:18px;cursor:pointer}
.faq p{line-height:1.65}

/* FOOTER */
.footer{background:var(--blue);color:#fff;padding:48px 0 100px}
.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.footer a{display:block;color:rgba(255,255,255,.82);margin:8px 0}
.copy{text-align:center;color:rgba(255,255,255,.65);margin-top:30px}

/* FIXED BUTTONS */
.fixed-buttons{position:fixed;bottom:0;left:0;right:0;display:flex;gap:0;z-index:40;background:var(--blue)}
.fixed-btn{flex:1;text-align:center;padding:14px 10px;font-weight:700;font-size:14px;border:none;cursor:pointer;text-transform:uppercase;letter-spacing:.03em}
.fixed-btn--primary{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--blue)}
.fixed-btn--outline{background:var(--blue);color:#fff;border-top:1px solid rgba(255,255,255,.2)}

/* BACK TO TOP */
.back-to-top{position:fixed;bottom:80px;right:24px;width:48px;height:48px;border-radius:50%;background:var(--blue);color:#fff;border:2px solid rgba(255,255,255,.3);font-size:22px;cursor:pointer;z-index:40;display:none;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.3)}
.back-to-top.visible{display:flex}

/* MODALS */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:50;padding:18px}
.modal.active{display:flex}
.modal__box{background:#fff;color:var(--blue);width:min(560px,100%);max-height:92vh;overflow:auto;border-radius:22px;padding:28px;position:relative}
.modal__box--wide{width:min(980px,100%)}
.modal__close{position:absolute;right:14px;top:10px;border:0;background:none;font-size:34px;cursor:pointer;color:var(--blue)}
.route-modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.route-modal-grid img{border-radius:16px;width:100%}

/* QUIZ */
.quiz__step{display:none}
.quiz__step.active{display:block}
.quiz__nav{display:flex;gap:12px;margin-top:14px}
.quiz-radio{display:block;margin:10px 0;padding:14px 18px;border:1px solid rgba(11,31,58,.1);border-radius:12px;cursor:pointer;transition:.2s}
.quiz-radio:hover{border-color:var(--gold)}
.quiz-radio input{display:inline;width:auto;margin-right:8px}

/* CABIN CARDS (QUIZ STEP 5) */
.cabin-cards{display:flex;gap:12px;overflow-x:auto;padding:8px 0}
.cabin-card{min-width:150px;flex-shrink:0;border:3px solid transparent;border-radius:14px;overflow:hidden;cursor:pointer;text-align:center;padding:8px;transition:.2s;background:#fafafa}
.cabin-card:hover{border-color:var(--gold)}
.cabin-card input{display:none}
.cabin-card.selected,.cabin-card:has(input:checked){border-color:var(--red);box-shadow:0 0 0 2px var(--red)}
.cabin-card img{width:100%;height:110px;object-fit:cover;border-radius:10px;margin-bottom:8px}
.cabin-card b{display:block;font-size:13px}
.cabin-card--undecided{background:#f0f0f0}
.cabin-card--undecided .cabin-card__question{width:100%;height:110px;border-radius:10px;background:var(--light);display:flex;align-items:center;justify-content:center;font-size:48px;color:var(--gold);font-family:Prata,serif;margin-bottom:8px}

/* MOBILE ADAPTIVE */
@media(max-width:900px){
  .container{padding:0 20px}
  .nav{flex-wrap:wrap}
  .burger{display:flex}
  .menu{position:fixed;top:0;right:-280px;width:280px;height:100vh;background:rgba(11,31,58,.97);flex-direction:column;gap:20px;padding:24px;z-index:150;transition:right .3s ease;display:flex;overflow-y:auto}
  .menu.open{right:0}
  .menu__close{display:inline-flex;align-items:center;justify-content:center}
  .menu__backdrop{display:block}
  .menu a{font-size:16px;padding:8px 0}
  .phone{order:1}
  .nav-callback{order:2}
  .hero__content,.about-grid,.route-modal-grid{grid-template-columns:1fr}
  .routes-grid,.icon-grid,.why-grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .liner-cards{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero{min-height:auto;padding-bottom:40px}
  .hero__content{padding-top:50px;gap:30px}
  .section{padding:58px 20px}
  .liner__buttons{flex-direction:column}
  .photo-card{min-width:78vw;height:380px}
  .about-facts{flex-direction:column}
}

@media(max-width:560px){
  .liner-cards,.footer-grid,.routes-grid,.icon-grid,.why-grid{grid-template-columns:1fr}
  .logos img{max-width:86px}
  .hero-form{padding:20px}
  .route-actions{display:grid}
  .hero h1{font-size:32px}
  .cabin-cards{flex-wrap:nowrap}
  .cabin-card{min-width:140px}
  .fixed-btn{font-size:12px;padding:12px 6px}
}

/* ===================================================================
   MOBILE-FIRST OVERRIDES — Азия / Шанхай
   продуманная адаптация 320–768 px
   =================================================================== */
html{scroll-behavior:smooth;overflow-x:hidden}
body{overflow-x:hidden;min-width:320px}
button,input,select,textarea{font-family:inherit}
.menu__phone{display:none}
body.modal-open .fixed-buttons{display:none}

@media(max-width:900px){
  body{padding-bottom:72px}
  .container{width:100%;padding-left:20px;padding-right:20px}
  .hero{min-height:auto;padding-bottom:30px;background-position:center top}
  .hero__overlay{background:linear-gradient(180deg,rgba(0,0,0,.72),rgba(0,0,0,.48) 58%,rgba(0,0,0,.38))}
  .nav{display:grid;grid-template-columns:minmax(0,1fr) 48px;align-items:center;gap:10px;padding-top:14px;flex-wrap:nowrap}
  .logos{min-width:0;gap:8px;justify-content:flex-start;overflow:hidden}
  .logos img{width:auto;object-fit:contain;flex-shrink:1}
  .nav .logos img:nth-child(1){max-width:82px;max-height:30px}
  .nav .logos img:nth-child(2){max-width:66px;max-height:30px}
  .nav .logos img:nth-child(3){max-width:82px;max-height:30px}
  .phone{display:none}
  .nav>.nav-callback{display:none}
  .burger{display:flex;justify-self:end;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22)}
  .burger span{width:24px;height:2px;background:#fff}
  .menu{position:fixed;top:0;right:-86vw;width:min(86vw,340px);height:100dvh;background:rgba(11,31,58,.98);box-shadow:-18px 0 50px rgba(0,0,0,.28);flex-direction:column;gap:8px;padding:18px 22px 28px;z-index:150;transition:right .28s ease;display:flex;overflow-y:auto;overscroll-behavior:contain}
  .menu.open{right:0}
  .menu__close{display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15)}
  .menu__backdrop{display:block}
  .menu a{font-size:17px;font-weight:600;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.12)}
  .menu__phone{display:block;margin-top:8px;color:var(--gold);border-bottom:0!important}
  .nav-callback--menu{display:inline-flex;margin-top:10px;justify-content:center;color:var(--blue);background:linear-gradient(135deg,var(--gold),var(--gold2));border:0}

  .hero__content{grid-template-columns:1fr;padding-top:46px;gap:24px;align-items:start}
  .hero__text{max-width:620px}
  .hero h1{font-size:clamp(31px,7.5vw,48px);line-height:1.12;letter-spacing:-.02em;text-wrap:balance}
  .hero h1 br{display:none}
  .hero h1 span{display:block;font-size:.62em;margin-top:8px;line-height:1.18}
  .lead{font-size:18px;line-height:1.35;margin:16px 0}
  .benefits{gap:8px;margin:18px 0 22px}
  .benefits span{font-size:13px;padding:8px 11px;line-height:1.2}
  .hero__text .btn{width:100%;max-width:420px}
  .hero-form,.lead-form{padding:22px;border-radius:20px;width:100%;max-width:560px;margin:0 auto;box-shadow:0 18px 42px rgba(0,0,0,.20)}
  .hero-form h3{font-size:20px;margin:0 0 8px}
  .hero-form p{margin:0 0 12px;line-height:1.45}
  .hero__plate{margin:18px 20px 0;padding:15px 16px;border-radius:16px;font-size:15px;line-height:1.35}
  .hero__plate small{font-size:12px;line-height:1.45}

  .section{padding:54px 20px}
  .section h2,.liner h2{font-size:clamp(28px,7.2vw,42px);line-height:1.12;margin-bottom:24px;text-wrap:balance}
  .subtitle{font-size:17px;margin-top:-14px}

  .slider{margin-left:-20px;margin-right:-20px;padding:6px 20px 16px;gap:14px;scroll-padding-left:20px}
  .photo-card{min-width:82vw;width:82vw;height:360px;border-radius:18px}
  .photo-card img{width:100%;height:100%;object-fit:cover}
  .photo-card:after{inset:35% 0 0;background:linear-gradient(180deg,transparent,rgba(0,0,0,.86))}
  .photo-card b{left:16px;right:16px;bottom:42px;font-size:19px;line-height:1.2;text-shadow:0 2px 10px rgba(0,0,0,.45)}
  .photo-card span{left:16px;right:16px;bottom:18px;font-size:14px;line-height:1.3;text-shadow:0 2px 10px rgba(0,0,0,.45)}

  .routes-grid{grid-template-columns:1fr;gap:18px;margin-top:26px;max-width:520px}
  .route-card{min-height:450px;border-radius:20px;align-items:flex-end}
  .route-card:after{inset:0;background:linear-gradient(180deg,rgba(0,0,0,.12),rgba(0,0,0,.42) 35%,rgba(0,0,0,.92) 100%)}
  .badge{top:14px;left:14px;font-size:13px;padding:7px 12px}
  .route-card__body{padding:20px 18px 18px}
  .route-card h3{font-size:19px;line-height:1.24;margin-bottom:10px;overflow-wrap:anywhere}
  .route-card p{font-size:14px;line-height:1.35;margin:5px 0}
  .price{font-size:24px;line-height:1.2;margin:14px 0 16px}
  .route-actions{display:grid;grid-template-columns:1fr;gap:10px}
  .route-actions .btn{width:100%;padding:15px 16px;font-size:14px;white-space:normal;text-align:center}

  .icon-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:22px 14px;text-align:center}
  .icon-grid>div{min-width:0;padding:12px 8px}
  .icon-grid img{width:52px;height:52px;margin-bottom:12px}
  .icon-grid h3{font-size:16px;margin:8px 0}
  .icon-grid p{font-size:14px;line-height:1.5;margin:0}

  .why{background-position:center;position:relative}
  .why:before{content:"";position:absolute;inset:0;background:rgba(5,15,30,.42)}
  .why>*{position:relative;z-index:1}
  .why-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:26px 16px;text-align:center}
  .why-grid img{width:118px;height:118px;margin-bottom:14px}
  .why-grid h3{font-size:15px;line-height:1.25;margin:0 0 8px}
  .why-grid p{font-size:14px;line-height:1.5;color:#fff;opacity:1;margin:0}

  .liner{padding:56px 0 50px;background:linear-gradient(180deg,rgba(5,15,30,.90),rgba(5,15,30,.74) 62%,rgba(5,15,30,.88)),url('../assets2/backgrounds/background7.webp') center/cover}
  .liner .container{padding-left:20px;padding-right:20px}
  .liner h2{text-align:left;font-size:clamp(50px,14vw,78px);line-height:1;margin-bottom:12px}
  .liner h3{font-size:16px;line-height:1.35}
  .liner p{font-size:16px;line-height:1.55;max-width:none}
  .liner__buttons{display:grid;grid-template-columns:1fr;gap:12px;margin:24px 0}
  .liner__buttons .btn{width:100%;white-space:normal;text-align:center}
  .stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:14px;margin:24px 0;border-radius:16px}
  .stats b{font-size:14px;line-height:1.35;padding:10px;border-radius:12px;background:rgba(255,255,255,.06)}
  .liner-cards{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:12px;margin-right:-20px;padding-right:20px}
  .liner-cards article{min-width:82vw;scroll-snap-align:start;background:rgba(0,0,0,.28);backdrop-filter:blur(2px)}
  .liner-cards img{height:220px;object-fit:cover;object-position:center}
  .liner-cards h4{font-size:16px;line-height:1.25;margin:14px 0 8px;color:#fff}
  .liner-cards p{font-size:14px;line-height:1.5;color:#fff;margin:0 0 16px}

  .about-grid{grid-template-columns:1fr;gap:24px;max-width:640px}
  .about-grid>img{order:0;width:100%;border-radius:20px;max-height:420px;object-fit:cover;object-position:center top}
  .about__text{order:1}
  .about__text h2{text-align:left;margin-bottom:14px}
  .about__partner{font-weight:600;border:0;border-bottom:2px solid var(--gold);background:none;padding:0 0 5px;margin:12px 0 18px;display:inline;box-decoration-break:clone;-webkit-box-decoration-break:clone}
  .about-facts{display:grid;grid-template-columns:1fr;gap:12px;margin-top:22px}
  .about-fact{min-width:0;padding:16px;border-radius:14px}
  .about__text .btn{width:100%;white-space:normal;text-align:center}

  .faq details{padding:14px 16px;margin:10px 0;border-radius:13px}
  .faq summary{font-size:16px;line-height:1.35;padding-right:8px;white-space:normal}
  .faq p{font-size:14px;line-height:1.55;margin:12px 0 0}

  .footer{padding:42px 0 calc(92px + env(safe-area-inset-bottom))}
  .footer-grid{grid-template-columns:1fr 1fr;gap:22px}
  .footer .logos{align-items:flex-start;flex-wrap:wrap}

  .fixed-buttons{min-height:64px;max-height:72px;padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -10px 28px rgba(0,0,0,.22)}
  .fixed-btn{display:flex;align-items:center;justify-content:center;min-height:64px;padding:10px 8px;font-size:12px;line-height:1.18;letter-spacing:.015em;white-space:normal}
  .back-to-top{bottom:86px;right:16px;width:42px;height:42px}

  .modal{z-index:300;align-items:flex-start;padding:12px 12px calc(12px + env(safe-area-inset-bottom));overflow-y:auto}
  .modal__box,.modal__box--wide{width:calc(100vw - 24px);max-width:none;max-height:90vh;overflow-y:auto;border-radius:18px;padding:24px 16px 18px;margin:auto 0;overscroll-behavior:contain}
  .modal__close{position:sticky;top:0;right:0;margin-left:auto;margin-top:-12px;margin-bottom:2px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#fff;box-shadow:0 4px 16px rgba(0,0,0,.12);z-index:5;font-size:32px;line-height:1}
  .modal__box h3{font-size:21px;line-height:1.25;margin:0 42px 12px 0}
  .lead-form input,.lead-form select,.quiz input,.quiz select{min-height:44px;padding:13px 14px;margin:6px 0;border-radius:11px;font-size:16px}
  .lead-form .btn,.quiz .btn{width:100%;min-height:46px;white-space:normal;text-align:center}
  .consent{font-size:12px;line-height:1.45;align-items:flex-start}
  .consent input{width:18px;height:18px;min-height:auto;margin:1px 0 0;flex:0 0 18px}
  .tourist-row{gap:9px;flex-wrap:nowrap;margin:8px 0;padding:8px 0}
  .tourist-row span:first-child{min-width:108px;flex:1;font-size:14px;line-height:1.25}
  .counter__btn{width:40px;height:40px;flex:0 0 40px}
  .child-row{display:grid;grid-template-columns:1fr 88px 40px;gap:8px;align-items:center}
  .child-row select{width:100%;min-height:40px}
  .route-modal-grid{grid-template-columns:1fr;gap:16px}
  .route-modal-grid img{max-height:52vh;object-fit:contain;background:var(--light)}
  .route-modal-grid .btn{width:100%}

  .quiz__step h3{font-size:21px;line-height:1.25;margin:0 0 14px}
  .quiz__nav{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}
  .quiz-radio{min-height:48px;padding:13px 14px;font-size:15px;line-height:1.35}
  .quiz-radio input{width:18px;height:18px;min-height:auto;vertical-align:middle}
  .cabin-cards{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 0 12px;margin-right:-16px;padding-right:16px}
  .cabin-card{min-width:44vw;max-width:190px;scroll-snap-align:start;border-width:3px;border-radius:14px;padding:8px;margin:0;font-size:13px}
  .cabin-card img,.cabin-card--undecided .cabin-card__question{height:116px;object-fit:cover}
  .cabin-card.selected,.cabin-card:has(input:checked){border-color:#ff4b24;box-shadow:0 0 0 2px #ff4b24;background:#fff7f4}
  .quiz__error{color:#E53935;font-size:14px;line-height:1.35;margin-top:10px;padding:9px 12px;background:#FFF3F0;border-radius:10px}
}

@media(max-width:560px){
  .container{padding-left:16px;padding-right:16px}
  .nav{padding-top:12px}
  .nav .logos{gap:6px}
  .nav .logos img:nth-child(1){max-width:72px;max-height:27px}
  .nav .logos img:nth-child(2){max-width:58px;max-height:27px}
  .nav .logos img:nth-child(3){max-width:72px;max-height:27px}
  .hero__content{padding-top:36px;gap:20px}
  .hero h1{font-size:clamp(28px,8.6vw,36px);line-height:1.13}
  .lead{font-size:16px}
  .benefits span{font-size:12px;padding:7px 10px}
  .hero-form,.lead-form{padding:18px;border-radius:18px}
  .hero__plate{margin:16px 12px 0;padding:14px}
  .section{padding:46px 16px}
  .slider{margin-left:-16px;margin-right:-16px;padding-left:16px;padding-right:16px;scroll-padding-left:16px}
  .photo-card{min-width:84vw;width:84vw;height:350px}
  .route-card{min-height:440px}
  .route-card__body{padding:18px 16px 16px}
  .route-card h3{font-size:18px}
  .price{font-size:23px}
  .icon-grid{grid-template-columns:1fr;gap:18px;max-width:360px}
  .why-grid{grid-template-columns:1fr;gap:24px;max-width:360px}
  .why-grid img{width:132px;height:132px}
  .stats{grid-template-columns:1fr 1fr;padding:12px;gap:8px}
  .liner-cards article{min-width:84vw}
  .liner-cards img{height:210px}
  .footer-grid{grid-template-columns:1fr}
  .fixed-btn{font-size:11px;padding:8px 5px;min-height:62px}
  .modal__box,.modal__box--wide{padding:22px 14px 16px}
  .quiz__nav{grid-template-columns:1fr 1fr}
  .quiz__nav .btn{padding-left:10px;padding-right:10px;font-size:13px}
  .cabin-card{min-width:58vw}
}

@media(max-width:340px){
  .nav .logos img:nth-child(1){max-width:66px;max-height:24px}
  .nav .logos img:nth-child(2){max-width:50px;max-height:24px}
  .nav .logos img:nth-child(3){max-width:66px;max-height:24px}
  .hero h1{font-size:27px}
  .btn{font-size:13px;padding:14px 16px}
  .photo-card{min-width:85vw;height:340px}
  .route-card{min-height:430px}
  .route-card p{font-size:13px}
  .route-actions .btn{font-size:12px;padding:13px 10px}
  .price{font-size:22px}
  .stats{grid-template-columns:1fr}
  .fixed-btn{font-size:10px;letter-spacing:0;line-height:1.15}
  .cabin-card{min-width:72vw}
  .tourist-row span:first-child{min-width:88px;font-size:13px}
}

@media(min-width:561px) and (max-width:900px){
  .photo-card{min-width:360px;width:360px;height:380px}
  .routes-grid{grid-template-columns:1fr 1fr;max-width:760px}
  .route-card{min-height:460px}
  .liner-cards article{min-width:360px}
  .cabin-card{min-width:170px}
}

@media(min-width:701px) and (max-width:900px){
  .hero__content{grid-template-columns:minmax(0,1fr) minmax(300px,360px);align-items:center;gap:28px;padding-top:56px}
  .hero h1{font-size:42px}
  .hero__text .btn{width:auto}
  .hero__plate{margin-top:28px}
  .about-grid{grid-template-columns:1fr 1fr;align-items:start;max-width:760px}
  .about-grid>img{position:sticky;top:16px}
}

/* ===== FINAL MOBILE MENU / HERO FIX ===== */
@media (max-width: 900px) {
  body { overflow-x: hidden; }
  .hero {
    background-position: center center !important;
    background-size: cover !important;
  }
  .nav {
    position: relative !important;
    z-index: 1001 !important;
    flex-wrap: nowrap !important;
  }
  .phone { display: none !important; }
  .burger {
    display: flex !important;
    margin-left: auto !important;
    position: relative !important;
    z-index: 1002 !important;
  }
  .menu__backdrop {
    display: block !important;
    position: fixed !important;
    inset: 0 !important;
    background: rgba(7, 15, 36, .62) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    z-index: 1000 !important;
    transition: opacity .25s ease, visibility .25s ease !important;
  }
  .menu__backdrop.active {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }
  .menu {
    position: fixed !important;
    top: 0 !important;
    right: -88vw !important;
    left: auto !important;
    width: min(88vw, 340px) !important;
    height: 100dvh !important;
    background: #0B1F3A !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    padding: 22px 24px 32px !important;
    z-index: 1003 !important;
    box-shadow: -20px 0 60px rgba(0,0,0,.35) !important;
    transition: right .28s ease !important;
    overflow-y: auto !important;
    transform: none !important;
    border-radius: 0 !important;
  }
  .menu.open { right: 0 !important; }
  .menu__close {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important;
    height: 44px !important;
    margin: 0 0 18px auto !important;
    color: #fff !important;
    background: rgba(255,255,255,.08) !important;
    border: 1px solid rgba(255,255,255,.16) !important;
    border-radius: 50% !important;
    font-size: 32px !important;
    line-height: 1 !important;
  }
  .menu a {
    display: block !important;
    color: #fff !important;
    font-size: 17px !important;
    font-weight: 600 !important;
    padding: 15px 0 !important;
    border-bottom: 1px solid rgba(255,255,255,.14) !important;
    pointer-events: auto !important;
  }
  .menu__phone {
    display: block !important;
    color: #F2C879 !important;
    border-bottom: 0 !important;
    margin-top: 10px !important;
  }
}

/* Messenger floating widget */
.messenger-widget{position:fixed;right:104px;bottom:24px;z-index:135;display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.messenger-widget__button{width:58px;height:58px;border:0;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--blue);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 12px 28px rgba(7,15,36,.28);transition:transform .2s ease,box-shadow .2s ease}
.messenger-widget__button svg{width:29px;height:29px}
.messenger-widget__button:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(7,15,36,.34)}
.messenger-widget__panel{display:flex;flex-direction:column;gap:8px;opacity:0;visibility:hidden;pointer-events:none;transform:translateY(10px);transition:opacity .2s ease,transform .2s ease,visibility .2s ease}
.messenger-widget.open .messenger-widget__panel{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0)}
.messenger-widget__link{min-width:164px;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:14px;background:#fff;color:var(--blue);font-weight:800;text-decoration:none;box-shadow:0 10px 24px rgba(7,15,36,.18);border:1px solid rgba(11,31,58,.08)}
.messenger-widget__link:hover{transform:translateX(-2px)}
.messenger-widget__icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:900;letter-spacing:0}
.messenger-widget__link--whatsapp .messenger-widget__icon{background:#25d366}
.messenger-widget__link--telegram .messenger-widget__icon{background:#229ed9}
.messenger-widget__link--max .messenger-widget__icon{background:#2b7cff}

@media(max-width:900px){
  .messenger-widget{right:74px;bottom:calc(84px + env(safe-area-inset-bottom));z-index:136}
  .messenger-widget__button{width:52px;height:52px}
  .messenger-widget__button svg{width:26px;height:26px}
  .messenger-widget__link{min-width:150px;padding:9px 11px;border-radius:12px;font-size:14px}
  .messenger-widget__icon{width:31px;height:31px;font-size:10px}
}

body.modal-open .messenger-widget{display:none}

/* CHAT WIDGET DISABLED */
.messenger-widget, .messenger-widget__button, .messenger-widget__panel { display: none !important; visibility: hidden !important; pointer-events: none !important; }
