/* ============================================================
   legacy.css — compat layer for migrated content (2026 redesign)
   Styles carried-over components with the new design tokens.
   Loads after style-v2.css + pages.css.
   ============================================================ */

/* Old koppar.css custom properties → new tokens (keeps any
   surviving inline styles coherent) */
:root {
  --clr-copper: var(--accent);
  --clr-copper-glow: var(--accent-soft);
  --clr-text: var(--ink);
  --clr-text-soft: var(--ink-2);
  --clr-text-muted: var(--ink-3);
  --clr-bg: var(--bg);
  --clr-surface: var(--surface);
  --clr-border-mid: var(--line);
  --font-mono: var(--font-body);
  --fs-xs: 13px;
}

.text-accent { color: var(--accent-ink); }
.wrap--narrow { max-width: 880px; }

/* ---------- Article / content typography ---------- */
.legacy-content { overflow-x: hidden; }
.legacy-content h2 {
  font-size: clamp(28px, 3.2vw, 40px);
  margin-bottom: 18px;
}
.legacy-content h3 {
  font-family: var(--font-display);
  font-size: 21px; font-weight: 800; letter-spacing: -0.02em;
  margin: 26px 0 10px;
}
.legacy-content h4 { font-family: var(--font-display); font-size: 17px; font-weight: 700; margin: 20px 0 8px; }
.legacy-content p { margin-bottom: 16px; color: var(--ink-2); max-width: 72ch; text-wrap: pretty; }
.legacy-content .section { padding: 72px 0; }
.legacy-content ul, .legacy-content ol { margin: 0 0 18px 22px; color: var(--ink-2); }
.legacy-content li { margin-bottom: 8px; }
.legacy-content li::marker { color: var(--accent); }
.legacy-content a:not(.btn):not(.card):not(.chip) { color: var(--accent-ink); font-weight: 600; }
.legacy-content a:not(.btn):not(.card):not(.chip):hover { text-decoration: underline; }
.legacy-content img { border-radius: 18px; }
.legacy-content blockquote {
  border-left: 3px solid var(--accent); padding: 6px 0 6px 22px;
  margin: 22px 0; color: var(--ink-2); font-style: italic;
}

/* ---------- Tables (price tables etc.) ---------- */
.legacy-content table {
  width: 100%; border-collapse: collapse; margin: 22px 0 28px;
  background: #fff; border: 1px solid var(--line); border-radius: 16px;
  overflow: hidden; font-size: 15px;
}
.legacy-content table { border-radius: 0; }
.legacy-content thead th, .legacy-content table tr:first-child th {
  font-family: var(--font-display); font-weight: 800; text-align: left;
  background: var(--surface); color: var(--ink);
  padding: 14px 18px; border-bottom: 1px solid var(--line);
}
.legacy-content td, .legacy-content tbody th {
  padding: 13px 18px; border-bottom: 1px solid var(--line); color: var(--ink-2);
  text-align: left; vertical-align: top;
}
.legacy-content tr:last-child td { border-bottom: none; }

/* ---------- Breadcrumb ---------- */
.breadcrumb { margin-bottom: 26px; font-size: 13.5px; }
.breadcrumb__list { display: flex; flex-wrap: wrap; gap: 6px; list-style: none; margin: 0; padding: 0; }
.breadcrumb__item { color: var(--ink-3); display: flex; align-items: center; gap: 6px; }
.breadcrumb__item + .breadcrumb__item::before { content: "/"; color: var(--line); }
.breadcrumb__link { color: var(--ink-3); font-weight: 600; }
.breadcrumb__link:hover { color: var(--accent-ink); }
.breadcrumb__item--active { color: var(--ink-2); font-weight: 600; }

/* ---------- Byline / dates ---------- */
.article-byline {
  display: flex; flex-wrap: wrap; gap: 6px 14px; align-items: center;
  margin: 14px 0 4px;
  font-size: 13px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ink-3);
}
.article-byline a { color: var(--accent-ink); }
.article-byline .meta-dates { font-weight: 600; letter-spacing: 0.06em; }
.meta-dates { font-size: 13px; color: var(--ink-3); }

/* ---------- Cards ---------- */
.card-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin: 28px 0; }
.card-grid--2 { grid-template-columns: repeat(2, 1fr); }
.card-grid--3 { grid-template-columns: repeat(3, 1fr); }
.card-grid--4 { grid-template-columns: repeat(4, 1fr); }
.card {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  padding: 28px 26px;
  transition: transform 0.45s var(--ease-spring), box-shadow 0.45s, border-color 0.3s;
}
.card:hover, .card--link:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); border-color: var(--accent-border); }
.card--flat { box-shadow: none; }
.card__eyebrow {
  font-size: 12px; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--accent-ink); margin-bottom: 10px; display: block;
}
.card__title, .card h3 { font-family: var(--font-display); font-size: 19px; font-weight: 800; letter-spacing: -0.015em; margin: 0 0 8px; }
.card__body p, .card__text, .card p { font-size: 14.5px; color: var(--ink-2); max-width: none; }
.card .btn { margin-top: 14px; }
.card__icon { width: 44px; height: 44px; border-radius: 14px; background: var(--accent-soft); color: var(--accent); display: grid; place-items: center; margin-bottom: 14px; }
.card__icon svg { width: 22px; height: 22px; }

/* ---------- Badges / pills ---------- */
.badge, .catalog__service-pill {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 7px 14px; border-radius: 999px;
  background: var(--accent-soft); color: var(--accent-ink);
  font-family: var(--font-display); font-size: 13px; font-weight: 700;
  margin: 0 6px 8px 0;
}

/* ---------- Section titles from old templates ---------- */
.section-title, .section__title { margin-bottom: 16px; }
.section-lead, .section__lead {
  font-size: 17px; color: var(--ink-2); max-width: 60ch; margin-bottom: 28px; text-wrap: pretty;
}

/* ---------- Steps flow ---------- */
.steps-flow { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin: 28px 0; counter-reset: step; }
.steps-flow__item {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  padding: 30px 26px;
}
.steps-flow__num, .steps-flow__item .num {
  font-family: var(--font-serif); font-style: italic; font-size: 38px; color: var(--accent); line-height: 1;
  display: block; margin-bottom: 14px;
}

/* ---------- Topic cluster / related links ---------- */
.topic-cluster .card-grid { margin-top: 18px; }
.related-links a, .topic-cluster a:not(.btn) { font-weight: 600; }

/* ---------- Buttons: legacy modifiers ---------- */
.btn--full { width: 100%; }

/* ---------- Catalog (elektriker/) ---------- */
.catalog__list { display: grid; gap: 18px; margin: 24px 0; }
.catalog__firm, .listing {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  padding: 26px;
}
.catalog__firm h3 { font-family: var(--font-display); font-weight: 800; }

/* ---------- Author page ---------- */
.author-portrait { border-radius: 24px; box-shadow: var(--shadow-md); }
.article-card {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  padding: 24px; margin-bottom: 14px;
  transition: transform 0.4s var(--ease-spring), box-shadow 0.4s;
}
.article-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }

/* ---------- Blog archive (new hub) ---------- */
.archive { columns: 3; column-gap: 40px; margin-top: 12px; }
.archive a {
  display: block; padding: 7px 0; font-size: 14.5px; font-weight: 600;
  color: var(--ink-2); border-bottom: 1px solid var(--line);
  break-inside: avoid;
}
.archive a:hover { color: var(--accent-ink); }
.archive-letter {
  font-family: var(--font-serif); font-style: italic; font-size: 26px; color: var(--accent);
  margin: 18px 0 6px; break-after: avoid;
}

/* ---------- Inline figures ---------- */
.article-hero-figure { margin: 24px 0; border-radius: 18px; overflow: hidden; border: 1px solid var(--line); }

/* ---------- Responsive ---------- */
@media (max-width: 1040px) {
  .card-grid, .card-grid--3, .card-grid--4, .steps-flow { grid-template-columns: 1fr 1fr; }
  .archive { columns: 2; }
}
@media (max-width: 640px) {
  .card-grid, .card-grid--2, .card-grid--3, .card-grid--4, .steps-flow { grid-template-columns: 1fr; }
  .archive { columns: 1; }
  .legacy-content .section { padding: 56px 0; }
}

/* ============================================================
   COMPAT LAYER 2 — tokens + components used by generated
   article/service pages but never defined (2026-06 fix).
   ============================================================ */
:root {
  /* spacing scale (old koppar.css 4px scale) */
  --sp-1: 4px; --sp-2: 8px; --sp-3: 12px; --sp-4: 16px; --sp-5: 20px;
  --sp-6: 24px; --sp-8: 32px; --sp-10: 40px; --sp-12: 48px;
  --sp-16: 64px; --sp-20: 80px; --sp-24: 96px;
  /* type scale */
  --fs-sm: 14px; --fs-base: 16px; --fs-md: 17px; --fs-lg: 19px;
  --fs-xl: 22px; --fs-2xl: 28px; --fs-3xl: 36px;
  --lh-normal: 1.6; --lh-loose: 1.75;
  /* colours → v2 tokens */
  --clr-border: var(--line); --clr-border-faint: #f1f3f7;
  --clr-muted: var(--ink-3); --clr-text-hi: var(--ink);
  --clr-text-faint: var(--ink-3); --text-muted: var(--ink-3);
  --clr-base: var(--ink); --clr-white: #fff;
  --clr-surface-1: var(--surface); --clr-surface-2: #eef1f5;
  --clr-surface-3: #e6eaf0; --clr-surface-alt: var(--surface);
  --clr-bg-alt: var(--surface); --clr-bg-light: var(--surface);
  --clr-copper-dark: var(--accent-ink); --clr-copper-light: var(--accent-soft);
  --clr-success: #178a5e; --clr-error: #d33c3c;
  /* misc */
  --radius-sm: 8px; --radius-md: 12px; --radius-lg: 18px; --radius-xl: 24px;
  --ff-mono: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  --font-sans: var(--font-body);
  --nav-h: 80px;
}

/* ---------- statbar used outside the homepage hero ---------- */
/* generated pages wrap items in .wrap/.trust-bar__grid → flatten into the grid */
.statbar > .wrap, .statbar .trust-bar__grid { display: contents; }
/* …and they have no hero photo to overlap → cancel the -64px pull-up */
section.statbar { margin-top: 28px; margin-bottom: 8px; }

/* ---------- generic article typography ---------- */
.prose h2, .article-body h2 { font-family: var(--font-display); font-size: clamp(24px, 2.6vw, 32px); font-weight: 800; letter-spacing: -0.02em; margin: 36px 0 14px; }
.prose h3, .article-body h3 { font-family: var(--font-display); font-size: 20px; font-weight: 800; margin: 26px 0 10px; }
.prose p, .article-body p { margin-bottom: 16px; color: var(--ink-2); text-wrap: pretty; }
.prose ul, .prose ol, .article-body ul, .article-body ol { margin: 0 0 18px 22px; color: var(--ink-2); }
.prose li, .article-body li { margin-bottom: 8px; }
.lead { font-size: var(--fs-lg); color: var(--ink-2); line-height: 1.65; }
.h3 { font-family: var(--font-display); font-size: 20px; font-weight: 800; }
.h4 { font-family: var(--font-display); font-size: 17px; font-weight: 700; }
.text--copper, .text-copper { color: var(--accent-ink); }
.mono-tag { font-family: var(--ff-mono); font-size: 12px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent-ink); }
.section-header { margin-bottom: 32px; }
.section-alt, .info-section { background: var(--surface); padding: 56px 0; }
.article-hero { padding: 44px 0 20px; }
.hero__ctas, .btn-group { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 20px; }

/* ---------- grids ---------- */
.grid, .cards-grid, .steps-grid, .type-grid, .info-grid, .price-grid,
.lamp-grid, .zone-grid, .options-grid, .light-grid, .comparison-grid { display: grid; gap: 20px; margin: 20px 0; }
.grid--2, .cards-grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3, .cards-grid--3, .grid--4 { grid-template-columns: repeat(3, 1fr); }
@media (min-width: 980px) { .grid--4 { grid-template-columns: repeat(4, 1fr); } }

/* ---------- two-column article layouts ---------- */
.blog-layout, .content-grid, .prose-grid { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 44px; align-items: start; }
.blog-content, .content-main, .prose-main, .blog-sidebar, .content-sidebar, .prose-side { min-width: 0; }
.sidebar-card, .sidebar-widget { border: 1px solid var(--line); border-radius: var(--radius-lg); background: var(--surface); padding: 20px 22px; margin-bottom: 18px; }
.sidebar-widget__title { font-family: var(--font-display); font-weight: 800; font-size: 16px; margin-bottom: 10px; }

/* ---------- cards ---------- */
.card__desc, .card__text { color: var(--ink-2); font-size: 15px; }
.card__link, .card__cta { font-weight: 700; color: var(--accent-ink); text-decoration: none; }
.card__footer { margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--line); }
.card--feature, .card--highlight { background: var(--accent-soft); border-color: var(--accent-border); }
.card--dark { background: var(--navy); color: #fff; }
.card--dark p, .card--dark .card__desc { color: rgba(255,255,255,0.78); }
.price-card, .info-card, .type-card, .zone-card, .option-card, .step-card,
.scene-card, .lamp-card, .light-card, .related-card, .solution-card,
.requirement-card, .req-card, .system-card, .appliance-card, .layer-card,
.rot-card, .comparison-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 22px; }
.pc-label, .ic-label, .rc-label, .lc-label, .zc-label, .tc-label, .rl-label, .rot-calc-item .label { font-size: 12.5px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); }
.pc-value, .ic-value, .rc-value, .rot-calc-item .amount { font-family: var(--font-display); font-weight: 800; font-size: 26px; letter-spacing: -0.02em; margin: 4px 0; }
.pc-note, .ic-note, .price-note, .rot-calc-item .note { font-size: 13.5px; color: var(--ink-3); }
.rot-calc { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 14px; margin: 18px 0; }
.rot-calc-item { background: var(--accent-soft); border: 1px solid var(--accent-border); border-radius: var(--radius-md); padding: 16px 18px; }
.related-link { display: block; padding: 12px 2px; border-bottom: 1px solid var(--line); text-decoration: none; color: inherit; }
.rl-title { font-weight: 600; }

/* ---------- steps ---------- */
.steps-list, .step-list, .diagnostic-steps { display: grid; gap: 12px; margin: 18px 0; padding: 0; list-style: none; }
.step-item, .step-box { display: flex; gap: 14px; align-items: flex-start; background: var(--surface); border-radius: var(--radius-md); padding: 16px 18px; }
.step-num, .step-badge, .step__number, .card__step-num { flex: none; width: 34px; height: 34px; border-radius: 50%; background: var(--accent); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 15px; }
.step-content, .step__content, .step__body { min-width: 0; }
.step__title, .step-card__title { font-weight: 700; margin-bottom: 4px; }
.step-card__text { color: var(--ink-2); font-size: 15px; }

/* ---------- callout boxes ---------- */
.tip-box, .info-box, .rot-box, .highlight-box, .callout, .example-block, .timeline-box {
  background: var(--accent-soft); border: 1px solid var(--accent-border);
  border-radius: var(--radius-md); padding: 18px 20px; margin: 18px 0;
}
.warn-box, .warning-box { background: #fdf3e8; border: 1px solid #f1dcbf; border-radius: var(--radius-md); padding: 18px 20px; margin: 18px 0; }
.check-list, .checklist, .highlight-list { list-style: none; margin: 14px 0 18px; padding: 0; }
.check-list li, .checklist li, .highlight-list li { position: relative; padding-left: 26px; margin-bottom: 8px; }
.check-list li::before, .checklist li::before, .highlight-list li::before { content: "✓"; position: absolute; left: 0; font-weight: 800; color: var(--clr-success); }

/* ---------- FAQ ---------- */
.faq-section { padding: 24px 0 8px; }
.faq-list { display: grid; gap: 12px; margin: 18px 0; }
.faq-item, .faq__item { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-md); padding: 18px 20px; }
.faq-item__question, .faq__question, .faq-question { font-family: var(--font-display); font-weight: 800; font-size: 16.5px; margin-bottom: 6px; }
.faq-item__answer, .faq__answer, .faq-answer { color: var(--ink-2); }

/* ---------- tables ---------- */
.price-table, .spec-table, .comparison-table, .compare-table, .lux-table,
.material-table, .req-table, .symptom-table, .content-table, .proto-table { width: 100%; border-collapse: collapse; font-size: 15px; margin: 18px 0; }
.price-table th, .spec-table th, .comparison-table th, .compare-table th, .lux-table th,
.material-table th, .req-table th, .symptom-table th, .content-table th, .proto-table th { text-align: left; font-weight: 700; padding: 10px 12px; border-bottom: 2px solid var(--line); }
.price-table td, .spec-table td, .comparison-table td, .compare-table td, .lux-table td,
.material-table td, .req-table td, .symptom-table td, .content-table td, .proto-table td { padding: 10px 12px; border-bottom: 1px solid var(--line); color: var(--ink-2); }
.table-wrap, .table-responsive, .article__table-wrapper { overflow-x: auto; }

/* ---------- CTA boxes & banners ---------- */
.cta-box, .cta-block, .cta-banner, .cta-panel, .cta-section, .cta-band,
.inline-cta, .inline-cta-box, .cta-inline, .inline-quote-box, .newsletter-cta {
  background: var(--accent-soft); border: 1px solid var(--accent-border);
  border-radius: var(--radius); padding: 28px; margin: 26px 0;
}
.cta-box__title, .cta-banner__title, .cta-panel__title, .inline-cta-box__title, .inline-quote-box__title { font-family: var(--font-display); font-weight: 800; font-size: 21px; letter-spacing: -0.02em; margin-bottom: 8px; }
.cta-box__text, .cta-box__body, .cta-banner__text, .cta-panel__text, .cta-block__text, .cta-inline__text, .inline-quote-box__body { color: var(--ink-2); margin-bottom: 14px; }
.cta-box__eyebrow { font-size: 12.5px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent-ink); margin-bottom: 8px; }
.cta-box__actions, .cta-banner__actions, .cta-panel__actions, .cta-block__actions, .cta-inline__actions, .inline-cta-box__actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 16px; }
.cta-box--dark, .cta-box--copper { background: var(--navy); border-color: var(--navy); color: #fff; }
.cta-box--dark p, .cta-box--copper p, .cta-box--dark .cta-box__text, .cta-box--copper .cta-box__text { color: rgba(255,255,255,0.8); }
.badge--copper { background: var(--accent-soft); color: var(--accent-ink); border: 1px solid var(--accent-border); }

/* ---------- forms ---------- */
.quote-form, .contact-form, .offer-form, .sidebar-form, .newsletter-form { display: block; }
.form-row, .quote-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-group, .form__group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.form-group--checkbox { flex-direction: row; align-items: center; gap: 10px; }
.form-label, .form__label { font-size: 14px; font-weight: 600; color: var(--ink); }
.form-input, .form-select, .form-control, .form-textarea, .form__input {
  width: 100%; padding: 12px 14px; font: inherit; color: var(--ink);
  background: #fff; border: 1px solid var(--line); border-radius: 10px;
}
.form-input:focus, .form-select:focus, .form-control:focus, .form-textarea:focus, .form__input:focus { outline: 2px solid var(--accent); outline-offset: 1px; border-color: var(--accent); }
.btn-primary, .btn-copper, .cta-btn, .btn-submit, .submit-btn, .form-submit {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 13px 24px; border: 0; border-radius: 999px; cursor: pointer;
  background: var(--accent); color: #fff; font: 700 15px var(--font-body);
  text-decoration: none;
}
.btn-primary:hover, .btn-copper:hover, .cta-btn:hover, .btn-submit:hover, .submit-btn:hover, .form-submit:hover { background: var(--accent-ink); }
.btn--secondary, .btn-secondary { background: #fff; color: var(--ink); border: 1px solid var(--line); }
.btn--large, .btn--xl { padding: 15px 30px; font-size: 16px; }
.btn-small { padding: 9px 16px; font-size: 14px; }

/* ---------- misc ---------- */
.footer__link { color: inherit; text-decoration: none; }
.footer__link:hover { color: #fff; }
.breadcrumb__item--current, .breadcrumb__current { color: var(--accent-ink); }
.breadcrumb__sep { color: var(--ink-3); margin: 0 6px; }

/* ---------- responsive collapse ---------- */
@media (max-width: 860px) {
  .blog-layout, .content-grid, .prose-grid { grid-template-columns: 1fr; }
  .grid--3, .grid--4, .cards-grid--3 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .grid--2, .grid--3, .grid--4, .cards-grid--2, .cards-grid--3, .form-row, .quote-form__row { grid-template-columns: 1fr; }
}

/* ---------- compat pass 3: FAQ short names, catalog, section-split ---------- */
.faq__q { font-family: var(--font-display); font-weight: 800; font-size: 16.5px; margin-bottom: 6px; }
.faq__a { color: var(--ink-2); }
.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.section-split { display: grid; grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr); gap: 40px; align-items: start; }
.info-box__title { font-weight: 800; font-family: var(--font-display); margin-bottom: 8px; }
.info-box__list { margin: 0 0 0 20px; color: var(--ink-2); }
.steps-flow__title { font-weight: 700; margin-bottom: 4px; }
.steps-flow__text, .steps-flow__content { color: var(--ink-2); font-size: 15px; }
.step-dot { flex: none; width: 12px; height: 12px; border-radius: 50%; background: var(--accent); margin-top: 6px; }
.card--blog { display: flex; flex-direction: column; }
.card--step { position: relative; }
.inline-cta-box__content, .cta-box__content, .inline-cta__content { min-width: 0; }
.cta-box__form { margin-top: 14px; }
.container { width: min(1140px, 100% - 48px); margin-inline: auto; }

/* catalog (national directory) */
.catalog__eyebrow { font-size: 12.5px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent-ink); margin-bottom: 6px; }
.catalog__city-grid, .catalog__electrician-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin: 22px 0; }
.catalog__city-card, .catalog__electrician-card { display: block; background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 20px; text-decoration: none; color: inherit; }
.catalog__city-card:hover { border-color: var(--accent-border); box-shadow: var(--shadow-sm); }
.catalog__city-name, .catalog__electrician-name { font-family: var(--font-display); font-weight: 800; font-size: 17px; }
.catalog__city-region, .catalog__electrician-address { font-size: 13.5px; color: var(--ink-3); }
.catalog__city-meta, .catalog__city-count, .catalog__electrician-desc { font-size: 14px; color: var(--ink-2); margin-top: 6px; }
.catalog__electrician-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.catalog__electrician-tag, .catalog__electrician-badge { font-size: 12.5px; font-weight: 600; background: var(--surface); border: 1px solid var(--line); border-radius: 999px; padding: 4px 10px; }
.catalog__electrician-actions { margin-top: 14px; display: flex; gap: 10px; flex-wrap: wrap; }
.catalog__lead-box { background: var(--accent-soft); border: 1px solid var(--accent-border); border-radius: var(--radius); padding: 24px; margin: 24px 0; }
.catalog__services { display: flex; flex-wrap: wrap; gap: 8px; margin: 14px 0; }
.catalog__disclaimer { font-size: 13px; color: var(--ink-3); margin-top: 20px; }
.catalog__map { border-radius: var(--radius-lg); overflow: hidden; margin: 18px 0; }

@media (max-width: 860px) {
  .section-split, .catalog__city-grid, .catalog__electrician-grid { grid-template-columns: 1fr; }
  .catalog__city-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .catalog__city-grid { grid-template-columns: 1fr; }
  .form__row { grid-template-columns: 1fr; }
}
.section-split__text, .section-split__aside { min-width: 0; }
.catalog__region-card { display: block; background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 20px; text-decoration: none; color: inherit; }
.catalog__region-name { font-family: var(--font-display); font-weight: 800; font-size: 17px; }
.catalog__region-meta { font-size: 14px; color: var(--ink-2); margin-top: 6px; }
