/* ========================================
   VARIABLES CSS - COLORES Y FUENTES DE RIE
   ======================================== */
:root {
	/* Colores principales de RIE */
	--cancel-color: #E3E1E1;
	--primary-color: #62B55A;
	--primary-hover: #4A9B47;
	--primary-light: rgba(98, 181, 90, 0.1);
	--primary-gradient: linear-gradient(135deg, #62B55A, #4A9B47);
	/* Colores de texto */
	--text-primary: #101623;
	--text-secondary: #717784;
	--text-hint: #A1A8B0;
	--white: #FFFFFF;
	/* Colores de fondo */
	--bg-primary: #FFFFFF;
	--bg-secondary: #F9FAFB;
	--bg-tertiary: #E8F3F1;
	--bg-field: #F9FAFB;
	/* Colores adicionales */
	--border-color: #E5E7EB;
	--shadow-light: rgba(0, 0, 0, 0.05);
	--shadow-medium: rgba(0, 0, 0, 0.1);
	--shadow-strong: rgba(0, 0, 0, 0.15);
	/* Colores de estado */
	--success-color: #10B981;
	--warning-color: #F59E0B;
	--error-color: #FF5C5C;

	/* Fuentes (Inter Family como en RIE) */
	--font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI',
		Roboto, sans-serif;
	--font-weight-regular: 400;
	--font-weight-medium: 500;
	--font-weight-semibold: 600;
	--font-weight-bold: 700;
	/* Tamaños de fuente */
	--font-size-xs: 12px;
	--font-size-sm: 14px;
	--font-size-base: 16px;
	--font-size-lg: 18px;
	--font-size-xl: 20px;
	--font-size-2xl: 24px;
	--font-size-3xl: 32px;
	--font-size-4xl: 40px;
	/* Espaciado */
	--spacing-xs: 4px;
	--spacing-sm: 8px;
	--spacing-md: 16px;
	--spacing-lg: 24px;
	--spacing-xl: 32px;
	--spacing-2xl: 48px;
	--spacing-3xl: 64px;
	/* Bordes redondeados */
	--border-radius-sm: 8px;
	--border-radius-md: 12px;
	--border-radius-lg: 16px;
	--border-radius-xl: 20px;
	--border-radius-2xl: 24px;
	/* Sombras */
	--shadow-sm: 0 2px 4px var(--shadow-light);
	--shadow-md: 0 4px 12px var(--shadow-medium);
	--shadow-lg: 0 8px 24px var(--shadow-medium);
	--shadow-xl: 0 16px 32px var(--shadow-strong);
	/* Transiciones */
	--transition-fast: 200ms ease;
	--transition-normal: 300ms ease;
	--transition-slow: 500ms ease;
}

/* ========================================
   RESET Y BASE
   ======================================== */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	font-family: var(--font-family);
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-regular);
	line-height: 1.6;
	color: var(--text-primary);
	background-color: var(--bg-primary);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 var(--spacing-lg);
}

/* ========================================
   UTILIDADES
   ======================================== */
.text-gradient {
	background: var(--primary-gradient);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	font-weight: var(--font-weight-bold);
}

.glass-morphism {
	background: linear-gradient(135deg, rgba(98, 181, 90, 0.15),
			rgba(98, 181, 90, 0.05), rgba(255, 255, 255, 0.1));
	border: 1px solid rgba(98, 181, 90, 0.2);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

/* ====
	TEXT
   ====
*/

.text-danger {
	color: #e63946 !important;
	/* rojo elegante */
	font-weight: 600;
}

.text-success {
	color: #2a9d8f !important;
	/* verde moderno */
	font-weight: 600;
}

/* ========================================
   BOTONES (Estilo RIE)
   ======================================== */
.btn {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-sm);
	padding: 12px 24px;
	border: none;
	border-radius: var(--border-radius-md);
	font-family: var(--font-family);
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-semibold);
	line-height: 1;
	text-decoration: none;
	cursor: pointer;
	transition: all var(--transition-normal);
	position: relative;
	overflow: hidden;
}

a.btn {
	display: inline-flex !important;
	align-items: center !important;
	gap: var(--spacing-sm) !important;
	padding: 12px 24px !important;
	border: none !important;
	border-radius: var(--border-radius-md) !important;
	font-family: var(--font-family) !important;
	font-size: var(--font-size-sm) !important;
	font-weight: var(--font-weight-semibold) !important;
	line-height: 1 !important;
	text-decoration: none !important;
	cursor: pointer !important;
}



.btn:hover {
	transform: translateY(-2px);
}

.btn:active {
	transform: translateY(0);
}


.btn-cancel {
	background: var(--error-color);
	color: var(--white);
	box-shadow: 0 4px 12px rgba(98, 181, 90, 0.3);
}

/* Variante peligrosa */
.danger-btn {
	background: linear-gradient(135deg, #ef4444, #dc2626) !important;
}

.danger-btn:hover {
	box-shadow: 0 6px 18px rgba(239, 68, 68, 0.4) !important;
}

.btn-warning {
	background: var(--warning-color);
	color: var(--text-primary);
	box-shadow: 0 4px 12px rgba(98, 181, 90, 0.3);
}

.btn-primary {
	background: var(--primary-gradient);
	color: var(--white);
	box-shadow: 0 4px 12px rgba(98, 181, 90, 0.3);
}

.btn-success {
	background: var(--primary-color);
	box-shadow: 0 4px 12px rgba(98, 181, 90, 0.3);
}


.btn-primary:hover {
	box-shadow: 0 6px 20px rgba(98, 181, 90, 0.4);
}

.btn-outline {
	background: transparent;
	color: var(--primary-color);
	border: 2px solid var(--primary-color);
}

.btn-outline:hover {
	background: var(--primary-color);
	color: var(--white);
}

.btn-white {
	background: var(--white);
	color: var(--primary-color);
	box-shadow: var(--shadow-md);
}

.btn-outline-white {
	background: transparent;
	color: var(--white);
	border: 2px solid var(--white);
}

.btn-outline-white:hover {
	background: var(--white);
	color: var(--primary-color);
}

.btn-small {
	padding: 8px 16px;
	font-size: var(--font-size-xs);
}

.btn-large {
	padding: 16px 32px;
	font-size: var(--font-size-base);
}

.btn-full {
	width: 100%;
	justify-content: center;
}

/* ========================================
   HEADER Y NAVEGACIÓN
   ======================================== */
.header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	background: rgba(255, 255, 255, 0.95);
	backdrop-filter: blur(20px);
	border-bottom: 1px solid var(--border-color);
	transition: all var(--transition-normal);
}

.header-content {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--spacing-md) 0;
}

.logo {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
}

.logo-container {
	width: 48px;
	height: 48px;
	border-radius: var(--border-radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.logo-icon {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-bold);
	color: var(--primary-color);
}

.logo-text {
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-bold);
	color: var(--text-primary);
}

/* Logo SVG styles */
.logo-svg {
	height: 64px;
	width: auto;
	max-width: 250px;
	display: block;
	transition: all var(--transition-normal);
}

.logo-svg:hover {
	transform: scale(1.05);
}

.logo-svg-footer {
	filter: brightness(0) invert(1);
}

/* Control de visibilidad de logos según tamaño de pantalla */
.logo-mobile {
	display: none;
}

.logo-desktop {
	display: block;
}

.nav-desktop {
	display: flex;
	gap: var(--spacing-xl);
}

.nav-link {
	color: var(--text-secondary);
	text-decoration: none;
	font-weight: var(--font-weight-medium);
	position: relative;
	transition: color var(--transition-normal);
}

.nav-link:hover,
.nav-link.active {
	color: var(--primary-color);
}

.nav-link::after {
	content: '';
	position: absolute;
	bottom: -4px;
	left: 0;
	width: 0;
	height: 2px;
	background: var(--primary-gradient);
	border-radius: 2px;
	transition: width var(--transition-normal);
}

.nav-link:hover::after,
.nav-link.active::after {
	width: 100%;
}

.header-actions {
	display: flex;
	gap: var(--spacing-md);
	align-items: center;
}

.mobile-menu-btn {
	/* Hidden by default, shown on mobile via media query */
	display: none;
	background: none;
	border: none;
	color: var(--primary-color);
	font-size: var(--font-size-2xl);
	cursor: pointer;
	/* Increased padding for larger tap area (minimum 44px recommended) */
	padding: var(--spacing-md);
	min-width: 48px;
	min-height: 48px;
	border-radius: 8px;
	transition: all 0.2s ease;
	position: relative;
	z-index: 1001;
	/* Center the icon within the button */
	align-items: center;
	justify-content: center;
	/* Prevent accidental text selection */
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	/* Better touch handling on mobile */
	-webkit-tap-highlight-color: rgba(98, 181, 90, 0.2);
	touch-action: manipulation;
}

.mobile-menu-btn:hover {
	background: rgba(98, 181, 90, 0.1);
	transform: scale(1.05);
}

.mobile-menu-btn:active {
	background: rgba(98, 181, 90, 0.2);
	transform: scale(0.95);
}

.mobile-menu-btn:focus {
	outline: 2px solid var(--primary-color);
	outline-offset: 2px;
}

/* Ensure the icon is properly centered and doesn't intercept clicks */
.mobile-menu-btn .material-icons {
	font-size: 24px;
	line-height: 1;
	display: block;
	pointer-events: none;
	/* Prevent icon from intercepting clicks */
	-webkit-user-select: none;
	/* Prevent text selection - Safari */
	-moz-user-select: none;
	/* Prevent text selection - Firefox */
	-ms-user-select: none;
	/* Prevent text selection - IE */
	user-select: none;
	/* Prevent text selection - Standard */
}

.mobile-nav-overlay {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0, 0, 0, 0.5);
	z-index: 999;
	opacity: 0;
	transition: opacity 0.3s ease;
}

.mobile-nav-overlay.open {
	opacity: 1;
}

/* ========================================
   NAVEGACIÓN MÓVIL
   ======================================== */
.mobile-nav {
	display: none;
	position: fixed;
	top: 80px;
	left: 0;
	right: 0;
	background: var(--white);
	border-bottom: 1px solid var(--border-color);
	box-shadow: var(--shadow-lg);
	z-index: 1000;
	transform: translateY(-100%);
	opacity: 0;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.mobile-nav.open {
	transform: translateY(0);
	opacity: 1;
}

.mobile-nav-content {
	padding: var(--spacing-lg);
	max-height: calc(100vh - 80px);
	overflow-y: auto;
}

.mobile-nav-link {
	display: block;
	padding: var(--spacing-md) 0;
	color: var(--text-primary);
	text-decoration: none;
	font-weight: var(--font-weight-medium);
	border-bottom: 1px solid var(--border-color);
	transition: color 0.2s ease;
}

.mobile-nav-link:hover,
.mobile-nav-link:focus {
	color: var(--primary-color);
}

.mobile-nav-link:last-of-type {
	border-bottom: none;
}

.mobile-nav-actions {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-md);
	margin-top: var(--spacing-lg);
	padding-top: var(--spacing-lg);
	border-top: 1px solid var(--border-color);
}

/* ========================================
   HERO SECTION
   ======================================== */
.hero {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	overflow: hidden;
	padding-top: 80px;
}

.hero-background {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: -1;
}

.hero-gradient {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(135deg, rgba(98, 181, 90, 0.05) 0%,
			rgba(98, 181, 90, 0.02) 50%, rgba(255, 255, 255, 1) 100%);
}

.hero-circles {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	overflow: hidden;
	pointer-events: none;
}

.hero-circle {
	position: absolute;
	border-radius: 50%;
	background: rgba(98, 181, 90, 0.08);
	animation: float 6s ease-in-out infinite;
	max-width: 600px;
	max-height: 600px;
	overflow: hidden;
}

.row {
	display: flex;
	justify-content: center;
	/* Centra horizontalmente */
	align-items: center;
	/* Centra verticalmente */
	gap: 2rem;
	/* Espacio entre cards */
	flex-wrap: wrap;
	/* Para que en mobile bajen uno debajo del otro */
	margin-top: 30px;
}

.hero-circle-3 {
	width: 150px;
	height: 150px;
	top: 50%;
	left: 10%;
	animation-delay: 4s;
}

@keyframes float {

	0%,
	100% {
		transform: translateY(0px);
	}

	50% {
		transform:




			translateY (-20px);
	}
}

.hero-content {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-3xl);
	align-items: center;
	width: 100%;
}

.hero-text {
	animation: slideInLeft 1s ease-out;
}

.hero-badge {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-sm);
	padding: var(--spacing-sm) var(--spacing-md);
	background: var(--primary-light);
	border: 1px solid rgba(98, 181, 90, 0.2);
	border-radius: 50px;
	color: var(--primary-color);
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-medium);
	margin-bottom: var(--spacing-lg);
}

.hero-title {
	font-size: var(--font-size-4xl);
	font-weight: var(--font-weight-bold);
	line-height: 1.2;
	margin-bottom: var(--spacing-lg);
	color: var(--text-primary);
}

.hero-description {
	font-size: var(--font-size-lg);
	color: var(--text-secondary);
	line-height: 1.6;
	margin-bottom: var(--spacing-xl);
}

.hero-actions {
	display: flex;
	gap: var(--spacing-lg);
	margin-bottom: var(--spacing-2xl);
}

.hero-stats {
	display: flex;
	gap: var(--spacing-xl);
}

.stat-item {
	text-align: center;
}

.stat-number {
	font-size: var(--font-size-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--primary-color);
	line-height: 1;
}

.rating-number {
	font-size: var(--font-size-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--white);

	/* 🔒 blindaje tipográfico */
	line-height: normal;
	display: inline-block;
	white-space: nowrap;

	/* evita glitches con fuentes */
	font-variant-numeric: normal;
	font-feature-settings: "tnum";
}


.stat-label {
	font-size: var(--font-size-sm);
	color: var(--text-secondary);
	margin-top: var(--spacing-xs);
}

.hero-image {
	position: relative;
	animation: slideInRight 1s ease-out;
}

.hero-cards {
	position: relative;
	height: 500px;
}

.hero-card {
	position: absolute;
	background: var(--white);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-lg);
	box-shadow: var(--shadow-lg);
	border: 1px solid var(--border-color);
	animation: fadeInUp 1s ease-out;
}

.hero-card-1 {
	top: 0;
	left: 0;
	width: 280px;
	animation-delay: 0.2s;
}

.hero-card-2 {
	top: 160px;
	right: 0;
	width: 260px;
	animation-delay: 0.4s;
}

.hero-card-3 {
	bottom: 0;
	left: 60px;
	width: 300px;
	animation-delay: 0.6s;
}

.card-icon {
	width: 48px;
	height: 48px;
	background: var(--primary-light);
	border-radius: var(--border-radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: var(--spacing-md);
}

.card-icon .material-icons {
	color: var(--primary-color);
	font-size: 24px;
}

.card-content h4 {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-semibold);
	margin-bottom: var(--spacing-xs);
	color: var(--text-primary);
}

.card-content p {
	color: var(--text-secondary);
	font-size: var(--font-size-sm);
}

/* ========================================
   ANIMACIONES
   ======================================== */
@keyframes slideInLeft {
	from {
		opacity: 0;
		transform: translateX(-50px);
	}

	to {
		opacity: 1;
		transform: translateX(0);
	}

}

@keyframes slideInRight {
	from {
		opacity: 0;
		transform: translateX(50px);
	}

	to {
		opacity: 1;
		transform: translateX(0);
	}

}

@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(30px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}

}

/* ========================================
   SECCIONES COMUNES
   ======================================== */
section {
	padding: var(--spacing-3xl) 0;
}

.section-header {
	text-align: center;
	margin-bottom: var(--spacing-3xl);
}

.section-badge {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-sm);
	padding: var(--spacing-sm) var(--spacing-md);
	background: var(--primary-light);
	border: 1px solid rgba(98, 181, 90, 0.2);
	border-radius: 50px;
	color: var(--primary-color);
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-medium);
	margin-bottom: var(--spacing-lg);
}

.section-title {
	font-size: var(--font-size-3xl);
	font-weight: var(--font-weight-bold);
	color: var(--text-primary);
	margin-bottom: var(--spacing-md);
	line-height: 1.2;
}

.section-description {
	font-size: var(--font-size-lg);
	color: var(--text-secondary);
	max-width: 600px;
	margin: 0 auto;
	line-height: 1.6;
}

.section-cta {
	text-align: center;
	margin-top: var(--spacing-2xl);
}

.user-menu-wrapper {
	position: relative;
	display: inline-block;
}

/* Avatar */
.user-avatar {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	overflow: hidden;
	cursor: pointer;
	border: 2px solid #e5e5e5;
}

.user-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.user-dropdown {
	position: fixed;
	top: 64px;
	/* ajustá según altura del header */
	right: 20px;
	background: #fff;
	min-width: 200px;
	border-radius: 12px;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
	display: none;
	flex-direction: column;
	z-index: 2000;
	/* máximo seguro */
	overflow: hidden;
}


.user-dropdown a {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 12px 16px;
	color: #333;
	text-decoration: none;
	font-size: 14px;
}

.user-dropdown a:hover {
	background-color: #f5f5f5;
}

.user-dropdown .material-icons {
	font-size: 20px;
	color: #666;
}

.dropdown-divider {
	height: 1px;
	background-color: #eee;
}


/* ========================================
   SERVICES SECTION
   ======================================== */
.services {
	background: var(--bg-secondary);
}

.services-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--spacing-xl);
}

.service-card {
	background: var(--white);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-xl);
	border: 1px solid var(--border-color);
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-normal);
	position: relative;
	text-align: center;
}

.service-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--shadow-xl);
}

.service-card.featured {
	border: 2px solid var(--primary-color);
	box-shadow: 0 8px 32px rgba(98, 181, 90, 0.15);
}

.featured-badge {
	position: absolute;
	top: -12px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--primary-gradient);
	color: var(--white);
	padding: var(--spacing-xs) var(--spacing-md);
	border-radius: 20px;
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-semibold);
}

.service-icon {
	width: 80px;
	height: 80px;
	margin: 0 auto var(--spacing-lg);
	border-radius: var(--border-radius-xl);
	display: flex;
	align-items: center;
	justify-content: center;
}

.service-icon .material-icons {
	font-size: 36px;
	color: var(--white);
}

.service-icon-medical {
	background: linear-gradient(135deg, #3B82F6, #2563EB);
}

.register-icon {
	background: var(--primary-color);
}

.service-icon-dental {
	background: linear-gradient(135deg, #10B981, #059669);
}

.service-icon-specialist {
	background: linear-gradient(135deg, #8B5CF6, #7C3AED);
}

.service-icon-emergency {
	background: linear-gradient(135deg, #EF4444, #DC2626);
}

.service-card h3 {
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-semibold);
	margin-bottom: var(--spacing-md);
	color: var(--text-primary);
}

.service-card p {
	color: var(--text-secondary);
	margin-bottom: var(--spacing-lg);
	line-height: 1.6;
}

.service-features {
	margin-bottom: var(--spacing-xl);
	text-align: left;
}

.feature {
	display: flex;
	align-items: center;
	margin-bottom: var(--spacing-sm);
	color: var(--text-secondary);
	font-size: var(--font-size-sm);
}

.feature::before {
	content: '✓';
	color: var(--primary-color);
	font-weight: var(--font-weight-bold);
	margin-right: var(--spacing-sm);
}

.d-none {
	display: none;
}

/* ========================================
   PROFESSIONALS SECTION
   ======================================== */
.professionals-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
	gap: var(--spacing-xl);
}

.professional-card {
	background: var(--white);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-xl);
	border: 1px solid var(--border-color);
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-normal);
}

.professional-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
}

.professional-image {
	position: relative;
	margin-bottom: var(--spacing-lg);
}

.professional-avatar {
	width: 80px;
	height: 80px;
	background: var(--primary-light);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 3px solid var(--white);
	box-shadow: var(--shadow-md);
}

.professional-avatar .material-icons {
	font-size: 36px;
	color: var(--primary-color);
}

.professional-status {
	position: absolute;
	bottom: 0;
	right: calc(100% - 80px);
	background: var(--success-color);
	color: var(--white);
	padding: var(--spacing-xs) var(--spacing-sm);
	border-radius: 20px;
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-medium);
}

.professional-status.offline {
	background: var(--text-hint);
}

.professional-info h3 {
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-semibold);
	margin-bottom: var(--spacing-xs);
	color: var(--text-primary);
}

.professional-specialty {
	color: var(--primary-color);
	font-weight: var(--font-weight-medium);
	margin-bottom: var(--spacing-sm);
}

.professional-rating {
	display: flex;
	align-items: center;
	gap: var(--spacing-xs);
	margin-bottom: var(--spacing-md);
}

.professional-rating .material-icons {
	color: #FFC107;
	font-size: 20px;
}

.rating-count {
	color: var(--text-secondary);
	font-size: var(--font-size-sm);
}

.professional-description {
	color: var(--text-secondary);
	margin-bottom: var(--spacing-lg);
	line-height: 1.6;
}

.professional-tags {
	display: flex;
	gap: var(--spacing-sm);
	margin-bottom: var(--spacing-lg);
	flex-wrap: wrap;
}

.tag {
	background: var(--primary-light);
	color: var(--primary-color);
	padding: var(--spacing-xs) var(--spacing-sm);
	border-radius: 20px;
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-medium);
}

.professional-actions {
	display: flex;
	gap: var(--spacing-md);
}

/* ========================================
   FEATURES SECTION
   ======================================== */
.features {
	background: var(--bg-secondary);
}

.features-content {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-3xl);
	align-items: center;
}

.features-text .section-header {
	text-align: left;
	margin-bottom: var(--spacing-xl);
}

.features-list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-lg);
}

.feature-item {
	display: flex;
	gap: var(--spacing-lg);
	align-items: flex-start;
}

.feature-icon {
	width: 56px;
	height: 56px;
	background: var(--primary-light);
	border-radius: var(--border-radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.feature-icon .material-icons {
	color: var(--primary-color);
	font-size: 24px;
}

.feature-content h4 {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-semibold);
	margin-bottom: var(--spacing-xs);
	color: var(--text-primary);
}

.feature-content p {
	color: var(--text-secondary);
	line-height: 1.6;
}

.features-image {
	display: flex;
	justify-content: center;
	align-items: center;
}

.features-card {
	background: var(--white);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-xl);
	box-shadow: var(--shadow-xl);
	border: 1px solid var(--border-color);
	max-width: 350px;
	width: 100%;
}

.card-header {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	margin-bottom: var(--spacing-lg);
}

.card-header .card-icon {
	width: 48px;
	height: 48px;
	background: var(--primary-light);
	border-radius: var(--border-radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
}

.card-header .material-icons {
	color: var(--primary-color);
	font-size: 24px;
}

.card-title h4 {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-semibold);
	color: var(--text-primary);
	margin-bottom: var(--spacing-xs);
}

.card-title p {
	color: var(--text-secondary);
	font-size: var(--font-size-sm);
}

.card-doctor {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	padding: var(--spacing-md);
	background: var(--bg-secondary);
	border-radius: var(--border-radius-md);
	margin-bottom: var(--spacing-lg);
	position: relative;
}

.doctor-avatar {
	width: 48px;
	height: 48px;
	background: var(--primary-light);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.doctor-avatar .material-icons {
	color: var(--primary-color);
	font-size: 24px;
}

.doctor-info h5 {
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-medium);
	color: var(--text-primary);
	margin-bottom: 2px;
}

.doctor-info p {
	color: var(--text-secondary);
	font-size: var(--font-size-sm);
}

.status-indicator {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	position: absolute;
	top: var(--spacing-md);
	right: var(--spacing-md);
}

.status-indicator.online {
	background: var(--success-color);
}

.status-icon {
	position: absolute;
	top: 8px;
	right: 8px;
	font-size: 22px;
}

.status-complete {
	color: #4caf50;
	/* verde */
}

.status-incomplete {
	color: #f44336;
	/* rojo */
}

.card-actions {
	display: flex;
	gap: var(--spacing-sm);
}

/* ========================================
   CTA SECTION
   ======================================== */
.cta {
	background: var(--primary-gradient);
	color: var(--white);
	text-align: center;
}

.cta-content {
	max-width: 800px;
	margin: 0 auto;
}

.cta-text h2 {
	font-size: var(--font-size-3xl);
	font-weight: var(--font-weight-bold);
	margin-bottom: var(--spacing-md);
}

.cta-text p {
	font-size: var(--font-size-lg);
	margin-bottom: var(--spacing-xl);
	opacity: 0.9;
}

.cta-actions {
	display: flex;
	justify-content: center;
	gap: var(--spacing-lg);
	flex-wrap: wrap;
}

/* ========================================
   FOOTER
   ======================================== */
.footer {
	background: var(--text-primary);
	color: var(--white);
	padding: var(--spacing-3xl) 0 var(--spacing-lg);
}

.footer-content {
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: var(--spacing-3xl);
	margin-bottom: var(--spacing-2xl);
}

.footer-brand .logo-text {
	color: var(--white);
}

.footer-brand p {
	margin: var(--spacing-lg) 0;
	color: rgba(255, 255, 255, 0.8);
	line-height: 1.6;
}

.footer-social {
	display: flex;
	gap: var(--spacing-md);
}

.social-link {
	width: 40px;
	height: 40px;
	background: rgba(255, 255, 255, 0.1);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--white);
	text-decoration: none;
	transition: background var(--transition-normal);
}

.social-link:hover {
	background: var(--primary-color);
}

.footer-links {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--spacing-xl);
}

.footer-column h4 {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-semibold);
	margin-bottom: var(--spacing-lg);
	color: var(--white);
}

.footer-column a {
	display: block;
	color: rgba(255, 255, 255, 0.8);
	text-decoration: none;
	margin-bottom: var(--spacing-sm);
	transition: color var(--transition-normal);
}

.footer-column a:hover {
	color: var(--primary-color);
}

.footer-bottom {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-top: var(--spacing-lg);
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	color: rgba(255, 255, 255, 0.8);
}

.footer-bottom-links {
	display: flex;
	gap: var(--spacing-lg);
}

.footer-bottom-links a {
	color: rgba(255, 255, 255, 0.8);
	text-decoration: none;
	transition: color var(--transition-normal);
}

.footer-bottom-links a:hover {
	color: var(--primary-color);
}

/* ========================================
   RESPONSIVE DESIGN
   ======================================== */
@media (max-width : 1024px) {

	nav .container {
		margin-top: 10px;
	}

	.hero .container {
		margin-top: 40px;
	}

	.hero-content {
		grid-template-columns: 1fr;
		text-align: center;
		gap: var(--spacing-2xl);
	}

	.features-content {
		grid-template-columns: 1fr;
		gap: var(--spacing-2xl);
		text-align: center;
	}

	.features-text .section-header {
		text-align: center;
	}
}

@media (max-width : 768px) {

	.hero .container {
		margin-top: 0;
	}

	.container {
		padding: 0 var(--spacing-sm);
		/* Reduce padding for more compact mobile view */
		max-width: 100%;
		margin: 2px 7px;
	}

	.header-content {
		padding: var(--spacing-sm) 0;
		/* Reduce vertical padding */
	}

	.nav-desktop,
	.header-actions {
		display: none;
	}

	.mobile-menu-btn {
		display: flex;
		/* Use flex instead of block for better centering */
		align-items: center;
		justify-content: center;
		/* Ensure adequate tap area on mobile */
		min-width: 48px;
		min-height: 48px;
		margin-left: var(--spacing-xs);
		/* Reduce margin for more compact layout */
	}

	.logo {
		gap: var(--spacing-sm);
		/* Reduce gap between logo elements */
	}

	.logo-container {
		width: 40px;
		/* Smaller logo container for mobile */
		height: 40px;
	}

	.logo-icon {
		font-size: var(--font-size-md);
		/* Smaller logo text */
	}

	.logo-text {
		font-size: var(--font-size-lg);
		/* Smaller logo text */
	}

	.logo-svg {
		height: 64px;
		/* Logo size on mobile */
		max-width: 150px;
	}

	/* Intercambiar logos en mobile */
	.logo-mobile {
		display: block;
		height: 48px;
		/* Tamaño específico para logo mobile (iso.svg) */
	}

	.logo-desktop {
		display: none;
	}

	.hero-title {
		font-size: var(--font-size-3xl);
	}

	.hero-text {
		text-align: center;
	}

	.hero {
		padding-top: 120px;
		/* Más espacio para evitar que el header oculte el badge */
		min-height: calc(100vh - 40px);
		/* Ajustar altura mínima */
	}

	.section-title {
		font-size: var(--font-size-2xl);
	}

	.hero-actions {
		flex-direction: column;
		align-items: center;
	}

	.hero-badge {
		display: inline-flex !important;
		font-size: var(--font-size-sm);
		padding: var(--spacing-xs) var(--spacing-md);
		margin-bottom: var(--spacing-md);
		justify-content: center;
	}

	.hero-badge .material-icons {
		font-size: 16px;
	}

	.hero-stats {
		justify-content: center;
	}

	.hero-cards {
		height: auto;
		position: static;
	}

	.hero-card {
		position: static;
		margin-bottom: var(--spacing-lg);
		width: 100% !important;
	}

	.services-grid {
		grid-template-columns: 1fr;
	}

	.professionals-grid {
		grid-template-columns: 1fr;
	}

	.cta-actions {
		flex-direction: column;
		align-items: center;
	}

	.footer-content {
		grid-template-columns: 1fr;
		text-align: center;
	}

	.footer-links {
		grid-template-columns: 1fr;
		text-align: left;
	}

	.footer-bottom {
		flex-direction: column;
		gap: var(--spacing-md);
		text-align: center;
	}

}

@media (max-width : 480px) {

	.hero .container {
		margin-top: 20px;
	}

	.container {
		padding: 0 var(--spacing-xs);
		/* Even more compact padding for very small screens */
	}

	.header-content {
		padding: var(--spacing-xs) 0;
		/* Minimal vertical padding */
	}

	.logo {
		gap: var(--spacing-xs);
		/* Minimal gap for very small screens */
	}

	.logo-container {
		width: 36px;
		/* Even smaller for very small screens */
		height: 36px;
	}

	.logo-icon {
		font-size: var(--font-size-sm);
	}

	.logo-text {
		font-size: var(--font-size-md);
	}

	.logo-svg {
		height: 56px;
		/* Logo size on very small screens */
		max-width: 130px;
	}

	.logo-mobile {
		height: 56px;
		/* Tamaño específico para logo mobile en pantallas pequeñas */
	}

	.hero-title {
		font-size: var(--font-size-2xl);
	}

	.section-title {
		font-size: var(--font-size-xl);
	}

	.professional-actions {
		flex-direction: column;
	}

	.card-actions {
		flex-direction: column;
	}

	.cta-text h2 {
		font-size: var(--font-size-2xl);
	}

	/* Enhanced mobile menu button for very small screens */
	.mobile-menu-btn {
		min-width: 44px;
		/* Slightly smaller for very compact layout */
		min-height: 44px;
		padding: var(--spacing-md);
		margin-left: 0;
		/* Remove margin for maximum space efficiency */
	}

	.mobile-menu-btn .material-icons {
		font-size: 24px;
		/* Standard size for very small screens */
	}
}

/* ========================================
   ESTADOS Y INTERACTIVIDAD
   ======================================== */
.btn:focus {
	outline: 2px solid var(--primary-color);
	outline-offset: 2px;
}

.service-card:focus-within {
	transform: translateY(-8px);
	box-shadow: var(--shadow-xl);
	outline: 2px solid var(--primary-color);
}

.professional-card:focus-within {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
	outline: 2px solid var(--primary-color);
}

/* Mejorar accesibilidad */
@media (prefers-reduced-motion : reduce) {

	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}

/* Estados de carga */
.loading {
	opacity: 0.7;
	pointer-events: none;
}

.loading::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 20px;
	height: 20px;
	margin: -10px 0 0 -10px;
	border: 2px solid var(--primary-color);
	border-radius: 50%;
	border-top-color: transparent;
	animation: spin 1s linear infinite;
}

@keyframes spin {
	to {
		transform: rotate(360deg);

	}

}

/* ========================================
   AUTH SECTION (Login/Registro)
   ======================================== */
.auth-section {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	padding-top: 80px;
	padding-bottom: var(--spacing-3xl);
}

.auth-background {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: -1;
}

.auth-container {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-3xl);
	align-items: center;
	max-width: 1100px;
	margin: 0 auto;
}

.auth-form-wrapper {
	max-width: 480px;
	margin: 0 auto;
}

.auth-header {
	text-align: center;
	margin-bottom: var(--spacing-2xl);
}

.auth-header h1 {
	font-size: var(--font-size-3xl);
	font-weight: var(--font-weight-bold);
	color: var(--text-primary);
	margin-bottom: var(--spacing-sm);
}

.auth-header p {
	color: var(--text-secondary);
	font-size: var(--font-size-base);
}

.auth-form {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-lg);
}

.form-group {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-sm);
}

.form-label {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	font-weight: var(--font-weight-medium);
	color: var(--text-primary);
	font-size: var(--font-size-sm);
}

.form-label .material-icons {
	font-size: 18px;
	color: var(--primary-color);
}

.form-input {
	width: 100%;
	padding: 14px 16px;
	border: 2px solid var(--border-color);
	border-radius: var(--border-radius-md);
	font-family: var(--font-family);
	font-size: var(--font-size-base);
	color: var(--text-primary);
	transition: all var(--transition-normal);
	background: var(--bg-field);
}

.form-input:focus {
	outline: none;
	border-color: var(--primary-color);
	background: var(--white);
	box-shadow: 0 0 0 4px rgba(98, 181, 90, 0.1);
}

.input-wrapper {
	position: relative;
}

.toggle-password {
	position: absolute;
	right: 12px;
	top: 0;
	/* transform: translateY(-50%); */
	background: none;
	border: none;
	color: var(--text-secondary);
	cursor: pointer;
	padding: 8px;
	border-radius: 4px;
	/* transition: all var(--transition-fast); */
	/* transition: background 0.2s ease, color 0.2s ease; */

}

.toggle-password {
	position: absolute;
	top: 10;
	right: 0;
	height: 100%;
	width: 48px;
	/* ancho fijo táctil */
	border: none;
	background: transparent;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
}

.toggle-password:hover {
	background: rgba(0, 0, 0, 0.05);
	color: var(--primary-color);
}

.form-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: var(--font-size-sm);
	width: 100%;
	gap: 80px;
}

.checkbox-label {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	cursor: pointer;
	color: var(--text-secondary);
}

.checkbox-label input[type="checkbox"] {
	width: 18px;
	height: 18px;
	cursor: pointer;
}

.link-primary {
	color: var(--primary-color);
	text-decoration: none;
	font-weight: var(--font-weight-medium);
	transition: color var(--transition-fast);
}

.link-primary:hover {
	color: var(--primary-hover);
	text-decoration: underline;
}

.divider {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	margin: var(--spacing-xl) 0;
}

.divider::before,
.divider::after {
	content: '';
	flex: 1;
	height: 1px;
	background: var(--border-color);
}

.divider span {
	color: var(--text-secondary);
	font-size: var(--font-size-sm);
}

.social-buttons {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-md);
	margin-top: var(--spacing-lg);
}

.btn-social {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--spacing-sm);
	padding: 12px 20px;
	border: 2px solid var(--border-color);
	border-radius: var(--border-radius-md);
	background: var(--white);
	font-family: var(--font-family);
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-medium);
	color: var(--text-primary);
	cursor: pointer;
	transition: all var(--transition-normal);
}

.btn-social:hover {
	background: var(--bg-secondary);
	border-color: var(--text-primary);
	transform: translateY(-2px);
	box-shadow: var(--shadow-sm);
}

.btn-social svg {
	flex-shrink: 0;
}

.social-login {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-md);
}

.social-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--spacing-sm);
}

.auth-footer {
	text-align: center;
	margin-top: var(--spacing-md);
	padding-top: var(--spacing-lg);
	border-top: 1px solid var(--border-color);
	color: var(--text-secondary);
}

.auth-image {
	display: flex;
	justify-content: center;
	align-items: center;
}

.auth-card {
	background: var(--white);
	border-radius: var(--border-radius-xl);
	padding: var(--spacing-3xl);
	box-shadow: var(--shadow-xl);
	border: 1px solid var(--border-color);
	text-align: center;
}

.auth-card .card-icon {
	width: 80px;
	height: 80px;
	background: var(--primary-light);
	border-radius: var(--border-radius-xl);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto var(--spacing-lg);
}

.auth-card .card-icon .material-icons {
	font-size: 40px;
	color: var(--primary-color);
}

.auth-card h3 {
	font-size: var(--font-size-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--text-primary);
	margin-bottom: var(--spacing-md);
}

.auth-card p {
	color: var(--text-secondary);
	line-height: 1.6;
	margin-bottom: var(--spacing-2xl);
}

.auth-stats {
	display: flex;
	justify-content: space-around;
	gap: var(--spacing-lg);
}

/* Auth: Forgot password variations */
.auth-container-center {
	max-width: 500px;
	margin: 0 auto;
}

.auth-icon-header {
	display: flex;
	justify-content: center;
	margin-bottom: var(--spacing-xl);
}

.auth-icon-circle {
	width: 80px;
	height: 80px;
	background: var(--primary-light);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.auth-icon-circle .material-icons {
	font-size: 40px;
	color: var(--primary-color);
}

.auth-footer a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--spacing-xs);
}

/* Registro page specifics */
.form-row-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-md);
}

.password-strength {
	margin-top: var(--spacing-sm);
	height: 4px;
	background: var(--border-color);
	border-radius: 2px;
	overflow: hidden;
	transition: all var(--transition-normal);
}

.password-strength::before {
	content: '';
	display: block;
	height: 100%;
	width: 0;
	transition: all var(--transition-normal);
}

.password-strength.weak::before {
	width: 33%;
	background: var(--error-color);
}

.password-strength.medium::before {
	width: 66%;
	background: var(--warning-color);
}

.password-strength.strong::before {
	width: 100%;
	background: var(--success-color);
}

.benefits-list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-md);
	text-align: left;
	margin-top: var(--spacing-xl);
}

.benefit-item {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	color: var(--text-primary);
	font-weight: var(--font-weight-medium);
}

.benefit-item .material-icons {
	color: var(--success-color);
	font-size: 24px;
}

/* Responsive for Auth */
@media (max-width : 1024px) {
	.auth-container {
		grid-template-columns: 1fr;
	}

	.auth-image {
		display: none;
	}
}

@media (max-width : 768px) {
	.auth-form-wrapper {
		padding: var(--spacing-xl);
	}

	.auth-header h1 {
		font-size: var(--font-size-2xl);
	}

	.social-login {
		grid-template-columns: 1fr;
	}

	/* .form-row-grid {
		grid-template-columns: 1fr;
	} */
	/* Form Horarios Profesional */
}



/* ========================================
   PACIENTES - DASHBOARD SHELL
   ======================================== */
.dashboard-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1001;
	background: var(--white);
	border-bottom: 1px solid var(--border-color);
	box-shadow: var(--shadow-sm);
}

.upload-box {
	border: 2px dashed #4CAF50;
	border-radius: 16px;
	padding: 25px;
	text-align: center;
	cursor: pointer;
	transition: 0.2s ease;
	background: #f7fff8;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
}

.upload-box:hover {
	background: #e9ffe9;
	border-color: #3c9e40;
}

.upload-icon {
	font-size: 48px;
	color: #4CAF50;
}

.upload-text {
	font-size: 16px;
	font-weight: 600;
	color: #333;
}

.upload-subtext {
	font-size: 13px;
	color: #777;
}

.preview-img {
	width: 180px;
	height: 180px;
	border-radius: 12px;
	object-fit: cover;
	border: 3px solid #4CAF50;
	margin-top: 12px;
	display: none;
	/* IMPORTANTE */
}

.dashboard-header-content {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--spacing-xl);
	padding: var(--spacing-md) 0;
	padding-bottom: 0;
	position: relative;
	z-index: 1002;
}

.search-bar-container {
	flex: 1;
	max-width: 37.5rem;
	/* 600px ÷ 16 = 37.5rem */
}

.search-bar {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	background: var(--bg-secondary);
	border: 2px solid var(--border-color);
	border-radius: var(--border-radius-md);
	padding: 0.625rem 1rem;
	/* 10px 16px */
	transition: all var(--transition-normal);
}

.search-bar:focus-within {
	border-color: var(--primary-color);
	background: var(--white);
}

.search-bar .material-icons {
	color: var(--text-secondary);
}

.search-bar input {
	flex: 1;
	border: none;
	background: transparent;
	font-family: var(--font-family);
	font-size: var(--font-size-base);
	color: var(--text-primary);
	outline: none;
}

.header-actions {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	position: relative;
	z-index: 1003;
}

.icon-btn {
	position: relative;
	width: 2.75rem;
	/* 44px ÷ 16 = 2.75rem */
	height: 2.75rem;
	background: var(--bg-secondary);
	border: none;
	border-radius: var(--border-radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: all var(--transition-normal);
	color: inherit;
	text-decoration: none;
}

.icon-btn:hover {
	background: var(--primary-light);
	color: var(--primary-color);
}

.icon-btn .badge {
	position: absolute;
	top: -0.25rem;
	/* -4px ÷ 16 = -0.25rem */
	right: -0.25rem;
	background: var(--error-color);
	color: var(--white);
	font-size: 0.625rem;
	/* 10px ÷ 16 = 0.625rem */
	font-weight: var(--font-weight-bold);
	padding: 0.125rem 0.375rem;
	/* 2px, 6px */
	border-radius: 0.625rem;
	/* 10px */
	min-width: 1.125rem;
	/* 18px */
	text-align: center;
}

.user-avatar {
	width: 2.75rem;
	/* 44px ÷ 16 = 2.75rem */
	height: 2.75rem;
	border-radius: 50%;
	overflow: hidden;
	cursor: pointer;
	border: 2px solid var(--primary-color);
}

.user-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.dashboard-nav {
	position: fixed;
	top: 4.75rem;
	/* 76px ÷ 16 = 4.75rem */
	left: 0;
	right: 0;
	z-index: 1000;
	background: var(--white);
	border-bottom: 1px solid var(--border-color);
}

.nav-items {
	display: flex;
	/* gap: var(--spacing-lg); */
}



.nav-item {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	padding: var(--spacing-md) var(--spacing-lg);
	color: var(--text-secondary);
	text-decoration: none;
	font-weight: var(--font-weight-medium);
	border-bottom: 3px solid transparent;
	transition: all var(--transition-normal);
}

.nav-item:hover {
	color: var(--primary-color);
	background: var(--primary-light);
}

.nav-item.active {
	color: var(--primary-color);
	border-bottom-color: var(--primary-color);
}

.dashboard-main {
	padding-top: 9.75rem;
	/* 156px ÷ 16 = 9.75rem */
	padding-bottom: var(--spacing-md);
	background: var(--bg-secondary);
	min-height: 100vh;
}

/* Mejora Mobile perfil-PATIENTS */
@media (max-width: 768px) {
	.dashboard-nav {
		width: 100%;
		max-width: 100%;
		overflow-x: hidden;
		box-sizing: border-box;
	}

	.container .nav-items {
		gap: 4px;
	}

}

.welcome-section {
	margin-bottom: var(--spacing-md);
}

.section {
	margin-bottom: var(--spacing-md);
}

.section-header-inline {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: var(--spacing-xs);
}

.section-header-inline h2 {
	font-size: var(--font-size-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--text-primary);
}

/* Dashboard: cards and grids */
.welcome-card {
	background: var(--primary-gradient);
	color: var(--white);
	border-radius: var(--border-radius-xl);
	padding: var(--spacing-2xl);
	display: flex;
	justify-content: space-between;
	align-items: center;
	box-shadow: var(--shadow-lg);
}

.welcome-content h1 {
	font-size: var(--font-size-3xl);
	font-weight: var(--font-weight-bold);
	margin-bottom: var(--spacing-sm);
}

.welcome-content p {
	font-size: var(--font-size-lg);
	opacity: 0.9;
}

.quick-actions {
	display: flex;
	gap: var(--spacing-md);
}

.quick-action-btn {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--spacing-sm);
	background: rgba(255, 255, 255, 0.2);
	backdrop-filter: blur(10px);
	border: 1px solid rgba(255, 255, 255, 0.3);
	border-radius: var(--border-radius-md);
	padding: var(--spacing-lg);
	color: var(--white);
	cursor: pointer;
	transition: all var(--transition-normal);
	min-width: 140px;
	text-decoration: none;

}

.quick-action-btn:hover {
	background: rgba(255, 255, 255, 0.3);
	transform: translateY(-4px);
}

.quick-action-btn .material-icons {
	font-size: 32px;
}

.appointments-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: var(--spacing-lg);
}

.appointment-card {
	background: var(--white);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-md);
	border: 1px solid var(--border-color);
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-normal);
	box-sizing: border-box;
}

.appointment-card:hover {
	box-shadow: var(--shadow-md);
	transform: translateY(-2px);
}

.appointment-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: var(--spacing-lg);
	padding-bottom: var(--spacing-md);
	border-bottom: 1px solid var(--border-color);
}

.appointment-date {
	display: flex;
	flex-direction: column;
	align-items: center;
	background: var(--primary-light);
	border-radius: var(--border-radius-md);
	padding: var(--spacing-sm) var(--spacing-md);
}

.date-day {
	font-size: var(--font-size-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--primary-color);
	line-height: 1;
}

.date-month {
	font-size: var(--font-size-sm);
	color: var(--text-secondary);
	text-transform: uppercase;
}

.appointment-status {
	padding: 4px 12px;
	border-radius: 20px;
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-semibold);
}

.status-confirmed {
	background: rgba(16, 185, 129, 0.1);
	color: var(--success-color);
}

.status-pending {
	background: rgba(245, 158, 11, 0.1);
	color: var(--warning-color);
}

.status-finished {
	background: rgba(16, 185, 129, 0.1);
	/* verde suave translúcido */
	color: var(--success-color);
	/* tono de éxito */
}

.appointment-body {
	margin-bottom: var(--spacing-lg);
}

.doctor-info {
	display: flex;
	gap: var(--spacing-md);
	margin-bottom: var(--spacing-md);
}

.doctor-avatar {
	width: 48px;
	height: 48px;
	background: var(--primary-light);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.doctor-avatar .material-icons {
	color: var(--primary-color);
	font-size: 24px;
}

.doctor-details {
	/* display: flex; */
}

.doctor-details h4 {
	font-weight: var(--font-weight-semibold);
	margin-bottom: 2px;
}

.doctor-details p {
	color: var(--text-secondary);
	font-size: var(--font-size-sm);
}

.appointment-info {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-sm);
}

.info-item {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	color: var(--text-secondary);
	font-size: var(--font-size-sm);
}

.info-item .material-icons {
	font-size: 18px;
	color: var(--primary-color);
}

.appointment-actions {
	display: flex;
	gap: var(--spacing-sm);
}

.services-grid-compact {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: var(--spacing-lg);
}

.service-card-compact {
	background: var(--white);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-lg);
	text-align: center;
	border: 1px solid var(--border-color);
	transition: all var(--transition-normal);
	cursor: pointer;
}

.service-card-compact:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-md);
}

.service-icon-compact {
	width: 60px;
	height: 60px;
	margin: 0 auto var(--spacing-md);
	border-radius: var(--border-radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
}

.service-icon-compact .material-icons {
	font-size: 30px;
	color: var(--white);
}

.service-card-compact h4 {
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-semibold);
	margin-bottom: var(--spacing-xs);
}

.service-card-compact p {
	color: var(--text-secondary);
	font-size: var(--font-size-sm);
}

.professionals-slider {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
	gap: var(--spacing-lg);
}

.professional-card-horizontal {
	background: var(--white);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-lg);
	border: 1px solid var(--border-color);
	display: flex;
	gap: var(--spacing-lg);
	transition: all var(--transition-normal);
}

.professional-card-horizontal:hover {
	box-shadow: var(--shadow-md);
	transform: translateY(-2px);
}

.professional-image {
	position: relative;
}

.professional-actions-vertical {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-sm);
}

.tips-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
	gap: var(--spacing-lg);
}

.tip-card {
	background: var(--white);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-lg);
	text-align: center;
	border: 1px solid var(--border-color);
}

.tip-card .material-icons {
	font-size: 48px;
	color: var(--primary-color);
	margin-bottom: var(--spacing-md);
}

.tip-card h4 {
	font-weight: var(--font-weight-semibold);
	margin-bottom: var(--spacing-sm);
}

.tip-card p {
	color: var(--text-secondary);
	font-size: var(--font-size-sm);
	line-height: 1.5;
}

@media (max-width : 768px) {
	.dashboard-header-content {
		flex-wrap: wrap;
	}

	.dashboard-header-content .header-actions {
		margin-right: var(--spacing-md);
	}

	.search-bar-container {
		order: 3;
		flex: 1 1 100%;
		margin-top: var(--spacing-md);
	}

	.welcome-card {
		flex-direction: column;
		text-align: center;
		gap: var(--spacing-xl);
	}

	.quick-actions {
		width: 100%;
		justify-content: center;
	}

	.nav-items {
		justify-content: space-between;
		/* flex-wrap: wrap;   */
		/* justify-content: center; */
	}

	.nav-item {
		flex: 1 1 20%;
		/* 5 items = 20% cada uno */
		justify-content: center;
		padding: var(--spacing-sm);
	}

	.nav-item span:last-child {
		display: none;
	}
}

/* ========================================
   PACIENTES - MENSAJES
   ======================================== */
.messages-layout {
	padding-top: 9.75rem;
	/* 156px */
	padding-bottom: 0;
	height: 100vh;
	box-sizing: border-box;
}

.container-full {
	max-width: 100%;
	padding: 0;
	height: calc(100vh - 9.75rem);
	/* 156px */
	box-sizing: border-box;
}

.messages-container {
	display: grid;
	grid-template-columns: 380px 1fr;
	height: 100%;
	background: var(--white);
	border-radius: 0;
	overflow: hidden;
}

.conversations-panel {
	border-right: 1px solid var(--border-color);
	display: flex;
	flex-direction: column;
	background: var(--bg-secondary);
}

.conversations-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--spacing-lg);
	border-bottom: 1px solid var(--border-color);
	background: var(--white);
}

.conversations-header h2 {
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-bold);
}

.search-conversations {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	padding: var(--spacing-md) var(--spacing-lg);
	background: var(--white);
	border-bottom: 1px solid var(--border-color);
}

.search-conversations input {
	flex: 1;
	border: none;
	background: var(--bg-secondary);
	padding: 10px 12px;
	border-radius: var(--border-radius-md);
	font-family: var(--font-family);
	font-size: var(--font-size-sm);
}

.search-conversations input:focus {
	outline: none;
	background: var(--white);
	box-shadow: 0 0 0 2px var(--primary-light);
}

.conversations-list {
	flex: 1;
	overflow-y: auto;
}

.conversation-item {
	display: flex;
	gap: var(--spacing-md);
	padding: var(--spacing-md) var(--spacing-lg);
	cursor: pointer;
	transition: all var(--transition-fast);
	background: var(--white);
	border-bottom: 1px solid var(--border-color);
}

.conversation-item:hover {
	background: var(--bg-secondary);
}

.conversation-item.active {
	background: var(--primary-light);
	border-left: 3px solid var(--primary-color);
}

.conversation-avatar {
	position: relative;
	flex-shrink: 0;
}

.conversation-avatar img {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	object-fit: cover;
}

.status-dot {
	position: absolute;
	bottom: 2px;
	right: 2px;
	width: 12px;
	height: 12px;
	background: var(--text-hint);
	border: 2px solid var(--white);
	border-radius: 50%;
}

.status-dot.online {
	background: var(--success-color);
}

.conversation-info {
	flex: 1;
	min-width: 0;
}

.conversation-header-row {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin-bottom: 4px;
}

.conversation-info h4 {
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-semibold);
	color: var(--text-primary);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.conversation-time {
	font-size: var(--font-size-xs);
	color: var(--text-secondary);
	flex-shrink: 0;
	margin-left: var(--spacing-sm);
}

.conversation-preview {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--spacing-sm);
}

.conversation-preview p {
	font-size: var(--font-size-sm);
	color: var(--text-secondary);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	flex: 1;
}

.unread-badge {
	background: var(--primary-color);
	color: var(--white);
	font-size: 11px;
	font-weight: var(--font-weight-bold);
	padding: 2px 6px;
	border-radius: 10px;
	min-width: 20px;
	text-align: center;
}

.chat-panel {
	display: flex;
	flex-direction: column;
	background: var(--bg-secondary);
	height: 100%;
	overflow: hidden;
}

.chat-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--spacing-lg);
	background: var(--white);
	border-bottom: 1px solid var(--border-color);
	flex-shrink: 0;
}

.chat-header-info {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
}

.chat-header-info h3 {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-semibold);
	margin-bottom: 2px;
}

.status-text {
	font-size: var(--font-size-sm);
	color: var(--success-color);
}

.chat-actions {
	display: flex;
	gap: var(--spacing-sm);
}

.chat-messages {
	flex: 1 1 auto;
	overflow-y: auto;
	overflow-x: hidden;
	padding: var(--spacing-lg);
	display: flex;
	flex-direction: column;
	gap: var(--spacing-md);
	min-height: 0;
	max-height: 100%;
}

.message-date-separator {
	text-align: center;
	margin: var(--spacing-lg) 0;
}

.message-date-separator span {
	background: var(--white);
	color: var(--text-secondary);
	padding: 4px 12px;
	border-radius: 20px;
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-medium);
	box-shadow: var(--shadow-sm);
}

.message {
	display: flex;
	gap: var(--spacing-sm);
	max-width: 70%;
}

.message.sent {
	align-self: flex-end;
	flex-direction: row-reverse;
}

.message.received {
	align-self: flex-start;
}

.message-avatar img {
	width: 32px;
	height: 32px;
	border-radius: 50%;
}

.message-content {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.message.sent .message-content {
	align-items: flex-end;
}

.message-bubble {
	padding: 10px 14px;
	border-radius: var(--border-radius-md);
	word-wrap: break-word;
}

.message.received .message-bubble {
	background: var(--white);
	color: var(--text-primary);
	border-bottom-left-radius: 4px;
}

.message.sent .message-bubble {
	background: var(--primary-color);
	color: var(--white);
	border-bottom-right-radius: 4px;
}

.message-time {
	font-size: 11px;
	color: var(--text-secondary);
	padding: 0 4px;
}

.chat-input-container {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	padding: var(--spacing-lg);
	background: var(--white);
	border-top: 1px solid var(--border-color);
	flex-shrink: 0;
}

.chat-input-wrapper {
	flex: 1;
}

.chat-input {
	width: 100%;
	padding: 12px 16px;
	border: 2px solid var(--border-color);
	border-radius: var(--border-radius-md);
	font-family: var(--font-family);
	font-size: var(--font-size-base);
	background: var(--bg-secondary);
	transition: all var(--transition-normal);
}

.chat-input:focus {
	outline: none;
	border-color: var(--primary-color);
	background: var(--white);
}

.btn-icon {
	width: 44px;
	height: 44px;
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: center;
}

@media (max-width : 768px) {
	.messages-container {
		grid-template-columns: 1fr;
	}

	.conversations-panel {
		display: none;
	}

	.message {
		max-width: 85%;
	}
}

button,
a.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;

	min-height: 44px;
	/* estándar touch */
	padding: 0.6rem 1.2rem;

	font-size: 0.95rem;
	font-weight: 500;
	line-height: 1;

	border-radius: 10px;
	gap: 0.4rem;

	cursor: pointer;
	text-decoration: none;

	white-space: nowrap;
	user-select: none;

	transition:
		background-color 0.2s ease,
		transform 0.1s ease,
		box-shadow 0.2s ease;
}

/* Íconos */
button .material-icons,
a.btn .material-icons {
	font-size: 1.1rem;
}

/* Hover */
button:hover,
a.btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.08);
}

/* Active */
button:active,
a.btn:active {
	transform: scale(0.98);
	box-shadow: none;
}

/* Focus accesible */
button:focus-visible,
a.btn:focus-visible {
	outline: 2px solid #5b9cff;
	outline-offset: 2px;
}

@media (max-width: 768px) {

	button,
	a.btn {
		width: 100%;
		/* botones full width */
		font-size: 1rem;
		padding: 0.75rem 1rem;
	}
}


/* ========================================
   PACIENTES - BUSCAR PROFESIONALES
   ======================================== */
.page-subtitle {
	color: var(--text-secondary);
	margin-top: var(--spacing-xs);
}

.filters-section {
	background: var(--white);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-lg);
	margin-bottom: var(--spacing-xl);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--spacing-lg);
	box-shadow: var(--shadow-sm);
}

.filters-container {
	display: flex;
	gap: var(--spacing-sm);
	flex-wrap: wrap;
	flex: 1;
}

.filter-chip {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	padding: 8px 16px;
	background: var(--bg-secondary);
	border: 2px solid transparent;
	border-radius: 50px;
	font-family: var(--font-family);
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-medium);
	color: var(--text-primary);
	cursor: pointer;
	transition: all var(--transition-normal);
}

.filter-chip:hover {
	background: var(--primary-light);
	color: var(--primary-color);
}

.filter-chip.active {
	background: var(--primary-color);
	color: var(--white);
	border-color: var(--primary-color);
}

.filter-chip .material-icons {
	font-size: 18px;
}

.filter-actions {
	display: flex;
	gap: var(--spacing-sm);
}

.results-info {
	margin-bottom: var(--spacing-lg);
}

.results-info p {
	color: var(--text-secondary);
}

.professionals-grid-search {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(500px, 1fr));
	gap: var(--spacing-lg);
	margin-bottom: var(--spacing-2xl);
}

.professional-card-search {
	background: var(--white);
	border-radius: var(--border-radius-lg);
	border: 1px solid var(--border-color);
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-normal);
	overflow: hidden;
}

.professional-card-search:hover {
	box-shadow: var(--shadow-md);
	transform: translateY(-2px);
}

.professional-card-header {
	padding: var(--spacing-lg);
	display: flex;
	gap: var(--spacing-lg);
}

.professional-image-section {
	position: relative;
	flex-shrink: 0;
}

.professional-avatar-lg {
	width: 80px;
	height: 80px;
	background: var(--primary-light);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	/* z-index: 0; */
}

.professional-avatar-md {
	width: 60px;
	height: 60px;
	background: var(--primary-light);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	/* z-index: 0; */
}

.professional-avatar-lg .material-icons {
	font-size: 40px;
	color: var(--primary-color);
}

.professional-status-online,
.professional-status-offline {
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	font-size: 10px;
	font-weight: var(--font-weight-semibold);
	padding: 2px 8px;
	border-radius: 10px;
	white-space: nowrap;
}

.professional-status-online {
	background: var(--success-color);
	color: var(--white);
}

.professional-status-offline {
	background: var(--text-hint);
	color: var(--white);
}

.favorite-btn {
	position: absolute;
	top: -8px;
	right: -8px;
	width: 32px;
	height: 32px;
	background: var(--white);
	border: 1px solid var(--border-color);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-normal);
}

.favorite-btn:hover {
	background: var(--primary-light);
	color: var(--primary-color);
	border-color: var(--primary-color);
}

.favorite-btn.active {
	background: var(--primary-color);
	color: var(--white);
	border-color: var(--primary-color);
}

.favorite-btn .material-icons {
	font-size: 18px;
}

.professional-info-section {
	flex: 1;
	min-width: 0;
}

.professional-title-row {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	margin-bottom: 4px;
}

.professional-title-row h3 {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-semibold);
}

.verified-badge {
	display: flex;
	align-items: center;
}

.verified-badge .material-icons {
	color: var(--info-color);
	font-size: 20px;
}

.professional-specialty-main {
	color: var(--primary-color);
	font-weight: var(--font-weight-medium);
	margin-bottom: var(--spacing-sm);
}

.professional-rating-row {
	display: flex;
	align-items: center;
	gap: 4px;
	margin-bottom: var(--spacing-sm);
}

.rating-stars {
	display: flex;
	align-items: center;
	gap: var(--spacing-xs);
}

.rating-stars .material-icons {
	color: #FFC107;
	font-size: 18px;
}

.rating-value {
	font-weight: var(--font-weight-semibold);
}

.rating-reviews {
	color: var(--text-secondary);
	font-size: var(--font-size-sm);
}

.experience-badge {
	display: flex;
	align-items: center;
	gap: 4px;
	color: var(--text-secondary);
	font-size: var(--font-size-sm);
}

.experience-badge .material-icons {
	font-size: 16px;
}

.professional-tags-row {
	display: flex;
	gap: var(--spacing-xs);
	flex-wrap: wrap;
}

.tag-badge {
	padding: 4px 10px;
	background: var(--primary-light);
	color: var(--primary-color);
	border-radius: 20px;
	font-size: 11px;
	font-weight: var(--font-weight-medium);
}

.professional-card-body {
	padding: 0 var(--spacing-lg) var(--spacing-lg);
}

.info-row {
	display: flex;
	gap: var(--spacing-lg);
	margin-bottom: var(--spacing-md);
}

.info-item-inline {
	display: flex;
	align-items: center;
	gap: var(--spacing-xs);
	color: var(--text-secondary);
	font-size: var(--font-size-sm);
}

.info-item-inline .material-icons {
	font-size: 16px;
	color: var(--primary-color);
}

.professional-bio {
	color: var(--text-secondary);
	font-size: var(--font-size-sm);
	line-height: 1.5;
}

.professional-card-footer {
	display: flex;
	gap: var(--spacing-sm);
	padding: var(--spacing-lg);
	border-top: 1px solid var(--border-color);
	background: var(--bg-secondary);
}

.pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: var(--spacing-md);
}

.pagination-numbers {
	display: flex;
	gap: var(--spacing-xs);
	align-items: center;
}

.pagination-btn {
	width: 36px;
	height: 36px;
	background: var(--white);
	border: 1px solid var(--border-color);
	border-radius: var(--border-radius-md);
	font-family: var(--font-family);
	font-weight: var(--font-weight-medium);
	color: var(--text-primary);
	cursor: pointer;
	transition: all var(--transition-normal);
}

.pagination-btn:hover {
	background: var(--primary-light);
	color: var(--primary-color);
	border-color: var(--primary-color);
}

.pagination-btn.active {
	background: var(--primary-color);
	color: var(--white);
	border-color: var(--primary-color);
}

@media (max-width : 1024px) {
	.professionals-grid-search {
		grid-template-columns: 1fr;
	}
}

@media (max-width : 768px) {
	.filters-section {
		flex-direction: column;
		align-items: stretch;
	}

	.filter-actions {
		width: 100%;
		justify-content: space-between;
	}

	.professional-card-header {
		flex-direction: column;
		align-items: center;
		text-align: center;
	}

	.professional-rating-row {
		/* flex-direction: column; */
		align-items: center;
		/* gap: var(--spacing-sm); */
	}

	.info-row {
		flex-direction: column;
		gap: var(--spacing-sm);
	}
}

/* ========================================
   PACIENTES - CITAS
   ======================================== */
.page-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: var(--spacing-xl);
}

.page-header h1 {
	font-size: var(--font-size-3xl);
	font-weight: var(--font-weight-bold);
	color: var(--text-primary);
}

.tabs-container {
	background: var(--white);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-md);
	margin-bottom: var(--spacing-xl);
	box-shadow: var(--shadow-sm);
}

.tabs {
	display: flex;
	gap: var(--spacing-sm);
}

.tab {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--spacing-sm);
	padding: var(--spacing-md) var(--spacing-lg);
	background: transparent;
	border: none;
	border-radius: var(--border-radius-md);
	font-family: var(--font-family);
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-medium);
	color: var(--text-secondary);
	cursor: pointer;
	transition: all var(--transition-normal);
}

.tabs a {
	text-decoration: none;
}

.tab:hover {
	background: var(--bg-secondary);
	color: var(--text-primary);
}

.tab.active {
	background: var(--primary-color);
	color: var(--white);
}

.tab-count {
	background: rgba(255, 255, 255, 0.2);
	padding: 2px 8px;
	border-radius: 12px;
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-bold);
}

.tab.active .tab-count {
	background: rgba(255, 255, 255, 0.3);
}

.tab-content {
	display: none;
}

.tab-content.active {
	display: block;
}

.appointments-list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-lg);
}

.appointment-card-full {
	background: var(--white);
	border-radius: var(--border-radius-xl);
	padding: var(--spacing-xl);
	border: 1px solid var(--border-color);
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-normal);
}

.appointment-card-full:hover {
	box-shadow: var(--shadow-md);
}

.appointment-main {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: var(--spacing-2xl);
	margin-bottom: var(--spacing-xl);
}

.appointment-date-section {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-md);
	align-items: center;
}

.appointment-date-large {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	background: var(--primary-light);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-lg);
	border: 2px solid var(--primary-color);
	justify-content: space-between;
}



.appointment-date-large .date-day {
	font-size: 48px;
	font-weight: var(--font-weight-bold);
	color: var(--primary-color);
	line-height: 1;
}

.date-info {
	display: flex;
	flex-direction: column;
}

.date-month {
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-semibold);
	color: var(--text-primary);
}

.date-year {
	font-size: var(--font-size-sm);
	color: var(--text-secondary);
}

.appointment-time {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	background: var(--bg-secondary);
	padding: var(--spacing-sm) var(--spacing-md);
	border-radius: var(--border-radius-md);
	font-weight: var(--font-weight-medium);
	color: var(--text-primary);
}

.appointment-time .material-icons {
	color: var(--primary-color);
	font-size: 20px;
}

.appointment-details {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-lg);
}

.appointment-status-badge {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-sm);
	padding: var(--spacing-sm) var(--spacing-md);
	border-radius: 20px;
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-semibold);
	width: fit-content;
}

.status-confirmed {
	background: rgba(16, 185, 129, 0.15);
	color: var(--success-color);
}

.status-pending {
	background: rgba(245, 158, 11, 0.15);
	color: var(--warning-color);
}

.status-completed {
	background: rgba(59, 130, 246, 0.15);
	color: var(--info-color);
}

.status-cancelled {
	background: rgba(255, 92, 92, 0.15);
	color: var(--error-color);
}

.doctor-card {
	display: flex;
	gap: var(--spacing-md);
	padding: var(--spacing-lg);
	background: var(--bg-secondary);
	border-radius: var(--border-radius-lg);
}

.doctor-avatar-medium {
	width: 48px;
	height: 48px;
	background: var(--primary-light);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}


.doctor-avatar-large {
	width: 64px;
	height: 64px;
	background: var(--primary-light);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.doctor-avatar-large .material-icons {
	color: var(--primary-color);
	font-size: 32px;
}

.doctor-info-full h3 {
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-semibold);
	margin-bottom: 4px;
}

.specialty {
	color: var(--primary-color);
	font-weight: var(--font-weight-medium);
	margin-bottom: var(--spacing-sm);
}

.rating-display {
	display: flex;
	align-items: center;
	gap: var(--spacing-xs);
}

.rating-display .material-icons {
	color: #FFC107;
	font-size: 18px;
}

.rating-display .reviews {
	color: var(--text-secondary);
	font-size: var(--font-size-sm);
}

.appointment-info-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: var(--spacing-md);
}

.info-card {
	display: flex;
	gap: var(--spacing-md);
	padding: var(--spacing-md);
	background: var(--white);
	border: 1px solid var(--border-color);
	border-radius: var(--border-radius-md);
}

.info-card .material-icons {
	color: var(--primary-color);
	font-size: 24px;
}

.info-label {
	font-size: var(--font-size-xs);
	color: var(--text-secondary);
	margin-bottom: 2px;
}

.info-value {
	font-weight: var(--font-weight-medium);
	color: var(--text-primary);
}

.cancellation-reason {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	padding: var(--spacing-md);
	background: rgba(255, 92, 92, 0.1);
	border-radius: var(--border-radius-md);
	color: var(--error-color);
	font-size: var(--font-size-sm);
}

.appointment-actions-full {
	display: flex;
	gap: var(--spacing-md);
	padding-top: var(--spacing-lg);
	border-top: 1px solid var(--border-color);
}

.text-error {
	color: var(--error-color) !important;
}

@media (max-width : 768px) {
	.appointment-main {
		grid-template-columns: 1fr;
	}

	.appointment-date-section {
		flex-direction: row;
		justify-content: space-between;
	}

	.appointment-actions-full {
		flex-direction: column;
	}

	.tabs {
		flex-direction: column;
	}
}

/* ========================================
   PACIENTES - PERFIL
   ======================================== */
.profile-header-section {
	margin-bottom: var(--spacing-xl);
}

.profile-header-card {
	background: var(--primary-gradient);
	color: var(--white);
	border-radius: var(--border-radius-xl);
	padding: var(--spacing-3xl);
	display: flex;
	align-items: center;
	gap: var(--spacing-2xl);
	box-shadow: var(--shadow-xl);
	position: relative;
}

.profile-avatar-container {
	position: relative;
}

.profile-avatar-large {
	width: 120px;
	height: 120px;
	border-radius: 50%;
	overflow: hidden;
	border: 4px solid rgba(255, 255, 255, 0.3);
	box-shadow: var(--shadow-lg);
}

.profile-avatar-large img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.edit-avatar-btn {
	position: absolute;
	bottom: 0;
	right: 0;
	width: 36px;
	height: 36px;
	background: var(--white);
	color: var(--primary-color);
	border: none;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	box-shadow: var(--shadow-md);
	transition: all var(--transition-normal);
}

.edit-avatar-btn:hover {
	transform: scale(1.1);
}

.profile-header-info {
	flex: 1;
}

.profile-header-info h1 {
	font-size: var(--font-size-3xl);
	font-weight: var(--font-weight-bold);
	margin-bottom: var(--spacing-xs);
	color: var(--white);
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.profile-subtitle {
	margin-bottom: var(--spacing-lg);
	color: rgba(255, 255, 255, 0.95);
}

.profile-stats {
	display: flex;
	gap: var(--spacing-2xl);
}

.profile-stats .stat-item {
	display: flex;
	flex-direction: column;
}

.profile-specialty {
	display: flex;
	color: #6FBF73;
	margin: 4px 0;
}

.status-yes {
	color: #3E8E5B;
	font-weight: 600;
}

.profile-stats .stat-number {
	font-size: var(--font-size-2xl);
	font-weight: var(--font-weight-bold);
	line-height: 1;
	color: var(--white);
}

.profile-stats .stat-label {
	font-size: var(--font-size-sm);
	margin-top: var(--spacing-xs);
	color: rgba(255, 255, 255, 0.95);
}

.profile-content-grid {
	display: grid;
	gap: var(--spacing-lg);
}

.profile-section {
	background: var(--white);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-xl);
	border: 1px solid var(--border-color);
	box-shadow: var(--shadow-sm);
}

.section-header-profile {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: var(--spacing-lg);
	padding-bottom: var(--spacing-md);
	border-bottom: 1px solid var(--border-color);
}

.section-header-profile h2 {
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-semibold);
	color: var(--text-primary);
}

.btn-icon-small {
	width: 36px;
	height: 36px;
	background: var(--bg-secondary);
	border: none;
	border-radius: var(--border-radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: all var(--transition-normal);
	color: var(--text-secondary);
}

.btn-icon-profile {
	width: 36px;
	height: 36px;
	border-radius: var(--border-radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: all var(--transition-normal);
	background: var(--primary-color);
	border: none;
}

/* Estado deshabilitado simulado */
.btn-icon-profile.is-disabled {
	opacity: 0.5;
	cursor: not-allowed;
	pointer-events: none;
	/* bloquea clics */
	filter: grayscale(40%);
}

.btn-icon-small:hover {
	background: var(--primary-light);
	color: var(--primary-color);
}

.info-list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-lg);
}

.info-item {
	display: flex;
	gap: var(--spacing-md);
	align-items: flex-start;
}

.info-icon {
	width: 44px;
	height: 44px;
	background: var(--primary-light);
	border-radius: var(--border-radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.info-icon .material-icons {
	color: var(--primary-color);
	font-size: 22px;
}

.info-content {
	flex: 1;
}

.info-label {
	font-size: var(--font-size-sm);
	color: var(--text-secondary);
	margin-bottom: 4px;
}

.info-value {
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-medium);
	color: var(--text-primary);
}

.menu-list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xs);
}

.menu-item {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	padding: var(--spacing-md);
	border-radius: var(--border-radius-md);
	text-decoration: none;
	color: var(--text-primary);
	transition: all var(--transition-normal);
}

.menu-item:hover {
	background: var(--bg-secondary);
}

.menu-icon {
	width: 44px;
	height: 44px;
	background: var(--bg-secondary);
	border-radius: var(--border-radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.menu-icon .material-icons {
	color: var(--primary-color);
	font-size: 22px;
}

.menu-content {
	flex: 1;
}

.menu-title {
	font-weight: var(--font-weight-medium);
	margin-bottom: 2px;
}

.menu-subtitle {
	font-size: var(--font-size-sm);
	color: var(--text-secondary);
}

.menu-item>.material-icons {
	color: var(--text-secondary);
}

@media (max-width : 768px) {
	.profile-header-card {
		flex-direction: column;
		text-align: center;
	}

	.profile-stats {
		justify-content: center;
	}
}

/* ========================================
   PACIENTES - ÍNDICE (listado de vistas)
   ======================================== */
.view-link {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	padding: var(--spacing-md);
	border: 1px solid var(--border-color);
	border-radius: var(--border-radius-md);
	text-decoration: none;
	color: var(--text-primary);
	transition: all var(--transition-normal);
}

.view-link:hover {
	background: var(--primary-light);
	border-color: var(--primary-color);
	transform: translateX(8px);
}

.view-link .material-icons {
	width: 44px;
	height: 44px;
	background: var(--primary-light);
	color: var(--primary-color);
	border-radius: var(--border-radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 24px;
}

.view-link div {
	flex: 1;
}

.view-link strong {
	display: block;
	margin-bottom: 4px;
	color: var(--text-primary);
}

.view-link p {
	font-size: var(--font-size-sm);
	color: var(--text-secondary);
	margin: 0;
}

/* ========================================
   PROFESIONALES - ESTADÍSTICAS Y EXTRAS
   ======================================== */
.stats-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: var(--spacing-lg);
	margin-bottom: 0;
}

.stat-card {
	display: flex;
	align-items: center;
	gap: var(--spacing-lg);
	background: var(--white);
	padding: var(--spacing-xl);
	border-radius: var(--border-radius-lg);
	border: 1px solid var(--border-color);
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-normal);
}

.stat-card:hover {
	box-shadow: var(--shadow-md);
	transform: translateY(-2px);
}

.stat-icon {
	width: 64px;
	height: 64px;
	border-radius: var(--border-radius-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.stat-icon .material-icons {
	color: var(--white);
	font-size: 32px;
}

.stat-content {
	flex: 1;
}

.stat-content h3 {
	font-size: var(--font-size-3xl);
	font-weight: var(--font-weight-bold);
	color: var(--text-primary);
	line-height: 1;
	margin-bottom: 4px;
}

.stat-content p {
	font-size: var(--font-size-sm);
	color: var(--text-secondary);
	margin: 0;
}

.messages-preview-list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-sm);
}

.message-preview-item {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	padding: var(--spacing-md);
	background: var(--white);
	border: 1px solid var(--border-color);
	border-radius: var(--border-radius-lg);
	cursor: pointer;
	transition: all var(--transition-normal);
}

.message-preview-item:hover {
	background: var(--bg-secondary);
	border-color: var(--primary-color);
}

.message-preview-content {
	flex: 1;
	min-width: 0;
}

.message-preview-header {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin-bottom: 4px;
}

.message-preview-header h4 {
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-semibold);
	margin: 0;
}

.message-time {
	font-size: var(--font-size-xs);
	color: var(--text-secondary);
}

.message-preview-text {
	font-size: var(--font-size-sm);
	color: var(--text-secondary);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	margin: 0;
}

.quick-actions-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	gap: var(--spacing-md);
}

.action-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--spacing-sm);
	padding: var(--spacing-xl);
	background: var(--white);
	border: 2px solid var(--border-color);
	border-radius: var(--border-radius-lg);
	font-family: var(--font-family);
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-medium);
	color: var(--text-primary);
	cursor: pointer;
	transition: all var(--transition-normal);
}

.action-card:hover {
	background: var(--primary-light);
	border-color: var(--primary-color);
	color: var(--primary-color);
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

.action-card .material-icons {
	font-size: 32px;
}

@media (max-width : 768px) {
	.stats-grid {
		grid-template-columns: 1fr;
	}

	.quick-actions-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* ========================================
   ALERT MESSAGES FOR SPRING SECURITY
   ======================================== */
.alert {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	padding: var(--spacing-lg);
	border-radius: var(--border-radius-lg);
	margin-bottom: var(--spacing-lg);
	font-size: var(--font-size-base);
	font-weight: var(--font-weight-medium);
}

.alert .material-icons {
	font-size: 20px;
	vertical-align: middle;
}

.alert-danger {
	background-color: #FEE2E2;
	border: 1px solid #FCA5A5;
	color: #991B1B;
}

.alert-success {
	background-color: #D1FAE5;
	border: 1px solid #6EE7B7;
	color: #065F46;
}

.alert-info {
	background-color: #DBEAFE;
	border: 1px solid #93C5FD;
	color: #1E40AF;
}

.alert-warning {
	background-color: #FEF3C7;
	border: 1px solid #FCD34D;
	color: #92400E;
}

.profile-progress-section {
	margin-top: 20px;
}

.progress-counter {
	font-size: 1.1rem;
	font-weight: bold;
	color: #444;
}


.progress-cards-grid {
	display: flex;
	flex-direction: column;
	gap: 12px;
	margin-top: 15px;
}

.progress-card {
	display: flex;
	align-items: center;
	gap: 15px;
	background: #fff;
	padding: 15px;
	border-radius: 14px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
	cursor: pointer;
	transition: 0.2s ease;
}

.progress-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);
}

/* Ícono grande */
.progress-icon {
	font-size: 42px;
	/* 👈 GRANDE */
	color: #007bff;
	/* azul vistoso, cambiable */
}

/* Contenido a la derecha del ícono */
.progress-content {
	display: flex;
	flex-direction: column;
}

/* Título */
.progress-title {
	font-size: 16px;
	font-weight: 600;
}

/* Texto descriptivo */
.progress-desc {
	font-size: 13px;
	color: #555;
}

.progress-icon {
	font-size: 32px;
	margin-right: 12px;
	color: #4CAF50;
}

.progress-title {
	font-size: 1rem;
	font-weight: 600;
}

.progress-title-completed {
	color: #4CAF50;
}

.progress-title-incompleted {
	color: red;
}

/* Compact header: reduce extra vertical space on mobile for the search area */
@media (max-width : 768px) {
	.dashboard-header-content .search-bar-container {
		/* keep it full width but reduce the top gap when it wraps */
		order: 3;
		/* ensure it stays below header row */
		flex: 1 1 100%;
		margin-top: var(--spacing-xs);
		/* was var(--spacing-md) */
	}

	.dashboard-header-content .search-bar {
		/* tighten vertical padding for compact mobile header */
		padding: 0.5rem 0.75rem;
		/* ~8px 12px */
	}

	.dashboard-header-content {
		align-items: center;
	}
}

/* ========================================
   DASHBOARD: Compact spacing overrides
   These rules reduce vertical rhythm only inside dashboard views
   without touching global section spacing used elsewhere.
   ======================================== */
.dashboard-main {
	/* reduce top offset so content sits closer under the nav */
	padding-top: 8rem;
	/* ~128px (was 9.75rem / 156px) */
}

.dashboard-main section {
	/* make sections tighter for dashboard pages */
	padding: var(--spacing-md) 0;
	/* 16px top/bottom instead of 64px */
}

.dashboard-main .welcome-card {
	/* slightly smaller welcome card padding for compactness */
	padding: var(--spacing-lg);
	/* 24px */
}

.dashboard-main .stats-grid {
	gap: var(--spacing-md);
	/* reduce gap between stat cards */
}

@media (max-width : 768px) {
	.dashboard-main {
		padding-top: 7rem;
		/* reduce a bit more on small screens */
	}

	.dashboard-main section {
		padding: var(--spacing-sm) 0;
		/* tighter on mobile */
	}

	.dashboard-main .welcome-card {
		padding: var(--spacing-md);
	}
}

/* Agenda / Dashboard page header spacing (moved from inline styles) */
.dashboard-main .page-header {
	margin: 0rem 2.0rem;
	/* left/right spacing previously inline */
	padding: 1.0rem 0rem;
	/* vertical padding previously inline */
}

/* MODAL LOGOUT BTN */


.modal-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.45);
	display: none;
	justify-content: center;
	align-items: center;
	z-index: 2000;
}

.modal-box {
	background: #fff;
	padding: 22px;
	border-radius: 12px;
	max-width: 500px;
	text-align: center;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.25);
}

.modal-box h3 {
	margin-bottom: 10px;
	font-size: 18px;
}

.modal-box p {
	font-size: 14px;
	color: #555;
	margin-bottom: 18px;
}

.modal-actions {
	display: flex;
	gap: 12px;
	justify-content: center;
}


/* LOGOUT BTN */

.logout-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 10px auto;
	padding: 8px 14px;

	font-size: 14px;
	font-weight: 500;
	color: #d32f2f;

	border: 1px solid #d32f2f;
	border-radius: 8px;
	background: transparent;

	max-width: 80%;
	gap: 6px;
	cursor: pointer;

	transition: 0.2s ease-in-out;
}

.logout-btn:hover {
	background: #ffe5e5;
}

.logout-btn .material-icons {
	font-size: 18px;
}

/* Mobile: ensure header elements keep a predictable order: logo, actions, search */
@media (max-width : 768px) {
	.dashboard-header-content {
		align-items: center;
		gap: var(--spacing-sm);
	}

	.dashboard-header-content .logo {
		order: 1;
		flex: 0 0 auto;
	}

	.dashboard-header-content .header-actions {
		order: 2;
		margin-left: auto;
		/* push icons to the right of the available space */
		display: flex;
		gap: var(--spacing-sm);
		align-items: center;
		flex: 0 0 auto;
	}

	.dashboard-header-content .search-bar-container {
		order: 3;
		flex: 1 1 100%;
		margin-top: var(--spacing-xs);
		width: 100%;
	}

	.header-actions .icon-btn {
		flex-shrink: 0;
		/* prevent icons from collapsing */
	}

	/* Margins */
	.m-0 {
		margin: 0 !important;
	}

	.m-1 {
		margin: 0.25rem !important;
	}

	.m-2 {
		margin: 0.5rem !important;
	}

	.m-3 {
		margin: 1rem !important;
	}

	.m-4 {
		margin: 1.5rem !important;
	}

	.m-5 {
		margin: 3rem !important;
	}

	/* Padding */
	.p-0 {
		padding: 0 !important;
	}

	.p-1 {
		padding: 0.25rem !important;
	}

	.p-2 {
		padding: 0.5rem !important;
	}

	.p-3 {
		padding: 1rem !important;
	}

	.p-4 {
		padding: 1.5rem !important;
	}

	.p-5 {
		padding: 3rem !important;
	}

	.services {
		background: var(--bg-secondary);
	}

}



/* PROFESIONALES FAVORITOS */
.favorite-btn {
	position: absolute;
	top: -15px;
	right: -10px;
	background: rgba(255, 255, 255, 0.9);
	border: none;
	border-radius: 50%;
	width: 36px;
	height: 36px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
}

.favorite-btn .material-icons {
	color: #9ca3af;
	font-size: 22px;
	transition: color 0.2s ease, transform 0.2s ease;
}

.favorite-btn.active .material-icons {
	color: #ef4444;
	transform: scale(1.1);
}


/* ESTRELLAS */
.given-rating {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-top: 6px;
	font-size: 14px;
	color: #374151;
}

.given-rating .star {
	font-size: 25px;
}

.rating-label {
	margin-left: 6px;
	font-weight: 500;
}

/* Boton puntuar */
.rate-btn-inline {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: linear-gradient(135deg, #facc15, #f59e0b);
	color: #78350f;
	font-weight: 600;
	padding: 10px 16px;
	border-radius: 12px;
	text-decoration: none;
	box-shadow: 0 6px 14px rgba(245, 158, 11, 0.25);
	transition: all 0.25s ease;
}

.rate-btn-inline:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 22px rgba(245, 158, 11, 0.35);
	background: linear-gradient(135deg, #fde047, #f59e0b);
}

/* Paginacion y paginacion btn */
.pagination {
	display: flex;
	justify-content: center;
	gap: 6px;
	margin-top: 24px;
}

.pagination-btn {
	padding: 8px 12px;
	border-radius: 8px;
	border: 1px solid var(--border-color);
	background: white;
	color: var(--text-primary);
	text-decoration: none;
	font-weight: 500;
	transition: all .2s;
}

.pagination-btn:hover {
	background: var(--bg-secondary);
}

.pagination-btn.active {
	background: var(--primary-color);
	color: white;
	border-color: var(--primary-color);
}

/* VERIFIED ICON */
.verified-icon {
	font-size: 20px;
	color: var(--success-color);
	/* verde del sistema */
}

.status-rejected {
	background: #FEE2E2;
	color: #B91C1C;
	/* border: 1px solid #FCA5A5; */
}

.status-rejected .material-icons {
	color: #DC2626;
}

.status-expired {
	background: #F3F4F6;
	color: #6B7280;
	border: 1px solid #D1D5DB;
}

.status-expired .material-icons {
	color: #9CA3AF;
}

/* =========================
   MODALES PARA PROFESIONALES
========================= */

.custom-alert {
	position: fixed;
	top: 30px;
	right: 30px;
	padding: 16px 24px;
	border-radius: 12px;
	color: white;
	font-weight: 600;
	opacity: 0;
	transform: translateY(-20px);
	transition: all .3s ease;
	z-index: 9999;
}

.custom-alert.success {
	background: #00b86b;
}

.custom-alert.error {
	background: #e53935;
}

.custom-alert.show {
	opacity: 1;
	transform: translateY(0);
}


/* =========================
   MODAL BASE (GENÉRICO)
========================= */

.modal-overlay .modal {
	background: #ffffff;
	width: 100%;
	max-width: 820px;
	border-radius: 20px;
	padding: 2rem;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.18);
	animation: scaleIn 0.25s ease;
	max-height: 90vh;
	overflow-y: auto;
}

.modal-overlay h3 {
	font-size: 1.6rem;
	font-weight: 600;
	margin-bottom: 1.8rem;
	color: #1e293b;
}

.modal-overlay .modal-section {
	margin-bottom: 2rem;
	padding: 1.2rem 1.4rem;
	background: #f8fafc;
	border-radius: 14px;
	border: 1px solid #e2e8f0;
}

.modal-overlay .modal-section h4 {
	font-size: 1rem;
	margin-bottom: 1rem;
	color: #16a34a;
	font-weight: 600;
}

.modal-overlay .switch-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.65rem 0;
	font-size: 0.95rem;
	color: #334155;
}

.modal-overlay .switch {
	position: relative;
	width: 46px;
	height: 24px;
	display: inline-block;
}

.modal-overlay .switch input {
	display: none;
}

.modal-overlay .slider {
	position: absolute;
	inset: 0;
	background: #cbd5e1;
	border-radius: 30px;
	transition: 0.3s;
}

.modal-overlay .circle {
	position: absolute;
	height: 18px;
	width: 18px;
	left: 3px;
	top: 3px;
	background: white;
	border-radius: 50%;
	transition: 0.3s;
}

.modal-overlay .switch input:checked+.slider {
	background: linear-gradient(135deg, #22c55e, #16a34a);
}

.modal-overlay .switch input:checked+.slider .circle {
	transform: translateX(22px);
}

.modal-overlay select,
.modal-overlay input[type="number"],
.modal-overlay input[type="date"] {
	width: 100%;
	padding: 0.6rem 0.75rem;
	border-radius: 10px;
	border: 1px solid #cbd5e1;
	background: #ffffff;
	font-size: 0.9rem;
	margin-top: 0.4rem;
	margin-bottom: 0.9rem;
	transition: all 0.2s ease;
}

.modal-overlay select:focus,
.modal-overlay input:focus {
	outline: none;
	border-color: #22c55e;
	box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
}

.modal-overlay .modal-actions {
	display: flex;
	justify-content: flex-end;
	gap: 1rem;
	margin-top: 1.5rem;
}

.modal-overlay .btn {
	border: none;
	padding: 0.7rem 1.4rem;
	border-radius: 12px;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s ease;
}

.modal-overlay .btn-primary {
	background: linear-gradient(135deg, #22c55e, #16a34a);
	color: white;
}

.modal-overlay .btn-primary:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(34, 197, 94, 0.4);
}

.modal-overlay .btn-cancel {
	background: #ef4444;
	color: white;
}

.modal-overlay .btn-cancel:hover {
	background: #dc2626;
}


/* =========================
   RESPONSIVE
========================= */

@media (max-width: 768px) {

	.modal-overlay .modal {
		padding: 1.2rem;
		border-radius: 16px;
		max-height: 95vh;
	}

	.modal-overlay h3 {
		font-size: 1.2rem;
	}

	.modal-overlay .modal-actions {
		flex-direction: column;
	}

	.modal-overlay .btn {
		width: 100%;
	}
}


/* =========================
   ANIMACIONES
========================= */

@keyframes fadeIn {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

@keyframes scaleIn {
	from {
		transform: scale(0.95);
		opacity: 0;
	}

	to {
		transform: scale(1);
		opacity: 1;
	}
}

/* =========================
   OBSERVACIONES MODAL
========================= */

.custom-modal {
	position: fixed;
	inset: 0;
	display: none;
	/* Cambiamos a none por defecto */
	width: 100vw;
	/* 100% del ancho del viewport */
	height: 100vh;
	/* 100% del alto del viewport */
	justify-content: center;
	align-items: center;
	/* z-index: 9999; */
	z-index: 1000000;
	pointer-events: none;
	/* No bloquea la pantalla si no está visible */
}

.custom-modal.show {
	display: flex !important;
	/* Forzamos el display */
	pointer-events: all;
	/* Permite interacción */
}

.modal-section.observations-section {
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 14px;
	padding: 1.2rem 1.4rem;
	margin-top: 1rem;
}

/* Contenedor interno */
.observations-section .form-row {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

/* Label */
.observations-section label {
	font-size: 0.9rem;
	font-weight: 600;
	color: #334155;
}

/* Textarea */
.observations-textarea {
	width: 100%;
	padding: 0.9rem 1rem;
	border-radius: 14px;
	border: 1px solid #cbd5e1;
	font-size: 0.9rem;
	line-height: 1.5;
	resize: vertical;
	min-height: 110px;
	transition: all 0.2s ease;
	background: #ffffff;
	box-sizing: border-box;
}

/* Focus elegante */
.observations-textarea:focus {
	outline: none;
	border-color: #22c55e;
	box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.12);
}

/* Contador */
.char-counter {
	font-size: 0.75rem;
	color: #64748b;
	text-align: right;
	margin-top: 4px;
}

/* =========================
   MOBILE FIX
========================= */

@media (max-width: 768px) {

	.modal-section.observations-section {
		padding: 1rem;
		border-radius: 12px;
	}

	.observations-section label {
		font-size: 0.85rem;
	}

	.observations-textarea {
		font-size: 0.85rem;
		padding: 0.8rem;
		min-height: 95px;
		border-radius: 12px;
	}

	.char-counter {
		font-size: 0.7rem;
	}
}

/* MODAL PARA PAGO */
/* ===== MODAL PREMIUM DASHBOARD ===== */

#paymentModal.custom-modal {
	position: fixed !important;
	inset: 0 !important;
	display: none;
	justify-content: center;
	align-items: center;
	z-index: 99999 !important;
}

#paymentModal.custom-modal.show {
	display: flex !important;
	background: rgba(15, 23, 42, 0.55);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}

#paymentModal .modal-overlay {
	position: absolute;
	inset: 0;
	background: transparent;
	/* importante */
}

#paymentModal .modal-content {
	position: relative;
	background: linear-gradient(145deg, #1e293b, #0f172a);
	padding: 32px;
	border-radius: 20px;
	width: 92%;
	max-width: 440px;
	z-index: 10;
	box-shadow: 0 25px 60px rgba(0, 0, 0, 0.6);
	animation: modalFadeIn 0.25s ease-out;
}

@keyframes modalFadeIn {
	from {
		transform: translateY(20px);
		opacity: 0;
	}

	to {
		transform: translateY(0);
		opacity: 1;
	}
}

.modal-content h3 {
	margin-bottom: 18px;
	font-size: 22px;
	font-weight: 600;
	color: #38bdf8;
}

.modal-actions {
	display: flex;
	justify-content: space-between;
	gap: 14px;
	margin-top: 20px;
}

.btn-modal-primary {
	flex: 1;
	padding: 10px 16px;
	border-radius: 12px;
	border: none;
	background: linear-gradient(135deg, #22c55e, #16a34a);
	color: white;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s ease;
}

.btn-modal-primary:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 18px rgba(34, 197, 94, 0.4);
}

.btn-modal-secondary {
	flex: 1;
	padding: 10px 16px;
	border-radius: 12px;
	border: 1px solid #334155;
	background: transparent;
	color: #e2e8f0;
	cursor: pointer;
	transition: all 0.2s ease;
}

.btn-modal-secondary:hover {
	background: #1e293b;
}

/* Borde superior rojo en modal de rechazar y cancelar */
.danger-modal {
	border-top: 4px solid #ef4444;
}