/* ============================================
   VARIABLES GLOBALES
============================================ */
:root {
    --maroon: #5b1220;  
    --gold: #bd9659;    
    --light: #efe1b3;   
    --text-dark: #222;
    --text-muted: #777;
    --radius: 6px;
    --shadow: 0 2px 8px rgba(0,0,0,0.12);
}

*{
    box-sizing:border-box;
    font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif;
}

/* ============================================
   LAYOUT GLOBAL (HEADER / MAIN / FOOTER)
============================================ */

html,body{
    height:100%;
}

body{
    margin:0;
    display:flex;
    flex-direction:column;
    background:#f5f5f5;
    color:var(--text-dark);
}

main{
    flex:1;
    width:100%;
}

a{
    text-decoration:none;
}

h1{
    color:var(--maroon);
    text-align:center;
}

/* ============================================
   HEADER SUPERIOR
============================================ */

.top-bar{
    background:var(--maroon);
    color:#fff;
    padding:8px 16px;
    text-align:right;
}

.top-bar a{
    color:#fff;
    margin-left:14px;
    font-size:14px;
    transition:opacity .3s;
}

.top-bar a:hover{
    opacity:.8;
}

/* ============================================
   NAVBAR
============================================ */

.navbar{
    background:var(--gold);
    padding:12px;
}

.navbar ul{
    list-style:none;
    margin:0;
    padding:0;
    display:flex;
    gap:18px;
    flex-wrap:wrap;
}

.navbar a{
    color:#fff;
    font-weight:500;
    transition:opacity .3s;
}

.navbar a:hover{
    opacity:.8;
}

/* ============================================
   HERO
============================================ */

.hero{
    display:flex;
    align-items:center;
    gap:20px;
    padding:40px 24px;

    background:linear-gradient(
        90deg,
        rgba(91,18,32,.95) 0%,
        rgba(91,18,32,.6) 35%,
        rgba(239,225,179,.6) 35%
    );

    color:#fff;
}

.hero-left h2{
    font-size:32px;
    margin:0;
    padding:12px 24px;
    line-height:1.4;
}

.hero-left strong{
    font-weight:800;
    color:var(--gold);
}

/* ============================================
   MENU
============================================ */

.menu{
    background:var(--gold);
    padding:12px;
}

.menu ul{
    list-style:none;
    display:flex;
    gap:18px;
    margin:0;
    padding:0;
}

.menu a{
    color:#fff;
    font-weight:500;
}

.menu a:hover{
    opacity:.8;
}

/* ============================================
   MAIN NEWS
============================================ */

.main-news{
    padding:20px;
}

/* ============================================
   NEWS SECTION
============================================ */

.news-section{
    padding:60px 5%;
    max-width:1400px;
    margin:0 auto;
    background:#fff;
    border-radius:8px;
    box-shadow:var(--shadow);
}

.news-section h1{
    font-size:2.5em;
    margin-bottom:50px;
    position:relative;
    padding-bottom:15px;
}

.news-section h1::after{
    content:'';
    position:absolute;
    bottom:0;
    left:50%;
    transform:translateX(-50%);
    width:100px;
    height:4px;
    background:linear-gradient(90deg,var(--maroon),var(--gold));
    border-radius:2px;
}

/* ============================================
   NEWS GRID
============================================ */

.news-container{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(350px,1fr));
    gap:30px;
}

/* ============================================
   NEWS CARD
============================================ */

.news-card{
    background:#fff;
    border-radius:12px;
    overflow:hidden;
    box-shadow:0 4px 15px rgba(0,0,0,.1);
    transition:.3s;
    display:flex;
    flex-direction:column;
}

.news-card:hover{
    transform:translateY(-5px);
    box-shadow:0 8px 25px rgba(0,0,0,.15);
}

.news-card img{
    width:100%;
    height:180px;
    object-fit:cover;
}

.news-content{
    padding:25px;
    flex:1;
    display:flex;
    flex-direction:column;
}

.news-title{
    font-size:1.4em;
    color:var(--maroon);
    margin-bottom:15px;
}

.news-text{
    color:#000;
    line-height:1.6;
    margin-bottom:20px;
    flex:1;

    display:-webkit-box;
    -webkit-line-clamp:4;
    -webkit-box-orient:vertical;
    overflow:hidden;
}

.news-date{
    color:var(--maroon);
    font-size:14px;
    font-weight:600;
}

.news-footer{
    display:flex;
    justify-content:space-between;
    align-items:center;
    border-top:1px solid #eee;
    padding-top:12px;
}

.read-more{
    color:var(--gold);
    font-weight:600;
    display:flex;
    gap:5px;
    transition:.3s;
}

.read-more:hover{
    gap:10px;
}

/* ============================================
   ADMIN PANEL
============================================ */

.admin-header{
    background:var(--gold);
    padding:14px 20px;
    display:flex;
    justify-content:space-between;
    align-items:center;
}

.admin-header nav ul{
    display:flex;
    gap:16px;
    list-style:none;
    margin:0;
    padding:0;
}

.admin-header nav a{
    color:#fff;
    font-weight:600;
}

.admin-main{
    padding:20px;
    max-width:1200px;
    margin:auto;
}

/* ============================================
   ADMIN FORM
============================================ */

.admin-form{
    background:#fff;
    padding:24px;
    border-radius:8px;
    box-shadow:var(--shadow);
    margin-bottom:30px;
}

.admin-form form{
    display:grid;
    gap:14px;
}

/* ============================================
   INPUTS
============================================ */

input,textarea{
    padding:10px;
    border:1px solid #ccc;
    border-radius:var(--radius);
    width:100%;
}

input:focus,textarea:focus{
    outline:none;
    border-color:var(--maroon);
}

/* ============================================
   BOTONES
============================================ */

button{
    background:var(--maroon);
    color:#fff;
    padding:12px 20px;
    border:none;
    border-radius:var(--radius);
    cursor:pointer;
    font-weight:600;
}

button:hover{
    background:#7a1829;
}

.btn-eliminar{
    background:#d9534f;
}

.btn-eliminar:hover{
    background:#c9302c;
}

/* ============================================
   CONTACTO
============================================ */

/* ============================================
   CONTACTO MEJORADO (FORMULARIO MÁS PEQUEÑO)
============================================ */

.contacto-contenido{
    max-width:600px;
    margin:40px auto;
    background:#fff;
    padding:22px 24px;
    border-radius:var(--radius);
    box-shadow:var(--shadow);
}

.contacto-contenido h1{
    text-align:center;
    font-size:24px;
    margin-bottom:6px;
}

.contacto-contenido p{
    text-align:center;
    font-size:13px;
    color:var(--text-muted);
    margin-bottom:18px;
}

/* FORMULARIO */

.contact-form{
    display:grid;
    gap:8px;
}

/* etiquetas */

.contact-form label{
    font-size:13px;
    font-weight:600;
    color:var(--maroon);
}

/* campos */

.contact-form input,
.contact-form textarea{
    padding:8px 10px;
    border:1px solid #ddd;
    border-radius:var(--radius);
    font-size:13px;
    width:100%;
    transition:.2s;
}

/* focus */

.contact-form input:focus,
.contact-form textarea:focus{
    border-color:var(--gold);
    box-shadow:0 0 5px rgba(189,150,89,.2);
    outline:none;
}

/* textarea tamaño */

.contact-form textarea{
    min-height:90px;
    resize:vertical;
}

/* botón */

.contact-form button{
    margin-top:6px;
    padding:9px;
    font-size:13px;
    background:var(--maroon);
    color:#fff;
    border:none;
    border-radius:var(--radius);
    cursor:pointer;
    font-weight:600;
}

.contact-form button:hover{
    background:#7a1829;
}

/* dirección */

.contact-address{
    margin-top:16px;
    padding:14px;
    background:var(--light);
    border-left:4px solid var(--gold);
    border-radius:var(--radius);
    font-size:13px;
}

.contact-address iframe{
    width:100%;
    height:220px;
    border:0;
    margin-top:8px;
    border-radius:var(--radius);
}

/* ============================================
   SERVICIOS
============================================ */

.servicios-contenido{
    padding:40px 20px;
    max-width:1200px;
    margin:auto;
}

.servicios{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
    gap:25px;
}

.servicios article{
    background:#fff;
    padding:24px;
    border-radius:8px;
    box-shadow:var(--shadow);
    transition:.3s;
}

.servicios article:hover{
    transform:translateY(-4px);
    box-shadow:0 4px 12px rgba(0,0,0,.15);
}

.servicios h3{
    color:var(--gold);
    border-bottom:2px solid var(--maroon);
    padding-bottom:8px;
}
/* ============================================
   lOGUIN
============================================ */
.main-login {
    padding: 30px;
    max-width: 900px;
    margin: 0 auto;
}

.login-section {
    display: flex;
    justify-content: center;
}

.login-form {
    background: #fff;
    padding: 24px;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    width: 100%;
    max-width: 500px;
}

.login-title {
    color: var(--maroon);
    margin-bottom: 20px;
    font-size: 28px;
    text-align: center;
}

.login-group {
    margin-bottom: 18px;
}

.login-label {
    font-weight: 600;
    display: block;
    margin-bottom: 6px;
    color: var(--text-dark);
}

.login-input,
.login-select {
    width: 100%;
    padding: 10px;
    border: 1px solid #ccc;
    border-radius: var(--radius);
    font-size: 14px;
    box-sizing: border-box;
}

.login-input:focus,
.login-select:focus {
    outline: none;
    border-color: var(--maroon);
}

.login-password-wrapper {
    position: relative;
    width: 100%;
}

.login-input--password {
    padding-right: 45px;
}

.login-toggle-icon {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    cursor: pointer;
    font-size: 18px;
    user-select: none;
}

.login-btn {
    width: 100%;
    background: var(--maroon);
    color: #fff;
    padding: 12px 20px;
    border: none;
    border-radius: var(--radius);
    cursor: pointer;
    font-size: 15px;
    font-weight: 600;
    transition: background 0.3s;
}

.login-btn:hover {
    background: #7a1829;
}

/* ================================
   BOTONES
================================ */
.form-buttons {
    display: flex;
    justify-content: flex-end;
    gap: 14px;
    margin-top: 10px;
}

button {
    background: var(--maroon);
    color: #fff;
    padding: 12px 20px;
    border: none;
    border-radius: var(--radius);
    cursor: pointer;
    font-size: 15px;
    font-weight: 600;
    transition: background 0.3s;
}

button:hover {
    background: #7a1829;
}

button[type="reset"] {
    background: #777;
}

button[type="reset"]:hover {
    background: #555;
}

/* ============================================
   IFRAME DIRECTORIO
============================================ */

.iframe-container iframe{
    width:100%;
    height:90vh;
    border:none;
    border-radius:8px;
    box-shadow:var(--shadow);
}

/* ============================================
   FOOTER
============================================ */

footer{
    background:#2b2b2b;
    color:#fff;
    padding:24px;
    margin-top:auto;
}

.footer-inner{
    display:flex;
    justify-content:space-between;
    flex-wrap:wrap;
    max-width:1200px;
    margin:auto;
    gap:20px;
}

.footer h3{
    color:var(--gold);
}

/* ============================================
   RESPONSIVE
============================================ */

@media (max-width:768px){

.news-container{
grid-template-columns:1fr 1fr;
}

}

@media (max-width:480px){

.news-container{
grid-template-columns:1fr;
}

.hero{
flex-direction:column;
text-align:center;
}

}