/**
 * TacTacFact - Feuille de style principale
 * Une application de suivi du temps et de facturation
 */

/* --- VARIABLES ET THÈME --- */
:root {
	/* Couleurs principales */
	--primary: #4361ee;
	--primary-light: #738aff;
	--primary-dark: #2e46c9;
	--secondary: #ff7b00;
	--secondary-light: #ff9933;
	--secondary-dark: #cc6200;
	
	/* Couleurs de contraste */
	--success: #38b000;
	--warning: #ffaa00;
	--danger: #e63946;
	--info: #4cc9f0;
	
	/* Tons neutres */
	--light: #f8f9fa;
	--dark: #212529;
	--gray-100: #f8f9fa;
	--gray-200: #e9ecef;
	--gray-300: #dee2e6;
	--gray-400: #ced4da;
	--gray-500: #adb5bd;
	--gray-600: #6c757d;
	--gray-700: #495057;
	--gray-800: #343a40;
	--gray-900: #212529;
	
	/* Couleurs de texte */
	--text-dark: #212529;
	--text-light: #f8f9fa;
	--text-muted: #6c757d;
	
	/* Couleurs de fond */
	--bg-body: #f5f7fa;
	--bg-card: #ffffff;
	--bg-input: #ffffff;
	
	/* Bordures et ombres */
	--border-color: #dee2e6;
	--border-radius: 8px;
	--box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05), 0 1px 3px rgba(0, 0, 0, 0.1);
	--box-shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.1), 0 4px 6px rgba(0, 0, 0, 0.05);
	--box-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
	
	/* Polices */
	--font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
	--font-size-base: 1rem;
	--font-size-sm: 0.875rem;
	--font-size-lg: 1.125rem;
	--font-size-xl: 1.25rem;
	--font-size-2xl: 1.5rem;
	--font-size-3xl: 1.875rem;
	--font-size-4xl: 2.25rem;
	--font-weight-light: 300;
	--font-weight-normal: 400;
	--font-weight-medium: 500;
	--font-weight-semibold: 600;
	--font-weight-bold: 700;
	
	/* Espacement */
	--spacing-1: 0.25rem;
	--spacing-2: 0.5rem;
	--spacing-3: 0.75rem;
	--spacing-4: 1rem;
	--spacing-5: 1.25rem;
	--spacing-6: 1.5rem;
	--spacing-8: 2rem;
	--spacing-10: 2.5rem;
	--spacing-12: 3rem;
	--spacing-16: 4rem;
	
	/* Transitions */
	--transition-fast: 150ms ease;
	--transition-normal: 300ms ease;
	--transition-slow: 500ms ease;
	
	/* Z-index */
	--z-dropdown: 1000;
	--z-sticky: 1020;
	--z-fixed: 1030;
	--z-modal: 1040;
	--z-tooltip: 1050;
}

/* Mode sombre */
@media (prefers-color-scheme: dark) {
	:root {
		--bg-body: #121212;
		--bg-card: #1e1e1e;
		--bg-input: #2a2a2a;
		
		--text-dark: #f8f9fa;
		--text-light: #f8f9fa;
		--text-muted: #adb5bd;
		
		--border-color: #333333;
		
		--primary: #5678ff;
		--primary-light: #738aff;
		--primary-dark: #3d5eff;
	}
}

/* --- RESET ET BASE --- */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

html {
	font-size: 16px;
	scroll-behavior: smooth;
}

body {
	font-family: var(--font-family);
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-normal);
	line-height: 1.5;
	color: var(--text-dark);
	background-color: var(--bg-body);
	min-height: 100vh;
}

a {
	color: var(--primary);
	text-decoration: none;
	transition: color var(--transition-fast);
}

a:hover {
	color: var(--primary-dark);
	text-decoration: underline;
}

img {
	max-width: 100%;
	height: auto;
}

.hidden {
	display: none !important;
}

/* --- TYPOGRAPHIE --- */
h1, h2, h3, h4, h5, h6 {
	margin-bottom: var(--spacing-4);
	font-weight: var(--font-weight-semibold);
	line-height: 1.2;
}

h1 {
	font-size: var(--font-size-4xl);
}

h2 {
	font-size: var(--font-size-3xl);
}

h3 {
	font-size: var(--font-size-2xl);
}

h4 {
	font-size: var(--font-size-xl);
}

h5 {
	font-size: var(--font-size-lg);
}

h6 {
	font-size: var(--font-size-base);
}

p {
	margin-bottom: var(--spacing-4);
}

.text-primary { color: var(--primary); }
.text-secondary { color: var(--secondary); }
.text-success { color: var(--success); }
.text-danger { color: var(--danger); }
.text-warning { color: var(--warning); }
.text-info { color: var(--info); }
.text-muted { color: var(--text-muted); }
.text-light { color: var(--text-light); }
.text-dark { color: var(--text-dark); }

.fw-light { font-weight: var(--font-weight-light); }
.fw-normal { font-weight: var(--font-weight-normal); }
.fw-medium { font-weight: var(--font-weight-medium); }
.fw-semibold { font-weight: var(--font-weight-semibold); }
.fw-bold { font-weight: var(--font-weight-bold); }

.fs-sm { font-size: var(--font-size-sm); }
.fs-base { font-size: var(--font-size-base); }
.fs-lg { font-size: var(--font-size-lg); }
.fs-xl { font-size: var(--font-size-xl); }
.fs-2xl { font-size: var(--font-size-2xl); }

.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

/* --- CONTENEUR ET GRILLE --- */
.container {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 var(--spacing-4);
}

.row {
	display: flex;
	flex-wrap: wrap;
	margin: 0 calc(-1 * var(--spacing-4));
}

.col {
	flex: 1 0 0%;
	padding: 0 var(--spacing-4);
}

.col-auto {
	flex: 0 0 auto;
	padding: 0 var(--spacing-4);
}

/* Grille à 12 colonnes */
@media (min-width: 768px) {
	.col-1 { flex: 0 0 8.33333%; max-width: 8.33333%; }
	.col-2 { flex: 0 0 16.66667%; max-width: 16.66667%; }
	.col-3 { flex: 0 0 25%; max-width: 25%; }
	.col-4 { flex: 0 0 33.33333%; max-width: 33.33333%; }
	.col-5 { flex: 0 0 41.66667%; max-width: 41.66667%; }
	.col-6 { flex: 0 0 50%; max-width: 50%; }
	.col-7 { flex: 0 0 58.33333%; max-width: 58.33333%; }
	.col-8 { flex: 0 0 66.66667%; max-width: 66.66667%; }
	.col-9 { flex: 0 0 75%; max-width: 75%; }
	.col-10 { flex: 0 0 83.33333%; max-width: 83.33333%; }
	.col-11 { flex: 0 0 91.66667%; max-width: 91.66667%; }
	.col-12 { flex: 0 0 100%; max-width: 100%; }
}

/* --- COMPOSANTS --- */

/* Boutons */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--spacing-2);
	padding: var(--spacing-2) var(--spacing-4);
	border: 1px solid transparent;
	border-radius: var(--border-radius);
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-medium);
	line-height: 1.5;
	text-align: center;
	cursor: pointer;
	transition: all var(--transition-fast);
	user-select: none;
}

.btn:focus {
	outline: none;
	box-shadow: 0 0 0 0.25rem rgba(67, 97, 238, 0.25);
}

.btn-primary {
	color: var(--text-light);
	background-color: var(--primary);
	border-color: var(--primary);
}

.btn-primary:hover {
	color: var(--text-light);
	background-color: var(--primary-dark);
	border-color: var(--primary-dark);
	text-decoration: none;
}

.btn-secondary {
	color: var(--text-light);
	background-color: var(--secondary);
	border-color: var(--secondary);
}

.btn-secondary:hover {
	color: var(--text-light);
	background-color: var(--secondary-dark);
	border-color: var(--secondary-dark);
	text-decoration: none;
}

.btn-success {
	color: var(--text-light);
	background-color: var(--success);
	border-color: var(--success);
}

.btn-success:hover {
	color: var(--text-light);
	background-color: #2d8f00;
	border-color: #2d8f00;
	text-decoration: none;
}

.btn-danger {
	color: var(--text-light);
	background-color: var(--danger);
	border-color: var(--danger);
}

.btn-danger:hover {
	color: var(--text-light);
	background-color: #c92a37;
	border-color: #c92a37;
	text-decoration: none;
}

.btn-outline-primary {
	color: var(--primary);
	background-color: transparent;
	border-color: var(--primary);
}

.btn-outline-primary:hover {
	color: var(--text-light);
	background-color: var(--primary);
	text-decoration: none;
}

.btn-outline-secondary {
	color: var(--text-dark);
	background-color: transparent;
	border-color: var(--gray-400);
}

.btn-outline-secondary:hover {
	color: var(--text-dark);
	background-color: var(--gray-200);
	text-decoration: none;
}

.btn-outline-success {
	color: var(--success);
	background-color: transparent;
	border-color: var(--success);
}

.btn-outline-success:hover {
	color: var(--text-light);
	background-color: var(--success);
	text-decoration: none;
}

.btn-outline-warning {
	color: var(--secondary-dark);
	background-color: transparent;
	border-color: var(--secondary);
}

.btn-outline-warning:hover {
	color: var(--text-dark);
	background-color: rgba(255, 193, 7, 0.15);
	text-decoration: none;
}

.btn-outline-danger {
	color: var(--danger);
	background-color: transparent;
	border-color: var(--danger);
}

.btn-outline-danger:hover {
	color: var(--text-light);
	background-color: var(--danger);
	text-decoration: none;
}

.btn-lg {
	padding: var(--spacing-3) var(--spacing-6);
	font-size: var(--font-size-lg);
}

.btn-sm {
	padding: var(--spacing-1) var(--spacing-3);
	font-size: var(--font-size-sm);
}

.btn-block {
	display: flex;
	width: 100%;
}

/* Cartes */
.card {
	position: relative;
	display: flex;
	flex-direction: column;
	min-width: 0;
	word-wrap: break-word;
	background-color: var(--bg-card);
	background-clip: border-box;
	border: 1px solid var(--border-color);
	border-radius: var(--border-radius);
	box-shadow: var(--box-shadow);
	/*margin-bottom: var(--spacing-6);*/
}

.card-header {
	padding: var(--spacing-4) var(--spacing-6);
	margin-bottom: 0;
	background-color: rgba(0, 0, 0, 0.03);
	border-bottom: 1px solid var(--border-color);
}

.card-header:first-child {
	border-radius: calc(var(--border-radius) - 1px) calc(var(--border-radius) - 1px) 0 0;
}

.card-body {
	flex: 1 1 auto;
	padding: var(--spacing-6);
}

.card-footer {
	padding: var(--spacing-4) var(--spacing-6);
	background-color: rgba(0, 0, 0, 0.03);
	border-top: 1px solid var(--border-color);
}

.card-footer:last-child {
	border-radius: 0 0 calc(var(--border-radius) - 1px) calc(var(--border-radius) - 1px);
}

/* Formulaires */
.form-group {
	margin-bottom: var(--spacing-4);
}

.form-label {
	display: inline-block;
	margin-bottom: var(--spacing-2);
	font-weight: var(--font-weight-medium);
}

.form-control {
	display: block;
	width: 100%;
	padding: var(--spacing-2) var(--spacing-3);
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-normal);
	line-height: 1.5;
	color: var(--text-dark);
	background-color: var(--bg-input);
	background-clip: padding-box;
	border: 1px solid var(--border-color);
	border-radius: var(--border-radius);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.form-control.select,
select.form-control {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	position: relative;
	background-image:
		linear-gradient(45deg, transparent 50%, currentColor 50%),
		linear-gradient(135deg, currentColor 50%, transparent 50%),
		linear-gradient(to right, transparent 0%, transparent 100%);
	background-position:
		calc(100% - 18px) 50%,
		calc(100% - 12px) 50%,
		100% 0;
	background-size:
		7px 7px,
		7px 7px,
		2.5em 100%;
	background-repeat: no-repeat;
	padding-right: 2.6em;
	cursor: pointer;
}

.form-control:focus {
	color: var(--text-dark);
	background-color: var(--bg-input);
	border-color: var(--primary-light);
	outline: 0;
	box-shadow: 0 0 0 0.25rem rgba(67, 97, 238, 0.25);
}

.form-text {
	margin-top: var(--spacing-1);
	font-size: var(--font-size-sm);
	color: var(--text-muted);
}

/* Bloc captcha */
.captcha-group {
	margin-top: var(--spacing-4);
}

.captcha-box {
	border: 1px solid var(--border-color);
	border-radius: var(--border-radius);
	background: var(--bg-card);
	padding: 12px 14px;
	display: grid;
	grid-template-columns: auto 1fr;
	column-gap: 12px;
	row-gap: 4px;
	align-items: center;
	box-shadow: var(--box-shadow-sm);
}

.captcha-checkbox {
	grid-row: 1 / span 2;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.captcha-box .checkbox-wrapper {
	margin: 0;
	position: relative;
}

/* Masquer la checkbox native */
.captcha-box .checkbox-wrapper input[type="checkbox"] {
	opacity: 0;
	position: absolute;
	width: 0;
	height: 0;
	margin: 0;
}

/* Case à cocher custom - flat design */
.captcha-box .checkbox-wrapper label {
	margin: 0;
	color: var(--text-dark);
	font-weight: var(--font-weight-medium);
	position: relative;
	display: inline-block;
	width: 36px;
	height: 36px;
	cursor: pointer;
}

/* Carré de la checkbox - style flat */
.captcha-box .checkbox-wrapper label:before {
	content: '';
	position: relative;
	display: block;
	left: 0;
	top: 0;
	width: 36px;
	height: 36px;
	border: 2px solid var(--gray-400);
	border-radius: 3px;
	background: var(--bg-card);
	transition: all 0.3s ease;
	z-index: 2;
}

/* Hover sur la checkbox */
.captcha-box .checkbox-wrapper label:hover:before {
	border-color: var(--gray-500);
	background: var(--gray-100);
}

/* Checkmark - style flat */
.captcha-box .checkbox-wrapper input[type="checkbox"]:checked + label:before {
	border-color: var(--success);
	background: var(--success);
}

/* Conteneur pour les lignes d'éclatement */
.captcha-box .checkbox-wrapper {
	overflow: visible;
	position: relative;
}

/* Lignes d'éclatement */
.captcha-box .checkbox-wrapper::after {
	content: '';
	position: absolute;
	left: 18px;
	top: 18px;
	width: 0;
	height: 0;
	border-radius: 50%;
	background:
		linear-gradient(0deg, transparent 49%, var(--warning) 49.5%, var(--warning) 50.5%, transparent 51%),
		linear-gradient(22.5deg, transparent 49%, var(--warning) 49.5%, var(--warning) 50.5%, transparent 51%),
		linear-gradient(45deg, transparent 49%, var(--warning) 49.5%, var(--warning) 50.5%, transparent 51%),
		linear-gradient(67.5deg, transparent 49%, var(--warning) 49.5%, var(--warning) 50.5%, transparent 51%),
		linear-gradient(90deg, transparent 49%, var(--warning) 49.5%, var(--warning) 50.5%, transparent 51%),
		linear-gradient(112.5deg, transparent 49%, var(--warning) 49.5%, var(--warning) 50.5%, transparent 51%),
		linear-gradient(135deg, transparent 49%, var(--warning) 49.5%, var(--warning) 50.5%, transparent 51%),
		linear-gradient(157.5deg, transparent 49%, var(--warning) 49.5%, var(--warning) 50.5%, transparent 51%);
	background-size: 100% 100%;
	background-position: center;
	mask: radial-gradient(circle, transparent 0%, transparent 35%, black 40%, black 90%, transparent 95%, transparent 100%);
	-webkit-mask: radial-gradient(circle, transparent 0%, transparent 35%, black 40%, black 90%, transparent 95%, transparent 100%);
	opacity: 0;
	transform: translate(-50%, -50%) scale(0.1);
	pointer-events: none;
	z-index: 0;
	transition: none;
}

.captcha-box .checkbox-wrapper input[type="checkbox"]:checked ~ .checkbox-wrapper::after,
.captcha-box .checkbox-wrapper:has(input[type="checkbox"]:checked)::after {
	width: 100px;
	height: 100px;
	animation: burstLines 0.6s ease forwards;
}

/* Le checkmark (coche) - reste au-dessus */
.captcha-box .checkbox-wrapper input[type="checkbox"]:checked + label:after {
	content: '';
	position: absolute;
	left: 13px;
	top: 7px;
	width: 8px;
	height: 16px;
	border: solid white;
	border-width: 0 3px 3px 0;
	transform: rotate(45deg);
	animation: checkmark 0.3s ease forwards;
	z-index: 3;
}

/* Animation pour le checkmark */
@keyframes checkmark {
	0% {
		height: 0;
		width: 0;
		opacity: 0;
	}
	50% {
		height: 16px;
		width: 8px;
		opacity: 1;
	}
	100% {
		height: 16px;
		width: 8px;
		opacity: 1;
	}
}


@keyframes burstLines {
	0% {
		opacity: 1;
		transform: translate(-50%, -50%) scale(0.1);
	}
	50% {
		opacity: 1;
		transform: translate(-50%, -50%) scale(0.8);
	}
	100% {
		opacity: 0;
		transform: translate(-50%, -50%) scale(1.2);
	}
}

.captcha-text {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.captcha-title {
	color: var(--text-dark);
	font-weight: var(--font-weight-medium);
}

.input-group {
	position: relative;
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	width: 100%;
}

.input-group > .form-control {
	position: relative;
	flex: 1 1 auto;
	width: 1%;
	min-width: 0;
}

.input-group-text {
	display: flex;
	align-items: center;
	padding: var(--spacing-2) var(--spacing-3);
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-normal);
	line-height: 1.5;
	color: var(--text-dark);
	text-align: center;
	white-space: nowrap;
	background-color: var(--gray-200);
	border: 1px solid var(--border-color);
}

@media (prefers-color-scheme: dark) {
	.input-group-text {
		background-color: #2a2a2a;
		color: #e5e7eb;
		border-color: #444;
	}
}

.input-icon-wrapper {
	position: relative;
}

.input-icon-wrapper i {
	position: absolute;
	top: 50%;
	left: var(--spacing-3);
	transform: translateY(-50%);
	color: var(--gray-500);
	pointer-events: none;
}

.input-icon-wrapper input {
	padding-left: var(--spacing-8);
}

/* Alertes */
.alert {
	position: relative;
	padding: var(--spacing-3) var(--spacing-4);
	margin-bottom: var(--spacing-4);
	border: 1px solid transparent;
	border-radius: var(--border-radius);
}

.alert-success {
	color: #155724;
	background-color: #d4edda;
	border-color: #c3e6cb;
}

.alert-danger {
	color: #721c24;
	background-color: #f8d7da;
	border-color: #f5c6cb;
}

.alert-warning {
	color: #856404;
	background-color: #fff3cd;
	border-color: #ffeeba;
}

.alert-info {
	color: #0c5460;
	background-color: #d1ecf1;
	border-color: #bee5eb;
}

/* Badges */
.badge {
	display: inline-block;
	padding: var(--spacing-1) var(--spacing-2);
	font-size: 0.75em;
	font-weight: var(--font-weight-bold);
	line-height: 1;
	text-align: center;
	white-space: nowrap;
	vertical-align: baseline;
	border-radius: 50rem;
}

.badge-primary { background-color: var(--primary); color: var(--text-light); }
.badge-secondary { background-color: var(--secondary); color: var(--text-light); }
.badge-success { background-color: var(--success); color: var(--text-light); }
.badge-danger { background-color: var(--danger); color: var(--text-light); }
.badge-warning { background-color: var(--warning); color: var(--text-dark); }
.badge-info { background-color: var(--info); color: var(--text-dark); }

/* --- COMPOSANTS SPÉCIFIQUES À L'APPLICATION --- */

/* Page d'authentification */
.auth-page {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 100vh;
	background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%);
}

.auth-container {
	width: 100%;
	max-width: 480px;
	margin: var(--spacing-6) auto;
	padding: 0 var(--spacing-4);
}

.auth-logo {
	text-align: center;
	margin-bottom: var(--spacing-6);
	color: var(--text-light);
}

.auth-logo img {
	width: 80px;
	height: 80px;
	margin-bottom: var(--spacing-3);
}

.auth-logo h1 {
	font-size: var(--font-size-3xl);
	font-weight: var(--font-weight-bold);
	margin-bottom: var(--spacing-2);
}

.auth-logo .tagline {
	font-size: var(--font-size-lg);
	opacity: 0.9;
}

.auth-card {
	background-color: var(--bg-card);
	border-radius: var(--border-radius);
	box-shadow: var(--box-shadow-lg);
	padding: var(--spacing-8);
	margin-bottom: var(--spacing-6);
}

.auth-header {
	text-align: center;
	margin-bottom: var(--spacing-6);
}

.auth-header h2 {
	font-size: var(--font-size-2xl);
	margin-bottom: var(--spacing-2);
}

.auth-header p {
	color: var(--text-muted);
	margin-bottom: 0;
}

.auth-form .form-group:last-child {
	margin-bottom: 0;
}

.auth-form input[type="text"],
.auth-form input[type="email"],
.auth-form input[type="password"] {
	width: 100%;
	padding: var(--spacing-3) var(--spacing-4);
	font-size: var(--font-size-base);
	border: 1px solid var(--border-color);
	border-radius: var(--border-radius);
	background-color: var(--bg-input);
	color: var(--text-dark);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
	height: 48px;
}

.auth-form input[type="text"]:focus,
.auth-form input[type="email"]:focus,
.auth-form input[type="password"]:focus {
	border-color: var(--primary);
	outline: none;
	box-shadow: 0 0 0 3px rgba(67, 97, 238, 0.2);
}

.auth-form .input-icon-wrapper {
	position: relative;
}

.auth-form .input-icon-wrapper i {
	position: absolute;
	left: var(--spacing-4);
	top: 50%;
	transform: translateY(-50%);
	color: var(--text-muted);
	font-size: var(--font-size-lg);
}

.auth-form .input-icon-wrapper input {
	padding-left: var(--spacing-10);
}

.auth-form label {
	display: block;
	margin-bottom: var(--spacing-2);
	font-weight: var(--font-weight-medium);
	color: var(--text-dark);
}

.auth-form .form-text {
	display: block;
	margin-top: var(--spacing-1);
	font-size: var(--font-size-sm);
	color: var(--text-muted);
}

.auth-actions {
	margin-top: var(--spacing-6);
}

.auth-links {
	display: flex;
	justify-content: space-between;
	margin-top: var(--spacing-6);
	font-size: var(--font-size-sm);
}

.auth-links a {
	color: var(--primary);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.auth-links a:hover {
	color: var(--primary-dark);
	text-decoration: underline;
}

.auth-links a i {
	margin-right: var(--spacing-1);
}

.auth-footer {
	text-align: center;
	color: var(--text-light);
	font-size: var(--font-size-sm);
	opacity: 0.7;
	margin-top: var(--spacing-4);
}

.checkbox-wrapper {
	display: flex;
	align-items: center;
}

.checkbox-wrapper input[type="checkbox"] {
	margin-right: var(--spacing-2);
	width: 18px;
	height: 18px;
	cursor: pointer;
}

.checkbox-wrapper label {
	margin-bottom: 0;
	cursor: pointer;
}

.checkbox-wrapper.checkbox-right {
	justify-content: flex-end;
}

.checkbox-wrapper.checkbox-right label {
	text-align: right;
}

.terms-link {
	color: var(--primary);
	text-decoration: underline;
}

/* Styles pour le message d'erreur dans les formulaires d'authentification */
.auth-card .error-message {
	margin-bottom: var(--spacing-4);
	display: flex;
	align-items: center;
	padding: var(--spacing-3) var(--spacing-4);
}

.auth-card .error-message::before {
	content: "\f071";
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	margin-right: var(--spacing-3);
}

.error-message {
	background-color: var(--danger);
	color: white;
	padding: var(--spacing-3);
	border-radius: var(--border-radius);
	margin-bottom: var(--spacing-4);
	font-weight: var(--font-weight-medium);
}

/* Navigation principale */
.main-nav {
	background-color: var(--bg-card);
	border-bottom: 1px solid var(--border-color);
	box-shadow: var(--box-shadow);
	position: sticky;
	top: 0;
	z-index: var(--z-sticky);
}

.nav-content {
	display: flex;
	align-items: center;
	height: 60px;
}

.logo {
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-bold);
	margin-right: var(--spacing-6);
	order: 1;
}

.logo a {
	display: flex;
	align-items: center;
	color: var(--primary);
	text-decoration: none;
}

.logo i {
	margin-right: var(--spacing-2);
}

/* Bouton hamburger (caché par défaut, visible sur mobile) */
.hamburger-btn {
	display: none;
	flex-direction: column;
	justify-content: space-around;
	width: 30px;
	height: 24px;
	background: transparent;
	border: none;
	cursor: pointer;
	padding: 0;
	margin-left: auto;
	z-index: 1001;
	order: 3;
}

.hamburger-btn span {
	width: 30px;
	height: 3px;
	background-color: var(--text-dark);
	border-radius: 3px;
	transition: all 0.3s ease;
	transform-origin: center;
}

.hamburger-btn.active span:nth-child(1) {
	transform: translateY(10.5px) rotate(45deg);
}

.hamburger-btn.active span:nth-child(2) {
	opacity: 0;
}

.hamburger-btn.active span:nth-child(3) {
	transform: translateY(-10.5px) rotate(-45deg);
}

.nav-items {
	display: flex;
	align-items: center;
	flex: 1;
	order: 2;
}

.nav-items a {
	display: flex;
	align-items: center;
	padding: 0 var(--spacing-4);
	height: 60px;
	color: var(--text-dark);
	text-decoration: none;
	font-weight: var(--font-weight-medium);
	transition: all var(--transition-fast);
}

.nav-items a i {
	margin-right: var(--spacing-2);
}

.nav-items a:hover {
	color: var(--primary);
	background-color: rgba(67, 97, 238, 0.05);
}

.nav-items a.active {
	color: var(--primary);
	background-color: rgba(67, 97, 238, 0.1);
	border-bottom: 2px solid var(--primary);
}

/* Masquer le menu utilisateur mobile sur desktop (visible uniquement sur mobile ≤768px) */
.user-menu-mobile {
	display: none;
}

.user-menu {
	position: relative;
	margin-left: auto;
	order: 4;
}

.user-info {
	display: flex;
	align-items: center;
	cursor: pointer;
	padding: var(--spacing-2) var(--spacing-4);
	border-radius: var(--border-radius);
	transition: background-color var(--transition-fast);
}

.user-info:hover {
	background-color: rgba(0, 0, 0, 0.05);
}

.user-info span {
	margin-right: var(--spacing-3);
	font-weight: var(--font-weight-medium);
}

.user-info img {
	width: 32px;
	height: 32px;
	border-radius: 50%;
}

.dropdown-menu {
	position: absolute;
	top: 100%;
	right: 0;
	width: 200px;
	background-color: var(--bg-card);
	border: 1px solid var(--border-color);
	border-radius: var(--border-radius);
	box-shadow: var(--box-shadow);
	display: none;
	z-index: var(--z-dropdown);
}

.user-menu:hover .dropdown-menu {
	display: block;
}

.dropdown-menu a {
	display: block;
	padding: var(--spacing-3) var(--spacing-4);
	color: var(--text-dark);
	text-decoration: none;
	transition: background-color var(--transition-fast);
}

.dropdown-menu a:hover {
	background-color: rgba(0, 0, 0, 0.05);
	text-decoration: none;
}

.dropdown-menu a i {
	margin-right: var(--spacing-2);
	width: 16px;
	text-align: center;
}

/* Interface de saisie rapide */
.quick-entry {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 100vh;
	background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
}

.quick-entry-card {
	background-color: var(--bg-card);
	border-radius: var(--border-radius);
	box-shadow: var(--box-shadow-lg);
	padding: var(--spacing-8);
	width: 100%;
	max-width: 560px;
	margin: var(--spacing-4);
}

.quick-entry-card .header {
	text-align: center;
	margin-bottom: var(--spacing-6);
}

.quick-entry-card .header h1 {
	font-size: var(--font-size-2xl);
	color: var(--primary);
	margin-bottom: var(--spacing-2);
}

.time-group {
	flex: 2;
}

.date-group {
	flex: 1;
}

.time-input-wrapper {
	display: flex;
}

.time-input-wrapper input {
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
}

.btn-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border: none;
	background-color: var(--primary);
	color: white;
	border-top-right-radius: var(--border-radius);
	border-bottom-right-radius: var(--border-radius);
	cursor: pointer;
	transition: background-color var(--transition-fast);
}

.btn-icon:hover {
	background-color: var(--primary-dark);
}

.form-actions {
	margin-top: var(--spacing-6);
}

.success-message {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--spacing-2);
	margin-top: var(--spacing-4);
	padding: var(--spacing-3);
	background-color: var(--success);
	color: white;
	border-radius: var(--border-radius);
	font-weight: var(--font-weight-medium);
}

/* --- UTILITAIRES --- */
.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: var(--spacing-1); }
.mb-2 { margin-bottom: var(--spacing-2); }
.mb-3 { margin-bottom: var(--spacing-3); }
.mb-4 { margin-bottom: var(--spacing-4); }
.mb-5 { margin-bottom: var(--spacing-5); }
.mb-6 { margin-bottom: var(--spacing-6); }

.mt-0 { margin-top: 0; }
.mt-1 { margin-top: var(--spacing-1); }
.mt-2 { margin-top: var(--spacing-2); }
.mt-3 { margin-top: var(--spacing-3); }
.mt-4 { margin-top: var(--spacing-4); }
.mt-5 { margin-top: var(--spacing-5); }
.mt-6 { margin-top: var(--spacing-6); }

.ml-auto { margin-left: auto; }
.mr-auto { margin-right: auto; }
.mx-auto { margin-left: auto; margin-right: auto; }

.d-flex { display: flex; }
.d-block { display: block; }
.d-inline-block { display: inline-block; }
.d-none { display: none; }

.flex-column { flex-direction: column; }
.flex-row { flex-direction: row; }
.flex-wrap { flex-wrap: wrap; }
.flex-nowrap { flex-wrap: nowrap; }
.flex-grow-1 { flex-grow: 1; }

.justify-content-start { justify-content: flex-start; }
.justify-content-end { justify-content: flex-end; }
.justify-content-center { justify-content: center; }
.justify-content-between { justify-content: space-between; }
.justify-content-around { justify-content: space-around; }

.align-items-start { align-items: flex-start; }
.align-items-end { align-items: flex-end; }
.align-items-center { align-items: center; }
.align-items-baseline { align-items: baseline; }
.align-items-stretch { align-items: stretch; }

.p-0 { padding: 0; }
.p-1 { padding: var(--spacing-1); }
.p-2 { padding: var(--spacing-2); }
.p-3 { padding: var(--spacing-3); }
.p-4 { padding: var(--spacing-4); }
.p-5 { padding: var(--spacing-5); }
.p-6 { padding: var(--spacing-6); }

.rounded { border-radius: var(--border-radius); }
.rounded-circle { border-radius: 50%; }
.rounded-pill { border-radius: 50rem; }

.shadow { box-shadow: var(--box-shadow); }
.shadow-sm { box-shadow: var(--box-shadow-sm); }
.shadow-lg { box-shadow: var(--box-shadow-lg); }

.w-100 { width: 100%; }
.h-100 { height: 100%; }

/* --- RESPONSIVE --- */

/* Tablettes et petits écrans */
@media (max-width: 992px) {
	.container {
		padding: 0 var(--spacing-3);
	}

	/* Grille responsive */
	.col-1, .col-2, .col-3, .col-4, .col-5, .col-6,
	.col-7, .col-8, .col-9, .col-10, .col-11, .col-12 {
		flex: 0 0 100%;
		max-width: 100%;
	}

	/* Cartes */
	.card {
		margin-bottom: var(--spacing-4);
	}

	.card-body {
		padding: var(--spacing-4);
	}

	/* Boutons */
	.btn-block {
		width: 100%;
	}
}

/* Mobiles et petits écrans */
@media (max-width: 768px) {
	/* Reset de base */
	html {
		font-size: 14px;
	}

	.container {
		padding: 0 var(--spacing-3);
	}

	/* Typographie responsive */
	h1 {
		font-size: var(--font-size-3xl);
	}

	h2 {
		font-size: var(--font-size-2xl);
	}

	h3 {
		font-size: var(--font-size-xl);
	}

	/* Navigation responsive avec menu hamburger */
	.nav-content {
		position: relative;
		height: 60px;
		justify-content: space-between;
	}

	.logo {
		margin-right: 0;
	}

	/* Afficher le bouton hamburger sur mobile à droite */
	.hamburger-btn {
		display: flex;
		margin-left: 0;
	}

	/* Masquer le menu utilisateur par défaut sur mobile (il sera dans le hamburger) */
	.user-menu {
		display: none;
	}

	/* Menu navigation mobile */
	.nav-items {
		position: fixed;
		top: 60px;
		left: 0;
		right: 0;
		flex-direction: column;
		background-color: var(--bg-card);
		border-bottom: 1px solid var(--border-color);
		box-shadow: var(--box-shadow-lg);
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.3s ease;
		z-index: 999;
	}

	.nav-items.active {
		max-height: calc(100vh - 60px);
		overflow-y: auto;
	}

	.nav-items a {
		width: 100%;
		height: auto;
		padding: var(--spacing-3) var(--spacing-4);
		border-bottom: 1px solid var(--border-color);
		border-left: 3px solid transparent;
	}

	.nav-items a:hover {
		background-color: rgba(67, 97, 238, 0.05);
	}

	.nav-items a.active {
		border-left: 3px solid var(--primary);
		border-bottom-color: var(--border-color);
		background-color: rgba(67, 97, 238, 0.05);
	}

	/* Menu utilisateur mobile dans le menu hamburger */
	.nav-items .user-menu-mobile {
		display: block;
		border-top: 2px solid var(--border-color);
		margin-top: var(--spacing-2);
	}

	.nav-items .user-menu-mobile .user-info-mobile {
		display: flex;
		align-items: center;
		width: 100%;
		padding: var(--spacing-3) var(--spacing-4);
		border-bottom: 1px solid var(--border-color);
		background-color: rgba(67, 97, 238, 0.03);
		font-weight: var(--font-weight-semibold);
	}

	.nav-items .user-menu-mobile .user-info-mobile img {
		width: 32px;
		height: 32px;
		border-radius: 50%;
		margin-right: var(--spacing-3);
	}

	.nav-items .user-menu-mobile a {
		padding-left: calc(var(--spacing-4) + var(--spacing-6));
	}

	/* Empêcher le scroll du body quand le menu est ouvert */
	body.menu-open {
		overflow: hidden;
	}

	/* Auth pages */
	.auth-card {
		padding: var(--spacing-4);
	}

	.auth-logo h1 {
		font-size: var(--font-size-2xl);
	}

	/* Formulaires */
	.form-row {
		flex-direction: column;
	}

	.form-group {
		margin-bottom: var(--spacing-3);
	}

	.input-group {
		flex-direction: column;
	}

	.input-group > .form-control,
	.input-group-text {
		width: 100%;
		border-radius: var(--border-radius) !important;
	}

	.input-group-text {
		margin-bottom: var(--spacing-2);
	}

	/* Boutons */
	.btn-group {
		flex-direction: column;
		gap: var(--spacing-2);
	}

	.btn-group .btn {
		width: 100%;
	}

	/* Cartes */
	.card-header {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--spacing-2);
	}

	.card-header .btn,
	.card-header .btn-group {
		width: 100%;
		margin-left: 0 !important;
	}

	/* Tableaux responsive */
	.table-responsive {
		width: 100%;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}

	table {
		min-width: 600px;
	}

	table th,
	table td {
		padding: var(--spacing-2) var(--spacing-1);
		font-size: var(--font-size-sm);
	}

	/* Grille */
	.row {
		margin-left: calc(-1 * var(--spacing-2));
		margin-right: calc(-1 * var(--spacing-2));
	}

	.col {
		padding: 0 var(--spacing-2);
	}

	/* Quick entry */
	.quick-entry-card {
		padding: var(--spacing-4);
		margin: var(--spacing-2);
	}

	.time-group,
	.date-group {
		min-width: 100%;
	}

	/* Dropdown menu */
	.dropdown-menu {
		position: fixed;
		top: auto;
		right: var(--spacing-2);
		left: var(--spacing-2);
		width: auto;
	}

	/* Espacements */
	.mb-6 { margin-bottom: var(--spacing-4); }
	.mt-6 { margin-top: var(--spacing-4); }
	.p-6 { padding: var(--spacing-4); }
}

/* Très petits écrans (smartphones en portrait) */
@media (max-width: 576px) {
	html {
		font-size: 13px;
	}

	.container {
		padding: 0 var(--spacing-2);
	}

	/* Typographie */
	h1 {
		font-size: var(--font-size-2xl);
	}

	h2 {
		font-size: var(--font-size-xl);
	}

	h3 {
		font-size: var(--font-size-lg);
	}

	/* Navigation */
	.nav-items a {
		padding: var(--spacing-2);
		/*font-size: 0.75rem;*/
		font-size: 1.8rem;
	}

	/* Formulaires */
	.form-control,
	.btn {
		font-size: var(--font-size-sm);
		padding: var(--spacing-2);
	}

	.btn-lg {
		padding: var(--spacing-2) var(--spacing-4);
		font-size: var(--font-size-base);
	}

	/* Cartes */
	.card-body {
		padding: var(--spacing-3);
	}

	.card-header,
	.card-footer {
		padding: var(--spacing-2) var(--spacing-3);
	}

	/* Auth */
	.auth-container {
		padding: 0 var(--spacing-2);
	}

	.auth-card {
		padding: var(--spacing-3);
	}

	.auth-logo h1 {
		font-size: var(--font-size-xl);
	}

	.auth-logo img {
		width: 60px;
		height: 60px;
	}

	/* Badges */
	.badge {
		font-size: 0.65rem;
		padding: 2px 6px;
	}

	/* Quick entry */
	.quick-entry-card .header h1 {
		font-size: var(--font-size-xl);
	}

	/* Espacements réduits */
	.mb-4 { margin-bottom: var(--spacing-3); }
	.mt-4 { margin-top: var(--spacing-3); }
	.p-4 { padding: var(--spacing-3); }
}

/* Mode paysage sur mobile */
@media (max-width: 768px) and (orientation: landscape) {
	.auth-page,
	.quick-entry {
		min-height: auto;
		padding: var(--spacing-4) 0;
	}

	.hero-section {
		min-height: auto;
		padding: var(--spacing-8) 0;
	}
}

/* Animation de chargement */
.spinner {
	display: inline-block;
	width: 40px;
	height: 40px;
	border: 4px solid rgba(0, 0, 0, 0.1);
	border-radius: 50%;
	border-top-color: var(--primary);
	animation: spin 1s ease-in-out infinite;
}

/* Pied de page principal */
.main-footer {
	margin-top: var(--spacing-8);
	padding: var(--spacing-6) 0;
	background-color: var(--bg-card);
	border-top: 1px solid var(--border-color);
	text-align: center;
	color: var(--text-muted);
	font-size: var(--font-size-sm);
}

@keyframes spin {
	to { transform: rotate(360deg); }
}

/* Imprimante */
@media print {
	.no-print {
		display: none !important;
	}
	
	body {
		background-color: #fff;
	}
	
	.container {
		max-width: 100%;
		padding: 0;
	}
	
	.card {
		box-shadow: none;
		border: 1px solid #000;
	}
}
