/*
Theme Name: EVCharge Colombia
Theme URI: https://evcharge.co
Author: EVCharge Colombia
Description: Mapa interactivo de estaciones de carga EV en Colombia. Mega menú, REST API, panel admin completo.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: GNU General Public License v2 or later
Text Domain: evcharge-colombia
*/

/* ── VARIABLES ─────────────────────────────── */
:root{
  --primary:#00C853; --primary-d:#00962E;
  --accent:#00BCD4;  --warn:#FF9800; --danger:#F44336;
  --dark:#0A0E1A;    --dark2:#111827; --dark3:#1F2937; --dark4:#374151;
  --mid:#6B7280;     --light:#9CA3AF;
  --white:#FFFFFF;
  --border:rgba(255,255,255,.08);
  --border-h:rgba(0,200,83,.4);
  --glass:rgba(255,255,255,.03);
  --shadow:0 8px 32px rgba(0,0,0,.6);
  --font-d:'Exo 2',sans-serif;
  --font-b:'DM Sans',sans-serif;
  --font-m:'JetBrains Mono',monospace;
  --hh:62px; --sw:370px;
  --r6:6px; --r10:10px; --r14:14px; --r20:20px; --rfull:9999px;
  --tr:all .22s cubic-bezier(.4,0,.2,1);
}

/* ── RESET ─────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit;}
img{max-width:100%;display:block;}

/* ── SCROLLBAR ─────────────────────────────── */
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:var(--dark2);}
::-webkit-scrollbar-thumb{background:var(--dark4);border-radius:var(--rfull);}
::-webkit-scrollbar-thumb:hover{background:var(--primary);}

/* ── BODY (página de mapa) ─────────────────── */
body{font-family:var(--font-b);background:var(--dark);color:var(--white);-webkit-font-smoothing:antialiased;}
body.ev-map-page{overflow:hidden;height:100vh;}

/* ── LOADING ───────────────────────────────── */
#ev-loading{position:fixed;inset:0;background:var(--dark);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;z-index:9999;transition:opacity .5s ease;}
.ld-icon{font-size:3.2rem;animation:zpulse 1.4s ease-in-out infinite;}
.ld-txt{font-family:var(--font-d);font-size:.95rem;font-weight:600;color:var(--light);letter-spacing:.02em;}
.ld-bar{width:220px;height:3px;background:var(--dark3);border-radius:var(--rfull);overflow:hidden;}
.ld-prog{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:var(--rfull);animation:ldprog 1.8s ease forwards;}
@keyframes ldprog{from{width:0}to{width:100%}}
@keyframes zpulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}

/* ── HEADER ────────────────────────────────── */
#ev-hdr{
  position:fixed;top:0;left:0;right:0;
  height:var(--hh);z-index:800;
  background:rgba(10,14,26,.97);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;
  padding:0 18px;gap:14px;
  backdrop-filter:blur(20px);
}

/* Logo */
.ev-logo{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:var(--r10);display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 0 16px rgba(0,200,83,.35);transition:var(--tr);}
.ev-logo:hover .logo-icon{transform:rotate(-8deg) scale(1.06);}
.logo-txt{font-family:var(--font-d);font-size:1.2rem;font-weight:800;letter-spacing:-.02em;}
.logo-txt em{color:var(--primary);font-style:normal;}
.logo-txt sup{color:var(--accent);font-size:.5em;font-weight:400;vertical-align:super;}
.ev-logo img{height:40px;width:auto;}

/* Nav */
#ev-nav{display:flex;align-items:center;gap:2px;flex:1;}
.ni{position:relative;}
.nl{display:flex;align-items:center;gap:6px;padding:7px 12px;font-size:.82rem;font-weight:500;color:var(--light);border-radius:var(--r6);transition:var(--tr);cursor:pointer;white-space:nowrap;}
.nl:hover,.nl.on{color:var(--white);background:var(--glass);}
.nl.hi{color:var(--primary);}
.nl.hi:hover{background:rgba(0,200,83,.1);}
.chev{transition:transform .2s;}
.has-mega:hover .chev{transform:rotate(180deg);}

/* Mega menu */
.mega{
  position:fixed;top:var(--hh);left:0;right:0;
  background:var(--dark2);border-bottom:1px solid var(--border);
  padding:26px 36px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:all .28s cubic-bezier(.4,0,.2,1);
  z-index:799;box-shadow:var(--shadow);
  pointer-events:none;
}
.has-mega:hover .mega{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto;}
.mc h4{font-size:.63rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--primary);margin-bottom:10px;padding-bottom:7px;border-bottom:1px solid var(--border);}
.ml{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:var(--r6);transition:var(--tr);margin-bottom:2px;cursor:pointer;}
.ml:hover{background:var(--glass);}
.mi{width:28px;height:28px;background:var(--dark3);border:1px solid var(--border);border-radius:var(--r6);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;}
.ml strong{display:block;font-size:.78rem;font-weight:600;color:var(--white);}
.ml span{font-size:.68rem;color:var(--mid);}

/* Header right */
.hdr-r{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.ev-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--r6);font-size:.78rem;font-weight:600;transition:var(--tr);cursor:pointer;}
.ev-btn-ghost{border:1px solid var(--border);color:var(--light);}
.ev-btn-ghost:hover{border-color:var(--border-h);color:var(--white);}
.ev-btn-pri{background:linear-gradient(135deg,var(--primary),var(--primary-d));color:var(--dark);font-weight:700;box-shadow:0 0 14px rgba(0,200,83,.3);}
.ev-btn-pri:hover{transform:translateY(-1px);box-shadow:0 0 22px rgba(0,200,83,.5);}

/* Avatar */
.ev-avatar{width:34px;height:34px;border-radius:var(--rfull);background:linear-gradient(135deg,var(--accent),#7C3AED);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;cursor:pointer;border:2px solid var(--border);transition:var(--tr);}
.ev-avatar:hover{border-color:var(--primary);transform:scale(1.05);}

/* Avatar dropdown */
#av-drop{position:fixed;top:calc(var(--hh) + 8px);right:16px;background:var(--dark2);border:1px solid var(--border);border-radius:var(--r14);padding:8px;min-width:190px;display:none;z-index:1000;box-shadow:var(--shadow);}
#av-drop.open{display:block;}
.avd-head{padding:8px 10px;border-bottom:1px solid var(--border);margin-bottom:4px;}
.avd-lnk{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--r6);font-size:.8rem;color:var(--light);transition:var(--tr);}
.avd-lnk:hover{background:var(--glass);color:var(--white);}
.avd-out{color:var(--danger);}
.avd-out:hover{background:rgba(244,67,54,.1);}

/* Mobile toggle */
#mob-toggle{width:36px;height:36px;border-radius:var(--r6);display:flex;align-items:center;justify-content:center;color:var(--light);border:1px solid var(--border);}

/* ── LAYOUT APP ─────────────────────────────── */
#ev-app{display:flex;height:100vh;padding-top:var(--hh);}

/* ── SIDEBAR ────────────────────────────────── */
#ev-sidebar{
  width:var(--sw);flex-shrink:0;
  background:rgba(10,14,26,.97);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  overflow:hidden;
  transition:width .3s ease;
  position:relative;z-index:100;
}
#ev-sidebar.collapsed{width:0;overflow:hidden;}

/* Search */
.ev-search-bar{padding:12px;border-bottom:1px solid var(--border);flex-shrink:0;}
.ev-search-wrap{position:relative;display:flex;align-items:center;}
.s-ico{position:absolute;left:11px;color:var(--mid);pointer-events:none;flex-shrink:0;}
.ev-search-input{width:100%;background:var(--dark3);border:1px solid var(--border);border-radius:var(--r10);padding:9px 11px 9px 36px;color:var(--white);font-size:.84rem;font-family:var(--font-b);outline:none;transition:var(--tr);}
.ev-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,200,83,.12);}
.ev-search-input::placeholder{color:var(--mid);}

/* Filter tabs */
.ev-filter-tabs{display:flex;padding:10px 12px 0;gap:4px;border-bottom:1px solid var(--border);overflow-x:auto;flex-shrink:0;}
.ev-ftab{flex-shrink:0;padding:7px 12px;font-size:.73rem;font-weight:600;color:var(--light);border-radius:var(--r6) var(--r6) 0 0;border-bottom:2px solid transparent;transition:var(--tr);cursor:pointer;font-family:var(--font-b);}
.ev-ftab.active{color:var(--primary);border-bottom-color:var(--primary);}
.ev-ftab:hover:not(.active){color:var(--white);}

/* Connector chips */
.ev-chips{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:6px;flex-shrink:0;}
.ev-chip{display:flex;align-items:center;gap:4px;padding:4px 10px;background:var(--dark3);border:1px solid var(--border);border-radius:var(--rfull);font-size:.7rem;font-weight:500;color:var(--light);cursor:pointer;transition:var(--tr);font-family:var(--font-b);}
.ev-chip.active{background:rgba(0,200,83,.14);border-color:var(--primary);color:var(--primary);}
.ev-chip:hover:not(.active){border-color:var(--border-h);color:var(--white);}
.ev-chip .dot{width:6px;height:6px;border-radius:var(--rfull);background:currentColor;flex-shrink:0;}

/* Station list */
.ev-list{flex:1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:8px;}

/* Station card */
.ev-card{background:var(--dark2);border:1px solid var(--border);border-radius:var(--r10);padding:13px;cursor:pointer;transition:var(--tr);position:relative;overflow:hidden;}
.ev-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary);border-radius:var(--r6) 0 0 var(--r6);transform:scaleY(0);transition:var(--tr);}
.ev-card:hover,.ev-card.active{border-color:var(--border-h);transform:translateX(2px);}
.ev-card:hover::before,.ev-card.active::before{transform:scaleY(1);}
.ev-card-hdr{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px;}
.ev-card-name{font-family:var(--font-d);font-size:.84rem;font-weight:600;line-height:1.3;color:var(--white);}
.ev-tag{flex-shrink:0;padding:2px 7px;border-radius:var(--rfull);font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;}
.ev-tag.available{background:rgba(0,200,83,.18);color:var(--primary);}
.ev-tag.busy{background:rgba(255,152,0,.18);color:var(--warn);}
.ev-tag.offline{background:rgba(244,67,54,.18);color:var(--danger);}
.ev-tag.coming_soon{background:rgba(0,188,212,.18);color:var(--accent);}
.ev-card-addr{font-size:.72rem;color:var(--mid);margin-bottom:7px;display:flex;align-items:center;gap:3px;}
.ev-card-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.ev-card-meta-item{display:flex;align-items:center;gap:3px;font-size:.7rem;color:var(--light);}
.ev-connectors{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px;}
.ev-cbadge{padding:2px 6px;background:var(--dark3);border:1px solid var(--border);border-radius:var(--r6);font-size:.6rem;font-weight:600;color:var(--light);font-family:var(--font-m);}

/* Stats bar */
.ev-statsbar{padding:12px;border-top:1px solid var(--border);display:flex;justify-content:space-around;flex-shrink:0;}
.ev-stat{text-align:center;}
.sv{font-family:var(--font-d);font-size:1.3rem;font-weight:700;color:var(--primary);line-height:1;}
.sl{font-size:.62rem;color:var(--mid);text-transform:uppercase;letter-spacing:.05em;margin-top:2px;}

/* Sidebar toggle */
.sb-toggle{
  position:absolute;left:var(--sw);top:50%;transform:translateY(-50%);
  z-index:200;width:22px;height:46px;
  background:var(--dark2);border:1px solid var(--border);
  border-left:none;border-radius:0 var(--r6) var(--r6) 0;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--mid);font-size:11px;transition:var(--tr);
}
.sb-toggle:hover{background:var(--dark3);color:var(--white);}
#ev-sidebar.collapsed~.sb-toggle{left:0;}

/* ── MAP ────────────────────────────────────── */
#ev-map-wrap{flex:1;position:relative;overflow:hidden;}
#ev-map{width:100%;height:100%;}

/* Map controls */
.map-ctrls{position:absolute;right:14px;top:14px;display:flex;flex-direction:column;gap:6px;z-index:10;}
.mc-btn{width:38px;height:38px;background:var(--dark2);border:1px solid var(--border);border-radius:var(--r10);display:flex;align-items:center;justify-content:center;color:var(--light);cursor:pointer;transition:var(--tr);box-shadow:0 4px 14px rgba(0,0,0,.4);}
.mc-btn:hover{background:var(--dark3);color:var(--white);border-color:var(--border-h);}

/* Legend */
.map-legend{position:absolute;bottom:14px;right:14px;background:rgba(10,14,26,.95);border:1px solid var(--border);border-radius:var(--r10);padding:13px;z-index:10;box-shadow:var(--shadow);min-width:160px;}
.ml-title{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--mid);margin-bottom:8px;}
.ml-item{display:flex;align-items:center;gap:8px;font-size:.74rem;color:var(--light);margin-bottom:4px;}
.ml-dot{width:10px;height:10px;border-radius:var(--rfull);flex-shrink:0;}

/* Popup bottom sheet */
.ev-popup{
  position:absolute;bottom:0;left:0;right:0;
  max-height:300px;overflow-y:auto;
  background:rgba(10,14,26,.97);
  border-top:1px solid var(--border);
  border-radius:var(--r20) var(--r20) 0 0;
  padding:18px;
  transform:translateY(100%);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  z-index:50;
}
.ev-popup.open{transform:translateY(0);}
.ev-popup-hdr{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:13px;gap:10px;}
.ev-popup-title{font-family:var(--font-d);font-size:1.05rem;font-weight:700;}
.ev-popup-addr{font-size:.74rem;color:var(--mid);margin-top:3px;}
.pp-close{width:30px;height:30px;background:var(--dark3);border-radius:var(--rfull);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--light);flex-shrink:0;transition:var(--tr);}
.pp-close:hover{background:var(--dark4);color:var(--white);}
.ev-popup-body{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.pp-info-item{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px;font-size:.78rem;color:var(--light);}
.pp-info-item strong{display:block;font-size:.72rem;color:var(--white);margin-bottom:2px;}
.pp-actions{display:flex;flex-direction:column;gap:8px;}

/* Marker icons */
.ev-pin{width:30px;height:30px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,.5);border:2px solid rgba(255,255,255,.25);}
.ev-pin.available{background:linear-gradient(135deg,#00C853,#00962E);}
.ev-pin.busy{background:linear-gradient(135deg,#FF9800,#e65100);}
.ev-pin.offline{background:linear-gradient(135deg,#F44336,#b71c1c);}
.ev-pin.coming_soon{background:linear-gradient(135deg,#00BCD4,#0097A7);}
.ev-pin .pi{transform:rotate(45deg);font-size:12px;color:#fff;}
.ev-cluster{width:38px;height:38px;border-radius:var(--rfull);background:linear-gradient(135deg,var(--accent),#7C3AED);display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-weight:700;font-size:.78rem;color:#fff;box-shadow:0 4px 14px rgba(0,0,0,.4),0 0 0 4px rgba(0,188,212,.18);}

/* ── SINGLE STATION ─────────────────────────── */
.ev-single-wrap{max-width:1080px;margin:0 auto;padding:36px 22px;}
.ev-breadcrumb{font-size:.78rem;color:var(--mid);margin-bottom:22px;}
.ev-breadcrumb a{color:var(--mid);}
.ev-breadcrumb a:hover{color:var(--white);}
.ev-single-hero{background:var(--dark2);border:1px solid var(--border);border-radius:var(--r20);overflow:hidden;margin-bottom:28px;}
.ev-single-hero-img{height:260px;background:var(--dark3);display:flex;align-items:center;justify-content:center;font-size:5rem;background-size:cover;background-position:center;}
.ev-single-hero-body{padding:28px;display:grid;grid-template-columns:1fr auto;gap:20px;align-items:start;}
.ev-single-grid{display:grid;grid-template-columns:1fr 320px;gap:22px;}
.ev-single-card{background:var(--dark2);border:1px solid var(--border);border-radius:var(--r14);padding:22px;margin-bottom:18px;}
.ev-single-card h3{font-family:var(--font-d);font-size:.95rem;font-weight:700;margin-bottom:14px;}
.ev-dr{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border);font-size:.82rem;}
.ev-dr:last-child{border-bottom:none;}
.ev-dr .lbl{color:var(--mid);}
.ev-dr .val{color:var(--white);font-weight:500;}

/* ── RESPONSIVE ─────────────────────────────── */
@media(max-width:768px){
  :root{--sw:100vw;--hh:56px;}
  #ev-sidebar{
    position:fixed;bottom:0;left:0;right:0;
    width:100%;height:60vh;
    border-right:none;border-top:1px solid var(--border);
    border-radius:var(--r20) var(--r20) 0 0;
    transform:translateY(calc(100% - 76px));
    transition:transform .4s cubic-bezier(.4,0,.2,1);
    z-index:200;
  }
  #ev-sidebar.expanded{transform:translateY(0);}
  #ev-nav{display:none;}
  #ev-nav.mob-open{display:flex;flex-direction:column;position:fixed;top:var(--hh);left:0;right:0;background:var(--dark2);padding:14px;z-index:797;border-bottom:1px solid var(--border);}
  .sb-toggle{display:none;}
  #ev-map-wrap{width:100%;}
  .ev-single-grid,.ev-single-hero-body{grid-template-columns:1fr;}
  .ev-popup-body{grid-template-columns:1fr;}
}

/* ── LEAFLET OVERRIDES ──────────────────────── */
.leaflet-control-attribution{background:rgba(10,14,26,.8)!important;color:var(--mid)!important;font-size:10px!important;}
.leaflet-control-attribution a{color:var(--light)!important;}
.leaflet-popup-content-wrapper{background:var(--dark2)!important;color:var(--white)!important;border:1px solid var(--border)!important;border-radius:var(--r10)!important;box-shadow:var(--shadow)!important;}
.leaflet-popup-tip{background:var(--dark2)!important;}
.leaflet-popup-close-button{color:var(--light)!important;}
.marker-cluster-small,.marker-cluster-medium,.marker-cluster-large{background:transparent!important;}
.marker-cluster-small div,.marker-cluster-medium div,.marker-cluster-large div{background:transparent!important;}

/* ── ADMIN STYLES ───────────────────────────── */
.evcharge-admin-wrap{max-width:1100px;}
