:root{
  --bg:#0a0a0a;
  --bg-2:#111;
  --fg:#fff;
  --muted:#b9b9b9;
  --primary:#e7e7e7;
  --accent:#ffffff;
  --card:#141414;
  --line:#222;
  --good:#2ecc71;
  --bad:#e74c3c;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--fg); background:var(--bg);
  line-height:1.55;
}

/* Блокировка прокрутки, когда открыт бургер (ставится классом из JS) */
body.no-scroll{
  overflow:hidden;
  height:100vh;
}

.container{max-width:1200px; margin:0 auto; padding:0 20px}

/* ================= Header ================= */
.header{
  position:sticky; top:0; z-index:50;
  background:rgba(10,10,10,.9);
  backdrop-filter:saturate(130%) blur(6px);
  border-bottom:1px solid var(--line);
}
.header__inner{display:flex; align-items:center; justify-content:space-between; height:64px}
.logo{display:flex; align-items:center; gap:10px; color:var(--fg); text-decoration:none}
.logo__text{display:flex; flex-direction:column; line-height:1}
.logo__text strong{font-weight:700; letter-spacing:.3px}
.logo__text em{font-style:normal; color:var(--muted); font-size:12px; margin-top:2px}

.nav{display:flex; gap:20px; align-items:center}
.nav a{color:var(--fg); text-decoration:none; opacity:.9}
.nav a:hover{opacity:1}

.btn{
  display:inline-block; padding:10px 16px; border:1px solid var(--line);
  text-decoration:none; color:var(--fg); border-radius:10px; transition:.2s transform, .2s opacity;
}
.btn:hover{transform:translateY(-1px)}
.btn--sm{padding:8px 12px}
.btn--ghost{background:transparent}
.btn--full{display:block; text-align:center; width:100%; background:var(--fg); color:#000; border-color:var(--fg);}

/* Кнопка бургера поверх шапки */
.burger{
  display:none; width:40px; height:40px; background:transparent;
  border:1px solid var(--line); border-radius:10px;
  align-items:center; justify-content:center; position:relative; z-index:10001;
}
.burger span{display:block; width:20px; height:2px; background:var(--fg); margin:3px 0; transition:.2s}

/* ================= Hero ================= */
.hero{
  background:
    radial-gradient(1200px 600px at 80% -20%, rgba(255,255,255,.08), transparent),
    radial-gradient(900px 500px at -20% 20%, rgba(255,255,255,.05), transparent);
}
.hero__inner{display:grid; grid-template-columns:1.1fr .9fr; gap:40px; padding:56px 0 24px}
.hero__text h1{font-size:40px; line-height:1.2; margin:70px 0 12px}
.hero__text p{color:var(--muted); margin:0 0 16px}
.hero__cta{display:flex; gap:12px; margin:8px 0 12px}
.hero__badges{list-style:none; padding:0; margin:10px 0 0; display:flex; gap:16px; flex-wrap:wrap; color:#d3d3d3}
.hero__media img{width:100%; height:100%; border-radius:16px; border:1px solid var(--line)}

/* ================= Sections ================= */
.strip{padding:56px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.strip--dark{background:var(--bg-2)}
.strip--contact{background:linear-gradient(180deg, #0f0f0f 0%, #0a0a0a 100%)}
h2{font-size:28px; margin:0 0 8px}
.lead{color:var(--muted); margin:0 0 24px}

/* Cards */
.cards{display:grid; grid-template-columns:repeat(4,1fr); gap:16px}
.card{background:var(--card); border:1px solid var(--line); padding:16px; border-radius:14px}
.card h3{margin:0 0 8px; font-size:18px}
.card p{margin:0; color:var(--muted)}

/* Pricing */
.pricing{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.p-card{background:var(--card); border:1px solid var(--line); border-radius:16px; padding:16px; display:flex; flex-direction:column; gap:12px}
.p-card--accent{outline:2px solid #fff}
.p-card h3{margin:0}
.price{font-size:32px; font-weight:700}
.price span{font-size:13px; color:var(--muted); font-weight:400; margin-left:8px}
.p-card ul{margin:0; padding-left:18px; color:#d6d6d6}
.p-card .btn{margin-top:auto}

/* ================= Gallery ================= */
.gallery{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap:10px;
}
.gallery img{
  width:100%; height:auto; aspect-ratio:4/3; object-fit:cover;
  border-radius:12px; border:1px solid var(--line); display:block;
}

/* ================= Reviews ================= */
.reviews{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
blockquote{margin:0; background:var(--card); border:1px solid var(--line); padding:16px; border-radius:14px; color:#dcdcdc}
cite{display:block; margin-top:10px; color:#999; font-style:normal}

/* ================= Contact ================= */
.contact{display:grid; grid-template-columns:1fr 1fr; gap:24px}
.contact__list{list-style:none; padding:0; margin:12px 0 0; color:#dcdcdc}
.contact__list a{color:#dcdcdc}

.form{background:var(--card); border:1px solid var(--line); border-radius:16px; padding:16px}
.field{display:flex; flex-direction:column; gap:6px; margin-bottom:12px}
.field input,.field textarea{
  width:100%; padding:12px; background:#0c0c0c; border:1px solid #242424; border-radius:10px; color:#fff;
}
.field input:focus,.field textarea:focus{outline:2px solid #3a3a3a}
.err{color:var(--bad); min-height:16px}
.form__actions{display:flex; flex-direction:column; gap:10px; margin-top:4px}
.form__note{color:var(--muted); margin:0}
.form__status{margin-top:10px; min-height:22px; color:var(--muted)}

/* ================= Footer ================= */
.footer{padding:20px 0}
.footer__inner{display:flex; align-items:center; justify-content:space-between; border-top:1px solid var(--line); padding-top:16px; color:#cfcfcf}
.to-top{color:#cfcfcf; text-decoration:none; border:1px solid var(--line); border-radius:8px; padding:6px 10px}

/* ================= Overlay (затемнение за меню) ================= */
.overlay{
  position:fixed; left:0; right:0; top:64px; bottom:0;
  background:rgba(0,0,0,.55);
  opacity:0; pointer-events:none;
  z-index:9998;
  transition:opacity .2s ease;
}
.overlay.show{ opacity:1; pointer-events:auto; }

/* ================= Base mobile menu visibility (важно!) ================= */
/* По умолчанию (на всех ширинах) мобильное меню спрятано */
.mobile{
  display:none;
  position:fixed;
  left:0; right:0; top:64px; bottom:0;
  z-index:9999;
}
.mobile.show{ display:flex; }

/* На десктопе гарантированно скрываем */
@media (min-width: 781px){
  .mobile{ display:none !important; }
}

/* ================= Responsive ================= */
@media (max-width: 900px){
  .hero__inner{grid-template-columns:1fr; padding:40px 0 8px}
  .cards{grid-template-columns:repeat(2,1fr)}
  .pricing{grid-template-columns:1fr}
  .reviews{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
}

@media (max-width: 780px){
  .nav{display:none}
  .burger{display:inline-flex}

  /* Мобильное меню — поверх оверлея и контента */
  .mobile{
    background:#0a0a0a; /* можно rgba(0,0,0,.95) если нужно темнее */
    border-top:1px solid var(--line);
    padding:16px;
    flex-direction:column; gap:12px;
    overflow-y:auto; -webkit-overflow-scrolling:touch;
    color:#fff; animation:slideDown .2s ease;
  }

  /* видимые ссылки в меню */
  .mobile a{color:#fff; text-decoration:none}

  .m-link{
    display:block;
    padding:12px 10px;
    border:1px solid var(--line);
    border-radius:10px;
    background:#0f0f0f;
  }

  /* контрастная кнопка в меню */
  .mobile .btn.btn--full{
    background:#fff; color:#000; border-color:#fff;
  }
}

@media (max-width: 560px){
  .gallery{grid-template-columns:1fr}
}

/* Анимация появления меню */
@keyframes slideDown{
  from{transform:translateY(-8px); opacity:0;}
  to{transform:translateY(0); opacity:1;}
}
