

/* ESTILOS PARA HEADER Y FOOTER */
header {
    font-family: Arial, sans-serif !important;
    background-color: #004D40 !important;
    color: white !important;
    padding: 20px 0 !important;
    text-align: center !important;
    width: 100% !important;
}

header .logo h1 {
    color: white !important;
    font-size: 2em !important;
    margin: 0 !important;
    padding: 0 !important;
}

footer {
	font-family: Arial, sans-serif !important;
    background-color: #004D40 !important;
    color: white !important;
    padding: 20px 0 !important;
    text-align: center !important;
    width: 100% !important;
    margin-top: 40px !important;
}

.footer-content {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
}

.footer-content p {
    margin: 5px 0 !important;
    color: white !important;
}

/* CONTENEDOR PRINCIPAL MEJORADO */
.main-content {
    min-height: calc(100vh - 160px) !important; /* Ajusta altura restando header y footer */
    padding: 20px 0 !important;
}

body {
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 100vh !important;
}


/* CONTENEDOR PRINCIPAL - FORZADO */
.contenedor {
    max-width: 1200px !important;
    margin: 20px auto !important;
    padding: 30px !important;
    border: 1px solid #ccc !important;
    border-radius: 0 !important;
    background-color: #ffffff !important;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1) !important;
}

.contenedor h2 {
    color: #004D40 !important;
    margin-bottom: 25px !important;
    text-align: center !important;
    font-size: 1.8em !important;
    border-bottom: 2px solid #004D40 !important;
    padding-bottom: 10px !important;
}

/* GRID DE 3 COLUMNAS - FORZADO CON !important */
.form-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 25px !important;
    margin-bottom: 30px !important;
    
}

.form-group {
    display: flex !important;
    flex-direction: column !important;
   
}

.form-group label {
    font-weight: bold !important;
    margin-bottom: 8px !important;
    color: #004D40 !important;
    font-size: 0.95em !important;
    
}

.form-group input,
.form-group select {
    padding: 12px !important;
    border: 1px solid #ccc !important;
    border-radius: 0 !important;
    font-size: 1em !important;
    width: 90% !important;
    background-color: #fff !important;
    display: block !important;
}

.form-group input:read-only {
    background-color: #f8f9fa !important;
    color: #666 !important;
}

/* BOTONES SIN MOVIMIENTO - FORZADO */
.botones {
    display: flex !important;
    justify-content: center !important;
    gap: 20px !important;
    margin-top: 40px !important;
    flex-wrap: wrap !important;
}

.botones form {
    margin: 0 !important;
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    display:inline-block; margin:0;
}

/* Botones base */
.botones button {
    background-color: #00796B !important;
    color: white !important;
    padding: 14px 30px !important;
    border: none !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    font-size: 1em !important;
    font-weight: bold !important;
    min-width: 140px !important;
    transition: background-color 0.2s ease !important;
}

.botones button:hover {
    background-color: #004D40 !important;
    transform: none !important;
    box-shadow: none !important;
}

/* Botón Eliminar específico */
.botones form[action*='eliminar'] button {
    background-color: #d32f2f !important;
}

.botones form[action*='eliminar'] button:hover {
    background-color: #b71c1c !important;
}

/* Botón Confirmar específico */
.botones form[action*='confirmar'] button {
    background-color: #004D40 !important;
}

.botones form[action*='confirmar'] button:hover {
    background-color: #00251a !important;
}

/* Botón Volver */
.boton-volver {
	font-family: Arial, sans-serif !important;
    display: inline-block !important;
    margin-top: 25px !important;
    padding: 12px 25px !important;
    background-color: #6c757d !important;
    color: white !important;
    border-radius: 0 !important;
    text-decoration: none !important;
    font-weight: bold !important;
    text-align: center !important;
}

.boton-volver:hover {
    background-color: #545b62 !important;
    transform: none !important;
    box-shadow: none !important;
    text-decoration: none !important;
    color: white !important;
}

/* Mensajes */
.mensaje-error {
    background-color: #f8d7da !important;
    color: #721c24 !important;
    padding: 15px !important;
    margin-bottom: 20px !important;
    border: 1px solid #f5c6cb !important;
    border-radius: 0 !important;
    font-weight: bold !important;
}

.mensaje-exito {
    background-color: #d4edda !important;
    color: #155724 !important;
    padding: 15px !important;
    margin-bottom: 20px !important;
    border: 1px solid #c3e6cb !important;
    border-radius: 0 !important;
    font-weight: bold !important;
}

/* === Botones especiales: Imprimir y Descargar === */
.acciones-extra {
    display: flex;
    justify-content: center;
    gap: 0px;
    margin-top: 20px;
    flex-wrap: wrap;
}

button.imprimir-btn {
    background-color: #C0C0C0;
	min-width: 200px;
	color: white;
	font-size: 1em;
    font-weight: bold;
	padding: 14px 30px;
    border: none;
    border-radius: 0;
    cursor: pointer;
}

button.imprimir-btn:hover {
    background-color: #004D40;
	
}

button.descargar-btn {
    background-color: #C0C0C0;
	min-width: 180px;
	color: white;
	font-size: 1em;
    font-weight: bold;
	padding: 14px 30px;
    border: none;
    border-radius: 0;
    cursor: pointer;
}

button.descargar-btn:hover {
    background-color: #004D40;
}
