:root {
  --bg:#f5f4f0;--surface:#ffffff;--surface2:#f0ede8;--border:#ddd9d0;
  --text:#1a1a18;--text2:#5a5850;--text3:#8a8880;
  --red:#c0392b;--red-bg:#fdf0ef;--red-border:#e8b4b0;
  --orange:#d35400;--orange-bg:#fef5ee;--orange-border:#f0c8a0;
  --green:#27ae60;--green-bg:#edfaf3;--green-border:#a8ddc0;
  --blue:#2980b9;--blue-bg:#eaf4fd;--blue-border:#a0cce8;
  --yellow:#f39c12;--yellow-bg:#fefaee;--yellow-border:#f0dca0;
  --purple:#8e44ad;--purple-bg:#f5eef8;--purple-border:#d7bde2;
  --brand:#1a1a2e;--accent:#e74c3c;
  --radius:8px;--radius-lg:12px;
  --shadow:0 1px 4px rgba(0,0,0,0.08);--shadow-md:0 2px 12px rgba(0,0,0,0.12);
  font-size:15px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}
.hidden{display:none!important}
.app{display:grid;grid-template-columns:220px 1fr;min-height:100vh}
.sidebar{background:var(--brand);color:#fff;display:flex;flex-direction:column;gap:14px;padding:18px 12px;position:sticky;top:0;height:100vh;overflow-y:auto}
.main{display:flex;flex-direction:column;overflow:hidden}
.brand{font-size:18px;font-weight:700;letter-spacing:-0.5px}
.brand span{color:#e74c3c}
.brand-sub{font-size:10px;color:rgba(255,255,255,0.4);margin-top:1px}
.nav{display:flex;flex-direction:column;gap:2px}
.nav-section{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,0.3);padding:8px 12px 4px}
.nav button{background:none;border:none;color:rgba(255,255,255,0.7);padding:8px 10px;border-radius:var(--radius);cursor:pointer;text-align:left;font-size:13px;transition:all .15s;display:flex;align-items:center;gap:8px;width:100%}
.nav button:hover{background:rgba(255,255,255,0.08);color:#fff}
.nav button.active{background:rgba(255,255,255,0.15);color:#fff;font-weight:500}
.nav-icon{font-size:14px;width:18px;text-align:center;flex-shrink:0}
.nav-badge{background:var(--red);color:#fff;border-radius:10px;padding:0 5px;font-size:10px;font-weight:700;margin-left:auto}
.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:14px 22px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.topbar h1{font-size:20px;font-weight:700;letter-spacing:-0.5px}
.eyebrow{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:2px}
.toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.btn{border:1px solid var(--border);background:var(--surface);color:var(--text);padding:7px 14px;border-radius:var(--radius);cursor:pointer;font-size:13px;font-weight:500;transition:all .15s;white-space:nowrap}
.btn:hover{background:var(--surface2)}.btn:active{transform:scale(0.98)}
.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand)}.btn-primary:hover{background:#2c2c4a}
.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}.btn-danger:hover{background:#a93226}
.btn-success{background:var(--green);color:#fff;border-color:var(--green)}.btn-success:hover{background:#229954}
.btn-warning{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn-purple{background:var(--purple);color:#fff;border-color:var(--purple)}
.btn-ghost{background:none;border-color:transparent;color:var(--text2)}.btn-ghost:hover{background:var(--surface2)}
.btn-xl{padding:14px 24px;font-size:16px;border-radius:var(--radius-lg)}
.btn-hero{padding:20px 28px;font-size:18px;font-weight:700;border-radius:var(--radius-lg);width:100%}
.view{padding:18px 22px;flex:1;overflow-y:auto}
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow)}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px}
.card-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);margin-bottom:5px}
.metric{font-size:34px;font-weight:700;line-height:1}
.card.tone-red{border-color:var(--red-border);background:var(--red-bg)}.card.tone-red .metric{color:var(--red)}
.card.tone-yellow{border-color:var(--yellow-border);background:var(--yellow-bg)}.card.tone-yellow .metric{color:var(--orange)}
.card.tone-blue{border-color:var(--blue-border);background:var(--blue-bg)}.card.tone-blue .metric{color:var(--blue)}
.card.tone-green{border-color:var(--green-border);background:var(--green-bg)}.card.tone-green .metric{color:var(--green)}
.card.tone-purple{border-color:var(--purple-border);background:var(--purple-bg)}.card.tone-purple .metric{color:var(--purple)}
.grid{display:grid;gap:12px}
.cards{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-bottom:12px}
.col2{grid-template-columns:1fr 1fr}.col3{grid-template-columns:1fr 1fr 1fr}
.section-title{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:10px;gap:8px}
.section-title h2{font-size:14px;font-weight:600}
.small{font-size:12px;color:var(--text3)}.muted{color:var(--text2);font-size:13px}
.task-list{display:flex;flex-direction:column;gap:7px}
.task-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;display:flex;align-items:center;gap:10px}
.task-item.expired{border-color:var(--red-border);background:var(--red-bg)}
.task-item.today{border-color:var(--orange-border);background:var(--orange-bg)}
.task-item.upcoming{border-color:var(--yellow-border);background:var(--yellow-bg)}
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}
.badge-red{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}
.badge-orange{background:var(--orange-bg);color:var(--orange);border:1px solid var(--orange-border)}
.badge-green{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}
.badge-blue{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-border)}
.badge-purple{background:var(--purple-bg);color:var(--purple);border:1px solid var(--purple-border)}
.badge-grey{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}
.input{width:100%;padding:8px 11px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;background:var(--surface);color:var(--text);outline:none;transition:border-color .15s}
.input:focus{border-color:var(--brand)}
.input-lg{padding:12px 14px;font-size:16px}
.field{display:flex;flex-direction:column;gap:4px}
.field label,.field>span{font-size:12px;font-weight:500;color:var(--text2)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.stack{display:flex;flex-direction:column;gap:10px}
.status{font-size:13px;color:var(--text3);padding:4px 0}
.status.error{color:var(--red)}.status.ok{color:var(--green)}
.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--brand)}
.login-card{background:var(--surface);border-radius:var(--radius-lg);padding:32px 28px;width:380px;max-width:95vw;box-shadow:var(--shadow-md)}
.me-box{background:rgba(255,255,255,0.08);border-radius:var(--radius);padding:8px 10px}
.me-name{font-size:13px;font-weight:600;color:#fff}
.me-role{font-size:11px;color:rgba(255,255,255,0.5)}
.separator{border:none;border-top:1px solid var(--border);margin:12px 0}
.empty-state{background:var(--surface2);border:1px dashed var(--border);border-radius:var(--radius);padding:18px;text-align:center;color:var(--text3);font-size:13px}

/* Terrain */
.terrain-layout{display:grid;grid-template-columns:1fr 320px;gap:14px}
.fiche-card{background:var(--surface);border:2px solid var(--brand);border-radius:var(--radius-lg);padding:18px}
.fiche-name{font-size:20px;font-weight:700;margin-bottom:4px}
.fiche-info{font-size:13px;color:var(--text2);margin-bottom:10px}
.fiche-expiry-ok{background:var(--green-bg);border:1px solid var(--green-border);color:var(--green);border-radius:var(--radius);padding:8px 12px;font-weight:600;margin-bottom:12px}
.fiche-expiry-warn{background:var(--orange-bg);border:1px solid var(--orange-border);color:var(--orange);border-radius:var(--radius);padding:8px 12px;font-weight:600;margin-bottom:12px}
.fiche-expiry-alert{background:var(--red-bg);border:1px solid var(--red-border);color:var(--red);border-radius:var(--radius);padding:8px 12px;font-weight:600;margin-bottom:12px}
.fiche-actions{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.urgent-item{background:var(--red-bg);border:1px solid var(--red-border);border-radius:var(--radius);padding:9px 11px;cursor:pointer}
.urgent-item:hover{background:#f9e0de}
.last-action{background:var(--green-bg);border:1px solid var(--green-border);border-radius:var(--radius);padding:9px 11px;font-size:13px;color:var(--green)}

/* Camera modal */
.camera-modal{position:fixed;inset:0;background:rgba(0,0,0,0.85);z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}
.camera-modal video{width:min(480px,95vw);border-radius:var(--radius-lg);border:3px solid #fff}
.camera-modal canvas{display:none}
.camera-controls{display:flex;gap:10px}
.photo-preview{width:min(480px,95vw);border-radius:var(--radius-lg);border:3px solid var(--green);object-fit:cover;max-height:300px}

/* OCR panel */
.ocr-panel{background:var(--purple-bg);border:1px solid var(--purple-border);border-radius:var(--radius-lg);padding:14px 16px}
.ocr-field{display:grid;grid-template-columns:120px 1fr;align-items:center;gap:8px;margin-bottom:6px}
.ocr-label{font-size:12px;color:var(--text3);font-weight:500}
.ocr-value{font-size:13px;font-weight:600;color:var(--text)}
.ocr-edit{font-size:13px;padding:4px 8px;border:1px solid var(--border);border-radius:4px;background:var(--surface);width:100%}
.confidence-high{color:var(--green)}.confidence-medium{color:var(--orange)}.confidence-low{color:var(--red)}

/* Temperature */
.temp-item{padding:9px 11px;border-radius:var(--radius);border:1px solid var(--border);display:flex;align-items:center;gap:10px}
.temp-item.alert{border-color:var(--red-border);background:var(--red-bg)}
.temp-value{font-size:20px;font-weight:700;min-width:58px}
.temp-item.alert .temp-value{color:var(--red)}

/* NC items */
.nc-item{padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius)}
.nc-item.critical{border-color:var(--red-border);background:var(--red-bg)}
.nc-item.major{border-color:var(--orange-border);background:var(--orange-bg)}
.nc-item.minor{border-color:var(--yellow-border);background:var(--yellow-bg)}

/* Alert items */
.alert-item{display:flex;align-items:flex-start;gap:9px;padding:9px 11px;border-radius:var(--radius);border:1px solid var(--border)}
.alert-item.expiry_passed{border-color:var(--red-border);background:var(--red-bg)}
.alert-item.expiry_soon{border-color:var(--orange-border);background:var(--orange-bg)}
.alert-item.temp_alert{border-color:var(--blue-border);background:var(--blue-bg)}
.alert-msg{flex:1;font-size:13px;line-height:1.4}
.loss-bar{height:8px;background:var(--surface2);border-radius:4px;overflow:hidden;margin:3px 0 6px}
.loss-bar-fill{height:8px;background:var(--red);border-radius:4px}
.scanner-video{width:100%;max-height:220px;object-fit:cover;border-radius:var(--radius);border:1px solid var(--border);margin:8px 0}
@media(max-width:900px){.app{grid-template-columns:1fr}.sidebar{display:none}.terrain-layout,.col2,.col3{grid-template-columns:1fr}}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
