/* ============================================================
   SEPA Club Fuencarral — Base styles
   Reset · Tipografía · Botones · Formularios · Cards
   Alertas · Tablas · Modales · Badges · Utilidades
   ============================================================
   IMPORTANTE: No usar hex ni valores hardcoded.
   Siempre var(--token). Ver tokens.css.
   ============================================================ */


/* ── Reset y base ───────────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
}

html, body {
  overflow-x: hidden;
}

body {
  font-family:    var(--font-family);
  font-weight:    var(--font-light);
  font-size:      var(--text-base);
  line-height:    1.6;
  color:          var(--color-text);
  background:     var(--color-bg-page);
}

/* ── Skip-to-content (WCAG obligatorio) ─────────────────────── */
.skip-link {
  position:     absolute;
  top:          -100%;
  left:         var(--space-4);
  background:   var(--color-primary);
  color:        #fff;
  padding:      var(--space-2) var(--space-4);
  border-radius: var(--radius-sm);
  font-weight:  var(--font-bold);
  font-size:    var(--text-sm);
  z-index:      9999;
  text-decoration: none;
  transition:   top var(--transition);
}
.skip-link:focus {
  top: var(--space-3);
}

/* ── Foco visible (WCAG AAA) ────────────────────────────────── */
:focus-visible {
  outline:        3px solid var(--color-primary);
  outline-offset: 2px;
  border-radius:  var(--radius-xs);
}

/* ── Tipografía ─────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  font-weight:  var(--font-bold);
  line-height:  1.2;
  color:        var(--color-text);
}

h1 { font-size: var(--text-3xl); }
h2 { font-size: var(--text-2xl); }
h3 { font-size: var(--text-xl);  font-weight: var(--font-semibold); }
h4 { font-size: var(--text-lg);  font-weight: var(--font-semibold); }

p { line-height: 1.7; }

a {
  color:           var(--color-primary);
  text-decoration: none;
  transition:      color var(--transition);
}
a:hover { color: var(--color-primary-dark); text-decoration: underline; }

/* Título de sección con línea decorativa teal */
.section-title {
  font-size:     var(--text-xl);
  font-weight:   var(--font-bold);
  letter-spacing: 0.3px;
  color:         var(--color-text);
  position:      relative;
  padding-bottom: var(--space-3);
  margin-bottom: var(--space-6);
}
.section-title::after {
  content:       '';
  position:      absolute;
  bottom:        0; left: 0;
  width:         48px; height: 3px;
  background:    var(--color-primary);
  border-radius: var(--radius-full);
}


/* ── Botones ────────────────────────────────────────────────── */
.btn {
  display:         inline-flex;
  align-items:     center;
  justify-content: center;
  gap:             var(--space-2);
  padding:         0 var(--space-5);
  min-height:      44px;   /* WCAG — área táctil mínima */
  border-radius:   var(--radius-sm);
  font-family:     var(--font-family);
  font-size:       var(--text-sm);
  font-weight:     var(--font-bold);
  line-height:     1;
  cursor:          pointer;
  border:          2px solid transparent;
  text-decoration: none;
  white-space:     nowrap;
  transition:      all var(--transition);
  user-select:     none;
}

.btn:active { transform: scale(0.98); }

/* Primario */
.btn--primary {
  background: var(--btn-primary-bg);
  color:      var(--btn-primary-text);
  border-color: var(--btn-primary-bg);
}
.btn--primary:hover {
  background:   var(--btn-primary-hover);
  border-color: var(--btn-primary-hover);
  color:        #fff;
  text-decoration: none;
  transform:    translateY(-1px);
  box-shadow:   var(--shadow-md);
}

/* Secundario (outline) */
.btn--secondary {
  background:   var(--btn-secondary-bg);
  color:        var(--btn-secondary-text);
  border-color: var(--btn-secondary-border);
}
.btn--secondary:hover {
  background:   var(--btn-secondary-hover-bg);
  text-decoration: none;
  transform:    translateY(-1px);
}

/* Ghost */
.btn--ghost {
  background:   transparent;
  color:        var(--color-text-muted);
  border-color: transparent;
}
.btn--ghost:hover {
  background:   var(--color-bg-surface);
  color:        var(--color-text);
  text-decoration: none;
}

/* Peligro */
.btn--danger {
  background:   var(--color-error);
  color:        #fff;
  border-color: var(--color-error);
}
.btn--danger:hover {
  background:   #9b2c2c;
  border-color: #9b2c2c;
  color:        #fff;
  text-decoration: none;
  transform:    translateY(-1px);
}

/* Tamaños */
.btn--sm {
  font-size:  var(--text-xs);
  padding:    0 var(--space-2);
  min-height: 28px;   /* de 36px → 28px */
}
.btn--lg {
  font-size:  var(--text-base);
  padding:    0 var(--space-8);
  min-height: 52px;
}
.btn--full { width: 100%; }

/* Estado desactivado */
.btn:disabled,
.btn[aria-disabled="true"] {
  opacity:       0.45;
  cursor:        not-allowed;
  pointer-events: none;
  transform:     none;
  box-shadow:    none;
}

/* Icono solo (sin texto) */
.btn--icon {
  padding:   0;
  width:     44px;
  min-height: 44px;
}


/* ── Formularios ────────────────────────────────────────────── */
.form-group {
  display:       flex;
  flex-direction: column;
  gap:           var(--space-2);
  margin-bottom: var(--space-5);
}

.form-label {
  font-size:   var(--text-sm);
  font-weight: var(--font-bold);
  color:       var(--color-text);
}

/* Campos requeridos */
.form-label .required {
  color:       var(--color-error);
  margin-left: var(--space-1);
  font-weight: var(--font-bold);
}

.form-input,
.form-select,
.form-textarea {
  width:         100%;
  padding:       0.625rem var(--space-3);
  min-height:    44px;
  border:        1.5px solid var(--input-border);
  border-radius: var(--radius-sm);
  background:    var(--input-bg);
  color:         var(--input-text);
  font-family:   var(--font-family);
  font-size:     var(--text-sm);
  font-weight:   var(--font-light);
  line-height:   1.5;
  transition:    border-color var(--transition), box-shadow var(--transition);
  appearance:    none;
  -webkit-appearance: none;
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline:      none;
  border-color: var(--input-focus-border);
  box-shadow:   0 0 0 3px rgba(46, 153, 161, 0.15);
}

/* Validación en blur — solo mostrar error si el campo fue tocado */
.form-input.touched:invalid,
.form-group--error .form-input,
.form-group--error .form-select,
.form-group--error .form-textarea {
  border-color: var(--input-error-border);
  box-shadow:   0 0 0 3px rgba(192, 57, 43, 0.12);
}
.form-input:invalid:not(.touched) {
  border-color: var(--input-border);
  box-shadow:   none;
}

.form-select {
  padding-right: var(--space-8);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23595959' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:   no-repeat;
  background-position: right var(--space-3) center;
  cursor:        pointer;
}

.form-textarea {
  min-height:  120px;
  resize:      vertical;
}

/* Placeholder */
.form-input::placeholder,
.form-textarea::placeholder {
  color:   var(--color-text-muted);
  opacity: 0.7;
}

/* Hint y error bajo el campo */
.form-hint {
  font-size: var(--text-xs);
  color:     var(--color-text-muted);
}
.form-error {
  font-size:   var(--text-xs);
  color:       var(--color-error);
  font-weight: var(--font-semibold);
  display:     none;
}
.form-group--error .form-error { display: block; }

/* Checkbox y radio */
.form-check {
  display:     flex;
  align-items: flex-start;
  gap:         var(--space-3);
  cursor:      pointer;
}
.form-check-input {
  width:        20px;
  height:       20px;
  min-width:    20px;
  border:       2px solid var(--color-border);
  border-radius: var(--radius-xs);
  background:   var(--input-bg);
  cursor:       pointer;
  appearance:   none;
  -webkit-appearance: none;
  transition:   all var(--transition);
  margin-top:   2px;
  flex-shrink:  0;
}
.form-check-input[type="radio"] {
  border-radius: var(--radius-full);
}
.form-check-input:checked {
  background:   var(--color-primary);
  border-color: var(--color-primary);
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
}
.form-check-input[type="radio"]:checked {
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='8' cy='8' r='3'/%3E%3C/svg%3E");
}
.form-check-input:focus-visible {
  outline:      3px solid var(--color-primary);
  outline-offset: 2px;
}
.form-check-label {
  font-size:   var(--text-sm);
  color:       var(--color-text);
  line-height: 1.5;
}

/* Campo obligatorio — leyenda */
.form-required-note {
  font-size:    var(--text-xs);
  color:        var(--color-text-muted);
  margin-bottom: var(--space-5);
}
.form-required-note span {
  color: var(--color-error);
  font-weight: var(--font-bold);
}


/* ── Cards ──────────────────────────────────────────────────── */
.card {
  background:    var(--card-bg);
  border:        1px solid var(--card-border);
  border-radius: var(--card-radius);
  box-shadow:    var(--card-shadow);
  overflow:      hidden;
}

.card--hover {
  transition: transform var(--transition), box-shadow var(--transition);
  cursor:     pointer;
}
.card--hover:hover {
  transform:  translateY(-3px);
  box-shadow: var(--shadow-lg);
}

.card__header {
  padding:       var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--color-border);
  display:       flex;
  align-items:   center;
  justify-content: space-between;
  gap:           var(--space-3);
}

.card__title {
  font-size:   var(--text-base);
  font-weight: var(--font-bold);
  color:       var(--color-text);
}

.card__body  { padding: var(--space-6); }
.card__footer {
  padding:    var(--space-4) var(--space-6);
  border-top: 1px solid var(--color-border);
  background: var(--color-bg-surface);
  display:    flex;
  align-items: center;
  justify-content: flex-end;
  gap:        var(--space-3);
}


/* ── KPI Cards (dashboard) ──────────────────────────────────── */
.kpi-grid {
  display:               grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap:                   var(--space-5);
  margin-bottom:         var(--space-8);
}

.kpi-card {
  background:     var(--color-bg);
  border:         1px solid var(--color-border);
  border-radius:  var(--radius-md);
  padding:        var(--space-5) var(--space-6);
  box-shadow:     var(--shadow-sm);
  display:        flex;
  flex-direction: column;
  gap:            var(--space-2);
  position:       relative;
  overflow:       hidden;
}

.kpi-card__label {
  font-size:      var(--text-xs);
  font-weight:    var(--font-bold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color:          var(--color-text-muted);
  /* Altura fija: evita que un label largo desplace el número */
  min-height:     2.4em;
  display:        flex;
  align-items:    flex-end; /* alinea el texto abajo → el número queda siempre a la misma altura */
}

.kpi-card__value {
  font-size:   var(--text-3xl);
  font-weight: var(--font-bold);
  color:       var(--color-text);
  line-height: 1;
}

.kpi-card__sub {
  font-size: var(--text-xs);
  color:     var(--color-text-muted);
  min-height: 2.8em; /* altura fija para el subtexto también */
  display:    flex;
  align-items: flex-start;
}

/* Acento de color por estado */
.kpi-card::before {
  content:  '';
  position: absolute;
  top: 0; left: 0;
  width: 4px; height: 100%;
  background: var(--color-primary);
  border-radius: var(--radius-xs) 0 0 var(--radius-xs);
}
.kpi-card--warning::before { background: var(--color-warning); }
.kpi-card--success::before { background: var(--color-success); }
.kpi-card--error::before   { background: var(--color-error); }
.kpi-card--info::before    { background: var(--color-info); }


/* ── Alertas / Banners ──────────────────────────────────────── */
.alert {
  display:       flex;
  align-items:   flex-start;
  gap:           var(--space-3);
  padding:       var(--space-4) var(--space-5);
  border-radius: var(--radius-sm);
  border-left:   4px solid;
  font-size:     var(--text-sm);
  line-height:   1.6;
  margin-bottom: var(--space-4);
}

.alert__icon {
  flex-shrink: 0;
  width:       20px;
  height:      20px;
  margin-top:  1px;
}

.alert__content { flex: 1; }
.alert__title {
  font-weight:   var(--font-bold);
  margin-bottom: var(--space-1);
}

.alert--success {
  background:   var(--color-success-bg);
  border-color: var(--color-success);
  color:        var(--color-success-text);
}
.alert--warning {
  background:   var(--color-warning-bg);
  border-color: var(--color-warning);
  color:        var(--color-warning-text);
}
.alert--error {
  background:   var(--color-error-bg);
  border-color: var(--color-error);
  color:        var(--color-error-text);
}
.alert--info {
  background:   var(--color-info-bg);
  border-color: var(--color-primary);
  color:        var(--color-info-text);
}


/* ── Badges / Etiquetas ─────────────────────────────────────── */
.badge {
  display:       inline-flex;
  align-items:   center;
  gap:           var(--space-1);
  padding:       0.2em 0.65em;
  font-size:     var(--text-xs);
  font-weight:   var(--font-bold);
  border-radius: var(--radius-full);
  white-space:   nowrap;
  letter-spacing: 0.02em;
}

/* Estados de mandato */
.badge--pendiente  { background: var(--color-warning-bg);  color: var(--color-warning-text); }
.badge--firmado    { background: var(--color-info-bg);     color: var(--color-info-text); }
.badge--validado   { background: var(--color-success-bg);  color: var(--color-success-text); }
.badge--rechazado  { background: var(--color-error-bg);    color: var(--color-error-text); }
.badge--cancelado  { background: var(--color-bg-surface);  color: var(--color-text-muted); }
.badge--expirado   { background: var(--color-bg-surface);  color: var(--color-text-muted); }

/* Roles de usuario */
.badge--admin   { background: #ede9fe; color: #4c1d95; }
.badge--gestor  { background: var(--color-primary-light); color: var(--color-primary-dark); }
.badge--visor   { background: var(--color-bg-surface); color: var(--color-text-muted); }


/* ── Tablas — compactas ──────────────────────────────────────── */
.table-wrap {
  overflow-x:      auto;
  border-radius:   var(--radius-md);
  border:          1px solid var(--color-border);
  box-shadow:      var(--shadow-sm);
  /* Scroll suave en móvil con rebote */
  -webkit-overflow-scrolling: touch;
  /* Indicador sutil de que hay más contenido a la derecha */
  background:
    linear-gradient(to right, var(--color-bg) 30%, transparent) left center,
    linear-gradient(to left,  var(--color-bg) 30%, transparent) right center,
    radial-gradient(farthest-side at 0 50%, rgba(0,0,0,.08), transparent) left center,
    radial-gradient(farthest-side at 100% 50%, rgba(0,0,0,.08), transparent) right center;
  background-size:   40px 100%, 40px 100%, 14px 100%, 14px 100%;
  background-repeat: no-repeat;
  background-attachment: local, local, scroll, scroll;
  background-color:  var(--color-bg);
}

table {
  width:           100%;
  border-collapse: collapse;
  font-size:       var(--text-xs);   /* más pequeño que text-sm */
  background:      var(--color-bg);
}

thead {
  background: var(--color-bg-surface);
}

th {
  padding:        6px var(--space-3); /* de space-3/space-4 → 6px/12px */
  text-align:     left;
  font-size:      10px;
  font-weight:    var(--font-bold);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color:          var(--color-text-muted);
  white-space:    nowrap;
  border-bottom:  1px solid var(--color-border);
}

td {
  padding:        6px var(--space-3); /* de space-3/space-4 → 6px/12px */
  border-bottom:  1px solid var(--color-border);
  color:          var(--color-text);
  vertical-align: middle;
  line-height:    1.4;
}

tbody tr:last-child td { border-bottom: none; }

tbody tr { transition: background var(--transition); }
tbody tr:hover { background: var(--color-bg-surface); }

/* Columna de acciones */
.td-actions {
  display:     flex;
  gap:         var(--space-1);   /* de space-2 → space-1 */
  align-items: center;
}


/* ── Modal ──────────────────────────────────────────────────── */
.modal-overlay {
  position:   fixed;
  inset:      0;
  background: rgba(0, 0, 0, 0.5);
  z-index:    1000;
  display:    flex;
  align-items: center;
  justify-content: center;
  padding:    var(--space-4);
  animation:  fadeIn 0.18s ease;
}
.modal-overlay[hidden] { display: none; }

@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.modal {
  background:    var(--color-bg);
  border-radius: var(--radius-md);
  box-shadow:    var(--shadow-xl);
  width:         100%;
  max-width:     520px;
  max-height:    90vh;
  overflow-y:    auto;
  animation:     slideUp 0.22s ease;
}

@keyframes slideUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

.modal__header {
  padding:         var(--space-5) var(--space-6);
  border-bottom:   1px solid var(--color-border);
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  gap:             var(--space-3);
}

.modal__title {
  font-size:   var(--text-lg);
  font-weight: var(--font-bold);
}

.modal__close {
  background:    none;
  border:        none;
  cursor:        pointer;
  color:         var(--color-text-muted);
  padding:       var(--space-2);
  border-radius: var(--radius-sm);
  min-height:    44px;
  min-width:     44px;
  display:       flex;
  align-items:   center;
  justify-content: center;
  transition:    all var(--transition);
}
.modal__close:hover { background: var(--color-bg-surface); color: var(--color-text); }

.modal__body   { padding: var(--space-6); }
.modal__footer {
  padding:    var(--space-4) var(--space-6);
  border-top: 1px solid var(--color-border);
  display:    flex;
  justify-content: flex-end;
  gap:        var(--space-3);
}


/* ── Indicador de carga ─────────────────────────────────────── */
.spinner {
  display:         inline-block;
  width:           20px;
  height:          20px;
  border:          2.5px solid var(--color-border);
  border-top-color: var(--color-primary);
  border-radius:   var(--radius-full);
  animation:       spin 0.7s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Skeleton loading */
@keyframes shimmer {
  from { background-position: -200% 0; }
  to   { background-position:  200% 0; }
}
.skeleton {
  background: linear-gradient(
    90deg,
    var(--color-bg-surface) 25%,
    var(--color-border)     50%,
    var(--color-bg-surface) 75%
  );
  background-size: 200% 100%;
  animation:       shimmer 1.4s infinite;
  border-radius:   var(--radius-sm);
  color:           transparent;
}


/* ── Toggle de tema ─────────────────────────────────────────── */
.btn-theme {
  display:         flex;
  align-items:     center;
  justify-content: center;
  width:           36px;
  height:          36px;
  min-height:      36px;
  border-radius:   var(--radius-full);
  background:      rgba(255, 255, 255, 0.14);
  border:          none;
  color:           rgba(255, 255, 255, 0.75);
  cursor:          pointer;
  transition:      all var(--transition);
}
.btn-theme:hover {
  background: rgba(255, 255, 255, 0.25);
  color:      #fff;
}


/* ── Estado vacío ───────────────────────────────────────────── */
.empty-state {
  display:        flex;
  flex-direction: column;
  align-items:    center;
  gap:            var(--space-4);
  padding:        var(--space-12) var(--space-8);
  text-align:     center;
  color:          var(--color-text-muted);
}
.empty-state__icon {
  width:   64px;
  height:  64px;
  opacity: 0.35;
}
.empty-state__text {
  font-size:  var(--text-base);
  max-width:  40ch;
  line-height: 1.6;
}


/* ── Footer corporativo A LA PAR ────────────────────────────── */
.footer-alapar {
  background:  #0f172a;
  color:       rgba(255, 255, 255, 0.65);
  padding:     var(--space-8) var(--space-6);
  margin-top:  auto;
}
.footer-alapar__inner {
  max-width:      1200px;
  margin:         0 auto;
  display:        flex;
  flex-direction: column;
  align-items:    center;
  gap:            var(--space-4);
  text-align:     center;
}
.footer-alapar__logo {
  height:  32px;
  width:   auto;
  opacity: 0.80;
}
.footer-alapar__links {
  display:     flex;
  gap:         var(--space-6);
  flex-wrap:   wrap;
  justify-content: center;
}
.footer-alapar__links a {
  color:           rgba(255, 255, 255, 0.55);
  text-decoration: none;
  font-size:       var(--text-sm);
  font-weight:     var(--font-semibold);
  min-height:      44px;
  display:         inline-flex;
  align-items:     center;
  transition:      color var(--transition);
}
.footer-alapar__links a:hover,
.footer-alapar__links a:focus-visible {
  color:           var(--color-primary);
  text-decoration: none;
}
.footer-alapar__copy {
  font-size: var(--text-xs);
  opacity:   0.45;
}

[data-theme="dark"] .footer-alapar { background: #070e0f; }

@media (max-width: 480px) {
  .footer-alapar__links { flex-direction: column; gap: var(--space-3); }
}


/* ── Utilidades ─────────────────────────────────────────────── */
.text-muted   { color: var(--color-text-muted); }
.text-sm      { font-size: var(--text-sm); }
.text-xs      { font-size: var(--text-xs); }
.text-center  { text-align: center; }
.text-right   { text-align: right; }
.fw-bold      { font-weight: var(--font-bold); }
.d-flex       { display: flex; }
.align-center { align-items: center; }
.gap-2        { gap: var(--space-2); }
.gap-3        { gap: var(--space-3); }
.gap-4        { gap: var(--space-4); }
.mt-4         { margin-top: var(--space-4); }
.mt-6         { margin-top: var(--space-6); }
.mb-4         { margin-bottom: var(--space-4); }
.mb-6         { margin-bottom: var(--space-6); }
.w-full       { width: 100%; }
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}


/* ── Footer mínimo del panel ────────────────────────────────── */
.footer-panel {
  margin-top:  auto;
  padding:     var(--space-5) var(--space-8) var(--space-4);
  border-top:  1px solid var(--color-border);
  display:     flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap:   wrap;
  gap:         var(--space-2);
  font-size:   var(--text-xs);
  color:       var(--color-text-muted);
}

.footer-panel a {
  color:           var(--color-text-muted);
  text-decoration: none;
}
.footer-panel a:hover { color: var(--color-primary); }


/* ── Toast notifications ────────────────────────────────────── */
#toast-container {
  position:       fixed;
  bottom:         var(--space-6);
  right:          var(--space-6);
  z-index:        9999;
  display:        flex;
  flex-direction: column;
  gap:            var(--space-3);
  pointer-events: none;
}

.toast {
  display:        flex;
  align-items:    flex-start;
  gap:            var(--space-3);
  padding:        var(--space-3) var(--space-4);
  border-radius:  var(--radius-md);
  box-shadow:     var(--shadow-lg);
  font-size:      var(--text-sm);
  min-width:      280px;
  max-width:      400px;
  pointer-events: auto;
  cursor:         pointer;
  animation:      toastIn .22s ease;
  border-left:    4px solid;
  background:     var(--color-bg);
  color:          var(--color-text);
}

.toast--success { border-color: var(--color-success); }
.toast--error   { border-color: var(--color-error);   }
.toast--info    { border-color: var(--color-primary);  }
.toast--warning { border-color: var(--color-warning);  }

.toast__icon { flex-shrink: 0; margin-top: 1px; }
.toast--success .toast__icon { color: var(--color-success); }
.toast--error   .toast__icon { color: var(--color-error);   }
.toast--info    .toast__icon { color: var(--color-primary);  }
.toast--warning .toast__icon { color: var(--color-warning);  }

.toast__body { flex: 1; line-height: 1.5; }
.toast__close {
  background: none; border: none; cursor: pointer;
  color: var(--color-text-muted); padding: 0; line-height: 1;
  flex-shrink: 0;
}
.toast__close:hover { color: var(--color-text); }

.toast.saliendo { animation: toastOut .2s ease forwards; }

@keyframes toastIn {
  from { opacity: 0; transform: translateY(12px) scale(.96); }
  to   { opacity: 1; transform: translateY(0)    scale(1);   }
}
@keyframes toastOut {
  from { opacity: 1; transform: translateY(0); max-height: 100px; margin-bottom: 0; }
  to   { opacity: 0; transform: translateY(8px); max-height: 0; padding: 0; margin-bottom: 0; }
}

@media (max-width: 480px) {
  #toast-container { left: var(--space-4); right: var(--space-4); bottom: var(--space-4); }
  .toast { min-width: auto; max-width: 100%; }
}


/* ── SharePoint folder picker ───────────────────────────────── */
.sp-status { padding:.5rem .85rem; border-radius:var(--radius-sm); font-size:var(--text-sm); margin-bottom:var(--space-3); }
.sp-status--ok       { background:var(--color-success-bg); color:var(--color-success-text); border:1px solid #bbf7d0; }
.sp-status--error    { background:var(--color-error-bg);   color:var(--color-error-text);   border:1px solid #fecaca; white-space:pre-wrap; }
.sp-status--cargando { background:var(--color-primary-light); color:var(--color-primary-dark); border:1px solid var(--color-border); }
.sp-spinner { display:inline-block; width:13px; height:13px; border:2px solid var(--color-border); border-top-color:var(--color-primary); border-radius:50%; animation:sp-spin .6s linear infinite; vertical-align:middle; margin-right:.35rem; }
@keyframes sp-spin { to { transform:rotate(360deg); } }

.sp-seccion-titulo { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--color-text-muted); margin-bottom:var(--space-2); }
.sp-drives-lista { display:flex; gap:var(--space-2); flex-wrap:wrap; margin-bottom:var(--space-3); }
.sp-drive-btn { background:var(--color-bg-surface); border:1.5px solid var(--color-border); border-radius:var(--radius-sm); padding:5px 12px; font-size:var(--text-xs); font-weight:500; cursor:pointer; font-family:var(--font-family); color:var(--color-text); transition:border-color .12s, background .12s; }
.sp-drive-btn:hover, .sp-drive-btn--activo { border-color:var(--color-primary); background:var(--color-primary-light); color:var(--color-primary-dark); }
.sp-drive-btn--activo { font-weight:700; }

.sp-nav { border:1px solid var(--color-border); border-radius:var(--radius-sm); overflow:hidden; }
.sp-nav__header { background:var(--color-bg-surface); border-bottom:1px solid var(--color-border); padding:6px 12px; display:flex; align-items:center; gap:var(--space-2); flex-wrap:wrap; }
.sp-nav__titulo { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--color-text-muted); white-space:nowrap; }
.sp-breadcrumb { display:flex; align-items:center; flex-wrap:wrap; }
.sp-bc-item { background:none; border:none; cursor:pointer; padding:2px 4px; border-radius:3px; font-size:var(--text-xs); color:var(--color-primary); font-family:var(--font-family); font-weight:500; }
.sp-bc-item:hover { background:var(--color-primary-light); }
.sp-bc-sep { color:var(--color-text-muted); font-size:var(--text-xs); }

.sp-carpetas-lista { padding:var(--space-2) var(--space-3); max-height:220px; overflow-y:auto; }
.sp-carpeta-fila { display:flex; align-items:center; gap:var(--space-2); padding:4px var(--space-1); border-radius:4px; }
.sp-carpeta-fila:hover { background:var(--color-bg-surface); }
.sp-carpeta-icono { font-size:.95rem; flex-shrink:0; }
.sp-carpeta-nombre { flex:1; background:none; border:none; cursor:pointer; text-align:left; font-size:var(--text-xs); color:var(--color-text); font-family:var(--font-family); padding:2px 3px; border-radius:3px; }
.sp-carpeta-nombre:hover { color:var(--color-primary); }
.sp-carpeta-flecha { color:var(--color-text-muted); }
.sp-carpeta-sel { flex-shrink:0; }
.sp-carpetas-vacio { font-size:var(--text-xs); color:var(--color-text-muted); padding:var(--space-2) var(--space-1); margin:0; }

.sp-nav__footer { background:var(--color-bg-surface); border-top:1px solid var(--color-border); padding:var(--space-2) var(--space-3); }
.sp-carpeta-manual { border-top:1px dashed var(--color-border); padding:var(--space-2) var(--space-3); background:var(--color-bg-surface); }
.sp-carpeta-manual__label { font-size:10px; color:var(--color-text-muted); display:block; margin-bottom:4px; }
.sp-carpeta-manual__fila { display:flex; gap:var(--space-2); align-items:center; flex-wrap:wrap; }
.sp-carpeta-manual__input { flex:1; min-width:140px; height:26px; padding:0 var(--space-2); border:1px solid var(--color-border); border-radius:var(--radius-xs); font-size:var(--text-xs); font-family:var(--font-family); color:var(--color-text); background:var(--color-bg); }
.sp-carpeta-manual__input:focus { outline:none; border-color:var(--color-primary); }
