/* style.css - estilos y background animado */
:root{
  /* palette */
  --primary: #004a80; /* main blue used for headers and accents */
  --accent: #0366d6;  /* action buttons */
  --danger: #d9534f;
  --success: #044d00;
  --white: #ffffff;
  --muted: #666;
  --bg-overlay: rgba(0,0,0,0.45);
}

.abel-regular {font-family: "Abel", sans-serif;font-weight: 400;font-style: normal;}

*{box-sizing:border-box}
html,body{margin:0;}

/* fondo animado usando pseudo-elemento */
body::before{
  content: '';
  position: fixed;
  inset: 0;
  z-index: -3;
  background-image: url('../img/back_1920x1080.png');
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  background-attachment: fixed;
  transform: scale(1);
  animation: bg-zoom 18s ease-in-out infinite;
  filter: brightness(1.02) saturate(1.05) contrast(0.98);
}

/* overlay semi-transparente sobre la imagen; reducir opacidad para dejar ver más la foto */
body::after{content:'';position:fixed;inset:0;z-index:-2;background:rgba(0,0,0,0.28)}

@keyframes bg-zoom{0%{transform:scale(1)}50%{transform:scale(1.08)}100%{transform:scale(1)}}

/* layout */
.container{max-width:600px;margin:6vh auto;padding:32px;background:white;border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,0.6);backdrop-filter: blur(6px);text-align: center;}

/* centrar el formulario en la pantalla para la página de login */
body.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh}
body.auth-page .container{margin:0;transform:translateY(-4%)}
h1{margin:0 0 18px;font-size:1.6rem;}
main h1, p, h2 {color: var(--primary); text-align: center;}
h2{text-transform: uppercase;}
.btnusrnew{display: inline-block;padding: 6px;background-color: var(--primary);text-decoration: none;border-radius: 6px;font-weight: 400;color: var(--white);}
.btnusrnew:hover{background-color: orange;color:var(--primary);}
.logoini{display:block;margin:0 auto 40px;width:346px}
.form label{display:block;margin:12px 0 6px;font-size:16px}
.form input[type=text],.form input[type=email],.form input[type=password],.form input[type=url],.form input[type=number],.form input[type=datetime-local],.form textarea{width:100%;padding:10px 12px;border-radius:8px;border:1px solid lightgray;text-align: center;margin-bottom: 20px;font-size:16px; color: var(--primary);}
.form button{margin-top:20px;width:100%;padding:10px 12px;border:0;border-radius:8px;background:var(--accent);color:#fff;font-weight:400;font-size:18px;text-transform: uppercase;}
.form button:hover{background: orange;color: var(--primary);}
.error{background:red;padding:10px;border-radius:6px;margin-bottom: 20px;color: white;}
.success{background:#044d00;padding:8px;border-radius:6px}
/* flash messages (global) */
.flash-success{background:#e6f7ea;border:1px solid #2e7d32;color:#145a32;padding:10px;border-radius:6px;margin:12px auto;max-width:500px;text-align:center;font-family: "Abel", sans-serif;font-weight: 400;font-style: normal;}
.flash-error{background:#fdecea;border:1px solid #d32f2f;color:#7a1919;padding:10px;border-radius:6px;margin:12px auto;max-width:500px;text-align:center;font-family: "Abel", sans-serif;font-weight: 400;font-style: normal;}
.footerini{margin-top:24px;margin-bottom: 0; font-size:0.8rem;text-align:center}
.select1{border:1px solid lightgray;border-radius:8px;padding:10px 12px;width:100%;text-align: center;font-size: 16px;color: var(--primary);margin-bottom: 20px;}


/* estilos para encabezados clicables en tablas (orden) */
table thead th a{color: #004a80;text-decoration: none;font-weight: 400;display: inline-block;padding: 6px 8px;border-radius: 6px;}
table thead th a:hover{background: rgba(255,255,255,0.04);}

/* indicador (▲/▼) tendrá un espaciado y color suave */
table thead th a::after{margin-left:6px;color:rgba(255,255,255,0.85)}

@media (prefers-reduced-motion: reduce){body::before{animation:none}}

/* estilos para header/menus responsive */
.site-header{background:var(--primary);color:var(--white);padding:10px 12px}
.site-header-inner{max-width:1024px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;}
.site-nav{display:flex;gap:12px}
.site-nav a{color:var(--white);text-decoration:none;padding:6px 8px;border-radius:6px; text-transform: uppercase; font-size: 24px;}
/* hover/focus: fondo y texto especificados por solicitud */
.site-nav a:hover, .site-nav a:focus {
  background: #004a80;
  color: orange;
}
.site-user{display:flex;align-items:center;gap:12px}
.btn-logout{background:var(--white);color:var(--primary);border:0;padding:6px 10px;border-radius:6px;cursor:pointer;font-size:16px;font-weight:400;}
.btn-logout:hover{background: orange; color: var(--primary);}

.logo {display: flex;justify-content: center;align-items: center;padding-top: 10px; padding-bottom: 5px;}
.logo img{height: 100px;}

/* mobile */
.nav-toggle{display:none;background:transparent;border:0;color:#fff;font-size:24px;padding:6px}

@media (max-width:960px){
  .site-header-inner{display:flex;align-items:center;gap:12px}
  /* menú en modo overlay: posición fija encima del contenido */
  .site-nav{position:fixed;left:0;right:0;top:120px;bottom:0;background:rgba(3,102,214,0.98);flex-direction:column;padding:16px 12px;display:none;z-index:1005;overflow:auto;background-color: var(--primary);}
  .site-nav a{display:block;padding:12px;border-radius:6px}
  .nav-toggle{display:inline-block;z-index:1100;position:relative}
  .site-nav.open{display:flex; align-items: center;}
  /* cuando el nav está abierto, evitar scroll del body */
  body.nav-open{overflow:hidden}
}

@media (max-width:500px){.logo img{height: 75px}.site-nav{top: 95px}}

/* small accessibility tweak */
.nav-toggle:focus{outline:2px solid #fff}

/* ==========================
   PORTALES (admin / user)
   El objetivo: ocultar el fondo animado y dejar fondo blanco
   cuando la página contiene el header de portal `.site-header`.
   Esto crea una pseudo-capa blanca por encima de los pseudo-elementos
   globales `body::before/::after` (que contienen la imagen animada).
   ========================== */
.site-header::before{content: '';position: fixed;inset: 0;background: var(--white);z-index: -1; 
  /* estará por encima de body::before (-3) y body::after (-2) */
}

/* (Revertido) Sticky header y logo eliminados: volver a comportamiento original */
/* Nota: la regla original de .site-header (background/padding) permanece arriba. */

/* Forzar colores legibles en el contenido posterior al header */
.site-header ~ * { color: #111; }
.site-header ~ main, .site-header ~ .container { background: var(--white); color: var(--primary); }
.site-header ~ main a, .site-header ~ .container a {text-decoration: none; }
.site-header ~ footer { background: var(--primary); color: var(--white); }

button{cursor: pointer;}

/* Footer sticky para portales */
.portal-footer{position:fixed;left:0;right:0;bottom:0;background:#004a80;border-top:1px solid rgba(255,255,255,0.06);z-index:1200;
}
.portal-footer-inner{max-width:1024px;margin:0 auto;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.portal-footer small{color: #ffffff}
.portal-footer-links a{color:#ffffff;text-decoration:none;margin-left:12px}

/* Reservar espacio para el footer en el contenido principal en portales */
.site-header ~ .container, .site-header ~ main{padding-bottom:72px}

/* Estilos para iconos de acción en tablas (editar / eliminar) */
.action-icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:6px;border:0;background:transparent;color:var(--primary);margin:0 4px;cursor:pointer;text-decoration:none}
.action-icon svg{width:18px;height:18px}
.action-icon.edit{background:transparent;color:var(--accent)}
.action-icon.edit:hover{background:rgba(3,102,214,0.08)}
.action-icon.delete{background:transparent;color:var(--danger)}
.action-icon.delete:hover{background:rgba(217,83,79,0.08)}
.inline-delete{display:inline}
.action-icon.view{background:transparent;color:var(--accent)}
.action-icon.view:hover{background:rgba(3,102,214,0.08)}


.btnusrnew{display:inline-block;background:#0366d6;color:#fff;padding:8px 12px;border-radius:8px;text-decoration:none;width: 200px;}

/* Font Awesome icons inside action-icon */
.action-icon i{font-size:16px;line-height:1;color:inherit}

/* Helper: sticky header helper removed for clientes page */

/* ===========================================
   RESPONSIVE TABLES FOR MOBILE
   Convertir tablas en cards en dispositivos móviles
   =========================================== */

/* Contenedor de tabla con scroll horizontal por defecto */
.table-responsive {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 12px 0;
}

/* Estilos base para tablas */
table {
  width: 100%;
  border-collapse: collapse;
  min-width: 500px; /* Mantener ancho mínimo en desktop */
}

table thead {
  background: none;

}

table thead th {
  padding: 12px 8px;
  text-align: center;
  font-weight: 600;
  white-space: nowrap;
}

table tbody td {
  padding: 10px 8px;
  border-bottom: 1px solid #eee;
}

table tbody tr:hover {
  background: rgba(3, 102, 214, 0.04);
}

/* Estilos para tabla de detalle (cliente_view) */
.detail-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 12px;
}

.detail-table th {
  text-align: left;
  padding: 12px;
  min-width: 180px;
  background: #f7f7f7;
  font-weight: 600;
  border-top: 1px solid #eee;
}

.detail-table td {
  padding: 12px;
  border-top: 1px solid #eee;
  word-break: break-word;
}

/* MOBILE: Convertir tablas a cards */
@media (max-width: 768px) {
  /* Ocultar tabla tradicional */
  .table-responsive table {
    display: none;
  }
  
  /* Mostrar vista de cards */
  .mobile-cards {
    display: block !important;
  }
  
  .mobile-card {
    background: var(--white);
    border: 1px solid #ddd;
    border-radius: 8px;
    padding: 16px;
    margin-bottom: 16px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
  }
  
  .mobile-card-header {
    border-bottom: 2px solid var(--primary);
    padding-bottom: 12px;
    margin-bottom: 12px;
  }
  
  .mobile-card-title {
    font-size: 18px;
    font-weight: 600;
    color: var(--primary);
    margin: 0 0 4px 0;
  }
  
  .mobile-card-subtitle {
    font-size: 14px;
    color: var(--muted);
    margin: 0;
  }
  
  .mobile-card-body {
    margin-bottom: 12px;
  }
  
  .mobile-card-row {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    border-bottom: 1px solid #f0f0f0;
  }
  
  .mobile-card-row:last-child {
    border-bottom: none;
  }
  
  .mobile-card-label {
    font-weight: 600;
    color: var(--muted);
    font-size: 13px;
    flex: 0 0 40%;
  }
  
  .mobile-card-value {
    color: var(--primary);
    font-size: 14px;
    flex: 1;
    text-align: right;
    word-break: break-word;
  }
  
  .mobile-card-actions {
    display: flex;
    gap: 8px;
    justify-content: center;
    padding-top: 12px;
    border-top: 1px solid #eee;
  }
  
  .mobile-card-actions .action-icon {
    flex: 1;
    max-width: 100px;
    height: 40px;
    font-size: 16px;
  }
  
  .mobile-card-actions form {
    flex: 1;
    max-width: 100px;
  }
  
  .mobile-card-actions .action-icon.delete {
    width: 100%;
    height: 40px;
  }
  
  /* Tabla de detalle (cliente_view) responsive */
  .detail-table {
    display: block;
  }
  
  .detail-table tbody {
    display: block;
  }
  
  .detail-table tr {
    display: block;
    margin-bottom: 12px;
    border: 1px solid #eee;
    border-radius: 6px;
    overflow: hidden;
  }
  
  .detail-table th,
  .detail-table td {
    display: block;
    width: 100% !important;
    min-width: auto !important;
    text-align: left !important;
    padding: 10px 12px !important;
    border: none !important;
  }
  
  .detail-table th {
    background: var(--primary) !important;
    color: var(--white) !important;
    font-size: 13px;
    font-weight: 600;
  }
  
  .detail-table td {
    background: var(--white) !important;
    font-size: 15px;
    padding-bottom: 14px !important;
  }
  
  /* Ajustar botones en móvil */
  .btnusrnew {
    width: 100%;
    max-width: 300px;
    margin: 8px auto;
    display: block;
    text-align: center;
  }
  
  /* Ajustar formulario de búsqueda */
  form[method="get"] {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 16px !important;
  }
  
  form[method="get"] input[type="search"] {
    width: 100%;
    padding: 12px;
    font-size: 16px;
    border: 1px solid #ddd;
    border-radius: 6px;
  }
  
  form[method="get"] button {
    width: 100%;
    padding: 12px;
    font-size: 16px;
    background: var(--accent);
    color: var(--white);
    border: none;
    border-radius: 6px;
    cursor: pointer;
  }
  
  form[method="get"] button:hover {
    background: var(--primary);
  }
  
  /* Ajustar paginación */
  div[style*="text-align:center"] {
    font-size: 14px;
    padding: 12px 0;
  }
  
  div[style*="text-align:center"] a {
    display: inline-block;
    padding: 8px 12px;
    margin: 0 4px;
    background: var(--primary);
    color: var(--white);
    border-radius: 6px;
    text-decoration: none;
  }
  
  /* Ajustar main para móvil */
  main {
    padding: 16px 12px 80px 12px !important;
  }
  
  main h2 {
    font-size: 24px;
    margin-bottom: 16px;
  }
}

/* Tablet: ajustes intermedios */
@media (min-width: 769px) and (max-width: 1024px) {
  table {
    min-width: 100%;
    font-size: 14px;
  }
  
  table thead th,
  table tbody td {
    padding: 8px 6px;
  }
  
  .action-icon {
    width: 30px;
    height: 30px;
  }
}

/* Ocultar cards en desktop */
@media (min-width: 769px) {
  .mobile-cards {
    display: none !important;
  }
}
