/* =========================
   Loader + Modal (UX)
   ========================= */

.ux-overlay{
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: grid;
  place-items: center;
  background:
    radial-gradient(900px 600px at 55% 20%, rgba(24,199,165,.14), transparent 60%),
    rgba(7,8,11,.72);
  backdrop-filter: blur(10px);
}
.ux-overlay.is-hidden{ display:none; }

.ux-loader{
  width: min(520px, 92%);
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(10,12,18,.72);
  box-shadow: 0 22px 60px rgba(0,0,0,.55);
  padding: 18px 18px 16px;
  text-align: center;
  transform: translateY(6px);
  animation: uxPop .25s ease forwards;
}
@keyframes uxPop{
  to{ transform: translateY(0); }
}

.ux-loader__ring{
  width: 52px;
  height: 52px;
  border-radius: 999px;
  border: 2px solid rgba(255,255,255,.12);
  border-top-color: rgba(24,199,165,.9);
  margin: 6px auto 10px;
  animation: uxSpin .9s linear infinite;
}
@keyframes uxSpin{
  to{ transform: rotate(360deg); }
}

.ux-loader__title{
  font-weight: 900;
  font-size: 15px;
  letter-spacing: .2px;
}
.ux-loader__sub{
  margin-top: 6px;
  color: rgba(255,255,255,.65);
  font-size: 13px;
  line-height: 1.6;
}

/* =========================
   ✅ Mobile scroll lock helpers
   ========================= */
body.ux-lock{
  overflow: hidden;              /* Android/desktop */
  height: 100%;
  touch-action: none;            /* important for mobile */
}
body.ux-lock-fixed{
  position: fixed;               /* iOS fix */
  left: 0;
  right: 0;
  width: 100%;
}

/* Modal wrapper */
.ux-modal{
  position: fixed;
  inset: 0;
  z-index: 1300;
  display: grid;
  place-items: center;
  overflow: hidden;              /* ✅ не даём модалке прокидывать скролл в body */
}
.ux-modal.is-hidden{ display:none; }

.ux-modal__backdrop{
  position:absolute;
  inset:0;
  background: rgba(7,8,11,.68);
  backdrop-filter: blur(10px);
  animation: uxFade .25s ease forwards;
}
@keyframes uxFade{
  from{ opacity: 0; }
  to{ opacity: 1; }
}

.ux-modal__card{
  position: relative;
  width: min(860px, 92%);
  border-radius: 26px;
  border: 1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(820px 520px at 220px 120px, rgba(24,199,165,.10), transparent 62%),
    rgba(10,12,18,.86);
  backdrop-filter: blur(14px);
  box-shadow: 0 22px 70px rgba(0,0,0,.60);
  padding: 18px 18px 16px;
  animation: uxSlide .28s cubic-bezier(.2,.9,.2,1) forwards;
  transform: translateY(14px) scale(.985);
  opacity: 0;

  /* ✅ главное: скролл внутри карточки */
  max-height: calc(100dvh - 32px);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
@keyframes uxSlide{
  to{
    transform: translateY(0) scale(1);
    opacity: 1;
  }
}

/* Чтобы на iOS не "резиновало" фон через overscroll */
.ux-modal__card{
  overscroll-behavior: contain;
}

.ux-modal__close{
  position:absolute;
  top: 12px;
  right: 12px;
  width: 40px;
  height: 40px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.9);
  display:grid;
  place-items:center;
  cursor:pointer;
  z-index: 2;
}
.ux-modal__close:hover{ background: rgba(255,255,255,.07); }

.ux-modal__head{
  padding: 6px 44px 12px 6px;
  border-bottom: 1px solid rgba(255,255,255,.10);
  margin-bottom: 14px;
}
.ux-modal__kicker{
  font-size: 12px;
  letter-spacing: .22em;
  font-weight: 900;
  color: rgba(24,199,165,.85);
  margin-bottom: 8px;
}
.ux-modal__title{
  font-weight: 900;
  font-size: 18px;
  letter-spacing: -.2px;
}
.ux-modal__note{
  margin-top: 6px;
  color: rgba(255,255,255,.65);
  font-size: 13px;
  line-height: 1.6;
}

.ux-form .field__control{
  background: rgba(255,255,255,.03);
}
.ux-form textarea.field__input{
  resize: vertical;
  min-height: 88px;
}

/* "locked" fields look */
.ux-form input[readonly]{
  opacity: .92;
  cursor: not-allowed;
}
.ux-form input[readonly]::placeholder{ opacity: .55; }

.ux-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  align-items:end;
}
.ux-grid--2{
  grid-template-columns: repeat(2, 1fr);
  margin-top: 10px;
}

.ux-actions{
  margin-top: 14px;
  display:flex;
  gap: 10px;
  justify-content:flex-end;
  flex-wrap: wrap;
}

.btn.btn--ghost{
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.88);
  padding: 12px 16px;
  font-weight: 800;
}
.btn.btn--ghost:hover{ background: rgba(255,255,255,.07); }

.ux-legal{
  margin-top: 10px;
  color: rgba(255,255,255,.55);
  font-size: 12px;
  line-height: 1.5;
}

/* Responsive */
@media (max-width: 980px){
  .ux-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px){
  .ux-grid, .ux-grid--2{ grid-template-columns: 1fr; }
  .ux-actions{ justify-content: stretch; }
  .ux-actions .btn{ width: 100%; }

  /* ✅ на мобиле чуть больше места под скролл */
  .ux-modal__card{
    width: min(860px, 94%);
    max-height: calc(100dvh - 18px);
  }
}


/* =========================
   Success modal
   ========================= */
.ux-modal__card--success{
  width: min(640px, 92%);
  padding: 22px 18px 18px;
}

.ux-success{
  text-align: center;
  padding: 6px 10px 6px;
}

.ux-success__icon{
  width: 62px;
  height: 62px;
  border-radius: 20px;
  border: 1px solid rgba(24,199,165,.35);
  background: rgba(24,199,165,.12);
  display:grid;
  place-items:center;
  margin: 6px auto 12px;
  box-shadow: 0 18px 50px rgba(0,0,0,.35);
}
.ux-success__icon i{
  font-size: 34px;
  color: rgba(24,199,165, .95);
}

.ux-success__title{
  font-weight: 950;
  font-size: 20px;
  letter-spacing: -.2px;
  margin-top: 6px;
}

.ux-success__text{
  margin-top: 8px;
  color: rgba(255,255,255,.68);
  font-size: 13px;
  line-height: 1.7;
}

.ux-success__summary{
  margin: 14px auto 0;
  text-align:left;
  width: min(520px, 100%);
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  padding: 12px 12px;
  color: rgba(255,255,255,.80);
  font-size: 13px;
  line-height: 1.6;
}

.ux-success__row{
  display:flex;
  gap: 10px;
  justify-content:space-between;
  border-bottom: 1px solid rgba(255,255,255,.08);
  padding: 8px 2px;
}
.ux-success__row:last-child{ border-bottom: 0; }
.ux-success__key{ color: rgba(255,255,255,.60); }
.ux-success__val{ font-weight: 800; }

.ux-actions--center{
  justify-content: center;
}



/* =========================
   LuxTransfer — index.css
   ========================= */

/* ===== Hero ===== */
.hero{
  position: relative;
  min-height: 720px;
  padding-bottom: 50px;
}
.hero__bg{
  position:absolute; inset:0;
  background:
    radial-gradient(800px 500px at 30% 35%, rgba(0,0,0,.15), rgba(0,0,0,.55)),
    linear-gradient(180deg, rgba(7,8,11,.35), rgba(7,8,11,.95)),
    url("/static/images/hero.jpg");
  background-size: cover;
  background-position: center;
  filter: saturate(.95) contrast(1.05);
}
.hero__overlay{
  position:absolute; inset:0;
  background: radial-gradient(900px 600px at 55% 20%, rgba(24,199,165,.18), transparent 60%);
  pointer-events:none;
}
.hero__inner{ position:relative; z-index: 2; }

.hero__content{ max-width: 720px; padding-top: 44px; }
.hero__kicker{
  font-size: 18px;
  letter-spacing: .3px;
  color: rgba(255,255,255,.86);
  margin-bottom: 10px;
}
.hero__title{
  margin: 0;
  font-size: clamp(44px, 6vw, 72px);
  line-height: 1.02;
  letter-spacing: -.8px;
}
.hero__script{
  font-family: "Playfair Display", serif;
  font-style: italic;
  font-weight: 500;
  color: rgba(255,255,255,.95);
}
.hero__subtitle{
  margin: 14px 0 0;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.7;
  max-width: 680px;
}

/* ===== Booking card ===== */
.booking{ margin-top: 26px; }

.booking__tabs{
  display:flex;
  gap: 10px;
  padding: 12px 0;
}
.tab{
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.86);
  padding: 10px 12px;
  border-radius: 14px;
  cursor:pointer;
  font-weight: 700;
  font-size: 13px;
}
.tab.is-active{
  background: rgba(24,199,165,.14);
  border-color: rgba(24,199,165,.40);
  color: #dffaf4;
}

.booking__form{ padding: 12px 0; }
.grid{
  display:grid;
  grid-template-columns: 1.2fr 1.2fr .8fr .8fr auto;
  gap: 10px;
  align-items: end;
}

.field{ display:block; }
.field__label{
  display:block;
  font-size: 12px;
  color: rgba(255,255,255,.70);
  margin: 0 0 6px 2px;
}
.field__control{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
}
.field__icon{ opacity:.8; font-size: 14px; }
.field__input{
  width:100%;
  border:0;
  outline:0;
  background: transparent;
  color: #fff;
  font-size: 14px;
}
.field__input::placeholder{ color: rgba(255,255,255,.50); }
.field--hours.is-hidden{ display:none; }

.booking__submit{
  height: 48px;
  border-radius: 14px;
  padding: 0 18px;
  font-weight: 800;
}

.booking__hint{
  margin-top: 10px;
  color: rgba(255,255,255,.62);
  font-size: 12px;
  padding: 0 2px 4px;
}

/* ===== Autocomplete dropdown (From/To) ===== */
.ac{
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 10px);
  z-index: 40;

  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(10,12,18,.92);
  backdrop-filter: blur(14px);
  box-shadow: 0 22px 60px rgba(0,0,0,.55);

  padding: 8px;
  display: none;
}
.ac.is-open{ display:block; }
.ac[aria-hidden="true"]{ display:none; }

.ac__list{
  max-height: 260px;
  overflow: auto;
  padding-right: 4px;
}
.ac__list::-webkit-scrollbar{ width: 8px; }
.ac__list::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,.12);
  border-radius: 999px;
}
.ac__list::-webkit-scrollbar-track{
  background: rgba(255,255,255,.04);
  border-radius: 999px;
}

.ac__item{
  width: 100%;
  text-align:left;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.86);
  cursor:pointer;

  font-weight: 800;
  font-size: 13px;
  margin-bottom: 8px;
}
.ac__item:hover{ background: rgba(255,255,255,.06); }
.ac__item.is-muted{
  opacity: .6;
  cursor: default;
  border-style: dashed;
}






/* =========================
   Partnership — красивый выбор "частное лицо / компания"
   (в стиле field__control + select)
   ========================= */

.field__control--chips{
  display:flex;
  align-items:center;
  gap: 12px;
}

/* контейнер "кнопок" */
.chips{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* chip */
.chip{
  position: relative;
  cursor: pointer;
  user-select:none;
}

.chip {
    text-decoration: none;
    font-size: 13px;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, .04);
    color: rgba(255, 255, 255, .85);
}

/* скрываем настоящий radio */
.chip input{
  position:absolute;
  inset:0;
  opacity:0;
  cursor:pointer;
}

/* визуал */
.chip span{
  display:block;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.85);
  font-weight: 800;
  font-size: 13px;
  letter-spacing: .2px;
  transition: transform .15s ease, background .15s ease, border-color .15s ease, box-shadow .15s ease;
}

/* hover */
.chip:hover span{
  background: rgba(255,255,255,.07);
}

/* selected */
.chip input:checked + span{
  border-color: rgba(24,199,165,.45);
  background: rgba(24,199,165,.14);
  color: #dffaf4;
  box-shadow: 0 0 0 2px rgba(24,199,165,.10);
}

/* keyboard focus */
.chip input:focus-visible + span{
  outline: 2px solid rgba(24,199,165,.35);
  outline-offset: 2px;
}

/* small screens: чтобы не "жало" */
@media (max-width: 520px){
  .chips{ gap: 8px; }
  .chip span{ padding: 10px 12px; }
}







/* ===== Features ===== */
.features{
  margin-top: 20px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 45px;
}
.feature{ text-align: center; }
.feature__icon{
  width: 50px;
  height: 50px;
  border-radius: 16px;
  border: 1px solid rgba(24,199,165,.28);
  background: rgba(24,199,165,.10);
  display:grid;
  place-items:center;
  margin: 30px auto;
  margin-bottom: 15px;
}
.feature__icon i{
  color: rgba(24,199,165, 1);
  font-size: 28px;
}
.feature__title{ font-weight: 800; font-size: 14px; }
.feature__text{
  color: rgba(255,255,255,.70);
  font-size: 13px;
  line-height: 1.6;
  margin-top: 6px;
}

/* ===== Sections + fixed smoke ===== */
.section{
  position: relative;
  isolation: isolate;
  padding: 64px 0;
  background: transparent;
  overflow: hidden;
}
.section::before{
  content:"";
  position:absolute;
  inset: 0;
  pointer-events:none;
  z-index: 0;
  background:
    radial-gradient(820px 520px at 220px 120px, rgba(24,199,165,.11), transparent 62%),
    radial-gradient(720px 460px at calc(100% - 260px) 260px, rgba(24,199,165,.08), transparent 60%);
  filter: blur(10px);
  opacity: .95;
}
.section > .container{
  position: relative;
  z-index: 1;
}

.section--muted{
  background: rgba(255,255,255,.02);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.section--muted::before{ opacity: .75; }

.section__head{ margin-bottom: 40px; }
.section__title{ margin:0; font-size: clamp(25px, 4.4vw, 30px);; letter-spacing: -.4px; }
.section__subtitle{ margin: 8px 0 0; color: var(--muted); line-height: 1.7; }

.cards{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.card{
  text-decoration:none;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  padding: 16px;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.card:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,.06);
  border-color: rgba(24,199,165,.25);
}
.card__title{ font-weight: 800; }
.card__meta{ margin-top: 6px; color: rgba(255,255,255,.65); font-size: 13px; }

.split{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 16px;
  align-items: start;
}

.bullets{ margin-top: 16px; display:grid; gap: 10px; }
.bullet{ color: rgba(255,255,255,.80); display:flex; gap: 10px; align-items:flex-start; }
.bullet__dot{
  width: 10px; height: 10px;
  border-radius: 999px;
  background: rgba(24,199,165,.9);
  margin-top: 6px;
  flex: 0 0 auto;
}

.panel{
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(10,12,18,.55);
  padding: 18px;
  box-shadow: var(--shadow);
}
.panel__title{ font-weight: 900; font-size: 16px; }
.panel__text{ color: rgba(255,255,255,.70); line-height: 1.6; margin: 10px 0 14px; }

/* ===== Modern Date/Time Picker ===== */
.field { position: relative; }
.field__control--click{ cursor: pointer; }
.field__control--click:focus-within{
  border-color: rgba(24,199,165,.35);
  box-shadow: 0 0 0 4px rgba(24,199,165,.10);
}

.dt{
  position: absolute;
  left: 0;
  top: calc(100% + 10px);
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(10,12,18,.92);
  backdrop-filter: blur(14px);
  box-shadow: 0 22px 60px rgba(0,0,0,.55);
  padding: 12px;
  z-index: 30;
  display: none;
}
.dt.is-open{ display: block; }

.dt__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 8px;
  padding: 4px 2px 10px;
}
.dt__head--time{
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(255,255,255,.10);
  margin-bottom: 10px;
}
.dt__title{
  font-weight: 900;
  letter-spacing: .2px;
  font-size: 14px;
  color: rgba(255,255,255,.92);
}

.dt__nav{
  width: 36px;
  height: 36px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.9);
  cursor: pointer;
}
.dt__nav:hover{ background: rgba(255,255,255,.07); }

.dt__close{
  width: 34px;
  height: 34px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.85);
  cursor: pointer;
}
.dt__close:hover{ background: rgba(255,255,255,.07); }

.dt__quick{
  display:flex;
  gap: 8px;
  padding: 0 2px 10px;
}
.dt__pill{
  border: 1px solid rgba(24,199,165,.30);
  background: rgba(24,199,165,.10);
  color: rgba(223,250,244,.95);
  padding: 8px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}
.dt__pill:hover{ background: rgba(24,199,165,.14); }

.dt__dow{
  display:grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  padding: 0 2px 8px;
  color: rgba(255,255,255,.58);
  font-size: 11px;
  text-align:center;
}
.dt__grid{
  display:grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  padding: 0 2px 2px;
}

.day{
  height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.86);
  cursor: pointer;
  font-weight: 800;
  font-size: 12px;
}
.day:hover{ background: rgba(255,255,255,.06); }
.day.is-muted{ opacity: .35; }
.day.is-disabled{ opacity: .25; cursor: not-allowed; }
.day.is-selected{
  border-color: rgba(24,199,165,.45);
  background: rgba(24,199,165,.14);
  color: #dffaf4;
}
.day.is-today{
  outline: 2px solid rgba(24,199,165,.25);
  outline-offset: 1px;
}

.time__meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  padding: 0 2px 10px;
}
.time__hint{ font-size: 12px; color: rgba(255,255,255,.62); }
.time__list{
  max-height: 260px;
  overflow: auto;
  padding-right: 4px;
}
.time__list::-webkit-scrollbar{ width: 8px; }
.time__list::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,.12);
  border-radius: 999px;
}
.time__list::-webkit-scrollbar-track{
  background: rgba(255,255,255,.04);
  border-radius: 999px;
}

.timebtn{
  width: 100%;
  text-align:left;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.86);
  cursor:pointer;
  font-weight: 800;
  font-size: 13px;
  margin-bottom: 8px;
}
.timebtn:hover{ background: rgba(255,255,255,.06); }
.timebtn.is-selected{
  border-color: rgba(24,199,165,.45);
  background: rgba(24,199,165,.14);
  color: #dffaf4;
}

/* ===== Generic helper ===== */
.is-hidden{ display:none !important; }

/* ===== Hourly layout ===== */
.booking.is-hourly .field--to{ display:none !important; }
.booking.is-hourly .grid{ grid-template-columns: 1.4fr .85fr .85fr .75fr auto; }

/* ===== Hours stepper ===== */
.hours{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  padding: 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
}
.hours__btn{
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.92);
  cursor:pointer;
  font-weight: 900;
  font-size: 18px;
}
.hours__btn:hover{ background: rgba(255,255,255,.07); }
.hours__btn:active{ transform: translateY(1px); }

.hours__core{
  flex: 1 1 auto;
  display:flex;
  align-items:center;
  gap: 10px;
  border-radius: 6px;
  justify-content:center;
}
.hours__input{
  border: 0;
  outline: 0;
  background: transparent;
  color: #fff;
  font-weight: 700;
  font-size: 16px;
  text-align:center;
  appearance: textfield;
}
.hours__input::-webkit-outer-spin-button,
.hours__input::-webkit-inner-spin-button{
  -webkit-appearance: none;
  margin: 0;
}

/* ===== Responsive ===== */
@media (max-width: 980px){
  .booking.is-hourly .grid{ grid-template-columns: 1fr 1fr 1fr 1fr; }
  .features{ gap: 0px; }
  .feature{ margin-bottom: 30px; }

  .grid{ grid-template-columns: 1fr 1fr 1fr 1fr; }
  .booking__submit{ grid-column: 1 / -1; }
  .cards{ grid-template-columns: repeat(2, 1fr); }
  .features{ grid-template-columns: 1fr; }
  .split{ grid-template-columns: 1fr; }

  .section::before{
    background:
      radial-gradient(700px 460px at 180px 110px, rgba(24,199,165,.10), transparent 62%),
      radial-gradient(620px 420px at calc(100% - 210px) 240px, rgba(24,199,165,.07), transparent 60%);
    filter: blur(12px);
  }
}
@media (max-width: 520px){
  .booking.is-hourly .grid{ grid-template-columns: 1fr; }
  .dt{ width: 100%; }
  .grid{ grid-template-columns: 1fr; }
  .hero{ min-height: 780px; }

  .section::before{
    background:
      radial-gradient(560px 380px at 140px 120px, rgba(24,199,165,.09), transparent 62%),
      radial-gradient(520px 360px at calc(100% - 160px) 220px, rgba(24,199,165,.06), transparent 60%);

  }
}




/* =========================
   Signature Service
   ========================= */
.signature{
  width: min(1160px, 92%);
}

.signature__head{
  text-align: center;
  margin-bottom: 18px;
}

.signature__subtitle{
  max-width: 860px;
  margin-left: auto;
  margin-right: auto;
}

.signature__grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 16px;
  align-items: start;
  margin-top: 40px;
}

/* Cards */
.signature__cards{
  display:grid;
  gap: 16px;
}

.sigcard{
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(520px 320px at 120px 90px, rgba(24,199,165,.09), transparent 60%),
    rgba(10,12,18,.55);
  box-shadow: 0 22px 60px rgba(0,0,0,.45);
  padding: 16px 16px 14px;
}

.sigcard__icon{
  width: 44px;
  height: 44px;
  border-radius: 16px;
  border: 1px solid rgba(24,199,165,.28);
  background: rgba(24,199,165,.10);
  display:grid;
  place-items:center;
  margin-bottom: 12px;
}
.sigcard__icon i{
  font-size: 20px;
  color: rgba(24,199,165,.95);
}

.sigcard__title{
  font-weight: 950;
  letter-spacing: -.2px;
  font-size: 15px;
}
.sigcard__text{
  margin-top: 8px;
  color: rgba(255,255,255,.70);
  line-height: 1.7;
  font-size: 13px;
}

/* Right panel */
.signature__panel{
  border-radius: 26px;
  border: 1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(820px 520px at 260px 120px, rgba(24,199,165,.10), transparent 62%),
    rgba(10,12,18,.72);
  box-shadow: 0 22px 70px rgba(0,0,0,.55);
  padding: 18px;
}

.signature__panelTitle{
  font-weight: 950;
  font-size: 16px;
  letter-spacing: -.2px;
}
.signature__panelText{
  margin-top: 10px;
  color: rgba(255,255,255,.70);
  line-height: 1.7;
  font-size: 13px;
}
.signature__panelText b{ color: rgba(255,255,255,.92); }

.signature__steps{
  margin-top: 14px;
  display:grid;
  gap: 10px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.10);
}

.sigstep{
  display:flex;
  gap: 12px;
  align-items:flex-start;
  padding: 10px 10px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}
.sigstep__num{
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  border: 1px solid rgba(24,199,165,.28);
  background: rgba(24,199,165,.08);
  color: rgba(223,250,244,.95);
  font-weight: 950;
  letter-spacing: .08em;
  font-size: 12px;
  flex: 0 0 auto;
}
.sigstep__title{
  font-weight: 900;
  font-size: 13px;
}
.sigstep__text{
  margin-top: 6px;
  color: rgba(255,255,255,.68);
  font-size: 13px;
  line-height: 1.6;
}

.signature__stats{
  margin-top: 12px;
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.sigstat{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  padding: 12px 12px 10px;
}
.sigstat__val{
  font-weight: 950;
  font-size: 18px;
  letter-spacing: -.2px;
}
.sigstat__key{
  margin-top: 4px;
  color: rgba(255,255,255,.62);
  font-size: 12px;
  line-height: 1.4;
}

.signature__cta{
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.10);
}
.signature__btn{
  display:inline-flex;
  width: 100%;
  justify-content:center;
}
.signature__note{
  margin-top: 10px;
  color: rgba(255,255,255,.58);
  font-size: 12px;
  line-height: 1.6;
}

/* Responsive */
@media (max-width: 980px){
  .signature__grid{ grid-template-columns: 1fr; }
  .signature__panel{ padding: 16px; }
}

@media (max-width: 520px){
  .signature__stats{ grid-template-columns: 1fr; }
  .sigstep{ padding: 10px; }
}





/* =========================
   ===== Fleet Slider =====
   ========================= */
.section--cars .container { width: 100%; }

.section__head--center{
  text-align:center;
  width: min(1160px, 92%);
  margin: 0 auto;
}
.section__eyebrow{
  font-size: 12px;
  letter-spacing: .22em;
  font-weight: 900;
  color: rgba(24,199,165,.85);
  margin-bottom: 8px;
}
.section__title--xl{
  font-size: clamp(30px, 4.4vw, 45px);
  letter-spacing: -1px;
}
.section__subtitle--center{ max-width: 800px; margin-left:auto; margin-right:auto; }

.fleet{
  position: relative;
  margin-top: 40px;
  padding: 10px 0 0;
}

.fleet__viewport{
  overflow: hidden;
  border-radius: 26px;
  padding: 25px 0;
  cursor: grab;
  user-select: none;
  -webkit-user-select: none;
  touch-action: pan-y;
}
.fleet__viewport:active{ cursor: grabbing; }

.fleet__track{
  display: flex;
  align-items: stretch;
  gap: 18px;
  will-change: transform;
  transition: transform .55s cubic-bezier(.2,.9,.2,1);
  padding: 0 140px;
}

.fleet__slide{
  flex: 0 0 56%;
  border-radius: 26px;
  position: relative;
  overflow: hidden;
  transform: scale(.90);
  opacity: .55;
  filter: saturate(.95);
  transition: transform .55s cubic-bezier(.2,.9,.2,1),
              opacity .55s cubic-bezier(.2,.9,.2,1),
              filter .55s cubic-bezier(.2,.9,.2,1);
}

.fleet__media{
  position: relative;
  height: 300px;
  display:flex;
  align-items:center;
  justify-content:center;
}

/* ✅ запрет “таскания” картинки */
.fleet__img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  transform: translateY(6px);

  pointer-events: none;         /* чтобы pointer events шли на viewport */
  user-select: none;
  -webkit-user-select: none;
  -webkit-user-drag: none;      /* Safari */
  -khtml-user-drag: none;
  -moz-user-drag: none;
  -o-user-drag: none;
}

/* ✅ 2) Скрываем ВСЁ под фото у неактивных */
.fleet__meta{
  position: relative;
  padding: 14px 20px 18px;
  text-align:center;

  display: none;
  opacity: 0;
}

.fleet__slide.is-active .fleet__meta{
  display: block;
  opacity: 1;
}

.fleet__name{
  font-weight: 900;
  font-size: 26px;
  letter-spacing: -.4px;
}

.fleet__desc{
  margin-top: 6px;
  color: rgba(255,255,255,.72);
  font-size: 14px;
}

.fleet__icons{
  margin-top: 10px;
  display:flex;
  gap: 18px;
  justify-content:center;
  flex-wrap: wrap;
  color: rgba(255,255,255,.70);
}
.fleet__cap{
  display:flex;
  align-items:center;
  gap: 8px;
  font-weight: 800;
  font-size: 13px;
}
.fleet__cap i{ color: rgba(255,255,255,.72); }

.fleet__slide.is-active{
  transform: scale(1);
  opacity: 1;
  filter: saturate(1.02);
  border-color: rgba(24,199,165,.22);
}
.fleet__slide.is-prev,
.fleet__slide.is-next{
  transform: scale(.90);
  opacity: .55;
}

.fleet__nav{
  position:absolute;
  top: 10%;
  transform: translateY(-65%);
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.06);
  display:grid;
  place-items:center;
  color: rgba(255,255,255,.92);
  cursor:pointer;
  z-index: 5;
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}
.fleet__nav:hover{
  background: rgba(255,255,255,.08);
  border-color: rgba(24,199,165,.22);
  transform: translateY(-65%) scale(1.03);
}
.fleet__nav:active{ transform: translateY(-65%) scale(.98); }

.fleet__nav--prev{ left: 18px; }
.fleet__nav--next{ right: 18px; }

.fleet__dots{
  margin-top: 10px;
  display:flex;
  justify-content:center;
  gap: 8px;
}
.fleet__dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  cursor:pointer;
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}
.fleet__dot:hover{ transform: scale(1.08); }
.fleet__dot.is-active{
  background: rgba(24,199,165,.75);
  border-color: rgba(24,199,165,.55);
}

/* Tablet */
@media (max-width: 1100px){
  .fleet__track{ padding: 0 90px; }
  .fleet__slide{ flex-basis: 64%; }
}

/* Mobile */
@media (max-width: 760px){
  .fleet__track{
    padding: 0 0;
    gap: 12px;
  }
  .fleet__slide{
    flex: 0 0 100%;
    transform: scale(1);
    opacity: 1;
  }
  .fleet__slide.is-prev,
  .fleet__slide.is-next{ opacity: 1; transform: scale(1); }

  .fleet__nav--prev{ left: 10px; }
  .fleet__nav--next{ right: 10px; }

  .fleet__name{ font-size: 22px; }
}

@media (max-width: 450px){
  .fleet__media{ height: 240px; }
}








/* =========================
   Partners
   ========================= */
.partners{
  width: min(1160px, 92%);
}

.partners__head{
  text-align: center;
  margin-bottom: 18px;
}

.partners__subtitle{
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

.partners__grid{
  margin-top: 40px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.partner{
  text-decoration: none;
  display: grid;
  place-items: center;
  height: 120px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(620px 360px at 140px 100px, rgba(24,199,165,.08), transparent 60%),
    rgba(10,12,18,.55);
  box-shadow: 0 22px 60px rgba(0,0,0,.40);
  transition: transform .15s ease, border-color .15s ease, background .15s ease;
  overflow: hidden;
}

.partner:hover{
  transform: translateY(-2px);
  border-color: rgba(24,199,165,.28);
  background:
    radial-gradient(620px 360px at 140px 100px, rgba(24,199,165,.12), transparent 60%),
    rgba(10,12,18,.62);
}

.partner__logo{
  width: 78%;
  max-width: 220px;
  max-height: 90px;
  object-fit: contain;

  /* default: серый */
  opacity: .78;
  filter: grayscale(1) brightness(1.25) contrast(1.05);
  transition: filter .18s ease, opacity .18s ease, transform .18s ease;
}

.partner:hover .partner__logo{
  filter: grayscale(0);
  opacity: 1;
  transform: translateY(-1px);
}

/* Если логотип — SVG с currentColor, он может краситься точно */
.partner svg{
  width: 78%;
  max-width: 220px;
  max-height: 90px;
  color: rgba(255,255,255,.55);
  transition: color .18s ease, transform .18s ease;
}


.partners__note{
  margin-top: 14px;
  text-align: center;
  color: rgba(255,255,255,.60);
  font-size: 12px;
  line-height: 1.6;
}

.partners__link{
  color: rgba(24,199,165, .92);
  text-decoration: none;
  font-weight: 900;
  border-bottom: 1px dashed rgba(24,199,165, .38);
}
.partners__link:hover{
  border-bottom-color: rgba(24,199,165, .75);
}

/* 2x2 */
@media (max-width: 980px){
  .partners__grid{
    grid-template-columns: repeat(2, 1fr);
  }
}

/* 1x4 */
@media (max-width: 520px){
  .partners__grid{
    grid-template-columns: 1fr;
  }

}





/* =========================
   FAQ
   ========================= */
.faq{
  width: min(1160px, 92%);
}

.faq__head{

  margin-bottom:40px;
}

.faq__subtitle{
  max-width: 650px;

}

.faq__search{
  margin: 26px auto 0;
  width: min(720px, 100%);
  position: relative;

  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(520px 320px at 140px 90px, rgba(24,199,165,.08), transparent 60%),
    rgba(10,12,18,.55);


  padding: 12px 14px;
  display:flex;
  align-items:center;
  gap: 10px;
}

.faq__searchIcon{
  opacity: .85;
  color: rgba(255,255,255,.88);
  font-size: 14px;
  padding-left: 2px;
}

.faq__searchInput{
  flex: 1 1 auto;
  border: 0;
  outline: 0;
  background: transparent;
  color: #fff;
  font-size: 14px;
  padding: 4px 2px;
}
.faq__searchInput::placeholder{ color: rgba(255,255,255,.50); }

.faq__searchClear{
  width: 38px;
  height: 38px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.88);
  cursor: pointer;
  display:grid;
  place-items:center;
}
.faq__searchClear:hover{ background: rgba(255,255,255,.07); }

.faq__grid{
  margin-top: 18px;
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  align-items: start;
}

.faq__col{
  display:grid;
  gap: 16px;
}

.faq__item{
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(620px 360px at 140px 100px, rgba(24,199,165,.08), transparent 60%),
    rgba(10,12,18,.55);
  box-shadow: 0 22px 60px rgba(0,0,0,.35);
  overflow: hidden;
}

.faq__q{
  list-style: none;
  cursor: pointer;
  padding: 14px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}

.faq__q::-webkit-details-marker{ display:none; }

.faq__qText{
  font-weight: 950;
  letter-spacing: -.2px;
  font-size: 14px;
  color: rgba(255,255,255,.92);
}

.faq__chev{
  width: 38px;
  height: 38px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  display:grid;
  place-items:center;
  color: rgba(255,255,255,.88);
  flex: 0 0 auto;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}

.faq__item[open] .faq__chev{
  transform: rotate(180deg);
  background: rgba(24,199,165,.14);
  border-color: rgba(24,199,165,.35);
  color: #dffaf4;
}

.faq__a{
  padding: 0 16px 14px;
  color: rgba(255,255,255,.70);
  font-size: 13px;
  line-height: 1.7;
  border-top: 1px solid rgba(255,255,255,.10);
  margin-top: 2px;
  padding-top: 12px;
}

.faq__a b{ color: rgba(255,255,255,.92); }

.faq__item:hover{
  border-color: rgba(24,199,165,.22);
  background:
    radial-gradient(620px 360px at 140px 100px, rgba(24,199,165,.12), transparent 60%),
    rgba(10,12,18,.62);
}

.faq__footer{
  margin-top: 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  flex-wrap: wrap;

  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  padding: 14px 14px;
}

.faq__note{
  color: rgba(255,255,255,.62);
  font-size: 12px;
  line-height: 1.6;
  max-width: 680px;
}

.faq__btn{
  border-radius: 16px;
  padding: 12px 16px;
  font-weight: 900;
}

/* hidden when filtered */
.faq__item.is-hidden{
  display: none !important;
}

/* Responsive */
@media (max-width: 980px){
  .faq__grid{ grid-template-columns: 1fr; }
  .faq__footer{ justify-content: stretch; }
  .faq__btn{ width: 100%; justify-content:center; display:inline-flex; }
}