/* ==========================================================================
   Main CSS - Le Clic à Vrac
   Layout, Buttons, Forms, Modal, Utilities
   
   Note: Variables définies dans critical.css
   ========================================================================== */

/* ==========================================================================
   Layout
   ========================================================================== */

.site-main {
	min-height: calc(100vh - var(--cav-header-height) - 200px);
	padding-block: var(--cav-space-xl);
}

@media (max-width: 767px) {
	.site-main {
		padding-bottom: calc(var(--cav-mobile-nav-height) + var(--cav-space-xl));
	}
}

/* ==========================================================================
   Search Form
   ========================================================================== */

.search-form {
	position: relative;
	display: flex;
	align-items: center;
}

.search-form__input {
	width: 100%;
	padding: var(--cav-space-sm) var(--cav-space-md);
	padding-left: 2.5rem;
	font-family: inherit;
	font-size: var(--cav-font-sm);
	color: var(--cav-text);
	background-color: var(--cav-bg);
	border: 1px solid transparent;
	border-radius: var(--cav-radius-full);
	transition: border-color var(--cav-transition-fast), box-shadow var(--cav-transition-fast);
}

.search-form__input:focus {
	outline: none;
	border-color: var(--cav-primary);
	box-shadow: 0 0 0 3px rgb(59 154 156 / 0.1);
}

.search-form__input::placeholder {
	color: var(--cav-text-lighter);
}

.search-form__icon {
	position: absolute;
	left: var(--cav-space-md);
	color: var(--cav-text-light);
	pointer-events: none;
}

.search-form__submit {
	position: absolute;
	right: 4px;
	padding: var(--cav-space-xs) var(--cav-space-md);
	font-size: var(--cav-font-sm);
	font-weight: 600;
	color: var(--cav-text-inverse);
	background-color: var(--cav-primary);
	border: none;
	border-radius: var(--cav-radius-full);
	transition: background-color var(--cav-transition-fast);
}

.search-form__submit:hover {
	background-color: var(--cav-primary-dark);
}

/* ==========================================================================
   Buttons
   ========================================================================== */

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--cav-space-sm);
	padding: var(--cav-space-sm) var(--cav-space-lg);
	font-family: inherit;
	font-size: var(--cav-font-sm);
	font-weight: 600;
	line-height: 1.5;
	text-align: center;
	text-decoration: none;
	color: var(--cav-text);
	background-color: var(--cav-secondary);
	border: none;
	border-radius: var(--cav-radius-lg);
	cursor: pointer;
	transition: background-color var(--cav-transition-fast), transform var(--cav-transition-fast);
}

.btn:hover {
	background-color: var(--cav-secondary-dark);
	transform: translateY(-1px);
}

.btn:active {
	transform: translateY(0);
}

.btn:disabled {
	opacity: 0.6;
	cursor: not-allowed;
	transform: none;
}

.btn--primary {
	color: var(--cav-text-inverse);
	background-color: var(--cav-primary);
}

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

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

.btn--outline:hover {
	color: var(--cav-text-inverse);
	background-color: var(--cav-primary);
}

.btn--ghost {
	color: var(--cav-text);
	background-color: transparent;
}

.btn--ghost:hover {
	background-color: var(--cav-bg);
}

.btn--success {
	color: var(--cav-text-inverse);
	background-color: var(--cav-success);
}

.btn--sm {
	padding: var(--cav-space-xs) var(--cav-space-md);
	font-size: var(--cav-font-xs);
}

.btn--lg {
	padding: var(--cav-space-md) var(--cav-space-xl);
	font-size: var(--cav-font-base);
}

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

.btn--icon {
	padding: var(--cav-space-sm);
}

/* ==========================================================================
   Forms
   ========================================================================== */

.form-group {
	margin-bottom: var(--cav-space-md);
}

.form-label {
	display: block;
	margin-bottom: var(--cav-space-xs);
	font-size: var(--cav-font-sm);
	font-weight: 600;
	color: var(--cav-text);
}

.form-label--required::after {
	content: ' *';
	color: var(--cav-error);
}

.form-input,
.form-textarea,
.form-select {
	width: 100%;
	padding: var(--cav-space-sm) var(--cav-space-md);
	font-family: inherit;
	font-size: var(--cav-font-base);
	color: var(--cav-text);
	background-color: var(--cav-bg-alt);
	border: 1px solid var(--cav-border);
	border-radius: var(--cav-radius-md);
	transition: border-color var(--cav-transition-fast), box-shadow var(--cav-transition-fast);
}

.form-input:focus,
.form-textarea:focus,
.form-select:focus {
	outline: none;
	border-color: var(--cav-primary);
	box-shadow: 0 0 0 3px rgb(59 154 156 / 0.1);
}

.form-input::placeholder,
.form-textarea::placeholder {
	color: var(--cav-text-lighter);
}

.form-input--error,
.form-textarea--error,
.form-select--error {
	border-color: var(--cav-error);
}

.form-error {
	margin-top: var(--cav-space-xs);
	font-size: var(--cav-font-sm);
	color: var(--cav-error);
}

.form-hint {
	margin-top: var(--cav-space-xs);
	font-size: var(--cav-font-sm);
	color: var(--cav-text-light);
}

/* ==========================================================================
   Breadcrumb
   ========================================================================== */

.breadcrumb {
	margin-bottom: var(--cav-space-lg);
}

/* Masquer le fil d'ariane en mobile */
@media (max-width: 767px) {
	.breadcrumb {
		display: none;
	}
}

.breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--cav-space-sm);
	margin: 0;
	padding: 0;
	list-style: none;
}

.breadcrumb__item {
	display: flex;
	align-items: center;
	gap: var(--cav-space-sm);
	font-size: var(--cav-font-sm);
	color: var(--cav-text-light);
}

.breadcrumb__item:not(:last-child)::after {
	content: '/';
	color: var(--cav-border-dark);
}

.breadcrumb__link {
	color: var(--cav-text-light);
	transition: color var(--cav-transition-fast);
}

.breadcrumb__link:hover {
	color: var(--cav-primary);
}

.breadcrumb__item--current {
	color: var(--cav-text);
	font-weight: 600;
}

/* ==========================================================================
   Notices
   ========================================================================== */

.cav-notice {
	display: flex;
	align-items: center;
	gap: var(--cav-space-sm);
	padding: var(--cav-space-md);
	border-radius: var(--cav-radius-md);
	font-size: var(--cav-font-sm);
}

.cav-notice--info {
	color: var(--cav-primary-dark);
	background-color: rgb(59 154 156 / 0.1);
}

.cav-notice--success {
	color: #2E7D32;
	background-color: var(--cav-success-light);
}

.cav-notice--warning {
	color: #E65100;
	background-color: var(--cav-warning-light);
}

.cav-notice--error {
	color: #C62828;
	background-color: var(--cav-error-light);
}

.cav-notice__icon {
	flex-shrink: 0;
	font-size: var(--cav-font-lg);
}

/* ==========================================================================
   Modal
   ========================================================================== */

.modal {
	position: fixed;
	inset: 0;
	z-index: 101;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--cav-space-md);
	background-color: rgb(128 128 128 / 0.6);
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--cav-transition-base), visibility var(--cav-transition-base);
}

.modal[aria-hidden="true"] {
	opacity: 0;
	visibility: hidden;
}

.modal[aria-hidden="false"],
.modal--open {
	opacity: 1;
	visibility: visible;
}

.modal__overlay {
	position: absolute;
	inset: 0;
}

.modal__container {
	position: relative;
	max-height: calc(90svh - var(--cav-mobile-nav-height));
	width: 100%;
	max-width: 600px;
	overflow: hidden;
	border-radius: var(--cav-radius-xl);
	background-color: var(--cav-bg-alt);
	border-radius: var(--cav-radius-xl);
	box-shadow: var(--cav-shadow-xl);
	transform: translateY(20px);
	transition: transform var(--cav-transition-base);
	display: flex;
	flex-direction: column;
}

.modal--open .modal__container,
.modal--open .modal__body,
.modal[aria-hidden="false"] .modal__container {
	transform: translateY(0);
}

.modal__header {
	position: sticky;
	top: 0;
	background-color: var(--cav-bg-alt);
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--cav-space-lg);
	border-bottom: 1px solid var(--cav-border);
}

.modal__title {
	margin: 0;
	font-size: var(--cav-font-lg);
}

.modal__subtitle {
	margin: 0 0 var(--cav-space-md);
	font-size: var(--cav-font-sm);
	color: var(--cav-text-light);
}

.modal__close {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	padding: 0;
	color: var(--cav-text-light);
	background: none;
	border: none;
	border-radius: var(--cav-radius-full);
	transition: background-color var(--cav-transition-fast), color var(--cav-transition-fast);
}

.modal__close:hover {
	color: var(--cav-text);
	background-color: var(--cav-bg);
}

.modal__close--absolute {
	position: absolute;
	top: var(--cav-space-md);
	right: var(--cav-space-md);
	z-index: 10;
}

.modal__body {
	max-height: 60vh;
	padding: var(--cav-space-lg);
	overflow: auto;

	/* Firefox */
	scrollbar-width: thin;
	scrollbar-color: var(--cav-primary) var(--cav-bg-alt);
}

.modal__body::-webkit-scrollbar-track {
	background: var(--cav-primary);
}

.modal__body::-webkit-scrollbar-thumb {
	background: var(--cav-primary);
}

.modal__body::-webkit-scrollbar-thumb:hover {
	background: var(--cav-primary);
}

.modal__footer {
	position: sticky;
	bottom: 0;
	background-color: var(--cav-bg-alt);
	display: flex;
	gap: var(--cav-space-md);
	padding: var(--cav-space-lg);
	border-top: 1px solid var(--cav-border);
}

.modal__btn {
	padding: var(--cav-space-sm) var(--cav-space-lg);
	font-family: inherit;
	font-size: var(--cav-font-base);
	font-weight: 600;
	border: none;
	border-radius: var(--cav-radius-md);
	cursor: pointer;
	transition: background-color var(--cav-transition-fast);
}

.modal__btn--primary {
	color: var(--cav-text-inverse);
	background-color: var(--cav-primary);
}

.modal__btn--primary:hover {
	background-color: var(--cav-primary-dark);
}

.modal__btn--secondary {
	color: var(--cav-text);
	background-color: var(--cav-bg);
}

.modal__btn--secondary:hover {
	background-color: var(--cav-border);
}

/* Bouton jaune pour modale info (consigne) */
.modal--info .modal__btn--primary {
	color: var(--cav-text);
	background-color: var(--cav-secondary);
}

.modal--info .modal__btn--primary:hover {
	background-color: var(--cav-secondary-dark, #e6a800);
}

.modal__view-product {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--cav-space-xs);
	margin-top: var(--cav-space-lg);
	font-size: var(--cav-font-sm);
	color: var(--cav-primary);
	text-decoration: none;
}

.modal__view-product:hover {
	text-decoration: underline;
}

/* Modal Info (style spécifique) */

.modal--info .modal__header {
	padding: var(--cav-space-lg) var(--cav-space-xl);
	border-bottom: none;
	text-align: center;
	align-items: flex-start;
}

.modal--info .modal__title {
	font-size: var(--cav-font-xl);
	font-weight: 700;
	color: var(--cav-text);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.modal--info .modal__footer {
	padding: var(--cav-space-lg) var(--cav-space-xl);
	display: flex;
	justify-content: center;
}

@media (max-width: 767px) {
	.modal {
		inset: 0 0 var(--cav-mobile-nav-height) 0
	}

	.modal--info .modal__title {
		font-size: var(--cav-font-lg);
	}
}

/* ==========================================================================
   Utilities
   ========================================================================== */

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

.font-bold { font-weight: 700; }
.font-semibold { font-weight: 600; }
.font-medium { font-weight: 500; }

.text-sm { font-size: var(--cav-font-sm); }
.text-lg { font-size: var(--cav-font-lg); }
.text-xl { font-size: var(--cav-font-xl); }

.text-muted { color: var(--cav-text-light); }
.text-primary { color: var(--cav-primary); }
.text-success { color: var(--cav-success); }
.text-error { color: var(--cav-error); }

.mt-0 { margin-top: 0; }
.mt-sm { margin-top: var(--cav-space-sm); }
.mt-md { margin-top: var(--cav-space-md); }
.mt-lg { margin-top: var(--cav-space-lg); }
.mt-xl { margin-top: var(--cav-space-xl); }

.mb-0 { margin-bottom: 0; }
.mb-sm { margin-bottom: var(--cav-space-sm); }
.mb-md { margin-bottom: var(--cav-space-md); }
.mb-lg { margin-bottom: var(--cav-space-lg); }
.mb-xl { margin-bottom: var(--cav-space-xl); }

.flex { display: flex; }
.flex-col { flex-direction: column; }
.items-center { align-items: center; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.gap-sm { gap: var(--cav-space-sm); }
.gap-md { gap: var(--cav-space-md); }
.gap-lg { gap: var(--cav-space-lg); }

.grid { display: grid; }

.hidden { display: none !important; }

@media (max-width: 767px) {
	.hidden-mobile { display: none !important; }
}

@media (min-width: 768px) {
	.hidden-desktop { display: none !important; }
}

/* WP Block overrides */
figure.aligncenter {
	margin-left: auto;
	margin-right: auto;
}

/* ==========================================================================
   Page 404
   ========================================================================== */

.error-404 {
	max-width: 600px;
	margin: 0 auto;
	padding: var(--cav-space-2xl) var(--cav-space-md);
	text-align: center;
}

.error-404__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 120px;
	height: 120px;
	margin: 0 auto var(--cav-space-xl);
	background: var(--cav-primary-light);
	border-radius: var(--cav-radius-full);
	color: var(--cav-primary);
}

.error-404__title {
	margin: 0 0 var(--cav-space-md);
	font-size: var(--cav-font-2xl);
	color: var(--cav-text);
}

.error-404__text {
	margin: 0 0 var(--cav-space-xl);
	font-size: var(--cav-font-md);
	color: var(--cav-text-light);
}

.error-404__search {
	margin-bottom: var(--cav-space-xl);
}

.error-404__search-form {
	position: relative;
	display: flex;
	max-width: 400px;
	margin: 0 auto;
}

.error-404__search-input {
	width: 100%;
	padding: var(--cav-space-md) var(--cav-space-lg);
	padding-right: 56px;
	font-family: inherit;
	font-size: var(--cav-font-base);
	color: var(--cav-text);
	background: var(--cav-bg-alt);
	border: 1px solid var(--cav-border);
	border-radius: var(--cav-radius-full);
	transition: border-color var(--cav-transition-fast), box-shadow var(--cav-transition-fast);
}

.error-404__search-input:focus {
	outline: none;
	border-color: var(--cav-primary);
	box-shadow: 0 0 0 3px rgba(59, 154, 156, 0.1);
}

.error-404__search-input::placeholder {
	color: var(--cav-text-lighter);
}

.error-404__search-btn {
	position: absolute;
	right: 4px;
	top: 50%;
	transform: translateY(-50%);
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	padding: 0;
	background: var(--cav-primary);
	border: none;
	border-radius: var(--cav-radius-full);
	color: var(--cav-text-inverse);
	cursor: pointer;
	transition: background-color var(--cav-transition-fast);
}

.error-404__search-btn:hover {
	background: var(--cav-primary-dark);
}

.error-404__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--cav-space-md);
	margin-bottom: var(--cav-space-2xl);
}

.error-404__actions .btn--secondary {
	color: var(--cav-text-inverse);
}

.error-404__actions .btn--secondary .icon {
	color: var(--cav-text-inverse);
}

.error-404__products {
	padding-top: var(--cav-space-xl);
	border-top: 1px solid var(--cav-border);
}

.error-404__products-title {
	margin: 0 0 var(--cav-space-lg);
	font-size: var(--cav-font-lg);
	color: var(--cav-text);
}

.error-404__products-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--cav-space-md);
}

@media (min-width: 640px) {
	.error-404__products-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
