/*
 * AFADIR — DRS (Digitalmente Responsables) public SPA styles
 *
 * All public DRS screens (drs-pledge, drs-mi-adhesion, drs-centro,
 * drs-mapa) consume only this stylesheet plus the design-system
 * tokens (--af-color-*, --space-*, --radius-*, --text-*) declared in
 * `afadir-design-system.css`. No inline `style` attributes, no hex
 * literals: dark mode is automatic via the design-system tokens.
 *
 * Namespacing convention: every selector is prefixed with `.drs-` so
 * this file cannot leak styles to other screens. Component-scoped
 * tokens (e.g. card padding) are declared on the page wrapper to keep
 * the rest of the file flat.
 *
 * @since 2.5.207
 */

/* ============================================================
 * Generic page wrapper used by every DRS screen.
 * ============================================================ */
.drs-page {
  max-width: 920px;
  margin: var(--space-6, 1.5rem) auto;
  padding: 0 var(--space-4, 1rem);
}
.drs-page--narrow {
  max-width: 680px;
}

.drs-page__header {
  margin-bottom: var(--space-4, 1rem);
}
.drs-page__title {
  margin: 0 0 var(--space-1, 0.25rem);
  font-size: var(--text-2xl, 1.5rem);
  color: var(--af-color-text);
}
.drs-page__subtitle {
  margin: 0;
  color: var(--af-color-text-muted);
  font-size: var(--text-sm, 0.875rem);
}

/* ============================================================
 * Card surface — neutral container reused across screens.
 * ============================================================ */
.drs-card {
  background: var(--af-color-surface);
  border: 1px solid var(--af-color-border);
  border-radius: var(--radius-lg, 12px);
  padding: var(--space-5, 1.25rem);
}
.drs-card + .drs-card {
  margin-top: var(--space-3, 0.75rem);
}
.drs-card__title {
  margin: 0 0 var(--space-2, 0.5rem);
  font-size: var(--text-base, 1rem);
  color: var(--af-color-text);
}
.drs-card__hint {
  margin: 0 0 var(--space-3, 0.75rem);
  font-size: var(--text-sm, 0.875rem);
  color: var(--af-color-text-muted);
}

/* ============================================================
 * Inline feedback boxes (info / success / error).
 * ============================================================ */
.drs-notice {
  border: 1px solid transparent;
  border-left-width: 4px;
  border-radius: var(--radius-md, 8px);
  padding: var(--space-3, 0.75rem) var(--space-4, 1rem);
  margin-bottom: var(--space-3, 0.75rem);
  font-size: var(--text-sm, 0.875rem);
}
.drs-notice--success {
  background: var(--af-color-success-bg);
  border-color: var(--af-color-success-strong);
  color: var(--af-color-success-text);
}
.drs-notice--error {
  background: var(--af-color-error-bg);
  border-color: var(--af-color-error-strong);
  color: var(--af-color-error-text);
}
.drs-notice--info {
  background: var(--af-color-info-bg);
  border-color: var(--af-color-info-strong);
  color: var(--af-color-info-text);
}
.drs-notice--warning {
  background: var(--af-color-warning-bg);
  border-color: var(--af-color-warning-strong);
  color: var(--af-color-warning-text);
}
.drs-notice__title {
  margin: 0 0 var(--space-2, 0.5rem);
  font-size: var(--text-base, 1rem);
  font-weight: 600;
}
.drs-notice__text {
  margin: 0;
}
.drs-notice--centered {
  text-align: center;
}

/* Section heading used by drs-mi-adhesion between the state card and
   the action cards. Slightly smaller than the page title and spaced
   to separate the two zones. */
.drs-actions-title {
  margin: var(--space-6, 1.5rem) 0 var(--space-2, 0.5rem);
  font-size: var(--text-xl, 1.25rem);
  color: var(--af-color-text);
}

/* ============================================================
 * Form — drs-pledge, drs-mi-adhesion (grade/center inputs).
 * ============================================================ */
.drs-form {
  background: var(--af-color-surface);
  border: 1px solid var(--af-color-border);
  border-radius: var(--radius-lg, 12px);
  padding: var(--space-5, 1.25rem);
  display: flex;
  flex-direction: column;
  gap: var(--space-4, 1rem);
}
.drs-form__field {
  display: flex;
  flex-direction: column;
  gap: var(--space-1, 0.25rem);
}
.drs-form__field--inline {
  flex-direction: row;
  align-items: flex-start;
  gap: var(--space-2, 0.5rem);
}
.drs-form__label {
  font-weight: 600;
  font-size: var(--text-sm, 0.875rem);
  color: var(--af-color-text);
}
.drs-form__input {
  border: 1px solid var(--af-color-border-strong);
  border-radius: var(--radius-md, 8px);
  padding: var(--space-2, 0.5rem) var(--space-3, 0.75rem);
  font-size: var(--text-base, 1rem);
  color: var(--af-color-text);
  background: var(--af-color-surface);
}
.drs-form__input:focus {
  outline: 2px solid var(--af-color-focus);
  outline-offset: 1px;
}
.drs-form__hint {
  font-size: var(--text-xs, 0.8125rem);
  color: var(--af-color-text-muted);
}
.drs-form__consent-text {
  font-size: var(--text-sm, 0.875rem);
  color: var(--af-color-text);
}
.drs-form__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2, 0.5rem);
  align-items: center;
}

/* ============================================================
 * Status badge (used in drs-mi-adhesion, drs-centro).
 *
 * The colour is set via a CSS variable so the JS only needs to
 * toggle a modifier class — no inline colours.
 * ============================================================ */
.drs-badge {
  display: inline-block;
  background: var(--drs-badge-bg, var(--af-color-info));
  color: var(--af-color-primary-contrast);
  padding: var(--space-1, 0.25rem) var(--space-3, 0.75rem);
  border-radius: var(--radius-full, 999px);
  font-size: var(--text-xs, 0.8125rem);
  font-weight: 600;
}
.drs-badge--active   { --drs-badge-bg: var(--af-color-success-strong); }
.drs-badge--pending  { --drs-badge-bg: var(--af-color-info-strong); }
.drs-badge--withdrawn,
.drs-badge--neutral  { --drs-badge-bg: var(--af-color-muted); }
.drs-badge--warning  { --drs-badge-bg: var(--af-color-warning-strong); }
.drs-badge--error    { --drs-badge-bg: var(--af-color-error-strong); }

/* ============================================================
 * drs-mi-adhesion — state card + dl + danger zone.
 * ============================================================ */
.drs-state__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3, 0.75rem);
  flex-wrap: wrap;
  margin-bottom: var(--space-3, 0.75rem);
}
.drs-state__label {
  font-size: var(--text-lg, 1.125rem);
  color: var(--af-color-text);
}
.drs-state__dl {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-2, 0.5rem) var(--space-6, 1.5rem);
  margin: 0;
  font-size: var(--text-sm, 0.875rem);
}
.drs-state__dt {
  color: var(--af-color-text-muted);
  font-size: var(--text-xs, 0.8125rem);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.drs-state__dd {
  margin: var(--space-1, 0.25rem) 0 0;
  color: var(--af-color-text);
}
.drs-state__footer {
  margin: var(--space-3, 0.75rem) 0 0;
  font-size: var(--text-sm, 0.875rem);
  color: var(--af-color-text-muted);
}

.drs-danger-zone {
  background: var(--af-color-surface);
  border: 1px solid var(--af-color-error-strong);
  border-left-width: 4px;
  border-radius: var(--radius-lg, 12px);
  padding: var(--space-5, 1.25rem);
  margin-top: var(--space-3, 0.75rem);
}
.drs-danger-zone__title {
  margin: 0 0 var(--space-2, 0.5rem);
  font-size: var(--text-base, 1rem);
  color: var(--af-color-error-text);
}
.drs-danger-zone__text {
  margin: 0 0 var(--space-3, 0.75rem);
  font-size: var(--text-sm, 0.875rem);
  color: var(--af-color-error-text);
}

/* ============================================================
 * Buttons — minimal extensions on top of the global .afadir-btn.
 *
 * The plugin already exposes .afadir-btn / .afadir-btn--primary /
 * .afadir-btn--secondary; we only add a danger variant that the
 * design-system does not currently expose under a public name.
 * ============================================================ */
.drs-btn--danger {
  background: var(--af-color-error-strong);
  color: var(--af-color-primary-contrast);
  border: 1px solid var(--af-color-error-strong);
}
.drs-btn--danger:hover {
  background: var(--af-color-error);
}

/* ============================================================
 * drs-centro — hero, stats, CTA.
 * ============================================================ */
.drs-hero {
  background: var(--af-color-surface);
  border: 1px solid var(--af-color-border);
  border-radius: var(--radius-lg, 12px);
  padding: var(--space-6, 1.5rem);
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, 1fr);
  gap: var(--space-6, 1.5rem);
  align-items: center;
}
@media (max-width: 720px) {
  .drs-hero {
    grid-template-columns: 1fr;
  }
}
.drs-hero__eyebrow {
  font-size: var(--text-xs, 0.8125rem);
  color: var(--af-color-text-muted);
  text-transform: uppercase;
  letter-spacing: 1px;
}
.drs-hero__title {
  margin: var(--space-1, 0.25rem) 0 var(--space-3, 0.75rem);
  font-size: var(--text-3xl, 1.875rem);
  color: var(--af-color-text);
}
.drs-hero__meta {
  margin: 0 0 var(--space-3, 0.75rem);
  color: var(--af-color-text);
  font-size: var(--text-sm, 0.875rem);
}
.drs-hero__validity {
  margin-top: var(--space-3, 0.75rem);
  color: var(--af-color-success-text);
  font-size: var(--text-sm, 0.875rem);
}
.drs-hero__note {
  margin-top: var(--space-3, 0.75rem);
  color: var(--af-color-text-muted);
  font-size: var(--text-sm, 0.875rem);
}
.drs-hero__note--revoked {
  color: var(--af-color-error-text);
}
.drs-hero__badge-wrap {
  text-align: center;
}
.drs-hero__badge-img {
  max-width: 360px;
  width: 100%;
  height: auto;
  border-radius: var(--radius-md, 8px);
  background: var(--af-color-surface);
}

.drs-stats {
  background: var(--af-color-surface);
  border: 1px solid var(--af-color-border);
  border-radius: var(--radius-lg, 12px);
  padding: var(--space-6, 1.5rem);
}
.drs-stats__title {
  margin: 0 0 var(--space-1, 0.25rem);
  color: var(--af-color-text);
}
.drs-stats__caption {
  margin: 0;
  color: var(--af-color-text-muted);
  font-size: var(--text-xs, 0.8125rem);
}
.drs-stats__total {
  margin-top: var(--space-4, 1rem);
  display: flex;
  align-items: baseline;
  gap: var(--space-2, 0.5rem);
}
.drs-stats__total-number {
  font-size: var(--text-5xl, 3rem);
  font-weight: 800;
  color: var(--af-color-link);
  line-height: 1;
}
.drs-stats__total-label {
  color: var(--af-color-text);
  font-size: var(--text-base, 1rem);
}
.drs-stats__breakdown-title {
  margin: var(--space-4, 1rem) 0 var(--space-2, 0.5rem);
  color: var(--af-color-text);
}
.drs-stats__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: var(--space-2, 0.5rem);
}
.drs-stats__cell {
  background: var(--af-color-surface-secondary);
  border: 1px solid var(--af-color-border);
  border-radius: var(--radius-md, 8px);
  padding: var(--space-3, 0.75rem);
  text-align: center;
}
.drs-stats__cell-number {
  font-size: var(--text-2xl, 1.5rem);
  font-weight: 700;
  color: var(--af-color-text);
}
.drs-stats__cell-label {
  font-size: var(--text-xs, 0.8125rem);
  color: var(--af-color-text-muted);
}
.drs-stats__threshold-note {
  margin-top: var(--space-3, 0.75rem);
  font-size: var(--text-xs, 0.8125rem);
  color: var(--af-color-text-muted);
}

.drs-cta {
  background: var(--af-color-info-bg);
  border: 1px solid var(--af-color-info-strong);
  border-radius: var(--radius-lg, 12px);
  padding: var(--space-6, 1.5rem);
  text-align: center;
  margin-top: var(--space-6, 1.5rem);
}
.drs-cta__title {
  margin: 0 0 var(--space-2, 0.5rem);
  color: var(--af-color-info-text);
}
.drs-cta__text {
  margin: 0 0 var(--space-4, 1rem);
  color: var(--af-color-info-text);
}

/* ============================================================
 * drs-mapa — Leaflet canvas + legend.
 *
 * Leaflet itself ships its own marker CSS via the CDN bundle; we
 * only style the canvas frame and the legend block. A min-height is
 * needed because Leaflet measures the parent at init time.
 * ============================================================ */
.drs-map__canvas {
  width: 100%;
  height: 60vh;
  min-height: 380px;
  border: 1px solid var(--af-color-border);
  border-radius: var(--radius-lg, 12px);
  overflow: hidden;
  background: var(--af-color-surface-secondary);
}
.drs-map__status {
  margin: var(--space-3, 0.75rem) 0;
  color: var(--af-color-text-muted);
  font-size: var(--text-sm, 0.875rem);
}
.drs-map__status--error {
  color: var(--af-color-error-text);
}
.drs-map__legend {
  margin-top: var(--space-3, 0.75rem);
  font-size: var(--text-sm, 0.875rem);
  color: var(--af-color-text-muted);
  display: flex;
  gap: var(--space-4, 1rem);
  flex-wrap: wrap;
}
.drs-map__legend-dot {
  display: inline-block;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  vertical-align: middle;
  margin-right: var(--space-1, 0.25rem);
}
.drs-map__legend-dot--valid    { background: var(--af-color-success-strong); }
.drs-map__legend-dot--expiring { background: var(--af-color-warning-strong); }

/* Leaflet popup contents — floated outside the SPA root but reachable
   via global stylesheet selectors. Keep the popup compact and readable
   in both light and dark mode. */
.drs-map__popup {
  min-width: 200px;
  color: var(--af-color-text);
}
.drs-map__popup-title {
  font-size: var(--text-sm, 0.875rem);
  color: var(--af-color-text);
}
.drs-map__popup-code {
  font-size: var(--text-xs, 0.8125rem);
  color: var(--af-color-text-muted);
}
.drs-map__popup-validity {
  margin-top: var(--space-1, 0.25rem);
  font-size: var(--text-xs, 0.8125rem);
}
.drs-map__popup-validity--valid    { color: var(--af-color-success-text); }
.drs-map__popup-validity--expiring { color: var(--af-color-warning-text); }
.drs-map__popup-link {
  margin-top: var(--space-2, 0.5rem);
}

.drs-map__footer {
  margin-top: var(--space-6, 1.5rem);
  background: var(--af-color-surface-secondary);
  border: 1px dashed var(--af-color-border-strong);
  border-radius: var(--radius-md, 8px);
  padding: var(--space-4, 1rem);
  text-align: center;
  color: var(--af-color-text);
}
.drs-map__footer-text {
  margin: 0 0 var(--space-2, 0.5rem);
}

/* ============================================================
 * drs-pledge success state.
 * ============================================================ */
.drs-pledge__success {
  background: var(--af-color-success-bg);
  border: 1px solid var(--af-color-success-strong);
  border-left-width: 4px;
  border-radius: var(--radius-md, 8px);
  padding: var(--space-5, 1.25rem);
  margin-top: var(--space-3, 0.75rem);
}
.drs-pledge__success-title {
  margin: 0 0 var(--space-2, 0.5rem);
  color: var(--af-color-success-text);
}
.drs-pledge__success-text {
  margin: 0;
  color: var(--af-color-success-text);
}
.drs-pledge__success-help {
  margin: var(--space-3, 0.75rem) 0 0;
  font-size: var(--text-sm, 0.875rem);
  color: var(--af-color-success-text);
}
