/* Variables CSS */ :root { --primary-color: #007bff; --primary-dark: #0056b3; --secondary-color: #6c757d; --success-color: #28a745; --danger-color: #dc3545; --warning-color: #ffc107; --info-color: #17a2b8; --light-color: #f8f9fa; --dark-color: #343a40; --white: #ffffff; --border-radius: 8px; --box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); --transition: all 0.3s ease; } /* Reset et base */ * { margin: 0; padding: 0; box-sizing: border-box; } body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif; font-size: 16px; line-height: 1.6; color: var(--dark-color); background-color: var(--light-color); } /* Navigation */ .navbar { background-color: var(--primary-color); color: var(--white); padding: 1rem 2rem; box-shadow: var(--box-shadow); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; } .nav-brand { font-size: 1.5rem; font-weight: bold; } .nav-menu { display: flex; gap: 1rem; flex-wrap: wrap; } .nav-menu a { color: var(--white); text-decoration: none; padding: 0.5rem 1rem; border-radius: var(--border-radius); transition: var(--transition); } .nav-menu a:hover, .nav-menu a.active { background-color: var(--primary-dark); } /* Container */ .container { max-width: 1200px; margin: 2rem auto; padding: 0 1rem; } /* Cards */ .card { background-color: var(--white); border-radius: var(--border-radius); box-shadow: var(--box-shadow); padding: 1.5rem; margin-bottom: 1.5rem; } .card h2 { margin-bottom: 1rem; color: var(--primary-color); } .card.warning { border-left: 4px solid var(--warning-color); background-color: #fff3cd; } .card.warning h3 { color: var(--warning-color); margin-bottom: 0.5rem; } .card.warning ul { margin-left: 1.5rem; } /* Grille de statistiques */ .stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 1rem; margin-bottom: 1.5rem; } .stat-card { background-color: var(--white); border-radius: var(--border-radius); box-shadow: var(--box-shadow); padding: 1.5rem; text-align: center; } .stat-label { font-size: 0.9rem; color: var(--secondary-color); margin-bottom: 0.5rem; } .stat-value { font-size: 1.5rem; font-weight: bold; color: var(--primary-color); } /* Grille de contrĂ´les */ .controls-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; } /* Formulaires */ .form-group { margin-bottom: 1.5rem; } .form-group label { display: block; margin-bottom: 0.5rem; font-weight: 500; color: var(--dark-color); } .form-group input[type="text"], .form-group input[type="password"], .form-group input[type="number"], .form-group input[type="file"] { width: 100%; padding: 0.75rem; border: 1px solid #ddd; border-radius: var(--border-radius); font-size: 1rem; transition: var(--transition); } .form-group input:focus { outline: none; border-color: var(--primary-color); box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.1); } /* Boutons */ .btn { display: inline-block; padding: 0.75rem 1.5rem; font-size: 1rem; font-weight: 500; text-align: center; text-decoration: none; border: none; border-radius: var(--border-radius); cursor: pointer; transition: var(--transition); width: 100%; } .btn-primary { background-color: var(--primary-color); color: var(--white); } .btn-primary:hover { background-color: var(--primary-dark); } .btn-secondary { background-color: var(--secondary-color); color: var(--white); } .btn-secondary:hover { background-color: #5a6268; } /* Messages */ .message { padding: 1rem; border-radius: var(--border-radius); margin-top: 1rem; margin-bottom: 1rem; display: none; } .message.success { display: block; background-color: #d4edda; border: 1px solid #c3e6cb; color: #155724; } .message.error { display: block; background-color: #f8d7da; border: 1px solid #f5c6cb; color: #721c24; } .message.info { display: block; background-color: #d1ecf1; border: 1px solid #bee5eb; color: #0c5460; } /* Barre de progression */ .progress-container { margin-top: 1rem; } .progress-bar { width: 100%; height: 30px; background-color: #e9ecef; border-radius: var(--border-radius); overflow: hidden; } .progress-fill { height: 100%; background-color: var(--primary-color); transition: width 0.3s ease; width: 0%; } .progress-text { text-align: center; margin-top: 0.5rem; font-weight: bold; } /* Page de login */ .login-page { display: flex; justify-content: center; align-items: center; min-height: 100vh; background: linear-gradient(135deg, var(--primary-color), var(--primary-dark)); } .login-container { width: 100%; max-width: 400px; padding: 1rem; } .login-card { background-color: var(--white); border-radius: var(--border-radius); box-shadow: 0 4px 6px rgba(0, 0, 0, 0.2); padding: 2rem; } .login-card h1 { text-align: center; color: var(--primary-color); margin-bottom: 0.5rem; font-size: 2rem; } .login-card h2 { text-align: center; color: var(--secondary-color); margin-bottom: 2rem; font-size: 1.5rem; } /* Responsive */ @media (max-width: 768px) { .navbar { flex-direction: column; gap: 1rem; } .nav-menu { justify-content: center; } .stats-grid { grid-template-columns: 1fr; } .controls-grid { grid-template-columns: 1fr; } } @media (max-width: 480px) { .container { margin: 1rem auto; } .card { padding: 1rem; } .nav-menu a { padding: 0.5rem; font-size: 0.9rem; } }