:root {
  --bg: #eef4fb;
  --card: #ffffff;
  --text: #172033;
  --muted: #64748b;
  --soft-muted: #9aa8bd;
  --border: #dde8f6;
  --primary: #1d4ed8;
  --primary-dark: #1e40af;
  --primary-soft: #dbeafe;
  --danger: #b91c1c;
  --success: #166534;
  --warning: #92400e;
  --shadow: 0 16px 42px rgba(15, 23, 42, .09);
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: Inter, Segoe UI, Arial, sans-serif;
  background: linear-gradient(180deg, #f4f8ff 0%, var(--bg) 48%, #f8fbff 100%);
  color: var(--text);
  min-height: 100vh;
}
.topbar {
  background: linear-gradient(135deg, #0f172a 0%, #1749a8 55%, #2563eb 100%);
  color: white;
  padding: 28px 42px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  box-shadow: 0 18px 45px rgba(15, 23, 42, .20);
}
.public-topbar {
  min-height: 150px;
  overflow: hidden;
}
.brand-block { max-width: 900px; }
.eyebrow {
  display: inline-block;
  margin-bottom: 10px;
  padding: 6px 11px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.22);
  color: rgba(255,255,255,.90);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.topbar h1 {
  margin: 0;
  font-size: clamp(34px, 4.2vw, 54px);
  letter-spacing: -.045em;
  line-height: 1.02;
  text-shadow: 0 4px 16px rgba(15, 23, 42, .18);
}
.topbar p { margin: 10px 0 0; color: rgba(255,255,255,.82); font-size: 16px; line-height: 1.5; }
nav {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  flex-shrink: 0;
}
nav a {
  color: white;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,.28);
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
}
nav a.active, nav a:hover { background: white; color: #0f172a; }
.container {
  width: min(1280px, calc(100% - 36px));
  margin: 24px auto 60px;
}
.public-container { margin-top: -24px; }
.two-col {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 28px;
}
.full { grid-column: 1 / -1; }
.card {
  background: rgba(255,255,255,.97);
  border: 1px solid rgba(221, 232, 246, .95);
  border-radius: 24px;
  box-shadow: var(--shadow);
  padding: 24px;
  margin-bottom: 18px;
}
.current-card {
  display: grid;
  grid-template-columns: minmax(320px, 1fr) auto;
  align-items: center;
  gap: 24px;
  border-color: rgba(191, 219, 254, .95);
}
.validation-current h2 {
  margin: 12px 0 0;
  font-size: 27px;
  letter-spacing: -.02em;
}
.badge {
  display: inline-block;
  color: var(--primary-dark);
  background: #dbeafe;
  border: 1px solid #bfdbfe;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.soft-badge { background: #eff6ff; }
h2 { margin: 12px 0 8px; }
h3 { margin: 0; font-size: 24px; letter-spacing: -.02em; }
h4 { margin: 0; }
.muted { color: var(--muted); line-height: 1.55; }
.summary-grid {
  display: grid;
  grid-template-columns: repeat(5, 112px);
  gap: 12px;
}
.summary-item {
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 16px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.summary-item::before {
  display: none;
}
.summary-item b { display: block; font-size: 30px; line-height: 1; margin-bottom: 8px; }
.summary-item span { color: var(--muted); font-size: 13px; font-weight: 800; }
.summary-total { background: linear-gradient(180deg, #eff6ff, #ffffff); border-color: #bfdbfe; }
.summary-total b { color: #1d4ed8; }
.summary-no-indicado { background: linear-gradient(180deg, #f8fafc, #ffffff); border-color: #cbd5e1; }
.summary-no-indicado b { color: #475569; }
.summary-observado { background: linear-gradient(180deg, #fff1f2, #ffffff); border-color: #fecdd3; }
.summary-observado b { color: #be123c; }
.summary-proceso { background: linear-gradient(180deg, #fffbeb, #ffffff); border-color: #fde68a; }
.summary-proceso b { color: #b45309; }
.summary-corregido { background: linear-gradient(180deg, #ecfdf5, #ffffff); border-color: #bbf7d0; }
.summary-corregido b { color: #15803d; }
.section-head, .table-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
}
.compact-head { margin-bottom: 16px; }
#row-count {
  background: #eff6ff;
  color: #1d4ed8;
  border: 1px solid #bfdbfe;
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 900;
}
.layer-panel {
  background: linear-gradient(180deg, #f3f8ff, #edf5ff);
  border: 1px solid #d7e7fb;
  border-radius: 18px;
  padding: 14px;
  margin-bottom: 16px;
}
.mini-label {
  display: block;
  color: #334155;
  font-size: 13px;
  font-weight: 900;
  margin-bottom: 10px;
}
.layer-filter {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin: 0;
}
.layer-btn {
  background: white;
  color: #334155;
  border: 1px solid #cbd5e1;
  box-shadow: 0 5px 14px rgba(15, 23, 42, .05);
  padding: 10px 14px;
  border-radius: 999px;
}
.layer-btn:hover { background: #ecfdf5; color: #166534; border-color: #bbf7d0; }
.layer-btn.active {
  background: linear-gradient(135deg, #16a34a, #22c55e);
  color: white;
  border-color: #16a34a;
  box-shadow: 0 8px 20px rgba(22, 163, 74, .20);
}
.filters {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(135px, 1fr));
  gap: 14px;
  align-items: end;
}
label { display: grid; gap: 8px; font-weight: 800; color: #334155; font-size: 13px; }
input, select, textarea {
  width: 100%;
  border: 1px solid #cbd5e1;
  border-radius: 14px;
  padding: 12px 13px;
  font: inherit;
  background: white;
  color: var(--text);
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
input:focus, select:focus, textarea:focus {
  border-color: #60a5fa;
  box-shadow: 0 0 0 4px rgba(96, 165, 250, .18);
}
input::placeholder, textarea::placeholder {
  color: var(--soft-muted);
  opacity: .42;
  font-weight: 400;
}
textarea { resize: vertical; }
button {
  border: 0;
  background: var(--primary);
  color: white;
  padding: 12px 16px;
  border-radius: 13px;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 8px 20px rgba(29, 78, 216, .22);
}
button:hover { background: var(--primary-dark); }
button.secondary { background: #475569; box-shadow: none; }
button.danger { background: var(--danger); box-shadow: none; }
.export-btn { min-width: 120px; }
.table-card { padding: 24px; }
.table-head { margin-bottom: 16px; }
.table-wrap { overflow: auto; border: 1px solid var(--border); border-radius: 16px; box-shadow: inset 0 1px 0 rgba(255,255,255,.8); }
table { border-collapse: collapse; width: 100%; min-width: 1280px; }
th, td { padding: 12px 10px; border-bottom: 1px solid var(--border); vertical-align: top; }
th { background: #f8fafc; text-align: left; font-size: 13px; color: #334155; position: sticky; top: 0; z-index: 1; }
tbody tr:hover { background: #f8fafc; }
td .status-pill {
  display: inline-block;
  border-radius: 999px;
  padding: 5px 9px;
  font-size: 12px;
  font-weight: 800;
}
.status-observado { background: #fee2e2; color: #991b1b; }
.status-en-proceso { background: #fef3c7; color: var(--warning); }
.status-corregido { background: #dcfce7; color: var(--success); }
.status-select { min-width: 134px; padding: 8px 9px; }
.file-note, .hint, .result-box {
  margin-top: 12px;
  color: var(--muted);
  background: #f8fafc;
  border: 1px dashed #cbd5e1;
  border-radius: 14px;
  padding: 14px;
}
.actions { display: flex; gap: 12px; flex-wrap: wrap; margin: 14px 0; }
.steps { line-height: 1.8; color: #334155; }
.empty-row { text-align: center; color: var(--muted); padding: 34px !important; }
@media (max-width: 1180px) {
  .current-card { grid-template-columns: 1fr; }
  .summary-grid { grid-template-columns: repeat(5, minmax(100px, 1fr)); }
  .filters { grid-template-columns: repeat(3, minmax(150px, 1fr)); }
}
@media (max-width: 900px) {
  .topbar { flex-direction: column; align-items: flex-start; padding: 24px; }
  .public-topbar { min-height: auto; }
  .public-container { margin-top: 18px; }
  .summary-grid { grid-template-columns: repeat(2, 1fr); width: 100%; }
  .filters, .two-col { grid-template-columns: 1fr; }
  .section-head, .table-head { flex-direction: column; align-items: flex-start; }
  .export-btn { width: 100%; }
}

/* Ajuste v6: filtro por capa sin etiqueta, integrado sobre la tabla */
.table-layer-panel {
  margin: 12px 0 14px;
  padding: 12px 14px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  background: linear-gradient(180deg, #f7fbff, #eef6ff);
}
.table-layer-panel .layer-filter {
  flex: 1;
}
.search-card .filters {
  margin-top: 4px;
}
@media (max-width: 900px) {
  .table-layer-panel { align-items: flex-start; }
}


/* Ajuste v12: navegación, panel limpio y desplegables redondeados */
.admin-topbar {
  min-height: 128px;
}
.admin-container {
  margin-top: 28px;
}
.admin-card h2 {
  margin-top: 14px;
}
select,
.status-select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, #64748b 50%),
    linear-gradient(135deg, #64748b 50%, transparent 50%),
    linear-gradient(180deg, #ffffff, #f8fbff);
  background-position:
    calc(100% - 20px) calc(50% - 3px),
    calc(100% - 14px) calc(50% - 3px),
    0 0;
  background-size: 6px 6px, 6px 6px, 100% 100%;
  background-repeat: no-repeat;
  padding-right: 42px;
  border-radius: 16px;
  cursor: pointer;
}
select:hover,
.status-select:hover {
  border-color: #93c5fd;
  background-image:
    linear-gradient(45deg, transparent 50%, #2563eb 50%),
    linear-gradient(135deg, #2563eb 50%, transparent 50%),
    linear-gradient(180deg, #ffffff, #eff6ff);
}
select:focus,
.status-select:focus {
  border-color: #22c55e;
  box-shadow: 0 0 0 4px rgba(34, 197, 94, .16);
}
.status-select {
  min-width: 150px;
  border-radius: 999px;
  font-weight: 800;
}
nav a {
  font-weight: 800;
}


/* Ajuste v13: logo INSYS + título centrado */
.brand-topbar {
  display: grid;
  grid-template-columns: minmax(230px, 330px) minmax(320px, 1fr) auto;
  align-items: center;
  gap: 22px;
}
.public-topbar,
.admin-topbar {
  min-height: 152px;
  overflow: hidden;
}
.brand-logo-shell {
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(255,255,255,.55);
  border-radius: 24px;
  padding: 10px 16px;
  box-shadow: 0 14px 32px rgba(15, 23, 42, .18);
  display: flex;
  align-items: center;
  justify-content: center;
}
.brand-logo {
  display: block;
  width: 100%;
  max-width: 300px;
  height: auto;
  object-fit: contain;
}
.brand-center {
  display: flex;
  justify-content: center;
  align-items: center;
}
.center-brand-title {
  margin: 0;
  width: 100%;
  text-align: center;
  font-size: clamp(24px, 2.9vw, 38px);
  line-height: 1.12;
  letter-spacing: .02em;
  font-weight: 900;
  color: #ffffff;
  padding: 18px 26px;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.06));
  border: 1px solid rgba(255,255,255,.20);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), 0 10px 26px rgba(15, 23, 42, .12);
  text-shadow: 0 3px 12px rgba(15, 23, 42, .25);
}
.topbar h1 {
  text-shadow: none;
}
@media (max-width: 1100px) {
  .brand-topbar {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
  }
  .brand-logo-shell {
    width: min(100%, 360px);
  }
  .brand-center {
    width: 100%;
  }
  .center-brand-title {
    width: min(100%, 780px);
  }
  nav {
    justify-content: center;
  }
}


/* Ajuste v14: cabecera similar a referencia */
.v14-topbar {
  width: min(1280px, calc(100% - 40px));
  margin: 18px auto 0;
  border-radius: 8px;
  padding: 14px 22px;
  min-height: 116px;
  grid-template-columns: 330px minmax(320px, 1fr) auto;
  background: linear-gradient(90deg, #061843 0%, #0f2e77 32%, #1658d8 100%);
  border: 1px solid rgba(0,0,0,.12);
  box-shadow: 0 10px 28px rgba(2, 6, 23, .20);
}
.public-container,
.admin-container {
  margin-top: 18px;
}
.header-logo-wrap {
  display: flex;
  align-items: center;
}
.header-logo-banner {
  display: block;
  width: 100%;
  max-width: 300px;
  height: auto;
  object-fit: contain;
}
.v14-brand-center {
  justify-content: center;
}
.v14-title {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0 10px;
  border-radius: 0;
  text-transform: uppercase;
  font-size: clamp(28px, 3vw, 42px);
  font-weight: 900;
  letter-spacing: .02em;
  color: #ffffff;
  text-shadow:
    -1px -1px 0 rgba(0,0,0,.35),
     1px -1px 0 rgba(0,0,0,.35),
    -1px  1px 0 rgba(0,0,0,.35),
     1px  1px 0 rgba(0,0,0,.35),
     0 3px 12px rgba(0,0,0,.25);
}
.v14-topbar nav a {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.26);
  font-weight: 800;
}
.v14-topbar nav a.active,
.v14-topbar nav a:hover {
  background: #ffffff;
  color: #0f172a;
}
@media (max-width: 1150px) {
  .v14-topbar {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
    gap: 16px;
  }
  .header-logo-wrap {
    justify-content: center;
  }
}


/* Ajuste v15: franja azul completa + logo sin fondo blanco */
.v15-topbar {
  width: 100%;
  margin: 0;
  border-radius: 0;
  padding: 24px 36px;
  min-height: 140px;
  grid-template-columns: minmax(260px, 410px) minmax(280px, 1fr) auto;
  background: linear-gradient(135deg, #0f172a 0%, #1749a8 55%, #2563eb 100%);
  border: 0;
  box-shadow: 0 18px 45px rgba(15, 23, 42, .20);
}
.header-logo-wrap {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  background: transparent;
}
.header-logo-banner {
  display: block;
  width: 100%;
  max-width: 360px;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 5px 12px rgba(0,0,0,.18));
}
.v15-brand-center {
  display: flex;
  align-items: center;
  justify-content: center;
}
.v15-title {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0 14px;
  border-radius: 0;
  text-transform: uppercase;
  text-align: center;
  font-size: clamp(28px, 3vw, 44px);
  font-weight: 900;
  letter-spacing: .02em;
  color: #ffffff;
  text-shadow: 0 3px 14px rgba(0,0,0,.28);
}
.v15-topbar nav a {
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.25);
  font-weight: 800;
}
.v15-topbar nav a.active,
.v15-topbar nav a:hover {
  background: #ffffff;
  color: #0f172a;
}
@media (max-width: 1100px) {
  .v15-topbar {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
    gap: 16px;
    padding: 22px 24px;
  }
  .header-logo-wrap {
    justify-content: center;
  }
  .header-logo-banner {
    max-width: min(100%, 360px);
  }
}


/* Ajuste v16: logo con letras blancas y mejor centrado del título */
.v15-topbar {
  grid-template-columns: minmax(300px, 460px) minmax(420px, 1fr) auto;
  column-gap: 34px;
  padding: 24px 42px;
}
.header-logo-banner {
  max-width: 390px;
}
.v15-brand-center {
  padding: 0 24px;
}
.v15-title {
  width: 100%;
  text-align: center;
  font-size: clamp(30px, 3.2vw, 46px);
  letter-spacing: .025em;
}
.v15-topbar nav {
  justify-self: end;
}
@media (max-width: 1280px) {
  .v15-topbar {
    grid-template-columns: minmax(280px, 360px) minmax(360px, 1fr) auto;
    column-gap: 22px;
  }
  .header-logo-banner {
    max-width: 340px;
  }
}
@media (max-width: 1100px) {
  .v15-topbar {
    grid-template-columns: 1fr;
    padding: 22px 24px;
  }
  .v15-brand-center {
    padding: 0;
  }
}


/* Ajuste v18: login modal y título en una sola línea */
.v15-title {
  white-space: nowrap;
  font-size: clamp(24px, 2.35vw, 38px);
}
.main-nav {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
}
.nav-action-btn {
  border: 1px solid rgba(255,255,255,.25);
  background: rgba(255,255,255,.10);
  color: #fff;
  padding: 10px 14px;
  border-radius: 999px;
  box-shadow: none;
  font-weight: 800;
}
.nav-action-btn:hover { background: #fff; color: #0f172a; }
.nav-user-box {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.user-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.24);
  color: #fff;
  font-weight: 800;
}
.active-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #22c55e;
  box-shadow: 0 0 0 3px rgba(34,197,94,.18);
}
.logout-btn {
  background: rgba(255,255,255,.10);
}
.modal-open { overflow: hidden; }
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, .52);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  z-index: 9999;
}
.login-modal {
  width: min(420px, 100%);
  background: #fff;
  border-radius: 22px;
  box-shadow: 0 24px 60px rgba(15,23,42,.28);
  padding: 24px;
  position: relative;
}
.login-modal h2 {
  margin: 0 0 18px;
  font-size: 28px;
}
.modal-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  padding: 0;
  background: #eff6ff;
  color: #334155;
  box-shadow: none;
  font-size: 24px;
  line-height: 1;
}
.login-form { display: grid; gap: 14px; }
.check-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 700;
}
.check-row input { width: 16px; height: 16px; }
.login-error {
  min-height: 20px;
  color: #b91c1c;
  font-size: 14px;
  font-weight: 700;
}
.login-submit {
  width: 100%;
  border-radius: 16px;
}
.admin-lock-card {
  text-align: center;
  padding: 38px 24px;
}
@media (max-width: 1200px) {
  .v15-title { white-space: normal; }
}


/* Ajuste v19: no abrir login al cargar + mejor distribución del encabezado */
[hidden] { display: none !important; }
.v15-topbar {
  grid-template-columns: minmax(280px, 380px) minmax(0, 1fr) auto;
  column-gap: 22px;
  align-items: center;
}
.v15-title {
  white-space: nowrap;
  font-size: clamp(20px, 1.95vw, 33px);
  line-height: 1.1;
  padding: 0 8px;
}
.v15-brand-center {
  min-width: 0;
  padding: 0 10px;
}
.main-nav {
  flex-wrap: nowrap;
  gap: 8px;
  justify-content: flex-end;
}
.main-nav a,
.nav-action-btn,
.user-chip {
  white-space: nowrap;
}
.header-logo-banner {
  max-width: 340px;
}
.nav-user-box {
  gap: 8px;
}
@media (max-width: 1400px) {
  .v15-title {
    font-size: clamp(18px, 1.75vw, 28px);
  }
  .header-logo-banner {
    max-width: 310px;
  }
}
@media (max-width: 1200px) {
  .v15-topbar {
    grid-template-columns: 1fr;
    justify-items: center;
  }
  .main-nav {
    flex-wrap: wrap;
    justify-content: center;
  }
  .v15-title {
    white-space: normal;
    text-align: center;
  }
}


/* Ajuste v20: menú de usuario desplegable y encabezado corregido */
.v15-topbar {
  grid-template-columns: minmax(240px, 320px) minmax(0, 1fr) auto;
  column-gap: 18px;
  padding: 22px 28px;
}
.v15-title {
  font-size: clamp(18px, 1.55vw, 28px);
  letter-spacing: .01em;
  text-align: center;
  overflow: hidden;
}
.header-logo-banner {
  max-width: 290px;
}
.v15-brand-center {
  padding: 0 6px;
}
.main-nav {
  flex-wrap: nowrap;
  align-items: center;
  gap: 8px;
}
.main-nav a,
.nav-action-btn,
.user-menu-toggle {
  padding: 10px 13px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.24);
  background: rgba(255,255,255,.10);
  color: #fff;
  font-weight: 800;
  line-height: 1;
}
.main-nav a.active,
.main-nav a:hover,
.nav-action-btn:hover,
.user-menu-toggle:hover,
.user-menu-toggle[aria-expanded="true"] {
  background: #fff;
  color: #0f172a;
}
.nav-user-menu {
  position: relative;
}
.user-menu-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  box-shadow: none;
}
.user-chip {
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  font-weight: 900;
}
.user-caret {
  font-size: 14px;
  opacity: .9;
}
.user-dropdown {
  position: absolute;
  right: 0;
  top: calc(100% + 10px);
  min-width: 180px;
  background: #fff;
  border: 1px solid #dbe4f0;
  border-radius: 16px;
  box-shadow: 0 18px 40px rgba(15,23,42,.18);
  padding: 8px;
  z-index: 40;
}
.dropdown-logout-btn {
  width: 100%;
  justify-content: flex-start;
  background: #fff1f2;
  color: #be123c;
  border: 1px solid #fecdd3;
  box-shadow: none;
  border-radius: 12px;
  padding: 12px 14px;
  text-align: left;
}
.dropdown-logout-btn:hover {
  background: #ffe4e6;
  color: #9f1239;
}
select,
.status-select {
  background-image:
    linear-gradient(45deg, transparent 50%, #64748b 50%),
    linear-gradient(135deg, #64748b 50%, transparent 50%),
    linear-gradient(180deg, #ffffff, #f8fbff);
  box-shadow: inset 0 1px 1px rgba(255,255,255,.9), 0 4px 12px rgba(15,23,42,.04);
  border-color: #c9d5e5;
}
select option,
.status-select option {
  color: #0f172a;
  background: #fff;
}
@media (max-width: 1500px) {
  .v15-title { font-size: clamp(16px, 1.4vw, 24px); }
  .header-logo-banner { max-width: 265px; }
}
@media (max-width: 1240px) {
  .v15-topbar {
    grid-template-columns: 1fr;
    justify-items: center;
  }
  .main-nav {
    flex-wrap: wrap;
    justify-content: center;
  }
  .v15-title {
    white-space: normal;
  }
}


/* Ajuste v21: dropdown de usuario completo + selects más modernos */
.public-topbar,
.admin-topbar,
.v15-topbar,
.brand-topbar {
  overflow: visible !important;
}

.v15-topbar {
  position: relative;
  z-index: 20;
}

.nav-user-menu {
  position: relative;
  overflow: visible;
}

.user-dropdown {
  width: 220px;
  min-width: 220px;
  right: 0;
  top: calc(100% + 12px);
  padding: 10px;
  border-radius: 18px;
  box-shadow: 0 18px 42px rgba(15,23,42,.22);
  background: #ffffff;
  border: 1px solid #dbe4f0;
}

.dropdown-logout-btn {
  display: block;
  width: 100%;
  background: #fff5f5;
  color: #c81e1e;
  border: 1px solid #fecaca;
  border-radius: 14px;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 15px;
  font-weight: 800;
  padding: 13px 14px;
}

.dropdown-logout-btn:hover {
  background: #fee2e2;
  color: #b91c1c;
  border-color: #fca5a5;
}

.user-menu-toggle {
  min-height: 44px;
}

/* campo select principal */
select,
.status-select {
  font-family: Arial, Helvetica, sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: #1f2937;
  border: 1px solid #d4dbe5;
  border-radius: 14px;
  background-image:
    linear-gradient(45deg, transparent 50%, #6b7280 50%),
    linear-gradient(135deg, #6b7280 50%, transparent 50%),
    linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  background-position:
    calc(100% - 19px) calc(50% - 3px),
    calc(100% - 14px) calc(50% - 3px),
    0 0;
  background-size: 5px 5px, 5px 5px, 100% 100%;
  background-repeat: no-repeat;
  padding: 12px 40px 12px 14px;
  box-shadow: 0 4px 14px rgba(15,23,42,.04), inset 0 1px 0 rgba(255,255,255,.9);
}

select:hover,
.status-select:hover {
  border-color: #bfc9d8;
  background-image:
    linear-gradient(45deg, transparent 50%, #4b5563 50%),
    linear-gradient(135deg, #4b5563 50%, transparent 50%),
    linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

select:focus,
.status-select:focus {
  border-color: #93c5fd;
  box-shadow: 0 0 0 4px rgba(147,197,253,.22), 0 8px 18px rgba(15,23,42,.06);
}

.status-select {
  min-width: 150px;
  border-radius: 14px;
}

/* menú abierto / opciones (limitado por el navegador, pero más pulido) */
select option,
.status-select option {
  font-family: Arial, Helvetica, sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: #1f2937;
  background: #ffffff;
  padding: 10px 12px;
}

/* algunos navegadores respetan estos colores de selección */
select option:checked,
.status-select option:checked {
  background: #dbeafe;
  color: #1d4ed8;
}

select option:hover,
.status-select option:hover {
  background: #f3f4f6;
}


/* Ajuste v22: custom selects de búsqueda, números negros y botón actualizar */
.summary-item b {
  color: #111111 !important;
}
.table-head-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.table-refresh-btn {
  background: #eff6ff;
  color: #1d4ed8;
  border: 1px solid #bfdbfe;
  border-radius: 999px;
  padding: 10px 14px;
  font-size: 14px;
  font-weight: 800;
  box-shadow: none;
}
.table-refresh-btn:hover {
  background: #dbeafe;
  color: #1e40af;
}
.table-refresh-btn.done {
  background: #dcfce7;
  border-color: #86efac;
  color: #166534;
}
.native-hidden.custom-target {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
  width: 0 !important;
  height: 0 !important;
}
.custom-select {
  position: relative;
  width: 100%;
  font-family: Arial, Helvetica, sans-serif;
}
.custom-select-trigger {
  width: 100%;
  min-height: 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid #d4dbe5;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  color: #1f2937;
  font-size: 14px;
  font-weight: 700;
  box-shadow: 0 4px 14px rgba(15,23,42,.04), inset 0 1px 0 rgba(255,255,255,.9);
}
.custom-select-trigger:hover {
  border-color: #bfc9d8;
}
.custom-select.open .custom-select-trigger,
.custom-select-trigger:focus {
  border-color: #93c5fd;
  box-shadow: 0 0 0 4px rgba(147,197,253,.22), 0 8px 18px rgba(15,23,42,.06);
}
.custom-select-arrow {
  color: #6b7280;
  font-size: 12px;
  line-height: 1;
  flex: 0 0 auto;
}
.custom-select-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  background: #ffffff;
  border: 1px solid #dbe4f0;
  border-radius: 16px;
  box-shadow: 0 18px 42px rgba(15,23,42,.14);
  padding: 8px;
  z-index: 70;
}
.custom-select-option {
  width: 100%;
  text-align: left;
  background: transparent;
  color: #1f2937;
  border: 0;
  border-radius: 12px;
  padding: 11px 12px;
  font-size: 14px;
  font-weight: 600;
  box-shadow: none;
}
.custom-select-option:hover {
  background: #f3f4f6;
}
.custom-select-option.selected {
  background: #dbeafe;
  color: #1d4ed8;
}


/* Ajuste v23: login centrado, ojo en contraseña y recordar usuario */
.login-modal h2 {
  text-align: center;
}
.password-field-wrap {
  position: relative;
}
.password-field-wrap input {
  padding-right: 52px;
}
.password-eye-btn {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid #dbe4f0;
  background: #f8fbff;
  color: #475569;
  box-shadow: none;
  padding: 0;
  font-size: 16px;
  line-height: 1;
}
.password-eye-btn:hover {
  background: #eef6ff;
  border-color: #bfdbfe;
  color: #1d4ed8;
}
.remember-row {
  margin-top: -2px;
}
.remember-row span,
.check-row span {
  font-weight: 700;
  color: #334155;
}


/* Ajuste v24: login más compacto + logo refinado + franja superior menos alta */
.v15-topbar {
  padding: 16px 26px;
  min-height: 108px;
  grid-template-columns: minmax(220px, 290px) minmax(0, 1fr) auto;
}
.header-logo-banner {
  max-width: 250px;
}
.v15-title {
  font-size: clamp(17px, 1.45vw, 26px);
}
.login-form {
  gap: 10px;
}
.password-eye-btn {
  border: 0 !important;
  background: transparent !important;
  width: 28px;
  height: 28px;
  right: 12px;
  color: #64748b;
}
.password-eye-btn:hover {
  background: transparent !important;
  color: #1d4ed8;
  border: 0 !important;
}
.remember-row {
  margin-top: 0;
  margin-bottom: 2px;
}
.login-submit {
  margin-top: 4px;
}
@media (max-width: 1500px) {
  .v15-topbar {
    padding: 14px 20px;
    min-height: 96px;
  }
  .header-logo-banner {
    max-width: 225px;
  }
}


/* Ajuste v25: menos espacio en login, logo más nítido y texto del botón */
.login-form {
  gap: 8px;
}
.remember-row {
  margin-top: -2px;
  margin-bottom: -6px;
}
.login-submit {
  margin-top: 0 !important;
}
.header-logo-banner {
  width: auto;
  max-width: 255px;
  max-height: 62px;
  object-fit: contain;
  image-rendering: -webkit-optimize-contrast;
  image-rendering: crisp-edges;
}
.v15-topbar {
  min-height: 100px;
  padding-top: 14px;
  padding-bottom: 14px;
}
@media (max-width: 1500px) {
  .header-logo-banner {
    max-width: 240px;
    max-height: 58px;
  }
  .v15-topbar {
    min-height: 92px;
    padding-top: 12px;
    padding-bottom: 12px;
  }
}


/* Ajuste v26: logo insys mejorado */
.header-logo-banner {
  width: auto;
  height: auto;
  max-width: 285px;
  max-height: 72px;
  object-fit: contain;
  image-rendering: auto;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.12));
}
@media (max-width: 1500px) {
  .header-logo-banner {
    max-width: 265px;
    max-height: 66px;
  }
}


/* Ajuste v27: logo display optimizado */
.header-logo-banner {
  width: auto;
  height: auto;
  max-width: 330px;
  max-height: 86px;
  object-fit: contain;
  image-rendering: auto;
  filter: none;
}
.v15-topbar {
  grid-template-columns: minmax(260px, 350px) minmax(0, 1fr) auto;
}
@media (max-width: 1500px) {
  .header-logo-banner {
    max-width: 305px;
    max-height: 80px;
  }
}


/* Ajuste v28: solo mejora del logo, sin aumentar la cabecera */
.header-logo-wrap {
  background: transparent;
}
.header-logo-banner {
  width: auto;
  height: auto;
  max-width: 312px;
  max-height: 68px;
  object-fit: contain;
  image-rendering: auto;
  filter: none;
}


/* Ajuste v29: restaurar logo correcto sin cambiar la cabecera */
.header-logo-wrap {
  background: transparent !important;
  padding: 0;
}
.header-logo-banner {
  max-width: 252px !important;
  max-height: 107px !important;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
  filter: none !important;
}


/* Ajuste v30: logo transparente limpio, sin bloque blanco */
.header-logo-wrap {
  background: transparent !important;
  padding: 0;
  display: flex;
  align-items: center;
}
.header-logo-banner {
  max-width: 290px !important;
  max-height: 76px !important;
  width: auto;
  height: auto;
  object-fit: contain;
  image-rendering: auto;
  filter: none !important;
  background: transparent !important;
}


/* Ajuste v31: solución real para el logo, sin deformación */
.header-logo-wrap {
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  overflow: visible;
}
.header-logo-banner {
  display: block;
  width: auto !important;
  height: 72px !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: contain !important;
  image-rendering: auto;
  filter: none !important;
  border: 0 !important;
  background: transparent !important;
}
@media (max-width: 1400px) {
  .header-logo-banner {
    height: 66px !important;
  }
}


/* Ajuste v32: logo final limpio, sin espacio blanco y con fondo azul integrado */
.header-logo-wrap {
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.header-logo-banner {
  display: block;
  width: auto !important;
  height: 74px !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: contain !important;
  background: transparent !important;
  border: 0 !important;
  filter: none !important;
}
@media (max-width: 1400px) {
  .header-logo-banner {
    height: 68px !important;
  }
}


/* Ajuste v34: icono interno blanco + página responsive */
.header-logo-banner {
  display: block;
  width: auto !important;
  height: 74px !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: contain !important;
  background: transparent !important;
  border: 0 !important;
  filter: none !important;
}
.table-wrap {
  -webkit-overflow-scrolling: touch;
}
@media (max-width: 1200px) {
  .v15-topbar {
    grid-template-columns: 1fr;
    gap: 14px;
    justify-items: center;
    text-align: center;
    padding: 14px 18px;
  }
  .header-logo-wrap,
  .v15-brand-center,
  .main-nav {
    justify-content: center !important;
  }
  .v15-title {
    white-space: normal;
    font-size: clamp(20px, 4vw, 30px);
    line-height: 1.15;
  }
  .main-nav {
    flex-wrap: wrap;
    gap: 8px;
  }
  .current-card {
    grid-template-columns: 1fr;
  }
  .summary-grid {
    width: 100%;
    grid-template-columns: repeat(2, minmax(140px, 1fr));
  }
}
@media (max-width: 900px) {
  .container {
    width: min(100% - 20px, 100%);
    margin: 16px auto 36px;
  }
  .card,
  .table-card {
    padding: 18px;
    border-radius: 20px;
  }
  .filters {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .section-head,
  .table-head,
  .table-head-actions {
    flex-direction: column;
    align-items: stretch;
  }
  .export-btn,
  .table-refresh-btn {
    width: 100%;
  }
  .layer-filter {
    gap: 8px;
  }
  .layer-btn {
    flex: 1 1 calc(50% - 8px);
    text-align: center;
  }
  .header-logo-banner {
    height: 64px !important;
  }
}
@media (max-width: 640px) {
  .v15-topbar {
    padding: 12px 14px;
  }
  .header-logo-banner {
    height: 56px !important;
  }
  .v15-title {
    font-size: clamp(18px, 5.4vw, 24px);
  }
  .summary-grid {
    grid-template-columns: 1fr;
  }
  .filters {
    grid-template-columns: 1fr;
  }
  .layer-btn {
    flex: 1 1 100%;
  }
  .login-modal {
    padding: 18px;
    border-radius: 18px;
  }
  .login-modal h2 {
    font-size: 24px;
  }
  .main-nav a,
  .nav-action-btn,
  .user-menu-toggle {
    width: 100%;
    justify-content: center;
  }
  .nav-user-menu,
  .user-dropdown {
    width: 100%;
  }
  .user-dropdown {
    right: auto;
    left: 50%;
    transform: translateX(-50%);
    min-width: min(260px, calc(100vw - 32px));
  }
}


/* Ajuste v35: administración de usuarios + volver al logo anterior */
.header-logo-banner {
  display: block;
  width: auto !important;
  height: 74px !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: contain !important;
  background: transparent !important;
  border: 0 !important;
  filter: none !important;
}

.user-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  align-items: end;
}
.user-form button {
  align-self: end;
}
.users-summary {
  background: #f8fafc;
  border: 1px solid #dbe4f0;
  color: #334155;
  border-radius: 14px;
  padding: 12px 14px;
  font-weight: 800;
  margin: 12px 0;
}
.users-table-wrap {
  border: 1px solid #dbe4f0;
  border-radius: 16px;
  overflow: auto;
  background: #fff;
}
.users-table {
  min-width: 520px;
}
.connection-pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border-radius: 999px;
  padding: 6px 10px;
  font-weight: 900;
  font-size: 12px;
}
.connection-pill::before {
  content: "";
  width: 9px;
  height: 9px;
  border-radius: 50%;
}
.connection-pill.is-online {
  background: #dcfce7;
  color: #166534;
}
.connection-pill.is-online::before {
  background: #22c55e;
}
.connection-pill.is-offline {
  background: #f1f5f9;
  color: #64748b;
}
.connection-pill.is-offline::before {
  background: #94a3b8;
}

@media (max-width: 900px) {
  .user-form {
    grid-template-columns: 1fr;
  }
  .users-table {
    min-width: 480px;
  }
}


/* Ajuste v36: eliminar usuarios y texto Usuario */
.delete-user-btn {
  background: #fff1f2;
  color: #be123c;
  border: 1px solid #fecdd3;
  border-radius: 999px;
  box-shadow: none;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 900;
}
.delete-user-btn:hover {
  background: #ffe4e6;
  color: #9f1239;
}
.delete-user-btn:disabled {
  opacity: .45;
  cursor: not-allowed;
  background: #f1f5f9;
  color: #64748b;
  border-color: #e2e8f0;
}
.users-table th:last-child,
.users-table td:last-child {
  text-align: center;
  white-space: nowrap;
}


/* Ajuste v37: visor gráfico y listado de usuarios compacto */
.visor-hero-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}
.visor-card {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 18px;
  min-height: 560px;
}
.visor-sidebar {
  background: #f8fbff;
  border: 1px solid #dbe4f0;
  border-radius: 18px;
  padding: 18px;
}
.visor-sidebar h3 {
  margin-bottom: 14px;
}
.visor-layer-check {
  display: flex;
  grid-template-columns: none;
  align-items: center;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid #e6eef8;
}
.visor-layer-check input {
  width: 16px;
  height: 16px;
}
.visor-note {
  margin-top: 16px;
  color: #64748b;
  font-size: 13px;
  line-height: 1.45;
  background: #ffffff;
  border: 1px dashed #cbd5e1;
  border-radius: 14px;
  padding: 12px;
}
.map-demo {
  position: relative;
  overflow: hidden;
  min-height: 520px;
  border-radius: 22px;
  border: 1px solid #cbd5e1;
  background: linear-gradient(180deg, #f8fbff, #eaf3ff);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.9);
}
.map-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(37,99,235,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,.08) 1px, transparent 1px);
  background-size: 42px 42px;
}
.map-shape {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  color: #0f172a;
  border: 3px solid currentColor;
  background: rgba(255,255,255,.70);
  box-shadow: 0 10px 22px rgba(15,23,42,.10);
}
.lote {
  left: 16%; top: 18%; width: 58%; height: 52%;
  color: #2563eb;
  border-radius: 14px;
  transform: rotate(-4deg);
}
.edifica {
  left: 36%; top: 34%; width: 22%; height: 20%;
  color: #16a34a;
  border-radius: 10px;
}
.construccion {
  left: 56%; top: 48%; width: 18%; height: 16%;
  color: #f59e0b;
  border-radius: 10px;
}
.puerta {
  left: 26%; top: 67%; width: 70px; height: 34px;
  color: #9333ea;
  border-radius: 999px;
  font-size: 12px;
}
.map-observation {
  position: absolute;
  left: 64%; top: 31%;
  width: 38px; height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #ef4444;
  color: #fff;
  font-weight: 900;
  box-shadow: 0 10px 22px rgba(239,68,68,.28);
}
.map-popup {
  position: absolute;
  left: 68%; top: 24%;
  background: #ffffff;
  border: 1px solid #dbe4f0;
  border-radius: 14px;
  padding: 10px 12px;
  box-shadow: 0 14px 30px rgba(15,23,42,.16);
  font-size: 13px;
}
.map-pulse {
  animation: mapPulse .7s ease;
}
@keyframes mapPulse {
  0% { box-shadow: 0 0 0 0 rgba(37,99,235,.28); }
  100% { box-shadow: 0 0 0 18px rgba(37,99,235,0); }
}
.user-search-label {
  margin: 12px 0;
}
.users-table-wrap {
  max-height: 302px;
  overflow-y: auto;
  overflow-x: auto;
}
.users-table th {
  position: sticky;
  top: 0;
  z-index: 2;
}

@media (max-width: 900px) {
  .visor-hero-card {
    flex-direction: column;
    align-items: stretch;
  }
  .visor-card {
    grid-template-columns: 1fr;
    min-height: auto;
  }
  .map-demo {
    min-height: 420px;
  }
}
@media (max-width: 640px) {
  .map-demo {
    min-height: 340px;
  }
  .map-popup {
    left: 42%;
    top: 12%;
  }
}


/* Ajuste v38: cabecera corregida, visor tipo catastral y panel de usuarios al final */
.v15-topbar {
  grid-template-columns: minmax(230px, 300px) minmax(420px, 1fr) auto !important;
  column-gap: 18px !important;
  padding: 14px 24px !important;
  min-height: 96px !important;
  align-items: center !important;
}
.v15-title {
  white-space: nowrap !important;
  overflow: visible !important;
  text-overflow: clip !important;
  font-size: clamp(23px, 2.15vw, 38px) !important;
  line-height: 1.05 !important;
  letter-spacing: -0.01em !important;
}
.main-nav {
  flex-wrap: nowrap !important;
  gap: 8px !important;
}
.main-nav a,
.nav-action-btn,
.user-menu-toggle {
  padding: 10px 12px !important;
}
.header-logo-banner {
  height: 74px !important;
}
@media (max-width: 1400px) {
  .v15-topbar {
    grid-template-columns: minmax(210px, 260px) minmax(340px, 1fr) auto !important;
    padding: 12px 18px !important;
  }
  .v15-title {
    font-size: clamp(20px, 1.85vw, 31px) !important;
  }
  .header-logo-banner {
    height: 66px !important;
  }
}
@media (max-width: 1100px) {
  .v15-topbar {
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    text-align: center !important;
  }
  .v15-title {
    white-space: normal !important;
  }
  .main-nav {
    flex-wrap: wrap !important;
    justify-content: center !important;
  }
}

/* Visor renovado */
.viewer-page-shell {
  width: min(1440px, calc(100% - 30px));
  margin: 18px auto 46px;
}
.viewer-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  margin-bottom: 14px;
}
.viewer-toolbar h2 {
  margin: 10px 0 0;
  font-size: 26px;
}
.viewer-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.viewer-layout {
  padding: 0;
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr);
  min-height: 650px;
  overflow: hidden;
}
.viewer-panel {
  background: #ffffff;
  border-right: 1px solid #dbe4f0;
  min-height: 650px;
  display: flex;
  flex-direction: column;
}
.viewer-panel-header {
  background: linear-gradient(135deg, #0f172a, #1f3a8a);
  color: #fff;
  padding: 18px 20px;
  text-align: center;
}
.viewer-panel-header h3 {
  margin: 0;
  font-size: 18px;
  font-weight: 900;
}
.viewer-panel-content {
  padding: 18px;
  overflow: auto;
}
.viewer-section {
  margin-bottom: 18px;
}
.viewer-section h4 {
  margin: 0 0 12px;
  color: #172033;
  font-size: 15px;
  font-weight: 900;
}
.viewer-section label:not(.visor-layer-check) {
  margin-bottom: 10px;
}
.viewer-search-btn {
  width: 100%;
  margin-top: 6px;
  border-radius: 14px;
}
.visor-layer-check {
  display: flex;
  grid-template-columns: none;
  align-items: center;
  gap: 10px;
  padding: 10px 10px;
  margin-bottom: 8px;
  border: 1px solid #e4edf8;
  border-radius: 12px;
  background: #f8fbff;
  cursor: pointer;
}
.visor-layer-check input {
  width: 16px;
  height: 16px;
}
.visor-layer-check span {
  color: #334155;
  font-weight: 800;
}
.viewer-note {
  color: #64748b;
  background: #f8fafc;
  border: 1px dashed #cbd5e1;
  border-radius: 14px;
  padding: 12px;
  font-size: 13px;
  line-height: 1.45;
}
.viewer-map {
  position: relative;
  min-height: 650px;
  overflow: hidden;
  background: linear-gradient(180deg, #eaf3ff, #f8fbff);
}
.viewer-map::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(37,99,235,.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,.10) 1px, transparent 1px);
  background-size: 46px 46px;
}
.map-grid { display: none; }
.leaflet-fake-controls {
  position: absolute;
  left: 16px;
  top: 16px;
  z-index: 5;
  display: grid;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 8px 22px rgba(15,23,42,.14);
}
.leaflet-fake-controls button {
  width: 36px;
  height: 36px;
  border-radius: 0;
  background: #fff;
  color: #172033;
  box-shadow: none;
  border-bottom: 1px solid #e2e8f0;
  padding: 0;
  font-size: 22px;
}
.north-control {
  position: absolute;
  top: 18px;
  right: 18px;
  z-index: 5;
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #fff;
  border: 2px solid #334155;
  font-weight: 900;
  color: #334155;
  box-shadow: 0 8px 18px rgba(15,23,42,.14);
}
.map-polygon,
.map-shape {
  position: absolute;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  color: #0f172a;
  border: 3px solid currentColor;
  background: rgba(255,255,255,.62);
  box-shadow: 0 10px 22px rgba(15,23,42,.10);
}
.manzana-shape {
  left: 13%; top: 17%; width: 64%; height: 58%;
  color: #0f766e;
  border-radius: 20px;
  transform: rotate(-3deg);
  background: rgba(240,253,250,.50);
}
.lote {
  left: 22%; top: 28%; width: 44%; height: 35%;
  color: #2563eb;
  border-radius: 14px;
  transform: rotate(-3deg);
}
.edifica {
  left: 39%; top: 40%; width: 18%; height: 16%;
  color: #16a34a;
  border-radius: 10px;
}
.construccion {
  left: 58%; top: 50%; width: 16%; height: 14%;
  color: #f59e0b;
  border-radius: 10px;
}
.puerta {
  left: 28%; top: 66%; width: 76px; height: 36px;
  color: #9333ea;
  border-radius: 999px;
  font-size: 12px;
}
.map-observation {
  position: absolute;
  z-index: 4;
  left: 66%; top: 33%;
  width: 38px; height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #ef4444;
  color: #fff;
  font-weight: 900;
  box-shadow: 0 10px 22px rgba(239,68,68,.28);
}
.map-popup {
  position: absolute;
  z-index: 4;
  left: 70%; top: 26%;
  background: #ffffff;
  border: 1px solid #dbe4f0;
  border-radius: 14px;
  padding: 11px 13px;
  box-shadow: 0 14px 30px rgba(15,23,42,.16);
  font-size: 13px;
  line-height: 1.45;
}
.map-pulse {
  animation: mapPulse .7s ease;
}
@keyframes mapPulse {
  0% { box-shadow: 0 0 0 0 rgba(37,99,235,.28); }
  100% { box-shadow: 0 0 0 18px rgba(37,99,235,0); }
}

/* Usuarios al final: buscador y scroll máximo 5 registros */
.user-search-label {
  margin: 12px 0;
}
.users-table-wrap {
  max-height: 258px !important;
  overflow-y: auto !important;
  overflow-x: auto !important;
}
.users-table th {
  position: sticky;
  top: 0;
  z-index: 2;
}

@media (max-width: 900px) {
  .viewer-toolbar {
    flex-direction: column;
    align-items: stretch;
  }
  .viewer-layout {
    grid-template-columns: 1fr;
  }
  .viewer-panel,
  .viewer-map,
  .viewer-layout {
    min-height: auto;
  }
  .viewer-map {
    min-height: 430px;
  }
}
@media (max-width: 640px) {
  .viewer-page-shell {
    width: calc(100% - 18px);
    margin-top: 12px;
  }
  .viewer-map {
    min-height: 360px;
  }
  .map-popup {
    left: 38%;
    top: 12%;
  }
}


/* Ajuste v39: visor Leaflet a pantalla completa y cabecera sin corte */
.v15-topbar {
  grid-template-columns: minmax(230px, 300px) minmax(0, 1fr) auto !important;
  column-gap: 16px !important;
  padding: 12px 24px !important;
  min-height: 92px !important;
}
.v15-title {
  font-size: clamp(20px, 2vw, 34px) !important;
  line-height: 1.05 !important;
  white-space: nowrap !important;
  overflow: visible !important;
  text-overflow: clip !important;
  letter-spacing: -0.01em !important;
}
.main-nav {
  flex-wrap: nowrap !important;
  gap: 7px !important;
}
.main-nav a,
.nav-action-btn,
.user-menu-toggle {
  padding: 9px 12px !important;
  font-size: 14px !important;
}
.header-logo-banner {
  height: 70px !important;
}
.viewer-full-shell {
  width: 100%;
  margin: 0;
  padding: 0;
}
.viewer-layout-full {
  border-radius: 0;
  border-left: 0;
  border-right: 0;
  border-bottom: 0;
  box-shadow: none;
  margin: 0;
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr);
  min-height: calc(100vh - 92px);
  padding: 0;
  overflow: hidden;
}
.viewer-layout-full .viewer-panel {
  min-height: calc(100vh - 92px);
  border-radius: 0;
  z-index: 600;
  box-shadow: 8px 0 24px rgba(15, 23, 42, .08);
}
.viewer-layout-full .viewer-panel-header {
  border-radius: 0;
}
.leaflet-map {
  position: relative;
  width: 100%;
  height: calc(100vh - 92px);
  min-height: 560px;
  background: #dbeafe;
}
.leaflet-map .map-loading {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: #334155;
  font-weight: 900;
  z-index: 1;
}
.leaflet-control-attribution {
  font-size: 10px;
}
.leaflet-control-zoom a {
  font-family: Arial, sans-serif;
  font-weight: 900;
}
.north-leaflet-control {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #ffffff;
  border: 2px solid #0f172a;
  box-shadow: 0 8px 22px rgba(15,23,42,.18);
  display: grid;
  place-items: center;
  position: relative;
  font-weight: 900;
  color: #0f172a;
}
.north-leaflet-control::before {
  content: "";
  position: absolute;
  top: 5px;
  width: 0;
  height: 0;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  border-bottom: 12px solid #ef4444;
}
.north-leaflet-control span {
  margin-top: 12px;
  font-size: 14px;
}
.viewer-legend {
  background: #f8fbff;
  border: 1px solid #e4edf8;
  border-radius: 14px;
  padding: 12px;
}
.viewer-legend div {
  display: flex;
  align-items: center;
  gap: 9px;
  margin: 7px 0;
  color: #334155;
  font-weight: 800;
  font-size: 13px;
}
.legend-line {
  width: 26px;
  height: 0;
  border-top: 4px solid;
  display: inline-block;
}
.legend-dot {
  width: 13px;
  height: 13px;
  border-radius: 50%;
  display: inline-block;
}
.lote-color { border-color: #2563eb; }
.edifica-color { border-color: #16a34a; }
.construccion-color { border-color: #f59e0b; }
.puerta-color { background: #9333ea; }
.leaflet-popup-content {
  font-family: Inter, Segoe UI, Arial, sans-serif;
  font-size: 13px;
  line-height: 1.45;
}
.viewer-section .visor-layer-check:last-child {
  margin-bottom: 0;
}
@media (max-width: 1500px) {
  .v15-title { font-size: clamp(18px, 1.75vw, 30px) !important; }
  .header-logo-banner { height: 64px !important; }
  .v15-topbar { min-height: 86px !important; }
  .viewer-layout-full { min-height: calc(100vh - 86px); }
  .viewer-layout-full .viewer-panel { min-height: calc(100vh - 86px); }
  .leaflet-map { height: calc(100vh - 86px); }
}
@media (max-width: 1200px) {
  .v15-topbar {
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    text-align: center !important;
  }
  .v15-title { white-space: normal !important; }
  .main-nav { flex-wrap: wrap !important; justify-content: center !important; }
  .viewer-layout-full { grid-template-columns: 1fr; }
  .viewer-layout-full .viewer-panel { min-height: auto; }
  .leaflet-map { height: 62vh; min-height: 430px; }
}
@media (max-width: 720px) {
  .viewer-panel-content { padding: 14px; }
  .leaflet-map { height: 58vh; min-height: 360px; }
}

/* Ajuste v40: visor catastral tipo Leaflet con panel lateral */
.compact-topbar.v15-topbar {
  grid-template-columns: minmax(230px, 300px) minmax(0, 1fr) auto !important;
  min-height: 92px !important;
  padding: 12px 24px !important;
  column-gap: 18px !important;
}
.compact-topbar .v15-title {
  white-space: nowrap !important;
  overflow: visible !important;
  text-overflow: clip !important;
  font-size: clamp(20px, 1.85vw, 32px) !important;
  letter-spacing: -0.01em !important;
  line-height: 1.05 !important;
}
.compact-topbar .main-nav {
  flex-wrap: nowrap !important;
  gap: 8px !important;
}
.compact-topbar .main-nav a,
.compact-topbar .nav-action-btn,
.compact-topbar .user-menu-toggle {
  padding: 9px 12px !important;
  font-size: 14px !important;
}
.compact-topbar .header-logo-banner {
  height: 70px !important;
}
.viewer-body {
  overflow: hidden;
}
.catastro-viewer-shell {
  height: calc(100vh - 92px);
  min-height: 560px;
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  background: #eef4fb;
}
.catastro-sidebar {
  min-width: 0;
  height: calc(100vh - 92px);
  background: #ffffff;
  border-right: 1px solid #d6e1ef;
  display: flex;
  flex-direction: column;
  z-index: 700;
  box-shadow: 8px 0 24px rgba(15,23,42,.08);
  transition: margin-left .22s ease;
}
.catastro-sidebar.is-collapsed {
  margin-left: -280px;
}
.catastro-sidebar-title {
  height: 62px;
  background: linear-gradient(135deg, #0f172a, #1d4ed8);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: 0 48px 0 18px;
}
.catastro-sidebar-title h3 {
  font-size: 18px;
  margin: 0;
  letter-spacing: -.01em;
}
.sidebar-collapse-btn {
  position: absolute;
  right: -18px;
  top: 16px;
  width: 36px;
  height: 30px;
  padding: 0;
  border-radius: 999px;
  box-shadow: 0 8px 18px rgba(15,23,42,.18);
  background: rgba(255,255,255,.22);
  border: 1px solid rgba(255,255,255,.28);
  color: #fff;
  font-size: 24px;
  line-height: 1;
  z-index: 15;
}
.catastro-sidebar-scroll {
  overflow-y: auto;
  padding: 16px 16px 24px;
}
.catastro-panel-section {
  border-bottom: 1px solid #e5edf7;
  padding-bottom: 16px;
  margin-bottom: 16px;
}
.catastro-panel-section h4 {
  font-size: 15px;
  margin: 0 0 12px;
  color: #0f172a;
}
.catastro-panel-section label {
  margin-bottom: 12px;
}
.catastro-panel-section input[type="text"] {
  height: 42px;
  border-radius: 8px;
  font-size: 14px;
}
.catastro-search-btn {
  width: 100%;
  background: linear-gradient(135deg, #0ea5e9, #2563eb);
  border-radius: 9px;
  box-shadow: 0 8px 18px rgba(37,99,235,.20);
}
.catastro-warning {
  margin-top: 12px;
  color: #92400e;
  font-size: 12px;
  line-height: 1.4;
}
.layer-group-title {
  width: 100%;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  color: #0f172a;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: none;
  border-radius: 6px;
  padding: 10px 12px;
  margin-bottom: 10px;
}
.catastro-layer-check {
  display: flex;
  grid-template-columns: none;
  align-items: center;
  gap: 10px;
  padding: 10px 8px;
  border-radius: 6px;
  background: #f8fafc;
  color: #0f172a;
  font-weight: 700;
  margin-bottom: 8px !important;
}
.catastro-layer-check input {
  width: 18px;
  height: 18px;
  accent-color: #2563eb;
}
.catastro-map-area {
  position: relative;
  min-width: 0;
}
.catastro-leaflet-map {
  width: 100%;
  height: calc(100vh - 92px);
  min-height: 560px;
  background: #e5edf5;
}
.catastro-leaflet-map .map-loading {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: #334155;
  font-weight: 900;
  z-index: 1;
}
.open-sidebar-btn {
  position: absolute;
  left: 12px;
  top: 12px;
  z-index: 900;
  border-radius: 8px;
  background: #ffffff;
  color: #0f172a;
  box-shadow: 0 8px 18px rgba(15,23,42,.16);
  border: 1px solid #dbe4f0;
}
.catastro-north-control {
  width: 34px;
  height: 34px;
  border-radius: 50% !important;
  display: grid;
  place-items: center;
  background: #fff !important;
  color: #0f172a;
  box-shadow: 0 4px 10px rgba(15,23,42,.22);
  border: 2px solid #334155 !important;
  font-size: 12px;
  position: relative;
}
.catastro-north-control .north-arrow {
  color: #1d4ed8;
  font-size: 12px;
  line-height: 1;
  position: absolute;
  top: 3px;
}
.catastro-north-control strong {
  position: absolute;
  bottom: 5px;
  font-size: 13px;
}
.catastro-tool-control {
  margin-top: 12px !important;
  display: grid;
  overflow: hidden;
  border-radius: 8px !important;
  box-shadow: 0 4px 10px rgba(15,23,42,.12);
}
.catastro-tool-control button {
  width: 34px;
  height: 34px;
  padding: 0;
  border-radius: 0;
  background: #fff;
  color: #0f172a;
  border-bottom: 1px solid #e2e8f0;
  box-shadow: none;
  font-size: 17px;
}
.leaflet-control-layers {
  border: 1px solid #dbe4f0 !important;
  border-radius: 8px !important;
  box-shadow: 0 8px 20px rgba(15,23,42,.12) !important;
  font-family: Inter, Segoe UI, Arial, sans-serif;
}
.leaflet-control-layers-expanded {
  padding: 12px 14px !important;
}
.leaflet-control-layers-base label {
  display: flex !important;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  font-size: 12px;
}
.catastro-label {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  font-weight: 900;
  text-shadow: 0 1px 0 #fff, 0 -1px 0 #fff, 1px 0 0 #fff, -1px 0 0 #fff;
  color: #1d4ed8;
}
.manzana-label { color: #a21caf; }
.lote-label { color: #111827; font-size: 11px; }
.edifica-label { color: #dc2626; }
.construccion-label { color: #2563eb; }
.puerta-label {
  color: #075985;
  font-size: 10px;
  letter-spacing: .02em;
}
.catastro-map-legend {
  min-width: 190px;
  background: #ffffff;
  border: 1px solid #dbe4f0;
  border-radius: 10px;
  box-shadow: 0 8px 20px rgba(15,23,42,.12);
  overflow: hidden;
  font-size: 12px;
}
.legend-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  background: #f8fafc;
  border-bottom: 1px solid #e2e8f0;
  font-weight: 900;
}
.legend-collapse {
  width: 28px;
  height: 24px;
  padding: 0;
  border-radius: 6px;
  background: #fff;
  color: #334155;
  box-shadow: none;
  border: 1px solid #dbe4f0;
}
.legend-body {
  padding: 10px 12px 12px;
  display: grid;
  gap: 7px;
}
.catastro-map-legend.is-collapsed .legend-body {
  display: none;
}
.legend-box,
.legend-line-small,
.legend-dot-small {
  display: inline-block;
  vertical-align: middle;
  margin-right: 7px;
}
.legend-box {
  width: 12px;
  height: 12px;
  border: 2px solid currentColor;
  border-radius: 3px;
}
.legend-box.manzana { color: #ff00ff; }
.legend-box.lote { color: #facc15; }
.legend-box.edifica { color: #ef4444; }
.legend-line-small {
  width: 16px;
  height: 3px;
  background: #2563eb;
}
.legend-dot-small {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #111827;
}
@media (max-width: 1320px) {
  .compact-topbar.v15-topbar {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
    min-height: auto !important;
  }
  .compact-topbar .v15-title {
    white-space: normal !important;
    font-size: clamp(22px, 4vw, 32px) !important;
  }
  .compact-topbar .main-nav {
    flex-wrap: wrap !important;
    justify-content: center !important;
  }
  .catastro-viewer-shell,
  .catastro-sidebar,
  .catastro-leaflet-map {
    height: calc(100vh - 184px);
  }
}
@media (max-width: 900px) {
  .catastro-viewer-shell {
    grid-template-columns: 1fr;
  }
  .catastro-sidebar {
    position: absolute;
    left: 0;
    top: 0;
    width: 280px;
    max-width: 86vw;
  }
  .catastro-sidebar.is-collapsed {
    margin-left: -290px;
  }
}


/* Ajuste v41: visor más limpio y controles sincronizados */
.catastro-viewer-shell {
  grid-template-columns: 280px minmax(0, 1fr);
  transition: grid-template-columns .24s ease;
}
.catastro-viewer-shell.sidebar-collapsed {
  grid-template-columns: 0 minmax(0, 1fr);
}
.catastro-sidebar {
  width: 280px;
  transition: transform .24s ease, opacity .18s ease;
}
.catastro-sidebar.is-collapsed {
  margin-left: 0 !important;
  transform: translateX(-100%);
  opacity: 0;
  pointer-events: none;
}
.open-sidebar-btn {
  left: 14px;
  top: 14px;
  width: 42px;
  height: 42px;
  padding: 0;
  display: grid;
  place-items: center;
  font-size: 20px;
}
.sidebar-collapse-btn {
  right: 12px !important;
  top: 16px !important;
  background: rgba(255,255,255,.16) !important;
}

/* Norte mejorado */
.catastro-north-control {
  width: 42px !important;
  height: 42px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,.96) !important;
  border: 1px solid #cbd5e1 !important;
  box-shadow: 0 5px 14px rgba(15,23,42,.20) !important;
  display: grid;
  place-items: center;
}
.north-compass {
  position: relative;
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
}
.north-compass svg {
  width: 32px;
  height: 32px;
  display: block;
}
.north-letter {
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  color: #0f172a;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .02em;
}
.needle-main { fill: #1d4ed8; stroke: #0f172a; stroke-width: 1.2; }
.needle-tail { fill: #ffffff; stroke: #0f172a; stroke-width: 1.2; }

/* Herramientas sin botón de ayuda */
.catastro-tool-control {
  margin-top: 10px !important;
}
.catastro-tool-control button:last-child {
  border-bottom: 0;
}

/* Capas base mejor alineadas */
.leaflet-control-layers {
  border: 1px solid #dbe4f0 !important;
  border-radius: 12px !important;
  overflow: hidden;
  background: #ffffff !important;
}
.leaflet-control-layers-expanded {
  min-width: 180px;
  padding: 12px 14px !important;
}
.leaflet-control-layers-base::before {
  content: 'Mapa base';
  display: block;
  color: #334155;
  font-size: 13px;
  font-weight: 900;
  margin-bottom: 8px;
}
.leaflet-control-layers-base label {
  display: block !important;
  margin: 8px 0 !important;
  font-size: 13px !important;
  color: #334155;
  line-height: 1.2;
}
.leaflet-control-layers-base label > span {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  white-space: nowrap;
}
.leaflet-control-layers-base input[type="radio"] {
  width: 15px !important;
  height: 15px !important;
  margin: 0 !important;
  accent-color: #2563eb;
  flex: 0 0 auto;
}
.leaflet-control-layers-overlays,
.leaflet-control-layers-separator {
  display: none !important;
}

/* Leyenda sincronizada con capas activas */
.catastro-map-legend {
  min-width: 190px;
}
.legend-body b {
  display: block;
  margin-bottom: 7px;
  color: #334155;
}
.legend-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 6px 0;
  color: #334155;
  font-weight: 700;
}
.legend-empty {
  color: #64748b;
  font-style: italic;
  padding: 4px 0;
}
.legend-box,
.legend-line-small,
.legend-dot-small {
  margin-right: 0 !important;
  flex: 0 0 auto;
}

@media (max-width: 900px) {
  .catastro-viewer-shell {
    grid-template-columns: 1fr;
  }
  .catastro-viewer-shell.sidebar-collapsed {
    grid-template-columns: 1fr;
  }
  .catastro-sidebar {
    transform: translateX(0);
  }
  .catastro-sidebar.is-collapsed {
    transform: translateX(-105%);
  }
}


/* v42 visor refinado */
.topbar.compact-topbar .v15-title, .v15-title {
  font-size: clamp(28px, 3.8vw, 44px);
}
.catastro-main-shell {
  width: 100%;
  margin: 0;
}
.catastro-viewer-shell {
  height: calc(100vh - 102px);
}
.catastro-sidebar {
  background: #ffffff;
}
.catastro-sidebar-title {
  justify-content: flex-end;
  height: 58px;
  padding: 0 14px;
}
.catastro-sidebar-title h3 { display: none; }
.sidebar-collapse-btn {
  position: static;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: rgba(255,255,255,.18) !important;
  color: #fff;
  font-size: 22px;
  line-height: 1;
}
.catastro-sidebar-scroll {
  padding-top: 14px;
}
.catastro-panel-section:last-child {
  border-bottom: 0;
  margin-bottom: 0;
  padding-bottom: 12px;
}
.catastro-layer-check {
  justify-content: flex-start;
}
.catastro-layer-check span {
  font-size: 14px;
}
.open-sidebar-btn {
  border-radius: 10px;
  width: 40px;
  height: 40px;
}
.catastro-tool-control button {
  font-size: 16px;
}
.catastro-north-control {
  width: 46px !important;
  height: 46px !important;
  padding: 0 !important;
}
.north-compass {
  width: 36px;
  height: 36px;
}
.north-compass svg {
  width: 36px;
  height: 36px;
}
.north-letter {
  top: 1px;
  font-size: 11px;
  font-weight: 900;
  color: #0f172a;
}
.north-ring {
  fill: #ffffff;
  stroke: #94a3b8;
  stroke-width: 1.5;
}
.needle-main {
  fill: #2563eb;
  stroke: #0f172a;
  stroke-width: 1.1;
}
.needle-tail {
  fill: #ef4444;
  stroke: #0f172a;
  stroke-width: 1.1;
}
.catastro-map-legend {
  min-width: 165px;
}
.legend-body {
  padding-top: 12px;
}
.legend-head {
  font-size: 13px;
}
.legend-empty {
  margin: 0;
}
/* remove any left legend leftovers */
.viewer-legend { display: none !important; }

/* improve base layer control alignment */
.leaflet-control-layers-base label {
  margin: 6px 0 !important;
}
.leaflet-control-layers-base label > span {
  align-items: center !important;
}
/* sidebar collapse responsive */
@media (max-width: 1180px) {
  .topbar.compact-topbar, .topbar.v15-topbar {
    padding: 18px 22px;
    min-height: 104px;
  }
  .catastro-viewer-shell, .catastro-sidebar, .catastro-leaflet-map {
    height: calc(100vh - 104px);
  }
}
@media (max-width: 900px) {
  .catastro-sidebar {
    position: absolute;
    width: min(290px, 84vw);
    max-width: 84vw;
    height: 100%;
  }
  .catastro-viewer-shell {
    height: calc(100vh - 96px);
  }
  .catastro-leaflet-map {
    height: calc(100vh - 96px);
    min-height: 440px;
  }
}


/* v43 visor: panel sin franja, orden de capas, popups/etiquetas y norte limpio */
.catastro-sidebar {
  position: relative;
}
.catastro-sidebar-title {
  display: none !important;
}
.sidebar-collapse-btn {
  position: absolute !important;
  right: 12px !important;
  top: 10px !important;
  z-index: 30;
  width: 34px !important;
  height: 34px !important;
  padding: 0 !important;
  display: grid;
  place-items: center;
  border-radius: 999px !important;
  background: #2563eb !important;
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,.55) !important;
  box-shadow: 0 8px 18px rgba(15,23,42,.20) !important;
  font-size: 22px !important;
}
.catastro-sidebar-scroll {
  padding-top: 16px !important;
}
.catastro-panel-section:first-child {
  padding-top: 0;
}
.catastro-layer-group {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  margin-bottom: 9px;
  overflow: hidden;
}
.catastro-layer-group .catastro-layer-check {
  margin-bottom: 0 !important;
  border-radius: 0;
  background: #f8fafc;
}
.catastro-layer-check.main-layer {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 9px;
  margin-bottom: 9px !important;
  background: #f8fafc;
}
.catastro-layer-check.main-layer > span {
  flex: 1;
}
.layer-toggle {
  width: 28px;
  height: 24px;
  padding: 0;
  box-shadow: none;
  background: transparent;
  color: #334155;
  border-radius: 6px;
  font-size: 14px;
  transform: rotate(-90deg);
  transition: transform .18s ease, background .18s ease;
}
.layer-toggle:hover {
  background: #e2e8f0;
  color: #0f172a;
}
.catastro-layer-group.is-open .layer-toggle {
  transform: rotate(0deg);
}
.layer-suboptions {
  display: none;
  padding: 0 8px 9px 32px;
  background: #ffffff;
  border-top: 1px solid #e2e8f0;
}
.catastro-layer-group.is-open .layer-suboptions {
  display: grid;
  gap: 4px;
}
.catastro-layer-check.sub-layer {
  margin: 0 !important;
  padding: 7px 6px;
  background: transparent;
  font-size: 12px;
  color: #475569;
}
.catastro-layer-check.sub-layer input {
  width: 15px;
  height: 15px;
}
.catastro-tool-control button {
  border-bottom: 0 !important;
}
.catastro-north-control {
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,.98) !important;
  border: 1px solid #cbd5e1 !important;
  box-shadow: 0 6px 16px rgba(15,23,42,.20) !important;
  padding: 0 !important;
  display: grid !important;
  place-items: center !important;
}
.north-symbol {
  position: relative;
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
}
.north-symbol span {
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 10px;
  font-weight: 900;
  color: #0f172a;
  z-index: 3;
}
.north-pointer {
  width: 0;
  height: 0;
  border-left: 9px solid transparent;
  border-right: 9px solid transparent;
  border-bottom: 27px solid #2563eb;
  position: relative;
  transform: translateY(4px);
  filter: drop-shadow(0 1px 0 #0f172a);
}
.north-pointer::after {
  content: "";
  position: absolute;
  left: -5px;
  top: 8px;
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-bottom: 15px solid #ffffff;
}
.legend-box.construccion { color: #2563eb; }
.legend-dot-small.puerta {
  background: #06b6d4;
  border: 2px solid #06b6d4;
}
.catastro-label {
  pointer-events: none;
}
@media (max-width: 900px) {
  .sidebar-collapse-btn {
    right: 10px !important;
    top: 10px !important;
  }
  .catastro-sidebar-scroll {
    padding-top: 54px !important;
  }
}


/* v44: visor refinado - norte, panel, acordeones y controles */
/* Botón para abrir barra lateral: evita superponerse con zoom/norte */
.open-sidebar-btn {
  top: 156px !important;
  left: 14px !important;
  width: 42px !important;
  height: 42px !important;
  border-radius: 12px !important;
  background: #ffffff !important;
  color: #0f172a !important;
  border: 1px solid #cbd5e1 !important;
  box-shadow: 0 10px 24px rgba(15,23,42,.18) !important;
}

/* Títulos del panel izquierdo */
.catastro-panel-section h4 {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  margin: 0 0 14px !important;
  padding: 10px 12px;
  border-radius: 12px;
  background: linear-gradient(135deg, #eaf3ff, #f8fbff);
  border: 1px solid #dbeafe;
  color: #0f172a;
  font-size: 15px !important;
  font-weight: 900;
}
.catastro-panel-section:first-child h4::before {
  content: '⌕';
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 8px;
  background: #2563eb;
  color: #ffffff;
  font-size: 14px;
}
.catastro-panel-section:nth-child(2) h4::before {
  content: '☰';
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 8px;
  background: #0f172a;
  color: #ffffff;
  font-size: 13px;
}

/* Acordeones de capas más limpios */
.catastro-layer-group {
  border-radius: 12px !important;
  border: 1px solid #dbe4f0 !important;
  background: #ffffff !important;
  box-shadow: 0 4px 12px rgba(15,23,42,.035);
  overflow: hidden;
}
.catastro-layer-check.main-layer {
  border-radius: 12px !important;
  background: #f8fafc !important;
  border: 1px solid #e5edf7 !important;
  padding: 11px 10px !important;
}
.catastro-layer-group .catastro-layer-check.main-layer {
  border: 0 !important;
  border-radius: 0 !important;
}
.layer-toggle {
  width: 30px !important;
  height: 28px !important;
  color: #475569 !important;
  background: #ffffff !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 9px !important;
  transform: rotate(-90deg) !important;
}
.catastro-layer-group.is-open .layer-toggle {
  transform: rotate(0deg) !important;
  background: #eff6ff !important;
  color: #1d4ed8 !important;
  border-color: #bfdbfe !important;
}
.layer-suboptions {
  padding: 8px 10px 10px 34px !important;
  background: #ffffff !important;
}
.catastro-layer-check.sub-layer {
  border-radius: 10px !important;
  background: #f8fafc !important;
  border: 1px solid #edf2f7 !important;
  margin-bottom: 6px !important;
  padding: 8px 8px !important;
}

/* Mapa base minimizable y mejor alineado */
.leaflet-control-layers {
  border-radius: 12px !important;
}
.leaflet-control-layers-toggle {
  width: 40px !important;
  height: 40px !important;
  background-size: 22px 22px !important;
}
.leaflet-control-layers-expanded {
  min-width: 190px !important;
}
.leaflet-control-layers-base label {
  margin: 7px 0 !important;
}
.leaflet-control-layers-base label > span {
  display: grid !important;
  grid-template-columns: 16px 1fr;
  gap: 8px !important;
  align-items: center !important;
}

/* Norte nuevo: estilo brújula limpio */
.catastro-north-control {
  width: 46px !important;
  height: 46px !important;
  border-radius: 50% !important;
  padding: 0 !important;
  display: grid !important;
  place-items: center !important;
  background: rgba(255,255,255,.98) !important;
  border: 1px solid #cbd5e1 !important;
  box-shadow: 0 7px 18px rgba(15,23,42,.18) !important;
}
.north-symbol, .north-pointer { display: none !important; }
.north-rose {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
}
.north-rose svg {
  width: 40px;
  height: 40px;
  display: block;
}
.rose-bg {
  fill: #ffffff;
  stroke: #334155;
  stroke-width: 1.4;
}
.rose-line {
  stroke: #cbd5e1;
  stroke-width: .8;
}
.rose-north {
  fill: #ef4444;
  stroke: #111827;
  stroke-width: 1;
}
.rose-south {
  fill: #e5e7eb;
  stroke: #111827;
  stroke-width: 1;
}
.rose-text {
  fill: #0f172a;
  font-size: 9px;
  font-weight: 900;
  text-anchor: middle;
  font-family: Arial, sans-serif;
}

/* Leyenda se mantiene abierta y limpia */
.catastro-map-legend {
  border-radius: 12px !important;
}
.legend-box.construccion {
  color: #2563eb !important;
}

@media (max-width: 900px) {
  .open-sidebar-btn {
    top: 150px !important;
  }
}


/* v45: limpieza del visor lateral y norte más claro */
/* Sin título Buscador: comienza directo por Sector */
.search-section-no-title {
  padding-top: 4px !important;
}
.search-section-no-title h4 {
  display: none !important;
}

/* Quitar iconos de títulos del panel izquierdo */
.catastro-panel-section h4::before,
.catastro-panel-section:first-child h4::before,
.catastro-panel-section:nth-child(2) h4::before {
  content: none !important;
  display: none !important;
}
.catastro-panel-section h4 {
  padding-left: 12px !important;
}

/* Mejor botón contraer / desplegar barra lateral */
.catastro-sidebar {
  position: relative;
}
.sidebar-collapse-btn {
  position: absolute !important;
  right: -17px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 34px !important;
  height: 42px !important;
  border-radius: 999px !important;
  z-index: 1200 !important;
  background: #2563eb !important;
  border: 1px solid rgba(255,255,255,.65) !important;
  box-shadow: 0 10px 24px rgba(15,23,42,.22) !important;
  color: #ffffff !important;
  font-size: 24px !important;
}
.open-sidebar-btn {
  top: 50% !important;
  left: 14px !important;
  transform: translateY(-50%) !important;
  z-index: 950 !important;
  width: 42px !important;
  height: 46px !important;
  border-radius: 999px !important;
  background: #2563eb !important;
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,.85) !important;
  box-shadow: 0 10px 24px rgba(15,23,42,.22) !important;
}

/* Acordeones: aspecto más claro para minimizar/desplegar */
.layer-toggle {
  display: grid !important;
  place-items: center !important;
  width: 32px !important;
  height: 30px !important;
  border-radius: 10px !important;
  font-size: 0 !important;
  transform: none !important;
}
.layer-toggle::before {
  content: '▸';
  font-size: 15px;
  font-weight: 900;
  color: #334155;
  transition: transform .16s ease;
}
.catastro-layer-group.is-open .layer-toggle::before {
  content: '▾';
  color: #1d4ed8;
}
.catastro-layer-group.is-open .layer-toggle {
  transform: none !important;
}

/* Norte nuevo: N más visible */
.catastro-north-control {
  width: 46px !important;
  height: 46px !important;
  border-radius: 50% !important;
  background: #ffffff !important;
  border: 1px solid #cbd5e1 !important;
  box-shadow: 0 7px 18px rgba(15,23,42,.18) !important;
  display: grid !important;
  place-items: center !important;
}
.north-rose { display: none !important; }
.north-modern {
  position: relative;
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
}
.north-modern span {
  position: absolute;
  top: 1px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  font-size: 13px;
  font-weight: 900;
  color: #0f172a;
  line-height: 1;
  text-shadow: 0 1px 0 #fff, 1px 0 0 #fff, -1px 0 0 #fff;
}
.north-modern svg {
  width: 32px;
  height: 32px;
  margin-top: 7px;
}
.north-modern-top {
  fill: #2563eb;
  stroke: #0f172a;
  stroke-width: 1.4;
}
.north-modern-bottom {
  fill: #ffffff;
  stroke: #0f172a;
  stroke-width: 1.4;
}

/* Mapa base minimizable: que no se vea pesado al inicio */
.leaflet-control-layers-toggle {
  border-radius: 10px !important;
}

@media (max-width: 900px) {
  .sidebar-collapse-btn {
    top: 50% !important;
    right: -17px !important;
  }
  .open-sidebar-btn {
    top: 50% !important;
  }
}


/* v46: símbolo de leyenda, norte rojo y modo oscuro general */
.legend-collapse {
  width: 28px;
  height: 26px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  font-size: 18px;
  line-height: 1;
  font-weight: 900;
  background: #ffffff;
  color: #334155;
  border: 1px solid #dbe4f0;
  box-shadow: none;
  transition: transform .18s ease, background .18s ease;
}
.catastro-map-legend:not(.is-collapsed) .legend-collapse {
  transform: rotate(90deg);
}
.catastro-map-legend.is-collapsed .legend-collapse {
  transform: rotate(0deg);
}
.legend-collapse:hover {
  background: #eff6ff;
  color: #1d4ed8;
}

/* Norte: flecha principal roja */
.needle-main {
  fill: #ef4444 !important;
  stroke: #0f172a !important;
  stroke-width: 1.1 !important;
}
.needle-tail {
  fill: #ffffff !important;
  stroke: #0f172a !important;
}

/* botón compacto de tema, sin engrosar cabecera */
.theme-toggle-btn {
  width: 42px;
  height: 42px;
  padding: 0 !important;
  border-radius: 999px;
  display: inline-grid;
  place-items: center;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.24);
  color: #fff;
  box-shadow: none;
  font-size: 17px;
  line-height: 1;
}
.theme-toggle-btn:hover {
  background: #ffffff;
  color: #0f172a;
}

/* Modo oscuro general */
body.dark-theme {
  --bg: #0f172a;
  --card: #111827;
  --text: #e5edf8;
  --muted: #a7b3c5;
  --soft-muted: #94a3b8;
  --border: #263347;
  --primary-soft: #1e3a8a;
  background: linear-gradient(180deg, #08111f 0%, #0f172a 45%, #111827 100%);
  color: var(--text);
}
body.dark-theme .card,
body.dark-theme .search-card,
body.dark-theme .table-card,
body.dark-theme .admin-card,
body.dark-theme .current-card {
  background: rgba(17,24,39,.96);
  border-color: #273449;
  color: var(--text);
}
body.dark-theme h2,
body.dark-theme h3,
body.dark-theme h4,
body.dark-theme label,
body.dark-theme th,
body.dark-theme td {
  color: var(--text);
}
body.dark-theme .muted,
body.dark-theme .summary-item span {
  color: #a7b3c5;
}
body.dark-theme input,
body.dark-theme select,
body.dark-theme textarea,
body.dark-theme .custom-select-trigger {
  background: #0b1220;
  color: #e5edf8;
  border-color: #334155;
}
body.dark-theme input::placeholder,
body.dark-theme textarea::placeholder {
  color: #94a3b8;
}
body.dark-theme .summary-item,
body.dark-theme .summary-total,
body.dark-theme .summary-observado,
body.dark-theme .summary-proceso,
body.dark-theme .summary-corregido {
  background: linear-gradient(180deg, #0b1220, #111827);
  border-color: #334155;
}
body.dark-theme .summary-item b {
  color: #ffffff !important;
}
body.dark-theme .table-wrap,
body.dark-theme .users-table-wrap {
  border-color: #334155;
  background: #0b1220;
}
body.dark-theme th {
  background: #0f172a;
}
body.dark-theme tbody tr:hover {
  background: #162033;
}
body.dark-theme .layer-panel,
body.dark-theme .table-layer-panel,
body.dark-theme .file-note,
body.dark-theme .hint,
body.dark-theme .result-box,
body.dark-theme .users-summary {
  background: #0b1220;
  border-color: #334155;
  color: #cbd5e1;
}
body.dark-theme .layer-btn,
body.dark-theme .custom-select-menu,
body.dark-theme .custom-select-option,
body.dark-theme .user-dropdown,
body.dark-theme .login-modal {
  background: #111827;
  color: #e5edf8;
  border-color: #334155;
}
body.dark-theme .custom-select-option:hover {
  background: #1f2937;
}
body.dark-theme .custom-select-option.selected {
  background: #1e3a8a;
  color: #dbeafe;
}

/* Modo oscuro para visor */
body.dark-theme .catastro-sidebar {
  background: #111827;
  border-right-color: #334155;
}
body.dark-theme .catastro-sidebar-scroll,
body.dark-theme .catastro-panel-section {
  color: #e5edf8;
  border-color: #334155;
}
body.dark-theme .catastro-panel-section h4,
body.dark-theme .catastro-panel-section label,
body.dark-theme .catastro-layer-check span {
  color: #e5edf8;
}
body.dark-theme .catastro-layer-check,
body.dark-theme .layer-group-title {
  background: #0b1220;
  border-color: #334155;
  color: #e5edf8;
}
body.dark-theme .leaflet-control-layers,
body.dark-theme .catastro-map-legend,
body.dark-theme .legend-head,
body.dark-theme .legend-collapse {
  background: #111827 !important;
  color: #e5edf8 !important;
  border-color: #334155 !important;
}
body.dark-theme .legend-head {
  border-bottom-color: #334155;
}
body.dark-theme .legend-row,
body.dark-theme .legend-empty {
  color: #cbd5e1;
}
body.dark-theme .catastro-north-control,
body.dark-theme .catastro-tool-control button,
body.dark-theme .open-sidebar-btn {
  background: #111827 !important;
  color: #e5edf8 !important;
  border-color: #334155 !important;
}


/* v47: modo oscuro refinado y mapa base oscuro */
.theme-toggle-btn {
  order: 99;
  margin-left: 0;
}
#nav-login-btn + .theme-toggle-btn {
  margin-left: 2px;
}

/* Mejor contraste general en modo oscuro */
body.dark-theme {
  background:
    radial-gradient(circle at top left, rgba(37,99,235,.12), transparent 38%),
    linear-gradient(180deg, #07111f 0%, #0b1220 45%, #0f172a 100%);
  color: #e7edf7;
}
body.dark-theme .topbar {
  background: linear-gradient(135deg, #07111f 0%, #102047 55%, #1d4ed8 100%);
}
body.dark-theme .card,
body.dark-theme .admin-card,
body.dark-theme .current-card,
body.dark-theme .search-card,
body.dark-theme .table-card {
  background: rgba(15, 23, 42, .96) !important;
  border-color: rgba(71, 85, 105, .72) !important;
  box-shadow: 0 18px 44px rgba(0,0,0,.28) !important;
}
body.dark-theme .badge,
body.dark-theme #row-count,
body.dark-theme .table-refresh-btn {
  background: #0b244f !important;
  color: #bfdbfe !important;
  border-color: #1d4ed8 !important;
}
body.dark-theme .table-refresh-btn:hover {
  background: #12346d !important;
}
body.dark-theme .summary-item {
  background: linear-gradient(180deg, #101a2d, #0b1220) !important;
  border-color: #334155 !important;
}
body.dark-theme .summary-item span,
body.dark-theme .validation-current h2,
body.dark-theme h2,
body.dark-theme h3,
body.dark-theme h4,
body.dark-theme label {
  color: #e7edf7 !important;
}
body.dark-theme .muted,
body.dark-theme .hint {
  color: #b6c2d3 !important;
}
body.dark-theme input,
body.dark-theme textarea,
body.dark-theme select,
body.dark-theme .custom-select-trigger {
  background: #0a1220 !important;
  border-color: #34445b !important;
  color: #e7edf7 !important;
}
body.dark-theme input:focus,
body.dark-theme textarea:focus,
body.dark-theme select:focus,
body.dark-theme .custom-select.open .custom-select-trigger {
  border-color: #60a5fa !important;
  box-shadow: 0 0 0 4px rgba(96, 165, 250, .18) !important;
}
body.dark-theme input::placeholder,
body.dark-theme textarea::placeholder {
  color: #94a3b8 !important;
  opacity: .65;
}
body.dark-theme .table-wrap,
body.dark-theme .users-table-wrap {
  background: #0a1220 !important;
  border-color: #34445b !important;
}
body.dark-theme th {
  background: #111827 !important;
  color: #dbeafe !important;
}
body.dark-theme td {
  color: #e7edf7 !important;
  border-color: #273449 !important;
}
body.dark-theme tbody tr:hover {
  background: #172036 !important;
}
body.dark-theme .layer-btn,
body.dark-theme .layer-panel,
body.dark-theme .table-layer-panel,
body.dark-theme .file-note,
body.dark-theme .result-box,
body.dark-theme .users-summary {
  background: #0a1220 !important;
  color: #e7edf7 !important;
  border-color: #34445b !important;
}
body.dark-theme .layer-btn.active {
  background: linear-gradient(135deg, #15803d, #22c55e) !important;
  color: #ffffff !important;
}

/* Login y menú usuario en modo oscuro */
body.dark-theme .login-modal,
body.dark-theme .user-dropdown {
  background: #0f172a !important;
  border-color: #34445b !important;
  color: #e7edf7 !important;
}
body.dark-theme .modal-close {
  background: #1e293b !important;
  color: #e7edf7 !important;
}
body.dark-theme .remember-row span,
body.dark-theme .check-row span {
  color: #cbd5e1 !important;
}

/* Visor en modo oscuro */
body.dark-theme .catastro-viewer-shell {
  background: #0b1220 !important;
}
body.dark-theme .catastro-sidebar {
  background: #0f172a !important;
  border-right-color: #34445b !important;
  box-shadow: 8px 0 28px rgba(0,0,0,.42) !important;
}
body.dark-theme .catastro-sidebar-scroll {
  background: #0f172a !important;
}
body.dark-theme .catastro-panel-section {
  border-color: #273449 !important;
}
body.dark-theme .catastro-panel-section h4,
body.dark-theme .catastro-panel-section label,
body.dark-theme .catastro-layer-check span {
  color: #e7edf7 !important;
}
body.dark-theme .catastro-layer-check,
body.dark-theme .layer-row,
body.dark-theme .layer-options,
body.dark-theme .layer-group-title {
  background: #101827 !important;
  border-color: #34445b !important;
  color: #e7edf7 !important;
}
body.dark-theme .catastro-layer-check:hover,
body.dark-theme .layer-row:hover {
  background: #172036 !important;
}
body.dark-theme .catastro-search-btn {
  background: linear-gradient(135deg, #0ea5e9, #1d4ed8) !important;
}
body.dark-theme .leaflet-control-layers,
body.dark-theme .leaflet-control-layers-expanded,
body.dark-theme .catastro-map-legend,
body.dark-theme .legend-head,
body.dark-theme .legend-collapse,
body.dark-theme .catastro-north-control,
body.dark-theme .catastro-tool-control button,
body.dark-theme .open-sidebar-btn {
  background: rgba(15, 23, 42, .96) !important;
  color: #e7edf7 !important;
  border-color: #34445b !important;
}
body.dark-theme .legend-head {
  border-bottom-color: #34445b !important;
}
body.dark-theme .legend-row,
body.dark-theme .legend-empty,
body.dark-theme .leaflet-control-layers-base label {
  color: #dbeafe !important;
}
body.dark-theme .leaflet-control-attribution {
  background: rgba(15,23,42,.78) !important;
  color: #cbd5e1 !important;
}
body.dark-theme .leaflet-control-attribution a {
  color: #93c5fd !important;
}
body.dark-theme .catastro-label {
  text-shadow:
    0 1px 0 #0b1220,
    0 -1px 0 #0b1220,
    1px 0 0 #0b1220,
    -1px 0 0 #0b1220 !important;
}

/* Ajustes de fluidez del visor: etiquetas pequeñas y capas con lectura clara */
.legend-box.lote {
  border-color: #111827 !important;
  background: rgba(17,24,39,.10) !important;
}
.legend-box.edifica {
  border-color: #dc2626 !important;
  background: rgba(220,38,38,.12) !important;
}
.leaflet-tooltip.catastro-label {
  padding: 0 2px !important;
  line-height: 1.05 !important;
  white-space: nowrap !important;
}
.leaflet-tooltip.puerta-label {
  padding: 1px 3px !important;
  border-radius: 4px !important;
  background: rgba(224,242,254,.78) !important;
}
body.dark-theme .leaflet-tooltip.puerta-label {
  background: rgba(8,47,73,.82) !important;
  color: #bae6fd !important;
}
body.dark-theme .lote-label {
  color: #f8fafc !important;
}

/* Suaviza el mapa claro si queda activo en modo oscuro; el nuevo base map oscuro se activa automáticamente */
body.dark-theme .leaflet-tile-pane img {
  transition: filter .2s ease;
}


/* v48: refina modo oscuro, mapa menos oscuro, login y visor */

/* separar mejor la cabecera azul del contenido */
.topbar.compact-topbar,
.topbar.v15-topbar,
.v15-topbar,
.brand-topbar {
  border-bottom: 2px solid rgba(147,197,253,.28);
}

/* botón de login y tema mejor alineados */
.main-nav {
  align-items: center;
}
.theme-toggle-btn {
  margin-left: 6px !important;
}

/* resumen en modo oscuro: recuperar color de estado */
body.dark-theme .summary-total {
  background: linear-gradient(180deg, rgba(29,78,216,.14), rgba(15,23,42,.96)) !important;
  border-color: #60a5fa !important;
}
body.dark-theme .summary-observado {
  background: linear-gradient(180deg, rgba(225,29,72,.12), rgba(15,23,42,.96)) !important;
  border-color: #fb7185 !important;
}
body.dark-theme .summary-proceso {
  background: linear-gradient(180deg, rgba(245,158,11,.12), rgba(15,23,42,.96)) !important;
  border-color: #fbbf24 !important;
}
body.dark-theme .summary-corregido {
  background: linear-gradient(180deg, rgba(34,197,94,.12), rgba(15,23,42,.96)) !important;
  border-color: #4ade80 !important;
}
body.dark-theme .summary-total b { color: #93c5fd !important; }
body.dark-theme .summary-observado b { color: #fda4af !important; }
body.dark-theme .summary-proceso b { color: #fcd34d !important; }
body.dark-theme .summary-corregido b { color: #86efac !important; }

/* login más distinguible en modo oscuro */
body.dark-theme .modal-backdrop {
  background: rgba(2, 6, 23, .72) !important;
  backdrop-filter: blur(6px);
}
body.dark-theme .login-modal {
  background: linear-gradient(180deg, rgba(15,23,42,.98), rgba(17,24,39,.98)) !important;
  border: 1px solid rgba(96,165,250,.28) !important;
  box-shadow: 0 30px 70px rgba(2,6,23,.58), 0 0 0 1px rgba(147,197,253,.08) inset !important;
}
body.dark-theme .login-modal h2,
body.dark-theme .login-modal label,
body.dark-theme .login-modal .check-row,
body.dark-theme .login-modal .remember-row {
  color: #f8fafc !important;
}
body.dark-theme .login-modal input {
  background: #0b1220 !important;
  border-color: #475569 !important;
}
body.dark-theme .login-submit {
  box-shadow: 0 14px 28px rgba(29,78,216,.28);
}

/* visor: panel y control de capas mejor integrados al oscuro */
body.dark-theme .catastro-panel-section {
  background: transparent !important;
}
body.dark-theme .catastro-panel-section h4 {
  background: linear-gradient(135deg, rgba(30,41,59,.96), rgba(15,23,42,.96));
  border: 1px solid #334155;
  border-radius: 16px;
  padding: 14px 16px !important;
  margin: 0 0 14px;
  box-shadow: 0 10px 22px rgba(2,6,23,.22);
}
body.dark-theme .catastro-layer-group {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
}
body.dark-theme .catastro-layer-check.main-layer {
  background: linear-gradient(180deg, #0b1220, #0f172a) !important;
  border: 1px solid #3b4b63 !important;
  border-radius: 14px !important;
  box-shadow: 0 8px 18px rgba(2,6,23,.20);
}
body.dark-theme .catastro-layer-check.main-layer:hover {
  border-color: #60a5fa !important;
  background: linear-gradient(180deg, #0f172a, #142033) !important;
}
body.dark-theme .layer-toggle {
  background: #ffffff !important;
  color: #1e3a8a !important;
  border-color: #cbd5e1 !important;
}
body.dark-theme .layer-toggle::before {
  color: #1e3a8a !important;
}
body.dark-theme .catastro-layer-group.is-open .layer-toggle {
  background: #dbeafe !important;
  border-color: #93c5fd !important;
}
body.dark-theme .layer-suboptions {
  background: transparent !important;
  padding-top: 8px !important;
}
body.dark-theme .catastro-layer-check.sub-layer {
  background: #111827 !important;
  border-color: #34445b !important;
}

/* leyenda oscura más limpia */
body.dark-theme .catastro-map-legend,
body.dark-theme .leaflet-control-layers-expanded {
  box-shadow: 0 14px 32px rgba(2,6,23,.35) !important;
}

/* norte: punta roja y N más visible */
.north-modern-top {
  fill: #ef4444 !important;
  stroke: #7f1d1d !important;
}
.north-modern span {
  color: #0f172a !important;
  text-shadow: 0 0 0 transparent, 0 1px 2px rgba(255,255,255,.95), 0 0 10px rgba(255,255,255,.95) !important;
  font-size: 14px !important;
  top: 0px !important;
}

/* mapa oscuro menos agresivo, más opaco/suave */
body.dark-theme .leaflet-tile-pane img {
  filter: brightness(1.28) contrast(.88) saturate(.82) !important;
  opacity: .96;
}

/* controles del mapa algo más visibles */
body.dark-theme .leaflet-bar a,
body.dark-theme .leaflet-bar a:hover,
body.dark-theme .catastro-tool-control button,
body.dark-theme .open-sidebar-btn,
body.dark-theme .catastro-north-control {
  box-shadow: 0 10px 24px rgba(2,6,23,.35) !important;
}


/* v49: ajustes solicitados: números negros, capas centradas, mapa claro igual y logout visible */

/* En modo oscuro, los números de los KPIs quedan negros como en modo claro */
body.dark-theme .summary-item b,
body.dark-theme .summary-total b,
body.dark-theme .summary-observado b,
body.dark-theme .summary-proceso b,
body.dark-theme .summary-corregido b {
  color: #111111 !important;
}

/* Mantener el borde/color de cada KPI en modo oscuro */
body.dark-theme .summary-total {
  border-color: #60a5fa !important;
}
body.dark-theme .summary-observado {
  border-color: #fb7185 !important;
}
body.dark-theme .summary-proceso {
  border-color: #fbbf24 !important;
}
body.dark-theme .summary-corregido {
  border-color: #4ade80 !important;
}

/* Controlador de capas más centrado dentro de su espacio */
.catastro-panel-section:nth-child(2) h4 {
  text-align: center !important;
  justify-content: center !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}
body.dark-theme .catastro-panel-section:nth-child(2) h4 {
  text-align: center !important;
}

/* Evitar que el mapa claro se oscurezca cuando el sitio está en modo oscuro.
   Así, si eliges Mapa claro, se verá como en modo claro. */
body.dark-theme .leaflet-tile-pane img {
  filter: none !important;
  opacity: 1 !important;
}

/* Si se usa el mapa oscuro, Carto ya trae su propio estilo oscuro;
   por eso no forzamos filtros generales sobre todos los mapas. */

/* Cerrar sesión completo en visor/cabecera */
.v15-topbar,
.compact-topbar,
.brand-topbar,
.public-topbar,
.admin-topbar,
.main-nav,
.nav-user-menu {
  overflow: visible !important;
}
.nav-user-menu {
  position: relative !important;
  z-index: 99999 !important;
}
.user-dropdown {
  z-index: 100000 !important;
  min-width: 210px !important;
  width: max-content !important;
  max-width: calc(100vw - 24px) !important;
  right: 0 !important;
  left: auto !important;
  white-space: nowrap !important;
}
.dropdown-logout-btn {
  white-space: nowrap !important;
  min-width: 170px !important;
  text-align: left !important;
}

/* Borde inferior de cabecera más claro para separar la franja azul */
.v15-topbar,
.compact-topbar.v15-topbar {
  border-bottom: 2px solid rgba(255,255,255,.22) !important;
  box-shadow: 0 8px 22px rgba(15,23,42,.18) !important;
}
body.dark-theme .v15-topbar,
body.dark-theme .compact-topbar.v15-topbar {
  border-bottom: 2px solid rgba(96,165,250,.38) !important;
}


/* v50: dropdown usuario visible, capas claras igual a oscuro y KPIs con color */

/* El menú de usuario debe quedar sobre el mapa Leaflet */
.topbar,
.v15-topbar,
.compact-topbar,
.brand-topbar,
.public-topbar,
.admin-topbar {
  position: relative !important;
  z-index: 999999 !important;
  overflow: visible !important;
}
.catastro-main-shell,
.catastro-viewer-shell,
.catastro-map-area,
.leaflet-container {
  position: relative;
  z-index: 1 !important;
}
.main-nav,
.nav-user-menu {
  position: relative !important;
  overflow: visible !important;
  z-index: 1000000 !important;
}
.user-dropdown {
  position: absolute !important;
  top: calc(100% + 12px) !important;
  right: 0 !important;
  left: auto !important;
  z-index: 1000001 !important;
  display: block;
  min-width: 210px !important;
  width: 210px !important;
  max-width: calc(100vw - 24px) !important;
  background: #ffffff !important;
  border: 1px solid #dbe4f0 !important;
  border-radius: 16px !important;
  box-shadow: 0 22px 50px rgba(15,23,42,.24) !important;
  padding: 8px !important;
}
.user-dropdown[hidden] {
  display: none !important;
}
.dropdown-logout-btn {
  width: 100% !important;
  min-width: 0 !important;
  display: block !important;
  white-space: nowrap !important;
  text-align: left !important;
  background: #fff1f2 !important;
  color: #be123c !important;
  border: 1px solid #fecdd3 !important;
  border-radius: 12px !important;
  padding: 12px 14px !important;
}
.dropdown-logout-btn:hover {
  background: #ffe4e6 !important;
  color: #9f1239 !important;
}
body.dark-theme .user-dropdown {
  background: #0f172a !important;
  border-color: #475569 !important;
  box-shadow: 0 22px 50px rgba(0,0,0,.46) !important;
}
body.dark-theme .dropdown-logout-btn {
  background: #3b0a16 !important;
  color: #fecdd3 !important;
  border-color: #9f1239 !important;
}

/* Controlador de capas en modo claro con el mismo estilo sólido del oscuro */
.catastro-panel-section:nth-child(2) h4 {
  background: linear-gradient(135deg, #f8fafc, #eff6ff) !important;
  border: 1px solid #cbd5e1 !important;
  border-radius: 16px !important;
  padding: 14px 16px !important;
  text-align: center !important;
  margin: 0 0 14px !important;
  box-shadow: 0 10px 22px rgba(15,23,42,.08) !important;
}
.catastro-layer-group {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  margin-bottom: 10px !important;
}
.catastro-layer-check.main-layer {
  background: linear-gradient(180deg, #ffffff, #f8fafc) !important;
  border: 1px solid #cbd5e1 !important;
  border-radius: 14px !important;
  box-shadow: 0 8px 18px rgba(15,23,42,.08) !important;
  padding: 11px 10px !important;
}
.catastro-layer-check.main-layer:hover {
  border-color: #60a5fa !important;
  background: linear-gradient(180deg, #ffffff, #eff6ff) !important;
}
.layer-toggle {
  background: #ffffff !important;
  color: #1e3a8a !important;
  border-color: #cbd5e1 !important;
  box-shadow: 0 4px 12px rgba(15,23,42,.06) !important;
}
.layer-toggle::before {
  color: #1e3a8a !important;
}
.catastro-layer-group.is-open .layer-toggle {
  background: #dbeafe !important;
  border-color: #93c5fd !important;
}
.layer-suboptions {
  background: transparent !important;
  padding-top: 8px !important;
}
.catastro-layer-check.sub-layer {
  background: #ffffff !important;
  border-color: #dbe4f0 !important;
  border-radius: 12px !important;
}

/* Mantener los números KPI con su color de identificación */
body.dark-theme .summary-total b,
.summary-total b {
  color: #1d4ed8 !important;
}
body.dark-theme .summary-observado b,
.summary-observado b {
  color: #be123c !important;
}
body.dark-theme .summary-proceso b,
.summary-proceso b {
  color: #b45309 !important;
}
body.dark-theme .summary-corregido b,
.summary-corregido b {
  color: #15803d !important;
}

/* Mejor contraste del número en tarjetas oscuras */
body.dark-theme .summary-item b {
  text-shadow: 0 1px 0 rgba(255,255,255,.18);
}

/* Si el menú abre muy pegado al borde derecho en pantallas pequeñas */
@media (max-width: 760px) {
  .user-dropdown {
    right: 50% !important;
    transform: translateX(50%) !important;
  }
}


/* v51: mejorar bordes del controlador de capas en modo claro sin alterar el oscuro */

/* Modo claro: más definición en cada recuadro del controlador de capas */
body:not(.dark-theme) .catastro-panel-section:nth-child(2) h4 {
  background: linear-gradient(135deg, #f8fbff, #eef5ff) !important;
  border: 1px solid #bfd0ea !important;
  box-shadow: 0 8px 18px rgba(15,23,42,.08) !important;
}

body:not(.dark-theme) .catastro-layer-group {
  margin-bottom: 12px !important;
}

body:not(.dark-theme) .catastro-layer-check.main-layer {
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%) !important;
  border: 1.6px solid #c7d4e5 !important;
  border-radius: 14px !important;
  box-shadow: 0 10px 18px rgba(15,23,42,.06), inset 0 0 0 1px rgba(255,255,255,.55) !important;
}

body:not(.dark-theme) .catastro-layer-check.main-layer:hover {
  border-color: #7aa7e8 !important;
  background: linear-gradient(180deg, #ffffff 0%, #eef6ff 100%) !important;
  box-shadow: 0 12px 22px rgba(37,99,235,.10), inset 0 0 0 1px rgba(255,255,255,.7) !important;
}

body:not(.dark-theme) .catastro-layer-check.sub-layer {
  background: #ffffff !important;
  border: 1.2px solid #d3dfef !important;
  border-radius: 12px !important;
}

body:not(.dark-theme) .layer-toggle {
  background: #ffffff !important;
  border: 1.3px solid #c7d4e5 !important;
  box-shadow: 0 4px 10px rgba(15,23,42,.07) !important;
}

body:not(.dark-theme) .catastro-layer-group.is-open .layer-toggle {
  background: #e8f1ff !important;
  border-color: #93baf3 !important;
}

/* Mantener exactamente el estilo oscuro anterior */
body.dark-theme .catastro-layer-check.main-layer {
  background: linear-gradient(180deg, #0b1220, #0f172a) !important;
  border: 1px solid #3b4b63 !important;
  border-radius: 14px !important;
  box-shadow: 0 8px 18px rgba(2,6,23,.20) !important;
}

body.dark-theme .catastro-layer-check.sub-layer {
  background: #111827 !important;
  border-color: #34445b !important;
}

body.dark-theme .layer-toggle {
  background: #ffffff !important;
  color: #1e3a8a !important;
  border-color: #cbd5e1 !important;
}


/* v52: mejora puntual en modo oscuro del encabezado Controlador de capas y botón lateral */

/* Solo modo oscuro: que el título Controlador de capas se distinga bien */
body.dark-theme .catastro-panel-section:nth-child(2) h4 {
  background: linear-gradient(135deg, #1b2434 0%, #0f172a 100%) !important;
  color: #f8fafc !important;
  border: 1px solid #3b4b63 !important;
  box-shadow: 0 10px 22px rgba(2,6,23,.26), inset 0 1px 0 rgba(255,255,255,.04) !important;
  text-shadow: 0 1px 1px rgba(0,0,0,.18);
}
body.dark-theme .catastro-panel-section:nth-child(2) h4::before {
  color: #93c5fd !important;
}

/* Mejorar el botón de minimizar / extender el panel */
.sidebar-collapse-btn,
.open-sidebar-btn {
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}
.sidebar-collapse-btn:hover,
.open-sidebar-btn:hover {
  transform: translateY(-1px) scale(1.02);
}

/* Estilo refinado del botón en ambos temas */
.sidebar-collapse-btn {
  width: 40px !important;
  height: 40px !important;
  border-radius: 999px !important;
  display: grid !important;
  place-items: center !important;
  font-size: 24px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
}

body:not(.dark-theme) .sidebar-collapse-btn {
  background: linear-gradient(135deg, #3b82f6, #2563eb) !important;
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,.38) !important;
  box-shadow: 0 12px 24px rgba(37,99,235,.24), 0 0 0 3px rgba(255,255,255,.78) !important;
}

body.dark-theme .sidebar-collapse-btn,
body.dark-theme .open-sidebar-btn {
  background: linear-gradient(135deg, #3b82f6, #2563eb) !important;
  color: #ffffff !important;
  border: 1px solid rgba(191,219,254,.44) !important;
  box-shadow: 0 14px 28px rgba(2,6,23,.36), 0 0 0 3px rgba(15,23,42,.65) !important;
}
body.dark-theme .sidebar-collapse-btn:hover,
body.dark-theme .open-sidebar-btn:hover {
  background: linear-gradient(135deg, #60a5fa, #2563eb) !important;
}

/* Ajuste del icono/flecha para que se vea más limpio */
.sidebar-collapse-btn::before,
.open-sidebar-btn::before {
  text-rendering: geometricPrecision;
}


/* v53: separar mejor el botón lateral del bloque de capas */
.catastro-sidebar {
  padding-right: 12px !important;
}
.catastro-sidebar-scroll {
  padding-right: 14px !important;
}
.sidebar-collapse-btn {
  right: -18px !important;
  top: 16px !important;
}
/* Mantener una holgura uniforme aunque se desplieguen capas */
.catastro-panel-section,
.catastro-layer-group {
  margin-right: 6px !important;
}
@media (max-width: 900px) {
  .sidebar-collapse-btn {
    right: -14px !important;
  }
  .catastro-sidebar-scroll {
    padding-right: 10px !important;
  }
}


/* v54: botón lateral debajo de recargar y secciones del panel con dimensiones uniformes */
.catastro-sidebar-scroll {
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
  padding-right: 12px !important;
}
.catastro-panel-section {
  width: 100% !important;
  box-sizing: border-box !important;
  margin-right: 0 !important;
  margin-bottom: 0 !important;
  padding: 16px !important;
  border: 1px solid rgba(191, 219, 254, 0.55) !important;
  border-radius: 16px !important;
  background: rgba(255,255,255,0.92) !important;
  box-shadow: 0 10px 22px rgba(15,23,42,.05) !important;
}
body.dark-theme .catastro-panel-section {
  background: rgba(8,15,30,0.92) !important;
  border-color: rgba(59,130,246,.26) !important;
  box-shadow: 0 12px 24px rgba(2,6,23,.28) !important;
}
.catastro-panel-section.search-section-no-title,
.catastro-panel-section:nth-child(2) {
  min-height: fit-content !important;
}
/* El botón de colapsar/abrir vive en el área del mapa y queda debajo de recargar */
.catastro-map-area {
  position: relative !important;
}
.catastro-map-area .open-sidebar-btn,
.catastro-map-area .sidebar-collapse-btn {
  position: absolute !important;
  left: 14px !important;
  top: 182px !important;
  right: auto !important;
  transform: none !important;
  z-index: 1200 !important;
  width: 42px !important;
  height: 42px !important;
  border-radius: 999px !important;
}
.catastro-map-area .sidebar-collapse-btn {
  display: grid !important;
  place-items: center !important;
}
.catastro-viewer-shell.sidebar-collapsed .catastro-map-area .sidebar-collapse-btn {
  display: none !important;
}
.catastro-map-area .open-sidebar-btn[hidden] {
  display: none !important;
}
@media (max-width: 900px) {
  .catastro-map-area .open-sidebar-btn,
  .catastro-map-area .sidebar-collapse-btn {
    top: 178px !important;
    left: 10px !important;
  }
  .catastro-sidebar-scroll {
    padding-right: 10px !important;
  }
}


/* v55: uniformar tarjeta de capas y alinear controles del mapa */
.catastro-layer-check.main-layer {
  display: grid !important;
  grid-template-columns: 20px minmax(0, 1fr) 34px !important;
  align-items: center !important;
  column-gap: 12px !important;
  min-height: 56px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.catastro-layer-check.main-layer > span {
  display: block !important;
  min-width: 0 !important;
}
.layer-toggle-placeholder {
  visibility: hidden !important;
  pointer-events: none !important;
}
.catastro-panel-section .catastro-layer-group,
.catastro-panel-section > .catastro-layer-check.main-layer.no-toggle {
  width: 100% !important;
  box-sizing: border-box !important;
}

/* Mejor alineación visual de zoom, norte y recargar */
.leaflet-top.leaflet-left .leaflet-control {
  margin-left: 14px !important;
}
.leaflet-top.leaflet-left .leaflet-control-zoom,
.leaflet-top.leaflet-left .catastro-north-control,
.leaflet-top.leaflet-left .catastro-tool-control {
  margin-top: 10px !important;
}
.leaflet-control-zoom,
.catastro-north-control,
.catastro-tool-control,
.catastro-tool-control button {
  width: 38px !important;
}
.catastro-north-control,
.catastro-tool-control button {
  height: 38px !important;
}
.leaflet-control-zoom a {
  width: 38px !important;
  height: 38px !important;
  line-height: 38px !important;
  display: grid !important;
  place-items: center !important;
}
.catastro-tool-control {
  display: grid !important;
  place-items: center !important;
  border-radius: 10px !important;
}
.north-modern {
  width: 34px !important;
  height: 34px !important;
}
.north-modern svg {
  width: 28px !important;
  height: 28px !important;
  margin-top: 6px !important;
}
.north-modern span {
  top: 1px !important;
}


/* v56: ajustes finales de validación y visor */
/* KPI en modo claro: texto negro y más marcado */
.summary-item b,
.summary-item span {
  color: #0f172a !important;
  font-weight: 800 !important;
}
.summary-item span {
  letter-spacing: .01em;
}

/* KPI en modo oscuro: recuperar colores por estado */
body.dark-theme .summary-total b,
body.dark-theme .summary-total span { color: #93c5fd !important; }
body.dark-theme .summary-no-indicado b,
body.dark-theme .summary-no-indicado span { color: #cbd5e1 !important; }
body.dark-theme .summary-observado b,
body.dark-theme .summary-observado span { color: #fda4af !important; }
body.dark-theme .summary-proceso b,
body.dark-theme .summary-proceso span { color: #fcd34d !important; }
body.dark-theme .summary-corregido b,
body.dark-theme .summary-corregido span { color: #86efac !important; }

/* Selects en modo oscuro: quitar línea clara superior y unificar aspecto */
body.dark-theme .custom-select-trigger {
  background: #0a1220 !important;
  border-color: #34445b !important;
  color: #e7edf7 !important;
  box-shadow: none !important;
}
body.dark-theme .custom-select-trigger:hover {
  border-color: #4b5f7a !important;
}
body.dark-theme .custom-select.open .custom-select-trigger,
body.dark-theme .custom-select-trigger:focus {
  box-shadow: 0 0 0 3px rgba(59,130,246,.16) !important;
}

/* Mapa base legible en modo oscuro */
body.dark-theme .leaflet-control-layers-base::before {
  color: #e5edf8 !important;
}
body.dark-theme .leaflet-control-layers-base label > span {
  color: #dbeafe !important;
}

/* Controles del visor: alineados pero sin superponerse */
.catastro-map-area .open-sidebar-btn,
.catastro-map-area .sidebar-collapse-btn {
  top: 206px !important;
}
@media (max-width: 900px) {
  .catastro-map-area .open-sidebar-btn,
  .catastro-map-area .sidebar-collapse-btn {
    top: 198px !important;
  }
}


/* v57: dos grupos de validación en la vista principal */
.validation-dashboard-card {
  display: grid;
  gap: 14px;
}
.validation-updated-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.updated-value {
  font-weight: 900;
  color: #334155;
}
.validation-option {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto;
  gap: 18px;
  align-items: center;
  padding: 16px 18px;
  border-radius: 20px;
  border: 1px solid #dbeafe;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  color: #0f172a;
  box-shadow: 0 10px 24px rgba(15,23,42,.055);
  text-align: left;
}
.validation-option:hover {
  border-color: #93c5fd;
  box-shadow: 0 14px 30px rgba(37,99,235,.10);
}
.validation-option.active {
  border-color: #2563eb;
  box-shadow: 0 0 0 3px rgba(37,99,235,.12), 0 14px 30px rgba(37,99,235,.10);
}
.validation-option-title h2 {
  margin: 0;
  font-size: clamp(20px, 2.1vw, 28px);
  letter-spacing: -.02em;
}
.compact-summary {
  grid-template-columns: repeat(5, 100px);
}
.compact-summary .summary-item {
  padding: 14px 12px;
  border-radius: 16px;
}
.compact-summary .summary-item b {
  font-size: 26px;
}
body.dark-theme .validation-option {
  background: linear-gradient(180deg, rgba(15,23,42,.98), rgba(17,24,39,.98));
  border-color: #334155;
  color: #e7edf7;
}
body.dark-theme .validation-option.active {
  border-color: #60a5fa;
  box-shadow: 0 0 0 3px rgba(96,165,250,.16), 0 14px 30px rgba(2,6,23,.32);
}
body.dark-theme .updated-value,
body.dark-theme .validation-option-title h2 {
  color: #f8fafc !important;
}
body.dark-theme .validation-option .summary-item {
  background: rgba(2,6,23,.28) !important;
}
@media (max-width: 1100px) {
  .validation-option {
    grid-template-columns: 1fr;
  }
  .compact-summary {
    grid-template-columns: repeat(3, minmax(108px, 1fr));
    width: 100%;
  }
}
@media (max-width: 640px) {
  .compact-summary {
    grid-template-columns: repeat(2, minmax(110px, 1fr));
  }
}
@media (max-width: 430px) {
  .compact-summary {
    grid-template-columns: 1fr;
  }
}


/* v58: Observación SICUN sin filtro de capas y selección más notoria */
.layer-panel[hidden] {
  display: none !important;
}

.validation-option {
  position: relative;
  overflow: hidden;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.validation-option::after {
  content: "";
  position: absolute;
  inset: 10px auto 10px 10px;
  width: 5px;
  border-radius: 999px;
  background: transparent;
  transition: background .18s ease, box-shadow .18s ease;
}
.validation-option.active {
  border-color: #2563eb !important;
  background:
    linear-gradient(90deg, rgba(37,99,235,.10), transparent 32%),
    linear-gradient(180deg, #ffffff 0%, #f8fbff 100%) !important;
  box-shadow:
    0 0 0 4px rgba(37,99,235,.14),
    0 18px 36px rgba(37,99,235,.13) !important;
  transform: translateY(-1px);
}
.validation-option.active::after {
  background: linear-gradient(180deg, #60a5fa, #2563eb);
  box-shadow: 0 0 14px rgba(37,99,235,.38);
}
.validation-option.active .validation-option-title h2 {
  color: #1d4ed8 !important;
}
.validation-option.active .validation-option-title::after {
  content: "Seleccionado";
  display: inline-flex;
  margin-top: 8px;
  padding: 5px 10px;
  border-radius: 999px;
  background: #dbeafe;
  color: #1d4ed8;
  border: 1px solid #bfdbfe;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .02em;
}
body.dark-theme .validation-option.active {
  border-color: #60a5fa !important;
  background:
    linear-gradient(90deg, rgba(96,165,250,.16), transparent 36%),
    linear-gradient(180deg, rgba(15,23,42,.98), rgba(17,24,39,.98)) !important;
  box-shadow:
    0 0 0 4px rgba(96,165,250,.18),
    0 18px 36px rgba(2,6,23,.38) !important;
}
body.dark-theme .validation-option.active::after {
  background: linear-gradient(180deg, #93c5fd, #3b82f6);
  box-shadow: 0 0 18px rgba(96,165,250,.42);
}
body.dark-theme .validation-option.active .validation-option-title h2 {
  color: #bfdbfe !important;
}
body.dark-theme .validation-option.active .validation-option-title::after {
  background: rgba(30,64,175,.34);
  color: #dbeafe;
  border-color: rgba(147,197,253,.34);
}


/* v59: título singular y selección más limpia */
.validation-option {
  padding-left: 24px !important;
}
.validation-option::after {
  left: 12px !important;
  top: 18px !important;
  bottom: 18px !important;
  width: 5px !important;
}
.validation-option.active .validation-option-title::after,
body.dark-theme .validation-option.active .validation-option-title::after {
  content: none !important;
  display: none !important;
}
.validation-option.active .validation-option-title h2 {
  margin-left: 6px !important;
}
.validation-option-title h2 {
  line-height: 1.18 !important;
}
@media (max-width: 640px) {
  .validation-option {
    padding-left: 22px !important;
  }
  .validation-option::after {
    left: 10px !important;
  }
}


/* v60: contador de token, explicación omisión/comisión y Excel único */
.token-card .token-head-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 12px;
}
.token-expiry-box {
  min-width: 180px;
  border: 1px solid #dbeafe;
  background: linear-gradient(180deg, #eff6ff, #ffffff);
  border-radius: 16px;
  padding: 10px 12px;
  text-align: center;
}
.token-expiry-label {
  display: block;
  color: #475569;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .02em;
  margin-bottom: 4px;
}
.token-expiry-box strong {
  color: #1d4ed8;
  font-size: 17px;
  font-weight: 900;
}
.token-expiry-box.is-warning {
  background: #fffbeb;
  border-color: #fbbf24;
}
.token-expiry-box.is-warning strong { color: #b45309; }
.token-expiry-box.is-expired {
  background: #fff1f2;
  border-color: #fb7185;
}
.token-expiry-box.is-expired strong { color: #be123c; }
.token-expiry-box.is-ok {
  background: #eff6ff;
  border-color: #93c5fd;
}
body.dark-theme .token-expiry-box {
  background: #0b1220;
  border-color: #34445b;
}
body.dark-theme .token-expiry-label { color: #cbd5e1; }
body.dark-theme .token-expiry-box strong { color: #93c5fd; }
body.dark-theme .token-expiry-box.is-warning strong { color: #fcd34d; }
body.dark-theme .token-expiry-box.is-expired strong { color: #fda4af; }

.observation-help-box {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  margin: 14px 0 14px;
  padding: 12px 14px;
  border: 1px solid #dbeafe;
  border-radius: 16px;
  background: linear-gradient(180deg, #f8fbff, #ffffff);
  color: #334155;
  font-size: 13px;
  line-height: 1.35;
}
.observation-help-box b {
  color: #1d4ed8;
}
body.dark-theme .observation-help-box {
  background: #0b1220;
  color: #cbd5e1;
  border-color: #34445b;
}
body.dark-theme .observation-help-box b {
  color: #93c5fd;
}
.export-btn:disabled {
  opacity: .65;
  cursor: not-allowed;
}
@media (max-width: 760px) {
  .token-card .token-head-row {
    flex-direction: column;
  }
  .token-expiry-box {
    width: 100%;
  }
}


/* v61: estado No indicado y ayudas solo para Observación Alfanumérica - Gráfica */
.status-no-indicado {
  background: #f1f5f9 !important;
  color: #475569 !important;
  border-color: #cbd5e1 !important;
}
body.dark-theme .status-no-indicado {
  background: rgba(148,163,184,.16) !important;
  color: #cbd5e1 !important;
  border-color: #475569 !important;
}
.observation-help-box[hidden] {
  display: none !important;
}


/* v62: etiqueta Base GIS actualizada y detalle comparativo */
.validation-updated-row .soft-badge {
  white-space: nowrap;
}
.observation-help-box {
  line-height: 1.45;
}
.validation-runtime-warning {
  margin: 12px 0 2px;
  padding: 10px 12px;
  border: 1px solid #fcd34d;
  border-radius: 12px;
  background: linear-gradient(180deg, #fffbea, #fffbeb);
  color: #92400e;
  font-size: 13px;
  line-height: 1.45;
  font-weight: 700;
}
body.dark-theme .validation-runtime-warning {
  background: rgba(146, 64, 14, 0.18);
  border-color: rgba(251, 191, 36, 0.45);
  color: #fde68a;
}


/* v3 real: barra de progreso y visor GIS real */
.validation-progress-box {
  margin: 14px 0 12px;
  padding: 14px;
  border: 1px solid #bfdbfe;
  border-radius: 16px;
  background: linear-gradient(180deg, #eff6ff, #ffffff);
}
.validation-progress-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
  font-weight: 900;
  color: #0f172a;
}
.validation-progress-track {
  height: 14px;
  border-radius: 999px;
  background: #dbeafe;
  overflow: hidden;
  box-shadow: inset 0 1px 2px rgba(15,23,42,.12);
}
.validation-progress-bar {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #0ea5e9, #2563eb);
  transition: width .35s ease;
}
body.dark-theme .validation-progress-box {
  background: #0b1220;
  border-color: #334155;
}
body.dark-theme .validation-progress-head {
  color: #e5edf8;
}
body.dark-theme .validation-progress-track {
  background: #1e293b;
}
.detected-layers-list {
  margin: 8px 0 0 18px;
  padding: 0;
  line-height: 1.55;
}
.popup-props {
  max-height: 260px;
  overflow: auto;
  min-width: 260px;
  display: grid;
  gap: 8px;
}
.popup-props-empty {
  min-width: 220px;
  color: #64748b;
  font-size: 12px;
}
.popup-prop-row {
  display: grid;
  grid-template-columns: minmax(88px, 112px) 1fr;
  gap: 10px;
  align-items: start;
  padding: 7px 8px;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  background: #f8fafc;
}
.popup-prop-key {
  font-weight: 800;
  color: #0f172a;
}
.popup-prop-value {
  color: #334155;
  word-break: break-word;
}
.map-popup-card {
  min-width: 260px;
}
.map-popup-title {
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid #dbe4f0;
  font-weight: 900;
  color: #0f172a;
}
.layer-suboptions-empty {
  padding: 6px 0 2px;
  color: #64748b;
  font-size: 12px;
  line-height: 1.45;
}


/* v4: paginación de tabla */
.table-pagination {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin: 8px 0 10px;
  padding: 6px 10px;
  border: 1px solid #dbeafe;
  border-radius: 10px;
  background: linear-gradient(180deg, #f8fbff, #ffffff);
}
.page-size-box,
.page-nav-box {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.page-size-box span,
.page-info {
  font-size: 12px;
  font-weight: 800;
  color: #334155;
}
.pagination-select {
  min-width: 78px;
  height: 30px;
  padding: 4px 9px;
  border: 1px solid #cbd5e1;
  border-radius: 9px;
  background: #ffffff;
  color: #0f172a;
  font-weight: 800;
}
.pagination-btn {
  height: 30px;
  padding: 0 10px;
  border-radius: 9px;
  border: 1px solid #bfdbfe;
  background: #eff6ff;
  color: #1d4ed8;
  font-weight: 800;
}
.pagination-btn:disabled {
  opacity: .45;
  cursor: not-allowed;
}
body.dark-theme .table-pagination {
  background: #0b1220 !important;
  border-color: #334155 !important;
}
body.dark-theme .page-size-box span,
body.dark-theme .page-info {
  color: #dbeafe !important;
}
body.dark-theme .pagination-select {
  background: #0a1220 !important;
  border-color: #34445b !important;
  color: #e7edf7 !important;
}
body.dark-theme .pagination-btn {
  background: #0b244f !important;
  border-color: #1d4ed8 !important;
  color: #bfdbfe !important;
}
@media (max-width: 720px) {
  .table-pagination {
    align-items: flex-start;
    flex-direction: column;
  }
}


/* Ajuste final: selección suave y KPI legibles en modo oscuro */
.validation-option.active {
  border-color: #93c5fd !important;
  background:
    linear-gradient(90deg, rgba(147,197,253,.16), transparent 34%),
    linear-gradient(180deg, #ffffff 0%, #fbfdff 100%) !important;
  box-shadow:
    0 0 0 3px rgba(147,197,253,.20),
    0 14px 28px rgba(59,130,246,.10) !important;
}
.validation-option.active::after {
  background: linear-gradient(180deg, #bfdbfe, #60a5fa) !important;
  box-shadow: 0 0 10px rgba(96,165,250,.24) !important;
}
.validation-option.active .validation-option-title h2 {
  color: #1e40af !important;
}
body.dark-theme .validation-option.active {
  border-color: rgba(147,197,253,.45) !important;
  background:
    linear-gradient(90deg, rgba(96,165,250,.10), transparent 38%),
    linear-gradient(180deg, rgba(15,23,42,.96), rgba(17,24,39,.96)) !important;
  box-shadow:
    0 0 0 3px rgba(96,165,250,.12),
    0 14px 28px rgba(2,6,23,.34) !important;
}
body.dark-theme .validation-option.active::after {
  background: linear-gradient(180deg, #bfdbfe, #60a5fa) !important;
  box-shadow: 0 0 12px rgba(147,197,253,.26) !important;
}
body.dark-theme .summary-no-indicado {
  background: rgba(148,163,184,.12) !important;
  border-color: rgba(203,213,225,.28) !important;
}
body.dark-theme .summary-no-indicado b,
body.dark-theme .summary-no-indicado span {
  color: #e2e8f0 !important;
}


/* v63: correcciones simples, popups amables y hover pastel */
tbody tr:hover,
body.dark-theme tbody tr:hover {
  background: #eef7ff !important;
}
body.dark-theme tbody tr:hover {
  background: rgba(125,211,252,.10) !important;
}
.correction-cell {
  min-width: 132px;
}
.correction-check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: 999px;
  background: #f8fafc;
  border: 1px solid #dbe4f0;
  color: #334155;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
  user-select: none;
}
.correction-check input {
  width: 17px;
  height: 17px;
  accent-color: #16a34a;
}
.correction-check:has(input:checked) {
  background: #ecfdf5;
  color: #166534;
  border-color: #bbf7d0;
}
.save-corrections-btn {
  background: #ecfdf5 !important;
  color: #166534 !important;
  border-color: #bbf7d0 !important;
}
.save-corrections-btn:disabled {
  opacity: .55;
  cursor: not-allowed;
  background: #f8fafc !important;
  color: #64748b !important;
  border-color: #dbe4f0 !important;
}
.map-popup-card {
  min-width: 280px;
  max-width: 360px;
}
.map-popup-title {
  margin: 0 0 12px !important;
  padding: 10px 12px !important;
  border-radius: 14px !important;
  background: linear-gradient(135deg, #e0f2fe, #f8fafc) !important;
  border: 1px solid #bae6fd !important;
  color: #0f172a !important;
  text-align: center !important;
}
.leaflet-tooltip.catastro-label {
  padding: 0 2px !important;
  line-height: 1.05 !important;
  white-space: nowrap !important;
}
.leaflet-tooltip.puerta-label {
  padding: 1px 3px !important;
  border-radius: 4px !important;
  background: rgba(224,242,254,.78) !important;
  color: #075985 !important;
}
body.dark-theme .correction-check {
  background: #0b1220;
  border-color: #334155;
  color: #cbd5e1;
}
body.dark-theme .correction-check:has(input:checked) {
  background: rgba(22,163,74,.16);
  color: #86efac;
  border-color: rgba(134,239,172,.32);
}
body.dark-theme .save-corrections-btn {
  background: rgba(22,163,74,.18) !important;
  color: #86efac !important;
  border-color: rgba(134,239,172,.34) !important;
}
body.dark-theme .save-corrections-btn:disabled {
  background: #0b1220 !important;
  color: #94a3b8 !important;
  border-color: #334155 !important;
}
body.dark-theme .map-popup-title {
  background: linear-gradient(135deg, rgba(14,165,233,.18), rgba(15,23,42,.94)) !important;
  border-color: rgba(125,211,252,.28) !important;
  color: #e0f2fe !important;
}
body.dark-theme .popup-prop-row {
  background: #0b1220;
  border-color: #334155;
}
body.dark-theme .popup-prop-key {
  color: #bae6fd;
}
body.dark-theme .popup-prop-value {
  color: #e5edf8;
}


/* v64: selector de validación suave, responsive y norte compacto */
.validation-dashboard-card {
  display: grid;
  gap: 14px;
}
.validation-option {
  grid-template-columns: minmax(240px, 1fr) minmax(260px, 360px) !important;
  background:
    radial-gradient(circle at top right, rgba(224,242,254,.72), transparent 46%),
    linear-gradient(180deg, #ffffff, #fbfdff) !important;
  border-color: #dbeafe !important;
}
.validation-option:hover:not(.active) {
  background:
    radial-gradient(circle at top right, rgba(219,234,254,.78), transparent 48%),
    linear-gradient(180deg, #ffffff, #f8fbff) !important;
  border-color: #bfdbfe !important;
  box-shadow: 0 10px 24px rgba(59,130,246,.08) !important;
  transform: translateY(-1px);
}
.compact-summary {
  grid-template-columns: repeat(2, minmax(118px, 1fr)) !important;
}
.compact-summary .summary-item {
  min-width: 0;
}
.north-modern {
  width: 32px !important;
  height: 32px !important;
}
.north-modern span {
  top: -1px !important;
  font-size: 10px !important;
}
.north-modern svg {
  width: 25px !important;
  height: 25px !important;
  margin-top: 8px !important;
}
.catastro-north-control {
  width: 38px !important;
  height: 38px !important;
}
body.dark-theme .validation-option {
  background:
    radial-gradient(circle at top right, rgba(14,165,233,.08), transparent 48%),
    linear-gradient(180deg, rgba(15,23,42,.98), rgba(17,24,39,.98)) !important;
  border-color: rgba(71,85,105,.78) !important;
}
body.dark-theme .validation-option:hover:not(.active) {
  background:
    radial-gradient(circle at top right, rgba(96,165,250,.12), transparent 48%),
    linear-gradient(180deg, rgba(20,32,52,.98), rgba(17,24,39,.98)) !important;
  border-color: rgba(147,197,253,.32) !important;
  box-shadow: 0 10px 24px rgba(2,6,23,.30) !important;
}

/* v65: tabla compacta, guardado por fila y etiquetas más livianas */
table {
  min-width: 1060px !important;
  table-layout: auto;
}
th,
td {
  padding: 9px 8px !important;
  text-align: center;
  vertical-align: middle;
}
th {
  text-align: center !important;
}
th:nth-last-child(2),
td.detail-cell {
  text-align: left !important;
  min-width: 250px;
  max-width: 430px;
  line-height: 1.35;
}
th:nth-last-child(2) {
  text-align: center !important;
}
.correction-cell {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-width: 146px;
}
.correction-check {
  padding: 6px 8px !important;
}
.row-save-btn {
  width: 32px;
  height: 32px;
  display: inline-grid;
  place-items: center;
  padding: 0;
  border-radius: 10px;
  border: 1px solid #bfdbfe;
  background: #eff6ff;
  color: #1d4ed8;
  box-shadow: none;
  cursor: pointer;
}
.row-save-btn:hover,
.row-save-btn.is-pending {
  background: #dbeafe;
  border-color: #93c5fd;
}
.row-save-btn.is-saving {
  opacity: .65;
  cursor: wait;
}
.row-save-btn.is-saved {
  background: #dcfce7;
  border-color: #86efac;
  color: #166534;
}
body.dark-theme .row-save-btn {
  background: #0b244f;
  border-color: #1d4ed8;
  color: #bfdbfe;
}
body.dark-theme .row-save-btn:hover,
body.dark-theme .row-save-btn.is-pending {
  background: #12346d;
}
body.dark-theme .row-save-btn.is-saved {
  background: rgba(22,163,74,.20);
  border-color: rgba(134,239,172,.36);
  color: #86efac;
}
@media (max-width: 760px) {
  table {
    min-width: 900px !important;
  }
  th,
  td {
    padding: 8px 7px !important;
    font-size: 12px;
  }
}
body.dark-theme .admin-card,
body.dark-theme .validation-dashboard-card,
body.dark-theme .public-container .card {
  color: #e7edf7;
}
@media (max-width: 1100px) {
  .validation-option {
    grid-template-columns: 1fr !important;
  }
  .compact-summary {
    width: 100%;
  }
}
@media (max-width: 760px) {
  body {
    overflow-x: hidden;
  }
  .topbar,
  .v15-topbar,
  .compact-topbar.v15-topbar {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    padding: 10px 12px !important;
  }
  .header-logo-wrap,
  .brand-center,
  .main-nav {
    justify-content: center !important;
    width: 100% !important;
  }
  .main-nav {
    flex-wrap: wrap !important;
  }
  .container,
  .public-container {
    width: min(100% - 18px, 100%) !important;
    margin: 12px auto !important;
  }
  .validation-option {
    padding: 14px 14px 14px 22px !important;
  }
  .compact-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .table-head-actions {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }
  table {
    min-width: 980px;
  }
  .catastro-viewer-shell {
    grid-template-columns: 1fr !important;
  }
  .catastro-sidebar {
    position: relative !important;
    width: 100% !important;
    max-height: 42vh;
    border-right: 0 !important;
    border-bottom: 1px solid #dbe4f0;
  }
  .catastro-map-area,
  .catastro-leaflet-map {
    min-height: 58vh !important;
  }
  .sidebar-collapse-btn,
  .open-sidebar-btn {
    display: none !important;
  }
}

/* v66: responsive general, tabla más compacta y guardado por fila sin salto visual */
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.table-wrap {
  max-width: 100%;
  overscroll-behavior-x: contain;
}

table.construction-table {
  min-width: 940px !important;
  font-size: 12.5px;
}

table.construction-table th,
table.construction-table td {
  padding: 7px 5px !important;
}

table.construction-table td.detail-cell {
  min-width: 190px;
  max-width: 310px;
}

.correction-cell {
  min-width: 78px !important;
  gap: 6px !important;
}

.correction-check {
  min-width: 30px;
  height: 30px;
  justify-content: center;
  padding: 4px !important;
}

.correction-check input {
  margin: 0;
}

.save-icon {
  position: relative;
  display: block;
  width: 15px;
  height: 15px;
  border: 2px solid currentColor;
  border-radius: 3px;
  box-sizing: border-box;
}

.save-icon::before {
  content: "";
  position: absolute;
  left: 2px;
  right: 2px;
  top: 1px;
  height: 4px;
  border-radius: 1px;
  background: currentColor;
  opacity: .82;
}

.save-icon::after {
  content: "";
  position: absolute;
  left: 3px;
  right: 3px;
  bottom: -2px;
  height: 6px;
  border: 2px solid currentColor;
  border-bottom: 0;
  border-radius: 2px 2px 0 0;
  background: #fff;
}

body.dark-theme .save-icon::after {
  background: #0b244f;
}

body.dark-theme .row-save-btn.is-saved .save-icon::after {
  background: #12351f;
}

.row-save-btn.is-saving .save-icon {
  animation: savePulse .8s ease-in-out infinite;
}

@keyframes savePulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(.88); }
}

@media (max-width: 1180px) {
  .public-container,
  .container {
    width: min(100% - 22px, 100%) !important;
  }

  .search-card,
  .table-card,
  .validation-dashboard-card,
  .admin-card {
    padding: 18px !important;
  }

  .filters.location-filters {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .table-head,
  .section-head {
    gap: 12px;
    flex-wrap: wrap;
  }

  table.construction-table {
    min-width: 900px !important;
  }
}

@media (max-width: 860px) {
  .brand-topbar,
  .topbar,
  .v15-topbar {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
  }

  .center-brand-title,
  .v15-title {
    font-size: clamp(18px, 5vw, 24px) !important;
    text-align: center !important;
  }

  .main-nav {
    justify-content: center !important;
    gap: 8px !important;
  }

  .filters.location-filters {
    grid-template-columns: 1fr !important;
  }

  .layer-filter,
  .table-pagination,
  .page-nav-box {
    width: 100%;
  }

  .layer-filter {
    justify-content: stretch;
  }

  .layer-btn,
  .pagination-btn,
  .export-btn {
    flex: 1 1 auto;
  }

  .table-wrap {
    border-radius: 12px;
  }

  table,
  table.construction-table {
    min-width: 760px !important;
  }

  th,
  td,
  table.construction-table th,
  table.construction-table td {
    padding: 7px 5px !important;
    font-size: 11.5px !important;
  }

  th:nth-last-child(2),
  td.detail-cell,
  table.construction-table td.detail-cell {
    min-width: 170px;
    max-width: 260px;
  }

  .catastro-viewer-shell {
    min-height: calc(100vh - 150px) !important;
  }

  .catastro-sidebar {
    max-height: 38vh !important;
  }

  .catastro-leaflet-map {
    height: 62vh !important;
    min-height: 440px !important;
  }
}

@media (max-width: 520px) {
  .header-logo-banner {
    max-width: min(280px, 92vw) !important;
  }

  .main-nav a,
  .nav-action-btn,
  .theme-toggle-btn {
    min-height: 36px;
    padding: 8px 10px !important;
    font-size: 12px !important;
  }

  .validation-option {
    padding: 12px 12px 12px 18px !important;
  }

  .compact-summary .summary-item {
    padding: 10px 8px !important;
  }

  .table-head h3,
  .section-head h3 {
    width: 100%;
    text-align: center;
  }

  .table-head-actions,
  .page-nav-box,
  .page-size-box {
    justify-content: center !important;
  }

  table,
  table.construction-table {
    min-width: 700px !important;
  }

  .catastro-sidebar {
    max-height: 34vh !important;
  }

  .catastro-leaflet-map {
    min-height: 390px !important;
  }
}

/* v67: layout responsive final, dashboard paralelo y tablas compactas uniformes */
.validation-dashboard-card {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  align-items: stretch;
}

.validation-updated-row,
.validation-runtime-warning {
  grid-column: 1 / -1;
}

.validation-option {
  grid-template-columns: 1fr !important;
  align-content: start;
  gap: 14px !important;
  min-height: 156px;
}

.validation-option .compact-summary {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  width: 100%;
}

.validation-option-title h2 {
  text-align: center;
  font-size: clamp(18px, 1.55vw, 22px) !important;
}

.table-card table {
  min-width: 980px !important;
  font-size: 12.5px !important;
}

.table-card th {
  padding: 7px 6px !important;
  font-size: 12px !important;
  letter-spacing: .01em;
  text-align: center !important;
}

.table-card td {
  padding: 7px 6px !important;
  font-size: 12.5px !important;
  line-height: 1.28;
  text-align: center;
}

.table-card td.detail-cell {
  min-width: 180px !important;
  max-width: 300px !important;
  white-space: normal;
  overflow-wrap: anywhere;
  text-align: left !important;
}

.table-card th:nth-last-child(2) {
  text-align: center !important;
}

table.construction-table {
  min-width: 880px !important;
  table-layout: fixed;
}

table.construction-table th:nth-child(1),
table.construction-table td:nth-child(1) { width: 46px; }

table.construction-table th:nth-child(2),
table.construction-table td:nth-child(2) { width: 52px; }

table.construction-table th:nth-child(3),
table.construction-table td:nth-child(3) { width: 58px; }

table.construction-table th:nth-child(4),
table.construction-table td:nth-child(4),
table.construction-table th:nth-child(5),
table.construction-table td:nth-child(5) { width: 52px; }

table.construction-table th:nth-child(6),
table.construction-table td:nth-child(6),
table.construction-table th:nth-child(7),
table.construction-table td:nth-child(7) { width: 76px; }

table.construction-table th:nth-child(8),
table.construction-table td:nth-child(8),
table.construction-table th:nth-child(9),
table.construction-table td:nth-child(9) { width: 62px; }

table.construction-table th:nth-child(10),
table.construction-table td:nth-child(10) {
  width: 230px;
  min-width: 0 !important;
  max-width: none !important;
}

table.construction-table th:nth-child(11),
table.construction-table td:nth-child(11) { width: 82px; }

table.sicun-table {
  min-width: 1040px !important;
}

table.sicun-table td.detail-cell {
  max-width: 280px !important;
}

@media (max-width: 900px) {
  .validation-dashboard-card {
    grid-template-columns: 1fr;
  }

  .validation-option {
    min-height: auto;
  }
}

@media (max-width: 700px) {
  html,
  body {
    max-width: 100%;
    overflow-x: hidden;
  }

  .catastro-main-shell {
    min-height: auto !important;
    padding: 8px 8px 12px !important;
  }

  .catastro-viewer-shell,
  .catastro-viewer-shell.sidebar-collapsed {
    display: flex !important;
    flex-direction: column !important;
    grid-template-columns: none !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    border-radius: 18px !important;
    overflow: hidden !important;
  }

  .catastro-sidebar,
  .catastro-sidebar.is-collapsed {
    position: relative !important;
    inset: auto !important;
    width: 100% !important;
    max-width: none !important;
    height: auto !important;
    max-height: 42vh !important;
    min-height: 0 !important;
    margin: 0 !important;
    transform: none !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    border-right: 0 !important;
    border-bottom: 1px solid #dbe4f0 !important;
    box-shadow: none !important;
  }

  .catastro-sidebar-scroll {
    max-height: 42vh !important;
    overflow-y: auto !important;
    padding: 12px !important;
  }

  .catastro-panel-section {
    padding: 12px !important;
    margin-bottom: 10px !important;
  }

  .catastro-panel-section.search-section-no-title {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .catastro-panel-section.search-section-no-title label:first-child,
  .catastro-search-btn {
    grid-column: 1 / -1;
  }

  .catastro-map-area {
    width: 100% !important;
    min-height: 0 !important;
  }

  .catastro-leaflet-map {
    width: 100% !important;
    height: 58vh !important;
    min-height: 360px !important;
  }

  .catastro-map-area .open-sidebar-btn,
  .catastro-map-area .sidebar-collapse-btn {
    display: none !important;
  }

  .leaflet-control-layers-expanded {
    max-width: calc(100vw - 32px);
    font-size: 12px;
  }

  .catastro-map-legend {
    min-width: 150px !important;
    max-width: calc(100vw - 34px);
  }

  .admin-container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: min(100% - 16px, 100%) !important;
    margin: 12px auto 28px !important;
    gap: 12px !important;
  }

  .admin-card {
    padding: 16px !important;
    border-radius: 18px !important;
  }

  .token-head-row,
  .actions,
  .user-form {
    grid-template-columns: 1fr !important;
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .actions button,
  .user-form button,
  #save-token,
  #run-validation,
  #clear-validation,
  #create-user-btn {
    width: 100% !important;
  }

  textarea#token {
    min-height: 118px;
  }

  .users-table {
    min-width: 620px !important;
  }

  .table-card table,
  table.construction-table,
  table.sicun-table {
    min-width: 760px !important;
  }
}

@media (max-width: 430px) {
  .validation-option .compact-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .summary-item b {
    font-size: 22px !important;
  }

  .summary-item span {
    font-size: 11px !important;
  }

  .catastro-panel-section.search-section-no-title {
    grid-template-columns: 1fr;
  }

  .catastro-panel-section.search-section-no-title label:first-child,
  .catastro-search-btn {
    grid-column: auto;
  }

  .catastro-leaflet-map {
    height: 56vh !important;
    min-height: 330px !important;
  }
}

/* v68: panel móvil del visor contraíble */
.mobile-sidebar-toggle {
  display: none;
}

@media (max-width: 700px) {
  .mobile-sidebar-toggle {
    display: flex !important;
    width: calc(100% - 24px);
    min-height: 38px;
    align-items: center;
    justify-content: center;
    margin: 12px 12px 0;
    padding: 9px 12px !important;
    border-radius: 999px !important;
    background: linear-gradient(135deg, #0ea5e9, #2563eb) !important;
    color: #ffffff !important;
    box-shadow: 0 8px 18px rgba(37,99,235,.22) !important;
    font-size: 13px !important;
    letter-spacing: .01em;
  }

  .catastro-viewer-shell.mobile-panel-collapsed .catastro-sidebar {
    max-height: 62px !important;
    overflow: hidden !important;
  }

  .catastro-viewer-shell.mobile-panel-collapsed .catastro-sidebar-scroll {
    display: none !important;
  }

  .catastro-viewer-shell.mobile-panel-collapsed .catastro-leaflet-map {
    height: calc(100vh - 172px) !important;
    min-height: 460px !important;
  }
}

@media (max-width: 430px) {
  .catastro-viewer-shell.mobile-panel-collapsed .catastro-leaflet-map {
    height: calc(100vh - 156px) !important;
    min-height: 390px !important;
  }
}

/* v69: SICUN valores de revisión estilo plugin */
.empty-value {
  font-weight: 950;
  color: #7f1d1d;
  background: #fff1f2;
  border-radius: 6px;
  padding: 1px 4px;
  white-space: nowrap;
}

body.dark-theme .empty-value {
  color: #fecdd3;
  background: rgba(127,29,29,.36);
}

/* v70: token persistente y paginación al pie */
.token-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.token-actions button {
  flex: 1 1 190px;
}

.table-card .table-pagination {
  margin: 12px 0 0 !important;
}

.page-size-box {
  min-width: 190px;
}

.page-size-box .custom-select {
  width: 92px;
}

.page-size-box .custom-select-trigger {
  min-height: 32px;
  padding: 5px 10px;
  border-radius: 10px;
  font-size: 12px;
  box-shadow: none;
}

.page-size-box .custom-select-menu {
  top: calc(100% + 6px);
  border-radius: 12px;
  padding: 6px;
}

.page-size-box .custom-select-option {
  padding: 8px 9px;
  border-radius: 9px;
  font-size: 12px;
  text-align: center;
}

@media (max-width: 720px) {
  .page-size-box,
  .page-nav-box {
    width: 100%;
    justify-content: center !important;
  }
}
