/**
 * Pretcurent Outage Pages — shortcode component styles.
 *
 * All values derived from the Pretcurent design system:
 *   Typography: Manrope (headings, 600), Inter (body, 400)
 *   Colors: --color-ink, --color-primary, --color-body, --color-dark-muted
 *   Spacing: --space-xxs (8px) … --space-xxl (80px)
 *   Radius: --radius-sm (8px), --radius-md (16px), --radius-lg (24px)
 *   Borders: --color-card-border (#CDDBFA), --color-faq-divider (#E2E8F0)
 */

/* ─── Stats (renders inside blue hero — white text) ─── */
.pcp-stats {
  display: flex;
  gap: var(--space-l, 48px);
  flex-wrap: wrap;
  padding: var(--space-m, 32px) 0 0;
}
.pcp-stats__item {
  display: flex;
  flex-direction: column;
  gap: var(--space-xxs, 8px);
}
.pcp-stats__value {
  font-family: 'Manrope', sans-serif;
  font-size: 4.2rem;
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--color-white, #FFFFFF);
}
.pcp-stats__label {
  font-family: 'Inter', sans-serif;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.7);
}
@media (max-width: 767px) {
  .pcp-stats {
    gap: var(--space-s, 24px);
  }
  .pcp-stats__value {
    font-size: 3.2rem;
  }
  .pcp-stats__label {
    font-size: 1.4rem;
  }
}

/* ─── Pillar-only adjustments ───────────────────────────────────────── */
/* sec_dso (DSO contact card) renders empty on the pillar because the card
   shortcode has no specific county to resolve. Without this rule, the
   section's 80px top + 80px bottom padding shows up as a phantom 160px gap. */
body.pcp-type-pillar #brxe-sec_dso {
  display: none;
}

/* ─── Outage table ─── */
.pcp-table {
  border: 1px solid var(--color-card-border, #CDDBFA);
  border-radius: var(--radius-md, 16px);
  overflow: hidden;
  background: var(--color-white, #FFFFFF);
}
.pcp-table--empty {
  padding: var(--space-l, 48px);
  text-align: center;
}
.pcp-table__empty {
  font-family: 'Inter', sans-serif;
  font-size: 1.5rem;
  color: var(--color-dark-muted, #64748B);
  font-style: italic;
  margin: 0;
}
.pcp-table__fallback-note {
  font-family: 'Inter', sans-serif;
  font-size: 1.4rem;
  color: var(--color-dark-muted, #64748B);
  margin: 0;
  padding: 1.6rem 2rem;
  background: #F8F9FC;
  border-bottom: 1px solid var(--color-card-border, #CDDBFA);
}
.pcp-table--fallback .pcp-table__fallback-note {
  display: block;
}

/* ─── Planned outages (DSO official feed) ─── */
.pcp-planned-outages {
  border: 1px solid var(--color-card-border, #CDDBFA);
  border-radius: var(--radius-md, 16px);
  overflow: hidden;
  background: var(--color-white, #FFFFFF);
  font-family: 'Inter', sans-serif;
}
.pcp-planned-outages__empty {
  padding: var(--space-l, 32px);
  text-align: center;
  color: var(--color-dark-muted, #64748B);
}
.pcp-planned-outages__empty-text {
  font-size: 1.5rem;
  margin: 0 0 1.2rem;
}
.pcp-planned-outages__dso-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 600;
  font-size: 1.4rem;
  color: var(--color-primary, #3B5BDB);
  text-decoration: none;
}
.pcp-planned-outages__dso-link:hover {
  text-decoration: underline;
}
.pcp-planned-outages__grid {
  width: 100%;
  border-collapse: collapse;
  font-size: 1.4rem;
}
.pcp-planned-outages__grid thead th {
  background: #F8F9FC;
  font-weight: 600;
  color: var(--color-ink, #0F172A);
  text-align: left;
  padding: 1.2rem 1.6rem;
  border-bottom: 1px solid var(--color-card-border, #CDDBFA);
  font-size: 1.2rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.pcp-planned-outages__grid tbody td {
  padding: 1.2rem 1.6rem;
  border-bottom: 1px solid #E2E8F0;
  vertical-align: top;
  color: #475569;
  line-height: 1.5;
}
.pcp-planned-outages__grid tbody tr:last-child td {
  border-bottom: none;
}
.pcp-planned-outages__type {
  display: inline-block;
  font-size: 1.1rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  padding: 2px 8px;
  border-radius: 100px;
  white-space: nowrap;
}
.pcp-planned-outages__type--planned {
  background: #DBEAFE;
  color: #1E40AF;
}
.pcp-planned-outages__type--accidental {
  background: #FEE2E2;
  color: #991B1B;
}
.pcp-planned-outages__source {
  font-size: 1.2rem;
  color: var(--color-dark-muted, #64748B);
  margin: 0;
  padding: 1.2rem 1.6rem;
  background: #F8F9FC;
  border-top: 1px solid var(--color-card-border, #CDDBFA);
}

/* National (pillar) view — summary + per-DSO blocks */
.pcp-planned-outages--national {
  background: transparent;
  border: none;
  border-radius: 0;
  overflow: visible;
}
.pcp-planned-outages__summary {
  display: grid;
  grid-template-columns: minmax(160px, 1fr) 2fr;
  gap: 2.4rem;
  align-items: center;
  padding: 2.4rem 2.4rem;
  background: linear-gradient(180deg, #F8F9FC 0%, #FFFFFF 100%);
  border: 1px solid var(--color-card-border, #CDDBFA);
  border-radius: var(--radius-md, 16px);
  margin-bottom: 2.4rem;
}
.pcp-planned-outages__summary-total {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.pcp-planned-outages__summary-num {
  font-family: 'Plus Jakarta Sans', 'Manrope', sans-serif;
  font-size: 4.4rem;
  font-weight: 700;
  line-height: 1;
  color: var(--color-primary, #3B5BDB);
}
.pcp-planned-outages__summary-label {
  font-size: 1.4rem;
  color: #475569;
  line-height: 1.4;
}
.pcp-planned-outages__summary-dsos {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.2rem;
}
.pcp-planned-outages__summary-dsos li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.2rem;
  padding: 1rem 1.4rem;
  background: #FFFFFF;
  border: 1px solid #E2E8F0;
  border-radius: 12px;
}
.pcp-planned-outages__summary-dso-name {
  font-size: 1.3rem;
  color: #0F172A;
  font-weight: 500;
  line-height: 1.3;
}
.pcp-planned-outages__summary-dso-count {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--color-primary, #3B5BDB);
  background: #EFF4FF;
  padding: 0.2rem 1rem;
  border-radius: 100px;
  min-width: 36px;
  text-align: center;
}

.pcp-planned-outages__dso-block {
  background: #FFFFFF;
  border: 1px solid var(--color-card-border, #CDDBFA);
  border-radius: var(--radius-md, 16px);
  margin-bottom: 2rem;
  overflow: hidden;
}
.pcp-planned-outages__dso-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.2rem;
  padding: 1.6rem 2rem;
  background: #F8F9FC;
  border-bottom: 1px solid var(--color-card-border, #CDDBFA);
}
.pcp-planned-outages__dso-title {
  margin: 0;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.7rem;
  font-weight: 600;
  color: #0F172A;
}
.pcp-planned-outages__dso-pill {
  background: #EFF4FF;
  color: #1E3A8A;
  font-size: 1.2rem;
  font-weight: 600;
  padding: 0.4rem 1rem;
  border-radius: 100px;
  white-space: nowrap;
}
.pcp-planned-outages__dso-block .pcp-planned-outages__grid thead th {
  background: #FFFFFF;
}
.pcp-planned-outages__dso-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.2rem;
  padding: 1.2rem 2rem;
  background: #F8F9FC;
  border-top: 1px solid var(--color-card-border, #CDDBFA);
  font-size: 1.3rem;
  color: var(--color-dark-muted, #64748B);
  margin: 0;
  flex-wrap: wrap;
}
.pcp-planned-outages__dso-more {
  font-style: italic;
}
.pcp-planned-outages__dso-block .pcp-planned-outages__dso-link {
  font-weight: 600;
  font-size: 1.3rem;
}

@media (max-width: 767px) {
  .pcp-planned-outages__summary {
    grid-template-columns: 1fr;
    gap: 1.6rem;
  }
  .pcp-planned-outages__summary-num {
    font-size: 3.6rem;
  }
}
@media (max-width: 640px) {
  .pcp-planned-outages__grid thead { display: none; }
  .pcp-planned-outages__grid tbody td {
    display: block;
    padding: 0.8rem 1.6rem;
    border-bottom: none;
  }
  .pcp-planned-outages__grid tbody tr {
    display: block;
    padding: 1.2rem 0;
    border-bottom: 1px solid #E2E8F0;
  }
  .pcp-planned-outages__grid tbody tr:last-child {
    border-bottom: none;
  }
  .pcp-planned-outages__grid tbody td:nth-child(1)::before { content: 'Data: '; font-weight: 600; color: #0F172A; }
  .pcp-planned-outages__grid tbody td:nth-child(2)::before { content: 'Interval: '; font-weight: 600; color: #0F172A; }
  .pcp-planned-outages__grid tbody td:nth-child(3)::before { content: 'Localitate: '; font-weight: 600; color: #0F172A; }
  .pcp-planned-outages__grid tbody td:nth-child(4)::before { content: 'Adrese: '; font-weight: 600; color: #0F172A; }
}
.pcp-table__grid {
  width: 100%;
  border-collapse: collapse;
  font-family: 'Inter', sans-serif;
  font-size: 1.4rem;
}
.pcp-table__grid thead {
  background: var(--color-slate-tint, #F1F4FA);
}
.pcp-table__grid th,
.pcp-table__grid td {
  padding: var(--space-xs, 16px) var(--space-s, 24px);
  text-align: left;
  border-bottom: 1px solid var(--color-faq-divider, #E2E8F0);
}
.pcp-table__grid th {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 1.2rem;
  color: var(--color-dark-muted, #64748B);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.pcp-table__grid td {
  color: var(--color-body, #475569);
  line-height: 1.5;
}
.pcp-table__grid tbody tr:last-child td {
  border-bottom: 0;
}

/* ─── Source dot prefix (v1.8.9) ──────────────────────────────────────────
   Small colored circle before the locality name. Color matches the map's
   marker layer so the table reads as a continuation of the map legend:
     • red    → user-reported outage
     • orange → DSO accidental
     • blue   → DSO planned
   No text label needed — the dot is decorative (`aria-hidden`) and the row
   `_source` class is available for any future a11y / styling needs. */
.pcp-table__dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 8px;
  vertical-align: middle;
  flex-shrink: 0;
  /* Slight outline matches the map's marker stroke convention so the dot
     reads as a "marker preview" rather than a generic bullet. */
  box-shadow: 0 0 0 1.5px rgba(0, 0, 0, 0.06) inset;
}

/* "Actualizat: 7 mai 2026, 16:30" line below the outage table when DSO data
   is the source. Quiet styling — visitors who want it find it, others scan
   past. Mirrors `.pcp-pl__source` color rhythm to feel like one system
   across both surfaces (table + timeline). */
.pcp-table__updated {
  margin: 12px 0 0;
  padding: 0 4px;
  font-family: 'Inter', sans-serif;
  font-size: 1.2rem;
  color: var(--color-dark-muted, #64748B);
  text-align: right;
}
@media (max-width: 480px) {
  .pcp-table__updated {
    text-align: left;
    font-size: 1.15rem;
  }
}
@media (max-width: 767px) {
  .pcp-table__grid th:nth-child(3),
  .pcp-table__grid td:nth-child(3) {
    display: none;
  }
  .pcp-table__grid th,
  .pcp-table__grid td {
    padding: var(--space-xs, 16px);
    font-size: 1.3rem;
  }
}

/* ─── DSO emergency contact card (redesigned v1.1.11) ─── */
/* Single-card civic-utility layout. Internal zones separated by hairline rules,
   not nested borders. Off-white surface for paper-like feel. Phone CTA gets the
   visual weight; helpers grid carries supporting service info. */

.pcp-dso-card {
  --dso-bg: #FAFAF7;
  --dso-ink: #0F172A;
  --dso-muted: #475569;
  --dso-line: #E2E8F0;
  --dso-blue: #3B5BDB;
  --dso-red: #C13C3C;
  --dso-red-2: #DC2626;

  background: var(--dso-bg);
  border: 1px solid var(--dso-line);
  border-radius: 20px;
  padding: clamp(2.4rem, 4vw, 4.8rem);
  max-width: 72rem;
  margin: 0 auto;
  font-family: 'Inter', sans-serif;
  color: var(--dso-ink);
  box-shadow:
    0 1px 0 rgba(15, 23, 42, 0.04),
    0 24px 48px -32px rgba(15, 23, 42, 0.18);
}

/* Zone 1 — head */
.pcp-dso-card__head { text-align: center; }

.pcp-dso-card__eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: 1.1rem;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--dso-blue);
  margin: 0 0 1.6rem;
}

.pcp-dso-card__title {
  font-family: 'Manrope', sans-serif;
  font-size: clamp(2.6rem, 3.2vw, 3.6rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.015em;
  color: var(--dso-ink);
  margin: 0 0 1.2rem;
}

.pcp-dso-card__lede {
  font-family: 'Inter', sans-serif;
  font-size: 1.55rem;
  font-weight: 400;
  line-height: 1.55;
  color: var(--dso-muted);
  max-width: 52ch;
  margin: 0 auto;
}

.pcp-dso-card__rule {
  border: 0;
  height: 1px;
  background: var(--dso-line);
  margin: clamp(2.4rem, 3vw, 3.6rem) 0;
}

/* Zone 2 — operator + phone */
.pcp-dso-card__action { text-align: center; }

.pcp-dso-card__operator-label {
  font-family: 'Inter', sans-serif;
  font-size: 1.1rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--dso-muted);
  margin: 0 0 0.8rem;
}

.pcp-dso-card__operator-name {
  font-family: 'Manrope', sans-serif;
  font-size: 2rem;
  font-weight: 800;
  font-style: italic;
  line-height: 1.2;
  color: var(--dso-ink);
  margin: 0 0 2.4rem;
}

.pcp-dso-card__phone {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 1.2rem 1.6rem;

  background: linear-gradient(180deg, var(--dso-red-2), var(--dso-red));
  color: #FFFFFF;
  text-decoration: none;
  padding: 2rem 2.8rem;
  border-radius: 14px;
  width: 100%;
  max-width: 48rem;
  margin: 0 auto;

  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 1px 0 rgba(0, 0, 0, 0.04),
    0 16px 32px -16px rgba(193, 60, 60, 0.45);
  transition: transform 120ms ease, box-shadow 120ms ease;
}
.pcp-dso-card__phone:hover {
  transform: translateY(-1px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.22),
    0 2px 0 rgba(0, 0, 0, 0.04),
    0 24px 40px -16px rgba(193, 60, 60, 0.55);
}
.pcp-dso-card__phone:focus-visible {
  outline: 3px solid #1d4ed8;
  outline-offset: 4px;
}

.pcp-dso-card__phone-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  line-height: 1;
}

.pcp-dso-card__phone-number {
  font-family: 'Manrope', sans-serif;
  font-size: clamp(2.4rem, 3.6vw, 3.4rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.01em;
  font-variant-numeric: tabular-nums;
}

.pcp-dso-card__phone-meta {
  font-family: 'Inter', sans-serif;
  font-size: 1.1rem;
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  opacity: 0.92;
  width: 100%;
  text-align: center;
}
.pcp-dso-card__phone-meta::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #FFFFFF;
  margin-right: 0.8rem;
  vertical-align: middle;
  animation: pcpLivePulse 1.6s ease-in-out infinite;
}
@keyframes pcpLivePulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%      { transform: scale(1.6); opacity: 0.5; }
}
@media (prefers-reduced-motion: reduce) {
  .pcp-dso-card__phone-meta::before { animation: none; }
}

/* Zone 3 — helper grid */
.pcp-dso-card__helpers {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem 3.2rem;
  list-style: none;
  padding: 0;
  margin: 0;
}
@media (min-width: 720px) {
  .pcp-dso-card__helpers { grid-template-columns: repeat(4, 1fr); }
}

.pcp-dso-helper {
  position: relative;
  padding-left: 2.6rem;
}

.pcp-dso-helper__glyph {
  position: absolute;
  left: 0;
  top: 0.2rem;
  font-size: 1.6rem;
  line-height: 1;
  color: var(--dso-blue);
}

.pcp-dso-helper__label {
  font-family: 'Inter', sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dso-ink);
  margin: 0 0 0.6rem;
}

.pcp-dso-helper__body,
.pcp-dso-helper__link {
  font-family: 'Inter', sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.55;
  color: var(--dso-muted);
  margin: 0;
}

.pcp-dso-helper__link {
  color: var(--dso-blue);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  font-weight: 600;
}
.pcp-dso-helper__link:hover { text-decoration-thickness: 2px; }

/* Zone 4 — trust footnote */
.pcp-dso-card__foot {
  margin: clamp(2.4rem, 3vw, 3.6rem) 0 0;
  padding-top: 1.6rem;
  border-top: 1px dashed var(--dso-line);
  font-family: 'Inter', sans-serif;
  font-size: 1.15rem;
  font-weight: 400;
  line-height: 1.45;
  color: var(--dso-muted);
  text-align: center;
}

/* ─── DSO directory grid ─── */
.pcp-dso-directory {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-s, 24px);
}
.pcp-dso-directory__card {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs, 16px);
  padding: var(--space-s, 24px);
  border: 1px solid var(--color-card-border, #CDDBFA);
  border-radius: var(--radius-md, 16px);
  background: var(--color-white, #FFFFFF);
  transition: border-color 0.2s ease;
}
.pcp-dso-directory__card:hover {
  border-color: var(--color-primary, #3B5BDB);
}
.pcp-dso-directory__name {
  margin: 0;
  font-family: 'Manrope', sans-serif;
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--color-ink, #0F172A);
  line-height: 1.3;
}
.pcp-dso-directory__coverage {
  margin: 0;
  font-family: 'Inter', sans-serif;
  font-size: 1.3rem;
  color: var(--color-dark-muted, #64748B);
  line-height: 1.5;
}
.pcp-dso-directory__phone {
  margin: 0;
  font-family: 'Manrope', sans-serif;
  font-size: 1.5rem;
}
.pcp-dso-directory__phone a {
  color: #DC2626;
  font-weight: 700;
  text-decoration: none;
  font-variant-numeric: tabular-nums;
}
.pcp-dso-directory__phone a:hover {
  text-decoration: underline;
}
.pcp-dso-directory__link {
  margin-top: auto;
  align-self: flex-start;
  font-family: 'Inter', sans-serif;
  font-size: 1.4rem;
  color: var(--color-primary, #3B5BDB);
  font-weight: 600;
  text-decoration: none;
}
.pcp-dso-directory__link:hover {
  text-decoration: underline;
}

/* ─── Cities pill card ─── */
.pcp-cities-card {
  background: var(--color-slate-tint, #F1F4FA);
  border: 1px solid var(--color-faq-divider, #E2E8F0);
  border-radius: var(--radius-md, 16px);
  padding: var(--space-s, 24px);
}
.pcp-cities-card__header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: var(--space-xs, 16px);
}
.pcp-cities-card__icon {
  color: var(--color-primary, #3B5BDB);
  flex-shrink: 0;
}
.pcp-cities-card__title {
  margin: 0;
  font-family: 'Inter', sans-serif;
  font-size: 1.2rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-dark-muted, #64748B);
}
.pcp-cities-card__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.pcp-cities-card__pill {
  display: inline-flex;
  align-items: center;
  padding: 8px 16px;
  background: var(--color-white, #FFFFFF);
  border: 1px solid var(--color-faq-divider, #E2E8F0);
  border-radius: var(--radius-pill, 100px);
  font-family: 'Inter', sans-serif;
  font-size: 1.4rem;
  font-weight: 500;
  color: var(--color-ink, #0F172A);
  text-decoration: none;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
}
.pcp-cities-card__pill:hover {
  border-color: var(--color-primary, #3B5BDB);
  color: var(--color-primary, #3B5BDB);
  background: #EEF1FF;
}

/* ─── Counties accordion ─── */
.pcp-counties-accordion__title {
  margin: 0 0 var(--space-s, 24px);
  font-family: 'Manrope', sans-serif;
  font-size: 1.8rem;
  font-weight: 600;
  color: var(--color-ink, #0F172A);
  letter-spacing: -0.01em;
}
.pcp-counties-accordion__search {
  position: relative;
  margin-bottom: var(--space-s, 24px);
}
.pcp-counties-accordion__search-icon {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-dark-muted, #64748B);
  pointer-events: none;
}
.pcp-counties-accordion__input {
  width: 100%;
  padding: 14px 48px 14px 48px;
  border: 1px solid var(--color-faq-divider, #E2E8F0);
  border-radius: var(--radius-sm, 8px);
  font-family: 'Inter', sans-serif;
  font-size: 1.5rem;
  color: var(--color-ink, #0F172A);
  background: var(--color-white, #FFFFFF);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
  box-sizing: border-box;
}
.pcp-counties-accordion__input:focus {
  border-color: var(--color-primary, #3B5BDB);
  box-shadow: 0 0 0 3px rgba(59, 91, 219, 0.12);
}
.pcp-counties-accordion__input::placeholder {
  color: var(--color-dark-muted, #64748B);
}
.pcp-counties-accordion__clear {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  font-size: 2rem;
  color: var(--color-dark-muted, #64748B);
  cursor: pointer;
  padding: 4px 8px;
  line-height: 1;
  display: none;
}
.pcp-counties-accordion__clear:hover {
  color: var(--color-ink, #0F172A);
}
.pcp-counties-accordion__region {
  border: 1px solid var(--color-faq-divider, #E2E8F0);
  border-radius: var(--radius-sm, 8px);
  margin-bottom: 8px;
  background: var(--color-white, #FFFFFF);
  overflow: hidden;
  transition: border-color 0.15s;
}
.pcp-counties-accordion__region:hover {
  border-color: #CBD5E1;
}
.pcp-counties-accordion__region[open] {
  border-color: var(--color-card-border, #CDDBFA);
}
.pcp-counties-accordion__header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  cursor: pointer;
  list-style: none;
  user-select: none;
}
.pcp-counties-accordion__header::-webkit-details-marker { display: none; }
.pcp-counties-accordion__header::marker { display: none; content: ''; }
.pcp-counties-accordion__region-name {
  font-family: 'Inter', sans-serif;
  font-size: 1.3rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-ink, #0F172A);
}
.pcp-counties-accordion__count {
  font-family: 'Inter', sans-serif;
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--color-dark-muted, #64748B);
  margin-left: auto;
}
.pcp-counties-accordion__header::after {
  content: '';
  width: 8px;
  height: 8px;
  border-right: 2px solid var(--color-dark-muted, #64748B);
  border-bottom: 2px solid var(--color-dark-muted, #64748B);
  transform: rotate(45deg);
  transition: transform 0.2s ease;
  flex-shrink: 0;
}
.pcp-counties-accordion__region[open] > .pcp-counties-accordion__header::after {
  transform: rotate(-135deg);
}
.pcp-counties-accordion__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 4px 20px 20px;
}
.pcp-counties-accordion__pill {
  display: inline-flex;
  align-items: center;
  padding: 8px 16px;
  background: var(--color-slate-tint, #F1F4FA);
  border: 1px solid transparent;
  border-radius: var(--radius-pill, 100px);
  font-family: 'Inter', sans-serif;
  font-size: 1.4rem;
  font-weight: 500;
  color: var(--color-ink, #0F172A);
  text-decoration: none;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.pcp-counties-accordion__pill:hover {
  background: #EEF1FF;
  border-color: var(--color-primary, #3B5BDB);
  color: var(--color-primary, #3B5BDB);
}
@media (max-width: 767px) {
  .pcp-counties-accordion__pills {
    padding: 4px 16px 16px;
  }
  .pcp-counties-accordion__pill {
    padding: 7px 14px;
    font-size: 1.3rem;
  }
  .pcp-cities-card__pill {
    padding: 7px 14px;
    font-size: 1.3rem;
  }
}

/* ─── Diagnostic block ─── */
.pcp-diagnostic {
  padding: var(--space-s, 24px);
  background: var(--color-white, #FFFFFF);
  border-radius: var(--radius-md, 16px);
  border: 1px solid var(--color-card-border, #CDDBFA);
  border-left: 4px solid var(--color-primary, #3B5BDB);
}
.pcp-diagnostic__title {
  margin: 0 0 var(--space-xs, 16px);
  font-family: 'Manrope', sans-serif;
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--color-ink, #0F172A);
  line-height: 1.3;
}
.pcp-diagnostic__intro {
  margin: 0 0 var(--space-s, 24px);
  font-family: 'Inter', sans-serif;
  font-size: 1.4rem;
  color: var(--color-dark-muted, #64748B);
  line-height: 1.6;
}
.pcp-diagnostic__steps {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs, 16px);
  margin: 0;
  padding-left: 2rem;
  font-family: 'Inter', sans-serif;
  font-size: 1.4rem;
  color: var(--color-body, #475569);
  line-height: 1.6;
}
.pcp-diagnostic__steps li strong {
  display: block;
  margin-bottom: 4px;
  font-family: 'Manrope', sans-serif;
  color: var(--color-ink, #0F172A);
}

/* ─── Safety tips ─── */
.pcp-safety-tips {
  padding: var(--space-s, 24px);
  background: var(--color-white, #FFFFFF);
  border-radius: var(--radius-md, 16px);
  border: 1px solid var(--color-card-border, #CDDBFA);
  border-left: 4px solid #F59E0B;
}
.pcp-safety-tips__title {
  margin: 0 0 var(--space-s, 24px);
  font-family: 'Manrope', sans-serif;
  font-size: 1.5rem;
  font-weight: 600;
  color: #92400E;
  line-height: 1.3;
}
.pcp-safety-tips__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-xs, 16px);
}
.pcp-safety-tips__list > li {
  position: relative;
  padding-left: 2.4rem;
  font-family: 'Inter', sans-serif;
  font-size: 1.4rem;
  color: var(--color-body, #475569);
  line-height: 1.6;
}
.pcp-safety-tips__list > li::before {
  content: "\2713";
  position: absolute;
  left: 0;
  top: 0;
  color: #F59E0B;
  font-weight: 700;
  font-size: 1.4rem;
}
.pcp-safety-tips__list > li strong {
  display: block;
  margin-bottom: 4px;
  font-family: 'Manrope', sans-serif;
  color: #92400E;
}

/* ─── Compensation rules ─── */
.pcp-compensation {
  padding: var(--space-s, 24px);
  border: 1px solid var(--color-card-border, #CDDBFA);
  border-radius: var(--radius-md, 16px);
  background: var(--color-white, #FFFFFF);
}
.pcp-compensation__title {
  margin: 0 0 var(--space-xs, 16px);
  font-family: 'Manrope', sans-serif;
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--color-ink, #0F172A);
  line-height: 1.3;
}
.pcp-compensation__intro {
  margin: 0 0 var(--space-s, 24px);
  font-family: 'Inter', sans-serif;
  font-size: 1.4rem;
  color: var(--color-dark-muted, #64748B);
  line-height: 1.6;
}
.pcp-compensation__grid {
  width: 100%;
  border-collapse: collapse;
  font-family: 'Inter', sans-serif;
  font-size: 1.3rem;
}
.pcp-compensation__grid th,
.pcp-compensation__grid td {
  padding: var(--space-xs, 16px);
  text-align: left;
  border-bottom: 1px solid var(--color-faq-divider, #E2E8F0);
  vertical-align: top;
}
.pcp-compensation__grid th {
  background: var(--color-slate-tint, #F1F4FA);
  font-weight: 600;
  font-size: 1.2rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-dark-muted, #64748B);
}
.pcp-compensation__grid td {
  color: var(--color-body, #475569);
  line-height: 1.5;
}
.pcp-compensation__list {
  margin: 0;
  padding-left: 2rem;
  display: flex;
  flex-direction: column;
  gap: var(--space-xs, 16px);
  font-family: 'Inter', sans-serif;
  font-size: 1.4rem;
  color: var(--color-body, #475569);
  line-height: 1.6;
}
/* v1.9.29 — bg flipped from yellow (#FFFBEB) to royal blue (brand primary)
 * + text flipped from dark amber to white. Per site-owner direction
 * 2026-05-09 — the warning panel reads as a brand-primary callout instead
 * of a "warning" pattern, since the content is informational (compensation
 * eligibility rules), not a system warning. */
.pcp-compensation__note {
  margin: var(--space-s, 24px) 0 0;
  padding: var(--space-xs, 16px) var(--space-s, 24px);
  background: #3B5BDB;
  border-radius: var(--radius-sm, 8px);
  font-family: 'Inter', sans-serif;
  font-size: 1.3rem;
  color: #FFFFFF;
  line-height: 1.5;
}

/* v1.9.29 — fallback note (the "no user reports, here's the DSO data"
 * paragraph) centered on the page so it reads as a section intro rather
 * than a left-aligned afterthought. Used by the national fallback in
 * render_outage_table. */
.pcp-table__fallback-note {
  text-align: center;
}

/* ─── FAQ accordion (matched to homepage accordion) ─── */
.pcp-faq {
  display: flex;
  flex-direction: column;
}
.pcp-faq__item {
  border-bottom: 1px solid #E2E8F0;
  padding: 2rem 0;
}
.pcp-faq__item:last-child {
  border-bottom: none;
}
.pcp-faq__question {
  padding: 1.5rem 4rem 1.5rem 0;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600;
  font-size: clamp(1.7rem, 1.6rem + 0.3vw, 2rem);
  color: var(--color-ink, #0F172A);
  cursor: pointer;
  list-style: none;
  position: relative;
  user-select: none;
  line-height: 1.4;
  text-align: left;
}
.pcp-faq__question::-webkit-details-marker {
  display: none;
}
.pcp-faq__question::after {
  content: "+";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.8rem;
  font-weight: 300;
  color: #3B5BDB;
  line-height: 1;
  flex-shrink: 0;
}
.pcp-faq__item[open] .pcp-faq__question::after {
  content: "\2212";
}
.pcp-faq__answer {
  padding-top: 1.2rem;
  font-family: 'DM Sans', sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  color: #475569;
  line-height: 1.7;
  text-align: left;
}
@media (max-width: 767px) {
  .pcp-faq__question {
    font-size: 1.7rem;
  }
}

/* ─── Expert byline trust bar ─── */
.pcp-byline-bar {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  padding: 2.4rem 0 0;
  margin-top: 2rem;
  border-top: 1px solid #E2E8F0;
}
.pcp-byline-bar img {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.pcp-byline-bar__text {
  font-family: 'DM Sans', sans-serif;
  font-size: 1.4rem;
  color: #94A3B8;
  line-height: 1.4;
}
.pcp-byline-bar__text a {
  color: #475569;
  font-weight: 600;
  text-decoration: none;
}
.pcp-byline-bar__text a:hover {
  color: #3B5BDB;
}

/* ─── Hash-anchor highlight on outage table rows (v1.7.0) ──────────── */
/*
 * When a user lands on /pana-de-curent/{county}/#pcp-report-{id} after
 * submitting a report, outage-pages.js scrolls the matching <tr> into
 * view and adds .pcp-table__row--highlight for 4 seconds. The flash
 * animates from a warm yellow into transparent so it reads on top of
 * any <td> background, plus a 4px brand-blue rule on the leading cell
 * so the eye locks onto the right row even after the flash fades.
 */
.pcp-table__row--highlight > td {
  animation: pcp-row-flash 4s ease-out both;
}
.pcp-table__row--highlight > td:first-child {
  box-shadow: inset 4px 0 0 0 #3B5BDB;
}
@keyframes pcp-row-flash {
  0%   { background: #FEF3C7; }
  20%  { background: #FEF9C3; }
  60%  { background: #EEF2FF; }
  100% { background: transparent; }
}
@media (prefers-reduced-motion: reduce) {
  .pcp-table__row--highlight > td {
    animation: none;
    background: #EEF2FF;
  }
}

/* ─── Distributors directory section (v1.9.6) ─────────────────────────────
   Single-column stack of 5 horizontal rows — one per electricity DSO.
   Sits between the planned-outages timeline and the diagnostic block on
   the pillar. Reuses civic-blue brand tokens from the rest of the page. */

.pcp-dso-grid {
  font-family: 'Inter', sans-serif;
  color: #0F172A;
  margin: 0;
}

.pcp-dso-grid__head {
  text-align: center;
  margin-bottom: 32px;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

.pcp-dso-grid__eyebrow {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #3B5BDB;
  margin: 0 0 12px;
  text-transform: uppercase;
}

.pcp-dso-grid__title {
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: clamp(24px, 3.5vw, 36px);
  font-weight: 700;
  line-height: 1.2;
  color: #0F172A;
  margin: 0 0 12px;
}

.pcp-dso-grid__lede {
  font-size: 16px;
  line-height: 1.55;
  color: #475569;
  margin: 0;
}

/* Outer card wrapping all 5 rows so they read as one directory. */
.pcp-dso-grid__list {
  background: #FFFFFF;
  border: 1px solid #E5E9F0;
  border-radius: 16px;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
  overflow: hidden;
}

/* Single row: 3-zone grid — identity (region+name+count) | chips | contact.
   v1.9.7: typographic identity (no avatar icon), text-only phone link. */
.pcp-dso-row {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(0, 2.2fr) minmax(200px, 1fr);
  gap: 32px;
  padding: 26px 28px;
  border-bottom: 1px solid #F1F5F9;
  align-items: start;
  transition: background-color 0.15s ease;
}

.pcp-dso-row:hover {
  background: #FAFBFD;
}

.pcp-dso-row:last-child {
  border-bottom: 0;
}

/* ── Identity zone ── typography only, no icon (v1.9.7) ── */
.pcp-dso-row__identity {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.pcp-dso-row__region-tag {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #3B5BDB;
  margin: 0;
  text-transform: uppercase;
  line-height: 1.4;
}

.pcp-dso-row__name {
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: #0F172A;
  margin: 2px 0 0;
  line-height: 1.2;
  letter-spacing: -0.005em;
}

.pcp-dso-row__county-sub {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: #64748B;
  margin: 4px 0 0;
}

/* ── Coverage zone ── all chips inline, no expander ── */
.pcp-dso-row__coverage {
  min-width: 0;
}

.pcp-dso-row__chips {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.pcp-dso-row__chip {
  display: inline-block;
  height: 28px;
  line-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: #F1F5F9;
  color: #1E293B;
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
}

/* ── Contact zone ── quiet text-only phone link (v1.9.7) ── */
.pcp-dso-row__contact {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.pcp-dso-row__phone {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
  text-decoration: none;
  color: #3B5BDB;
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.005em;
  background: none;
  border: 0;
  border-radius: 4px;
  transition: color 0.15s ease;
}

.pcp-dso-row__phone:hover {
  color: #1E3A8A;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.pcp-dso-row__phone:focus-visible {
  outline: 2px solid #3B5BDB;
  outline-offset: 3px;
}

.pcp-dso-row__phone-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #3B5BDB;
}

.pcp-dso-row__phone-number {
  font-variant-numeric: tabular-nums;
}

.pcp-dso-row__phone-meta {
  margin: 0 0 6px;
  font-family: 'Inter', sans-serif;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.07em;
  color: #94A3B8;
  text-transform: uppercase;
}

/* v1.9.25 — Option C: plain underlined text link. Phone CTA is the
 * primary action on each DSO row; this is the low-emphasis fallback for
 * users who want to verify on the operator's official outage map. */
.pcp-dso-row__site {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: #3B5BDB;
  text-decoration: underline;
  text-underline-offset: 2px;
  line-height: 1.4;
  margin-top: 2px;
}

.pcp-dso-row__site:hover {
  color: #2840B8;
}

.pcp-dso-row__site:focus-visible {
  outline: 2px solid #3B5BDB;
  outline-offset: 2px;
  border-radius: 2px;
}

/* ── Mobile: stack zones vertically inside each row ── */
@media (max-width: 767px) {
  .pcp-dso-row {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 22px 20px;
  }
  .pcp-dso-row__name {
    font-size: 20px;
  }
}

@media (max-width: 480px) {
  .pcp-dso-grid__head {
    margin-bottom: 24px;
  }
  .pcp-dso-row {
    padding: 20px 16px;
    gap: 14px;
  }
  .pcp-dso-row__name {
    font-size: 19px;
  }
  .pcp-dso-row__phone {
    font-size: 17px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .pcp-dso-row,
  .pcp-dso-row__phone {
    transition: none;
  }
}

/* ─── DSO mobile phone bar (v1.9.9, SEO P0.3) ─────────────────────────────
   Compact mobile-first emergency-phone surface. Renders inside the hero on
   county and city pages so provincial mobile visitors see the DSO phone
   above the fold. Hidden on ≥768px — desktop visitors get the full
   `[pcp-dso-card]` further down the page instead. */
.pcp-dso-phone-bar {
  display: none; /* desktop default */
  margin: 0;
}

@media (max-width: 767px) {
  .pcp-dso-phone-bar {
    display: block;
    background: #FFF7ED; /* soft amber surface — signals urgency without alarm */
    border: 1px solid #FCD34D;
    border-left: 4px solid #F59E0B;
    border-radius: 12px;
    padding: 14px 16px;
    margin: 0 0 18px;
    text-align: left;
    font-family: 'Inter', sans-serif;
  }

  .pcp-dso-phone-bar__operator {
    margin: 0 0 6px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.07em;
    color: #92400E;
    text-transform: uppercase;
  }

  .pcp-dso-phone-bar__phone {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    background: #FFFFFF;
    border: 1px solid #F59E0B;
    border-radius: 10px;
    text-decoration: none;
    color: #B45309 !important;
    font-family: 'Manrope', system-ui, sans-serif;
    font-size: 22px;
    font-weight: 700;
    letter-spacing: 0.005em;
    line-height: 1;
    min-height: 44px; /* touch target */
    transition: background-color 0.15s ease, transform 0.15s ease;
  }

  .pcp-dso-phone-bar__phone:hover,
  .pcp-dso-phone-bar__phone:active {
    background: #FFFBEB;
    transform: translateY(-1px);
  }

  .pcp-dso-phone-bar__phone:focus-visible {
    outline: 2px solid #F59E0B;
    outline-offset: 3px;
  }

  .pcp-dso-phone-bar__phone-icon {
    color: #F59E0B;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .pcp-dso-phone-bar__phone-number {
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
  }

  .pcp-dso-phone-bar__meta {
    margin: 8px 0 0;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.07em;
    color: #92400E;
    text-transform: uppercase;
  }
}

@media (max-width: 480px) {
  .pcp-dso-phone-bar__phone {
    font-size: 20px;
    padding: 9px 12px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .pcp-dso-phone-bar__phone {
    transition: none;
  }
  .pcp-dso-phone-bar__phone:hover,
  .pcp-dso-phone-bar__phone:active {
    transform: none;
  }
}

/* ─── Top Cities Grid (v1.9.39) ─────────────────────────────────────────
 * Renders the [pcp-top-cities-grid] shortcode output as a responsive
 * card grid. Shortcode markup:
 *   <div class="pcp-top-cities-grid">
 *     <a class="pcp-top-cities-grid__card">
 *       <span class="...__city">Sectorul 3 București</span>
 *       <span class="...__county">București</span>
 *       <span class="...__dso">E-Distribuție Muntenia</span>
 *       <span class="...__count">42 evenimente</span>
 *       <span class="...__arrow" aria-hidden="true">→</span>
 *     </a>
 *     ... 11 more cards ...
 *   </div>
 *
 * Background: When this shortcode was first placed in template 1308
 * (audit 2026-05-09 morning), the CSS file shipped without these rules.
 * Result was a flat run-on text wall that the site owner flagged.
 * Shortcode was deleted; shortcode + CSS now ship together.
 *
 * Design system anchors: --color-primary #3B5BDB, --color-card-border
 * #CDDBFA (matches FAQ + DSO card styling), Plus Jakarta Sans + DM Sans.
 * ─────────────────────────────────────────────────────────────────────── */

.pcp-top-cities-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 14px;
  margin: 32px 0 0;
  padding: 0;
}

/* v1.9.43 — county + DSO are now wrapped in a __meta parent span (PHP
 * markup change), so CSS treats them as a single inline-flow line.
 * Eliminates the wrap+overlap bug where "E-Distribuție Muntenia" would
 * stack under "București" instead of flowing alongside it.
 *
 * Card layout:
 *   ┌──────────────────────────────────────┐
 *   │ [city span row 1]              [→]   │
 *   │                                      │
 *   │ [county · dso (inline)]    [count]   │
 *   └──────────────────────────────────────┘
 */
.pcp-top-cities-grid__card {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  column-gap: 12px;
  row-gap: 10px;
  padding: 16px 18px;
  background: #FFFFFF;
  border: 1px solid #CDDBFA;
  border-radius: 12px;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
  cursor: pointer;
}

.pcp-top-cities-grid__card:hover {
  border-color: #3B5BDB;
  box-shadow: 0 4px 14px rgba(59, 91, 219, 0.12);
  transform: translateY(-1px);
}

.pcp-top-cities-grid__card:focus-visible {
  outline: 3px solid rgba(59, 91, 219, 0.35);
  outline-offset: 2px;
}

.pcp-top-cities-grid__city {
  grid-column: 1 / -1; /* full width on row 1 */
  grid-row: 1;
  padding-right: 28px; /* leave room for absolute-positioned arrow */
  font-family: 'Plus Jakarta Sans', 'DM Sans', system-ui, sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: #0F172A;
  line-height: 1.3;
  letter-spacing: -0.01em;
}

.pcp-top-cities-grid__arrow {
  position: absolute;
  top: 16px;
  right: 18px;
  font-size: 18px;
  font-weight: 600;
  color: #3B5BDB;
  line-height: 1;
  transition: transform 0.15s ease;
}

.pcp-top-cities-grid__card:hover .pcp-top-cities-grid__arrow {
  transform: translateX(3px);
}

/* v1.9.43 — meta parent wrapper holds county + DSO as inline siblings.
   Left-aligned, allowed to wrap if the line is too long for the card.
   On row 2, takes the 1fr column so it gets all available width. */
.pcp-top-cities-grid__meta {
  grid-column: 1;
  grid-row: 2;
  align-self: end;
  display: block;
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: 12px;
  color: #64748B;
  line-height: 1.45;
  text-align: left;
}

.pcp-top-cities-grid__county,
.pcp-top-cities-grid__dso {
  display: inline; /* flow naturally within __meta */
  font-family: inherit;
  font-size: inherit;
  color: inherit;
  line-height: inherit;
}

.pcp-top-cities-grid__dso::before {
  content: "·";
  color: #94A3B8;
  margin: 0 6px;
}

.pcp-top-cities-grid__count {
  grid-column: 2;
  grid-row: 2;
  justify-self: end;
  align-self: end;
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: 11px;
  font-weight: 600;
  color: #3B5BDB;
  background: #EEF2FF;
  padding: 3px 8px;
  border-radius: 999px;
  letter-spacing: 0.02em;
  line-height: 1.4;
  white-space: nowrap;
}

@media (max-width: 480px) {
  .pcp-top-cities-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .pcp-top-cities-grid__card {
    padding: 14px 16px;
  }
}

@media (max-width: 480px) {
  .pcp-top-cities-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .pcp-top-cities-grid__card {
    padding: 14px 16px;
  }
}

/* v1.9.47 — `.pcp-locality-intro` rule removed. The locality-aware
 * subhead is now a native Bricks text-basic element on template 1308
 * (id "dp2xmk") that uses the existing `ofj1re` (hero-subtitle)
 * global class. No plugin-side CSS needed; styling comes from the
 * canonical Bricks design system. */

/* ──────────────────────────────────────────────────────────────────
 * v1.9.54 — /pana-de-curent/programate/ (pcp_type='national') page
 * differentiation. The page reuses the cluster Bricks template 1308
 * for layout consistency, but several pillar-specific sections are
 * irrelevant to the planned-outages intent and would constitute
 * duplicate content if visible. CSS-hide them on this page type.
 *
 * Pattern matches the existing v1.9.26 hide rule for sec_dso on
 * pcp-type-pillar — simplest cross-cutting concern handler.
 * ────────────────────────────────────────────────────────────────── */

/*
 * Hide on national:
 *   #brxe-pill001     — hero pill (replaced by programate intro)
 *   #brxe-ttl001      — original H1 (replaced by programate intro)
 *   #brxe-sub001      — original sub (replaced by programate intro)
 *   #brxe-col002      — right-column report form
 *   #brxe-sec_outages — Live Outages section (intent mismatch)
 *   #brxe-sec_dso     — DSO Feature single-card (replaced by full directory)
 *   #brxe-sec_diag    — Diagnostic block (planned outages are external)
 *   #brxe-sec_safe    — Safety tips (different intent)
 *   #brxe-sec_comp    — Compensation rules + calculator
 *   #brxe-sec_nav     — Counties/sectors/top-cities grid
 * Comments are intentionally kept OUTSIDE the selector list — some CSS
 * minifiers truncate the rule when they encounter inline comments
 * between commas. Verified live 2026-05-10.
 */
body.pcp-type-national #brxe-pill001,
body.pcp-type-national #brxe-ttl001,
body.pcp-type-national #brxe-sub001,
body.pcp-type-national #brxe-col002,
body.pcp-type-national #brxe-sec_outages,
body.pcp-type-national #brxe-sec_dso,
body.pcp-type-national #brxe-sec_diag,
body.pcp-type-national #brxe-sec_safe,
body.pcp-type-national #brxe-sec_comp,
body.pcp-type-national #brxe-sec_nav {
  display: none !important;
}

/* Ensure the Distributors Reference section IS shown on national.
 * (sj2ys8 currently uses a :has() rule that collapses when its
 * inner [pcp-distributors-section] shortcode renders empty. Make
 * sure that shortcode renders on national pages so the section
 * stays.) */
body.pcp-type-national #brxe-sj2ys8 {
  display: block;
}

/* Style the [pcp-programate-intro] hero replacement. */
.pcp-programate-hero {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: var(--space-l, 1.25rem);
}
.pcp-programate-hero__title {
  /* Inherits styling from the cl5wer global class added in HTML. */
  margin: 0;
}
.pcp-programate-hero__intro {
  /* Inherits styling from the ofj1re global class added in HTML. */
  margin: 0;
  max-width: 64ch;
  opacity: 0.92;
  line-height: 1.55;
}
.pcp-programate-hero__intro a {
  color: inherit;
  text-decoration: underline;
}
