/* ── V1 : repris tel quel ──────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f4f1ea;--surface:#fff;--surface2:#f8f6f1;--border:#e0d9cc;
  --text:#1a1a1a;--muted:#6b6355;
  --accent:#2d6a4f;--accent-light:#d8f3dc;--accent-mid:#52b788;
  --warn:#b5451b;--warn-light:#fdebd6;
  --nord:#3a5ba0;--nord-light:#dde8f8;--nord-mid:#6b8ecf;
  --danger:#c0392b;--danger-light:#fdecea;
  --rain:#1565c0;--rain-light:#e3f0fd;
  --irrig:#7b3fa0;--irrig-light:#f2e8fb;
  --water-row:#f0f7e6;--water-border:#b7dfb0;
  --temp-col:#c0392b;
  --radius:10px;
  --font-body:'Lato',sans-serif;--font-mono:'IBM Plex Mono',monospace;
}
@media(prefers-color-scheme:dark){:root{
  --bg:#161614;--surface:#1e1e1c;--surface2:#252523;--border:#333330;
  --text:#f0ede6;--muted:#9a9486;
  --accent:#52b788;--accent-light:#1a3d2b;--accent-mid:#3a8c61;
  --warn:#f07048;--warn-light:#3a2010;
  --nord:#6b8ecf;--nord-light:#1a2740;--nord-mid:#3a5ba0;
  --danger:#e74c3c;--danger-light:#3a1010;
  --rain:#4a90d9;--rain-light:#0d2a4a;
  --irrig:#b07fd4;--irrig-light:#2a1040;
  --water-row:#1a2d1a;--water-border:#2d6a4f;
  --temp-col:#e74c3c;
}}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh;padding-bottom:env(safe-area-inset-bottom,0px)}

/* HEADER */
header{background:var(--accent);color:#fff;padding:1rem 1.25rem 0;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.18)}
header h1{font-size:1.2rem;font-weight:900;letter-spacing:.02em;text-transform:uppercase}
.header-sub{display:flex;justify-content:space-between;align-items:center;margin-top:2px}
header p{font-size:.82rem;opacity:.8;font-family:var(--font-mono)}
.meteo-pill{font-size:.76rem;font-family:var(--font-mono);background:rgba(255,255,255,.18);border-radius:20px;padding:2px 8px;opacity:.9;white-space:nowrap}
.meteo-pill.ok{background:rgba(255,255,255,.25)}
.meteo-pill.err{background:rgba(220,50,50,.4)}
nav.main-nav{display:flex;margin-top:.85rem}
nav.main-nav button{flex:1;background:transparent;border:none;color:rgba(255,255,255,.6);font-family:var(--font-body);font-weight:700;font-size:.92rem;padding:.65rem 0;cursor:pointer;border-bottom:3px solid transparent;text-transform:uppercase;letter-spacing:.06em;transition:color .15s,border-color .15s}
nav.main-nav button.active{color:#fff;border-bottom-color:#fff}

/* ZONE NAV */
.zone-nav{display:flex;background:var(--surface2);border-bottom:1px solid var(--border);position:sticky;top:94px;z-index:99}
.zone-nav button{flex:1;background:transparent;border:none;border-bottom:3px solid transparent;font-family:var(--font-body);font-weight:700;font-size:.92rem;color:var(--muted);padding:.65rem 0;cursor:pointer;text-transform:uppercase;letter-spacing:.06em;transition:color .15s,border-color .15s,background .15s}
.zone-nav button.active.sud{color:var(--accent);border-bottom-color:var(--accent)}
.zone-nav button.active.nord{color:var(--nord);border-bottom-color:var(--nord)}

/* TABS */
.tab{display:none;padding:0}
.tab.active{display:block}
.zone-tab{display:none;padding:.75rem 1rem 2rem}
.zone-tab.active{display:block}

/* ALERTE */
.alerte-banner{background:var(--warn-light);border:1px solid var(--warn);border-radius:var(--radius);padding:.65rem .9rem;font-size:.88rem;color:var(--warn);font-weight:700;margin-bottom:.85rem;display:none;align-items:center;gap:8px}
.alerte-banner.show{display:flex}

/* CONFIG */
.config-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;overflow:hidden}
.config-header{display:flex;justify-content:space-between;align-items:center;padding:.65rem .9rem;background:var(--surface2);border-bottom:1px solid var(--border);cursor:pointer;user-select:none}
.config-header span{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-family:var(--font-mono)}
.cfg-arrow{font-size:.8rem;color:var(--muted);transition:transform .2s;display:inline-block}
.config-header.open .cfg-arrow{transform:rotate(180deg)}
.config-body{display:none;padding:.75rem .9rem;gap:8px;flex-direction:column}
.config-body.open{display:flex}
.cfg-row{display:grid;grid-template-columns:1fr 80px;align-items:center;gap:8px}
.cfg-row-full{grid-template-columns:1fr;display:flex;flex-direction:column;gap:4px}
.cfg-row-full .cfg-input{width:100%;box-sizing:border-box}
.cfg-hint{font-size:.74rem;color:var(--muted);margin:.2rem 0 .5rem;line-height:1.4}
.cfg-hint code{font-family:var(--font-mono);background:var(--surface2);padding:.1rem .3rem;border-radius:3px;font-size:.72rem}
.cfg-label{font-size:.88rem;color:var(--muted);font-family:var(--font-mono)}
.cfg-label strong{color:var(--text);font-weight:500}
.cfg-input{background:var(--surface2);border:1.5px solid var(--border);border-radius:6px;padding:.4rem .5rem;font-family:var(--font-mono);font-size:.96rem;color:var(--text);text-align:center;width:100%;-moz-appearance:textfield;appearance:textfield}
.cfg-input::-webkit-outer-spin-button,.cfg-input::-webkit-inner-spin-button{-webkit-appearance:none}
.cfg-input:focus{outline:2px solid var(--accent);outline-offset:1px}
.cfg-select{appearance:none;-webkit-appearance:none;cursor:pointer;text-align-last:center}
.btn-cfg-save{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:.5rem .9rem;font-family:var(--font-body);font-weight:700;font-size:.78rem;cursor:pointer;margin-top:.25rem;width:100%}

/* Groupes capteurs */
.cfg-capteur{padding-bottom:.6rem;border-bottom:1px solid var(--border)}
.cfg-capteur:last-of-type{border-bottom:none;padding-bottom:0}
.cfg-capteur-head{font-size:.82rem;font-weight:900;font-family:var(--font-mono);letter-spacing:.05em;padding:.28rem .65rem;border-radius:6px;margin-bottom:4px;display:flex;align-items:center;justify-content:space-between}
.cfg-capteur-head.th-t1{background:rgba(74,144,217,.15);color:#4a90d9}
.cfg-capteur-head.th-t2{background:rgba(126,200,227,.15);color:#7ec8e3}
.cfg-capteur-head.th-t3{background:rgba(230,138,30,.15);color:#e68a1e}

/* TABLEAU — date | capteurs… | °C | actions */
.table-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:.85rem}
.table-header{display:grid;background:var(--surface2);border-bottom:1px solid var(--border);padding:.5rem .5rem;gap:2px}
.th{font-size:.68rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-mono);text-align:center}
.th:first-child{text-align:left}
.th-sub{font-size:.62rem;display:block;font-weight:700;text-transform:none;letter-spacing:.02em}
.th-id{display:block;font-size:.92rem;font-weight:900;letter-spacing:.01em;line-height:1.2}
.th-t1{color:#4a90d9}
.th-t2{color:#7ec8e3}
.th-t3{color:#e68a1e}
.th-temp{color:var(--temp-col)}

/* Groupes de lignes */
.row-group{border-bottom:1px solid var(--border)}
.row-group:last-child{border-bottom:none}

/* Ligne tension */
.data-row{display:grid;padding:.46rem .5rem;gap:2px;align-items:center;transition:background .1s}
.row-group:hover .data-row{background:var(--surface2)}

/* Ligne édition tension */
.edit-row{display:grid;padding:.4rem .5rem;gap:2px;align-items:center;background:var(--surface2)}

/* Ligne eau (affichage) */
.water-data-row{display:grid;padding:.42rem .5rem;gap:2px;align-items:center;background:var(--water-row);border-top:1px solid var(--water-border)}
.row-group:hover .water-data-row{filter:brightness(.97)}
/* Ligne eau (édition) */
.water-edit-row{display:grid;padding:.38rem .5rem;gap:2px;align-items:center;background:var(--water-row);border-top:1px solid var(--water-border)}

.date-cell{font-size:.82rem;color:var(--muted);font-family:var(--font-mono);line-height:1.3}
.val-cell{text-align:center;font-family:var(--font-mono);font-size:.88rem}
.temp-cell{text-align:center;font-family:var(--font-mono);font-size:.8rem;color:var(--temp-col)}
.actions-cell{display:flex;gap:2px;justify-content:center}
.edit-date-col{font-size:.76rem;color:var(--accent);font-family:var(--font-mono);font-weight:700}
.edit-actions{display:flex;gap:2px;justify-content:center;flex-direction:column}
.auto-badge{font-size:.62rem;font-family:var(--font-mono);background:var(--accent-light);color:var(--accent);border-radius:10px;padding:1px 4px;margin-left:2px}

/* Inputs édition */
.edit-input{width:100%;background:var(--surface);border:1.5px solid var(--accent-mid);border-radius:5px;padding:.32rem .15rem;font-family:var(--font-mono);font-size:.88rem;color:var(--text);text-align:center;-moz-appearance:textfield;appearance:textfield}
.edit-input::-webkit-outer-spin-button,.edit-input::-webkit-inner-spin-button{-webkit-appearance:none}
.edit-input:focus{outline:2px solid var(--accent);outline-offset:1px}
.edit-date-input{width:100%;background:var(--surface);border:1.5px solid var(--accent-mid);border-radius:5px;padding:.32rem .2rem;font-family:var(--font-mono);font-size:.82rem;color:var(--text);text-align:center}
.edit-date-input:focus{outline:2px solid var(--accent);outline-offset:1px}
.edit-water-input{background:var(--surface);border:1.5px solid var(--water-border);border-radius:5px;padding:.32rem .15rem;font-family:var(--font-mono);font-size:.88rem;color:var(--text);text-align:center;-moz-appearance:textfield;appearance:textfield;width:100%}
.edit-water-input::-webkit-outer-spin-button,.edit-water-input::-webkit-inner-spin-button{-webkit-appearance:none}
.edit-water-sel{width:100%;background:var(--surface);border:1.5px solid var(--water-border);border-radius:5px;padding:.28rem .1rem;font-family:var(--font-mono);font-size:.82rem;color:var(--text);cursor:pointer;appearance:none;-webkit-appearance:none;text-align-last:center}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:2px;font-size:.74rem;font-family:var(--font-mono);padding:3px 7px;border-radius:20px;font-weight:500;white-space:nowrap}
.badge-ok{background:var(--accent-light);color:var(--accent)}
.badge-warn{background:var(--warn-light);color:var(--warn)}
.badge-na{background:var(--surface2);color:var(--muted);border:1px solid var(--border)}
.badge .zero{font-size:.64rem;opacity:.65}
.water-badge{display:inline-flex;align-items:center;gap:3px;font-size:.74rem;font-family:var(--font-mono);padding:3px 8px;border-radius:20px;font-weight:500}
.water-badge.pluie{background:var(--rain-light);color:var(--rain)}
.water-badge.irrig{background:var(--irrig-light);color:var(--irrig)}

/* SAISIE */
.input-row{display:grid;padding:.48rem .5rem;gap:2px;align-items:center;background:var(--accent-light);border-top:1.5px solid var(--accent-mid)}
.input-water-row{display:grid;grid-template-columns:50px 1fr 1fr 50px;padding:.35rem .5rem .45rem;gap:3px;align-items:center;background:var(--water-row);border-top:1px solid var(--water-border)}
.today-label{font-size:.78rem;color:var(--accent);font-family:var(--font-mono);font-weight:500;line-height:1.3}
.water-label{font-size:.74rem;color:var(--accent);font-family:var(--font-mono);font-weight:500;opacity:.8}
.num-input{width:100%;background:var(--surface);border:1.5px solid var(--accent-mid);border-radius:5px;padding:.38rem .15rem;font-family:var(--font-mono);font-size:.9rem;color:var(--text);text-align:center;-moz-appearance:textfield;appearance:textfield}
.num-input::-webkit-outer-spin-button,.num-input::-webkit-inner-spin-button{-webkit-appearance:none}
.num-input:focus{outline:2px solid var(--accent);outline-offset:1px}
.water-mm-input{width:100%;background:var(--surface);border:1.5px solid var(--water-border);border-radius:5px;padding:.34rem .15rem;font-family:var(--font-mono);font-size:.88rem;color:var(--text);text-align:center;-moz-appearance:textfield;appearance:textfield}
.water-mm-input::-webkit-outer-spin-button,.water-mm-input::-webkit-inner-spin-button{-webkit-appearance:none}
.water-mm-input:focus{outline:2px solid var(--accent);outline-offset:1px}
.water-type-sel{width:100%;background:var(--surface);border:1.5px solid var(--water-border);border-radius:5px;padding:.3rem .05rem;font-family:var(--font-mono);font-size:.82rem;color:var(--text);cursor:pointer;appearance:none;-webkit-appearance:none;text-align-last:center}
.temp-placeholder{text-align:center;font-size:.74rem;color:var(--muted);font-family:var(--font-mono);opacity:.4}

.btn-save{width:100%;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);padding:.8rem;font-family:var(--font-body);font-weight:700;font-size:.9rem;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;margin-top:.65rem;transition:background .15s,transform .1s}
.btn-save:active{transform:scale(.97)}

.icon-btn{width:28px;height:28px;border:none;border-radius:5px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.88rem;transition:background .12s,transform .1s;flex-shrink:0}
.icon-btn:active{transform:scale(.93)}
.btn-edit{background:var(--surface2);color:var(--muted)}
.btn-edit:hover{background:var(--accent-light);color:var(--accent)}
.btn-delete{background:var(--surface2);color:var(--muted)}
.btn-delete:hover{background:var(--danger-light);color:var(--danger)}
.btn-ok{background:var(--accent-light);color:var(--accent)}
.btn-cancel{background:var(--surface2);color:var(--muted)}

/* GRAPHIQUE */
.chart-controls{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:.85rem}
.chip{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:.35rem .85rem;font-size:.84rem;font-family:var(--font-mono);color:var(--muted);cursor:pointer;transition:.12s}
.chip.active{background:var(--accent);border-color:var(--accent);color:#fff}
.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem;margin-bottom:.85rem}
.chart-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-family:var(--font-mono);margin-bottom:.7rem}
.legend{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:.6rem}
.leg-item{display:flex;align-items:center;gap:4px;font-size:.76rem;color:var(--muted);font-family:var(--font-mono)}
.leg-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.65rem .8rem}
.stat-label{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;font-family:var(--font-mono);margin-bottom:3px}
.stat-val{font-size:1.2rem;font-weight:700;font-family:var(--font-mono)}
.empty-state{text-align:center;color:var(--muted);font-size:.85rem;padding:2.5rem 1rem;font-family:var(--font-mono)}
.zone-selector{display:flex;gap:6px;margin-bottom:.85rem}
.zone-selector button{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:.45rem;font-family:var(--font-mono);font-size:.84rem;color:var(--muted);cursor:pointer;transition:.15s;font-weight:500}
.zone-selector button.active{background:var(--accent);border-color:var(--accent);color:#fff}

/* EXPORT */
.btn-export{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.65rem 1rem;font-family:var(--font-body);font-weight:700;font-size:.82rem;color:var(--text);cursor:pointer;width:100%;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .12s}
.btn-export:hover{background:var(--surface2)}

/* CONFIRM */
.confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;display:flex;align-items:center;justify-content:center;padding:1rem}
.confirm-box{background:var(--surface);border-radius:var(--radius);padding:1.25rem;max-width:300px;width:100%;border:1px solid var(--border)}
.confirm-box h3{font-size:1rem;font-weight:700;margin-bottom:.5rem}
.confirm-box p{font-size:.85rem;color:var(--muted);margin-bottom:1rem}
.confirm-btns{display:flex;gap:8px}
.confirm-btns button{flex:1;padding:.6rem;border:none;border-radius:6px;font-family:var(--font-body);font-weight:700;font-size:.85rem;cursor:pointer}
.btn-confirm-yes{background:var(--danger);color:#fff}
.btn-confirm-no{background:var(--surface2);color:var(--text);border:1px solid var(--border)!important}

.loading{text-align:center;padding:1.5rem;color:var(--muted);font-family:var(--font-mono);font-size:.8rem}

/* ── VUE PUBLIQUE ──────────────────────────────────────────────────── */
.pub-header{background:var(--accent);color:#fff;padding:.7rem 1.1rem .5rem;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.18)}
.pub-header-top{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}
.pub-logo{font-size:1.15rem;font-weight:900;letter-spacing:.02em;text-transform:uppercase;margin:0}
.pub-range-bar{justify-content:flex-start;gap:.45rem;padding:0 0 .4rem}
.pub-range-bar .chip{font-size:.8rem;padding:.3rem .75rem}
.btn-connexion{background:#fff;color:var(--accent);border:none;border-radius:20px;padding:.45rem 1.1rem;font-family:var(--font-body);font-weight:800;font-size:.88rem;cursor:pointer;transition:background .15s,transform .1s;white-space:nowrap;flex-shrink:0;box-shadow:0 1px 4px rgba(0,0,0,.15)}
.btn-connexion:hover{background:rgba(255,255,255,.88)}
.btn-connexion:active{transform:scale(.96)}
.pub-charts-container{padding:.5rem 0}
.pub-parcelle-block{border-bottom:2px solid var(--border);padding-bottom:1.5rem;margin-bottom:1.5rem}
.pub-parcelle-block:last-child{border-bottom:none;margin-bottom:0}
.pub-parcelle-header{font-size:.95rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);padding:.85rem 1rem .5rem;font-family:var(--font-mono)}
.pub-zone-nav{border-bottom:1px solid var(--border)}
#pub-chart-area{padding:1rem 1rem 2rem}

/* ── VUE LOGIN ─────────────────────────────────────────────────────── */
#view-login{display:flex;flex-direction:column;min-height:100dvh}
.login-header{justify-content:space-between}
.login-back-btn{background:transparent;border:none;color:#fff;font-size:1.1rem;cursor:pointer;padding:.25rem .5rem;border-radius:6px;line-height:1;width:40px;text-align:left}
.login-back-btn:hover{background:rgba(255,255,255,.2)}
#login-step-users,#login-step-pin{flex:1;display:flex;flex-direction:column;justify-content:center;padding-bottom:env(safe-area-inset-bottom,0px)}
.login-hint{text-align:center;color:var(--muted);font-size:.85rem;font-family:var(--font-mono);padding:.75rem 1rem .5rem}
.login-users-grid{display:grid;gap:.85rem;padding:.75rem 1.25rem 1rem;justify-content:center;margin:0 auto;width:100%;box-sizing:border-box}
.login-user-btn{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:1.35rem .75rem;font-family:var(--font-body);font-weight:700;font-size:1.05rem;color:var(--text);cursor:pointer;text-align:center;line-height:1.3;transition:border-color .15s,background .15s,transform .1s;box-shadow:0 1px 4px rgba(0,0,0,.08);width:100%}
.login-user-btn:hover{border-color:var(--accent);background:var(--accent-light);color:var(--accent)}
.login-user-btn:active{transform:scale(.95)}

/* ── PAVÉ NUMÉRIQUE PIN ────────────────────────────────────────────── */
.pin-user-name{text-align:center;font-size:1.15rem;font-weight:900;color:var(--text);letter-spacing:.01em;padding:0 1rem .5rem;margin:0}
.pin-display{display:flex;justify-content:center;gap:1.1rem;padding:.6rem 0 .4rem}
.pin-dot{width:20px;height:20px;border-radius:50%;border:2.5px solid var(--border);background:transparent;transition:background .1s,border-color .1s}
.pin-dot.filled{background:var(--accent);border-color:var(--accent)}
.pin-dot.error{background:var(--danger);border-color:var(--danger)}
.pin-error{text-align:center;color:var(--danger);font-size:.82rem;font-family:var(--font-mono);min-height:1.4em;padding:.2rem 1rem}
.pin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.55rem;padding:.2rem .9rem .5rem;width:100%;box-sizing:border-box}
.pin-btn{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:1.2rem .5rem;font-family:var(--font-mono);font-size:1.55rem;font-weight:700;color:var(--text);cursor:pointer;text-align:center;user-select:none;box-shadow:0 1px 3px rgba(0,0,0,.08);touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:background .08s}
.pin-btn:hover{background:var(--surface2);border-color:var(--accent-mid)}
.pin-btn:active{transform:scale(.91);background:var(--accent-light)}
.pin-btn-del{font-size:1.15rem;color:var(--muted)}
.pin-btn-del:hover{background:var(--danger-light)!important;border-color:var(--danger)!important;color:var(--danger)}
.pin-back-btn{display:block;width:100%;background:transparent;border:none;color:var(--accent);font-size:.86rem;font-family:var(--font-mono);font-weight:700;cursor:pointer;padding:.65rem 1rem 1rem;text-align:center}
.pin-back-btn:hover{text-decoration:underline}

/* ── VUE ADMIN ─────────────────────────────────────────────────────────── */
.btn-admin-dash{
  background:rgba(255,255,255,.18);border:none;color:#fff;
  border-radius:6px;width:30px;height:30px;cursor:pointer;
  font-size:.9rem;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:background .15s;
}
.btn-admin-dash:hover{background:rgba(255,255,255,.3)}
.admin-create-form{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:1rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.65rem;
}
.admin-input{
  width:100%;background:var(--surface2);border:1.5px solid var(--border);
  border-radius:6px;padding:.5rem .65rem;font-family:var(--font-body);
  font-size:.92rem;color:var(--text);
}
.admin-input:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.admin-check-label{display:flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--muted);cursor:pointer}
.admin-form-btns{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}
.admin-btn-cancel{
  background:var(--surface2);border:1px solid var(--border);color:var(--muted);
  border-radius:6px;padding:.4rem .9rem;font-family:var(--font-body);font-weight:700;
  font-size:.78rem;cursor:pointer;transition:background .12s;
}
.admin-btn-cancel:hover{background:var(--danger-light);color:var(--danger);border-color:var(--danger)}
.admin-user-row{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:.7rem 1rem;display:flex;align-items:center;gap:.75rem;margin-bottom:.45rem;
}
.admin-user-info{flex:1;min-width:0}
.admin-user-name{display:block;font-weight:700;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-user-email{display:block;font-size:.74rem;color:var(--muted);font-family:var(--font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-user-meta{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.admin-user-date{font-size:.7rem;color:var(--muted);font-family:var(--font-mono);white-space:nowrap}
.admin-user-actions{display:flex;gap:.3rem;flex-shrink:0}
.pin-reset-name{font-size:.9rem;color:var(--muted);margin-bottom:.75rem}
.pin-reset-field{font-size:1.5rem;letter-spacing:.4em;text-align:center;width:100%;margin-bottom:.4rem;display:block}
.pin-reset-error{font-size:.8rem;color:var(--danger);min-height:1.2em;margin-bottom:.25rem;text-align:center}
.toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%) translateY(80px);background:var(--accent);color:#fff;padding:.65rem 1.3rem;border-radius:40px;font-size:.82rem;font-weight:700;transition:transform .3s cubic-bezier(.4,1.4,.6,1);z-index:999;white-space:nowrap;pointer-events:none}
.toast.show{transform:translateX(-50%) translateY(0)}

#tab-releves{padding:0}
#tab-graphique{padding:1rem 1rem 2rem}
.chart-canvas-wrap{position:relative;width:100%;height:280px}
.zone-heading{display:none}

/* ── DESKTOP (≥ 900px) ──────────────────────────────────────────────── */
@media(min-width:900px){
  html{background:var(--bg)}
  body{max-width:1240px;margin:0 auto;box-shadow:0 0 0 1px var(--border)}

  header{padding:1.25rem 2.5rem 0}
  header h1{font-size:1.4rem}
  header p{font-size:.85rem}
  .meteo-pill{font-size:.8rem;padding:4px 14px}
  .header-status-txt{display:inline}
  nav.main-nav button{flex:0 0 auto;font-size:.9rem;padding:.75rem 2.5rem}

  .zone-nav{display:none}

  #tab-releves.tab.active{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;padding:1.5rem;align-items:start}
  .zone-tab,.zone-tab.active{display:block;padding:0}

  .zone-heading{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase;padding:.65rem 1rem;border-radius:var(--radius);margin-bottom:1rem}

  .th{font-size:.76rem}
  .th-id{font-size:1.08rem}
  .th-sub{font-size:.66rem}
  .date-cell{font-size:.9rem}
  .val-cell{font-size:.92rem}
  .temp-cell{font-size:.85rem}
  .badge{font-size:.76rem;padding:3px 8px}
  .badge .zero{font-size:.65rem}
  .water-badge{font-size:.76rem;padding:3px 9px}
  .today-label{font-size:.82rem}
  .water-label{font-size:.78rem;opacity:1}
  .icon-btn{width:30px;height:30px;font-size:.88rem}
  .alerte-banner{font-size:.88rem}

  .config-body.open{flex-direction:row;flex-wrap:wrap;gap:10px}
  .cfg-row{flex:1 1 calc(50% - 10px)}
  .cfg-label{font-size:.85rem}
  .cfg-input{font-size:.95rem;padding:.45rem .6rem}
  .btn-cfg-save{margin-top:0;width:auto;align-self:flex-end;padding:.5rem 1.2rem}

  .cfg-capteurs.open{flex-direction:row;flex-wrap:nowrap;align-items:stretch;gap:12px}
  .cfg-capteur{flex:1;border-bottom:none;border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;background:var(--surface2);display:flex;flex-direction:column;gap:6px}
  .cfg-capteur .cfg-row{flex:none}
  .cfg-footer{padding:.65rem 0 0}
  .cfg-footer-btns{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
  .cfg-footer-btns .btn-cfg-save{width:auto;margin-top:0}

  .num-input,.edit-input{font-size:.88rem}
  .water-mm-input,.edit-water-input{font-size:.85rem}
  .edit-date-input{font-size:.8rem}
  .btn-save{font-size:.95rem;padding:.9rem}

  #tab-graphique{padding:1.5rem 2rem 2.5rem}
  .chart-canvas-wrap{height:420px}
  .stats-grid{grid-template-columns:repeat(3,1fr);gap:12px}
  .stat-label{font-size:.7rem}
  .stat-val{font-size:1.3rem}
  .chart-card{padding:1.25rem 1.5rem}
  .chart-title{font-size:.8rem}
  .legend{gap:14px;margin-bottom:.85rem}
  .leg-item{font-size:.78rem}
  .leg-dot{width:12px;height:12px}
  .chip{font-size:.82rem;padding:.38rem 1rem}
  .btn-export{width:auto;padding:.65rem 1.75rem}
  .zone-selector button{flex:0 0 auto;padding:.45rem 1.5rem;font-size:.82rem}
}


/* ════════════════════════════════════════════════════════════════════════
   V2 — extensions (login, dashboard, multi-parcelle, zones dynamiques)
   ════════════════════════════════════════════════════════════════════════ */

/* ── Système de vues ─────────────────────────────────────────────────── */
[hidden]{display:none!important}

/* ── Vue LOGIN ───────────────────────────────────────────────────────── */
#view-login{
  display:flex;align-items:center;justify-content:center;
  min-height:100vh;padding:1.5rem 1rem;
  background:var(--bg);
}
.login-card{
  width:100%;max-width:360px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:2.25rem 2rem;
  box-shadow:0 4px 20px rgba(0,0,0,.15);
}
.login-logo{
  font-family:var(--font-mono);font-size:1.5rem;font-weight:500;
  color:var(--accent);text-align:center;margin-bottom:.25rem;
}
.login-tagline{
  text-align:center;font-size:.8rem;color:var(--muted);
  font-family:var(--font-mono);margin-bottom:2rem;
}
.login-form{display:flex;flex-direction:column;gap:1.1rem}
.login-field{display:flex;flex-direction:column;gap:.35rem}
.login-field label{
  font-size:.75rem;font-weight:700;color:var(--muted);
  text-transform:uppercase;letter-spacing:.06em;
}
.login-field input{
  background:var(--surface2);border:1.5px solid var(--border);
  border-radius:6px;padding:.5rem .75rem;
  font-family:var(--font-body);font-size:.9375rem;color:var(--text);
  -webkit-appearance:none;appearance:none;width:100%;
  transition:border-color .15s;
}
.login-field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(82,183,136,.12)}
.login-error{
  font-size:.875rem;color:var(--warn);
  background:var(--warn-light);border:1px solid var(--warn);
  border-radius:6px;padding:.5rem .75rem;text-align:center;
}
.btn-login{
  width:100%;background:var(--accent);color:#fff;border:none;
  border-radius:var(--radius);padding:.75rem;
  font-family:var(--font-body);font-weight:700;font-size:.9rem;
  letter-spacing:.04em;text-transform:uppercase;cursor:pointer;
  transition:background .15s,transform .1s;
}
.btn-login:hover:not(:disabled){background:var(--accent-mid);}
.btn-login:active{transform:scale(.97)}
.btn-login:disabled{opacity:.55;cursor:not-allowed}

/* ── Vue DASHBOARD ───────────────────────────────────────────────────── */
.dash-header{
  background:var(--accent);color:#fff;
  padding:.85rem 1.25rem;
  position:sticky;top:0;z-index:100;
  box-shadow:0 2px 8px rgba(0,0,0,.18);
  display:flex;align-items:center;gap:.75rem;
}
.dash-logo{font-size:1.1rem;font-weight:900;letter-spacing:.02em;text-transform:uppercase;flex:1}
.dash-header-user{font-size:.78rem;font-family:var(--font-mono);opacity:.8;white-space:nowrap}
.btn-logout-dash{
  background:rgba(255,255,255,.18);border:none;color:#fff;
  border-radius:6px;width:30px;height:30px;cursor:pointer;
  font-size:.9rem;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:background .15s;
}
.btn-logout-dash:hover{background:rgba(255,255,255,.3)}
.dash-main{padding:1.5rem 1rem 3rem;max-width:900px;margin:0 auto}
.dash-section-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:.85rem}
.dash-section-label{
  font-size:.75rem;font-weight:700;color:var(--muted);
  text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-mono);
}
.btn-new-parcelle{
  background:var(--accent);color:#fff;border:none;border-radius:6px;
  padding:.4rem .9rem;font-family:var(--font-body);font-weight:700;
  font-size:.78rem;cursor:pointer;letter-spacing:.03em;
  transition:background .15s;
}
.btn-new-parcelle:hover{background:var(--accent-mid)}
.parcelles-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:.85rem;
}
.parcelle-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:.9rem 1rem;
  cursor:pointer;transition:border-color .15s,transform .1s;
  text-align:left;display:flex;align-items:center;gap:.5rem;
}
.parcelle-card:hover{border-color:var(--accent-mid);transform:translateY(-1px)}
.parcelle-card:active{transform:none}
.parcelle-card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.parcelle-card-body{flex:1;min-width:0}
.parcelle-card h2{font-size:.95rem;font-weight:700;margin-bottom:.2rem}
.parcelle-card p{font-size:.78rem;color:var(--muted);font-family:var(--font-mono)}
.parcelle-del-btn{flex-shrink:0;opacity:.45;background:var(--surface2);color:var(--muted)}
.parcelle-del-btn:hover{opacity:1;background:var(--danger-light);color:var(--danger)}
.add-zone-section{padding:1rem;border-top:1px solid var(--border);margin-top:.5rem}
.btn-add-zone{background:var(--surface2);border:1.5px dashed var(--border);color:var(--muted);
  border-radius:var(--radius);padding:.55rem 1.2rem;font-family:var(--font-body);font-weight:700;
  font-size:.85rem;cursor:pointer;width:100%;transition:border-color .15s,color .15s}
.btn-add-zone:hover{border-color:var(--accent);color:var(--accent)}
.btn-delete-zone{background:transparent;border:none;color:var(--danger);font-family:var(--font-body);
  font-size:.78rem;cursor:pointer;padding:.3rem 0;margin-top:.5rem;text-align:left;
  opacity:.7;transition:opacity .12s}
.btn-delete-zone:hover{opacity:1}
.cfg-del-cap{width:22px;height:22px;font-size:.72rem;opacity:.45;background:var(--surface2);color:var(--muted)}
.cfg-del-cap:hover{opacity:1;background:var(--danger-light);color:var(--danger)}
.cfg-footer{display:none}
.cfg-footer.open{display:block;padding:.65rem 0 0}
.cfg-add-cap{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:.65rem;margin-bottom:.5rem}
.cfg-add-cap-row{display:flex;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}
.cfg-add-cap-row .cfg-input{flex:1;min-width:120px}
.btn-cfg-add{background:transparent;border:1.5px dashed var(--border);color:var(--muted);
  border-radius:6px;padding:.35rem .8rem;font-family:var(--font-body);font-weight:700;
  font-size:.78rem;cursor:pointer;width:100%;margin-top:.5rem;transition:border-color .15s,color .15s}
.btn-cfg-add:hover{border-color:var(--accent);color:var(--accent)}

/* ── En-tête parcelle ──────────────────────────────────────────────────── */
.header-row{display:flex;align-items:center;gap:.6rem;overflow:hidden}
.app-logo{font-size:1rem;font-weight:900;color:#fff;flex:1;margin:0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* Masqué sur mobile : prend trop de place dans le bandeau */
.header-status-txt{display:none}
.btn-back-hdr{
  background:rgba(255,255,255,.18);border:none;color:#fff;
  border-radius:6px;width:30px;height:30px;flex-shrink:0;
  font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .15s;
}
.btn-back-hdr:hover{background:rgba(255,255,255,.3)}
.parcelle-tabs-bar{
  display:flex;overflow-x:auto;scrollbar-width:none;
  background:rgba(0,0,0,.15);
}
.parcelle-tabs-bar::-webkit-scrollbar{display:none}
.parcelle-tab{
  background:transparent;border:none;border-bottom:3px solid transparent;
  padding:.55rem 1rem;font-family:var(--font-body);font-weight:700;font-size:.82rem;
  color:rgba(255,255,255,.6);cursor:pointer;white-space:nowrap;flex-shrink:0;
  transition:color .15s,border-color .15s;
}
.parcelle-tab.active{color:#fff;border-bottom-color:rgba(255,255,255,.9)}
.parcelle-tab:hover:not(.active){color:rgba(255,255,255,.85)}
.header-right-group{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.header-status-txt{font-size:.76rem;font-family:var(--font-mono);opacity:.8}
.btn-logout-hdr{
  background:rgba(255,255,255,.18);border:none;color:#fff;
  border-radius:6px;width:28px;height:28px;cursor:pointer;
  font-size:.85rem;display:flex;align-items:center;justify-content:center;
  transition:background .15s;flex-shrink:0;
}
.btn-logout-hdr:hover{background:rgba(255,255,255,.3)}

/* ── Zones dynamiques (remplace les classes .sud / .nord fixes) ──────── */
/* Les couleurs sont injectées via style inline sur les boutons et headings */
.zone-nav button.active{
  border-bottom-color:var(--zone-color,var(--accent));
  color:var(--zone-color,var(--accent));
  background:color-mix(in srgb, var(--zone-color,var(--accent)) 14%, transparent);
}
.zone-heading{background:var(--zone-bg,var(--accent-light));color:var(--zone-color,var(--accent))}

/* ── Colonnes de tableau dynamiques selon nb capteurs ─────────────────
   V2 génère grid-template-columns inline ; ces classes définissent
   l'espacement et l'affichage commun à toutes les lignes.            */
.table-header,.data-row,.input-row,.edit-row,.water-data-row,.water-edit-row{
  display:grid;gap:2px;
}
/* Valeurs par défaut 3 capteurs (rétrocompat si inline manque) */
.table-header,.data-row,.input-row{
  grid-template-columns:50px 1fr 1fr 1fr 38px 50px;
}
.edit-row{grid-template-columns:50px 60px 1fr 1fr 1fr 38px 50px;}
.water-data-row{grid-template-columns:50px 1fr 1fr 1fr 38px 50px;}
.water-edit-row{grid-template-columns:50px 60px 1fr 1fr 50px;}

/* ── Desktop overrides pour les largeurs dynamiques ─────────────────── */
@media(min-width:900px){
  .table-header,.data-row,.input-row{padding:.65rem 1rem;gap:8px}
  .edit-row{padding:.6rem 1rem;gap:8px}
  .water-data-row{padding:.45rem 1rem;gap:8px}
  .water-edit-row{padding:.42rem 1rem;gap:8px}
  .input-water-row{padding:.45rem 1rem .6rem;gap:8px}
}

/* Zones desktop : heading coloré repris du V1 */
@media(min-width:900px){
  .zone-heading{
    display:flex;align-items:center;gap:8px;
    font-size:1rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase;
    padding:.65rem 1rem;border-radius:var(--radius);margin-bottom:1rem;
  }
  /* Le grid s'applique sur #zones-content (wrapper direct des zone-tab),
     pas sur #tab-releves dont l'enfant unique est ce wrapper. */
  #tab-releves.tab.active{display:block;padding:1.5rem}
  #zones-content{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1.5rem;align-items:start}
  .dash-header{max-width:1240px}
}
