/* ===================================================
   STYLE.CSS - LIMPIO y CONFORME A DISEÑO ACTUAL
   Mantiene apariencia original, sin reglas duplicadas
   Secciones ordenadas: Global / Header / Banners / About /
   Products / Clients / CTA / Contact / Services / Footer / Responsive
=================================================== */

/* -----------------------
   RESET Y GLOBAL
------------------------*/
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family: "Roboto", sans-serif;
  background:#fff;
  color:#222;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block}
.container{width:92%;max-width:1200px;margin:0 auto}

/* -----------------------
   VARIABLES (colores)
------------------------*/
:root{
  --red:#8F191D;
  --black:#000;
  --white:#fff;
  --muted:#f2f2f2;
  --shadow: 0 6px 25px rgba(0,0,0,0.12);
}

/* ===================================================
   HEADER (3 columnas)
=================================================== */
.header{
  width:100%;
  background:#fff;
  border-bottom:1px solid #e6e6e6;
  position:relative;
  z-index:10;
}
.header-container{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:18px;
  padding:10px 16px;
}
.logo-col{display:flex;align-items:center;justify-content:flex-start}
.header-logo{height:200px;margin:0;padding:0}
.title-col{display:flex;flex-direction:column;justify-content:center;margin-left:8px}
.title-main{font-family:"Poppins",sans-serif;font-size:28px;font-weight:700;color:var(--red)}
.title-sub{font-family:"Poppins",sans-serif;font-size:15px;color:#444;margin-top:4px}
.right-col{display:flex;flex-direction:column;align-items:flex-end;gap:8px;padding-right:8px}

/* redes circulares (header/footer) */
.header-social{display:flex;gap:10px}
.header-social a{
  width:35px;height:35px;border-radius:50%;border:2px solid var(--red);
  display:flex;align-items:center;justify-content:center;color:var(--red);background:var(--white);font-size:16px;
  transition:all .22s ease;
}
.header-social a:hover{background:var(--red);color:var(--white);transform:scale(1.06)}

/* menu botones */
.header-menu ul{display:flex;gap:8px;list-style:none;margin:0;padding:0}
.header-menu a,
.public-nav ul li a{
  font-family:"Poppins";font-weight:600;font-size:14px;
  background:var(--red);color:var(--white);padding:8px 14px;border-radius:8px;border:2px solid var(--red);
  text-decoration:none;transition:all .22s ease;white-space:nowrap;
}
.header-menu a:hover,
.public-nav ul li a:hover{background:var(--white);color:var(--red)}

/* small header spacing utility */
.header-spacing{width:100%;height:40px}

/* ===================================================
   BANNERS (tarjeta grande)
=================================================== */
.banner-card-section{padding:36px 0;background:var(--muted)}
.banner-card{background:var(--white);border-radius:8px;box-shadow:var(--shadow);overflow:hidden}
.banner-slider{position:relative;width:100%;height:400px}
.banner-slide{position:absolute;inset:0;opacity:0;transition:opacity .4s ease-in-out}
.banner-slide.active{opacity:1}
.banner-slide img{width:100%;height:450px;object-fit:cover;display:block}

/* ===================================================
   QUIÉNES SOMOS
=================================================== */
.about-section{background:var(--white);padding:60px 0}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.section-title{font-size:30px;font-family:"Poppins",sans-serif;color:var(--red);margin-bottom:16px}
.about-right img{width:100%;border-radius:12px;box-shadow:0 8px 20px rgba(0,0,0,0.08)}
.about-left p{margin-bottom:16px;color:#444}

/* ===================================================
   PRODUCTOS
=================================================== */
.products-section{background:var(--muted);padding:60px 0}
.products-grid{margin-top:30px;display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.product-card{
  background:var(--white);padding:28px 22px;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,0.06);
  text-align:center;transition:transform .25s ease,background .25s ease;color:#222;border:2px solid transparent;
}
.product-icon{font-size:42px;color:var(--red);transition:.25s}
.product-card:hover{background:var(--red);color:#fff;transform:translateY(-6px);border-color:#741317}
.product-card:hover .product-icon{color:#fff;transform:scale(1.05)}

/* ===================================================
   CTA FRANJA CORPORATIVA
=================================================== */
.cta-banner{background:var(--red);padding:22px 0;color:var(--white)}
.cta-flex{display:flex;align-items:center;justify-content:space-between}
.cta-text{font-size:22px;font-family:"Poppins";font-weight:600;display:flex;align-items:center;gap:10px}
.cta-button{background:var(--white);color:var(--red);padding:10px 24px;border-radius:6px;font-weight:600;text-decoration:none;border:2px solid var(--white)}

/* ===================================================
   CLIENTES - SLIDER
=================================================== */
.clients-slider{width:100%;overflow:hidden;padding:20px 0;background:transparent}
.clients-track{display:flex;gap:50px;animation:scrollClients 28s linear infinite;align-items:center}
@keyframes scrollClients{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.client-logo{min-width:240px;max-width:240px;height:140px;background:#fff;border-radius:12px;box-shadow:0 6px 14px rgba(0,0,0,0.12);display:flex;align-items:center;justify-content:center;padding:20px}
.client-logo img{max-height:100px;object-fit:contain;filter:grayscale(30%);transition:.2s}

/* ===================================================
   TOP CONTACT STRIP
=================================================== */
.top-contact-strip{background:var(--red);padding:40px 0;color:var(--white);font-family:"Poppins";font-size:16px}
.contact-strip-flex{display:flex;justify-content:flex-end;gap:60px;align-items:center}
.contact-item{display:flex;gap:10px;align-items:center}
.contact-item .text{display:flex;flex-direction:column;text-align:right;line-height:1.1}
.contact-item .line1{font-weight:600;font-size:16px}
.contact-item .line2{font-size:15px;opacity:.95}

/* ===================================================
   CONTACTO PAGE
=================================================== */
.contact-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:35px;margin:60px auto}
.contact-subtitle{color:var(--red);font-family:"Poppins";font-size:22px;margin-bottom:15px}
.contact-form input,.contact-form textarea{width:100%;padding:12px;border:2px solid #ccc;border-radius:6px;font-family:"Roboto"}
.btn-submit{background:var(--red);color:var(--white);padding:12px 25px;border-radius:6px;border:none;cursor:pointer}

/* ===================================================
   SERVICES PAGE
=================================================== */
.page-title{text-align:center;margin:40px 0 10px}
.page-title h1{font-size:32px;color:var(--red);font-family:"Poppins"}
.services-page{display:grid;grid-template-columns:1fr 1fr;gap:25px;margin-bottom:50px}
.service-block{background:#fff;border:1px solid #ddd;padding:25px;border-radius:10px;transition:.3s}
.service-block:hover{background:var(--red);color:#fff;transform:scale(1.02)}
.service-icon{color:var(--red);font-size:40px;margin-bottom:15px}

/* ===================================================
   FOOTER
=================================================== */
.site-footer{background:var(--red);color:var(--white);margin-top:60px;padding-top:50px}
.footer-inner{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.footer-col h3{font-size:20px;font-family:"Poppins";margin-bottom:8px}
.footer-hr{width:100%;height:1px;background:rgba(255,255,255,0.35);margin-bottom:16px}
.footer-socials{display:flex;gap:12px;margin-top:12px}
.footer-socials a{width:40px;height:40px;border-radius:50%;border:2px solid white;display:flex;align-items:center;justify-content:center;color:white;transition:.25s}
.footer-socials a:hover{background:#fff;color:var(--red);transform:translateY(-4px)}
.footer-bottom{background:rgba(0,0,0,0.18);margin-top:30px;padding:12px 0}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center}

/* ===================================================
   HEADER VARIANTS & UTILITIES
=================================================== */
/* older header layout variant (if present) */
.public-header{width:100%;background:#fff;padding:15px 0;border-bottom:3px solid var(--red)}
.header-columns{display:grid;grid-template-columns:200px auto auto;align-items:center;gap:20px}
.col-logo img.logo{width:200px}
.col-titles{display:flex;flex-direction:column;margin-left:-10px}
.public-nav ul{display:flex;gap:10px;margin:0;padding:0}

/* small site utilities */
body::before { height: 0; }

/* ===================================================
   PORTAL (LOGIN + DASHBOARD) - estilos mínimos públicos
   (separar más en assets/css/portal.css)
=================================================== */

.login-area{width:100%;display:flex;justify-content:center;padding:40px 15px;background:#f7f7f7}
.login-card{width:420px;background:#fff;border-radius:18px;padding:40px 35px;border-top:8px solid var(--red);box-shadow:0 6px 25px rgba(0,0,0,0.20);text-align:center}
.login-icon{width:90px;height:90px;background:var(--red);color:#fff;border-radius:50%;margin:0 auto 18px;display:flex;align-items:center;justify-content:center;font-size:38px;animation:pulseLogin 1.6s infinite}
@keyframes pulseLogin{0%{transform:scale(1)}50%{transform:scale(1.1)}100%{transform:scale(1)}}
.login-title{font-size:26px;font-weight:700;color:var(--red)}
.login-subtitle{font-size:14px;color:#555;margin-top:4px;margin-bottom:25px}
.login-field{position:relative;margin-bottom:22px}
.login-field i{position:absolute;top:12px;left:12px;color:var(--red)}
.login-field input{width:100%;padding:12px 15px 12px 42px;border-radius:8px;border:1px solid #cfcfcf;font-size:15px;font-family:'Roboto',sans-serif}
.btn-login{width:100%;background:var(--red);color:#fff;border:none;padding:13px;font-size:17px;border-radius:8px;cursor:pointer;font-weight:600}
.btn-login:hover{background:#fff;color:var(--red);border:2px solid var(--red)}
.login-error{background:var(--red);color:#fff;padding:10px;margin-bottom:18px;border-radius:6px;font-size:14px;text-align:center}

/* ===================================================
   RESPONSIVE
=================================================== */
@media(max-width:1100px){
  .clients-track{gap:30px}
  .client-logo{min-width:200px;max-width:200px;height:120px}
  .banner-slider{height:460px}
  .banner-slide img{height:460px;object-fit:cover}
}
@media(max-width:900px){
  .about-grid{grid-template-columns:1fr}
  .products-grid{grid-template-columns:repeat(2,1fr)}
  .footer-inner{grid-template-columns:1fr}
  .cta-flex{flex-direction:column;gap:12px;text-align:center}
  .banner-slider{height:380px}
  .banner-slide img{height:380px}
  .client-logo{min-width:160px;max-width:160px;height:100px}
}
@media(max-width:600px){
  .products-grid{grid-template-columns:1fr}
  .banner-slider{height:300px}
  .banner-slide img{height:300px}
  .client-logo{min-width:140px;max-width:140px;height:90px}
  .footer-bottom-inner{flex-direction:column;text-align:center;gap:6px}
}

/* CENTRAR TITULOS PRINCIPALES DE SECCION */
.section-title,
.section-main-title {
    text-align: center !important;
    width: 100%;
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.section-subtitle,
.section-main-subtitle {
    text-align: center !important;
    width: 100%;
    display: block;
    margin-left: auto;
    margin-right: auto;
}
/* END OF FILE */
