/*
 * Theme Name:   Hello Elementor Child – Prensa Insumos
 * Theme URI:    https://elementor.com/
 * Description:  Child theme de Hello Elementor para Prensa Insumos.
 *               Los estilos globales de marca están aquí; el contenido
 *               se edita 100 % desde Elementor.
 * Author:       Prensa Insumos
 * Template:     hello-elementor
 * Version:      1.0.0
 * Text Domain:  hello-elementor-child
*/

/* =============================================================
   DESIGN TOKENS – Variables de marca
   Estas variables se usan en toda la hoja de estilos.
   Si cambias un color aquí, se aplica en todo el sitio.
   ============================================================= */
:root {
  --pi-orange:         #E8640C;   /* Naranja principal – botones CTA   */
  --pi-orange-dark:    #C75509;   /* Naranja hover                      */
  --pi-green-dark:     #1B3B2A;   /* Verde oscuro – hero, footer, CTA   */
  --pi-green-mid:      #2D5A3D;   /* Verde medio – hover de fondo       */
  --pi-white:          #FFFFFF;
  --pi-gray-light:     #F5F5F5;   /* Fondo secciones alternas           */
  --pi-gray-mid:       #E0E0E0;   /* Bordes, separadores                */
  --pi-text-dark:      #1A1A1A;   /* Texto principal oscuro             */
  --pi-text-medium:    #555555;   /* Texto secundario                   */
  --pi-border-radius:  4px;
  --pi-transition:     0.25s ease;
}

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

body {
  font-family: 'Inter', 'Segoe UI', Arial, sans-serif;
  color: var(--pi-text-dark);
}

/* =============================================================
   TIPOGRAFÍA GLOBAL
   ============================================================= */
h1, h2, h3, h4, h5, h6 {
  font-weight: 700;
  line-height: 1.2;
}

/* =============================================================
   SECCIÓN: HERO
   Editable desde Elementor: texto, imagen, botones, espaciado.
   CSS aquí: overlay dark sobre imagen de fondo.
   ============================================================= */
.pi-section-hero {
  position: relative;
  background-color: var(--pi-green-dark); /* fallback si no hay imagen */
}

/* El overlay lo maneja Elementor con "Background Overlay" nativo.
   Esta clase es solo por si se necesita ajuste fino. */
.pi-section-hero .elementor-background-overlay {
  background-color: rgba(27, 59, 42, 0.72) !important;
}

/* =============================================================
   BOTONES – Clases aplicadas en campo CSS Class del botón
   ============================================================= */

/* Botón primario naranja */
.pi-btn-primary .elementor-button {
  background-color: var(--pi-orange) !important;
  color: var(--pi-white) !important;
  border: 2px solid var(--pi-orange) !important;
  border-radius: var(--pi-border-radius) !important;
  font-weight: 600;
  letter-spacing: 0.3px;
  transition: background-color var(--pi-transition), border-color var(--pi-transition);
}
.pi-btn-primary .elementor-button:hover {
  background-color: var(--pi-orange-dark) !important;
  border-color: var(--pi-orange-dark) !important;
}

/* Botón outline blanco (sobre fondo oscuro) */
.pi-btn-outline-white .elementor-button {
  background-color: transparent !important;
  color: var(--pi-white) !important;
  border: 2px solid var(--pi-white) !important;
  border-radius: var(--pi-border-radius) !important;
  font-weight: 600;
  transition: background-color var(--pi-transition), color var(--pi-transition);
}
.pi-btn-outline-white .elementor-button:hover {
  background-color: var(--pi-white) !important;
  color: var(--pi-green-dark) !important;
}

/* Botón outline naranja (sobre fondo claro) */
.pi-btn-outline-orange .elementor-button {
  background-color: transparent !important;
  color: var(--pi-orange) !important;
  border: 2px solid var(--pi-orange) !important;
  border-radius: var(--pi-border-radius) !important;
  font-weight: 600;
}
.pi-btn-outline-orange .elementor-button:hover {
  background-color: var(--pi-orange) !important;
  color: var(--pi-white) !important;
}

/* =============================================================
   SECCIONES – Fondos y espaciado
   Aplica estas clases CSS en el campo "CSS Classes" de la sección.
   ============================================================= */
.pi-section-dark {
  background-color: var(--pi-green-dark) !important;
}
.pi-section-light {
  background-color: var(--pi-gray-light) !important;
}
.pi-section-white {
  background-color: var(--pi-white) !important;
}

/* =============================================================
   BARRA DE BENEFICIOS
   Editable desde Elementor: Icon Box widget × 4 columnas.
   CSS aquí: bordes sutiles entre columnas.
   ============================================================= */
.pi-benefits-bar {
  border-top: 3px solid var(--pi-orange);
  box-shadow: 0 4px 20px rgba(0,0,0,0.08);
}

.pi-benefits-bar .elementor-icon-box-icon .elementor-icon {
  color: var(--pi-orange);
}

.pi-benefits-bar .elementor-col-25 + .elementor-col-25 {
  border-left: 1px solid var(--pi-gray-mid);
}

/* =============================================================
   SECCIÓN: QUIÉNES SOMOS
   100 % editable desde Elementor: Image + Heading + Text Editor.
   ============================================================= */
.pi-section-quienes-somos .elementor-widget-heading .elementor-heading-title {
  color: var(--pi-green-dark);
}

/* Acento naranja bajo el subtítulo */
.pi-heading-accent-left::after {
  content: '';
  display: block;
  width: 50px;
  height: 3px;
  background-color: var(--pi-orange);
  margin-top: 10px;
}

/* =============================================================
   SECCIÓN: INFRAESTRUCTURA Y LOGÍSTICA
   Fondo verde oscuro, texto blanco, icon boxes blancos.
   Editable desde Elementor: Icon Box widget.
   CSS aquí: sobrescrituras de color sobre fondo oscuro.
   ============================================================= */
.pi-section-infra {
  background-color: var(--pi-green-dark) !important;
}

.pi-section-infra .elementor-icon-box-icon .elementor-icon {
  color: var(--pi-white) !important;
  background-color: rgba(255,255,255,0.1);
  border-radius: 50%;
  padding: 14px;
}
.pi-section-infra .elementor-icon-box-title,
.pi-section-infra .elementor-icon-box-description {
  color: var(--pi-white) !important;
}
.pi-section-infra .elementor-heading-title {
  color: var(--pi-white) !important;
}

/* =============================================================
   SECCIÓN: PROVEEDORES / CLIENTES
   Editable desde Elementor: Heading + Text Editor con listas.
   ============================================================= */
.pi-section-proveedores .elementor-widget-text-editor ul {
  list-style: none;
  padding-left: 0;
  margin: 0;
}
.pi-section-proveedores .elementor-widget-text-editor ul li {
  padding: 5px 0 5px 22px;
  position: relative;
  color: var(--pi-text-medium);
  font-size: 15px;
}
.pi-section-proveedores .elementor-widget-text-editor ul li::before {
  content: '•';
  position: absolute;
  left: 0;
  color: var(--pi-orange);
  font-weight: 700;
  font-size: 18px;
  line-height: 1.2;
}

.pi-column-divider {
  border-left: 2px solid var(--pi-gray-mid);
}

/* =============================================================
   SECCIÓN: CTA FINAL
   Editable desde Elementor: texto y botón.
   CSS aquí: fondo oscuro + layout flex del contenido.
   ============================================================= */
.pi-section-cta {
  background-color: var(--pi-green-dark) !important;
}
.pi-section-cta .elementor-heading-title {
  color: var(--pi-white) !important;
}
.pi-section-cta .elementor-widget-text-editor p {
  color: rgba(255,255,255,0.85) !important;
}

/* CTA inline: texto + botón en la misma fila (desktop) */
.pi-cta-inline-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 20px;
}

/* =============================================================
   HEADER – Ajustes sobre Hello Elementor + Header Footer plugin
   Editable desde Elementor: logo, menú, botón Cotizar.
   CSS aquí: fondo blanco, sombra, logo size.
   ============================================================= */
.site-header,
.hfe-nav-menu__layout-horizontal {
  background-color: var(--pi-white) !important;
}

.hfe-nav-menu .hfe-nav-menu__toggle {
  color: var(--pi-text-dark);
}

/* Botón "Cotizar" en el header */
.pi-header-cta .elementor-button {
  background-color: var(--pi-orange) !important;
  color: var(--pi-white) !important;
  border-radius: var(--pi-border-radius) !important;
  padding: 10px 22px !important;
  font-weight: 600;
  font-size: 14px;
}

/* Subrayado activo del menú */
.hfe-nav-menu li.current-menu-item > a {
  color: var(--pi-orange) !important;
}

/* =============================================================
   FOOTER
   Editable desde Elementor (Header Footer plugin): texto, links.
   CSS aquí: fondo verde oscuro, texto blanco.
   ============================================================= */
.pi-section-footer {
  background-color: var(--pi-green-dark) !important;
}
.pi-section-footer,
.pi-section-footer p,
.pi-section-footer a,
.pi-section-footer .elementor-icon-box-description,
.pi-section-footer .elementor-icon-box-title {
  color: rgba(255,255,255,0.85) !important;
}
.pi-section-footer a:hover {
  color: var(--pi-orange) !important;
}
.pi-section-footer .elementor-icon-box-icon .elementor-icon {
  color: var(--pi-orange) !important;
}

/* =============================================================
   OCULTAR TÍTULO DE PÁGINA DEL TEMA
   El título ya se muestra dentro del hero de Elementor.
   ============================================================= */
.page-header,
.entry-header,
.site-main > article > .entry-header {
  display: none !important;
}

/* =============================================================
   RESPONSIVE – Mobile (≤767px)
   ============================================================= */
@media (max-width: 767px) {

  /* Hero headings */
  .pi-section-hero .elementor-heading-title {
    font-size: 28px !important;
    line-height: 1.2 !important;
  }

  /* CTA inline → stack vertical */
  .pi-cta-inline-row {
    flex-direction: column;
    text-align: center;
  }

  /* Divisor de columna → horizontal en mobile */
  .pi-column-divider {
    border-left: none;
    border-top: 2px solid var(--pi-gray-mid);
    padding-top: 30px;
    margin-top: 10px;
  }

  /* Benefits bar: quitar borde lateral */
  .pi-benefits-bar .elementor-col-25 + .elementor-col-25 {
    border-left: none;
    border-top: 1px solid var(--pi-gray-mid);
  }

  /* Footer columns stack */
  .pi-section-footer .elementor-column {
    width: 100% !important;
    margin-bottom: 32px;
  }
  .pi-section-footer .elementor-column:last-child {
    margin-bottom: 0;
  }

  /* Secciones: reducir padding horizontal */
  .elementor-section > .elementor-container {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  /* Inner page mini-hero: ajustar altura mínima */
  .pi-section-hero.elementor-section {
    min-height: 240px !important;
  }

  /* Galería de 3 imágenes en servicios: stack */
  .elementor-col-33 {
    width: 100% !important;
    margin-bottom: 16px;
  }

  /* Imagen en Nosotros: altura reducida en mobile */
  .elementor-widget-image img {
    height: auto !important;
    max-height: 260px;
    object-fit: cover;
    width: 100%;
  }

  /* Botón CTA en footer header: ancho completo */
  .pi-header-cta .elementor-button {
    width: 100%;
    text-align: center;
  }

  /* Menú hamburger visible en mobile */
  .hfe-nav-menu__layout-horizontal .hfe-nav-menu {
    display: none;
  }
}

/* =============================================================
   RESPONSIVE – Tablet (768px – 1024px)
   ============================================================= */
@media (max-width: 1024px) and (min-width: 768px) {

  /* Hero heading */
  .pi-section-hero .elementor-heading-title {
    font-size: 36px !important;
  }

  /* Footer: columnas al 50% en tablet */
  .pi-section-footer .elementor-column {
    width: 50% !important;
  }
  .pi-section-footer .elementor-column:nth-child(3) {
    width: 100% !important;
    margin-top: 24px;
  }
}


/* Contact-form */
.cs-contact-form {
  max-width: 720px;
  margin: 0 auto;
}

.cs-contact-form .cs-form-group {
  margin-bottom: 20px;
}

.cs-contact-form label {
  display: block;
  margin-bottom: 8px;
  font-size: 15px;
  font-weight: 600;
  color: #1f2937;
}

.cs-contact-form input[type="text"],
.cs-contact-form input[type="email"],
.cs-contact-form textarea {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid #d1d5db;
  border-radius: 12px;
  background: #ffffff;
  font-size: 15px;
  color: #111827;
  outline: none;
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
  box-sizing: border-box;
}

.cs-contact-form input[type="text"]:focus,
.cs-contact-form input[type="email"]:focus,
.cs-contact-form textarea:focus {
  border-color: #2563eb;
  box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.12);
}

.cs-contact-form textarea {
  min-height: 150px;
  resize: vertical;
}

.cs-contact-form .cs-form-submit {
  margin-top: 10px;
}

.cs-contact-form input[type="submit"] {
  display: inline-block;
  padding: 14px 28px;
  border: none;
  border-radius: 999px;
  background: #111827;
  color: #ffffff;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  transition: transform 0.2s ease, opacity 0.2s ease, background 0.2s ease;
}

.cs-contact-form input[type="submit"]:hover {
  opacity: 0.95;
  transform: translateY(-1px);
}

.cs-contact-form input[type="submit"]:active {
  transform: translateY(0);
}

.cs-contact-form .wpcf7-not-valid-tip {
  margin-top: 6px;
  font-size: 13px;
}

.cs-contact-form .wpcf7-response-output {
  margin: 20px 0 0;
  padding: 12px 16px;
  border-radius: 10px;
  font-size: 14px;
}

/*Buttons*/
body [type=button], body [type=submit], body button, body .cs-contact-form input[type="submit"]{
    border: 1px solid #E8640C;
    color: #E8640C;
    background: transparent;
    border-radius: 5px;
}

body [type=button]:hover, body [type=submit]:hover, body button:hover, body .cs-contact-form input[type="submit"]:hover{

    background: #1B3B2A;
    color: white;
    border: none;
}