/* ============================================================
   АВТО108 · Страница «Услуги» (/preview-v4/services/)
   Перенос из прототипа Claude Design (Услуги.html + r/services.css).
   Токены и базовые классы (.container, .btn, .sec-head, .v4-h2,
   .v4-cases, .v4-white-section) берутся из design.css / cases.css.
   Здесь — только то, чего нет в шаблоне: .svc-*, .rf-faq*, и хелперы
   из remont.css дизайн-бандла (.rf-band, .rf-grid-4, .rf-guarantee,
   .rf-ico, .rf-sec, .btn-white).
   ============================================================ */

/* ── Хелперы из дизайн-бандла (remont.css), которых нет в v4 ──── */
.btn-white { background: #fff; color: var(--accent-ink); }
.btn-white:hover { background: rgba(255,255,255,0.92); }

.rf-sec { margin-top: 8px; }
.rf-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.rf-ico { width: 44px; height: 44px; border-radius: 10px; background: var(--accent-soft); color: var(--accent-ink); display: grid; place-items: center; flex-shrink: 0; }
.rf-guarantee { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 24px; display: flex; flex-direction: column; gap: 16px; transition: all 0.15s; }
.rf-guarantee:hover { border-color: var(--ink-400); box-shadow: 0 6px 24px rgba(0,0,0,0.05); }
.rf-guarantee h3 { font-family: var(--font-display); font-weight: 800; font-size: 17px; letter-spacing: -0.015em; margin: 0; color: var(--ink-900); line-height: 1.25; }
.rf-guarantee p { margin: 0; font-size: 12.5px; line-height: 1.55; color: var(--ink-600); }

/* CTA-полоса (rf-band-accent) */
.rf-band { padding: 56px 0; }
.rf-band-inner { display: flex; align-items: center; gap: 48px; }
.rf-band-inner .txt { flex: 1; }
.rf-band-eyebrow { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 14px; }
.rf-band-actions { display: flex; flex-direction: column; gap: 10px; width: 300px; flex-shrink: 0; }
.rf-band-accent { background: var(--accent); color: #fff; }
.rf-band-accent .rf-band-eyebrow { color: rgba(255,255,255,0.8); }
.rf-band-accent h2 { font-family: var(--font-display); font-weight: 800; font-size: 40px; letter-spacing: -0.03em; line-height: 1.08; margin: 0; color: #fff; max-width: 620px; }
.rf-band-accent p { margin: 14px 0 0; font-size: 15px; color: rgba(255,255,255,0.9); max-width: 50ch; line-height: 1.55; }
.rf-band-accent .btn-white { background: #fff; color: var(--accent-ink); padding: 15px 24px; font-size: 15px; font-weight: 700; }
.rf-band-accent .btn-white:hover { background: rgba(255,255,255,0.92); }
.rf-band-accent .btn-ghost { background: transparent; border: 1px solid rgba(255,255,255,0.45); color: #fff; padding: 15px 24px; font-size: 15px; font-weight: 600; }
.rf-band-accent .btn-ghost:hover { background: rgba(255,255,255,0.12); }

/* ── hero страницы услуг — мягкая акцентная подложка ──────────── */
.svc-hero { background: linear-gradient(180deg, var(--accent-soft) 0%, #fff 100%); padding: 24px 0 24px; }
.svc-hero-inner { display: grid; grid-template-columns: 1fr 470px; gap: 40px; align-items: stretch; }
.svc-hero-left { display: flex; flex-direction: column; }
.svc-hero-eyebrow { font-family: var(--font-mono); font-size: 11px; color: var(--accent); letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 18px; }
.svc-hero-h1 { font-family: var(--font-display); font-size: 44px; font-weight: 800; line-height: 1.1; letter-spacing: -0.03em; color: var(--ink-900); margin: 0 0 18px; }
.svc-hero-h1 em { font-style: normal; color: var(--accent); }
.svc-hero p { font-size: 16px; color: var(--ink-600); line-height: 1.6; max-width: 720px; margin: 0 0 24px; }
.svc-hero-facts { display: flex; flex-wrap: wrap; gap: 8px; margin-top: auto; }
.svc-hero-fact { font-family: var(--font-mono); font-size: 12px; font-weight: 600; letter-spacing: 0.02em; padding: 9px 15px; background: #fff; border: 1.5px solid var(--accent); border-radius: 999px; color: var(--accent-ink); box-shadow: 0 2px 8px -2px rgba(0,121,196,0.18); }

/* правая панель hero — фирменный градиент (deep navy → brand) */
.svc-hero-panel { display: flex; flex-direction: column; background: linear-gradient(135deg, #021138 0%, #0A2A6B 52%, #0079C4 100%); color: #fff; border-radius: 18px; padding: 28px; position: relative; overflow: hidden; }
.svc-hero-panel::after { content: ''; position: absolute; top: -80px; right: -80px; width: 280px; height: 280px; border-radius: 50%; background: radial-gradient(circle, rgba(140,202,232,0.28), transparent 70%); pointer-events: none; }
.svc-hero-panel-eyebrow { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: #8CCAE8; margin-bottom: 14px; position: relative; }
.svc-hero-panel h2 { margin: 0 0 12px; font-family: var(--font-display); font-weight: 800; font-size: 26px; letter-spacing: -0.028em; line-height: 1.1; color: #fff; position: relative; white-space: nowrap; }
.svc-hero-panel p { font-size: 14px; line-height: 1.6; color: rgba(255,255,255,0.78); margin: 0 0 22px; max-width: none; position: relative; }
.svc-hero-panel-cta { display: flex; flex-direction: column; gap: 10px; position: relative; }
.svc-hero-panel-cta .btn { white-space: nowrap; }
.svc-hero-panel .btn-white { background: #fff; color: #021138; font-weight: 700; }
.svc-hero-panel .btn-white:hover { background: rgba(255,255,255,0.9); }
.svc-btn-ghost { background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.28); color: #fff; }
.svc-btn-ghost:hover { background: rgba(255,255,255,0.16); }
.svc-hero-panel-foot { display: flex; align-items: center; gap: 12px; margin-top: 22px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,0.16); position: relative; }
.svc-hero-rating { display: flex; align-items: center; gap: 8px; }
.svc-hero-stars { color: #FFC83D; font-size: 16px; letter-spacing: 1px; }
.svc-hero-rating b { font-family: var(--font-display); font-weight: 800; font-size: 18px; letter-spacing: -0.02em; }
.svc-hero-rating-note { font-size: 12px; color: rgba(255,255,255,0.6); }

/* ── Строка с эффектом печатания (под H1) ───────────────────── */
.svc-type-line { font-family: var(--font-display); font-weight: 800; font-size: 44px; line-height: 1.1; letter-spacing: -0.03em; color: var(--ink-900); margin: -8px 0 20px; min-height: 1.1em; display: flex; align-items: baseline; }
.svc-type-caret { display: inline-block; width: 3px; align-self: stretch; background: var(--ink-900); margin-left: 4px; animation: svc-caret 1s steps(1) infinite; }
@keyframes svc-caret { 0%, 50% { opacity: 1; } 50.01%, 100% { opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .svc-type-caret { animation: none; opacity: 1; } }

/* ── Карточки услуг (главный кликабельный элемент) ───────────── */
.svc-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.svc-card { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--line); border-radius: 16px; overflow: hidden; text-decoration: none; color: inherit; transition: all 0.16s ease; }
.svc-card:hover { border-color: var(--accent); transform: translateY(-3px); box-shadow: 0 14px 36px -12px rgba(11,15,20,0.18); }
.svc-card-img { position: relative; aspect-ratio: 16/10; background: var(--surface-soft, var(--ink-100)); overflow: hidden; display: grid; place-items: center; border-bottom: 1px solid var(--line-soft); }
.svc-card-img svg { width: 84%; height: 84%; }
.svc-card:hover .svc-card-img { background: oklch(0.985 0.006 240); }
/* реальное фото услуги — заполняет бокс с кропом, лёгкий скрим под номер */
.svc-card-img--photo { background: #0C1320; }
.svc-card-img--photo img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.3s ease; }
.svc-card:hover .svc-card-img--photo { background: #0C1320; }
.svc-card:hover .svc-card-img--photo img { transform: scale(1.04); }
.svc-card-img--photo::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,0.18) 0%, rgba(0,0,0,0) 40%, rgba(0,0,0,0.28) 100%); pointer-events: none; }
.svc-card-img--photo .svc-card-n { color: #fff; opacity: 0.92; text-shadow: 0 1px 10px rgba(0,0,0,0.45); }
.svc-card-tag { position: absolute; top: 12px; left: 12px; font-family: var(--font-mono); font-size: 10px; background: var(--accent); color: #fff; padding: 4px 9px; border-radius: 5px; letter-spacing: 0.08em; text-transform: uppercase; }
.svc-card-n { position: absolute; top: 12px; right: 14px; font-family: var(--font-display); font-weight: 800; font-size: 28px; letter-spacing: -0.03em; color: var(--ink-400); opacity: 0.55; }
.svc-card-body { padding: 20px 22px 22px; display: flex; flex-direction: column; flex: 1; }
.svc-card-body h3, .svc-card-title { margin: 0 0 8px; font-family: var(--font-display); font-weight: 800; font-size: 21px; letter-spacing: -0.022em; color: var(--ink-900); line-height: 1.2; }
.svc-card-body p, .svc-card-text { margin: 0 0 20px; font-size: 13.5px; line-height: 1.6; color: var(--ink-600); flex: 1; text-wrap: pretty; }
.svc-card-cta { font-size: 13px; font-weight: 600; color: var(--accent); margin-top: auto; }
.svc-card-foot { display: flex; align-items: flex-end; justify-content: space-between; gap: 12px; padding-top: 16px; border-top: 1px solid var(--line-soft); }
.svc-card-meta { display: flex; flex-direction: column; gap: 6px; }
.svc-card-price { font-family: var(--font-display); font-weight: 800; font-size: 20px; letter-spacing: -0.015em; color: var(--ink-900); }
.svc-card-time { display: inline-flex; align-items: center; gap: 5px; font-family: var(--font-mono); font-size: 11px; color: var(--ink-500); letter-spacing: 0.03em; }
.svc-card-time svg { width: 13px; height: 13px; }
.svc-card-go { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 600; color: var(--accent); white-space: nowrap; }
.svc-card-go svg { transition: transform 0.16s ease; }
.svc-card:hover .svc-card-go svg { transform: translateX(3px); }

/* ── Вводный SEO-блок «о студии» ──────────────────────────────── */
.svc-intro-band { background: var(--feature-soft, oklch(0.975 0.012 240)); border-top: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft); padding: 56px 0; }
.svc-intro-inner { display: grid; grid-template-columns: 1.5fr 1fr; gap: 48px; align-items: center; }
.svc-intro-main h2 { margin: 12px 0 16px; font-family: var(--font-display); font-weight: 800; font-size: 30px; letter-spacing: -0.03em; color: var(--ink-900); line-height: 1.1; }
.svc-intro-main p { margin: 0 0 14px; font-size: 14.5px; line-height: 1.68; color: var(--ink-700); max-width: 64ch; text-wrap: pretty; }
.svc-intro-main p:last-child { margin-bottom: 0; }
.svc-intro-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.svc-stat { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 20px; }
.svc-stat b { display: block; font-family: var(--font-display); font-weight: 800; font-size: 30px; letter-spacing: -0.03em; color: var(--accent); line-height: 1; margin-bottom: 8px; }
.svc-stat span { font-size: 12px; color: var(--ink-500); line-height: 1.4; }

/* портфолио без мета-строки (только иллюстрация + подпись) */
.svc-cases .v4-case-img { display: grid; place-items: center; background: var(--surface-soft, var(--ink-100)); }
.svc-cases .v4-case-img svg { width: 86%; height: 86%; }
.svc-cases .v4-case-work { margin-bottom: 0; }

/* ── FAQ (используется и на странице услуги) ─────────────────── */
.rf-faq { display: flex; flex-direction: column; gap: 10px; }
.rf-faq-item { background: #fff; border: 1px solid var(--line); border-radius: 14px; overflow: hidden; transition: border-color 0.15s; }
.rf-faq-item[open] { border-color: var(--ink-400); }
.rf-faq-item:hover { border-color: var(--ink-400); }
.rf-faq-q { list-style: none; cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 20px 24px; font-family: var(--font-display); font-weight: 700; font-size: 16.5px; letter-spacing: -0.012em; color: var(--ink-900); line-height: 1.35; }
.rf-faq-q::-webkit-details-marker { display: none; }
.rf-faq-mark { flex-shrink: 0; width: 30px; height: 30px; border-radius: 8px; background: var(--accent-soft); color: var(--accent-ink); display: grid; place-items: center; transition: transform 0.2s ease, background 0.15s; }
.rf-faq-item[open] .rf-faq-mark { transform: rotate(45deg); background: var(--accent); color: #fff; }
.rf-faq-a { padding: 0 24px 22px; font-size: 14px; line-height: 1.68; color: var(--ink-600); max-width: 90ch; text-wrap: pretty; }

/* ── Адаптив ─────────────────────────────────────────────────── */
@media (max-width: 1000px) {
  .svc-hero-inner { grid-template-columns: 1fr; gap: 28px; }
  .svc-hero-h1 { font-size: 40px; }
  .svc-type-line { font-size: 40px; }
  .svc-cards { grid-template-columns: 1fr 1fr; }
  .svc-intro-inner { grid-template-columns: 1fr; gap: 28px; }
  .rf-grid-4 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
  .svc-hero { padding: 28px 0 20px; }
  .svc-hero-h1 { font-size: 30px; }
  .svc-hero-h1 br { display: none; }
  .svc-type-line { font-size: 26px; margin: -2px 0 18px; }
  .svc-hero p { font-size: 14.5px; }
  .svc-hero-panel { padding: 24px; }
  .svc-hero-panel h2 { font-size: 23px; white-space: normal; }
  .svc-cards { grid-template-columns: 1fr; }
  .svc-cases { grid-template-columns: 1fr 1fr; }
  .svc-intro-band { padding: 36px 0; }
  .svc-intro-main h2 { font-size: 24px; }
  .rf-grid-4 { grid-template-columns: 1fr; }
  .rf-band-inner { flex-direction: column; align-items: stretch; gap: 24px; }
  .rf-band-actions { width: 100%; }
  .rf-band-accent h2 { font-size: 30px; }
  .rf-faq-q { font-size: 15px; padding: 17px 18px; }
  .rf-faq-a { padding: 0 18px 18px; }
}
@media (max-width: 460px) {
  .svc-cases { grid-template-columns: 1fr; }
}
