/* ===========================================================
   components.css — редакційні блоки, списки, прайс, контакти
   =========================================================== */

/* список послуг — нумерований, типографічний, без карток-плиток */
.index {
  border-top: 1px solid var(--line-light);
}
.index__row {
  display: grid; grid-template-columns: auto 1fr; gap: clamp(16px,3vw,40px);
  align-items: start;
  padding: clamp(22px,3vw,34px) 0;
  border-bottom: 1px solid var(--line-light);
}
@media (min-width: 820px) {
  .index__row { grid-template-columns: 88px minmax(0,1fr) minmax(0,2fr); }
}
.index__no {
  font-family: var(--serif); font-size: var(--step-2); color: var(--brass-deep); line-height: 1;
}
.index__name { font-family: var(--serif); font-size: var(--step-1); }
.index__name + .index__desc { margin-top: 8px; }
.index__desc { color: var(--muted-2); max-width: 52ch; }
.index__row:hover .index__name { color: var(--brass-deep); }

/* мітки-чіпси несправностей */
.chips { display: flex; flex-wrap: wrap; gap: 10px; }
.chip {
  border: 1px solid var(--line-light); padding: 9px 15px;
  font-size: var(--step--1); letter-spacing: .04em; color: var(--ink);
}
.on-ink .chip { border-color: var(--line); color: var(--paper); }

/* процес — горизонтальні нумеровані рядки з лінією */
.steps { counter-reset: st; border-top: 1px solid var(--line); }
.step {
  display: grid; gap: 6px 26px; grid-template-columns: 1fr;
  padding: clamp(24px,3vw,36px) 0; border-bottom: 1px solid var(--line);
}
@media (min-width: 760px) { .step { grid-template-columns: 120px 1fr; } }
.step__k {
  font-size: var(--step--1); letter-spacing: .24em; text-transform: uppercase;
  color: var(--brass); font-weight: 700;
}
.step h3 { font-size: var(--step-1); margin-bottom: 8px; color: var(--paper); }
.step p { color: var(--muted); max-width: 60ch; margin: 0; }

/* прайс — редакційна таблиця-список */
.price { border-top: 1px solid var(--line-light); }
.price__group { padding-block: clamp(26px,3vw,40px); border-bottom: 1px solid var(--line-light); }
.price__head {
  display: flex; align-items: baseline; gap: 14px; margin-bottom: 20px;
}
.price__head h3 { font-size: var(--step-2); }
.price__head .tag { margin-left: auto; }
.price__row {
  display: grid; grid-template-columns: 1fr auto; gap: 16px;
  align-items: baseline; padding: 13px 0;
  border-bottom: 1px dotted var(--line-light);
}
.price__row:last-child { border-bottom: 0; }
.price__row dt { font-size: var(--step-0); }
.price__row dt small { display: block; color: var(--muted-2); font-size: var(--step--1); margin-top: 3px; }
.price__row dd {
  margin: 0; font-family: var(--serif); font-size: var(--step-1); white-space: nowrap; color: var(--brass-deep);
}
.price__note { color: var(--muted-2); font-size: var(--step--1); margin-top: 26px; }

/* великий заявний блок (pull quote) */
.statement {
  font-family: var(--serif); font-size: var(--step-3); line-height: 1.06;
  letter-spacing: -.015em; max-width: 22ch;
}
.statement em { color: var(--brass); font-style: italic; }

/* факти — горизонтальна стрічка з тонкими роздільниками */
.facts { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--line); border: 1px solid var(--line); }
@media (min-width: 760px) { .facts { grid-template-columns: repeat(4,1fr); } }
.fact { background: var(--ink); padding: clamp(22px,3vw,34px); }
.fact b { display: block; font-family: var(--serif); font-size: var(--step-3); color: var(--brass); line-height: 1; }
.fact span { display: block; margin-top: 12px; color: var(--muted); font-size: var(--step--1); letter-spacing: .04em; }

/* контактні рядки */
.contact-list { border-top: 1px solid var(--line-light); }
.contact-row {
  display: grid; grid-template-columns: 1fr; gap: 4px;
  padding: clamp(18px,2.4vw,28px) 0; border-bottom: 1px solid var(--line-light);
}
@media (min-width: 640px) { .contact-row { grid-template-columns: 200px 1fr; gap: 24px; align-items: baseline; } }
.contact-row dt { font-size: var(--step--1); letter-spacing: .2em; text-transform: uppercase; color: var(--brass-deep); font-weight: 700; }
.contact-row dd { margin: 0; font-size: var(--step-1); font-family: var(--serif); }
.contact-row dd small { font-family: var(--sans); display:block; color: var(--muted-2); font-size: var(--step--1); margin-top: 4px; }
.contact-row a:hover { color: var(--brass-deep); }

.msgr { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 6px; }

/* карта */
.map { width: 100%; border: 1px solid var(--line-light); aspect-ratio: 16/9; }
.map iframe { width: 100%; height: 100%; border: 0; display: block; filter: grayscale(.2) contrast(1.02); }

/* контентні сторінки (політики) */
.doc { max-width: 70ch; }
.doc h2 { font-size: var(--step-2); margin: clamp(30px,4vw,52px) 0 14px; }
.doc h3 { font-family: var(--serif); font-size: var(--step-1); margin: 28px 0 10px; }
.doc p, .doc li { color: var(--ink); }
.doc ul { margin: 0 0 1.1em; }
.doc li { position: relative; padding-left: 24px; margin-bottom: 8px; }
.doc li::before { content: "—"; position: absolute; left: 0; color: var(--brass-deep); }
.doc__meta { color: var(--muted-2); font-size: var(--step--1); letter-spacing: .04em; }

/* галерея робіт — асиметрична сітка */
.gallery { display: grid; grid-template-columns: 1fr; gap: clamp(6px,1vw,12px); }
@media (min-width: 720px) { .gallery { grid-template-columns: 1fr 1fr; } }
.gallery figure { position: relative; margin: 0; overflow: hidden; background: var(--ink-2); }
.gallery img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.gallery figure:hover img { transform: scale(1.04); }
.gallery figure.span2 { grid-column: 1 / -1; }
.gallery figure img { aspect-ratio: 4/3; }
.gallery figure.span2 img { aspect-ratio: 16/7; }
.gallery figcaption {
  position: absolute; left: 0; bottom: 0; background: var(--ink); color: var(--paper);
  font-size: var(--step--1); letter-spacing: .12em; text-transform: uppercase; padding: 9px 15px;
}

/* hero для внутрішніх сторінок */
.phead { padding-top: clamp(36px,6vw,80px); }
.phead .crumbs {
  font-size: var(--step--1); letter-spacing: .14em; text-transform: uppercase; color: var(--muted-2); margin-bottom: 22px;
}
.phead .crumbs a { color: var(--brass-deep); }
.phead h1 { font-size: var(--step-3); max-width: 17ch; }
.phead p { margin-top: 20px; max-width: 52ch; color: var(--muted-2); font-size: var(--step-1); line-height: 1.4; }

/* CTA-смуга */
.cta {
  display: grid; gap: 22px; align-items: center;
  grid-template-columns: 1fr;
}
@media (min-width: 820px) { .cta { grid-template-columns: 1.4fr auto; } }
.cta h2 { font-size: var(--step-3); max-width: 18ch; color: var(--paper); }
.cta__side { display: flex; flex-direction: column; gap: 12px; }
.cta__phone { font-family: var(--serif); font-size: var(--step-2); color: var(--brass); }
