:root{--primary-color: #7cb342;--primary-dark: #689f38;--secondary-color: #66bb6a;--danger-color: #ef4444;--warning-color: #f59e0b;--bg-color: #f9fafb;--card-bg: #ffffff;--text-primary: #111827;--text-secondary: #6b7280;--border-color: #e5e7eb;--sidebar-bg: #2e7d32;--sidebar-text: #f3f4f6;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-color);color:var(--text-primary);line-height:1.6}.app-container{display:flex;min-height:100vh}.sidebar{width:260px;background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;position:fixed;height:100vh;overflow-y:auto}.sidebar-header{padding:2rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1);text-align:center}.logo{width:80px;height:80px;border-radius:50%;margin-bottom:1rem;background:#fff;padding:.5rem}.sidebar-header h1{font-size:1.5rem;margin-bottom:.25rem}.subtitle{font-size:.875rem;color:#fff9}.nav-links{flex:1;padding:1rem 0}.nav-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:var(--sidebar-text);text-decoration:none;transition:all .2s}.nav-link:hover{background:#ffffff1a}.nav-link.router-link-active{background:var(--primary-color);border-left:4px solid white}.nav-link .icon{font-size:1.25rem}.sidebar-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.1)}.user-info{display:flex;align-items:center;gap:.75rem;padding:.75rem;margin-bottom:.5rem}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-color);display:flex;align-items:center;justify-content:center;font-weight:600}.user-details{flex:1;min-width:0}.user-name{font-weight:500;font-size:.875rem}.user-email{font-size:.75rem;color:#fff9;overflow:hidden;text-overflow:ellipsis}.btn-logout{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:#ef44441a;color:#fca5a5;border:none;border-radius:.5rem;cursor:pointer;transition:all .2s}.btn-logout:hover{background:#ef444433}.main-content{flex:1;margin-left:260px;padding:2rem;min-height:100vh}.page-header{margin-bottom:2rem}.page-header h1{font-size:2rem;margin-bottom:.5rem}.page-header p{color:var(--text-secondary)}.btn-primary,.btn-secondary,.btn-danger{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--border-color);color:var(--text-primary)}.btn-secondary:hover{background:#d1d5db}.btn-danger{background:var(--danger-color);color:#fff}.btn-danger:hover{background:#dc2626}.btn-primary:disabled,.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #7cb3421a}.card{background:var(--card-bg);border-radius:.75rem;padding:1.5rem;box-shadow:var(--shadow)}.stat-card{background:var(--card-bg);border-radius:.75rem;padding:1.5rem;box-shadow:var(--shadow);display:flex;align-items:center;gap:1rem}.stat-icon{font-size:2.5rem}.stat-value{font-size:2rem;font-weight:700;color:var(--primary-color)}.stat-label{color:var(--text-secondary);font-size:.875rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem}.dashboard-section{background:var(--card-bg);border-radius:.75rem;padding:1.5rem;box-shadow:var(--shadow)}.dashboard-section h2{font-size:1.25rem;margin-bottom:1rem}.table-container{background:var(--card-bg);border-radius:.75rem;overflow:hidden;box-shadow:var(--shadow)}table{width:100%;border-collapse:collapse}thead{background:var(--bg-color)}th{padding:1rem;text-align:left;font-weight:600;color:var(--text-secondary);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}td{padding:1rem;border-top:1px solid var(--border-color)}tr:hover{background:var(--bg-color)}.badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.badge-success{background:#d1fae5;color:#065f46}.badge-warning{background:#fef3c7;color:#92400e}.badge-danger{background:#fee2e2;color:#991b1b}.badge-info{background:#dbeafe;color:#1e40af}.status-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.status-disponible{background:#d1fae5;color:#065f46}.status-affecté{background:#dbeafe;color:#1e40af}.status-en_maintenance{background:#fef3c7;color:#92400e}.status-hors_service{background:#fee2e2;color:#991b1b}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#7cb342,#2e7d32)}.login-container{background:#fee2e2;color:#991b1b;border-radius:.5rem;margin-bottom:1rem;font-size:.875rem}.success-message{padding:.75rem;background:#d1fae5;color:#065f46;border-radius:.5rem;margin-bottom:1rem;font-size:.875rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:1rem;padding:2rem;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{font-size:1.5rem}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary)}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}@media(max-width:768px){.sidebar{width:100%;position:relative;height:auto}.main-content{margin-left:0}.stats-grid,.dashboard-grid{grid-template-columns:1fr}}.login-card{background:#fff;border-radius:1rem;padding:2.5rem;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:100px;height:100px;border-radius:50%;margin-bottom:1rem;background:#fff;padding:.5rem;box-shadow:0 4px 6px #0000001a}
