/*
Theme Name: Olium Recicla Galicia
Theme URI: https://oliumrecicla.com
Description: Tema WordPress profesional para empresa de reciclaje industrial. Compatible con Elementor.
Author: Olium Recicla Galicia
Version: 1.0.0
Requires at least: 6.2
Tested up to: 6.7
Requires PHP: 8.0
License: GPL-2.0-or-later
Text Domain: olium
*/

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=Inter:wght@300;400;500;600&display=swap');

/* ══════════════════════════════════════════
   TOKENS — Paleta industrial-verde
══════════════════════════════════════════ */
:root {
  --verde-950: #051a0a;
  --verde-900: #0a2e12;
  --verde-800: #0f4020;
  --verde-700: #155c2e;
  --verde-600: #1a7a3e;
  --verde-500: #22a052;
  --verde-400: #34c46a;
  --verde-200: #8ddcac;
  --verde-100: #c4f0d4;
  --verde-50:  #edfaf2;

  --gris-950: #0d0f0e;
  --gris-900: #161a17;
  --gris-800: #232926;
  --gris-700: #323c36;
  --gris-600: #4a564e;
  --gris-400: #7a8a80;
  --gris-200: #c2ccc5;
  --gris-100: #e5ebe7;
  --gris-50:  #f4f7f5;

  --amarillo:  #e8c84a;
  --amarillo-l:#f5e080;
  --blanco:    #ffffff;
  --negro:     #080c09;

  --font-display: 'Syne', system-ui, sans-serif;
  --font-body:    'Inter', system-ui, sans-serif;

  --r-sm:   6px;
  --r-md:   12px;
  --r-lg:   20px;
  --r-xl:   32px;
  --r-pill: 9999px;

  --shadow-sm:  0 2px 8px rgba(0,0,0,.08);
  --shadow-md:  0 8px 24px rgba(0,0,0,.12);
  --shadow-lg:  0 24px 56px rgba(0,0,0,.18);
  --shadow-verde: 0 8px 28px rgba(26,122,62,.3);

  --t: 0.25s cubic-bezier(0.4,0,0.2,1);
}

/* ══════════════════════════════════════════
   RESET
══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--gris-900);background:var(--blanco);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color var(--t)}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section-pad{padding:88px 0}

/* ══════════════════════════════════════════
   TIPOGRAFÍA
══════════════════════════════════════════ */
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.08;letter-spacing:-.02em;font-weight:800}
h1{font-size:clamp(2.6rem,5.5vw,4.8rem)}
h2{font-size:clamp(2rem,3.5vw,3.2rem)}
h3{font-size:clamp(1.2rem,2vw,1.6rem);font-weight:700}
p{font-size:1rem;line-height:1.7}

/* ══════════════════════════════════════════
   BOTONES
══════════════════════════════════════════ */
.ol-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 30px;border-radius:var(--r-pill);font-family:var(--font-body);font-size:.9rem;font-weight:600;letter-spacing:.02em;border:2px solid transparent;cursor:pointer;transition:transform var(--t),box-shadow var(--t),background var(--t),color var(--t),border-color var(--t);white-space:nowrap;text-decoration:none}
.ol-btn:hover{transform:translateY(-2px)}
.ol-btn--verde{background:var(--verde-600);color:var(--blanco);border-color:var(--verde-600)}
.ol-btn--verde:hover{background:var(--verde-500);box-shadow:var(--shadow-verde);color:var(--blanco)}
.ol-btn--amarillo{background:var(--amarillo);color:var(--negro);border-color:var(--amarillo)}
.ol-btn--amarillo:hover{background:var(--amarillo-l);box-shadow:0 8px 24px rgba(232,200,74,.4);color:var(--negro)}
.ol-btn--outline{background:transparent;color:var(--blanco);border-color:rgba(255,255,255,.45)}
.ol-btn--outline:hover{background:rgba(255,255,255,.1);border-color:var(--blanco)}
.ol-btn--dark{background:var(--gris-900);color:var(--blanco);border-color:var(--gris-900)}
.ol-btn--dark:hover{background:var(--gris-800);color:var(--blanco)}

/* ══════════════════════════════════════════
   TOPBAR
══════════════════════════════════════════ */
.ol-topbar{background:var(--verde-900);color:rgba(255,255,255,.7);font-size:.8rem;padding:9px 0}
.ol-topbar__inner{display:flex;justify-content:space-between;align-items:center;gap:16px}
.ol-topbar__left{display:flex;gap:20px;flex-wrap:wrap}
.ol-topbar__left span{display:flex;align-items:center;gap:6px}
.ol-topbar__right a{color:rgba(255,255,255,.5);margin-left:16px;transition:color var(--t)}
.ol-topbar__right a:hover{color:var(--verde-400)}

/* ══════════════════════════════════════════
   HEADER
══════════════════════════════════════════ */
.ol-header{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.97);backdrop-filter:blur(16px);border-bottom:1px solid var(--gris-100);transition:box-shadow var(--t)}
.ol-header.scrolled{box-shadow:var(--shadow-md)}
.ol-header__inner{display:flex;align-items:center;height:72px;gap:32px}

.ol-logo{display:flex;align-items:center;gap:12px;flex-shrink:0;text-decoration:none}
.ol-logo__icon{width:42px;height:42px;background:var(--verde-700);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.ol-logo__text strong{display:block;font-family:var(--font-display);font-size:1rem;font-weight:800;color:var(--verde-900);line-height:1.1;letter-spacing:-.02em}
.ol-logo__text span{font-size:.65rem;color:var(--gris-400);text-transform:uppercase;letter-spacing:.06em}

.ol-nav{flex:1}
.ol-nav__list{display:flex;gap:2px}
.ol-nav__link{display:block;padding:8px 14px;font-size:.88rem;font-weight:500;color:var(--gris-700);border-radius:var(--r-sm);transition:background var(--t),color var(--t)}
.ol-nav__link:hover{background:var(--verde-50);color:var(--verde-700)}

.ol-header__actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.ol-tel-btn{display:flex;align-items:center;gap:8px;padding:9px 18px;background:var(--verde-700);color:var(--blanco);border-radius:var(--r-pill);font-size:.875rem;font-weight:600;text-decoration:none;transition:background var(--t),transform var(--t)}
.ol-tel-btn:hover{background:var(--verde-600);transform:translateY(-1px);color:var(--blanco)}

.ol-hamburger{display:none;flex-direction:column;gap:5px;width:42px;height:42px;align-items:center;justify-content:center;border-radius:var(--r-md);background:transparent;border:none;cursor:pointer}
.ol-hamburger span{display:block;width:22px;height:2px;background:var(--gris-900);border-radius:2px}

/* ══════════════════════════════════════════
   HERO
══════════════════════════════════════════ */
.ol-hero{position:relative;min-height:90vh;display:flex;align-items:center;overflow:hidden;isolation:isolate}
.ol-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--verde-950) 0%,var(--gris-900) 50%,#1a3020 100%);z-index:-2}

/* Patrón hexagonal de fondo */
.ol-hero::after{
  content:'';position:absolute;inset:0;z-index:-1;opacity:.06;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='52' viewBox='0 0 60 52'%3E%3Cpolygon points='30,2 58,17 58,47 30,52 2,47 2,17' fill='none' stroke='%2322a052' stroke-width='1.5'/%3E%3C/svg%3E");
  background-size:60px 52px;
}

.ol-hero__glow{position:absolute;top:-20%;right:-10%;width:60%;height:140%;background:radial-gradient(ellipse,rgba(26,122,62,.2) 0%,transparent 60%);z-index:-1;pointer-events:none}

.ol-hero__content{position:relative;z-index:1;padding:120px 0 160px}
.ol-hero__inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}

.ol-hero__eyebrow{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;background:rgba(34,160,82,.18);border:1px solid rgba(34,160,82,.4);border-radius:var(--r-pill);color:var(--verde-400);font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:20px}
.ol-hero__eyebrow::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--verde-400);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}

.ol-hero__title{color:var(--blanco);margin-bottom:16px}
.ol-hero__title em{font-style:normal;color:var(--verde-400)}
.ol-hero__title .ol-accent{color:var(--amarillo)}

.ol-hero__sub{color:rgba(255,255,255,.7);font-size:1.05rem;line-height:1.75;margin-bottom:32px;max-width:500px}

.ol-hero__actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}

.ol-hero__stats{display:flex;gap:32px;flex-wrap:wrap}
.ol-stat{display:flex;flex-direction:column}
.ol-stat__num{font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--blanco);line-height:1}
.ol-stat__label{font-size:.75rem;color:rgba(255,255,255,.5);margin-top:2px}
.ol-stat__divider{width:1px;background:rgba(255,255,255,.12);align-self:stretch}

/* Panel derecho del hero */
.ol-hero__panel{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-xl);padding:32px;backdrop-filter:blur(8px)}
.ol-hero__panel-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--verde-400);text-transform:uppercase;letter-spacing:.08em;margin-bottom:20px;font-size:.8rem}
.ol-service-list{display:flex;flex-direction:column;gap:16px}
.ol-service-item{display:flex;align-items:flex-start;gap:14px;padding:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:var(--r-lg);transition:background var(--t),border-color var(--t)}
.ol-service-item:hover{background:rgba(34,160,82,.12);border-color:rgba(34,160,82,.3)}
.ol-service-item__icon{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.ol-service-item__icon--aceite{background:rgba(232,200,74,.15)}
.ol-service-item__icon--patatas{background:rgba(34,160,82,.15)}
.ol-service-item__icon--limpieza{background:rgba(30,130,220,.15)}
.ol-service-item__text strong{display:block;color:var(--blanco);font-size:.9rem;font-weight:600;margin-bottom:3px}
.ol-service-item__text span{color:rgba(255,255,255,.5);font-size:.8rem}

/* Ola inferior */
.ol-hero__wave{position:absolute;bottom:-1px;left:0;right:0;z-index:2;line-height:0}
.ol-hero__wave svg{width:100%;height:auto}

/* ══════════════════════════════════════════
   TRUST BAR
══════════════════════════════════════════ */
.ol-trust{background:var(--verde-800);padding:28px 0}
.ol-trust__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.ol-trust__item{display:flex;align-items:center;gap:14px}
.ol-trust__icon{font-size:1.6rem;flex-shrink:0}
.ol-trust__label strong{display:block;color:var(--blanco);font-size:.875rem;font-weight:700}
.ol-trust__label span{color:var(--verde-200);font-size:.75rem}

/* ══════════════════════════════════════════
   SERVICIOS
══════════════════════════════════════════ */
.ol-services{background:var(--gris-50)}
.ol-services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}

.ol-card{background:var(--blanco);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform var(--t),box-shadow var(--t)}
.ol-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}

.ol-card__header{padding:36px 32px 28px;position:relative;overflow:hidden}
.ol-card__header--aceite{background:linear-gradient(135deg,#1a2a0a,#2d4a10)}
.ol-card__header--patatas{background:linear-gradient(135deg,#1a2e1a,#0f4020)}
.ol-card__header--limpieza{background:linear-gradient(135deg,#0a1a2e,#102040)}

.ol-card__header::after{content:'';position:absolute;top:-30%;right:-20%;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none}

.ol-card__icon{font-size:3rem;margin-bottom:16px;position:relative;z-index:1}
.ol-card__title{font-family:var(--font-display);font-size:1.2rem;font-weight:800;color:var(--blanco);line-height:1.2;position:relative;z-index:1}

.ol-card__body{padding:28px 32px 32px}
.ol-card__desc{color:var(--gris-600);font-size:.9rem;line-height:1.65;margin-bottom:20px}
.ol-card__features{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.ol-card__feature{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--gris-700)}
.ol-card__feature::before{content:'✓';width:18px;height:18px;border-radius:50%;background:var(--verde-50);color:var(--verde-700);font-size:.65rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ol-card__cta{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;color:var(--verde-700);text-decoration:none;transition:gap var(--t),color var(--t)}
.ol-card__cta:hover{gap:12px;color:var(--verde-600)}

/* ══════════════════════════════════════════
   SOBRE NOSOTROS / QUIÉNES SOMOS
══════════════════════════════════════════ */
.ol-about{background:var(--blanco)}
.ol-about__inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.ol-about__badge{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;background:var(--verde-50);border:1px solid var(--verde-200);border-radius:var(--r-pill);color:var(--verde-700);font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px}
.ol-about__title{color:var(--verde-900);margin-bottom:16px}
.ol-about__text{color:var(--gris-600);margin-bottom:24px;line-height:1.75}
.ol-about__data{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:32px}
.ol-data-card{background:var(--gris-50);border-radius:var(--r-lg);padding:20px;border-left:3px solid var(--verde-500)}
.ol-data-card__num{font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--verde-700);line-height:1}
.ol-data-card__label{font-size:.8rem;color:var(--gris-600);margin-top:4px}

/* Mapa visual / Info visual */
.ol-about__visual{position:relative}
.ol-about__map-card{background:var(--verde-900);border-radius:var(--r-xl);padding:36px;color:var(--blanco)}
.ol-about__map-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--verde-400);margin-bottom:20px;text-transform:uppercase;letter-spacing:.06em;font-size:.8rem}
.ol-contact-info{display:flex;flex-direction:column;gap:16px}
.ol-ci{display:flex;align-items:flex-start;gap:14px}
.ol-ci__icon{width:36px;height:36px;background:rgba(34,160,82,.15);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem}
.ol-ci__text strong{display:block;color:var(--blanco);font-size:.875rem;margin-bottom:2px}
.ol-ci__text span,.ol-ci__text a{color:rgba(255,255,255,.55);font-size:.85rem;text-decoration:none;transition:color var(--t)}
.ol-ci__text a:hover{color:var(--verde-400)}

.ol-about__badge-float{position:absolute;top:-16px;right:-16px;background:var(--amarillo);color:var(--negro);padding:12px 20px;border-radius:var(--r-lg);font-family:var(--font-display);font-weight:800;font-size:.85rem;box-shadow:var(--shadow-md);text-align:center;line-height:1.3}

/* ══════════════════════════════════════════
   CTA CENTRAL
══════════════════════════════════════════ */
.ol-cta{background:linear-gradient(135deg,var(--verde-900),var(--gris-900));padding:88px 0;position:relative;overflow:hidden}
.ol-cta::before{content:'';position:absolute;inset:0;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='52' viewBox='0 0 60 52'%3E%3Cpolygon points='30,2 58,17 58,47 30,52 2,47 2,17' fill='none' stroke='%2322a052' stroke-width='1.5'/%3E%3C/svg%3E");background-size:60px 52px}
.ol-cta__inner{text-align:center;position:relative;z-index:1;max-width:680px;margin:0 auto}
.ol-cta h2{color:var(--blanco);margin-bottom:12px}
.ol-cta p{color:rgba(255,255,255,.65);font-size:1.1rem;margin-bottom:36px}
.ol-cta__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ══════════════════════════════════════════
   PROCESO
══════════════════════════════════════════ */
.ol-proceso{background:var(--gris-50)}
.ol-proceso__steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative}
.ol-proceso__steps::before{content:'';position:absolute;top:32px;left:12%;right:12%;height:2px;background:linear-gradient(to right,var(--verde-200),var(--verde-500),var(--verde-200));z-index:0}
.ol-paso{background:var(--blanco);border-radius:var(--r-xl);padding:32px 20px;text-align:center;position:relative;z-index:1;box-shadow:var(--shadow-sm);transition:transform var(--t),box-shadow var(--t)}
.ol-paso:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.ol-paso__num{width:44px;height:44px;border-radius:50%;background:var(--verde-700);color:var(--blanco);font-weight:800;font-size:.85rem;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-family:var(--font-display)}
.ol-paso__icon{font-size:2.2rem;margin-bottom:12px}
.ol-paso h3{font-size:1rem;color:var(--verde-900);margin-bottom:8px}
.ol-paso p{font-size:.82rem;color:var(--gris-600);line-height:1.55}

/* ══════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
.ol-footer{background:var(--verde-950)}
.ol-footer__top{padding:56px 0 40px;border-bottom:1px solid rgba(255,255,255,.07)}
.ol-footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px}
.ol-footer__brand-name{font-family:var(--font-display);font-size:1.3rem;font-weight:800;color:var(--blanco);letter-spacing:-.02em;margin-bottom:4px}
.ol-footer__brand-sub{font-size:.75rem;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px}
.ol-footer__brand-desc{color:rgba(255,255,255,.45);font-size:.85rem;line-height:1.65}
.ol-footer__heading{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:16px}
.ol-footer__links{display:flex;flex-direction:column;gap:9px}
.ol-footer__links a{color:rgba(255,255,255,.5);font-size:.875rem;transition:color var(--t),padding-left var(--t)}
.ol-footer__links a:hover{color:var(--verde-400);padding-left:4px}
.ol-footer__bottom{padding:18px 0;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.ol-footer__copy{color:rgba(255,255,255,.25);font-size:.78rem}
.ol-footer__legal{display:flex;gap:16px}
.ol-footer__legal a{color:rgba(255,255,255,.25);font-size:.78rem;transition:color var(--t)}
.ol-footer__legal a:hover{color:rgba(255,255,255,.6)}

/* Elementor compat */
.ol-elementor-page{min-height:60vh}

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media(max-width:1024px){
  .ol-services__grid{grid-template-columns:1fr 1fr}
  .ol-about__inner{grid-template-columns:1fr;gap:40px}
  .ol-hero__inner{grid-template-columns:1fr}
  .ol-hero__panel{display:none}
}
@media(max-width:768px){
  .section-pad{padding:60px 0}
  .ol-topbar{display:none}
  .ol-nav{display:none}
  .ol-hamburger{display:flex}
  .ol-trust__grid{grid-template-columns:1fr 1fr}
  .ol-services__grid{grid-template-columns:1fr}
  .ol-proceso__steps{grid-template-columns:1fr 1fr}
  .ol-proceso__steps::before{display:none}
  .ol-footer__grid{grid-template-columns:1fr}
  .ol-footer__bottom{flex-direction:column;text-align:center}
  .ol-cta__actions{flex-direction:column;align-items:center}
  .ol-hero__actions{flex-direction:column;align-items:flex-start}
  .ol-hero__stats{gap:20px}
}
@media(max-width:480px){
  .ol-trust__grid{grid-template-columns:1fr}
  .ol-about__data{grid-template-columns:1fr}
  .ol-proceso__steps{grid-template-columns:1fr}
}
