:root{--primary: #1a5276;--primary-light: #2980b9;--accent: #d4a017;--bg: #f5f6fa;--sidebar-bg: #1a2035;--sidebar-text: #a0aec0;--sidebar-active: #ffffff;--white: #ffffff;--border: #e2e8f0;--text: #2d3748;--text-light: #718096;--success: #27ae60;--warning: #f39c12;--danger: #e74c3c;--shadow: 0 2px 8px rgba(0,0,0,.08)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,sans-serif;background:var(--bg);color:var(--text)}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:260px;background:var(--sidebar-bg);display:flex;flex-direction:column;flex-shrink:0}.main-content{flex:1;overflow-y:auto}.sidebar-header{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo-img{width:140px;object-fit:contain;border-radius:8px;background:#fff;padding:6px}.sidebar-site{color:var(--sidebar-text);font-size:12px;text-align:center}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;color:var(--sidebar-text);text-decoration:none;font-size:14px;transition:all .2s}.nav-item:hover{background:#ffffff0f;color:#fff}.nav-item.active{background:var(--primary-light);color:#fff}.nav-icon{font-size:16px}.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.08)}.user-info{display:flex;align-items:center;gap:10px;margin-bottom:12px}.user-avatar{width:36px;height:36px;background:var(--primary-light);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px}.user-name{color:#fff;font-size:13px;font-weight:600}.user-role{color:var(--sidebar-text);font-size:11px}.btn-logout{width:100%;padding:8px;background:#ffffff0f;border:none;border-radius:6px;color:var(--sidebar-text);cursor:pointer;font-size:13px;transition:all .2s}.btn-logout:hover{background:#e74c3c33;color:#e74c3c}.page{padding:32px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.page-header h1{font-size:24px;font-weight:700;color:var(--text)}.header-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.card{background:var(--white);border-radius:12px;padding:24px;box-shadow:var(--shadow);margin-bottom:20px}.card h2{font-size:16px;font-weight:700;margin-bottom:16px;color:var(--text)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.kpi-card{background:var(--white);border-radius:12px;padding:20px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:8px;border-left:4px solid var(--primary-light)}.kpi-card.warning{border-left-color:var(--warning)}.kpi-card.danger{border-left-color:var(--danger)}.kpi-icon{font-size:24px}.kpi-value{font-size:22px;font-weight:800;color:var(--text)}.kpi-label{font-size:13px;color:var(--text-light)}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 900px){.dashboard-grid{grid-template-columns:1fr}}.table{width:100%;border-collapse:collapse;font-size:14px}.table th{text-align:left;padding:10px 12px;background:var(--bg);color:var(--text-light);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.table td{padding:12px;border-bottom:1px solid var(--border)}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:#fafbfc}.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}.badge.ok{background:#e8f5e9;color:var(--success)}.badge.warning,.badge.bas{background:#fff3e0;color:var(--warning)}.badge.danger,.badge.rupture{background:#fce4ec;color:var(--danger)}.badge.entree,.mvt-badge.entree{background:#e8f5e9;color:var(--success)}.badge.sortie,.mvt-badge.sortie{background:#fce4ec;color:var(--danger)}.badge.ajustement,.mvt-badge.ajustement{background:#e3f2fd;color:var(--primary-light)}.badge.statut-en_attente{background:#fff3e0;color:var(--warning)}.badge.statut-recue{background:#e8f5e9;color:var(--success)}.badge.statut-annulee{background:#fce4ec;color:var(--danger)}.badge.statut-envoyee{background:#e3f2fd;color:var(--primary-light)}.btn{padding:8px 16px;border-radius:8px;border:1px solid var(--border);background:var(--white);cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.btn:hover{background:var(--bg)}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-light);border-color:var(--primary-light)}.btn-full{width:100%;padding:12px}.btn-sm{padding:4px 8px;font-size:12px;border:none;background:none;cursor:pointer}.btn-sm.danger:hover{color:var(--danger)}.site-toggle{display:flex;background:var(--bg);border-radius:8px;padding:3px;gap:2px}.site-toggle button{padding:6px 14px;border:none;background:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-light);transition:all .2s}.site-toggle button.active{background:var(--white);color:var(--primary);box-shadow:0 1px 4px #0000001a}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;color:var(--text);transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-light)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.search-input{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-size:14px;margin-bottom:16px}.search-input:focus{outline:none;border-color:var(--primary-light)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--white);border-radius:16px;padding:32px;width:90%;max-width:480px;box-shadow:0 20px 60px #0003}.modal h2{font-size:18px;font-weight:700;margin-bottom:24px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%)}.login-card{background:var(--white);border-radius:20px;padding:48px 40px;width:90%;max-width:400px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:32px}.login-logo-img{width:200px;object-fit:contain;margin:0 auto 12px;display:block}.login-header p{color:var(--text-light);font-size:14px;margin-top:4px}.alert{padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:16px}.alert-error{background:#fce4ec;color:var(--danger)}.mvt-list{display:flex;flex-direction:column;gap:8px}.mvt-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.mvt-item:last-child{border-bottom:none}.mvt-type{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.mvt-type.entree{background:#e8f5e9;color:var(--success)}.mvt-type.sortie{background:#fce4ec;color:var(--danger)}.mvt-type.ajustement{background:#e3f2fd;color:var(--primary-light)}.mvt-info{flex:1}.mvt-article{font-size:14px;font-weight:500}.mvt-meta{font-size:12px;color:var(--text-light);margin-top:2px}.mvt-qty{font-weight:700;font-size:15px}.mvt-qty.entree{color:var(--success)}.mvt-qty.sortie{color:var(--danger)}.rapport-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 900px){.rapport-grid{grid-template-columns:1fr}}.rapport-total{font-size:14px;color:var(--text-light);margin-bottom:16px}.rapport-bar-item{margin-bottom:14px}.rapport-bar-header{display:flex;justify-content:space-between;font-size:13px;margin-bottom:6px}.rapport-bar-track{height:8px;background:var(--bg);border-radius:4px;overflow:hidden}.rapport-bar-fill{height:100%;background:var(--primary-light);border-radius:4px;transition:width .5s}.loading{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-light);font-size:16px}.empty{text-align:center;color:var(--text-light);padding:32px;font-size:14px}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:9999}.toast{display:flex;align-items:center;gap:10px;padding:14px 20px;border-radius:10px;background:var(--white);box-shadow:0 4px 20px #00000026;font-size:14px;font-weight:500;min-width:280px;animation:slideIn .3s ease}.toast-success{border-left:4px solid var(--success)}.toast-error{border-left:4px solid var(--danger)}.toast-info{border-left:4px solid var(--primary-light)}.toast-icon{font-size:18px}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.guide-btn{width:32px;height:32px;border-radius:50%;border:2px solid var(--primary-light);background:var(--white);color:var(--primary-light);font-weight:800;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.guide-btn:hover{background:var(--primary-light);color:#fff}.guide-list{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.guide-item{display:flex;gap:12px;align-items:flex-start;font-size:14px;line-height:1.5}.guide-num{width:24px;height:24px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;margin-top:1px}.btn-outline{background:var(--white);border:1px solid var(--primary-light);color:var(--primary-light)}.btn-outline:hover{background:var(--primary-light);color:#fff}.btn-danger{background:#fce4ec;border:1px solid var(--danger);color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-accent{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.btn-accent:hover{opacity:.9}.btn-large{padding:12px 24px;font-size:15px}.btn-sm-text{padding:6px 12px;font-size:13px}.input-large{font-size:18px;padding:12px;text-align:center}.type-toggle{display:flex;gap:8px;margin-bottom:20px}.type-toggle button{flex:1;padding:12px;border:2px solid var(--border);background:var(--bg);border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s}.type-toggle button.active{border-color:var(--primary-light);background:var(--primary-light);color:#fff}.type-toggle button.active.entree{border-color:var(--success);background:var(--success)}.type-toggle button.active.sortie{border-color:var(--danger);background:var(--danger)}.mobile-cards{display:none;flex-direction:column;gap:12px}.stock-card{border-radius:12px;border:1px solid var(--border);padding:16px;background:var(--white)}.stock-card.status-bas{border-left:4px solid var(--warning)}.stock-card.status-rupture{border-left:4px solid var(--danger)}.stock-card.status-ok{border-left:4px solid var(--success)}.stock-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.stock-card-nom{font-weight:700;font-size:15px}.stock-card-unite{font-size:12px;color:var(--text-light);margin-top:2px}.stock-card-body{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px}.stock-stat{display:flex;flex-direction:column;gap:2px}.stock-stat span{font-size:11px;color:var(--text-light);text-transform:uppercase}.stock-stat strong{font-size:15px}.stock-card-actions{display:flex;gap:8px}.stock-card-actions .btn{flex:1;text-align:center;justify-content:center}@media (max-width: 768px){.sidebar{display:none}.page{padding:16px}.page-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%;flex-wrap:wrap}.kpi-grid{grid-template-columns:1fr 1fr}.dashboard-grid,.rapport-grid{grid-template-columns:1fr}.desktop-only{display:none}.mobile-cards{display:flex}.table{font-size:12px}.table th,.table td{padding:8px 6px}.modal{padding:24px 16px}.type-toggle{flex-direction:column}}.mobile-nav,.mobile-header,.mobile-bottom-spacer{display:none}@media (max-width: 768px){.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--sidebar-bg);position:sticky;top:0;z-index:100}.mobile-logo{height:36px;object-fit:contain;background:#fff;border-radius:6px;padding:3px}.mobile-user-info{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.mobile-site{color:var(--sidebar-text);font-size:11px}.mobile-logout{background:none;border:none;color:#e74c3c;font-size:12px;cursor:pointer;padding:0}.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--sidebar-bg);border-top:1px solid rgba(255,255,255,.1);z-index:200;padding-bottom:env(safe-area-inset-bottom)}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:10px 4px 8px;text-decoration:none;color:var(--sidebar-text);gap:3px;transition:all .2s}.mobile-nav-item.active{color:#fff;background:#ffffff14}.mobile-nav-icon{font-size:20px}.mobile-nav-label{font-size:10px;font-weight:500}.mobile-bottom-spacer{display:block;height:70px}}.rapport-pdg{background:var(--white);border-radius:12px;padding:32px;box-shadow:var(--shadow)}.rapport-entete{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding-bottom:24px;border-bottom:3px solid var(--primary)}.rapport-entete h2{font-size:22px;font-weight:800;color:var(--primary);margin-bottom:4px}.rapport-entete p{color:var(--text-light);font-size:14px}.rapport-date{margin-top:8px;font-weight:600;color:var(--text)}.rapport-badge-global{text-align:right}.rapport-valeur-totale{font-size:28px;font-weight:800;color:var(--primary)}.rapport-footer{text-align:center;color:var(--text-light);font-size:12px;margin-top:32px;padding-top:16px;border-top:1px solid var(--border)}.pdg-comparatif{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.pdg-site-card{background:var(--bg);border-radius:12px;padding:20px;border:1px solid var(--border)}.pdg-site-card h3{font-size:16px;font-weight:700;margin-bottom:16px;color:var(--primary)}.pdg-site-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}.pdg-stat{background:var(--white);border-radius:8px;padding:12px;text-align:center}.pdg-stat.alert{background:#fce4ec}.pdg-stat.warn{background:#fff3e0}.pdg-stat-val{font-size:22px;font-weight:800;color:var(--text)}.pdg-stat-label{font-size:11px;color:var(--text-light);margin-top:2px}.pdg-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:0}.pdg-commande-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border);font-size:14px}.pdg-commande-item:last-child{border-bottom:none}.badge-perem{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:700}.perem-expire{background:#fce4ec;color:var(--danger)}.perem-urgent{background:#fff3e0;color:#c0392b}.perem-proche{background:#fff8e1;color:#e67e22}.maint-tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.maint-tab{padding:10px 16px;border:2px solid var(--border);background:var(--white);border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;color:var(--text-light);transition:all .2s;display:flex;align-items:center;gap:6px}.maint-tab.active{border-color:var(--primary-light);background:var(--primary-light);color:#fff}.maint-tab-badge{background:var(--danger);color:#fff;border-radius:10px;padding:1px 6px;font-size:11px;font-weight:700}.maint-tache-card{background:var(--white);border-radius:12px;border:1px solid var(--border);padding:16px;border-left:5px solid var(--border)}.maint-tache-card.en_retard{border-left-color:var(--danger);background:#fff8f8}.maint-tache-card.aujourd_hui{border-left-color:var(--warning);background:#fffdf5}.maint-tache-card.bientot{border-left-color:#3498db;background:#f5faff}.maint-tache-header{display:flex;align-items:flex-start;gap:12px}.maint-tache-emoji{font-size:2rem;flex-shrink:0}.maint-tache-info{flex:1}.maint-tache-titre{font-weight:700;font-size:16px}.maint-tache-equip{font-size:13px;color:var(--text-light);margin-top:2px}.maint-tache-date{font-size:12px;color:var(--text-light);margin-top:4px}.maint-tache-desc{font-size:13px;color:var(--text);margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.maint-urgence-badge{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:700;white-space:nowrap;flex-shrink:0}.urgence-retard{background:#fce4ec;color:var(--danger)}.urgence-aujourdhui{background:#fff3e0;color:#c0392b}.urgence-bientot{background:#e3f2fd;color:#1565c0}.maint-equip-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.maint-equip-row:last-child{border-bottom:none}.maint-equip-emoji{font-size:1.6rem;flex-shrink:0;width:36px;text-align:center}.maint-equip-info{flex:1;font-size:14px}.maint-equip-loc{color:var(--text-light);font-size:13px}.badge-equip{padding:3px 10px;border-radius:12px;font-size:12px;font-weight:600;white-space:nowrap}.statut-ok{background:#e8f5e9;color:var(--success)}.statut-maintenance_due{background:#fff3e0;color:var(--warning)}.statut-en_panne{background:#fce4ec;color:var(--danger)}.maint-panne-card{background:var(--white);border-radius:12px;border:1px solid var(--border);padding:16px;border-left:5px solid var(--border)}.maint-panne-card.priorite-urgente{border-left-color:var(--danger)}.maint-panne-card.priorite-haute{border-left-color:var(--warning)}.maint-panne-card.resolue{opacity:.6}.badge-priorite{padding:3px 10px;border-radius:12px;font-size:12px;font-weight:600}.priorite-faible{background:#e8f5e9;color:var(--success)}.priorite-normale{background:#e3f2fd;color:#1565c0}.priorite-haute{background:#fff3e0;color:var(--warning)}.priorite-urgente{background:#fce4ec;color:var(--danger)}@media (max-width: 768px){.maint-tabs{gap:6px}.maint-tab{padding:8px 12px;font-size:12px}.maint-tache-emoji{font-size:1.5rem}.maint-equip-row{flex-wrap:wrap}}.alert-peremption-banner{background:#fff3e0;border:1px solid #f39c12;border-radius:10px;padding:14px 18px;margin-bottom:20px}.alert-peremption-title{font-weight:700;font-size:14px;color:#7d4e00;margin-bottom:10px}.alert-peremption-list{display:flex;flex-wrap:wrap;gap:8px}.mobile-quick-links{display:none}@media (max-width: 768px){.mobile-quick-links{display:block;margin-bottom:20px}.mobile-quick-title{font-size:14px;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.mobile-quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.mobile-quick-card{display:flex;flex-direction:column;align-items:center;gap:6px;background:var(--white);border:1px solid var(--border);border-radius:12px;padding:16px 8px;text-decoration:none;color:var(--text);font-size:13px;font-weight:500;text-align:center;transition:all .2s}.mobile-quick-card:hover,.mobile-quick-card:active{background:var(--primary);color:#fff;border-color:var(--primary)}.mobile-quick-icon{font-size:24px}}.input-pin{text-align:center;font-size:24px;letter-spacing:8px;font-weight:700}.input-inventaire{width:80px;padding:6px 8px;border:1px solid var(--border);border-radius:6px;text-align:center;font-size:14px}.input-inventaire:focus{outline:none;border-color:var(--primary-light)}.input-note{width:160px;padding:6px 8px;border:1px solid var(--border);border-radius:6px;font-size:13px}.row-ecart-pos{color:var(--success);font-weight:700}.row-ecart-neg{color:var(--danger);font-weight:700}.row-ecart-zero{color:var(--text-light)}.demande-detail{font-size:13px;color:var(--text-light);margin-top:2px}.badge-pending{background:#fff3e0;color:#e67e22;padding:3px 8px;border-radius:12px;font-size:12px;font-weight:600}.badge-approved{background:#e8f5e9;color:var(--success);padding:3px 8px;border-radius:12px;font-size:12px;font-weight:600}.badge-refused{background:#fce4ec;color:var(--danger);padding:3px 8px;border-radius:12px;font-size:12px;font-weight:600}.alert-warning{background:#fff3e0;border:1px solid #f39c12;color:#7d5a00;padding:12px 16px;border-radius:8px;font-size:14px}.alert-success{background:#e8f5e9;border:1px solid var(--success);color:#1b5e20;padding:12px 16px;border-radius:8px;font-size:14px}@media (max-width: 768px){.pdg-comparatif,.pdg-grid-2{grid-template-columns:1fr}.rapport-entete{flex-direction:column;gap:16px}.rapport-badge-global{text-align:left}.input-inventaire{width:64px}.input-note{width:120px}}
