:root{
  --verde:#1B4332; --verde-2:#2D6A4F; --verde-claro:#E1F5EE; --verde-mid:#9FE1CB;
  --rojo:#E24B4A; --rojo-bg:#FCEBEB; --rojo-tx:#A32D2D;
  --ambar:#EF9F27; --ambar-bg:#FAEEDA; --ambar-tx:#854F0B;
  --ok:#1D9E75; --ok-bg:#E1F5EE; --ok-tx:#0F6E56;
  --tx:#1f2421; --tx-2:#5f6b65; --linea:#e3e8e5; --fondo:#f4f7f5; --blanco:#fff;
  --rad:10px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Plus Jakarta Sans',system-ui,Segoe UI,sans-serif;color:var(--tx);background:var(--fondo);line-height:1.5}
a{color:inherit;text-decoration:none}
.layout{display:flex;min-height:100vh}

/* Sidebar */
.side{width:230px;background:var(--verde);color:#dff3ea;display:flex;flex-direction:column;flex-shrink:0}
.side .marca{padding:18px 18px 14px;border-bottom:1px solid rgba(255,255,255,.1)}
.side .marca b{color:#fff;font-size:15px;display:block;font-weight:700}
.side .marca span{font-size:11px;color:var(--verde-mid)}
.side nav{padding:10px;display:flex;flex-direction:column;gap:2px;flex:1}
.side nav a{padding:10px 12px;border-radius:8px;font-size:14px;display:flex;align-items:center;gap:10px;color:#cdeadd}
.side nav a:hover{background:var(--verde-2);color:#fff}
.side nav a.activo{background:var(--verde-2);color:#fff}
.side .pie{padding:12px;border-top:1px solid rgba(255,255,255,.1);font-size:12px}
.side .pie .u{color:#fff;font-weight:600}
.side .pie a{color:var(--verde-mid)}

/* Topbar móvil */
.topbar{display:none;background:var(--verde);color:#fff;padding:12px 16px;align-items:center;justify-content:space-between}
.topbar b{font-size:15px}

/* Main */
.main{flex:1;min-width:0}
.contenido{padding:22px 26px;max-width:1100px}
h1{font-size:21px;font-weight:700;margin-bottom:4px}
.sub{color:var(--tx-2);font-size:13px;margin-bottom:18px}

/* Cards de métricas */
.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin-bottom:22px}
.metric{background:var(--blanco);border:1px solid var(--linea);border-radius:var(--rad);padding:14px 16px}
.metric .n{font-size:26px;font-weight:700}
.metric .l{font-size:12px;color:var(--tx-2)}
.metric.rojo .n{color:var(--rojo-tx)} .metric.ambar .n{color:var(--ambar-tx)} .metric.ok .n{color:var(--ok-tx)}

/* Botones */
.btn{display:inline-flex;align-items:center;gap:7px;border:none;border-radius:9px;padding:10px 16px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit}
.btn-pri{background:var(--verde);color:#fff} .btn-pri:hover{background:var(--verde-2)}
.btn-sec{background:#fff;border:1px solid var(--linea);color:var(--tx)} .btn-sec:hover{border-color:#c6d2cc}
.btn-rojo{background:var(--rojo);color:#fff}
.btn-sm{padding:7px 12px;font-size:13px}
.btn-block{width:100%;justify-content:center}

/* Tabla / lista */
.panel{background:#fff;border:1px solid var(--linea);border-radius:var(--rad);overflow:hidden}
.fila{display:flex;align-items:center;gap:12px;padding:13px 16px;border-bottom:1px solid var(--linea)}
.fila:last-child{border-bottom:none}
.fila:hover{background:#fafcfb}
.barra{width:7px;height:38px;border-radius:4px;flex-shrink:0}
.b-rojo{background:var(--rojo)} .b-ambar{background:var(--ambar)} .b-ok{background:var(--ok)}
.fila .tx b{font-size:14px;font-weight:600;display:block}
.fila .tx small{font-size:12px;color:var(--tx-2)}
.fila .der{margin-left:auto;display:flex;align-items:center;gap:10px}
.pill{font-size:11px;font-weight:600;padding:4px 9px;border-radius:7px}
.p-rojo{background:var(--rojo-bg);color:var(--rojo-tx)}
.p-ambar{background:var(--ambar-bg);color:var(--ambar-tx)}
.p-ok{background:var(--ok-bg);color:var(--ok-tx)}

/* Filtros */
.filtros{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.filtros a{font-size:13px;padding:6px 13px;border-radius:20px;background:#fff;border:1px solid var(--linea);color:var(--tx-2)}
.filtros a.activo{background:var(--verde);color:#fff;border-color:var(--verde)}

/* Formularios */
.form{background:#fff;border:1px solid var(--linea);border-radius:var(--rad);padding:22px;max-width:560px}
.campo{margin-bottom:16px}
.campo label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}
.campo input,.campo select,.campo textarea{width:100%;padding:10px 12px;border:1px solid var(--linea);border-radius:8px;font-size:14px;font-family:inherit}
.campo input:focus,.campo select:focus,.campo textarea:focus{outline:none;border-color:var(--verde-2);box-shadow:0 0 0 3px rgba(45,106,79,.12)}
.fila-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.acciones{display:flex;gap:10px;margin-top:8px}

/* Tablas */
table.tabla{width:100%;border-collapse:collapse;background:#fff}
table.tabla th,table.tabla td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--linea);font-size:14px}
table.tabla th{font-size:12px;color:var(--tx-2);text-transform:uppercase;letter-spacing:.04em}

/* Avisos */
.aviso{padding:11px 15px;border-radius:9px;font-size:13px;margin-bottom:16px}
.aviso-ok{background:var(--ok-bg);color:var(--ok-tx)}
.aviso-err{background:var(--rojo-bg);color:var(--rojo-tx)}
.aviso-warn{background:var(--ambar-bg);color:var(--ambar-tx)}

/* Detalle */
.detalle-grid{display:grid;grid-template-columns:2fr 1fr;gap:18px}
.box{background:#fff;border:1px solid var(--linea);border-radius:var(--rad);padding:18px}
.box h3{font-size:15px;margin-bottom:12px}
.timeline{border-left:2px solid var(--linea);padding-left:14px;display:flex;flex-direction:column;gap:10px}
.timeline .ev b{font-size:13px} .timeline .ev small{font-size:12px;color:var(--tx-2);display:block}
.kv{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--linea);font-size:13px}
.kv:last-child{border:none} .kv span{color:var(--tx-2)}

@media(max-width:760px){
  .side{display:none}
  .topbar{display:flex}
  .detalle-grid{grid-template-columns:1fr}
  .fila-2{grid-template-columns:1fr}
  .contenido{padding:16px}
}

/* ====== Manzanas y avance (Fase 2) ====== */
.manzanas{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;margin:8px 0 4px}
.mz{border:1px solid var(--linea);border-radius:10px;padding:12px 10px;text-align:center;background:#fff;position:relative}
.mz .et{font-size:20px;font-weight:700;line-height:1}
.mz .dom{font-size:11px;color:var(--tx-2);margin-top:2px}
.mz.hecha{background:var(--ok-bg);border-color:#7fd3bb}
.mz.hecha .et{color:var(--ok-tx)}
.mz button{margin-top:9px;width:100%;border:none;border-radius:7px;padding:7px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit}
.mz .marcar{background:var(--verde);color:#fff}
.mz .desmarcar{background:#fff;border:1px solid #7fd3bb;color:var(--ok-tx)}
.mz .del{position:absolute;top:6px;right:7px;background:none;border:none;color:var(--rojo);cursor:pointer;font-size:14px;width:auto;margin:0;padding:0}
.mz .check{font-size:11px;color:var(--ok-tx);font-weight:600;margin-top:6px;display:block}

/* Barra de progreso */
.progreso{margin:10px 0}
.progreso .track{height:10px;background:var(--linea);border-radius:6px;overflow:hidden}
.progreso .fill{height:100%;background:var(--ok);border-radius:6px;transition:width .3s}
.progreso .lbl{font-size:12px;color:var(--tx-2);margin-top:5px;display:flex;justify-content:space-between}

/* Mini-form para agregar manzana */
.add-mz{display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap;margin-top:10px;padding-top:12px;border-top:1px solid var(--linea)}
.add-mz .campo{margin:0}
.add-mz input{padding:8px 10px}

/* ====== Mapa editor admin (Leaflet) ====== */
#mapa{height:400px;border-radius:10px;border:1px solid var(--linea);z-index:0}
.mapa-tools{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:10px}
.mapa-tools select{padding:8px 10px;border:1px solid var(--linea);border-radius:8px;font-size:14px;font-family:inherit}
.mz-label{background:rgba(27,67,50,.9);color:#fff;border:none;border-radius:6px;font-weight:700;font-size:13px;padding:2px 7px;box-shadow:none}
.mz-label:before{display:none}

/* Mapas simples (pin) */
#mapaPin{height:300px;border-radius:10px;border:1px solid var(--linea);z-index:0}
#mapaVer{height:240px;border-radius:10px;border:1px solid var(--linea);z-index:0}
