
/* ===== Service Page: landshaft (локальные стили в rem) ===== */
:root{
  --gap: 1.2rem;
  --rad: 1.2rem;
  --Font-main: 'Montserrat', sans-serif;
}

html, body{ margin: 0; }

body{
  padding-top: 1rem;
  font-family: var(--Font-main);

  /* Fallback для старых браузеров без OKLCH */
  background-color: #f6faf7;

  /* Основной фон (современные браузеры) */
  background:
    radial-gradient(75rem 37.5rem at 5% 0%, oklch(0.95 0.03 160 / .55), transparent 60%),
    radial-gradient(50rem 25rem at 100% 10%, oklch(0.93 0.05 165 / .35), transparent 70%),
    linear-gradient(to bottom, #fff, #f8fbf9 60%, #f6faf7);
  position: relative;
}

.breadcrumbs{ margin:1.2rem auto; font-size:1rem; gap:.6rem; display:flex; align-items:center; }
.breadcrumbs .crumb{ text-decoration: underline; }

.service-hero{ display:grid; grid-template-columns:1fr 1fr; gap:2rem; align-items:center; margin:2rem 0; }
.service-hero__media img{ width:100%; height:auto; border-radius:1.2rem; }
.service-hero__content h1{ margin:0 0 .8rem; }
.service-hero__content p{ line-height:1.7; }
.service-hero__content .cta{ display:flex; gap:1rem; margin-top:1rem; flex-wrap:wrap; }

.btn{ display:inline-flex; align-items:center; justify-content:center; padding:.8rem 1.2rem; border-radius:.8rem; text-decoration:none; font-weight:600; }
.btn--primary{ background:#22d3a1; color:#06251a; }
.btn--ghost{ outline:.1rem solid rgba(34,211,161,.4); color:#0b3b2a; }

.service-body{ margin:2rem 0; }
.service-body .h3{ margin:1.6rem 0 .8rem; }
.service-list{ 
    display:grid; 
    grid-template-columns:repeat(auto-fit, minmax(16rem,1fr)); 
    gap:.8rem 1.2rem; 
    margin:2rem 0 2rem; 
    padding-left:1.2rem; }
.service-list li{ line-height:1.6; }
.service-spec{ display:grid; grid-template-columns:repeat(auto-fit, minmax(16rem,1fr)); gap:1rem; }
.service-card{ background:rgba(255,255,255,.6); border-radius:1rem; padding:1rem 1.2rem; box-shadow:0 .2rem 1rem rgba(0,0,0,.05); }

/* Resources & FAQ */
.resources{ margin:3rem 0 2rem; }
.resources .h3, .faq .h3{ margin-bottom:1rem; }
.resources-note{ margin:.4rem 0 1rem; color:rgba(0,0,0,.7); }
.resources-list{ display:grid; grid-template-columns:repeat(auto-fit,minmax(16rem,1fr)); gap:.8rem 1rem; }
.resources-list a{ text-decoration: underline; }

.faq{ margin:2rem 0 3rem; }
.faq-item{ border-radius:1rem; padding:1rem 1.2rem; background:rgba(255,255,255,.6); margin-bottom:.8rem; }
.faq-item summary{ cursor:pointer; font-weight:600; }
.faq-a{ margin-top:.6rem; line-height:1.6; }

@media (max-width:56rem){
  .service-hero{ grid-template-columns:1fr; }
}

@media (prefers-reduced-motion: reduce){
  .btn, .service-card{ transition: none !important; }
}

/* === Anti-jump hotfix for call button in footer/header =================== */
.btn.btn-call,
.footer .contacts-call-button{
  display:inline-flex; align-items:center; justify-content:center; gap:.6rem;

  /* фиксируем габариты */
  padding:1rem 1.6rem;
  min-height:3.2rem;
  border-radius:1rem;

  /* резерв под бордер, чтобы на hover размер не менялся */
  border:.16rem solid transparent;

  line-height:1;
  font-weight:700;
  letter-spacing:.02rem;

  /* только безопасные для лейаута анимации */
  transition: transform .2s ease, background-color .2s ease, color .2s ease, box-shadow .2s ease;
  will-change: transform;
  box-sizing: border-box;

  /* страховка от чужих глобальных правил */
  margin:0;
}

.btn.btn-call:hover,
.footer .contacts-call-button:hover{
  transform: translateY(-.08rem);
}

.btn.btn-call:active,
.footer .contacts-call-button:active{
  transform: translateY(.04rem);
}

/* Текст внутри <strong> не должен менять метрики при hover */
.footer .contacts-call-button strong{ font-weight: inherit; }

/* Стабилизируем выравнивание */
.footer .contacts-call-button{ vertical-align: middle; }

/* Изоляция от соседних reflow */
.footer-rating, .footer-socials{ contain: layout paint; }

/* Общая защита внутри модального окна и футера */
.modal, .modal *{ box-sizing: border-box; }


/* ===== SERVICE HERO: фиксация наложения и отступов ===== */
.service-hero{
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: start;                          
  column-gap: clamp(1.6rem, 4vw, 3.2rem);     
  row-gap: 1.6rem;
}

/* Медиа-контейнер: держим пропорции, без обрезки и без налезания */
.service-hero__media{
  aspect-ratio: 16 / 9;                        
  min-height: 22rem;                           
  background: #000;                            
  overflow: hidden;
  display: grid;
  place-items: center;
  min-width: 0;                                
  contain: layout paint;
}

/* Само видео: показываем весь кадр, не обрезаем */
.landshaft-video{
  width: 100%;
  height: 100%;
  object-fit: contain;                          
  object-position: center;
  display: block;
}

/* Контент-карточка: убираем возможные негативные отступы и накладки */
.service-hero__content{
  margin: 0 !important;                        
  position: relative;
  z-index: 1;
  background: linear-gradient(180deg, #f7fbf8 0%, #f2fff6 100%);
  border-radius: 1.2rem;
  padding: clamp(1.6rem, 2.2vw, 2.4rem);
  box-shadow: 0 0.625rem 1.875rem rgba(0,0,0,.12);
  min-width: 0;
  contain: layout paint;
}

/* Адаптив: одна колонка — сверху медиа, снизу контент */
@media (max-width: 81.25rem){
  .service-hero{ grid-template-columns: 1fr; }
}


/* ===========================
   SERVICE BODY (cards grid)
   =========================== */

.service-body {
  margin-block: clamp(4rem, 6vw, 6rem);
  margin-bottom: 2rem;
}

.service-body > .h3 {
  margin: 0 0 1.2rem 0;
}

/* ---- "Что входит" — список карточек ---- */
.service-list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(24rem, 1fr));
  gap: 1.2rem;
  margin-bottom: 1.5rem;
}

.service-list li{
  position: relative;
  display: flex;
  align-items: flex-start;
  min-height: 6.4rem;
  padding: 1.4rem 1.6rem 1.4rem 3.6rem; /* место под иконку слева */
  border-radius: var(--rad, 1.2rem);
  background: var(--surface, oklch(0.99 0.01 160 / .75));
  border: 0.06rem solid oklch(0.92 0.01 160 / .45);
  box-shadow: var(--shadow-1, 0 0.625rem 1.875rem oklch(0.20 0.02 160 / .12));
  color: var(--ink, oklch(0.28 0.03 160));
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  will-change: transform;
}

.service-list li::before{
  content: "";
  position: absolute;
  left: 1.2rem;
  top: 1.4rem;
  inline-size: 1.4rem;
  block-size: 1.4rem;
  background: var(--brand, oklch(0.79 0.15 160));
  /* маска-листочек (инлайн-SVG) */
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'><path d='M20.9 3.1C16.3 3.7 8.8 6.4 5.3 9.9c-3.8 3.8-3.5 8.9-.9 11.4 2.6 2.6 7.6 2.9 11.4-.9 3.5-3.5 6.2-11 6.8-15.6a.9.9 0 0 0-.8-1zM9.8 14.2c2.2-2.2 6.1-4.1 8.9-4.7-.6 2.8-2.5 6.7-4.7 8.9-2.9 2.9-6.7 3-8.6 1.1-1.9-1.9-1.8-5.7 1.1-8.6z'/></svg>") center/contain no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'><path d='M20.9 3.1C16.3 3.7 8.8 6.4 5.3 9.9c-3.8 3.8-3.5 8.9-.9 11.4 2.6 2.6 7.6 2.9 11.4-.9 3.5-3.5 6.2-11 6.8-15.6a.9.9 0 0 0-.8-1zM9.8 14.2c2.2-2.2 6.1-4.1 8.9-4.7-.6 2.8-2.5 6.7-4.7 8.9-2.9 2.9-6.7 3-8.6 1.1-1.9-1.9-1.8-5.7 1.1-8.6z'/></svg>") center/contain no-repeat;
  opacity: .95;
}

.service-list li:hover{
  transform: translateY(-.2rem);
  box-shadow: 0 1rem 2.4rem oklch(0.20 0.02 160 / .16);
  border-color: var(--ring, oklch(0.77 0.15 160 / .55));
}

@media (max-width: 48rem){
  .service-list{
    grid-template-columns: repeat(auto-fit, minmax(18rem, 1fr));
    gap: 1rem;
    
  }
  .service-list li{ padding-left: 3.2rem; }
}

/* ---- "Почему это работает в 2025" — промокарточки ---- */
.service-spec{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(24rem, 1fr));
  gap: 1.2rem;
  margin-block: 1.6rem 0;
}

.service-card{
  position: relative;
  padding: 1.6rem 1.6rem 1.4rem 1.6rem;
  border-radius: var(--rad, 1.2rem);
  background:
    linear-gradient(180deg, oklch(0.99 0.01 160 / .9), oklch(0.98 0.02 160 / .8));
  border: 0.06rem solid oklch(0.92 0.01 160 / .45);
  box-shadow: var(--shadow-1, 0 0.625rem 1.875rem oklch(0.20 0.02 160 / .12));
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.service-card::before{
  content: "";
  position: absolute;
  inset-inline-start: 0;
  inset-block: 0;
  inline-size: .3rem;
  border-radius: var(--rad, 1.2rem);
  background: linear-gradient(180deg,
    var(--brand, oklch(0.79 0.15 160)),
    var(--brand-2, oklch(0.82 0.10 165))
  );
}

.service-card:hover{
  transform: translateY(-.2rem);
  box-shadow: 0 1rem 2.4rem oklch(0.20 0.02 160 / .16);
  border-color: var(--ring, oklch(0.77 0.15 160 / .55));
}

.service-card .h4{
  margin: 0 0 .6rem 0;
  font-weight: 700;
  color: var(--ink, oklch(0.28 0.03 160));
}

.service-card p{
  margin: 0;
  color: var(--muted, oklch(0.45 0.02 160));
  line-height: 1.55;
}

/* ---- Тёмная тема ---- */
[data-theme="dark"] .service-list li,
[data-theme="dark"] .service-card{
  background: oklch(0.22 0.02 160 / .6);
  border-color: oklch(0.35 0.02 160 / .5);
  color: oklch(0.93 0.02 160);
}
[data-theme="dark"] .service-card p{
  color: oklch(0.80 0.02 160);
}
[data-theme="dark"] .service-list li::before{
  background: var(--brand, oklch(0.79 0.15 160));
}

/* ---- Respect user preferences ---- */
@media (prefers-reduced-motion: reduce){
  .service-list li,
  .service-card{
    transition: border-color .2s ease;
    transform: none !important;
  }
}


