:root{
  --verde:#0f3d2e; --verde2:#1c6b4a; --acento:#4ea76e; --acento2:#6fce8f;
  --bg:#f4f7f4; --card:#ffffff; --txt:#1b2b22; --gris:#8aa094; --linea:#e2eae4;
  --rojo:#d9483b; --ambar:#e2a93b;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{font-family:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  background:var(--bg);color:var(--txt);font-size:17px;line-height:1.4}
.hidden{display:none!important}

/* ---- header ---- */
header{position:sticky;top:0;z-index:50;background:var(--verde);color:#fff;
  padding:12px 16px;display:flex;align-items:center;justify-content:space-between;
  box-shadow:0 2px 8px rgba(0,0,0,.15)}
header .t{font-weight:700;font-size:18px;display:flex;align-items:center;gap:8px}
header .who{font-size:13px;opacity:.85}
.estado{font-size:13px;display:flex;align-items:center;gap:6px}
.dot{width:9px;height:9px;border-radius:50%;background:var(--acento2)}
.dot.pend{background:var(--ambar)}
.dot.off{background:var(--rojo)}

/* ---- login ---- */
#login{min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  align-items:center;padding:24px;background:linear-gradient(160deg,var(--verde),var(--verde2))}
#login h1{color:#fff;font-size:26px;margin:0 0 4px;text-align:center}
#login p{color:#cdeecc;margin:0 0 28px;text-align:center}
#login .logo{width:88px;height:88px;margin-bottom:18px}
.names{width:100%;max-width:420px;display:flex;flex-direction:column;gap:12px}
.name-btn{background:#fff;border:none;border-radius:16px;padding:18px 20px;font-size:19px;
  font-weight:600;color:var(--verde);text-align:left;display:flex;align-items:center;gap:14px;
  box-shadow:0 4px 12px rgba(0,0,0,.12)}
.name-btn .ini{width:42px;height:42px;border-radius:50%;background:var(--acento);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700}
.name-btn small{display:block;font-size:13px;color:var(--gris);font-weight:400}

/* ---- main / secciones ---- */
main{max-width:560px;margin:0 auto;padding:12px 12px 120px}
.sec{background:var(--card);border-radius:16px;margin-bottom:12px;overflow:hidden;
  box-shadow:0 2px 8px rgba(0,0,0,.06)}
.sec>.head{display:flex;align-items:center;gap:12px;padding:16px;cursor:pointer;user-select:none}
.sec>.head .ic{font-size:22px}
.sec>.head .tt{flex:1;font-weight:700;font-size:17px}
.sec>.head .resumen{font-size:13px;color:var(--gris);font-weight:500}
.sec>.head .chev{transition:transform .2s;color:var(--gris)}
.sec.open>.head .chev{transform:rotate(180deg)}
.sec>.body{padding:0 16px;max-height:0;overflow:hidden;transition:max-height .25s ease}
.sec.open>.body{max-height:3000px;padding:0 16px 16px}

label.f{display:block;font-size:14px;font-weight:600;color:var(--verde2);margin:14px 0 6px}
select,input[type=text],input[type=number],input[type=date],textarea{
  width:100%;padding:14px;border:1.5px solid var(--linea);border-radius:12px;font-size:17px;
  background:#fbfdfb;color:var(--txt);font-family:inherit}
select:focus,input:focus,textarea:focus{outline:none;border-color:var(--acento)}
textarea{min-height:90px;resize:vertical}

.auto{background:#eaf6ee;border:1px dashed var(--acento);border-radius:12px;padding:12px 14px;
  margin-top:10px;font-size:15px;color:var(--verde2)}
.auto b{color:var(--verde)}
.auto .big{font-size:20px;font-weight:700;color:var(--verde)}

/* segment (cultivo / sistema) */
.seg{display:flex;gap:8px;flex-wrap:wrap}
.seg button{flex:1;min-width:120px;padding:14px;border:1.5px solid var(--linea);border-radius:12px;
  background:#fbfdfb;font-size:16px;font-weight:600;color:var(--txt)}
.seg button.on{background:var(--acento);border-color:var(--acento);color:#fff}

/* stepper +/- */
.stepper{display:flex;align-items:center;gap:0;border:1.5px solid var(--linea);border-radius:12px;
  overflow:hidden;background:#fbfdfb}
.stepper button{width:54px;height:54px;border:none;background:#eef4ef;font-size:26px;
  font-weight:700;color:var(--verde2)}
.stepper button:active{background:var(--acento2)}
.stepper input{border:none;text-align:center;background:transparent;flex:1;font-size:20px;font-weight:700}
.stepper .u{padding-right:12px;color:var(--gris);font-size:14px}

/* intensidad chips */
.chips{display:flex;gap:8px}
.chips button{flex:1;padding:12px;border:1.5px solid var(--linea);border-radius:12px;
  background:#fbfdfb;font-weight:600;font-size:14px}
.chips button.on1{background:#eaf6ee;border-color:var(--acento);color:var(--verde)}
.chips button.on2{background:#fdf4e3;border-color:var(--ambar);color:#8a5a00}
.chips button.on3{background:#fde8e6;border-color:var(--rojo);color:#a11}

/* filas dinamicas */
.row{display:flex;gap:8px;align-items:center;margin-top:10px;flex-wrap:wrap}
.row .grow{flex:1;min-width:120px}
.row .del{width:46px;height:46px;border:none;border-radius:10px;background:#fde8e6;color:var(--rojo);
  font-size:20px;flex:none}
.add{margin-top:12px;width:100%;padding:14px;border:1.5px dashed var(--acento);border-radius:12px;
  background:#eaf6ee;color:var(--verde2);font-weight:700;font-size:16px}

/* progreso slider */
.prog{display:flex;align-items:center;gap:10px}
.prog input[type=range]{flex:1}
.prog .val{width:54px;text-align:right;font-weight:700;color:var(--verde2)}

/* nutrientes grid */
.nut-tabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:6px;margin-top:8px}
.nut-tabs button{padding:10px 14px;border:1.5px solid var(--linea);border-radius:10px;
  background:#fbfdfb;font-weight:600;white-space:nowrap;font-size:14px}
.nut-tabs button.on{background:var(--verde2);color:#fff;border-color:var(--verde2)}
.nut-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.nut-grid label{font-size:13px;color:var(--gris);font-weight:600;display:block;margin-bottom:4px}

/* buscador tabla (modal) */
.buscador{position:fixed;inset:0;background:rgba(15,61,46,.45);z-index:100;display:flex;
  align-items:flex-end}
.buscador .panel{background:#fff;width:100%;max-height:80vh;border-radius:20px 20px 0 0;
  display:flex;flex-direction:column;padding:16px}
.buscador h3{margin:4px 0 10px}
.buscador .lista{overflow:y;overflow-y:auto;flex:1;margin-top:10px}
.buscador .item{padding:14px;border-bottom:1px solid var(--linea);font-size:16px}
.buscador .item b{color:var(--verde)}
.buscador .item small{color:var(--gris);display:block;font-size:13px}
.buscador .cerrar{margin-top:10px;padding:14px;background:#eef4ef;border:none;border-radius:12px;
  font-weight:700;color:var(--verde2);font-size:16px}

.pick-tabla{width:100%;text-align:left;padding:16px;border:1.5px solid var(--linea);border-radius:12px;
  background:#fbfdfb;font-size:17px;color:var(--txt);display:flex;justify-content:space-between;align-items:center}
.pick-tabla.sel{border-color:var(--acento);background:#eaf6ee;font-weight:600;color:var(--verde)}

/* voz */
.voz{margin-top:8px;display:flex;gap:8px}
.voz button{flex:1;padding:13px;border:1.5px solid var(--acento);border-radius:12px;background:#eaf6ee;
  color:var(--verde2);font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;gap:8px}
.voz button.rec{background:var(--rojo);color:#fff;border-color:var(--rojo);animation:pulse 1s infinite}
@keyframes pulse{50%{opacity:.6}}

/* footer enviar */
.barra{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--linea);
  padding:12px 16px;display:flex;gap:12px;align-items:center;z-index:60}
.barra .prom{font-size:13px;color:var(--gris)}
.barra .prom b{font-size:22px;color:var(--verde);display:block}
.barra .enviar{flex:1;padding:16px;background:var(--acento);color:#fff;border:none;border-radius:14px;
  font-size:18px;font-weight:700}
.barra .enviar:disabled{background:#b9d6c4}

.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%);background:var(--verde);
  color:#fff;padding:14px 22px;border-radius:14px;font-weight:600;z-index:200;box-shadow:0 6px 18px rgba(0,0,0,.25)}
