:root{
  --blue:#1f6fff;
  --blue-600:#0e56d3;
  --text:#0b1b2b;
  --muted:#5b6b7c;
  --bg-top:#f7fbff;
  --bg-bottom:#e9f1ff;
  --card:#ffffffcc;
  --shadow:0 6px 18px rgba(0,0,0,.07);
  --radius:18px;
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Arial, sans-serif;
  color:var(--text);
  background: linear-gradient(180deg, var(--bg-top), var(--bg-bottom));
}

.container{
  width:100%;
  max-width:1100px;
  margin:0 auto;
  padding:0 16px;
}

.topbar{
  background: var(--blue);
  color:#fff;
  position:sticky;
  top:0; z-index:1000;
  box-shadow: var(--shadow);
}

.topbar .nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 0;
}

.topbar .brand{font-weight:700; letter-spacing:.2px}
.topbar nav a{
  color:#fff; text-decoration:none; margin-left:16px; font-weight:600;
}
.topbar nav a:hover{ text-decoration:underline }

.hero{
  padding:48px 0 16px 0;
}
.hero h1{ margin:0 0 8px 0; font-size:clamp(22px,4vw,34px)}
.hero .meta{ color:var(--muted) }
.cta{ margin-top:16px; display:flex; gap:12px; flex-wrap:wrap }
.btn{
  display:inline-block; padding:10px 16px; border-radius:999px;
  border:2px solid var(--blue); color:var(--blue); text-decoration:none; font-weight:700;
}
.btn.primary{ background:var(--blue); color:#fff; border-color:var(--blue-600) }
.btn:hover{ filter:brightness(1.05) }

.card{
  background:var(--card);
  backdrop-filter: blur(3px);
  box-shadow:var(--shadow);
  border-radius:var(--radius);
  padding:20px;
  margin:18px 0;
}

.bullets{ padding-left:18px }
.bullets li{ margin:6px 0 }

.price-list{ font-size:16px }
.price-row{
  display:grid; grid-template-columns: auto 1fr auto; align-items:center;
  gap:10px; padding:6px 0; border-bottom:1px dashed #cfd8e3;
}
.price-row .name{ font-weight:600 }
.price-row .dots{ border-bottom:1px dotted #b6c2d1; height:1px }
.price-row .price{ font-weight:800 }

.news{ list-style:none; padding:0; margin:0 }
.news li{ padding:10px 0; border-bottom:1px dashed #cfd8e3 }
.news-date{ color:var(--muted); font-size:14px }
.news-title{ font-weight:700 }

/* Галерея: показываем ВСЁ изображение без обрезки */
.slider{
  position:relative;
  overflow:hidden;
  border-radius:var(--radius);
  /* Управляем «окном» через соотношение сторон: на мобиле выше, на десктопе шире */
  --ratio: 4/3;
}
@media (min-width: 768px){
  .slider{ --ratio: 16/9; }
}
/* Резервируем высоту слайдера по соотношению сторон, без скачков при загрузке */
.slider::before{
  content:"";
  display:block;
  width:100%;
  padding-top: calc(100% / (var(--ratio)));
}

/* Трек растягиваем на всё «окно» */
.track{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;      /* центр по вертикали */
  transition:transform .35s ease;
}

/* Каждый слайд — ровно ширина «окна», контент по центру */
.slide{
  min-width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;         /* мягкая подложка под «письма» */
}

/* Ключевое: вписываем изображение целиком, без обрезки */
.slide img{
  max-width:100%;
  max-height:100%;
  width:auto;
  height:auto;
  object-fit: contain;     /* Никакого кропа */
  display:block;
}

/* Кнопки оставляем как были, можно чуть приподнять на мобиле при высоких фото */
.slide-btn{
  position:absolute; top:50%; transform:translateY(-50%);
  background:#ffffffd9; border:none; width:40px; height:40px; border-radius:50%;
  box-shadow:var(--shadow); font-size:22px; cursor:pointer;
}
.slide-btn.prev{ left:12px }
.slide-btn.next{ right:12px }


.hint{ color:var(--muted); font-size:14px; margin-top:6px }

.fab{
  position:fixed; right:14px; bottom:14px; display:flex; flex-direction:column; gap:10px; z-index:1100;
}
.fab-btn{
  width:52px; height:52px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  background:var(--blue); color:#fff; text-decoration:none; font-weight:800; box-shadow:var(--shadow);
}

.footer{ padding:24px 0; color:var(--muted) }
