/* Subdere Registro - estilos base */

:root {
  --sr-blue: #0B5ED7; /* Ajusta según paleta oficial */
  --sr-red: #C60018;
  --sr-text: #1f2937;
  --sr-muted: #6b7280;
  --sr-bg: #ffffff;
  --sr-container: 1200px;
}

.subdere-registro body {
  color: var(--sr-text);
  background: var(--sr-bg);
  line-height: 1.6;
}

.container {
  max-width: var(--sr-container);
  margin: 0 auto;
  padding: 0 1rem;
}

/* Header */
.sr-header {
  background: #fff;
  border-bottom: 3px solid var(--sr-blue);
}
.sr-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: var(--sr-container);
  margin: 0 auto;
  padding: .75rem 1rem;
}
.sr-branding { display: flex; align-items: center; gap: .75rem; }
.sr-branding__name a { font-weight: 700; font-size: 1.125rem; color: var(--sr-blue); text-decoration: none; }

/* Primary menu */
.sr-primary-menu { font-weight: 600; }
.sr-primary-menu a {
  text-decoration: none;
  padding: .5rem .75rem;
  border-radius: .375rem;
}
.sr-primary-menu a.is-active,
.sr-primary-menu a:hover { background: var(--sr-blue); color: #fff; }

/* Hero */
.sr-hero {
  background: linear-gradient(90deg, var(--sr-blue), var(--sr-red));
  color: #fff;
  padding: 1.25rem 0;
  text-align: center;
}

/* Content layout */
.sr-layout { display: grid; grid-template-columns: 1fr; gap: 2rem; }
@media (min-width: 1024px) {
  .sr-layout { grid-template-columns: 1fr 300px; }
  .sr-sidebar--second { order: 2; }
}

.sr-highlighted { background: #f8fafc; padding: 1rem; border-radius: .5rem; }

/* Breadcrumb */
.sr-breadcrumb { background: #f1f5f9; padding: .5rem 1rem; font-size: .9rem; }

/* Footer */
.sr-footer { background: #0f172a; color: #fff; margin-top: 2rem; }
.sr-footer__inner { padding: 0rem 1rem; }
.sr-footer__bottom { border-top: 1px solid rgba(255,255,255,.2); margin-top: 1rem; padding-top: 1rem; font-size: .875rem; color: #cbd5e1; }

/* Views lists (listado de asociaciones/documentos) */
.view, .views-view-responsive-grid, .views-exposed-form { margin: 1rem 0; }
.views-exposed-form .form-item { margin-right: 1rem; }
.views-row { padding: 1rem 0; border-bottom: 1px solid #e5e7eb; }
.views-row:last-child { border-bottom: 0; }

/* Tables & filters */
table { width: 100%; border-collapse: collapse; }
th, td { padding: .5rem .75rem; border-bottom: 1px solid #e5e7eb; }
th { text-align: left; color: var(--sr-muted); }

/* Buttons */
.button, .form-submit {
  background: var(--sr-blue);
  color: #fff;
  border: none;
  padding: .5rem .9rem;
  border-radius: .375rem;
  cursor: pointer;
}
.button:hover, .form-submit:hover { filter: brightness(.95); }


/* Contenedor general */
.ruam-view-wrapper,
.page .sr-content .container,
.layout-container {
  max-width: 990px;
  margin: 0 auto;
}

/* Tarjeta de header (el Text area) */
.ruam-header-card {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: 16px 20px;
  margin: 12px 0 20px;
  box-shadow: 0 1px 0 rgba(0,0,0,.04);
}

/* Grid de cards */
.ruam-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

/* Card */
.ruam-card {
  position: relative;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 16px 18px;
  box-shadow: 0 1px 0 rgba(0,0,0,.04);
}

.ruam-card__title {
  margin: 0 0 8px 0;
  font-size: 1.05rem;
  line-height: 1.3;
}

.ruam-card__meta {
  font-size: .92rem;
  color: #4b5563;
  margin: 6px 0 4px;
}

.ruam-card__icon { margin-right: 4px; }

.ruam-card__year { font-size: .9rem; color: #334155; }

.ruam-card__badge {
  position: absolute;
  top: -12px;
  right: 422px;
  background: #f1f5f9;
  color: #111827;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: .85rem;
  border: 1px solid #e5e7eb;
}

/* Sidebar (exposed form) */
.region-sidebar-second .block-views-exposed-filter-block {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 14px 14px 10px;
  box-shadow: 0 1px 0 rgba(0,0,0,.04);
}

.region-sidebar-second .block-views-exposed-filter-block h2 {
  margin: 0 0 8px;
  font-size: 1rem;
}

/* Tabs "Registro / Documentos" (si usas el menú principal) */
nav.sr-primary-menu {
  border-bottom: 1px solid #e5e7eb;
  margin-bottom: 8px;
}
nav.sr-primary-menu a {
  display: inline-block;
  padding: 8px 16px;
}
nav.sr-primary-menu .is-active > a {
  border-bottom: 3px solid #1e73be;
}

/* Fondo general gris */
body { background: rgb(230,230,230); }


/* ===== Footer base ===== */
.sr-footer { background: #fff; }
.sr-footer__inner { 
  max-width: 990px;
  margin: 0 auto;
  /*padding: 16px 0 24px;*/
}

/* El contenedor que realmente envuelve los 2 bloques */
.sr-footer__inner .region--footer {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-areas: "main account";
  gap: 24px;
}

/* Línea superior bicolor (azul/rojo) a lo ancho del footer */
.sr-footer__inner .region--footer::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(to right, #0f69b4 50%, #eb3646 50%);
}

/* Separador vertical gris */
.sr-footer__inner .region--footer::after {
  content: "";
  position: absolute;
  top: 16px; bottom: 16px;
  left: 50%;
  width: 1px;
  background: #d9d9d9;
}

/* Ubicaciones en el grid (forzamos main a la IZQUIERDA, user a la DERECHA) */
#block-subdere-registro-mainnavigation     { grid-area: main; }
#block-subdere-registro-useraccountmenu    { grid-area: account; }

/* Bordes superiores por columna */
#block-subdere-registro-mainnavigation  { border-top: 3px solid #0f69b4; padding-top: 8px; }
#block-subdere-registro-useraccountmenu { border-top: 3px solid #eb3646; padding-top: 8px; }

/* Títulos y listas */
#block-subdere-registro-mainnavigation h2,
#block-subdere-registro-useraccountmenu h2 { margin: 0 0 8px; font-size: 1rem; }

.region-footer .menu,
.region--footer .menu { margin: 0; padding-left: 18px; }

/* Barra bicolor inferior bajo la PRIMERA columna (Main menu) */

#block-subdere-registro-mainnavigation::after {
  content: "";
  display: block;
  width: 120px;     /* ajusta a gusto */
  height: 20px;
  margin-top: 32px;
  background: linear-gradient(to right, #0f69b4 50%, #eb3646 50%);
}

/* Responsivo */
@media (max-width: 900px) {
  .sr-footer__inner .region--footer {
    grid-template-columns: 1fr;
    grid-template-areas:
      "main"
      "account";
  }
  .sr-footer__inner .region--footer::after { display: none; }
}


/* === Overrides: blanco sólo dentro de 990px en header/footer === */

/* Fondo general gris (ya lo tienes, lo dejo aquí para asegurar) */
body { background: rgb(230,230,230); }

/* Un helper opcional por si lo usas en el markup */
.sr-container { max-width: 990px; margin: 0 auto; }

/* HEADER:
   - Quita el fondo blanco a todo el ancho
   - Pasa el borde azul al contenedor interno y deja ese fondo blanco */
.sr-header {
  background: transparent !important;   /* antes: #fff */
  border-bottom: 0 !important;          /* el borde lo ponemos en el inner */
}

.sr-header__inner {
  max-width: 990px !important;
  margin: 0 auto !important;
  background: #fff !important;          /* blanco sólo dentro de 990px */
  padding-left: 16px;                    /* pequeños paddings laterales */
  padding-right: 16px;
  /*border-bottom: 3px solid var(--sr-blue);  antes estaba en .sr-header */
}

/* FOOTER:
   - Quita fondo a todo el ancho
   - Deja el blanco en el inner centrado a 990px */
.sr-footer {
  background: transparent !important;   /* si había #fff o un color oscuro */
  color: inherit;                        /* por si sobrescribiste el color */
}

.sr-footer__inner {
  max-width: 990px !important;
  margin: 0 auto !important;
  background: #fff !important;          /* blanco sólo dentro de 990px */
  /*padding: 16px 0 24px;                  recupera padding si lo quitaste */
}

/* El resto de tu maquetación del footer (bicolor superior, separador, etc.)
   ya lo estás dibujando DENTRO de .sr-footer__inner, así que no cambia. */

/* Si usas la barra bicolor inferior bajo el Main menu y quieres que quede
   por debajo del separador:
   (mantén estos ajustes si no los tenías ya) */
.sr-footer__inner .region--footer::after { z-index: 2; }
#block-subdere-registro-mainnavigation { position: relative; }
#block-subdere-registro-mainnavigation::after {
  content: "";
  position: absolute;
  top: 73px;
  left: 0px;
  bottom: 0;
  width: 120px;      /* ajusta a gusto */
  height: 12px;
  background: linear-gradient(to right, #0f69b4 50%, #eb3646 50%);
  z-index: 1;        /* queda por debajo del separador */
  pointer-events: none;
}


/* Quitar línea azul bajo header (si la tenías) */
.sr-header__inner {
  border-bottom: 0 !important;
}

/* Wrapper genérico centrado a 990 px (si aún no lo tienes) */
.sr-container {
  max-width: 990px;
  margin: 0 auto;
}

/* Menú debajo del header (mismo ancho, fondo blanco) */
.sr-primary-menu {
  background: #fff;
  padding: 8px 16px;     /* margen interno similar al header */
}

/* Mostrar ítems en una fila, sin bullets */
.sr-primary-menu .menu {
  display: flex;
  gap: 24px;
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Opcional: resalta el activo tipo “pestaña” como en tu captura */
.sr-primary-menu .menu a {
  text-decoration: none;
  padding: 10px 14px;
  border-radius: 8px;
  display: inline-block;
}
.sr-primary-menu .menu a.is-active {
  background: #0f69b4;
  color: #fff;
}


/* Contenedor genérico a 990px centrado (lo usa el contenido ahora) */
.sr-container {
  max-width: 990px;
  margin: 0 auto;
}

/* Caja del contenido: blanco solo dentro de 990px */
.sr-content {
  background: #fff;
  padding: 16px;
}

/* Layout del área principal + sidebar (si existe) */
.sr-layout {
  display: grid;
  gap: 24px;
  grid-template-columns: 1fr;         /* por defecto, 1 columna (sin sidebar) */
}

/* En pantallas medias/grandes, si hay sidebar se verá en 2 columnas.
   Si no hay aside, no pasa nada: el main ocupa toda la 1ª columna */
@media (min-width: 900px) {
  .sr-layout {
    grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  }
}

/* Asegura que el contenido aproveche el ancho al 100% del contenedor */
.sr-content__main { min-width: 0; }


/* Evita overflow horizontal del select dentro del sidebar */
#f-region-select {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  font-size: medium;
}



html body:not(.is-always-mobile-nav) .primary-nav__menu-link-inner { 
  padding-block: 0; 
}


/* Quita paddings y fondo tipo pastilla */
body:not(.is-always-mobile-nav) .primary-nav__menu-link-inner{
  padding-block: 0;
  padding-inline: 0;
  background: none;
  border-radius: 0;
}

/* Apaga la barra animada */
.primary-nav__menu-link-inner::after{
  content: none !important;
}



/* Quitar pill/caja y barra animada de Olivero */
body:not(.is-always-mobile-nav) .primary-nav__menu-link-inner::before,
body:not(.is-always-mobile-nav) .primary-nav__menu-link-inner::after,
body:not(.is-always-mobile-nav) .primary-nav__menu-link--active-trail .primary-nav__menu-link-inner::before,
body:not(.is-always-mobile-nav) .primary-nav__menu-link.is-active .primary-nav__menu-link-inner::before {
  content: none !important;
  background: none !important;
}

/* Asegurar que no quede fondo ni borde redondeado */
body:not(.is-always-mobile-nav) .primary-nav__menu-link-inner {
  background: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  outline: none !important;
}

/* Opcional: foco accesible sencillo en teclado */
body:not(.is-always-mobile-nav) .primary-nav__menu-link-inner:focus-visible {
  outline: none;
  text-decoration: underline;
  text-underline-offset: 3px;
}




/* Tabla de contactos: base sólida y sin “sorpresas” del tema */
.asoc-contactos-table {
  width: 100%;
  border-collapse: collapse;  /* evita dobles bordes y “cajitas” internas */
  table-layout: fixed;        /* respeta los anchos del colgroup */
}

/* Encabezados y celdas: alineación y espaciado uniforme */
.asoc-contactos-table th,
.asoc-contactos-table td {
  vertical-align: top;
  padding: 0.5rem 0.75rem;
  border: 1px solid #d0d6dc; /* opcional: para depurar; quítalo si no quieres borde */
}

/* Columna nombre: que no se corte raro el nombre propio */
.asoc-contactos-table .asoc-contacto__nombre {
  white-space: nowrap;        /* evita quiebres bruscos en nombres largos */
  font-weight: 600;           /* un pelito más de énfasis si te gusta */
}

/* Columna datos: que quiebre líneas amablemente */
.asoc-contactos-table .asoc-contacto__datos {
  word-break: break-word;
}

/* Resetea márgenes internos que meten algunos estilos del tema */
.asoc-contactos-table td > * {
  margin: 0;
}

/* 1) Apaga el marco de enfoque de Olivero en los links del menú */
@media (min-width: 75rem) {
  body:not(.is-always-mobile-nav)
  .primary-nav__menu-link:focus::before {
    content: none !important;
    border: 0 !important;
    width: 0 !important;
    height: 0 !important;
  }
}

/* 2) Apaga la “barrita”/subrayado animado */
body:not(.is-always-mobile-nav)
.primary-nav__menu-link-inner::after,
body:not(.is-always-mobile-nav)
.primary-nav__menu-link-inner--level-1::after {
  content: none !important;
  border: 0 !important;
}

/* (Opcional) deja un focus accesible y discreto */
body:not(.is-always-mobile-nav)
.primary-nav__menu-link:focus-visible .primary-nav__menu-link-inner {
  outline: 2px solid currentColor;
  outline-offset: 2px;
  background: transparent !important;
  box-shadow: none !important;
}

/* Evita highlight azul en móvil al tocar */
.primary-nav__menu-link,
.primary-nav__menu-link-inner {
  -webkit-tap-highlight-color: transparent;
}
