/**
 * Composants UI — boutons, cartes, badges, forms, sticky-actions
 */

/* ============================================
   BOUTONS
   ============================================ */

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-sm);
	padding: 14px 28px;
	font-family: var(--font-body);
	font-size: var(--fs-sm);
	font-weight: 700;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	text-decoration: none;
	border-radius: var(--radius-sm);
	transition: transform .35s cubic-bezier(.2,.8,.2,1),
	            box-shadow .35s cubic-bezier(.2,.8,.2,1),
	            background-color .25s ease,
	            color .25s ease,
	            border-color .25s ease;
	cursor: pointer;
	border: 0;
	min-height: 48px;
	white-space: nowrap;
	position: relative;
	overflow: hidden;
}

/* ---------- Bouton primaire (CTA Réserver / Appeler / Valider…) ---------- */
.btn--primary {
	background: var(--accent);
	color: #fff;
}

/* Shimmer doré : trait de lumière qui traverse au hover (de gauche à droite) */
.btn--primary::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(105deg, transparent 40%, rgba(255,255,255,.42) 50%, transparent 60%);
	transform: translateX(-110%);
	transition: transform .9s ease;
	pointer-events: none;
}

.btn--primary:hover::after {
	transform: translateX(110%);
}

.btn--primary:hover {
	background: var(--accent-hover);
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 14px 30px -8px rgba(176,137,64,.45);
}

/* Variante médicale : remplace l'ombre dorée par une ombre bleue douce */
body.is-medical .btn--primary:hover {
	box-shadow: 0 14px 30px -8px rgba(42,111,186,.35);
}

/* ---------- Bouton fantôme (ghost) ---------- */
.btn--ghost {
	background: transparent;
	color: var(--accent);
	border: 1px solid var(--accent);
}

.btn--ghost:hover {
	background: var(--accent);
	color: #fff;
	transform: translateY(-1px);
}

/* ---------- Bouton "solid" (texte foncé sur fond clair) ---------- */
.btn--solid {
	background: var(--premium-panel, #1A1A1A);
	color: #fff;
}

.btn--solid::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(105deg, transparent 40%, rgba(201,168,106,.5) 50%, transparent 60%);
	transform: translateX(-110%);
	transition: transform .9s ease;
	pointer-events: none;
}
.btn--solid:hover::after { transform: translateX(110%); }

.btn--solid:hover {
	background: var(--accent);
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 14px 30px -8px rgba(176,137,64,.45);
}

/* ---------- WhatsApp (vert) avec shimmer adapté ---------- */
.btn--whatsapp {
	background: var(--color-whatsapp);
	color: #fff;
}

.btn--whatsapp::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(105deg, transparent 40%, rgba(255,255,255,.4) 50%, transparent 60%);
	transform: translateX(-110%);
	transition: transform .9s ease;
	pointer-events: none;
}
.btn--whatsapp:hover::after { transform: translateX(110%); }

.btn--whatsapp:hover {
	background: #1fb858;
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 14px 30px -8px rgba(37,211,102,.35);
}

/* ---------- Halo doux pour bouton MÉDICAL au hover (pulse subtil) ---------- */
@keyframes taxi-medical-halo {
	0%   { box-shadow: 0 0 0 0 rgba(42,111,186,.18), 0 14px 30px -8px rgba(42,111,186,.35); }
	70%  { box-shadow: 0 0 0 14px rgba(42,111,186,0), 0 14px 30px -8px rgba(42,111,186,.35); }
	100% { box-shadow: 0 0 0 0 rgba(42,111,186,0),   0 14px 30px -8px rgba(42,111,186,.35); }
}
body.is-medical .btn--primary:hover {
	animation: taxi-medical-halo 1.4s ease-out infinite;
}

.btn--sm { padding: 10px 18px; min-height: 36px; font-size: var(--fs-xs); }
.btn--lg { padding: 18px 36px; min-height: 56px; font-size: var(--fs-md); }
.btn--block { width: 100%; }

/* ============================================
   BADGES & PILLS
   ============================================ */

.badge {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	padding: 4px 12px;
	border-radius: var(--radius-pill);
	font-size: var(--fs-xs);
	font-weight: 700;
	background: var(--bg-alt);
	color: var(--text);
	border: 1px solid var(--border);
}

.badge--accent {
	background: var(--accent);
	color: var(--on-accent);
	border: 0;
}

.badge--success {
	background: rgba(76, 175, 142, 0.15);
	color: var(--color-success);
	border: 0;
}

.badge--cpam {
	background: rgba(41, 171, 226, 0.12);
	color: var(--medical-signature);
	border: 0;
}

/* ============================================
   CARTES
   ============================================ */

.card {
	background: var(--bg-alt);
	border: 1px solid var(--border);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
}

.card__icon {
	width: 48px;
	height: 48px;
	color: var(--accent);
	margin-bottom: var(--space-md);
}

.card__title {
	font-size: var(--fs-xl);
	margin-bottom: var(--space-sm);
}

.card__text {
	color: var(--text-muted);
	font-size: var(--fs-base);
}

/* ============================================
   FORMS
   ============================================ */

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

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

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

.form-input:focus,
.form-textarea:focus,
.form-select:focus {
	outline: 0;
	border-color: var(--accent);
	box-shadow: 0 0 0 3px rgba(201, 169, 97, 0.18);
}

body.is-medical .form-input:focus,
body.is-medical .form-textarea:focus,
body.is-medical .form-select:focus {
	box-shadow: 0 0 0 3px rgba(41, 171, 226, 0.18);
}

.form-textarea {
	min-height: 120px;
	resize: vertical;
}

.form-help {
	font-size: var(--fs-xs);
	color: var(--text-muted);
	margin-top: var(--space-xs);
}

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

/* ============================================
   STICKY ACTIONS (click-to-call + WhatsApp)
   ============================================ */

.sticky-actions {
	position: fixed;
	bottom: var(--space-lg);
	right: var(--space-lg);
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
	z-index: var(--z-sticky);
}

.sticky-actions__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	box-shadow: var(--shadow-lg);
	color: #fff;
	transition: transform var(--transition-fast), box-shadow var(--transition-fast);
	position: relative;
}

.sticky-actions__btn:hover {
	transform: scale(1.08);
	box-shadow: var(--shadow-xl);
	color: #fff;
}

.sticky-actions__btn--whatsapp { background: var(--color-whatsapp); }
.sticky-actions__btn--phone {
	background: var(--accent);
	color: var(--on-accent);
}
.sticky-actions__btn--phone:hover {
	color: var(--on-accent);
}

.sticky-actions__btn svg {
	width: 26px;
	height: 26px;
}

.sticky-actions__btn--phone {
	display: none;
}

@media (max-width: 1024px) {
	.sticky-actions__btn--phone {
		display: inline-flex;
	}
}

/* Pulse animation pour attirer le regard */
.sticky-actions__btn--whatsapp::before {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: 50%;
	background: var(--color-whatsapp);
	opacity: 0.5;
	animation: pulse 2s infinite;
	z-index: -1;
}

@keyframes pulse {
	0%   { transform: scale(1);   opacity: 0.5; }
	100% { transform: scale(1.8); opacity: 0;   }
}

/* ============================================
   HERO (utilisé en Phase 3)
   ============================================ */

.hero {
	position: relative;
	padding-block: var(--space-4xl);
	overflow: hidden;
}

.hero__title {
	font-size: clamp(var(--fs-3xl), 6vw, var(--fs-5xl));
	margin-bottom: var(--space-md);
}

.hero__lead {
	font-size: var(--fs-lg);
	color: var(--text-muted);
	max-width: 600px;
	margin-bottom: var(--space-xl);
}

.hero__actions {
	display: flex;
	gap: var(--space-md);
	flex-wrap: wrap;
}
