
* { box-sizing: border-box; }
:root{
  --bg:#0d0f13; --card:#151821; --muted:#9aa3ad; --text:#e6e8ea; --accent:#ffc107; --accent-2:#ffe082; --line:#232837;
}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;line-height:1.6;}
a{color:var(--text);text-decoration:none}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.site-header{position:sticky;top:0;background:rgba(13,15,19,.85);backdrop-filter: blur(8px);border-bottom:1px solid var(--line);z-index:50}
.header-row{display:flex;align-items:center;justify-content:space-between;min-height:64px}
.brand{display:flex;gap:.5rem;align-items:center;font-weight:700;letter-spacing:.2px}
.brand-mark{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:8px;background:var(--accent);color:#111;font-weight:900}
.nav-toggle{display:none;background:transparent;border:1px solid var(--line);color:var(--text);padding:.5rem .75rem;border-radius:10px}
.menu{display:flex;gap:18px;align-items:center;list-style:none;margin:0;padding:0}
.menu a{opacity:.9}
.menu .btn{opacity:1}
.btn{display:inline-block;padding:.8rem 1.1rem;border-radius:12px;border:1px solid var(--line);transition:.2s ease;background:transparent}
.btn:hover{transform:translateY(-1px)}
.btn-accent{background:var(--accent);border-color:var(--accent);color:#111;font-weight:700}
.btn-ghost{background:transparent;color:var(--text)}

.hero{padding:52px 0 18px;border-bottom:1px solid var(--line);background: radial-gradient(1000px 500px at 70% -10%, rgba(255,193,7,.1), transparent 60%);}
.hero-inner{display:grid;grid-template-columns:1.2fr .8fr;gap:32px;align-items:center}
.lead{color:var(--muted);max-width:54ch}
.hero-cta{display:flex;gap:12px;margin:18px 0 8px}
.hero-benefits{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:10px;list-style:none;padding:0;margin-top:10px;color:var(--muted);font-size:.95rem}

.placeholder-ratio,.placeholder-16x9,.placeholder-3x4,.placeholder-3x2{position:relative;background:var(--card);border:1px dashed var(--line);border-radius:16px;overflow:hidden}
.placeholder-ratio{aspect-ratio:4/3}
.placeholder-16x9{aspect-ratio:16/9}
.placeholder-3x4{aspect-ratio:3/4}
.placeholder-3x2{aspect-ratio:3/2}
.photo-block{position:absolute;inset:0;display:grid;place-items:center;background:linear-gradient(135deg, #1b1f2b, #10131a);color:var(--muted);background-size:cover;background-position:center}
.hero-media .photo-block{background-image:url('/assets/images/hero/main-hero.webp')}
.photo-block[style*="background-image"]::after{content:"";display:none}

.cards{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:18px;margin:28px auto}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px}
.card h3{margin-top:0}

.stats{display:grid;grid-template-columns:repeat(4, minmax(0,1fr));gap:18px;margin:28px auto}
.stat{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;text-align:center}
.stat span{font-size:1.6rem;font-weight:800;color:var(--accent)}

.wide .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:center}
.checklist{list-style:none;padding:0}
.checklist li{position:relative;padding-left:28px;margin:10px 0}
.checklist li::before{content:"✓";position:absolute;left:0;top:0;color:var(--accent)}

.page h1{margin-top:24px}
.service-grid{display:grid;grid-template-columns:repeat(2, minmax(0,1fr));gap:18px}
.service-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px}

.grid-3{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:18px}
.grid-2{display:grid;grid-template-columns:repeat(2, minmax(0,1fr));gap:18px}

.table-wrap{overflow:auto;background:var(--card);border:1px solid var(--line);border-radius:16px}
.price-table{width:100%;border-collapse:collapse}
.price-table th,.price-table td{padding:14px;border-bottom:1px solid var(--line);text-align:left}
.price-table th{color:var(--muted);font-weight:600}

.calc{margin-top:24px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px}
.calc-form label{display:block;font-size:.95rem;color:var(--muted)}
.calc-form input,.calc-form select{width:100%;margin-top:6px;margin-bottom:8px;padding:.7rem;border-radius:10px;border:1px solid var(--line);background:#0f1218;color:var(--text)}
.calc-actions{display:flex;gap:12px;align-items:center;margin-top:8px}
.calc-result{font-weight:800;color:var(--accent)}

.contact-form{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px}

.masonry{columns:3 280px;column-gap:18px}
.masonry-item{break-inside:avoid;margin-bottom:18px}
.mt{margin-top:18px}

.site-footer{margin-top:40px;border-top:1px solid var(--line);background:#0b0e12;padding:28px 0}
.brand-footer{margin-bottom:10px}
.list{list-style:none;padding-left:0;margin:10px 0}
.small{font-size:.9rem}

@media (max-width: 960px){
  .hero-inner{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .service-grid{grid-template-columns:1fr}
  .menu{display:none;position:absolute;right:20px;top:60px;background:#0f1218;border:1px solid var(--line);border-radius:12px;padding:10px 12px;flex-direction:column}
  .nav-toggle{display:inline-block}
}

/* Стили для страницы городов */
.cities-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 20px;
  margin-top: 24px;
}

.city-district {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 18px;
}

.city-district h3 {
  margin-top: 0;
  margin-bottom: 12px;
  color: var(--accent);
  font-size: 1.1rem;
}

.city-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.city-list li {
  padding: 0;
}

.city-list a {
  display: block;
  padding: 8px 12px;
  border-radius: 8px;
  transition: all 0.2s ease;
  opacity: 0.85;
}

.city-list a:hover {
  background: rgba(255, 193, 7, 0.1);
  opacity: 1;
  transform: translateX(4px);
}

@media (max-width: 960px) {
  .cities-grid {
    grid-template-columns: 1fr;
  }
}

/* Phone blur effect */
.phone-blur {
  cursor: pointer;
  position: relative;
}

.phone-blur .blur {
  filter: blur(4px);
  transition: filter 0.3s ease;
}

.phone-blur.reveal .blur {
  filter: blur(0);
}

.show-desktop {
  display: inline;
}

.hide-desktop {
  display: none;
}

@media (max-width: 1024px) {
  .show-desktop {
    display: none !important;
  }
  .hide-desktop {
    display: inline;
  }
}

/* Icon links */
.iconbar {
  display: flex;
  gap: 12px;
  align-items: center;
}

.iconbar-inline {
  display: flex !important;
  gap: 8px;
}

.icon-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 8px;
  transition: all 0.2s ease;
  opacity: 0.9;
}

.icon-link:hover {
  opacity: 1;
  background: rgba(255, 193, 7, 0.1);
  transform: translateY(-1px);
}

.icon-link svg {
  width: 20px;
  height: 20px;
}

/* Mobile nav actions */
.nav-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

@media (min-width: 1025px) {
  .nav-actions {
    display: none;
  }
}


/* Отзывы */
.rating-summary {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 32px;
  text-align: center;
  margin-bottom: 32px;
}

.rating-big {
  display: inline-block;
}

.rating-number {
  font-size: 64px;
  font-weight: 900;
  color: var(--accent);
  line-height: 1;
  display: block;
}

.stars {
  color: var(--accent);
  font-size: 24px;
  letter-spacing: 4px;
  margin: 8px 0;
}

.reviews-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
  gap: 20px;
  margin-bottom: 32px;
}

.review-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 20px;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.review-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0,0,0,.3);
}

.review-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 12px;
}

.review-header strong {
  display: block;
  margin-bottom: 4px;
}

.review-header .stars {
  font-size: 16px;
  letter-spacing: 2px;
  margin: 4px 0;
}

.review-header time {
  color: var(--muted);
  font-size: 14px;
}

.review-card p {
  margin: 12px 0;
  line-height: 1.6;
}

.review-meta {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.badge {
  display: inline-block;
  padding: 4px 12px;
  background: rgba(255,193,7,.15);
  color: var(--accent);
  border-radius: 12px;
  font-size: 13px;
  font-weight: 600;
}

.cta-block {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 32px;
  text-align: center;
}

.cta-block h2 {
  margin-top: 0;
  color: var(--accent);
}

@media (max-width: 768px) {
  .reviews-grid {
    grid-template-columns: 1fr;
  }
  
  .rating-number {
    font-size: 48px;
  }
}


/* Форма отзыва */
.review-form-wrapper {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 32px;
  margin-top: 32px;
}

.review-form-wrapper h2 {
  margin-top: 0;
  color: var(--accent);
}

.review-form label {
  display: block;
  font-weight: 600;
  margin-bottom: 6px;
  color: var(--text);
}

.review-form input,
.review-form select,
.review-form textarea {
  width: 100%;
  background: #0f1218;
  border: 1px solid var(--line);
  border-radius: 10px;
  color: var(--text);
  padding: 12px 14px;
  font-size: 15px;
  margin-bottom: 16px;
  transition: border-color 0.2s ease;
}

.review-form input:focus,
.review-form select:focus,
.review-form textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(255,193,7,.15);
}

.review-form textarea {
  resize: vertical;
  min-height: 120px;
  font-family: inherit;
}

/* Рейтинг (звезды) */
.rating-input {
  display: flex;
  flex-direction: row-reverse;
  justify-content: flex-end;
  gap: 8px;
  margin-bottom: 16px;
}

.rating-input input[type="radio"] {
  display: none;
}

.rating-input label {
  font-size: 32px;
  color: var(--line);
  cursor: pointer;
  transition: color 0.2s ease, transform 0.2s ease;
  margin: 0;
}

.rating-input label:hover,
.rating-input label:hover ~ label {
  color: var(--accent);
  transform: scale(1.1);
}

.rating-input input[type="radio"]:checked ~ label {
  color: var(--accent);
}

.form-actions {
  margin-top: 8px;
}

.success {
  background: rgba(16,185,129,.15);
  border: 1px solid #10b981;
  border-radius: 12px;
  padding: 16px;
  text-align: center;
  color: #10b981;
  font-weight: 600;
  margin-top: 16px;
}

.error {
  background: rgba(239,68,68,.15);
  border: 1px solid #ef4444;
  border-radius: 12px;
  padding: 16px;
  text-align: center;
  color: #ef4444;
  font-weight: 600;
  margin-top: 16px;
}

@media (max-width: 768px) {
  .review-form-wrapper {
    padding: 20px;
  }
  
  .rating-input label {
    font-size: 28px;
  }
}

/* Blog Styles */
.blog-grid{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:20px;margin:32px 0}
.blog-card{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:.2s ease}
.blog-card:hover{transform:translateY(-2px);border-color:var(--accent)}
.blog-card-image{margin:0;border-radius:0}
.blog-card-content{padding:18px}
.blog-meta{display:flex;gap:12px;align-items:center;font-size:.9rem;color:var(--muted);margin-bottom:8px}
.blog-card h2{font-size:1.25rem;margin:8px 0 12px}
.blog-card h2 a{color:var(--text)}
.blog-card h2 a:hover{color:var(--accent)}
.blog-card p{color:var(--muted);font-size:.95rem;margin-bottom:16px}
.badge{display:inline-block;padding:.25rem .6rem;background:rgba(255,193,7,.15);color:var(--accent);border-radius:6px;font-size:.85rem;font-weight:600}
.btn-sm{padding:.5rem .9rem;font-size:.9rem}

/* Blog Article */
.blog-article{max-width:800px;margin:0 auto}
.blog-header{margin-bottom:32px}
.breadcrumbs{font-size:.9rem;color:var(--muted);margin-bottom:16px}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs a:hover{color:var(--accent)}
.blog-content{line-height:1.8}
.blog-content h2{margin-top:32px;margin-bottom:16px;color:var(--accent-2)}
.blog-content h3{margin-top:24px;margin-bottom:12px}
.blog-content p{margin:16px 0}
.blog-content ul{margin:16px 0}
.blog-content ul li{margin:8px 0}
.blog-content .lead{font-size:1.1rem;line-height:1.7;margin-bottom:24px}
.cta-block{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px;margin:40px 0;text-align:center}
.cta-block h3{margin-top:0}
.cta-block p{color:var(--muted);margin-bottom:20px}

/* Service Card */
.service-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px}
.service-card h2{margin-top:0;font-size:1.4rem}
.service-card .list{list-style:none;padding:0;margin:16px 0}
.service-card .list li{padding-left:24px;position:relative;margin:8px 0;color:var(--muted)}
.service-card .list li::before{content:"→";position:absolute;left:0;color:var(--accent)}

/* Rating */
.rating-summary{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px;margin:24px 0;text-align:center}
.rating-big{display:inline-block}
.rating-number{font-size:3rem;font-weight:800;color:var(--accent);display:block}
.stars{color:var(--accent);font-size:1.5rem;letter-spacing:2px}

/* Reviews */
.reviews-grid{display:grid;grid-template-columns:repeat(2, minmax(0,1fr));gap:18px;margin:24px 0}
.review-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px}
.review-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.review-card .stars{font-size:1rem;letter-spacing:1px;margin-top:4px}
.review-card time{font-size:.9rem;color:var(--muted)}
.review-meta{display:flex;gap:8px;margin-top:12px}

/* Form */
.review-form-wrapper{max-width:700px;margin:40px auto}
.review-form{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px}
.review-form label{display:block;margin-bottom:6px;font-weight:600}
.review-form input,.review-form select,.review-form textarea{width:100%;padding:.7rem;background:var(--bg);border:1px solid var(--line);border-radius:8px;color:var(--text);font-family:inherit;margin-bottom:16px}
.review-form input:focus,.review-form select:focus,.review-form textarea:focus{outline:none;border-color:var(--accent)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-actions{margin-top:8px}
.rating-input{display:flex;flex-direction:row-reverse;justify-content:flex-end;gap:4px}
.rating-input input{display:none}
.rating-input label{cursor:pointer;font-size:1.5rem;color:var(--line);transition:.2s}
.rating-input label:hover,.rating-input label:hover ~ label,.rating-input input:checked ~ label{color:var(--accent)}
.success{background:rgba(76,175,80,.15);color:#81c784;padding:16px;border-radius:8px;margin:16px 0;border:1px solid rgba(76,175,80,.3)}
.error{background:rgba(244,67,54,.15);color:#e57373;padding:16px;border-radius:8px;margin:16px 0;border:1px solid rgba(244,67,54,.3)}

/* Footer */
.site-footer{background:var(--card);border-top:1px solid var(--line);padding:40px 0 20px;margin-top:60px}
.site-footer .grid-3{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:32px}
.site-footer h4{margin-top:0;color:var(--accent-2)}
.site-footer .list{list-style:none;padding:0}
.site-footer .list li{margin:8px 0}
.site-footer .list a:hover{color:var(--accent)}
.brand-footer{margin-bottom:16px}
.muted{color:var(--muted)}
.small{font-size:.9rem}
.iconbar{display:flex;gap:12px;flex-wrap:wrap}
.iconbar-inline{display:flex;gap:8px}
.icon-link{display:flex;align-items:center;gap:6px;padding:.5rem .8rem;background:var(--card);border:1px solid var(--line);border-radius:8px;transition:.2s}
.icon-link:hover{background:var(--accent);color:#111;border-color:var(--accent)}
.icon-link svg{flex-shrink:0}

/* Responsive */
@media(max-width:768px){
  .hero-inner{grid-template-columns:1fr}
  .hero-benefits{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2, minmax(0,1fr))}
  .wide .grid-2{grid-template-columns:1fr}
  .service-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .site-footer .grid-3{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .nav-toggle{display:block}
  .menu{display:none;position:absolute;top:64px;left:0;right:0;background:var(--bg);border-bottom:1px solid var(--line);flex-direction:column;padding:20px;gap:12px}
  .menu.active{display:flex}
  .show-desktop{display:none}
  .hide-desktop{display:inline}
}
@media(min-width:769px){
  .hide-desktop{display:none}
}

/* Phone blur effect */
.phone-blur .blur{filter:blur(4px);user-select:none}

/* Price styles */
.price-big{font-size:2rem;font-weight:800;color:var(--accent);margin:16px 0}

/* Уникальный контент для городов */

/* Секции с отступами */
section.container {
  margin-top: 60px;
  margin-bottom: 60px;
}

section.container h2 {
  font-size: 2rem;
  margin-bottom: 32px;
  text-align: center;
  position: relative;
  padding-bottom: 16px;
}

section.container h2::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 60px;
  height: 3px;
  background: var(--accent);
  border-radius: 2px;
}

/* Отзывы */
.reviews-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 24px;
  margin-top: 40px;
}

.review-card {
  background: var(--card);
  padding: 28px;
  border-radius: 16px;
  border: 1px solid var(--line);
  position: relative;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.review-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(255, 193, 7, 0.1);
}

.review-card::before {
  content: '"';
  position: absolute;
  top: 16px;
  left: 20px;
  font-size: 4rem;
  color: var(--accent);
  opacity: 0.2;
  font-family: Georgia, serif;
  line-height: 1;
}

.review-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
  position: relative;
  z-index: 1;
}

.review-header strong {
  font-size: 1.1rem;
  color: var(--text);
}

.review-rating {
  color: var(--accent);
  font-size: 16px;
  letter-spacing: 2px;
}

.review-text {
  margin: 16px 0;
  line-height: 1.7;
  color: var(--muted);
  position: relative;
  z-index: 1;
}

.review-date {
  font-size: 0.85rem;
  color: var(--muted);
  opacity: 0.7;
  margin-top: 16px;
}

/* Оборудование */
.equipment-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 24px;
  margin-top: 40px;
}

.equipment-card {
  background: var(--card);
  padding: 24px;
  border-radius: 16px;
  border: 1px solid var(--line);
  transition: transform 0.2s ease, border-color 0.2s ease;
  position: relative;
  overflow: hidden;
}

.equipment-card::before {
  content: '⚙️';
  position: absolute;
  top: -10px;
  right: -10px;
  font-size: 5rem;
  opacity: 0.05;
}

.equipment-card:hover {
  transform: translateY(-4px);
  border-color: var(--accent);
}

.equipment-card h3 {
  font-size: 1.15rem;
  margin: 0 0 12px 0;
  color: var(--text);
  position: relative;
  z-index: 1;
}

.equipment-card p {
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.6;
  margin: 0;
  position: relative;
  z-index: 1;
}

/* Цены */
.prices-table {
  max-width: 900px;
  margin: 40px auto 0;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 32px;
}

.price-row {
  display: flex;
  align-items: center;
  padding: 20px 0;
  border-bottom: 1px solid var(--line);
  transition: background 0.2s ease;
}

.price-row:hover {
  background: rgba(255, 193, 7, 0.03);
  margin: 0 -16px;
  padding-left: 16px;
  padding-right: 16px;
  border-radius: 8px;
}

.price-row:last-child {
  border-bottom: none;
}

.price-service {
  flex-shrink: 0;
  font-weight: 500;
  color: var(--text);
}

.price-dots {
  flex-grow: 1;
  border-bottom: 2px dotted var(--line);
  margin: 0 16px;
  min-width: 40px;
}

.price-value {
  flex-shrink: 0;
  font-weight: 700;
  font-size: 1.15rem;
  color: var(--accent);
  white-space: nowrap;
}

.price-value small {
  font-size: 0.8rem;
  font-weight: 400;
  color: var(--muted);
  margin-left: 4px;
}

/* Статьи блога */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 24px;
  margin-top: 40px;
}

.blog-card {
  background: var(--card);
  padding: 28px;
  border-radius: 16px;
  border: 1px solid var(--line);
  transition: transform 0.2s ease, border-color 0.2s ease;
  display: flex;
  flex-direction: column;
}

.blog-card:hover {
  transform: translateY(-4px);
  border-color: var(--accent);
}

.blog-card h3 {
  font-size: 1.2rem;
  margin: 0 0 12px 0;
  color: var(--text);
  line-height: 1.4;
}

.blog-card p {
  color: var(--muted);
  margin: 12px 0 20px;
  line-height: 1.6;
  flex-grow: 1;
}

.btn-sm {
  padding: 10px 18px;
  font-size: 0.9rem;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  align-self: flex-start;
}

.btn-sm:hover {
  background: rgba(255, 193, 7, 0.1);
}

/* Адаптивность для новых блоков */
@media (max-width: 960px) {
  section.container h2 {
    font-size: 1.6rem;
  }
  
  .reviews-grid,
  .equipment-grid,
  .blog-grid {
    grid-template-columns: 1fr;
  }
  
  .prices-table {
    padding: 20px;
  }
  
  .price-row {
    flex-wrap: wrap;
    gap: 8px;
  }
  
  .price-dots {
    display: none;
  }
  
  .price-service {
    width: 100%;
  }
  
  .price-value {
    width: 100%;
    text-align: left;
  }
}


/* Соседние населенные пункты */
.nearby-section {
  background: linear-gradient(135deg, rgba(255, 193, 7, 0.03), rgba(255, 193, 7, 0.01));
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 48px 32px;
  margin-top: 60px;
}

.nearby-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 16px;
  margin-top: 32px;
}

.nearby-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 12px;
  transition: all 0.2s ease;
  text-decoration: none;
  color: var(--text);
}

.nearby-card:hover {
  transform: translateX(4px);
  border-color: var(--accent);
  background: rgba(255, 193, 7, 0.05);
}

.nearby-icon {
  font-size: 1.2rem;
  flex-shrink: 0;
}

.nearby-name {
  flex-grow: 1;
  font-weight: 500;
  font-size: 0.95rem;
}

.nearby-arrow {
  color: var(--accent);
  font-size: 1.2rem;
  opacity: 0;
  transform: translateX(-8px);
  transition: all 0.2s ease;
  flex-shrink: 0;
}

.nearby-card:hover .nearby-arrow {
  opacity: 1;
  transform: translateX(0);
}

@media (max-width: 960px) {
  .nearby-section {
    padding: 32px 20px;
  }
  
  .nearby-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================
   FAQ Section
   ============================================ */

.faq-section {
  padding: 60px 20px;
  background: linear-gradient(135deg, rgba(13, 15, 19, 0.95) 0%, rgba(20, 23, 28, 0.95) 100%);
  border-radius: 24px;
  margin-bottom: 60px;
}

.faq-section h2 {
  text-align: center;
  margin-bottom: 12px;
  font-size: 2.2rem;
}

.faq-list {
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.faq-item {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 16px;
  overflow: hidden;
  transition: all 0.3s ease;
}

.faq-item:hover {
  border-color: var(--accent);
  box-shadow: 0 4px 20px rgba(255, 193, 7, 0.1);
}

.faq-item.active {
  border-color: var(--accent);
  background: rgba(255, 193, 7, 0.03);
}

.faq-question {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  padding: 24px 28px;
  background: none;
  border: none;
  color: var(--text);
  font-size: 1.1rem;
  font-weight: 600;
  text-align: left;
  cursor: pointer;
  transition: all 0.2s ease;
}

.faq-question:hover {
  color: var(--accent);
}

.faq-icon {
  font-size: 1.8rem;
  color: var(--accent);
  font-weight: 300;
  line-height: 1;
  transition: transform 0.3s ease;
  flex-shrink: 0;
}

.faq-item.active .faq-icon {
  transform: rotate(180deg);
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, padding 0.3s ease;
}

.faq-item.active .faq-answer {
  max-height: 500px;
  padding: 0 28px 24px 28px;
}

.faq-answer p {
  color: var(--muted);
  line-height: 1.7;
  font-size: 1rem;
  margin: 0;
}

/* ============================================
   Performance Optimizations
   ============================================ */

/* Lazy loading placeholder */
img[loading="lazy"] {
  background: linear-gradient(90deg, var(--card) 0%, rgba(255, 255, 255, 0.05) 50%, var(--card) 100%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
}

@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

/* Улучшение производительности анимаций */
* {
  will-change: auto;
}

.hero-card:hover,
.service-card:hover,
.stat-card:hover,
.reason-card:hover,
.review-card:hover,
.equipment-card:hover,
.price-card:hover,
.blog-card:hover,
.nearby-card:hover,
.faq-item:hover {
  will-change: transform, box-shadow;
}

/* Оптимизация шрифтов */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('/assets/Inter-Variable.woff2') format('woff2');
}

/* Preload критичных ресурсов */
body::before {
  content: '';
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
  z-index: -1;
  background-image: url('/assets/images/hero/main-hero.webp');
}

/* ============================================
   AMP-ready styles (базовые)
   ============================================ */

.amp-only {
  display: none;
}

@media (max-width: 768px) {
  /* Оптимизация для мобильных */
  .faq-section {
    padding: 40px 16px;
  }
  
  .faq-section h2 {
    font-size: 1.8rem;
  }
  
  .faq-question {
    padding: 20px 20px;
    font-size: 1rem;
  }
  
  .faq-answer {
    font-size: 0.95rem;
  }
  
  .faq-item.active .faq-answer {
    padding: 0 20px 20px 20px;
  }
}

/* ============================================
   Print styles
   ============================================ */

@media print {
  .header,
  .footer,
  .cta-section,
  .faq-icon {
    display: none;
  }
  
  .faq-answer {
    max-height: none !important;
    padding: 0 0 16px 0 !important;
  }
  
  body {
    background: white;
    color: black;
  }
}

/* ============================================
   Accessibility improvements
   ============================================ */

/* Focus styles для клавиатурной навигации */
a:focus-visible,
button:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* Улучшение контрастности для текста */
.muted {
  color: rgba(255, 255, 255, 0.7);
}

/* Анимации только если пользователь не отключил их */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
/* Темная тема всегда активна (светлая тема отключена) */
