/* garde.baldassa.ch — app.css */
:root{
  --teal:#1d9e75; --teal-d:#0f6e56; --teal-l:#e1f5ee;
  --bg:#f2f1ec; --bg-card:#ffffff; --bg-sec:#eceae3;
  --txt:#1c1c1e; --txt-sec:#6b6b70; --txt-ter:#a0a0a6;
  --bord:rgba(0,0,0,.08); --bord-2:rgba(0,0,0,.14);
  --danger:#d8433a; --danger-bg:#fbe9e8;
  --warn:#a26a08; --warn-bg:#faeeda;
  --safe-top:env(safe-area-inset-top,0px);
  --safe-bot:env(safe-area-inset-bottom,0px);
  --nav-h:calc(58px + var(--safe-bot));
}
@media (prefers-color-scheme:dark){
  :root{
    --bg:#000000; --bg-card:#1c1c1e; --bg-sec:#2c2c2e;
    --txt:#ffffff; --txt-sec:#a0a0a6; --txt-ter:#636366;
    --bord:rgba(255,255,255,.12); --bord-2:rgba(255,255,255,.2);
    --teal-l:#15352b; --danger-bg:#3a1816; --warn-bg:#3a2a10;
  }
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;background:var(--bg);color:var(--txt);
  font-family:-apple-system,BlinkMacSystemFont,"SF Pro Text","Helvetica Neue",sans-serif;
  -webkit-font-smoothing:antialiased;overscroll-behavior-y:none}
body{padding-bottom:var(--nav-h)}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:16px}
.hidden{display:none!important}

/* En-tête de page */
.page-head{padding:calc(var(--safe-top) + 8px) 20px 8px;display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.page-head h1{font-size:28px;font-weight:700;margin:0;letter-spacing:-.5px}
.page-head .sub{font-size:13px;color:var(--txt-sec);margin-top:2px}
.head-btn{width:38px;height:38px;border-radius:50%;border:none;background:var(--bg-sec);
  color:var(--teal-d);display:flex;align-items:center;justify-content:center;font-size:20px;position:relative}
.badge-dot{position:absolute;top:-2px;right:-2px;min-width:18px;height:18px;border-radius:9px;
  background:var(--danger);color:#fff;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;padding:0 4px}

/* Recherche */
.search{margin:6px 16px 12px;display:flex;align-items:center;gap:8px;background:var(--bg-sec);
  border-radius:11px;padding:9px 12px;color:var(--txt-ter)}
.search input{border:none;background:none;outline:none;flex:1;color:var(--txt);font-size:16px}

/* Listes groupées iOS */
.group-label{font-size:13px;font-weight:600;color:var(--txt-sec);text-transform:uppercase;
  letter-spacing:.4px;margin:14px 0 6px;padding:0 20px}
.card{background:var(--bg-card);margin:0 16px 14px;border-radius:14px;border:.5px solid var(--bord);overflow:hidden}
.row{display:flex;align-items:center;gap:13px;padding:13px 16px;background:none;border:none;width:100%;text-align:left;color:var(--txt)}
.row + .row{border-top:.5px solid var(--bord)}
.row .ic{width:34px;height:34px;border-radius:9px;background:var(--teal-l);color:var(--teal-d);
  display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}
.row .ic.photo{background:var(--bg-sec);color:var(--txt-ter)}
.row .main{flex:1;min-width:0;display:flex;flex-direction:column}
.row .t{font-size:16px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row .s{font-size:13px;color:var(--txt-sec);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:3px}
.row.zone-row{padding:15px 16px}
.row.zone-row .t{font-size:17px;font-weight:600}
.row.zone-row .s{margin-top:5px}
.row .chev{color:var(--txt-ter);font-size:18px}
.row .qty-num{font-size:17px;font-weight:600;min-width:20px;text-align:center}
.sub-row{background:var(--bg-sec)}
.sub-row .t{color:var(--txt-sec)}

/* Drag & drop réglages */
.dd-zone{margin:0 16px 14px;background:var(--bg-card);border-radius:14px;border:.5px solid var(--bord);overflow:hidden}
.dd-zone-head{display:flex;align-items:center;gap:10px;padding:12px 14px;font-weight:600;font-size:15px;background:var(--teal-l);color:var(--teal-d)}
.dd-zone-head .handle{cursor:grab;color:var(--teal-d);opacity:.7;font-size:20px;touch-action:none}
.dd-zone-head .zedit{margin-left:auto;font-size:13px;font-weight:400;color:var(--teal-d)}
.dd-item{display:flex;align-items:center;gap:12px;padding:13px 14px;border-top:.5px solid var(--bord);background:var(--bg-card)}
.dd-item .handle{cursor:grab;color:var(--txt-ter);font-size:22px;touch-action:none;padding:4px}
.dd-item .name{flex:1;font-size:15px}
.dd-item .edit{color:var(--txt-ter);font-size:18px;padding:4px}
.dd-item.dragging{opacity:.5;background:var(--teal-l)}
.dd-item.placeholder{height:48px;background:var(--teal-l);border:1.5px dashed var(--teal);border-radius:8px;margin:2px 8px}
.dd-add{display:flex;align-items:center;gap:8px;padding:12px 14px;border-top:.5px solid var(--bord);color:var(--teal-d);font-size:14px;background:none;border-left:none;border-right:none;border-bottom:none;width:100%}
.dd-float{position:fixed;left:0;right:0;z-index:300;pointer-events:none;opacity:.95;box-shadow:0 8px 24px rgba(0,0,0,.3);border-radius:10px}

/* Pills / badges */
.pill{font-size:11px;font-weight:500;padding:2px 9px;border-radius:8px;display:inline-block;margin-top:4px}
.pill.bas{color:var(--warn);background:var(--warn-bg)}
.pill.rupt{color:var(--danger);background:var(--danger-bg)}

/* Boutons */
.btn{border:none;border-radius:12px;padding:13px;font-size:16px;font-weight:600;width:100%;
  display:flex;align-items:center;justify-content:center;gap:8px}
.btn-primary{background:var(--teal);color:#fff}
.btn-sec{background:var(--bg-sec);color:var(--txt)}
.btn-line{background:none;border:.5px solid var(--bord-2);color:var(--txt)}
.btn-danger{background:none;border:.5px solid var(--danger);color:var(--danger)}
.btn:active{transform:scale(.98)}
.btn.small{width:auto;padding:8px 14px;font-size:14px;border-radius:10px}
.pad{padding:0 16px 18px}

/* +/- ronds */
.stepper{display:flex;align-items:center;gap:12px}
.rbtn{width:32px;height:32px;border-radius:50%;border:.5px solid var(--bord-2);background:var(--bg-card);
  color:var(--txt);font-size:18px;display:flex;align-items:center;justify-content:center;padding:0}
.rbtn.plus{border-color:var(--teal);color:var(--teal-d)}
.rbtn:active{transform:scale(.92)}

/* Bottom nav */
.tabbar{position:fixed;left:0;right:0;bottom:0;height:var(--nav-h);padding-bottom:var(--safe-bot);
  background:var(--bg-card);border-top:.5px solid var(--bord);display:flex;z-index:50}
.tab{flex:1;border:none;background:none;color:var(--txt-ter);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:3px;font-size:10px;padding-top:8px;position:relative}
.tab i{font-size:23px}
.tab.active{color:var(--teal-d)}
.tab .badge-dot{position:absolute;top:4px;left:50%;margin-left:6px}

/* Modale feuille (sheet) */
.sheet-bg{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:100;display:flex;align-items:flex-end;
  opacity:0;pointer-events:none;transition:opacity .2s}
.sheet-bg.show{opacity:1;pointer-events:auto}
.sheet{background:var(--bg-card);width:100%;border-radius:20px 20px 0 0;
  padding:8px 0 calc(24px + var(--safe-bot));
  min-height:42vh;max-height:88vh;overflow-y:auto;-webkit-overflow-scrolling:touch;
  transform:translateY(100%);transition:transform .25s;overscroll-behavior:contain}
.sheet-bg.show .sheet{transform:translateY(0)}
.grip{width:38px;height:5px;border-radius:3px;background:var(--bord-2);margin:6px auto 14px}
.sheet h2{font-size:19px;font-weight:700;margin:0 0 4px;padding:0 20px}
.sheet .sub{font-size:13px;color:var(--txt-sec);padding:0 20px;margin-bottom:12px}
.field{margin:0 16px 12px}
.field label{display:block;font-size:13px;color:var(--txt-sec);margin-bottom:5px;padding-left:2px}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:.5px solid var(--bord-2);
  border-radius:11px;background:var(--bg-card);color:var(--txt);outline:none}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--teal)}

/* Scanner */
.scan-frame{position:relative;margin:0 16px;aspect-ratio:4/3;background:#000;border-radius:18px;overflow:hidden}
.scan-frame video{width:100%;height:100%;object-fit:cover}
.scan-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}
.scan-box{width:74%;height:42%;border:2px solid rgba(255,255,255,.9);border-radius:14px;position:relative}
.scan-line{position:absolute;left:6%;right:6%;top:50%;height:2px;background:var(--teal);box-shadow:0 0 8px var(--teal);animation:scan 2s ease-in-out infinite}
@keyframes scan{0%,100%{top:18%}50%{top:82%}}
.scan-hint{position:absolute;bottom:14px;left:0;right:0;text-align:center;color:rgba(255,255,255,.85);font-size:13px}
.mode-tabs{display:flex;gap:8px;padding:0 16px 12px}
.mode-tabs .mt{flex:1;padding:10px;border-radius:11px;border:none;background:var(--bg-sec);color:var(--txt-sec);font-size:14px;font-weight:500}
.mode-tabs .mt.on{background:var(--teal);color:#fff}

/* Métriques accueil */
.metrics{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 16px 8px}
.metric{background:var(--bg-sec);border-radius:12px;padding:14px}
.metric .lbl{font-size:13px;color:var(--txt-sec)}
.metric .val{font-size:26px;font-weight:700;margin-top:4px}
.metric .val.warn{color:var(--warn)}
.metric .val.danger{color:var(--danger)}

/* Toast */
.toast{position:fixed;left:50%;bottom:calc(var(--nav-h) + 14px);transform:translateX(-50%) translateY(20px);
  background:var(--txt);color:var(--bg);padding:11px 18px;border-radius:12px;font-size:14px;font-weight:500;
  opacity:0;pointer-events:none;transition:.25s;z-index:200;max-width:90%}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Login */
.login-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}
.login-logo{width:84px;height:84px;border-radius:22px;background:var(--teal);color:#fff;display:flex;
  align-items:center;justify-content:center;font-size:42px;margin-bottom:18px}
.login-wrap h1{font-size:26px;font-weight:700;margin:0 0 24px}
.login-card{width:100%;max-width:340px}
.login-card .field{margin:0 0 12px}

/* États vides */
.empty{text-align:center;color:var(--txt-ter);padding:40px 24px;font-size:14px}
.empty i{font-size:40px;display:block;margin-bottom:10px;color:var(--bord-2)}

.spinner{width:22px;height:22px;border:2.5px solid var(--bord-2);border-top-color:var(--teal);
  border-radius:50%;animation:spin .7s linear infinite;margin:30px auto}
@keyframes spin{to{transform:rotate(360deg)}}
