.stage{
  position:relative;
  overflow:hidden;
  height:100%;
  min-height:0;
}

#map-panel{
  position:relative;
  width:100%;
  height:100%;
  overflow:hidden;
}

#map{
  position:absolute;
  inset:0;
  z-index:1;
  background:#07101C;
}

.leaflet-container{
  width:100%;
  height:100%;
  background:#07101C;
  font-family:var(--font);
}

.leaflet-control-attribution{
  display:none !important;
}

.leaflet-top,
.leaflet-bottom{
  z-index:450 !important;
}

.leaflet-control-zoom{
  margin-left:310px !important;
  margin-top:16px !important;
  border:none !important;
  box-shadow:0 8px 24px rgba(0,0,0,.35) !important;
}

.leaflet-control-zoom a{
  width:30px !important;
  height:30px !important;
  line-height:30px !important;
  background:rgba(5,13,24,.88) !important;
  color:var(--t2) !important;
  border:1px solid rgba(255,255,255,.08) !important;
  backdrop-filter:blur(18px);
}

.leaflet-control-zoom a:hover{
  color:var(--t1) !important;
  background:rgba(15,29,48,.96) !important;
}

.leaflet-control-zoom-in{
  border-bottom:none !important;
}

.leaflet-interactive{
  transition:fill-opacity .15s ease, stroke-width .15s ease, filter .15s ease;
}

.leaflet-interactive.selected-sec{
  filter:brightness(1.2) drop-shadow(0 0 7px rgba(255,255,255,.32));
}

/* LEFT PANEL */
.left{
  position:absolute;
  top:0;
  left:0;
  bottom:0;
  width:292px;
  z-index:500;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(5,13,24,.94) 0, rgba(5,13,24,.88) 100%);
  border-right:1px solid rgba(255,255,255,.07);
  backdrop-filter:blur(28px) saturate(1.4);
  box-shadow:0 10px 40px rgba(0,0,0,.18);
}

.lp-top{
  padding:16px 18px 13px;
  border-bottom:1px solid var(--line-2);
}

.lp-lbl,
.kpi-l,
.w-lbl,
.leg-title,
.det-lbl,
.terr-t,
.scale-b,
.sec-label,
.sec-kpi-lbl{
  font-size:10px;
  font-family:var(--mono);
  color:var(--t3);
  text-transform:uppercase;
  letter-spacing:.14em;
}

.lp-title{
  font-size:15px;
  font-weight:700;
  color:var(--t1);
  letter-spacing:-.02em;
  margin-top:4px;
}

.lp-meta{
  margin-top:6px;
  font-size:11px;
  font-family:var(--mono);
  color:var(--t3);
  line-height:1.6;
}

.kpi-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  border-bottom:1px solid var(--line-2);
}

.kpi{
  padding:12px 16px;
  border-right:1px solid rgba(255,255,255,.04);
  border-bottom:1px solid rgba(255,255,255,.04);
}

.kpi:nth-child(even){
  border-right:none;
}

.kpi:nth-last-child(-n+1){
  grid-column:1 / -1;
  border-bottom:none;
}

.kpi-v{
  font-size:24px;
  font-weight:800;
  font-family:var(--mono);
  color:var(--t1);
  line-height:1;
  letter-spacing:-.03em;
  margin-top:5px;
}

.kpi-s{
  margin-top:5px;
  font-size:11px;
  color:var(--t3);
}

.lp-winner{
  padding:16px 18px;
  border-bottom:1px solid var(--line-2);
}

.w-name{
  margin-top:8px;
  font-size:16px;
  font-weight:700;
  line-height:1.25;
  color:var(--t1);
}

.w-party{
  display:flex;
  align-items:center;
  gap:6px;
  margin-top:5px;
  margin-bottom:8px;
}

.w-dot{
  width:7px;
  height:7px;
  border-radius:2px;
  background:var(--t3);
}

.w-pname{
  font-size:11px;
  font-family:var(--mono);
  color:var(--t2);
  text-transform:uppercase;
  letter-spacing:.10em;
}

.w-pct{
  font-family:var(--mono);
  font-size:34px;
  font-weight:800;
  color:var(--coral);
  line-height:1;
  letter-spacing:-.03em;
}

.w-sub{
  margin-top:4px;
  font-size:10px;
  font-family:var(--mono);
  color:var(--t3);
  text-transform:uppercase;
  letter-spacing:.10em;
}

.lp-leg{
  padding:12px 18px;
  border-bottom:1px solid var(--line-2);
}

#leg-body{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-top:10px;
}

.leg-item{
  display:flex;
  align-items:center;
  gap:8px;
}

.leg-dot{
  width:7px;
  height:7px;
  border-radius:2px;
  flex-shrink:0;
}

.leg-name{
  width:56px;
  font-size:11px;
  font-weight:700;
  color:var(--t1);
  flex-shrink:0;
}

.leg-track{
  flex:1;
  height:5px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  overflow:hidden;
}

.leg-fill{
  height:100%;
  width:0;
  border-radius:999px;
  transition:width .45s ease;
}

.leg-pct{
  width:40px;
  flex-shrink:0;
  text-align:right;
  font-size:11px;
  font-weight:700;
  font-family:var(--mono);
  color:var(--t1);
}

.lp-det{
  flex:1;
  padding:14px 18px 18px;
  overflow-y:auto;
}

.det-hint{
  padding:14px 0;
  font-size:11px;
  font-family:var(--mono);
  color:var(--t3);
  line-height:1.8;
}

.det-sn{
  font-size:30px;
  font-weight:800;
  font-family:var(--mono);
  color:var(--t1);
  line-height:1;
  letter-spacing:-.03em;
}

.det-meta{
  margin:8px 0 14px;
  font-size:11px;
  font-family:var(--mono);
  color:var(--t3);
  line-height:1.7;
}

.det-bars,
.sec-bars{
  display:flex;
  flex-direction:column;
  gap:9px;
}

.det-bi{
  display:flex;
  align-items:center;
  gap:8px;
}

.det-bn{
  width:54px;
  flex-shrink:0;
  font-size:10px;
  font-weight:700;
  font-family:var(--mono);
}

.det-bt{
  flex:1;
  height:6px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  overflow:hidden;
}

.det-bf{
  height:100%;
  width:0;
  border-radius:999px;
  transition:width .55s ease;
}

.det-bp{
  width:36px;
  flex-shrink:0;
  text-align:right;
  font-size:10px;
  font-weight:700;
  font-family:var(--mono);
  color:var(--t1);
}

/* RIGHT SIDE */
.right{
  position:absolute;
  top:0;
  right:0;
  bottom:0;
  width:222px;
  z-index:520;
  pointer-events:none;
}

.right > *{
  pointer-events:auto;
}

.terr,
.layer-card{
  position:absolute;
  right:14px;
  min-width:180px;
  border-radius:12px;
  background:rgba(5,13,24,.82);
  border:1px solid rgba(255,255,255,.07);
  backdrop-filter:blur(20px);
  box-shadow:0 10px 28px rgba(0,0,0,.18);
}

.terr{
  top:14px;
  z-index:600;
  padding:12px 14px;
}

#terr-rows,
#terr-rows-resumen{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-top:10px;
}

.terr-r{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:7px;
}

.terr-d{
  width:8px;
  height:8px;
  border-radius:2px;
  flex-shrink:0;
}

.terr-n{
  flex:1;
  font-size:10px;
  font-family:var(--mono);
  color:var(--t2);
}

.terr-v{
  font-size:10px;
  font-weight:700;
  font-family:var(--mono);
  color:var(--t1);
}

.layer-card{
  z-index:600;
  padding:12px 14px;
}

.right .layer-card:nth-of-type(2){
  top:148px;
}

.right .layer-card:nth-of-type(3){
  top:258px;
}

.ly-switch{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-top:10px;
}

.ly-btn{
  border:none;
  border-radius:9px;
  padding:8px 10px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  color:var(--t2);
  font-size:10px;
  font-family:var(--mono);
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  transition:all .18s ease;
}

.ly-btn:hover{
  color:var(--t1);
  border-color:rgba(248,112,96,.24);
  background:rgba(248,112,96,.07);
}

.ly-btn.on{
  color:#fff;
  border-color:rgba(248,112,96,.24);
  background:linear-gradient(180deg, rgba(255,144,128,.20), rgba(248,112,96,.12));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}

#cb-toggle{
  margin-top:10px;
  width:100%;
  justify-content:center;
}

.scale-b{
  position:absolute;
  right:14px;
  bottom:14px;
  z-index:600;
  padding:8px 11px;
  border-radius:8px;
  background:rgba(5,13,24,.66);
  border:1px solid rgba(255,255,255,.05);
  backdrop-filter:blur(12px);
  color:var(--t3);
  text-align:right;
  max-width:180px;
}

/* TOOLTIP */
.map-tip{
  position:absolute;
  z-index:700;
  min-width:160px;
  padding:12px 14px;
  border-radius:12px;
  pointer-events:none;
  background:rgba(5,13,24,.94);
  border:1px solid rgba(255,255,255,.11);
  box-shadow:0 8px 40px rgba(0,0,0,.65);
  backdrop-filter:blur(24px);
  opacity:0;
  transition:opacity .12s ease;
}

.map-tip.show{
  opacity:1;
}

.tip-sec{
  font-size:10px;
  font-family:var(--mono);
  color:var(--t3);
  text-transform:uppercase;
  letter-spacing:.14em;
  margin-bottom:4px;
}

.tip-win{
  font-size:12px;
  font-weight:700;
  color:var(--t1);
}

.tip-pct{
  margin-top:2px;
  font-size:24px;
  font-weight:800;
  font-family:var(--mono);
  line-height:1;
  letter-spacing:-.03em;
  color:var(--t1);
}

.tip-mg{
  margin-top:4px;
  font-size:10px;
  font-family:var(--mono);
  color:var(--t3);
}

.tip-ln{
  margin-top:7px;
  padding-top:7px;
  border-top:1px solid rgba(255,255,255,.06);
  font-size:10px;
  font-family:var(--mono);
  color:var(--t3);
}

/* MODAL */
.sec-modal{
  position:fixed;
  right:24px;
  bottom:24px;
  z-index:2000;
  width:320px;
  max-width:calc(100vw - 32px);
}

.sec-card{
  position:relative;
  overflow:hidden;
  border-radius:16px;
  background:rgba(5,13,24,.97);
  border:1px solid rgba(255,255,255,.13);
  box-shadow:0 14px 56px rgba(0,0,0,.60);
  backdrop-filter:blur(24px);
}

.sec-close{
  position:absolute;
  top:10px;
  right:10px;
  width:28px;
  height:28px;
  border:none;
  border-radius:8px;
  background:rgba(255,255,255,.06);
  color:var(--t2);
  font-size:16px;
  line-height:1;
}

.sec-close:hover{
  color:var(--t1);
  background:rgba(255,255,255,.10);
}

.sec-card-hdr{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:16px 18px 14px;
  border-bottom:1px solid rgba(255,255,255,.07);
}

.sec-color-bar{
  width:4px;
  min-height:46px;
  border-radius:999px;
  background:var(--t3);
  flex-shrink:0;
}

.sec-main{
  flex:1;
  min-width:0;
}

.sec-num{
  margin-top:4px;
  font-size:24px;
  font-weight:800;
  line-height:1;
  letter-spacing:-.03em;
  color:var(--t1);
}

.sec-col{
  margin-top:5px;
  font-size:11px;
  color:var(--t2);
  line-height:1.5;
}

.sec-win{
  text-align:right;
  flex-shrink:0;
}

.sec-winner-pct{
  font-size:28px;
  font-weight:800;
  font-family:var(--mono);
  line-height:1;
  letter-spacing:-.03em;
}

.sec-winner-name{
  margin-top:4px;
  font-size:10px;
  font-family:var(--mono);
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--t2);
}

.sec-kpis{
  display:grid;
  grid-template-columns:1fr 1fr;
  border-bottom:1px solid rgba(255,255,255,.07);
}

.sec-kpi{
  padding:12px 16px;
}

.sec-kpi:first-child{
  border-right:1px solid rgba(255,255,255,.05);
}

.sec-kpi-val{
  margin-top:5px;
  font-size:18px;
  font-weight:800;
  font-family:var(--mono);
  color:var(--t1);
}

.sec-bars{
  padding:14px 18px 18px;
}

.sec-bar-row{
  display:flex;
  align-items:center;
  gap:8px;
}

.sec-bar-name{
  width:54px;
  flex-shrink:0;
  font-size:10px;
  font-weight:700;
  font-family:var(--mono);
}

.sec-bar-track{
  flex:1;
  height:6px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  overflow:hidden;
}

.sec-bar-fill{
  height:100%;
  width:0;
  border-radius:999px;
  transition:width .55s ease;
}

.sec-bar-pct{
  width:38px;
  flex-shrink:0;
  text-align:right;
  font-size:10px;
  font-weight:700;
  font-family:var(--mono);
  color:var(--t1);
}

/* COLOR BLIND MODE */
body.cb-mode .ly-btn[data-l="winner"].on{
  background:linear-gradient(180deg, rgba(56,189,248,.18), rgba(34,211,165,.14));
  border-color:rgba(56,189,248,.28);
}

body.cb-mode .w-dot{
  box-shadow:0 0 0 1px rgba(255,255,255,.14);
}

/* MEDIUM */
@media (max-width: 1180px){
  .right{
    width:196px;
  }

  .terr,
  .layer-card,
  .scale-b{
    right:10px;
  }

  .terr,
  .layer-card{
    min-width:168px;
  }

  .leaflet-control-zoom{
    margin-left:304px !important;
  }
}

/* MOBILE */
@media (max-width: 768px){
  .leaflet-control-zoom{
    margin-left:auto !important;
    margin-top:10px !important;
    margin-right:10px !important;
  }

  .left{
    top:auto;
    left:0;
    right:0;
    bottom:0;
    width:100%;
    max-height:40vh;
    border-right:none;
    border-top:1px solid rgba(255,255,255,.08);
    border-radius:18px 18px 0 0;
  }

  .left::before{
    content:"";
    width:38px;
    height:4px;
    border-radius:999px;
    background:rgba(255,255,255,.18);
    margin:9px auto 0;
    flex-shrink:0;
  }

  .lp-top{
    padding-top:10px;
  }

  .kpi-grid{
    grid-template-columns:1fr 1fr 1fr;
  }

  .kpi:nth-last-child(-n+1){
    grid-column:auto;
  }

  .kpi{
    padding:10px 12px;
  }

  .kpi-v{
    font-size:18px;
  }

  .w-pct{
    font-size:28px;
  }

  .det-sn{
    font-size:24px;
  }

  .right{
    width:auto;
    left:auto;
    right:0;
    bottom:auto;
  }

  .terr{
    top:10px;
    right:10px;
    min-width:140px;
    padding:10px 11px;
  }

  .right .layer-card:nth-of-type(2){
    top:124px;
    right:10px;
    min-width:150px;
  }

  .right .layer-card:nth-of-type(3){
    top:228px;
    right:10px;
    min-width:150px;
  }

  .ly-switch{
    grid-template-columns:1fr 1fr;
    gap:6px;
  }

  .ly-btn{
    padding:7px 8px;
    font-size:9px;
  }

  .scale-b{
    right:10px;
    bottom:calc(40vh + 10px);
    font-size:9px;
    max-width:150px;
  }

  .sec-modal{
    right:10px;
    bottom:calc(40vh + 12px);
    width:min(300px, calc(100vw - 20px));
  }

  .map-tip{
    display:none;
  }
}

@media (max-width: 540px){
  .kpi-grid{
    grid-template-columns:1fr 1fr;
  }

  .terr{
    min-width:126px;
  }

  .right .layer-card:nth-of-type(2),
  .right .layer-card:nth-of-type(3){
    min-width:132px;
  }

  .sec-modal{
    width:calc(100vw - 20px);
  }

  .sec-card-hdr{
    padding:14px 14px 12px;
  }

  .sec-bars{
    padding:12px 14px 14px;
  }
}
