:root{
  --bg:#f4f1ea; --text:#3b3b3b; --muted:#7a7a72; --olive:#b0b39a; --olive-dark:#9ea287;
  --white:#fff; --radius:14px; --shadow:0 8px 22px rgba(0,0,0,0.06);
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter, system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}
/* CONTAINER */
.container{max-width:1200px;margin:0 auto;padding:0 20px}

/* HEADER */
header{padding:26px 0;border-bottom:1px solid #e7e2d6;background:var(--bg)}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:14px}
.logo{height:56px}
.main-nav ul{display:flex;gap:28px;align-items:center;margin:0;padding:0;list-style:none}
.main-nav a{font-size:16px;opacity:0.95}

/* DROPDOWN */
.nav-item{position:relative}
.dropdown-menu{position:absolute;left:0;top:44px;width:280px;background:var(--olive);color:var(--white);border-radius:8px;padding:6px 0;box-shadow:var(--shadow);display:none;z-index:20}
.nav-item:hover .dropdown-menu{display:block}
.dropdown-menu a{display:block;padding:10px 18px;color:#fff}

/* CONTACTS */
.contacts{ text-align:right; font-weight:700 }
.contacts .email{font-weight:400;font-size:14px;color:var(--muted)}

/* HERO */
.hero{display:flex;gap:36px;align-items:center;padding:56px 0}
.hero-left{flex:1;max-width:640px}
.hero-small{font-family:'Caveat',cursive;font-size:34px;color:var(--muted);margin-bottom:-6px}
.hero-title{font-size:56px;line-height:1;margin:0 0 16px;font-weight:800;letter-spacing:1px;word-break:break-word}
.hero-desc{font-size:18px;color:var(--muted);max-width:560px}
.hero-cta{margin-top:24px;display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-block;padding:12px 24px;border-radius:40px;font-weight:700;border:2px solid var(--olive);background:var(--olive);color:var(--white);cursor:pointer}
.btn.outline{background:transparent;color:var(--text);border:2px solid rgba(58,58,58,0.08)}
.btn:hover{background:var(--olive-dark)}
.hero-right{width:460px}

/* FEATURES */
.features{display:flex;gap:18px;justify-content:space-between;margin-top:32px;flex-wrap:wrap}
.feature{flex:1 1 200px;text-align:center}
.feature img{width:64px;opacity:0.9}
.feature p{margin-top:10px;color:var(--muted)}

/* CATALOG GRID */
.catalog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
.card{background:var(--white);border-radius:12px;padding:14px;box-shadow:var(--shadow)}
.card img{width:100%;border-radius:10px}
.card h4{margin:10px 0 6px}
.small-muted{color:var(--muted);font-size:14px}

/* ROWS */
.services-row{display:flex;gap:16px;margin-top:16px;flex-wrap:wrap}
.app-row{display:flex;gap:20px;align-items:center;margin-top:28px;flex-wrap:wrap}
.app-row img{width:280px;border-radius:12px}

/* MODAL */
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,0.45);z-index:90}
.modal.open{display:flex}
.modal-box{width:760px;background:var(--white);border-radius:12px;padding:20px;box-shadow:0 20px 60px rgba(0,0,0,0.18)}
.modal-grid{display:grid;grid-template-columns:1fr 320px;gap:18px}
label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}
input,select,textarea{width:100%;padding:10px;border-radius:8px;border:1px solid #e6e1d7;margin-bottom:12px}
.consent{display:flex;gap:8px;align-items:center;font-size:13px}

/* FAQ */
.faq{margin-top:36px}
.faq details{background:#fff;padding:12px;border-radius:10px;margin-bottom:8px;box-shadow:var(--shadow)}
.faq summary{font-weight:700;cursor:pointer}

/* FOOTER */
footer{margin-top:40px;padding:28px 0;color:var(--muted);text-align:center}

/* ========== RESPONSIVE ========== */

/* Tablets (до 980px) */
@media(max-width:980px){
  .hero{flex-direction:column;text-align:center}
  .hero-right{width:100%;max-width:400px;margin:auto}
  .hero-title{font-size:42px}
  .catalog-grid{grid-template-columns:repeat(2,1fr)}
  .modal-box{width:92%}
  .modal-grid{grid-template-columns:1fr}
}

/* MOBILE (до 720px) — основной блок адаптации */
@media(max-width:720px){
  body{font-size:16px}

  /* HEADER */
  .header-row{flex-direction:column;align-items:flex-start}
  .contacts{text-align:left}

  /* HERO */
  .hero-title{font-size:34px}
  .hero-small{font-size:28px}
  .hero-desc{font-size:16px}

  /* GRID */
  .catalog-grid{grid-template-columns:1fr}

  /* FEATURES */
  .features{flex-direction:column}
  .feature img{width:52px}

  /* SERVICES */
  .services-row{flex-direction:column}

  /* APP ROW */
  .app-row{flex-direction:column}
  .app-row img{width:100%;max-width:300px}

  /* NAVIGATION — мобилка */
  .main-nav ul{display:none}
}

/* SMALL MOBILE (до 480px) */
@media(max-width:480px){
  .hero-title{font-size:30px}
  .hero-small{font-size:24px}
  .hero{padding:36px 0}
  .btn{width:100%;text-align:center}

  .modal-box{padding:16px}
  .modal-grid{gap:12px}
}

/* =========================
   MOBILE MENU (720px)
========================= */
.mobile-menu-btn{
  display:none;
}

@media(max-width:720px){

  /* Показываем бургер только на мобилке */
  .mobile-menu-btn{
    position:fixed;
    top:18px;
    right:18px;
    background:var(--olive);
    color:#fff;
    border:0;
    font-size:28px;
    padding:6px 14px;
    border-radius:10px;
    z-index:200;
    display:block;
  }

  /* Скрываем ПК-меню */
  .main-nav{
    display:none !important;
  }

  /* Контакты остаются */
  .contacts{
    display:block;
  }

  /* Само мобильное меню */
  .mobile-menu{
    position:fixed;
    top:0;
    right:-260px;
    width:260px;
    height:100%;
    background:#fff;
    box-shadow:-4px 0 22px rgba(0,0,0,0.15);
    padding:20px;
    transition:0.35s;
    z-index:300;
  }

  .mobile-menu.open{
    right:0;
  }

  /* Кнопка закрыть */
  .close-menu{
    background:none;
    border:0;
    font-size:28px;
    cursor:pointer;
    display:block;
    margin-left:auto;
  }

  /* Навигация */
  .mobile-nav{
    margin-top:40px;
    display:flex;
    flex-direction:column;
    gap:16px;
  }

  .mobile-nav a{
    font-size:18px;
    padding:8px 0;
    border-bottom:1px solid #eee;
  }

  /* Контакты в моб-меню */
  .mobile-contacts{
    margin-top:28px;
    font-weight:600;
  }

  .mobile-contacts div{
    margin-bottom:6px;
  }
}

/* ПК — скрываем бургер, крестик, мобильную почту, само меню */
@media (min-width: 981px) {
  .mobile-menu-btn,
  .close-menu,
  .mobile-menu {
    display: none !important;
  }
}

@media (min-width: 981px) {
  .mobile-contacts {
    display: none !important;
  }
}

/* ====== Отзывы ====== */
.reviews-list {
  margin-top: 40px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.review-card {
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.08);
  padding: 16px 20px;
  transition: transform 0.2s;
}

.review-card:hover {
  transform: translateY(-3px);
}

.review-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.review-name {
  font-weight: 700;
  font-size: 16px;
  color: #3b3b3b;
}

.review-stars {
  font-size: 14px;
  color: #f5b50a;
}

.review-text {
  font-size: 15px;
  color: #555;
  margin-bottom: 8px;
}

.review-date {
  font-size: 13px;
  color: #999;
  text-align: right;
}

/* Адаптация под мобильные */
@media(max-width:720px) {
  .review-card {
    padding: 14px 16px;
  }

  .review-name {
    font-size: 15px;
  }

  .review-text {
    font-size: 14px;
  }
}

/* Отступы между отзывами */
#reviewsContainer {
  display: flex;
  flex-direction: column;
  gap: 26px; /* расстояние между отзывами */
  margin-top: 20px;
}

.review-card {
  margin-bottom: 12px; /* дополнительный запас */
}

/* =========================
   МОДАЛЬНОЕ ОКНО — АДАПТАЦИЯ
========================= */
.modal-box {
  width: 760px;
  max-width: 95%; /* не вылезает за экран */
  box-sizing: border-box; /* padding не увеличивает ширину */
  background: var(--white);
  border-radius: 12px;
  padding: 20px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.18);
}

.modal-grid {
  display: grid;
  grid-template-columns: 1fr 320px; /* форма + контактные данные */
  gap: 18px;
}

/* Tablets (до 980px) */
@media(max-width:980px){
  .modal-box {
    width: 92%;
  }
  .modal-grid {
    grid-template-columns: 1fr; /* форма и контакты под друг другом */
  }
}

/* MOBILE (до 720px) */
@media(max-width:720px){
  .modal-box {
    width: 95%;
    padding: 16px;
  }
  .modal-grid {
    grid-template-columns: 1fr; /* вертикальное расположение */
    gap: 12px;
  }
  .modal-box form label {
    font-size: 13px;
  }
  .modal-box form input,
  .modal-box form select,
  .modal-box form textarea {
    font-size: 14px;
  }
  .modal-box h3 {
    font-size: 18px;
  }
  .modal-box h4 {
    font-size: 16px;
  }
}

