/* ================================================================
   IWC — Sistema Integral de Servicios
   Diseño moderno 2026 — RSG
   ================================================================ */

/* ---------- Importar fuente moderna ---------- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

/* ---------- Variables de color y diseño ---------- */
:root {
  /* Paleta primaria: azul cielo medio — tono suave y no agresivo */
  --blue-900: #2c5878;
  --blue-800: #376e95;
  --blue-700: #4485b2;
  --blue-600: #559cca;
  --blue-500: #6db4de;
  --blue-400: #90caea;
  --blue-100: #d9eef8;
  --blue-50:  #edf6fc;

  --teal-500: #2db8cc;

  --green-600: #2e9e5a;
  --green-100: #dcfce7;

  --red-600:   #d94040;
  --red-100:   #fee2e2;

  --amber-500: #e8a020;
  --amber-100: #fef3c7;

  /* Grises con leve tinte azulado — evitan el negro puro en el contenido */
  --gray-900: #26384a;
  --gray-700: #3e5368;
  --gray-600: #556882;
  --gray-500: #7a90a4;
  --gray-300: #c8d4de;
  --gray-200: #dde6ee;
  --gray-100: #edf2f7;
  --gray-50:  #f5f8fb;
  --white:    #ffffff;

  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;

  --shadow-xs: 0 1px 3px rgba(0,0,0,.08);
  --shadow-sm: 0 2px 8px rgba(0,0,0,.10);
  --shadow-md: 0 4px 16px rgba(0,0,0,.12);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.14);

  --transition: .18s ease;
}

/* ================================================================
   MICRO-ANIMACIONES (sutiles)
   ================================================================ */
@keyframes iwc-header-shift {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

@keyframes iwc-float-soft {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-1px); }
}

@keyframes iwc-panel-enter {
  0% {
    opacity: 0;
    transform: translateY(8px) scale(.995);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes iwc-btn-enter-right {
  0% {
    opacity: 0;
    transform: translateX(10px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}

/* ================================================================
   BASE
   ================================================================ */
*, *::before, *::after {
  box-sizing: border-box;
}

* {
  color: var(--gray-900);
  font-size: 14px;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* Cualquier descendiente de un contenedor con color blanco explícito
   hereda ese blanco; evita que el selector * lo sobreescriba con gray-900 */
.content > header.header *,
.custom-auth-modal-header *,
#user_panel_actions .btn-primary *,
#user_panel_actions .btn-primary span,
thead th *,
#panel_sucess * {
  color: inherit !important;
}

html, body {
  margin: 0;
  padding: 0;
  background: #eef5fb;
  background-image:
    radial-gradient(ellipse at 20% 10%, rgba(109,180,222,.09) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 90%, rgba(45,184,204,.06) 0%, transparent 60%);
  min-height: 100vh;
}

/* ================================================================
   TOPBAR / HEADER
   ================================================================ */
.content > header.header {
  display: flex !important;
  align-items: center;
  justify-content: center;
  margin: 0 0 18px 0;
  padding: 14px 24px 14px 60px;
  background: linear-gradient(135deg, var(--blue-900) 0%, var(--blue-700) 55%, var(--blue-600) 100%);
  color: var(--white) !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  letter-spacing: .5px;
  border-radius: 0 0 12px 12px;
  box-shadow: 0 4px 20px rgba(44,88,120,.30);
  text-shadow: 0 1px 2px rgba(0,0,0,.30);
  position: relative;
  background-size: 180% 180%;
  animation: iwc-header-shift 16s ease-in-out infinite;
}

.content > header.header::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 0 0 12px 12px;
  background: linear-gradient(180deg, rgba(255,255,255,.06) 0%, transparent 100%);
  pointer-events: none;
}

.header { font-size: 26px; color: var(--blue-600); margin-left: 0; }
.blue   { color: var(--blue-600); }

/* ================================================================
   HAMBURGER
   ================================================================ */
#open-button {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: fixed !important;
  top: 9px !important;
  left: 12px !important;
  z-index: 1200 !important;
  width: 38px !important;
  height: 38px !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: visible !important;
  background: var(--blue-800) !important;
  border: 1.5px solid rgba(255,255,255,.30) !important;
  border-radius: 8px !important;
  box-shadow: 0 2px 10px rgba(0,0,0,.22) !important;
  cursor: pointer !important;
  font-size: 0 !important;
  color: transparent !important;
  text-indent: 0 !important;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition) !important;
  animation: iwc-float-soft 4s ease-in-out infinite;
}
#open-button::before,
#open-button::after { display: none !important; content: none !important; }
#open-button span.iwc-ham {
  display: block !important;
  position: relative !important;
  top: auto !important;
  left: auto !important;
  transform: none !important;
  width: 20px !important;
  height: 2px !important;
  background: #fff !important;
  border-radius: 2px !important;
  box-shadow: 0 -6px 0 #fff, 0 6px 0 #fff !important;
  flex-shrink: 0 !important;
}
#open-button:hover {
  background: var(--blue-700) !important;
  box-shadow: 0 4px 14px rgba(0,0,0,.35) !important;
  transform: scale(1.05) !important;
  animation-play-state: paused;
}

/* ================================================================
   SIDEBAR MENU (OffCanvas)
   ================================================================ */
.menu-wrap {
  background: linear-gradient(180deg, var(--blue-900) 0%, #1c3e58 100%) !important;
}

.menu .icon-list a {
  color: rgba(255,255,255,.88) !important;
  transition: background var(--transition), color var(--transition), padding-left var(--transition), transform var(--transition) !important;
  border-radius: var(--radius-sm) !important;
  margin: 2px 8px !important;
  padding: 9px 12px !important;
  font-weight: 500 !important;
  position: relative;
  overflow: hidden;
}

.menu .icon-list a::before {
  content: "";
  position: absolute;
  left: 0;
  top: 20%;
  height: 60%;
  width: 2px;
  background: rgba(255,255,255,.55);
  transform: scaleY(0);
  transition: transform var(--transition) !important;
}

/* Forzar que span e i hereden el color del enlace padre
   (el selector * {color} los sobreescribía directamente) */
.menu .icon-list a span,
.menu .icon-list a * {
  color: inherit !important;
}

.menu .icon-list a:hover,
.menu .icon-list a:focus {
  background: rgba(255,255,255,.12) !important;
  color: #fff !important;
  padding-left: 18px !important;
  transform: translateX(2px);
}

.menu .icon-list a:hover::before,
.menu .icon-list a:focus::before {
  transform: scaleY(1);
}

.menu .icon-list a i {
  color: var(--blue-400) !important;
  width: 20px !important;
}

/* ================================================================
   LAYOUT PRINCIPAL — sin desperdiciar espacio
   ================================================================ */
.container {
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
}

.content-wrap {
  padding: 0 !important;
  width: 100% !important;
}

.content {
  padding-bottom: 30px;
  padding-left: 4px;
  padding-right: 4px;
}

/* Hacer que las columnas de Bootstrap usen el ancho al máximo */
.row { margin-left: -8px !important; margin-right: -8px !important; }
[class*="col-"] { padding-left: 8px !important; padding-right: 8px !important; }

/* Fieldsets col-md-4 que queden más anchos y no desperdicien espacio */
.col-md-4 { width: 33.333% !important; }
.col-md-3 { width: 25% !important; }
.col-md-5 { width: 41.666% !important; }
.col-md-6 { width: 50% !important; }
.col-md-7 { width: 58.333% !important; }
.col-md-12 { width: 100% !important; }

/* ================================================================
   PANEL DE USUARIO — logo+nombre izquierda, botones columna derecha
   ================================================================ */
#user_panel[style*="display: block"],
#user_panel[style*="display:block"],
#user_panel[style*="display: flex"],
#user_panel[style*="display:flex"] {
  display: flex !important;
  flex-direction: row !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
}

#user_panel {
  padding: 12px 18px;
  margin: 0 0 12px 0;
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  float: none !important;
  height: auto;
  min-height: 0;
}

/* Logo arriba + nombre de usuario debajo */
#user_panel_name {
  background-image: url(module/img/logo_full.png) !important;
  background-size: 160px 68px !important;
  background-repeat: no-repeat !important;
  background-position: left top !important;
  min-width: 170px !important;
  width: 170px !important;
  margin: 0 !important;
  padding-top: 74px !important;
  padding-left: 2px !important;
  padding-bottom: 4px !important;
  float: none !important;
  display: block !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  color: var(--blue-700) !important;
  line-height: 1.4 !important;
}

/* Botones en columna, alineados a la derecha */
#user_panel_actions {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 6px !important;
  padding: 0 !important;
}

#user_panel_actions .btn {
  width: 190px !important;
  text-align: center !important;
  border-radius: var(--radius-md) !important;
  padding: 8px 14px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  margin: 0 !important;
  float: none !important;
  display: block !important;
  position: static !important;
  box-sizing: border-box !important;
  letter-spacing: .1px;
  transition: all var(--transition) !important;
  white-space: nowrap !important;
}

/* Entrada escalonada de botones superiores cuando aparece el panel */
#user_panel[style*="display: block"] #user_panel_actions .btn,
#user_panel[style*="display:block"] #user_panel_actions .btn,
#user_panel[style*="display: flex"] #user_panel_actions .btn,
#user_panel[style*="display:flex"] #user_panel_actions .btn {
  animation: iwc-btn-enter-right .28s ease-out both;
}
#user_panel[style*="display: block"] #user_panel_actions .btn:nth-child(1),
#user_panel[style*="display:block"] #user_panel_actions .btn:nth-child(1),
#user_panel[style*="display: flex"] #user_panel_actions .btn:nth-child(1),
#user_panel[style*="display:flex"] #user_panel_actions .btn:nth-child(1) { animation-delay: .02s; }
#user_panel[style*="display: block"] #user_panel_actions .btn:nth-child(2),
#user_panel[style*="display:block"] #user_panel_actions .btn:nth-child(2),
#user_panel[style*="display: flex"] #user_panel_actions .btn:nth-child(2),
#user_panel[style*="display:flex"] #user_panel_actions .btn:nth-child(2) { animation-delay: .06s; }
#user_panel[style*="display: block"] #user_panel_actions .btn:nth-child(3),
#user_panel[style*="display:block"] #user_panel_actions .btn:nth-child(3),
#user_panel[style*="display: flex"] #user_panel_actions .btn:nth-child(3),
#user_panel[style*="display:flex"] #user_panel_actions .btn:nth-child(3) { animation-delay: .10s; }
#user_panel[style*="display: block"] #user_panel_actions .btn:nth-child(4),
#user_panel[style*="display:block"] #user_panel_actions .btn:nth-child(4),
#user_panel[style*="display: flex"] #user_panel_actions .btn:nth-child(4),
#user_panel[style*="display:flex"] #user_panel_actions .btn:nth-child(4) { animation-delay: .14s; }
#user_panel[style*="display: block"] #user_panel_actions .btn:nth-child(5),
#user_panel[style*="display:block"] #user_panel_actions .btn:nth-child(5),
#user_panel[style*="display: flex"] #user_panel_actions .btn:nth-child(5),
#user_panel[style*="display:flex"] #user_panel_actions .btn:nth-child(5) { animation-delay: .18s; }

#menu_search_student_alt,
#menu_student_internal_pay_alt,
#menu_student_pay_alt {
  background: linear-gradient(135deg, var(--blue-600), var(--blue-700)) !important;
  border: none !important;
  color: #fff !important;
  box-shadow: 0 2px 5px rgba(68,133,178,.28) !important;
}
#menu_search_student_alt:hover,
#menu_student_internal_pay_alt:hover,
#menu_student_pay_alt:hover {
  background: linear-gradient(135deg, var(--blue-700), var(--blue-800)) !important;
  transform: translateY(-1px);
  box-shadow: 0 3px 10px rgba(68,133,178,.38) !important;
}

#btn_activar_totp {
  background: var(--white) !important;
  border: 1.5px solid var(--blue-400) !important;
  color: var(--blue-700) !important;
}
#btn_activar_totp:hover {
  background: var(--blue-50) !important;
  border-color: var(--blue-600) !important;
}

#logout {
  background: linear-gradient(135deg, #2c5878, #233f58) !important;
  border: none !important;
  color: #fff !important;
}
#logout:hover {
  background: linear-gradient(135deg, #233f58, #1b3046) !important;
  transform: translateY(-1px);
}

/* ================================================================
   FORMULARIO DE LOGIN — centrado en pantalla
   NOTA: display NO lleva !important para que jQuery pueda ocultarlo
   ================================================================ */
#form_log {
  display: flex;
  justify-content: center !important;
  align-items: center !important;
  min-height: calc(100vh - 60px) !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 20px 0 !important;
}

/* Anular offset Bootstrap que descentra */
#form_log .col-md-4,
#form_log .col-md-offset-4 {
  float: none !important;
  margin-left: 0 !important;
  width: auto !important;
  padding: 0 !important;
}

#form_log > div {
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: 36px 36px 30px !important;
  border: 1px solid var(--gray-200);
  width: 400px !important;
  max-width: 96vw !important;
  text-align: center;
}

#form_log img {
  filter: drop-shadow(0 4px 10px rgba(0,0,0,.18));
  margin-bottom: 8px;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

#form_log h3.blue {
  font-size: 20px !important;
  font-weight: 700 !important;
  color: var(--blue-800) !important;
  margin: 10px 0 18px !important;
  border-bottom: 2px solid var(--blue-100);
  padding-bottom: 10px;
  text-align: center;
}

#form_log label {
  display: block;
  font-weight: 600;
  color: var(--gray-700);
  margin: 12px 0 5px;
  font-size: 13px;
  text-align: left;
}

#go {
  width: 100%;
  margin-top: 18px;
  padding: 12px 0;
  font-size: 15px !important;
  font-weight: 700 !important;
  letter-spacing: .4px;
  background: linear-gradient(135deg, var(--blue-600), var(--blue-800)) !important;
  border: none !important;
  color: #fff !important;
  border-radius: var(--radius-md) !important;
  box-shadow: 0 4px 14px rgba(68,133,178,.30) !important;
  transition: all var(--transition) !important;
  cursor: pointer;
  display: block;
}
#go:hover {
  background: linear-gradient(135deg, var(--blue-700), var(--blue-900)) !important;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(68,133,178,.38) !important;
}

/* ================================================================
   INPUTS Y FORM CONTROLS
   ================================================================ */
.form-control {
  width: 100%;
  padding: 8px 12px !important;
  border: 1.5px solid var(--gray-300) !important;
  border-radius: var(--radius-sm) !important;
  background: var(--white) !important;
  color: var(--gray-900) !important;
  font-size: 14px !important;
  transition: border-color var(--transition), box-shadow var(--transition) !important;
  appearance: auto;
}
.form-control:focus {
  border-color: var(--blue-500) !important;
  box-shadow: 0 0 0 3px rgba(77,159,208,.20) !important;
  outline: none !important;
}
.form-control:disabled {
  background: var(--gray-100) !important;
  color: var(--gray-500) !important;
  cursor: not-allowed;
}

select.form-control { cursor: pointer; }

label {
  display: block;
  font-weight: 600;
  color: var(--gray-700);
  margin: 10px 0 4px;
  font-size: 13px;
}

/* ================================================================
   BOTONES GENERALES
   ================================================================ */
.btn, button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 18px;
  border-radius: var(--radius-sm) !important;
  font-weight: 600 !important;
  font-size: 13.5px !important;
  cursor: pointer;
  border: 1.5px solid transparent;
  transition: all var(--transition) !important;
  line-height: 1.4;
  white-space: nowrap;
}
.btn:hover, button:hover { transform: translateY(-1px); }
.btn:active, button:active { transform: translateY(0); }

.btn-primary {
  background: linear-gradient(135deg, var(--blue-600), var(--blue-700)) !important;
  border-color: var(--blue-700) !important;
  color: #fff !important;
  box-shadow: 0 2px 6px rgba(68,133,178,.25) !important;
}
.btn-primary:hover {
  background: linear-gradient(135deg, var(--blue-700), var(--blue-800)) !important;
  box-shadow: 0 4px 12px rgba(68,133,178,.35) !important;
}

.btn-success {
  background: linear-gradient(135deg, #22c55e, var(--green-600)) !important;
  border-color: var(--green-600) !important;
  color: #fff !important;
  box-shadow: 0 2px 6px rgba(22,163,74,.25) !important;
}
.btn-success:hover { box-shadow: 0 4px 12px rgba(22,163,74,.35) !important; }

.btn-danger {
  background: linear-gradient(135deg, #ef4444, var(--red-600)) !important;
  border-color: var(--red-600) !important;
  color: #fff !important;
}
.btn-danger:hover { box-shadow: 0 4px 12px rgba(220,38,38,.35) !important; }

.btn-default {
  background: var(--white) !important;
  border-color: var(--gray-300) !important;
  color: var(--gray-700) !important;
}
.btn-default:hover {
  background: var(--gray-50) !important;
  border-color: var(--blue-400) !important;
  color: var(--blue-700) !important;
}

/* Botones sin clase explícita (botones del sistema) */
button:not(.btn):not(.close-button):not(.custom-auth-close):not(.md-close) {
  background: linear-gradient(135deg, var(--blue-500), var(--blue-600));
  color: #fff;
  border: none;
  padding: 9px 20px;
  border-radius: var(--radius-sm) !important;
  box-shadow: 0 2px 6px rgba(68,133,178,.22);
  margin-top: 6px;
}
button:not(.btn):not(.close-button):not(.custom-auth-close):not(.md-close):hover {
  background: linear-gradient(135deg, var(--blue-600), var(--blue-700));
  box-shadow: 0 4px 12px rgba(68,133,178,.32);
}

/* ================================================================
   PANEL PRINCIPAL
   ================================================================ */
#main_panel {
  background: var(--white) !important;
  border: 1px solid var(--gray-200) !important;
  border-radius: var(--radius-lg) !important;
  padding: 20px 24px !important;
  box-shadow: var(--shadow-sm) !important;
  margin-bottom: 20px;
}

/* ================================================================
   FIELDSETS Y LEYENDAS
   ================================================================ */
fieldset {
  border: 1.5px solid var(--gray-200) !important;
  border-radius: var(--radius-md) !important;
  padding: 18px 20px 20px !important;
  background: var(--white) !important;
  box-shadow: var(--shadow-xs) !important;
  margin-bottom: 16px;
  transition: box-shadow var(--transition), transform var(--transition), border-color var(--transition) !important;
}
fieldset:hover {
  box-shadow: var(--shadow-sm) !important;
  border-color: var(--blue-100) !important;
  transform: translateY(-1px);
}
legend {
  font-weight: 700 !important;
  color: var(--blue-700) !important;
  font-size: 14px !important;
  padding: 2px 10px !important;
  background: var(--white) !important;
  border: 1.5px solid var(--blue-100) !important;
  border-radius: 20px !important;
  margin-bottom: 12px !important;
  width: auto !important;
  letter-spacing: .2px;
}

/* ================================================================
   HEADINGS
   ================================================================ */
h1, h2, h3 {
  color: var(--blue-800) !important;
  font-weight: 700 !important;
  margin: 18px 0 14px !important;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--blue-100);
  display: flex;
  align-items: center;
  gap: 8px;
}
h3 { font-size: 16px !important; }
h2 { font-size: 18px !important; }
h4 { font-size: 14px !important; font-weight: 600 !important; color: var(--gray-700) !important; }

/* ================================================================
   TABLAS
   ================================================================ */
table {
  width: 100%;
  border: 1px solid var(--gray-200) !important;
  border-radius: var(--radius-md) !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  overflow: hidden;
  box-shadow: var(--shadow-xs) !important;
  background: var(--white);
}

thead {
  background: linear-gradient(135deg, var(--blue-800), var(--blue-700)) !important;
}

thead th {
  color: #fff !important;
  font-weight: 600 !important;
  font-size: 12.5px !important;
  padding: 11px 14px !important;
  text-transform: uppercase;
  letter-spacing: .4px;
  border: none !important;
  border-right: 1px solid rgba(255,255,255,.10) !important;
}
thead th:last-child { border-right: none !important; }

tbody tr {
  transition: background var(--transition);
  border-bottom: 1px solid var(--gray-100);
}
tbody tr:last-child { border-bottom: none; }
tbody tr:hover { background: var(--blue-50) !important; }

td, th { padding: 9px 14px !important; font-size: 13px !important; }
td { color: var(--gray-700); }

/* Colores de estado de tabla */
.active-student       { background: #d1fae5 !important; }
.suspended-student    { background: #fef9c3 !important; }
.admn-block-student   { background: #ffedd5 !important; }
.inactive-student     { background: #fee2e2 !important; }
.rejected-payment     { background: #fecaca !important; }
.payment-returned     { background: #e0e7ff !important; }
.missed-payment       { background: #d1fae5 !important; }

/* ================================================================
   ALERTAS
   ================================================================ */
.alert {
  border-radius: var(--radius-md) !important;
  font-size: 13.5px !important;
  padding: 12px 16px !important;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  border-left-width: 4px !important;
  border-left-style: solid !important;
}
.alert-success {
  background: var(--green-100) !important;
  border-color: #86efac !important;
  border-left-color: var(--green-600) !important;
  color: #166534 !important;
}
.alert-info {
  background: var(--blue-50) !important;
  border-color: var(--blue-100) !important;
  border-left-color: var(--blue-500) !important;
  color: var(--blue-800) !important;
}
.alert-warning {
  background: var(--amber-100) !important;
  border-color: #fde68a !important;
  border-left-color: var(--amber-500) !important;
  color: #92400e !important;
}
.alert-danger {
  background: var(--red-100) !important;
  border-color: #fca5a5 !important;
  border-left-color: var(--red-600) !important;
  color: #991b1b !important;
}

/* ================================================================
   PANEL DE ÉXITO / STATUS
   ================================================================ */
#panel_sucess {
  background: linear-gradient(135deg, var(--blue-600), var(--teal-500)) !important;
  box-shadow: 0 4px 20px rgba(44,105,150,.35) !important;
  color: #fff !important;
  display: none;
  margin: 20% auto;
  left: 0;
  width: 100%;
  height: auto;
  min-height: 60px;
  position: fixed;
  border-radius: var(--radius-md) !important;
  overflow: hidden;
  text-align: center;
  padding: 16px 24px !important;
  z-index: 999;
}
#panel_sucess * { font-size: 18px !important; color: #fff !important; font-weight: 600 !important; }

/* ================================================================
   CLASES DE UTILIDAD
   ================================================================ */
.hidden  { display: none !important; }
.hand    { cursor: pointer; }
.b       { font-weight: 700 !important; }
.cl1     { color: var(--amber-500) !important; }

.imgbtn {
  border: 1.5px solid var(--blue-400) !important;
  border-radius: var(--radius-sm) !important;
  width: 30px; height: 30px;
  transition: all var(--transition);
}
.imgbtn:hover { background: var(--blue-50) !important; cursor: pointer; transform: scale(1.08); }

/* Zona suavizada */
.smoothness-1 { background: var(--blue-50); border-radius: var(--radius-md); padding: 8px; }
.smoothness-2 { background: var(--white); border-radius: var(--radius-md); padding: 8px; }

/* ================================================================
   PANEL DE BÚSQUEDA — ancho completo
   ================================================================ */
#search_panel {
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 14px 18px;
  border: 1px solid var(--gray-200);
  box-shadow: var(--shadow-xs);
  margin-bottom: 14px;
  position: relative;
  z-index: 0;
  overflow: visible !important;
}

/* Quitar max-width del contenedor de búsqueda inline del HTML */
#search_panel > div[style] {
  max-width: 100% !important;
  width: 100% !important;
  position: relative;
  overflow: visible !important;
}

#search_text {
  padding: 10px 46px 10px 16px !important;
  font-size: 14px !important;
  border: 1.5px solid var(--gray-300) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-xs) !important;
  transition: all var(--transition) !important;
  width: 100% !important;
}
#search_text:focus {
  border-color: var(--blue-500) !important;
  box-shadow: 0 0 0 3px rgba(77,159,208,.18) !important;
}

#search_button {
  background: linear-gradient(135deg, var(--blue-500), var(--blue-700)) !important;
  color: #fff !important;
  border: none !important;
  padding: 9px 28px !important;
  border-radius: var(--radius-md) !important;
  font-weight: 700 !important;
  box-shadow: 0 2px 8px rgba(68,133,178,.28) !important;
  min-width: 100px !important;
}
#search_button:hover {
  box-shadow: 0 4px 14px rgba(68,133,178,.40) !important;
}

#search_results {
  border: 1.5px solid var(--gray-200) !important;
  border-radius: 0 0 var(--radius-md) var(--radius-md) !important;
  box-shadow: var(--shadow-md) !important;
  z-index: 100 !important;
}

/* ================================================================
   MODAL — CERRAR SESIÓN
   ================================================================ */
.iwc-logout-modal {
  padding: 36px 32px 28px !important;
  text-align: center !important;
  border-radius: var(--radius-lg) !important;
  background: var(--white) !important;
  min-width: 300px;
  max-width: 380px;
}
.iwc-logout-icon {
  display: flex;
  justify-content: center;
  margin-bottom: 14px;
}
.iwc-logout-icon svg {
  background: var(--red-100);
  border-radius: 50%;
  padding: 14px;
  box-sizing: content-box;
}
.iwc-logout-title {
  font-size: 22px !important;
  font-weight: 800 !important;
  color: var(--gray-900) !important;
  margin: 0 0 8px !important;
  padding: 0 !important;
  border: none !important;
}
.iwc-logout-desc {
  font-size: 14px !important;
  color: var(--gray-600) !important;
  margin: 0 0 24px !important;
  line-height: 1.6 !important;
}
.iwc-logout-actions { display: flex; flex-direction: column; gap: 10px; }

.iwc-btn-confirm {
  background: linear-gradient(135deg, #ef4444, var(--red-600)) !important;
  border: none !important;
  color: #fff !important;
  border-radius: var(--radius-md) !important;
  padding: 12px 0 !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  width: 100% !important;
  cursor: pointer;
  transition: all var(--transition);
  box-shadow: 0 2px 8px rgba(220,38,38,.25) !important;
}
.iwc-btn-confirm:hover {
  background: linear-gradient(135deg, var(--red-600), #b91c1c) !important;
  box-shadow: 0 4px 14px rgba(220,38,38,.40) !important;
}

.iwc-btn-cancel {
  background: var(--gray-100) !important;
  border: 1.5px solid var(--gray-300) !important;
  color: var(--gray-700) !important;
  border-radius: var(--radius-md) !important;
  padding: 11px 0 !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  width: 100% !important;
  cursor: pointer;
  transition: all var(--transition);
}
.iwc-btn-cancel:hover { background: var(--gray-200) !important; }

.md-overlay { background: rgba(10,20,40,.60) !important; backdrop-filter: blur(2px); }
#modal-3 .md-content { border-radius: var(--radius-lg) !important; overflow: hidden; }

/* ================================================================
   MODAL DE AUTORIZACIÓN (custom)
   ================================================================ */
.custom-auth-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(10,20,40,.65);
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(3px);
}
.custom-auth-modal {
  width: 90%;
  max-width: 520px;
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  font-family: inherit;
}
.custom-auth-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  background: linear-gradient(135deg, var(--blue-700), var(--blue-600));
  color: #fff;
}
.custom-auth-modal-header #auth_modal_title { font-weight: 700; font-size: 15px; }
.custom-auth-close {
  background: transparent;
  border: none;
  color: #fff !important;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  padding: 0 4px;
  border-radius: 4px;
  transition: background var(--transition);
}
.custom-auth-close:hover { background: rgba(255,255,255,.18) !important; }
.custom-auth-modal-body { padding: 20px; }
.custom-auth-modal-footer {
  padding: 14px 20px;
  border-top: 1px solid var(--gray-200);
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
.custom-input-row { display: flex; gap: 8px; align-items: center; }
.custom-label { font-weight: 600; color: var(--gray-700); font-size: 13px; }

/* Advertencia TOTP */
#student_colegiaturas_pay_inputs .warning-totp {
  background: var(--amber-100);
  border: 1px solid #fde68a;
  color: #92400e;
  padding: 10px;
  border-radius: var(--radius-sm);
  text-align: center;
}

/* ================================================================
   ELEMENTOS OCULTOS (funcionalidad del sistema — no modificar)
   ================================================================ */
#student_edit_panel, #panel_sucess, #user_panel,
#masive_mail_panel, #search_panel, #upload_panel,
#student_internal_pay_panel, #student_pay_panel,
#group_edit_panel, #ins_panel, #suspended_panel, #smfb_panel,
#create_user_panel, #boucher_panel, #cards_panel,
#inscritos_panel, #ticket_panel, #becas_panel, #preview_panel, #warn_people_advice,
#brothers_panel, #status_panel, #single_mail_panel, #erase_student, #prorroga_panel,
#blocked_panel, #upload_panel_xls, #is_ni, #internal_pay_edit_panel, #migration_panel,
#taller_panel, #menu_migration, #menu_taller, #estado_cuenta_panel {
  display: none;
}

#servicio_medico option { display: none; }
#atencion_interna option { display: none; }

/* Entrada suave cuando los paneles ocultos del sistema se muestran por JS */
[id$="_panel"]:not(#panel_sucess)[style*="display: block"],
[id$="_panel"]:not(#panel_sucess)[style*="display:block"],
[id$="_panel"]:not(#panel_sucess)[style*="display: flex"],
[id$="_panel"]:not(#panel_sucess)[style*="display:flex"] {
  animation: iwc-panel-enter .30s ease-out both;
}

/* ================================================================
   ANIMACIONES CSS
   ================================================================ */
.header-ani {
  margin-left: 80px;
  -webkit-transition: margin-left ease-in-out .50s;
  transition: margin-left ease-in-out .50s;
}
.user-ani {
  padding-left: 80px;
  -webkit-transition: padding-left ease-in-out .60s;
  transition: padding-left ease-in-out .60s;
}

/* ================================================================
   SUBMENÚ LATERAL (OffCanvas)
   ================================================================ */
.menu-item-with-submenu { position: relative; }
.menu-item-with-submenu > a {
  display: block;
  padding: 0.4em;
  position: relative;
}
.submenu-arrow {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  transition: transform .3s ease;
}
.submenu {
  position: absolute;
  left: 100%;
  top: 0;
  background: var(--white);
  min-width: 200px;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-md);
  z-index: 1000;
  opacity: 0;
  visibility: hidden;
  transform: translateX(-12px) scale(.98);
  transition: opacity .22s ease, visibility .22s ease, transform .22s ease;
}
.submenu a {
  display: block;
  padding: .8em 1.2em;
  color: var(--gray-700);
  text-decoration: none;
  border-bottom: 1px solid var(--gray-100);
  transition: background .2s;
}
/* Especificidad 0,3,1 — supera a .menu .icon-list a (0,2,1) aunque ambos tengan !important */
.menu .icon-list .submenu a {
  color: var(--gray-700) !important;
}
.menu .icon-list .submenu a span,
.menu .icon-list .submenu a i,
.menu .icon-list .submenu a * {
  color: inherit !important;
}
.submenu a:hover,
.submenu a:focus,
.menu .icon-list .submenu a:hover,
.menu .icon-list .submenu a:focus {
  background: var(--blue-50);
  color: var(--blue-700) !important;
}
.submenu a:last-child { border-bottom: none; }
.menu-item-with-submenu:hover .submenu { opacity: 1; visibility: visible; transform: translateX(0) scale(1); }
.menu-item-with-submenu:hover .submenu-arrow { transform: translateY(-50%) rotate(90deg); }
.submenu a i { margin-right: 8px; width: 20px; text-align: center; }
.submenu a span { font-size: 14px; }

/* ================================================================
   MÓDULO MÉDICO
   ================================================================ */
@media screen and (min-width: 992px) {
  #medical_module { width: 850px; margin-left: 10px; }
  #medical_module legend { font-size: 18px; }
  #medical_module label { font-size: 14px; margin: 5px; }
  #medical_module input, #medical_module select {
    width: 100%;
    max-width: 550px;
    height: 40px;
    margin: 4px;
    font-size: 14px;
  }
  #medical_module button { font-size: 14px; }
}

/* ================================================================
   BOTÓN CONFLICTO (ícono W)
   ================================================================ */
#conflicto_button {
  width: 40px;
  height: 40px;
  background-image: url('../img/W.png');
  background-size: 100% 100%;
  float: right;
  background-color: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
  border: none !important;
}

/* ================================================================
   MODAL HEREDADO (plugin)
   ================================================================ */
.modalCP {
  background: rgba(0,0,0,.75);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  display: none;
  justify-content: center;
  align-items: center;
}
.modal-contentsCP {
  height: auto;
  min-height: 280px;
  width: 500px;
  background: var(--white);
  text-align: center;
  padding: 24px;
  position: relative;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
}
.inputCP {
  margin: 12px auto;
  display: block;
  width: 60%;
  padding: 8px 12px;
  border: 1.5px solid var(--gray-300);
  border-radius: var(--radius-sm);
}
.closeCP {
  position: absolute;
  top: 8px;
  right: 14px;
  font-size: 36px;
  color: var(--gray-500);
  transform: rotate(45deg);
  cursor: pointer;
  transition: color var(--transition);
}
.closeCP:hover { color: var(--gray-700); }

/* ================================================================
   OVERRIDES — neutralizan reglas antiguas
   ================================================================ */
#logout,
#menu_student_pay_alt,
#menu_student_internal_pay_alt,
#menu_search_student_alt {
  margin-left: 0 !important;
  float: none !important;
  display: block !important;
}

#user_panel_name { background-image: none; }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 992px) {
  .col-md-4, .col-md-3, .col-md-5, .col-md-6, .col-md-7 { width: 100% !important; }
}

@media (max-width: 768px) {
  .content > header.header { font-size: 13px !important; padding-left: 54px !important; }
  #user_panel { flex-direction: column !important; }
  #user_panel_name { min-width: unset !important; width: 100% !important; height: 64px !important; }
  #user_panel_actions { align-items: stretch !important; justify-content: stretch !important; }
  #user_panel_actions .btn { min-width: unset !important; flex: 1 !important; }
  #form_log > div { padding: 24px 18px !important; }
  .modal-contentsCP { width: 90%; }
}

@media (max-width: 480px) {
  .content > header.header { font-size: 12px !important; }
  #main_panel { padding: 10px !important; }
  #user_panel_actions .btn { font-size: 11.5px !important; padding: 6px 10px !important; }
}

/* ================================================================
   REDUCCIÓN DE ESPACIO VERTICAL EN PANELES INTERNOS
   ================================================================ */

/* Menos margen entre etiquetas y controles */
#main_panel label { margin-top: 8px !important; margin-bottom: 3px !important; }
#main_panel .form-control { margin-bottom: 2px !important; }

/* Botones de acción dentro de paneles */
#main_panel button:not(.btn):not(.custom-auth-close):not(.md-close),
#main_panel .btn {
  margin-top: 10px !important;
}

/* Reducir br vacíos que Bootstrap hereda */
#main_panel br { line-height: 0.5; }

/* Alertas de aviso sin margen excesivo */
#warn_people_advice { margin-bottom: 10px !important; }

/* Encabezados de sección más compactos */
#main_panel h3 {
  margin-top: 10px !important;
  margin-bottom: 10px !important;
  padding-bottom: 6px !important;
  font-size: 15px !important;
}

/* Columnas de paneles de alumnos usan el 100% de la fila */
#student_edit_panel.row > [class*="col-"] { float: left; }

/* Panel de pagos: tabla ocupa el ancho completo */
#student_pay_panel table,
#student_edit_panel table,
#group_edit_panel table,
#suspended_panel table {
  width: 100% !important;
}

/* Watch panel sin contenedor estrecho */
#watch_student_pay_panel { width: 100% !important; padding: 0 !important; }

/* Respeta accesibilidad: sin animaciones para usuarios que lo prefieren */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation: none !important;
    transition: none !important;
  }
}
