/*
 Theme Name: Prespa Child
 Template: prespa
 Description: Child theme — Services archive, hero, FAQ, dark theme, filters
 Author: Partmost
 Version: 1.1.0
*/

/* =====================  Токены  ===================== */
:root{
  --svc-gap: 24px;
  --svc-accent: #3a72d3;

  --svc-text: #111111;
  --svc-surface: #ffffff;
  --svc-border: #eeeeee;

  --svc-card-bg: #ffffff;
  --svc-card-bd: #e9eef3;

  /* dark */
  --svc-text-dark: #e6e6e6;
  --svc-surface-dark: #111417;
  --svc-border-dark: #23282d;
  --svc-card-bg-dark:#121417;
  --svc-card-bd-dark:#23282d;
}

/* =====================  Общие контейнеры  ===================== */
.svc-wrap{ max-width:1080px; margin:0 auto; padding:24px 16px 64px; }
.svc-wrap .svc-content,
.svc-wrap .svc-block{ width:100%; max-width:100%; margin:0; box-sizing:border-box; }

/* =====================  Hero  ===================== */
/* Вариант-1: двухколоночный (устойчив к сеткам темы) */
.svc-hero{
  display:grid !important;
  grid-template-columns:minmax(0,1.2fr) minmax(0,0.8fr) !important;
  gap:var(--svc-gap) !important;
  align-items:center !important;
  margin:12px 0 24px !important;
  width:100% !important; max-width:100% !important;
}
.svc-hero > *{ min-width:0; }
@media (max-width:1024px){ .svc-hero{ grid-template-columns:1fr !important; } }

/* Вариант-2: заголовок на всю ширину + контент/картинка */
.svc-hero--grid{
  display:grid !important;
  grid-template-columns:minmax(0,1.2fr) minmax(0,0.8fr) !important;
  grid-template-rows:auto auto;
  gap:19px !important; align-items:center !important;
  margin:12px 0 24px !important; width:100% !important; max-width:100% !important;
}
.svc-hero__title{ grid-column:1 / -1; grid-row:1; margin:0 0 8px; line-height:1.2; }
.svc-hero__left{ grid-column:1; grid-row:2; min-width:0; }
.svc-hero__right{ grid-column:2; grid-row:2; min-width:0; }
.svc-hero--grid:not(.has-cover) .svc-hero__left{ grid-column:1 / -1; }
@media (max-width:1024px){
  .svc-hero--grid{ grid-template-columns:1fr !important; grid-template-rows:auto auto auto; }
  .svc-hero__title{ grid-column:1; grid-row:1; }
  .svc-hero__left{ grid-column:1; grid-row:2; }
  .svc-hero__right{ grid-column:1; grid-row:3; }
}

/* Вариант-3: стек (h1 → обложка → текст) */
.svc-hero--stack{ display:block !important; margin:12px 0 24px; }
.svc-hero__cover{ margin:12px 0 16px; }
.svc-hero__cover img,
.svc-cover__img{ width:100%; height:auto; display:block; border-radius:12px; }

/* Заголовки/подзаголовки/мета */
.svc-title{ margin:0 0 8px; line-height:1.2; }
.svc-teaser{ margin:6px 0 12px; opacity:.9; }
.svc-meta{ display:flex; align-items:center; gap:10px; margin:6px 0 16px; flex-wrap:wrap; }
.svc-badge{ display:inline-block; background:#e8f0ff; color:var(--svc-accent); border-radius:999px; padding:6px 12px; font-weight:600; }
.svc-dot{ opacity:.5; }
.svc-sub{ opacity:.8; }
.svc-cta-row{ display:flex; gap:14px; align-items:center; flex-wrap:wrap; }

/* =====================  Списки/шаги/FAQ  ===================== */
.svc-list{ list-style:none !important; margin:0; padding:0; display:grid; gap:8px; }
.svc-list > li{ position:relative; padding-left:24px; }
.svc-list > li::before{ content:"•"; position:absolute; left:0; top:0; color:var(--svc-accent); font-weight:700; line-height:1; }
.svc-bullet{ display:none !important; }

.svc-steps{ list-style:none; margin:0; padding:0; display:grid; gap:14px; counter-reset:svcstep; }
.svc-steps > li{
  position:relative; counter-increment:svcstep;
  background:var(--svc-surface); border:1px solid var(--svc-border);
  border-radius:12px; padding:14px 16px 12px 44px;
}
.svc-steps > li::before{
  content:counter(svcstep); position:absolute; left:12px; top:12px;
  width:24px; height:24px; border-radius:50%; display:grid; place-items:center;
  background:var(--svc-accent); color:#fff; font-weight:700;
}
.svc-step-desc{ margin-top:4px; opacity:.9; }
.svc-step-time{ display:inline-block; margin-top:6px; color:#666; }

.svc-two{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
@media (max-width:780px){ .svc-two{ grid-template-columns:1fr; } }

.svc-faq details{
  border:1px solid var(--svc-border); border-radius:10px;
  background:var(--svc-surface); padding:10px 12px;
}
.svc-faq details + details{ margin-top:10px; }
.svc-faq summary{ cursor:pointer; font-weight:600; list-style:none; }
.svc-faq summary::-webkit-details-marker{ display:none; }

.svc-cta-center{ text-align:center; margin:36px 0 8px; }

/* =====================  Тёмная тема  ===================== */
.dark-mode .svc-steps > li,
body.dark .svc-steps > li{
  background:var(--svc-surface-dark); border-color:var(--svc-border-dark); color:var(--svc-text-dark);
}
.dark-mode .svc-faq details,
body.dark .svc-faq details{
  background:var(--svc-surface-dark); border-color:var(--svc-border-dark); color:var(--svc-text-dark);
}
.dark-mode .svc-list > li::before,
body.dark .svc-list > li::before{ color:var(--svc-accent); }
.dark-mode .svc-step-time,
body.dark .svc-step-time{ color:#9aa4ad; }

.svc-steps > li:focus-within,
.svc-faq details:focus-within{ outline:2px solid rgba(29,61,246,.25); outline-offset:2px; }

/* =====================  Архив услуг: сетка/карточки  ===================== */
.svc-arch{ max-width:1180px; margin:0 auto; padding:24px 16px 56px; }
.svc-arch__head{ margin:4px 0 18px; }
.svc-arch__title{ margin:0 0 6px; line-height:1.15; }

/* Описание архива временно скрыто, чтобы не прыгала высота при фильтре */
.svc-arch__desc{ display:none !important; }

/* Сетка */
.svc-grid{
  display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:var(--svc-gap);
}
@media (max-width:1180px){ .svc-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); } }
@media (max-width:640px){ .svc-grid{ grid-template-columns:1fr; } }

/* Карточка */
.svc-card{
  display:flex; flex-direction:column;
  background:var(--svc-card-bg); border:1px solid var(--svc-card-bd);
  border-radius:14px; overflow:hidden;
}
body.dark .svc-card,
.dark-mode .svc-card{ background:var(--svc-card-bg-dark); border-color:var(--svc-card-bd-dark); color:var(--svc-text-dark); }

.svc-card__thumb{ display:block; aspect-ratio:16/9; background:#f3f6fa; }
.svc-card__thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.svc-card__ph{ width:100%; height:100%; background:linear-gradient(180deg,#f0f3f7,#e8edf3); }
body.dark .svc-card__thumb{ background:#0f1215; }
body.dark .svc-card__ph{ background:#0f1215; }

.svc-card__body{ padding:14px 14px 16px; display:flex; flex-direction:column; gap:10px; }
.svc-card__title{ margin:0; font-size:1.05rem; line-height:1.25; }
.svc-card__title a{ text-decoration:none; }

/* Тизеры временно скрыты — зафиксированная высота карточки */
.svc-card__teaser{ display:none !important; }

.svc-card__meta{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.svc-card__price{ display:inline-block; background:#e8f0ff; color:var(--svc-accent); padding:6px 10px; border-radius:999px; font-weight:600; }
.svc-card__dot{ opacity:.5; }
.svc-card__dur{ opacity:.85; }
.svc-card__cta{ margin-top:6px; }

/* Пагинация */
.svc-arch__pager{ margin-top:28px; text-align:center; }
.svc-arch__pager .pagination,
.svc-arch__pager .nav-links{ display:inline-flex; gap:8px; align-items:center; }
.svc-arch__pager a, .svc-arch__pager span{
  display:inline-block; min-width:38px; padding:8px 10px; border:1px solid var(--svc-card-bd);
  border-radius:10px; text-decoration:none;
}
body.dark .svc-arch__pager a, body.dark .svc-arch__pager span{ border-color:var(--svc-card-bd-dark); }
.svc-arch__pager .current{ background:#e8f0ff; color:var(--svc-accent); font-weight:700; }

.svc-arch__empty{ opacity:.8; margin:12px 0 32px; }

/* =====================  Фильтры (селект + «Показать все»)  ===================== */
/* Оставлен только селект — без горизонтальных чипов */
.svc-filterbar{
  display:flex; align-items:center; gap:10px;
  margin:6px 0 2px; flex-wrap:wrap; justify-content:flex-start;
}
.svc-select-wrap{ flex:0 0 auto; }

/* Добавлен «воздух» справа под стрелку селекта */
.svc-select{
  min-width:220px;
  padding:8px 14px 8px 12px; /* right 14px => больше места для стрелки */
  border-radius:10px;
  border:1px solid var(--svc-card-bd,#e9eef3);
  background:#fff;
  color:var(--svc-text);
  line-height:1.2;
}
.svc-select::-ms-expand{ display:none; }
@supports(-webkit-appearance:none){
  .svc-select{ -webkit-appearance:none; background-position:right 10px center; }
}

/* Кнопка «Показать все» (скрывается через hidden, управляется JS) */
.svc-reset{
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 12px;
  border:1px solid var(--svc-card-bd,#e9eef3);
  background:#f7f9ff;
  color:var(--svc-accent,#3a72d3);
  border-radius:10px;
  font-weight:600; cursor:pointer;
  transition:background .15s, box-shadow .15s, border-color .15s;
}
.svc-reset:hover{ background:#eef3ff; box-shadow:0 1px 0 rgba(0,0,0,.04); }
.svc-reset[hidden]{ display:none !important; }

@media (max-width:780px){
  .svc-filterbar{ gap:8px; }
  .svc-select{ min-width:100%; }
  .svc-reset{ width:100%; justify-content:center; }
}
/* === Select: стрелка + дополнительный отступ справа === */
.svc-select{
  /* собственная стрелка */
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%233a72d3' d='M7.41 8.58L12 13.17l4.59-4.59L18 10l-6 6-6-6z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;   /* «воздух» справа */
  background-size: 14px 14px;

  /* чтобы текст не наехал на стрелку */
  padding-right: 38px;                      /* было 10px → стало 38px */
}

/* Тёмная тема: светлая стрелка и фон/бордер под тёмную палитру */
body.dark .svc-select,
.dark-mode .svc-select{
  background-image: url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%23e6e6e6' d='M7.41 8.58L12 13.17l4.59-4.59L18 10l-6 6-6-6z'/%3E%3C/svg%3E");
  background-color: var(--svc-card-bg-dark, #121417);
  border-color: var(--svc-card-bd-dark, #23282d);
  color: var(--svc-text-dark, #e6e6e6);
}

/* iOS/старые браузеры — гарантируем, что «системные» стрелки не мешают */
select::-ms-expand{ display:none; }
/* Мобила: селект и кнопка на всю ширину */
@media (max-width: 780px){
  .svc-filterbar,
  #svc-filters{
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .svc-select-wrap{ width:100%; }
  .svc-select{
    width:100%;
    max-width:100%;
    min-width:0;           /* переопределяет ранее заданные 180–220px */
    padding-right:38px;    /* воздух для стрелки сохраняем */
  }
  #svc-reset{
    width:100%;
    justify-self: stretch;
  }
}
