/*
Theme Name: FUMIZA — Manejo Integrado de Plagas
Theme URI: https://fumiza.com
Author: nickramen
Author URI: https://nickramen.com
Description: Tema personalizado para FUMIZA. Compatible con Elementor.
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: fumiza
*/


@import url('https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');

:root{
  /* ── Paleta corporativa FUMIZA ── */
  --fum-color-blanco:    #ffffff;
  --fum-color-negro:    #0b1714;   /* texto principal */
  --fum-color-gris:     #53555c;   /* texto secundario oscuro */
  --fum-color-verde:    #56a446;   /* accent primario */
  --fum-color-verde-hover: #459537;
  --fum-color-rojo:     #e31e24;   /* accent secundario */
  --fum-color-azul:     #163d7c;   /* accent terciario */

  /* ── Fondos blancos ── */
  --fum-color-bg:          #ffffff;
  --fum-color-bg-surface:  #f7f9f7;   /* verde muy pálido */
  --fum-color-bg-card:     #ffffff;
  --fum-color-bg-social:   #eef4ed;
  --fum-color-bg-input:    #f4f4f3;

  /* ── Accent = verde ── */
  --fum-color-accent:       var(--fum-color-verde);
  --fum-color-accent-hover: var(--fum-color-verde-hover);
  --fum-color-accent-text:  #ffffff;

  /* ── Texto ── */
  --fum-color-text-primary:   var(--fum-color-negro);
  --fum-color-text-secondary: var(--fum-color-gris);
  --fum-color-text-muted:     #8a8e8a;
  --fum-color-text-accent:    var(--fum-color-verde);

  /* ── Bordes ── */
  --fum-color-border:       rgba(60,60,56,0.12);
  --fum-color-border-input: rgba(60,60,56,0.18);

  /* ── Tipografía ── */
  --fum-font-family:"Inter", "Inter Placeholder", sans-serif;
  --fum-font-size-2xs:0.6875rem;
  --fum-font-size-xs:0.75rem;
  --fum-font-size-sm:0.875rem;
  --fum-font-size-base:1rem;
  --fum-font-size-md:1.0625rem;
  --fum-font-size-lg:1.125rem;
  --fum-font-size-xl:1.25rem;
  --fum-font-size-2xl:1.5rem;
  --fum-font-size-3xl:2rem;
  --fum-font-size-4xl:2.75rem;
  --fum-font-size-hero:clamp(2.2rem,5.5vw,3.8rem);
  --fum-font-weight-regular:400;
  --fum-font-weight-medium:500;
  --fum-font-weight-semibold:600;
  --fum-font-weight-bold:700;
  --fum-font-weight-extrabold:800;
  --fum-font-weight-black:900;
  --fum-line-height-tight:1.05;
  --fum-line-height-snug:1.2;
  --fum-line-height-normal:1.5;
  --fum-line-height-relaxed:1.7;
  --fum-letter-spacing-tight:-0.03em;
  --fum-letter-spacing-hero:-0.02em;

  /* ── Espaciado ── */
  --fum-space-1:0.25rem; --fum-space-2:0.5rem; --fum-space-3:0.75rem;
  --fum-space-4:1rem; --fum-space-5:1.25rem; --fum-space-6:1.5rem;
  --fum-space-7:1.75rem; --fum-space-8:2rem; --fum-space-10:2.5rem;
  --fum-space-12:3rem; --fum-space-14:3.5rem; --fum-space-16:4rem;
  --fum-space-20:5rem; --fum-space-24:6rem;
  --fum-max-width:1500px;
  --fum-gutter:var(--fum-space-10);
  --fum-navbar-height: 94px; /* 38px topbar + 56px navbar */
  --fum-radius-sm:0.375rem;
  --fum-radius-md:0.75rem;
  --fum-radius-lg:1rem;
  --fum-radius-pill:999px;
  --fum-transition-fast:0.15s ease;
  --fum-transition-base:0.25s ease;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--fum-font-family);background:var(--fum-color-bg);color:var(--fum-color-text-primary);line-height:var(--fum-line-height-normal);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{display:block;max-width:100%}
button{cursor:pointer;font-family:inherit;border:none;background:none}
i{display:flex;align-items:center;justify-content:center}

/* WHATSAPP */
.fum-wa{position:fixed;bottom:var(--fum-space-10);right:var(--fum-space-8);width:52px;height:52px;background:#25d366;border-radius:var(--fum-radius-md);display:flex;align-items:center;justify-content:center;z-index:998;transition:transform var(--fum-transition-base)}
.fum-wa:hover{transform:translateY(-3px)}
.fum-wa i{font-size:1.5rem;color:#fff}

/* OVERLAY */
.fum-overlay{position:fixed;inset:0;background:rgba(60,60,56,.5);z-index:998;opacity:0;visibility:hidden;transition:opacity var(--fum-transition-base),visibility var(--fum-transition-base)}
.fum-overlay.is-active{opacity:1;visibility:visible}

/* MOBILE MENU */
.fum-mobile-menu{position:fixed;top:0;right:0;bottom:0;width:min(300px,82vw);background:#fff;z-index:999;display:flex;flex-direction:column;padding:var(--fum-space-6);gap:2px;transform:translateX(100%);transition:transform .35s ease;overflow-y:auto;border-left:1px solid var(--fum-color-border);}
.fum-mobile-menu.is-active{transform:translateX(0)}
.fum-mobile-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--fum-space-6);padding-bottom:var(--fum-space-6);border-bottom:1px solid var(--fum-color-border)}
.fum-mobile-logo{display:flex;align-items:center;gap:var(--fum-space-2);font-size:var(--fum-font-size-base);font-weight:var(--fum-font-weight-black);color:var(--fum-color-negro);letter-spacing:.04em}
.fum-mobile-logo-icon{width:32px;height:32px;background:var(--fum-color-verde);border-radius:var(--fum-radius-sm);display:flex;align-items:center;justify-content:center}
.fum-mobile-logo-icon i{font-size:1rem;color:#fff}
.fum-mobile-logo img {display: flex; height: 40px;}
.fum-mobile-close{width:36px;height:36px;border:1px solid var(--fum-color-border);border-radius:var(--fum-radius-sm);display:flex;align-items:center;justify-content:center;color:var(--fum-color-text-secondary);transition:all var(--fum-transition-fast)}
.fum-mobile-close:hover{border-color:var(--fum-color-verde);color:var(--fum-color-verde)}
.fum-mobile-close i{font-size:var(--fum-font-size-base)}
.fum-mobile-link{display:flex;flex-direction:row; gap: 10px; padding:var(--fum-space-3) var(--fum-space-4);font-size:var(--fum-font-size-base);font-weight:var(--fum-font-weight-medium);color:var(--fum-color-text-secondary);border-radius:var(--fum-radius-sm);transition:color var(--fum-transition-fast),background var(--fum-transition-fast)}
.fum-mobile-link:hover,.fum-mobile-link.is-active{color:var(--fum-color-verde);background:rgba(86,164,70,.08)}
.fum-mobile-cta{margin-top:auto;padding-top:var(--fum-space-6);border-top:1px solid var(--fum-color-border)}
.fum-mobile-cta-btn{justify-content: center; display:flex; flex-direction: row; gap: 10px; width:100%;padding:var(--fum-space-3) var(--fum-space-6);background:var(--fum-color-verde);color:#fff;font-size:var(--fum-font-size-base);font-weight:var(--fum-font-weight-bold);border-radius:var(--fum-radius-sm);text-align:center;transition:background var(--fum-transition-fast)}
.fum-mobile-cta-btn:hover{background:var(--fum-color-verde-hover)}
body.menu-open{overflow:hidden}

/* ── TOPBAR ── */
.fum-topbar{
  background: var(--fum-color-azul);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.fum-topbar-inner{
  max-width: var(--fum-max-width);
  margin: 0 auto;
  padding: 0 var(--fum-gutter);
  height: 38px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--fum-space-6);
}
.fum-topbar-left{
  display: flex;
  align-items: center;
  gap: var(--fum-space-5);
}
.fum-topbar-item{
  display: flex;
  align-items: center;
  gap: var(--fum-space-2);
  font-size: var(--fum-font-size-xs);
  color: rgba(255,255,255,.55);
  transition: color var(--fum-transition-fast);
  white-space: nowrap;
}
.fum-topbar-item i{ font-size: .8rem; color: rgba(255,255,255,.55);}
.fum-topbar-item:hover{ color: rgba(255,255,255,.9); }
.fum-topbar-social{
  display: flex;
  align-items: center;
  gap: 2px;
}
.fum-topbar-social-btn{
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--fum-radius-sm);
  color: rgba(255,255,255,.45);
  transition: color var(--fum-transition-fast), background var(--fum-transition-fast);
}
.fum-topbar-social-btn i{ font-size: .95rem; }
.fum-topbar-social-btn:hover{
  color: #fff;
  background: rgba(255,255,255,.08);
}
@media(max-width: 768px){
  .fum-topbar-left .fum-topbar-item:not(:first-child){ display: none; }
  .fum-topbar-item{ font-size: var(--fum-font-size-2xs); }
}

/* NAVBAR */
.fum-navbar{background:#fff;z-index:100;border-bottom:1px solid var(--fum-color-border);}
.fum-navbar-inner{max-width:var(--fum-max-width);margin:0 auto;padding: 10px var(--fum-gutter);height:auto;display:flex;align-items:center;justify-content:space-between;gap:var(--fum-space-8)}
.fum-navbar-logo{display:flex;align-items:center;gap:var(--fum-space-2);flex-shrink:0}
.fum-navbar-logo img {height: 50px;}
@media (max-width: 480px){
    .fum-navbar-logo img{
        height:50px;
    }
}
.fum-navbar-logo-icon{width:34px;height:34px;background:var(--fum-color-verde);border-radius:var(--fum-radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fum-navbar-logo-icon i{font-size:1rem;color:#fff}
.fum-navbar-logo-text{display:flex;flex-direction:column;line-height:1}
.fum-navbar-logo-name{font-size:var(--fum-font-size-base);font-weight:var(--fum-font-weight-black);color:var(--fum-color-negro);letter-spacing:.04em}
.fum-navbar-logo-tagline{font-size:var(--fum-font-size-2xs);font-weight:var(--fum-font-weight-medium);color:var(--fum-color-text-muted);margin-top:2px}
.fum-navbar-nav{display:flex;align-items:center;gap:2px}
.fum-navbar-nav a{line-height: 1;}
.fum-navbar-link{display: flex; gap: 10px; font-size:var(--fum-font-size-md);font-weight:var(--fum-font-weight-medium);color:var(--fum-color-text-secondary);padding:var(--fum-space-2) var(--fum-space-3);border-radius:var(--fum-radius-sm);white-space:nowrap;transition:color var(--fum-transition-fast)}
.fum-navbar-link:hover,.fum-navbar-link.is-active{color:var(--fum-color-verde)}
.fum-navbar-link i {display: flex;}
.fum-navbar-sep{width:1px;height:18px;background:var(--fum-color-border);flex-shrink:0;margin:0 var(--fum-space-2)}
.fum-navbar-toggle{display:none;width:40px;height:40px;align-items:center;justify-content:center;color:var(--fum-color-negro);flex-shrink:0}
.fum-navbar-toggle i{font-size:1.25rem}

/* ── SECTION LABEL ── */
.fum-section-label{display:inline-flex;align-items:center;gap:var(--fum-space-2);font-size:var(--fum-font-size-xs);font-weight:var(--fum-font-weight-bold);color:var(--fum-color-verde);letter-spacing:.12em;text-transform:uppercase;margin-bottom:var(--fum-space-6)}
.fum-section-label::before,.fum-section-label::after{content:'◆';font-size:.5rem}



/* ── FOOTER ── */
.fum-footer{background:var(--fum-color-azul);border-top:1px solid rgba(255,255,255,.1)}
.fum-footer-inner{max-width:var(--fum-max-width);margin:0 auto;padding:0 var(--fum-gutter)}
.fum-footer-top{display:grid;grid-template-columns:1.4fr 0.8fr 0.5fr 1fr;gap:var(--fum-space-16);padding:var(--fum-space-14) 0}
.fum-footer-contact-list{display:flex;flex-direction:column;gap:var(--fum-space-6)}
.fum-footer-contact-item{display:flex;align-items:flex-start;gap:var(--fum-space-4)}
.fum-footer-contact-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--fum-color-verde);margin-top:2px}
.fum-footer-contact-icon i{font-size:.9rem}
.fum-footer-contact-value{font-size:var(--fum-font-size-sm);color:rgba(255,255,255,.75);line-height:var(--fum-line-height-relaxed)}
.fum-footer-hours{font-size:var(--fum-font-size-sm);font-weight:var(--fum-font-weight-semibold);color:rgba(255,255,255,.9);margin-bottom:2px}
.fum-footer-hours-line{font-size:var(--fum-font-size-sm);color:rgba(255,255,255,.65);line-height:var(--fum-line-height-relaxed)}
.fum-footer-col-title{font-size:var(--fum-font-size-lg);font-weight:var(--fum-font-weight-bold);color:var(--fum-color-verde);margin-bottom:var(--fum-space-5)}
.fum-footer-nav-list{display:flex;flex-direction:column;gap:var(--fum-space-3)}
.fum-footer-nav-list a{font-size:var(--fum-font-size-sm);color:rgba(255,255,255,.65);transition:color var(--fum-transition-fast)}
.fum-footer-nav-list a:hover{color:#fff}
.fum-footer-nav-list a.is-active{color:var(--fum-color-verde);text-decoration:underline;text-underline-offset:3px}
.fum-footer-divider{height:1px;background:rgba(255,255,255,.1)}
.fum-footer-social{padding:var(--fum-space-10) 0}
.fum-footer-social-label{text-align:center;font-size:var(--fum-font-size-base);font-weight:var(--fum-font-weight-semibold);color:var(--fum-color-verde);margin-bottom:var(--fum-space-5)}
.fum-footer-social-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--fum-space-3)}
.fum-footer-social-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--fum-space-2);padding:var(--fum-space-5) var(--fum-space-4);background:rgba(255,255,255,.07);border-radius:var(--fum-radius-md);color:rgba(255,255,255,.65);font-size:var(--fum-font-size-xs);font-weight:var(--fum-font-weight-medium);transition:color var(--fum-transition-fast),border-color var(--fum-transition-fast),background var(--fum-transition-fast)}
.fum-footer-social-btn i{font-size:1.25rem}
.fum-footer-social-btn:hover{color:#fff;border-color:rgba(86,164,70,.5);background:rgba(86,164,70,.12)}
.fum-footer-bottom{padding:var(--fum-space-5) 0;display:flex;align-items:center;justify-content:space-between;gap:var(--fum-space-4)}
.fum-footer-bottom-left{display:flex;align-items:center;gap:var(--fum-space-6)}
.fum-footer-bottom-link{font-size:var(--fum-font-size-xs);color:rgba(255,255,255,.5);transition:color var(--fum-transition-fast)}
.fum-footer-bottom-link:hover{color:#fff}
.fum-footer-bottom-right{font-size:var(--fum-font-size-xs);color:rgba(255,255,255,.5)}
.fum-footer-bottom-right a{color:var(--fum-color-verde) !important;transition:color var(--fum-transition-fast)}
.fum-footer-bottom-right a:hover{color:var(--fum-color-verde)}

/* ── RESPONSIVE GENERAL ── */
@media(max-width:1024px){
  .fum-footer-top{grid-template-columns:1fr 1fr;gap:var(--fum-space-10)}
}
@media(max-width:768px){
  :root{--fum-navbar-height:52px}
  .fum-navbar-nav{display:none}
  .fum-navbar-toggle{display:flex}
  .fum-footer-top{grid-template-columns:1fr}
  .fum-footer-top>*:first-child{grid-column:span 1}
  .fum-footer-social-grid{grid-template-columns:repeat(3,1fr);gap:var(--fum-space-2)}
  .fum-footer-bottom{flex-direction:column;align-items:flex-start;gap:var(--fum-space-3)}
}
@media(max-width:480px){
  .fum-footer-social-grid{grid-template-columns:repeat(2,1fr)}
  .fum-footer-social-btn:last-child{grid-column:span 2}
}