:root{
  --green:#0F3D2E;
  --sage:#7FAE9E;
  --beige:#E6DCCB;
  --ink:#1C1C1C;
  --paper:#F5F5F2;
  --copper:#9C7A3C;
  --copper-rgb:156,122,60;

  --radius:18px;
  --shadow: 0 12px 34px rgba(28,28,28,.08);
  --shadow2: 0 18px 46px rgba(15,61,46,.14);
  --line: rgba(15,61,46,.14);
  --max: 1120px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--ink);
  letter-spacing:.2px;

  /* Más color sin “fondo verde plano” */
  background:
    radial-gradient(1100px 700px at 10% 0%, rgba(15,61,46,.20), transparent 60%),
    radial-gradient(900px 600px at 92% 10%, rgba(127,174,158,.34), transparent 58%),
    radial-gradient(720px 520px at 48% 105%, rgba(var(--copper-rgb),.18), transparent 62%),
    linear-gradient(180deg, rgba(15,61,46,.12) 0%, rgba(245,245,242,1) 56%),
    var(--paper);
}

a{ color:inherit; text-decoration:none; }
.wrap{ max-width:var(--max); margin:0 auto; padding:0 20px; }

/* ===== Header (verdoso premium + cápsula clara para que el logo verde se vea) ===== */
.top{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(180%) blur(14px);
  background: linear-gradient(180deg, rgba(15,61,46,.30), rgba(245,245,242,.74));
  border-bottom:1px solid rgba(15,61,46,.18);
}
.top::before{
  content:"";
  position:absolute; left:0; right:0; top:0; height:3px;
  background: linear-gradient(90deg,
    rgba(15,61,46,0),
    rgba(15,61,46,.78),
    rgba(var(--copper-rgb),.82),
    rgba(15,61,46,.42),
    rgba(15,61,46,0)
  );
  pointer-events:none;
}
.top-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px;
  position:relative;

  margin:10px 0;
  padding:12px 14px;
  border-radius:999px;
  background: rgba(245,245,242,.86);
  border:1px solid rgba(15,61,46,.16);
  box-shadow: var(--shadow2);
}

.brand{ display:flex; align-items:center; gap:12px; min-width:260px; }

/* LOGO wordmark grande (≈1.5x) */
.logo-slot{ height:74px; width:auto; display:flex; align-items:center; padding:0; }
.logo-img{
  height:74px;
  width:auto;
  object-fit:contain;
  display:block;
  filter: drop-shadow(0 14px 24px rgba(15,61,46,.18));
}

.brand-text{ display:flex; flex-direction:column; line-height:1.1; }
.brand-text strong{
  font-weight:900;
  letter-spacing:1.0px;
  font-size:13px;
  color: var(--green);
}
.brand-text span{ font-size:12px; color: rgba(28,28,28,.70); }

nav{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; justify-content:center; }
.navlink{
  font-size:13px;
  color: rgba(28,28,28,.82);
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(15,61,46,.12);
  background: rgba(127,174,158,.12);
  transition: background .2s ease, border-color .2s ease, transform .08s ease;
}
.navlink:hover{
  background: rgba(127,174,158,.22);
  border-color: rgba(var(--copper-rgb),.28);
}
.navlink:active{ transform: translateY(1px); }

.actions{ display:flex; align-items:center; gap:10px; min-width:260px; justify-content:flex-end; }

.pill{
  border:1px solid rgba(15,61,46,.16);
  background: rgba(245,245,242,.80);
  padding:8px 12px;
  border-radius:999px;
  font-size:12px;
  display:inline-flex; gap:8px; align-items:center;
  cursor:pointer;
  transition: transform .08s ease, background .2s ease;
}
.pill:hover{ background: rgba(127,174,158,.16); }
.pill:active{ transform: translateY(1px); }

.btn{
  border:none;
  background: linear-gradient(180deg, rgba(15,61,46,1), rgba(15,61,46,.92));
  color: var(--paper);
  padding:10px 14px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  cursor:pointer;
  box-shadow: var(--shadow2);
  transition: transform .08s ease, filter .2s ease;
  display:inline-flex; align-items:center; gap:8px;
}
.btn:hover{ filter: brightness(1.06); }
.btn:active{ transform: translateY(1px); }

.btn-copper{
  background: linear-gradient(180deg,
    rgba(var(--copper-rgb), 1) 0%,
    rgba(var(--copper-rgb), .88) 100%
  );
  color: var(--paper);
  border: 1px solid rgba(var(--copper-rgb), .55);
  box-shadow: 0 16px 34px rgba(var(--copper-rgb), .18);
  filter: saturate(1.05) contrast(1.02);
}

.btn-ghost{
  background: transparent;
  color: var(--green);
  border:1px solid rgba(15,61,46,.22);
  box-shadow:none;
}
.btn-ghost:hover{ background: rgba(127,174,158,.16); }

/* ===== Cards / UI ===== */
.card{
  border:1px solid rgba(15,61,46,.14);
  background:
    radial-gradient(640px 380px at 18% 18%, rgba(127,174,158,.14), transparent 62%),
    linear-gradient(180deg, rgba(245,245,242,.86), rgba(230,220,203,.16));
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(700px 420px at 90% 0%, rgba(var(--copper-rgb),.14), transparent 60%);
  pointer-events:none;
  opacity:.9;
}
.card > *{ position:relative; }

.kicker{
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 12px;
  border-radius:999px;
  background: rgba(127,174,158,.24);
  border:1px solid rgba(15,61,46,.16);
  font-size:12px;
  color: rgba(15,61,46,.98);
}
.dot{
  width:8px; height:8px; border-radius:999px;
  background: var(--copper);
  box-shadow: 0 0 0 4px rgba(var(--copper-rgb),.20);
}

h1{
  margin:0;
  font-size:44px;
  letter-spacing:-.9px;
  line-height:1.05;
  color: var(--green);
}
.sub{
  margin:12px 0 18px;
  font-size:15px;
  color: rgba(28,28,28,.72);
  max-width: 64ch;
}

section{ padding:38px 0; }

.sec-head{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:18px; margin-bottom:14px;
}
.sec-head h2{
  margin:0;
  font-size:20px;
  letter-spacing:-.3px;
  color: var(--green);
  position:relative;
  padding-bottom:8px;
}
.sec-head h2::after{
  content:"";
  position:absolute; left:0; bottom:0;
  width:86px; height:2px;
  border-radius:999px;
  background: linear-gradient(90deg, rgba(var(--copper-rgb),.95), rgba(15,61,46,.72));
}
.sec-head p{
  margin:0;
  font-size:13px;
  color: rgba(28,28,28,.68);
  max-width: 62ch;
}

.grid-3{ display:grid; grid-template-columns: repeat(3, 1fr); gap:12px; }
.tile{
  padding:16px;
  border-radius: var(--radius);
  border:1px solid rgba(15,61,46,.14);
  background:
    linear-gradient(180deg, rgba(245,245,242,.86), rgba(127,174,158,.10));
  box-shadow: 0 10px 26px rgba(28,28,28,.05);
}
.tile h3{ margin:0 0 8px; font-size:14px; color: var(--green); }
.tile p{ margin:0; font-size:13px; color: rgba(28,28,28,.70); line-height:1.45; }

.hr{ height:1px; background: rgba(15,61,46,.14); margin:10px 0 0; }

footer{
  padding:26px 0 34px;
  color: rgba(28,28,28,.62);
  font-size:12px;
}

/* ===== Estaciones / mapa ===== */
.mapwrap{
  margin-top:12px;
  border-radius: var(--radius);
  overflow:hidden;
  border:1px solid rgba(15,61,46,.14);
  background: rgba(245,245,242,.92);
}
iframe{ width:100%; height:280px; border:0; display:block; }

/* ===== CARGA (demo PayU + sesión) ===== */
.two-col{ display:grid; grid-template-columns: 1.05fr .95fr; gap:12px; }
.panel{ padding:18px; }

.badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(var(--copper-rgb),.24);
  background: rgba(var(--copper-rgb),.12);
  color: rgba(28,28,28,.78);
  font-size:12px;
}

.station-grid{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
.station{
  padding:16px;
  border-radius: var(--radius);
  border:1px solid rgba(15,61,46,.14);
  background: rgba(245,245,242,.86);
}
.station h3{ margin:0; font-size:15px; color: var(--green); }
.meta{ font-size:12px; color: rgba(28,28,28,.68); margin-top:6px; line-height:1.35; }
.tag{
  font-size:11px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(15,61,46,.18);
  background: rgba(127,174,158,.18);
  color: rgba(15,61,46,.95);
  white-space:nowrap;
}

.chargers{ margin-top:12px; display:flex; flex-direction:column; gap:8px; }
.charger{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:10px 12px;
  border-radius: 14px;
  border:1px solid rgba(15,61,46,.14);
  background: rgba(245,245,242,.94);
  cursor:pointer;
  transition: transform .08s ease, background .2s ease, border-color .2s ease;
}
.charger:hover{
  background: rgba(127,174,158,.18);
  border-color: rgba(var(--copper-rgb),.30);
}
.charger:active{ transform: translateY(1px); }
.power{ font-weight:900; color: var(--green); font-size:12px; }
.small{ font-size:12px; color: rgba(28,28,28,.66); }
.pill-status{
  font-size:11px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(var(--copper-rgb),.22);
  background: rgba(var(--copper-rgb),.10);
  color: rgba(28,28,28,.75);
  white-space:nowrap;
}
.selected{
  border-color: rgba(var(--copper-rgb),.45) !important;
  box-shadow: 0 14px 34px rgba(var(--copper-rgb),.12);
}

.control{
  display:flex; flex-direction:column; gap:10px;
  padding:14px;
  border-radius: var(--radius);
  border:1px solid rgba(15,61,46,.14);
  background:
    radial-gradient(520px 260px at 10% 0%, rgba(127,174,158,.18), transparent 70%),
    rgba(245,245,242,.90);
}
label{ font-size:12px; color: rgba(28,28,28,.66); }
.range{ width:100%; }

.kpi-row{ display:grid; grid-template-columns: 1fr 1fr; gap:10px; }
.kpi{
  padding:12px;
  border-radius: 16px;
  border:1px solid rgba(15,61,46,.14);
  background: rgba(245,245,242,.94);
}
.kpi .t{ font-size:12px; color: rgba(28,28,28,.62); }
.kpi .v{ font-size:16px; font-weight:900; color: var(--green); margin-top:6px; }
.kpi .s{ font-size:11px; color: rgba(28,28,28,.62); margin-top:6px; line-height:1.35; }

.progress{
  height:10px;
  border-radius:999px;
  background: rgba(15,61,46,.12);
  overflow:hidden;
  border:1px solid rgba(15,61,46,.12);
}
.progress > div{
  height:100%;
  width:0%;
  background: linear-gradient(90deg, rgba(var(--copper-rgb),.96), rgba(15,61,46,.92));
  border-radius:999px;
  transition: width .25s ease;
}

.toast{
  position: fixed;
  left: 50%;
  bottom: 22px;
  transform: translateX(-50%);
  background: rgba(28,28,28,.92);
  color: var(--paper);
  padding: 10px 12px;
  border-radius: 999px;
  font-size: 12px;
  opacity: 0;
  pointer-events:none;
  transition: opacity .2s ease, transform .2s ease;
  z-index: 999;
}
.toast.show{
  opacity: 1;
  transform: translateX(-50%) translateY(-2px);
}

@media (max-width: 980px){
  h1{ font-size:36px; }
  .grid-3{ grid-template-columns:1fr; }
  .two-col{ grid-template-columns:1fr; }
  .station-grid{ grid-template-columns:1fr; }
  .logo-slot{ height:58px; }
  .logo-img{ height:58px; }
}
/* =========================
   MOBILE HEADER FIX (EON)
   ========================= */
@media (max-width: 980px){
  /* header menos alto */
  .top-inner{
    margin: 6px 0;
    padding: 8px 10px;
    gap: 10px;
    border-radius: 16px;   /* ya no cápsula gigante */
  }

  /* logo más pequeño */
  .brand{ min-width: 0; }
  .logo-slot{ height: 44px; }
  .logo-img{ height: 44px; }

  /* oculta el tagline para ahorrar altura */
  .brand-text span{ display:none; }

  /* NAV: que no “wrapee” y se coma la pantalla */
  nav{
    gap: 8px;
    flex-wrap: nowrap;
    overflow-x: auto;      /* si no cabe, se puede deslizar horizontal */
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  nav::-webkit-scrollbar{ display:none; }

  .navlink{
    padding: 7px 10px;
    font-size: 12px;
    white-space: nowrap;
  }

  /* botones más compactos */
  .actions{ min-width: 0; gap: 8px; }
  .btn{ padding: 8px 10px; font-size: 12px; }
  .pill{ padding: 7px 10px; font-size: 12px; }

  /* opcional: esconder botones extra en móvil (deja solo 1 CTA)
     si quieres que el header sea ultrafino, descomenta estas 2 líneas:
  */
  /* .actions .pill{ display:none; } */
  /* .actions .btn-ghost{ display:none; } */
}
/* =========================
   MOBILE: header usable + no overlap
   ========================= */
@media (max-width: 980px){

  /* Header más delgado */
  .top-inner{
    margin: 6px 0;
    padding: 8px 10px;
    border-radius: 16px;
    gap: 8px;
  }

  /* Logo compacto */
  .logo-slot{ height: 42px; }
  .logo-img{ height: 42px; }
  .brand-text span{ display:none; } /* quita tagline en móvil */

  /* Nav: en móvil NO debe apilarse ni ocupar 2 filas */
  nav{
    display:none;  /* <- solución premium y limpia: escondemos el menú */
  }

  /* Acciones: deja solo lo esencial */
  .actions{
    min-width: 0;
    gap: 8px;
  }
  #langToggle{ display:none; } /* opcional: quita ES/EN en móvil para ganar espacio */
  .btn{ padding: 8px 10px; font-size: 12px; }

  /* Asegura que el contenido tenga espacio y no quede debajo del header sticky */
  main.wrap{ padding-top: 10px; }
}

/* =========================
   MOBILE MENU (hamburger)
   ========================= */
.mobile-menu-btn{ display:none; }
.mobile-drawer, .mobile-overlay{ display:none; }

@media (max-width: 980px){

  /* Header compacto */
  .top-inner{
    margin: 6px 0;
    padding: 8px 10px;
    border-radius: 16px;
    gap: 8px;
  }
  .logo-slot{ height: 42px; }
  .logo-img{ height: 42px; }
  .brand-text span{ display:none; }

  /* Esconde nav en móvil (para que NO se amontone) */
  nav{ display:none !important; }

  /* Botón menú visible */
  .mobile-menu-btn{
    display:inline-flex;
    align-items:center;
    gap:8px;
    white-space:nowrap;
  }

  /* Overlay + Drawer */
  .mobile-overlay{
    display:block;
    position: fixed;
    inset: 0;
    background: rgba(28,28,28,.32);
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s ease;
    z-index: 999;
  }

  .mobile-drawer{
    display:block;
    position: fixed;
    left: 12px;
    right: 12px;
    top: 76px; /* debajo del header */
    background: rgba(245,245,242,.96);
    border: 1px solid rgba(15,61,46,.16);
    border-radius: 18px;
    box-shadow: 0 24px 60px rgba(28,28,28,.18);
    padding: 10px;
    opacity: 0;
    transform: translateY(-8px);
    pointer-events: none;
    transition: opacity .2s ease, transform .2s ease;
    z-index: 1000;
  }

  body.menu-open .mobile-overlay{
    opacity: 1;
    pointer-events: auto;
  }
  body.menu-open .mobile-drawer{
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }

  .mobile-navlink{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding: 12px 12px;
    border-radius: 14px;
    border: 1px solid rgba(15,61,46,.12);
    background: rgba(127,174,158,.10);
    font-size: 13px;
    color: rgba(28,28,28,.86);
  }
  .mobile-navlink + .mobile-navlink{ margin-top: 8px; }

  .mobile-navlink:active{ transform: translateY(1px); }

  .mobile-drawer .mini-row{
    display:flex;
    gap:8px;
    margin-top:10px;
    flex-wrap:wrap;
  }
}
/* =========================
   MOBILE MENU: colors (no blue)
   ========================= */

/* quita highlight azul de iOS al tocar */
a, button { -webkit-tap-highlight-color: rgba(var(--copper-rgb), .22); }

/* drawer más premium */
@media (max-width: 980px){
  .mobile-drawer{
    background:
      radial-gradient(620px 260px at 10% 0%, rgba(127,174,158,.22), transparent 60%),
      rgba(245,245,242,.96);
  }

  .mobile-navlink{
    background: rgba(230,220,203,.38);           /* beige */
    border: 1px solid rgba(15,61,46,.16);        /* green line */
    color: rgba(15,61,46,.96);                   /* green text */
  }
  .mobile-navlink:hover{
    background: rgba(127,174,158,.18);           /* sage hover */
    border-color: rgba(var(--copper-rgb), .28);  /* gold accent */
  }

  /* ES/EN dentro del drawer: nada azul */
  #langToggleMobile, #langToggle{
    background: rgba(230,220,203,.45);
    border: 1px solid rgba(15,61,46,.18);
    color: rgba(15,61,46,.92);
  }
  #langToggleMobile:focus, #langToggle:focus{ outline:none; }
  #langToggleMobile:focus-visible, #langToggle:focus-visible{
    outline: 2px solid rgba(var(--copper-rgb), .45);
    outline-offset: 2px;
  }
}
/* Header: solo EON DYNAMICS */

/* Home H1 un poco más compacto */
main h1{
  font-size: clamp(34px, 4.2vw, 54px);
  line-height: 1.05;
  letter-spacing: -0.02em;
}
@media (max-width: 980px){
  main h1{ font-size: clamp(30px, 7.5vw, 44px); }
}
/* Menú móvil: nada azul */
.mobile-menu-btn{
  -webkit-appearance: none;
  appearance: none;
  color: rgba(15,61,46,.95) !important;
  background: rgba(230,220,203,.50) !important;
  border: 1px solid rgba(15,61,46,.18) !important;
  text-decoration: none !important;
}

/* Links del drawer: no azul ni visited */
.mobile-navlink,
.mobile-navlink:visited{
  color: rgba(15,61,46,.95) !important;
  text-decoration: none !important;
}

/* =========================
   RESTORE HEADER TAGLINE
   ========================= */
.brand-text span{
  display:block !important;
  margin-top:2px;
  font-size:12px;
  line-height:1.1;
  color: rgba(15,61,46,.74);
  font-weight:500;
}

/* en móvil: pequeño y sin romper el header */
@media (max-width: 980px){
  .brand-text span{
    display:block !important;
    font-size:11px;
    white-space:nowrap;
    max-width: 180px;
    overflow:hidden;
    text-overflow:ellipsis;
  }
}
