:root{
  --olive:#46582c; --olive-d:#33401f; --sage:#aebd86; --oil:#c9a227; --terr:#c4622d;
  --bg:#f6f3ea; --paper:#fffdf7; --ink:#2a2b22; --soft:#5d5f4f; --line:#e3decd; --ok:#3e7d3a;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg)}
#app{display:flex;flex-direction:column;height:100vh}

#bar{display:flex;align-items:center;justify-content:space-between;gap:14px;background:var(--olive);color:#fff;padding:10px 16px;flex:none;box-shadow:0 2px 8px rgba(0,0,0,.15);z-index:600}
.brand{font-weight:800;font-size:16px;display:flex;align-items:center;gap:8px}
.brand .leaf{font-size:18px}
.brand em{font-style:normal;font-weight:600;font-size:11px;background:rgba(255,255,255,.16);padding:2px 8px;border-radius:999px}
.hint{font-size:12.5px;color:#e7e8d2}

#main{flex:1;display:flex;min-height:0}
#map{flex:1;min-width:0;background:#cdd2bd}
#side{width:380px;flex:none;background:var(--bg);border-left:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden}

.tabs{display:flex;flex:none;border-bottom:1px solid var(--line);background:var(--paper)}
.tab{flex:1;border:0;background:none;padding:13px 0;font-size:14px;font-weight:700;color:var(--soft);cursor:pointer;border-bottom:3px solid transparent}
.tab.on{color:var(--olive);border-bottom-color:var(--olive)}
.tabpane{display:none;overflow:auto;padding:14px;gap:14px;flex-direction:column}
.tabpane.on{display:flex}

.card{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:15px}
.card h3{margin:0 0 6px;font-size:15px;color:var(--olive-d)}
.muted{font-size:12.5px;color:var(--soft);margin:0 0 10px}
.muted.offline{margin-top:10px}
.src{font-size:10.5px;color:var(--soft);font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin:10px 0 0}

.ref-grid,.marco-grid{display:grid;gap:9px}
.ref-grid{grid-template-columns:repeat(4,1fr);margin-bottom:10px}
.marco-grid{grid-template-columns:1fr 1fr;margin-bottom:11px}
label{display:flex;flex-direction:column;font-size:11px;font-weight:700;color:var(--soft);gap:4px;text-transform:uppercase;letter-spacing:.03em}
input{font:inherit;font-size:15px;font-weight:600;color:var(--ink);border:1px solid var(--line);border-radius:10px;padding:9px 10px;background:#fff;width:100%}
input:focus{outline:none;border-color:var(--olive);box-shadow:0 0 0 3px rgba(70,88,44,.12)}

.btn{width:100%;border:1px solid var(--line);background:#fff;color:var(--olive-d);font-weight:700;font-size:14px;border-radius:11px;padding:12px;cursor:pointer}
.btn:hover{border-color:var(--sage)}
.btn.primary{background:var(--terr);border-color:var(--terr);color:#fff}
.btn.ghost{width:auto;padding:7px 13px;font-size:12.5px}

.kv{display:flex;justify-content:space-between;gap:10px;padding:7px 0;border-bottom:1px dashed var(--line);font-size:13.5px}
.kv:last-of-type{border-bottom:0}
.kv span{color:var(--soft)} .kv b{color:var(--olive-d)}

.count{display:flex;gap:10px;margin-top:12px}
.count div{flex:1;background:#eef0e2;border-radius:11px;text-align:center;padding:11px}
.count span{display:block;font-size:24px;font-weight:800;color:var(--olive-d)}
.count small{font-size:10.5px;color:var(--soft);text-transform:uppercase;letter-spacing:.05em}

.seg{display:flex;gap:6px;background:#eef0e2;border-radius:11px;padding:4px;margin-bottom:11px}
.segbtn{flex:1;border:0;background:none;border-radius:8px;padding:8px;font-size:13px;font-weight:700;color:var(--soft);cursor:pointer}
.segbtn.on{background:#fff;color:var(--olive);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.fld{margin-bottom:10px;text-transform:none;letter-spacing:0;font-size:11px}

.cuad-head{display:flex;align-items:center;justify-content:space-between}
.cuad-list{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:8px}
.cuad-list li{display:flex;justify-content:space-between;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:11px;padding:10px 12px}
.cuad-list li.empty{justify-content:center;color:var(--soft);font-size:12.5px;border-style:dashed}
.cuad-list b{font-size:13.5px;color:var(--olive-d);display:block}
.cuad-list small{font-size:11.5px;color:var(--soft)}
.cuad-list .ll{display:flex;align-items:center;gap:8px}
.cuad-list time{font-size:11px;color:var(--soft)}
.cuad-list button{border:0;background:#f3eede;color:var(--terr);border-radius:8px;width:26px;height:26px;cursor:pointer;font-weight:800}

#toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(20px);background:var(--olive-d);color:#fff;padding:11px 18px;border-radius:999px;font-size:13.5px;font-weight:600;opacity:0;pointer-events:none;transition:.25s;z-index:1000;max-width:90vw}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.err{background:var(--terr)}

/* Inicio / cumplimiento */
.statuscard{border-radius:14px;padding:16px;color:#fff;background:linear-gradient(150deg,#3e7d3a,#54923f);margin-bottom:11px}
.statuscard.warn{background:linear-gradient(150deg,#c98a1f,#d99a2b)}
.statuscard .ic{font-size:24px}
.statuscard h4{margin:6px 0 2px;font-size:17px}
.statuscard p{margin:0;font-size:12.5px;opacity:.93}
.bigbtn{display:flex;align-items:center;gap:11px;width:100%;border:1px solid var(--line);border-radius:13px;background:#fff;padding:14px;margin-top:9px;font-size:14.5px;font-weight:700;color:var(--olive-d);cursor:pointer;text-align:left}
.bigbtn:hover{border-color:var(--sage)}
.bigbtn .plus{width:28px;height:28px;border-radius:8px;background:var(--olive);color:#fff;display:grid;place-items:center;font-size:17px;flex:none}
.bigbtn.sec .plus{background:var(--terr)}
.ministat{display:flex;gap:8px;margin-top:12px}
.ministat>div{flex:1;background:#eef0e2;border-radius:11px;text-align:center;padding:10px}
.ministat .n{display:block;font-size:20px;font-weight:800;color:var(--olive-d)}
.ministat small{font-size:10px;color:var(--soft);text-transform:uppercase;letter-spacing:.05em}

/* leyenda de edición */
.legend{display:flex;flex-wrap:wrap;gap:8px 14px;margin-top:11px;font-size:12px;color:var(--soft)}
.legend span{display:inline-flex;align-items:center;gap:6px}
.legend b{color:var(--ink)}
.legend i{width:11px;height:11px;border-radius:50%;display:inline-block}
.legend .d-sano{background:#5f7d39}
.legend .d-vigor{background:#d99a2b}
.legend .d-marra{background:#f6f3ea;border:2px solid #c0492f}
.legend .d-trat{background:#4a90a4}

/* lista de recintos de la finca */
.rec-list{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:8px}
.rec-list li{border:1px solid var(--line);border-radius:11px;padding:10px 11px;background:#fff;cursor:pointer}
.rec-list li.on{border-color:var(--olive);box-shadow:0 0 0 2px rgba(70,88,44,.14)}
.rl-head{display:flex;justify-content:space-between;gap:8px;align-items:baseline;font-size:12px}
.rl-head b{color:var(--olive-d);font-size:13px}
.rl-head span{color:var(--soft);text-align:right;font-size:11px}
.rl-row{display:flex;gap:7px;margin-top:8px}
.rl-row select{flex:1;font:inherit;font-size:13px;font-weight:600;border:1px solid var(--line);border-radius:9px;padding:7px 8px;background:#fff;color:var(--ink)}
.rl-row button{border:0;background:#f3eede;color:var(--terr);border-radius:8px;width:34px;cursor:pointer;font-weight:800}

select#act-cultivo{font:inherit;font-size:14px;font-weight:600;border:1px solid var(--line);border-radius:10px;padding:9px 10px;background:#fff;color:var(--ink);width:100%}
#act-src{font-size:12px}
#act-src b{color:var(--olive-d)}

/* resumen de la finca */
.resumen{margin-top:12px;display:flex;flex-direction:column;gap:7px}
.res-row{display:flex;align-items:center;gap:9px;font-size:12.5px;background:#eef0e2;border-radius:10px;padding:8px 11px}
.res-row i{width:11px;height:11px;border-radius:50%;flex:none}
.res-row b{color:var(--olive-d)}
.res-row span{color:var(--soft);margin-left:auto;text-align:right}

/* popup de edición de olivo */
.tree-popup .leaflet-popup-content{margin:10px 12px}
.tpop b{font-size:13px;color:var(--olive-d)}
.tpop-row{display:flex;flex-wrap:wrap;gap:5px;margin-top:7px}
.tpop-row button{border:1px solid var(--line);background:#fff;border-radius:8px;padding:6px 9px;font-size:12px;cursor:pointer;color:var(--ink)}
.tpop-row button:hover{border-color:var(--sage)}
.tpop-row button.del{color:var(--terr);border-color:#eecdc2}

/* ficha del recinto */
.ficha{margin-top:14px;border-top:1px solid var(--line);padding-top:12px}
.ficha-t{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--olive-l,#8a9a5b);color:#8a9a5b}
.ficha-est{display:flex;flex-wrap:wrap;gap:7px 12px;margin:8px 0}
.ficha-est span{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--soft)}
.ficha-est i{width:10px;height:10px;border-radius:50%}
.ficha-sub{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#8a9a5b;margin-top:8px}
.ficha-hist{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.ficha-hist div{display:flex;justify-content:space-between;gap:8px;background:#fff;border:1px solid var(--line);border-radius:9px;padding:7px 10px;font-size:12px}
.ficha-hist b{color:var(--olive-d)} .ficha-hist span{color:var(--soft)}
#act-reg{margin-top:10px}

/* chip de vigor NDVI */
.ndvi-chip{display:flex;align-items:center;gap:11px;background:#eef0e2;border:1px solid var(--line);border-radius:11px;padding:10px 12px;margin-top:8px;font-size:13px}
.ndvi-chip .dot{width:15px;height:15px;border-radius:50%;flex:none}
.ndvi-chip b{color:var(--olive-d)}
.ndvi-chip small{display:block;color:var(--soft);font-size:10.5px;margin-top:2px}

/* botón 3D destacado */
.d3btn{background:linear-gradient(120deg,#2f4d22,#46582c 60%,#3f7d8c);border:0;color:#fff;font-weight:800}
.d3btn:hover{filter:brightness(1.08)}

/* avisos */
.alert{display:flex;gap:11px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:9px;border-left:4px solid var(--line)}
.alert.hi{border-left-color:var(--terr)} .alert.md{border-left-color:var(--amber,#d99a2b)} .alert.lo{border-left-color:#6fa3b0}
.alert .ai{font-size:20px;line-height:1.2}
.alert h5{margin:0;font-size:13.5px;color:var(--ink)}
.alert p{margin:3px 0 0;font-size:12px;color:var(--soft)}
.alert .asrc{display:block;margin-top:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#8a9a5b}

/* documento oficial (escrito) */
#doc-overlay{position:fixed;inset:0;z-index:2000;background:rgba(30,33,20,.55);backdrop-filter:blur(2px);overflow:auto;padding:28px 16px}
.doc-paper{max-width:760px;margin:0 auto;background:#fff;border-radius:6px;box-shadow:0 18px 50px rgba(0,0,0,.35);padding:44px 48px 40px;color:#23241d;font-size:14px}
.doc-actions{display:flex;justify-content:flex-end;gap:9px;margin-bottom:18px}
.doc-actions button{border:1px solid var(--line);background:#fff;border-radius:9px;padding:9px 14px;font:inherit;font-size:13px;font-weight:700;color:var(--olive-d);cursor:pointer}
.doc-actions button#doc-print{background:var(--olive);border-color:var(--olive);color:#fff}
.doc-head{display:flex;justify-content:space-between;align-items:flex-end;border-bottom:3px solid var(--olive);padding-bottom:14px}
.doc-k{font-family:Georgia,'Times New Roman',serif;font-size:24px;font-weight:700;color:var(--olive-d);letter-spacing:-.01em}
.doc-sub{font-size:12.5px;color:var(--soft);margin-top:3px}
.doc-logo{font-weight:800;color:var(--olive);font-size:16px}
.doc-meta{width:100%;border-collapse:collapse;margin-top:18px;font-size:13px}
.doc-meta td{padding:7px 10px;border:1px solid var(--line)}
.doc-meta td:nth-child(odd){background:#f4f3ea;font-weight:700;color:var(--olive-d);width:22%}
.doc-recs{margin-top:16px;font-size:13px;line-height:1.6;background:#f8f7f0;border:1px solid var(--line);border-radius:8px;padding:12px 14px}
.doc-recs .dg{color:var(--soft)}
.doc-sec{margin:20px 0 8px;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--olive)}
.doc-tab{width:100%;border-collapse:collapse;font-size:12.5px}
.doc-tab th{background:var(--olive);color:#fff;text-align:left;padding:9px 10px;font-size:11px;text-transform:uppercase;letter-spacing:.03em}
.doc-tab td{padding:8px 10px;border-bottom:1px solid var(--line)}
.doc-tab tbody tr:nth-child(even){background:#faf9f3}
.doc-foot{margin-top:22px;padding-top:14px;border-top:1px solid var(--line);font-size:11px;color:var(--soft);line-height:1.5}
@media print{#doc-overlay{position:static;background:#fff;padding:0}.doc-paper{box-shadow:none;max-width:none}.doc-actions{display:none}}

/* barra: usuario + salir */
.userbox{display:flex;align-items:center;gap:10px;flex:none}
.user-email{font-size:12px;color:#e7e8d2;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
#btn-logout{border:1px solid rgba(255,255,255,.4);background:rgba(255,255,255,.12);color:#fff;font-weight:700;font-size:12px;border-radius:999px;padding:6px 13px;cursor:pointer}
#btn-logout:hover{background:rgba(255,255,255,.22)}

/* overlay de acceso (cuentas) */
#auth-overlay{position:fixed;inset:0;z-index:3000;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(160deg,#46582c,#33401f);overflow:auto}
#auth-overlay[hidden]{display:none}
.auth-card{width:100%;max-width:360px;background:var(--paper);border-radius:18px;padding:24px 22px;box-shadow:0 18px 50px rgba(0,0,0,.35)}
.auth-brand{font-weight:800;font-size:22px;color:var(--olive-d);display:flex;align-items:center;gap:8px}
.auth-brand .leaf{font-size:24px}
.auth-sub{font-size:13px;color:var(--soft);margin:6px 0 16px;line-height:1.45}
.auth-seg{margin-bottom:14px}
.auth-err{background:#fdecea;border:1px solid #f3c0b8;color:#a8341f;font-size:12.5px;font-weight:600;border-radius:9px;padding:9px 11px;margin:10px 0 0}
.auth-foot{margin:14px 0 0;font-size:11px;line-height:1.5}
#auth-submit{margin-top:4px}

@media(max-width:760px){
  #main{flex-direction:column}
  #map{height:46vh;flex:none}
  #side{width:100%;flex:1}
  .hint{display:none}
  .user-email{max-width:96px}
}
