/* ==========================================================================
   Cusco Creativos - Hoja de Estilos Principal
   Autor: Paul Pumalloclla
   Versión: 1.0.0
   ========================================================================== */

/* ==========================================================================
   1. CUSTOM PROPERTIES (Variables CSS)
   ========================================================================== */
:root {
	/* Colores de marca */
	--cc-color-primary: #E91E63;
	--cc-color-primary-light: #F48FB1;
	--cc-color-primary-dark: #C2185B;
	--cc-color-secondary: #FF9800;
	--cc-color-secondary-light: #FFB74D;
	--cc-color-accent: #9C27B0;
	--cc-color-accent-light: #CE93D8;
	--cc-color-yellow: #FFC107;

	/* Colores neutros */
	--cc-color-dark: #1a1a2e;
	--cc-color-dark-soft: #2d2d44;
	--cc-color-gray-900: #212121;
	--cc-color-gray-800: #424242;
	--cc-color-gray-700: #616161;
	--cc-color-gray-600: #757575;
	--cc-color-gray-500: #9e9e9e;
	--cc-color-gray-400: #bdbdbd;
	--cc-color-gray-300: #e0e0e0;
	--cc-color-gray-200: #eeeeee;
	--cc-color-gray-100: #f5f5f5;
	--cc-color-gray-50: #fafafa;
	--cc-color-white: #ffffff;

	/* Gradientes */
	--cc-gradient-primary: linear-gradient(135deg, var(--cc-color-primary) 0%, var(--cc-color-secondary) 100%);
	--cc-gradient-accent: linear-gradient(135deg, var(--cc-color-primary) 0%, var(--cc-color-accent) 100%);
	--cc-gradient-dark: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
	--cc-gradient-warm: linear-gradient(135deg, var(--cc-color-secondary) 0%, var(--cc-color-yellow) 100%);

	/* Tipografía */
	--cc-font-heading: 'Poppins', -apple-system, BlinkMacSystemFont, sans-serif;
	--cc-font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
	--cc-font-size-xs: 0.75rem;
	--cc-font-size-sm: 0.875rem;
	--cc-font-size-base: 1rem;
	--cc-font-size-md: 1.125rem;
	--cc-font-size-lg: 1.25rem;
	--cc-font-size-xl: 1.5rem;
	--cc-font-size-2xl: 2rem;
	--cc-font-size-3xl: 2.5rem;
	--cc-font-size-4xl: 3rem;
	--cc-font-size-5xl: 3.5rem;

	/* Espaciado */
	--cc-spacing-xs: 0.25rem;
	--cc-spacing-sm: 0.5rem;
	--cc-spacing-md: 1rem;
	--cc-spacing-lg: 1.5rem;
	--cc-spacing-xl: 2rem;
	--cc-spacing-2xl: 3rem;
	--cc-spacing-3xl: 4rem;
	--cc-spacing-4xl: 6rem;
	--cc-spacing-5xl: 8rem;

	/* Bordes */
	--cc-radius-sm: 0.375rem;
	--cc-radius-md: 0.625rem;
	--cc-radius-lg: 1rem;
	--cc-radius-xl: 1.5rem;
	--cc-radius-full: 9999px;

	/* Sombras */
	--cc-shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.06);
	--cc-shadow-md: 0 4px 6px rgba(0, 0, 0, 0.07), 0 2px 4px rgba(0, 0, 0, 0.06);
	--cc-shadow-lg: 0 10px 25px rgba(0, 0, 0, 0.1), 0 6px 10px rgba(0, 0, 0, 0.08);
	--cc-shadow-xl: 0 20px 40px rgba(0, 0, 0, 0.12), 0 8px 16px rgba(0, 0, 0, 0.08);
	--cc-shadow-glow: 0 0 40px rgba(233, 30, 99, 0.3);

	/* Transiciones */
	--cc-transition-fast: 150ms ease;
	--cc-transition-base: 300ms ease;
	--cc-transition-slow: 500ms ease;
	--cc-transition-bounce: 500ms cubic-bezier(0.68, -0.55, 0.265, 1.55);

	/* Layout */
	--cc-container-max: 1200px;
	--cc-container-narrow: 800px;
	--cc-container-wide: 1400px;
	--cc-header-height: 80px;
}

/* ==========================================================================
   2. RESET Y BASE
   ========================================================================== */
*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
	font-size: 16px;
}

body {
	font-family: var(--cc-font-body);
	font-size: var(--cc-font-size-base);
	font-weight: 400;
	line-height: 1.7;
	color: var(--cc-color-gray-800);
	background-color: var(--cc-color-white);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--cc-font-heading);
	font-weight: 700;
	line-height: 1.3;
	color: var(--cc-color-dark);
	margin-bottom: var(--cc-spacing-md);
}

h1 { font-size: var(--cc-font-size-4xl); }
h2 { font-size: var(--cc-font-size-3xl); }
h3 { font-size: var(--cc-font-size-2xl); }
h4 { font-size: var(--cc-font-size-xl); }
h5 { font-size: var(--cc-font-size-lg); }
h6 { font-size: var(--cc-font-size-md); }

/* Título de sección global — escala profesional adaptativa por dispositivo */
.section__title {
	font-size: clamp(1.25rem, 2vw, 2rem); /* Móvil 20px → Desktop 2vw (~29px en 1440px) → Tope 32px */
	line-height: 1.25;
	font-weight: 800;
	letter-spacing: -0.02em;
}

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

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

a:hover,
a:focus {
	color: var(--cc-color-primary-dark);
}

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

ul, ol {
	list-style: none;
}

/* Accesibilidad */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: var(--cc-color-white);
	border-radius: var(--cc-radius-sm);
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	clip-path: none;
	color: var(--cc-color-dark);
	display: block;
	font-size: var(--cc-font-size-sm);
	font-weight: 700;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

.skip-link {
	position: fixed;
	top: -100px;
	left: 0;
	z-index: 99999;
	padding: var(--cc-spacing-sm) var(--cc-spacing-md);
	background: var(--cc-color-primary);
	color: var(--cc-color-white);
	transition: top var(--cc-transition-fast);
}

.skip-link:focus {
	top: 0;
	color: var(--cc-color-white);
}

/* ==========================================================================
   3. LAYOUT
   ========================================================================== */
.container {
	width: 100%;
	max-width: var(--cc-container-max);
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--cc-spacing-xl);
	padding-right: var(--cc-spacing-xl);
}

.container--narrow {
	max-width: var(--cc-container-narrow);
}

.container--wide {
	max-width: var(--cc-container-wide);
}

.site {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

.site-main {
	flex: 1;
}

/* ==========================================================================
   4. HEADER
   ========================================================================== */
.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	background: rgba(255, 255, 255, 0.95);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	border-bottom: 1px solid rgba(0, 0, 0, 0.05);
	transition: all var(--cc-transition-base);
	height: var(--cc-header-height);
}

.site-header--scrolled {
	box-shadow: var(--cc-shadow-md);
}

.site-header__container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 100%;
	gap: var(--cc-spacing-2xl);
}

/* WA Default State (Oculto en Escritorio) */
.site-header__whatsapp {
	display: none;
}

.site-header__brand {
	flex-shrink: 0;
}

.site-logo__image {
	height: 50px;
	width: auto;
}

.site-logo__link {
	display: flex;
	align-items: center;
}

/* Botón WhatsApp Integrado Header */
.site-header__whatsapp {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0 var(--cc-spacing-md);
}

.btn-wa-header {
	display: flex;
	align-items: center;
	gap: var(--cc-spacing-sm);
	padding: 10px 24px;
	background: linear-gradient(135deg, var(--cc-color-primary) 0%, var(--cc-color-secondary) 100%);
	color: var(--cc-color-white) !important;
	border-radius: var(--cc-radius-full);
	font-weight: 600;
	font-size: var(--cc-font-size-sm);
	text-decoration: none;
	transition: all var(--cc-transition-base);
	box-shadow: 0 4px 12px rgba(233, 30, 99, 0.2);
}

.btn-wa-header:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 18px rgba(233, 30, 99, 0.35);
}

.btn-wa-header svg {
	flex-shrink: 0;
}

/* Navegación */
.main-navigation {
	flex: 1;
	display: flex;
	justify-content: center;
}

.nav__wrapper {
	display: flex;
}

.nav__list {
	display: flex;
	align-items: center;
	gap: var(--cc-spacing-xs);
}

.nav__link {
	display: inline-flex;
	align-items: center;
	padding: var(--cc-spacing-sm) var(--cc-spacing-md);
	font-family: var(--cc-font-heading);
	font-size: var(--cc-font-size-sm);
	font-weight: 500;
	color: var(--cc-color-gray-700);
	border-radius: var(--cc-radius-md);
	transition: all var(--cc-transition-fast);
	position: relative;
}

.nav__link::after {
	content: '';
	position: absolute;
	bottom: 2px;
	left: 50%;
	transform: translateX(-50%) scaleX(0);
	width: 20px;
	height: 2px;
	background: var(--cc-gradient-primary);
	border-radius: var(--cc-radius-full);
	transition: transform var(--cc-transition-base);
}

.nav__link:hover,
.nav__link--active {
	color: var(--cc-color-primary);
}

.nav__link:hover::after,
.nav__link--active::after {
	transform: translateX(-50%) scaleX(1);
}

/* Submenú estándar (no mega) */
.nav__item--has-children {
	position: relative;
}

.nav__submenu {
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 220px;
	background: var(--cc-color-white);
	border-radius: var(--cc-radius-lg);
	box-shadow: var(--cc-shadow-xl);
	padding: var(--cc-spacing-sm) 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(10px);
	transition: all var(--cc-transition-base);
	z-index: 100;
}

.nav__item--has-children:hover > .nav__submenu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.nav__submenu .nav__link {
	display: block;
	padding: var(--cc-spacing-sm) var(--cc-spacing-lg);
	border-radius: 0;
	font-size: var(--cc-font-size-sm);
}

.nav__submenu .nav__link::after {
	display: none;
}

.nav__submenu .nav__link:hover {
	background: var(--cc-color-gray-50);
}

/* Nav Link Arrow Indicator */
.nav__arrow {
	transition: transform var(--cc-transition-base);
	margin-left: 2px;
	flex-shrink: 0;
}

.nav__item--mega:hover .nav__arrow,
.nav__item--mega.is-open .nav__arrow {
	transform: rotate(180deg);
}

/* Nav link active state for mega menu parent */
.nav__item--mega:hover > .nav__link,
.nav__item--mega.is-open > .nav__link {
	color: var(--cc-color-primary);
	background: rgba(233, 30, 99, 0.06);
	border-radius: var(--cc-radius-full);
}

/* ==========================================================================
   MEGA MENU
   ========================================================================== */

/* Overlay */
.mega-menu-overlay {
	position: fixed;
	inset: 0;
	top: var(--cc-header-height);
	background: rgba(26, 26, 46, 0.4);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	z-index: 98;
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--cc-transition-base), visibility var(--cc-transition-base);
}

.mega-menu-overlay.is-visible {
	opacity: 1;
	visibility: visible;
}

/* Panel principal */
.mega-menu {
	position: fixed;
	top: var(--cc-header-height);
	left: 0;
	right: 0;
	background: var(--cc-color-white);
	border-top: 1px solid var(--cc-color-gray-200);
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.12), 0 8px 20px rgba(0, 0, 0, 0.06);
	z-index: 99;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-8px);
	transition: opacity var(--cc-transition-base),
				visibility var(--cc-transition-base),
				transform var(--cc-transition-base);
	max-height: calc(100vh - var(--cc-header-height) - 40px);
	overflow-y: auto;
}

.nav__item--mega:hover > .mega-menu,
.nav__item--mega.is-open > .mega-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

/* Contenedor interno */
.mega-menu__container {
	max-width: var(--cc-container-max);
	margin: 0 auto;
	padding: var(--cc-spacing-2xl) var(--cc-spacing-xl);
}

/* Grid principal del mega menú */
.mega-menu__grid {
	display: flex;
	flex-direction: column;
	gap: var(--cc-spacing-lg);
}

/* Sección */
.mega-menu__section {
	border-bottom: 1px solid var(--cc-color-gray-200);
	padding-bottom: var(--cc-spacing-lg);
}

.mega-menu__section:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

/* Título de la sección */
.mega-menu__section-title {
	font-family: var(--cc-font-heading);
	font-size: var(--cc-font-size-sm);
	font-weight: 700;
	color: var(--cc-color-gray-600);
	text-transform: uppercase;
	letter-spacing: 1.5px;
	margin-bottom: var(--cc-spacing-md);
	padding-left: var(--cc-spacing-xs);
}

/* Grid de items dentro de una sección */
.mega-menu__section-items {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--cc-spacing-md);
}

/* --- Item del Mega Menú --- */
.mega-menu__item {
	display: flex;
	align-items: flex-start;
	gap: var(--cc-spacing-md);
	padding: var(--cc-spacing-md);
	border-radius: var(--cc-radius-lg);
	text-decoration: none;
	transition: all var(--cc-transition-fast);
	color: inherit;
	background: var(--cc-color-gray-50);
	border: 1px solid transparent;
}

.mega-menu__item:hover {
	background: var(--cc-color-white);
	border-color: rgba(233, 30, 99, 0.3);
	box-shadow: 0 6px 15px rgba(233, 30, 99, 0.06);
	color: inherit;
	transform: translateY(-2px);
}

/* Item con descripción (style grande como en la imagen) */
.mega-menu__item--with-desc {
	align-items: flex-start;
}

/* Item compacto (sin descripción, como "Industries" en la imagen) */
.mega-menu__item--compact {
	align-items: center;
	padding: var(--cc-spacing-sm) var(--cc-spacing-lg);
}

/* Icono del item */
.mega-menu__item-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	border-radius: var(--cc-radius-md);
	background: linear-gradient(135deg, rgba(233, 30, 99, 0.08) 0%, rgba(156, 39, 176, 0.08) 100%);
	color: var(--cc-color-primary);
	transition: all var(--cc-transition-fast);
}

.mega-menu__item:hover .mega-menu__item-icon {
	background: linear-gradient(135deg, rgba(233, 30, 99, 0.14) 0%, rgba(156, 39, 176, 0.14) 100%);
	color: var(--cc-color-primary-dark);
	transform: scale(1.05);
}

.mega-menu__item--compact .mega-menu__item-icon {
	width: 36px;
	height: 36px;
}

.mega-menu__item--compact .mega-menu__item-icon svg {
	width: 18px;
	height: 18px;
}

/* Contenido del item */
.mega-menu__item-content {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.mega-menu__item-title {
	font-family: var(--cc-font-heading);
	font-size: var(--cc-font-size-sm);
	font-weight: 600;
	color: var(--cc-color-dark);
	line-height: 1.4;
	transition: color var(--cc-transition-fast);
}

.mega-menu__item:hover .mega-menu__item-title {
	color: var(--cc-color-primary);
}

.mega-menu__item-desc {
	font-size: var(--cc-font-size-xs);
	color: var(--cc-color-gray-600);
	line-height: 1.5;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Compact item title size */
.mega-menu__item--compact .mega-menu__item-title {
	font-size: var(--cc-font-size-sm);
	font-weight: 500;
}

/* Hamburger Menu */
.menu-toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
	width: 44px;
	height: 44px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 8px;
	z-index: 1001;
}

.menu-toggle__bar {
	display: block;
	width: 24px;
	height: 2px;
	background: var(--cc-color-dark);
	border-radius: var(--cc-radius-full);
	transition: all var(--cc-transition-base);
}

.menu-toggle[aria-expanded="true"] .menu-toggle__bar:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

.menu-toggle[aria-expanded="true"] .menu-toggle__bar:nth-child(2) {
	opacity: 0;
}

.menu-toggle[aria-expanded="true"] .menu-toggle__bar:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

/* Header CTA */
.site-header__cta {
	flex-shrink: 0;
}

/* Body offset para header fijo */
body {
	padding-top: var(--cc-header-height);
}

/* ==========================================================================
   5. BOTONES
   ========================================================================== */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--cc-spacing-sm);
	font-family: var(--cc-font-heading);
	font-weight: 600;
	text-align: center;
	white-space: nowrap;
	cursor: pointer;
	border: 2px solid transparent;
	border-radius: var(--cc-radius-full);
	transition: all var(--cc-transition-base);
	text-decoration: none;
	line-height: 1;
}

.btn--sm {
	padding: 0.5rem 1.25rem;
	font-size: var(--cc-font-size-sm);
}

.btn--md {
	padding: 0.75rem 1.75rem;
	font-size: var(--cc-font-size-base);
}

.btn--lg {
	padding: 1rem 2.25rem;
	font-size: var(--cc-font-size-md);
}

.btn--primary {
	background: var(--cc-gradient-primary);
	color: var(--cc-color-white);
	border-color: transparent;
	box-shadow: 0 4px 15px rgba(233, 30, 99, 0.3);
}

.btn--primary:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(233, 30, 99, 0.4);
	color: var(--cc-color-white);
}

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

.btn--outline:hover {
	background: var(--cc-color-primary);
	color: var(--cc-color-white);
	transform: translateY(-2px);
}

.btn--white {
	background: var(--cc-color-white);
	color: var(--cc-color-primary);
	border-color: var(--cc-color-white);
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.btn--white:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
	color: var(--cc-color-primary-dark);
}

/* ==========================================================================
   6. HERO SECTION
   ========================================================================== */
.hero {
	position: relative;
	min-height: 90vh;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	background: var(--cc-gradient-dark);
	margin-top: calc(-1 * var(--cc-header-height));
	padding-top: var(--cc-header-height);
}

.hero__background {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.hero__background::before {
	content: '';
	position: absolute;
	width: 500px;
	height: 500px;
	background: radial-gradient(circle, rgba(233, 30, 99, 0.3) 0%, transparent 70%);
	top: -100px;
	right: -100px;
	border-radius: 50%;
	animation: float 8s ease-in-out infinite;
}

.hero__background::after {
	content: '';
	position: absolute;
	width: 400px;
	height: 400px;
	background: radial-gradient(circle, rgba(255, 152, 0, 0.2) 0%, transparent 70%);
	bottom: -100px;
	left: -100px;
	border-radius: 50%;
	animation: float 10s ease-in-out infinite reverse;
}

.hero__content {
	position: relative;
	z-index: 2;
	text-align: center;
	padding: var(--cc-spacing-4xl) 0;
}

.hero__title {
	font-size: clamp(2.5rem, 6vw, 4.5rem);
	font-weight: 800;
	color: var(--cc-color-white);
	margin-bottom: var(--cc-spacing-lg);
	letter-spacing: -1px;
	line-height: 1.1;
}

.hero__title span {
	background: var(--cc-gradient-primary);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.hero__subtitle {
	font-size: clamp(1.1rem, 2.5vw, 1.35rem);
	color: rgba(255, 255, 255, 0.8);
	max-width: 650px;
	margin: 0 auto var(--cc-spacing-2xl);
	font-weight: 300;
	line-height: 1.8;
}

.hero__actions {
	display: flex;
	gap: var(--cc-spacing-md);
	justify-content: center;
	flex-wrap: wrap;
}

.hero__actions .btn--outline {
	color: var(--cc-color-white);
	border-color: rgba(255, 255, 255, 0.4);
}

.hero__actions .btn--outline:hover {
	background: rgba(255, 255, 255, 0.1);
	border-color: var(--cc-color-white);
	color: var(--cc-color-white);
}

.hero__scroll-indicator {
	position: absolute;
	bottom: 30px;
	left: 50%;
	transform: translateX(-50%);
	color: rgba(255, 255, 255, 0.5);
	animation: bounce 2s ease-in-out infinite;
}

/* ==========================================================================
   7. SECCIONES
   ========================================================================== */
.section {
	padding: var(--cc-spacing-5xl) 0;
}

.section--services {
	background: var(--cc-color-gray-50);
}

.section--portfolio {
	background: var(--cc-color-white);
}

.section--testimonials {
	background: var(--cc-color-gray-50);
}

.section--cta {
	background: var(--cc-gradient-accent);
	padding: var(--cc-spacing-4xl) 0;
}

.section__header {
	text-align: center;
	margin-bottom: var(--cc-spacing-3xl);
}

.section__label {
	display: inline-block;
	font-family: var(--cc-font-heading);
	font-size: var(--cc-font-size-sm);
	font-weight: 600;
	color: var(--cc-color-primary);
	text-transform: uppercase;
	letter-spacing: 2px;
	margin-bottom: var(--cc-spacing-sm);
}

.section__title {
	font-size: clamp(2rem, 4vw, 3rem);
	margin-bottom: var(--cc-spacing-md);
}

.section__description {
	font-size: var(--cc-font-size-lg);
	color: var(--cc-color-gray-600);
	max-width: 600px;
	margin: 0 auto;
}

/* ==========================================================================
   8. SERVICIOS
   ========================================================================== */
.services-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	gap: var(--cc-spacing-xl);
}

.service-card {
	background: var(--cc-color-white);
	padding: var(--cc-spacing-2xl);
	border-radius: var(--cc-radius-xl);
	text-align: center;
	transition: all var(--cc-transition-base);
	border: 1px solid var(--cc-color-gray-200);
	position: relative;
	overflow: hidden;
}

.service-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: var(--cc-gradient-primary);
	transform: scaleX(0);
	transition: transform var(--cc-transition-base);
}

.service-card:hover {
	transform: translateY(-5px);
	box-shadow: var(--cc-shadow-xl);
	border-color: transparent;
}

.service-card:hover::before {
	transform: scaleX(1);
}

.service-card__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 80px;
	height: 80px;
	border-radius: var(--cc-radius-lg);
	background: linear-gradient(135deg, rgba(233, 30, 99, 0.1) 0%, rgba(255, 152, 0, 0.1) 100%);
	color: var(--cc-color-primary);
	margin-bottom: var(--cc-spacing-lg);
}

.service-card__icon img {
	width: 48px;
	height: 48px;
	object-fit: contain;
}

.service-card__title {
	font-size: var(--cc-font-size-xl);
	margin-bottom: var(--cc-spacing-sm);
}

.service-card__description {
	color: var(--cc-color-gray-600);
	font-size: var(--cc-font-size-sm);
	margin-bottom: var(--cc-spacing-md);
}

.service-card__link {
	display: inline-flex;
	align-items: center;
	gap: var(--cc-spacing-xs);
	font-family: var(--cc-font-heading);
	font-weight: 600;
	font-size: var(--cc-font-size-sm);
	color: var(--cc-color-primary);
	transition: gap var(--cc-transition-base);
}

.service-card__link:hover {
	gap: var(--cc-spacing-sm);
}

/* ==========================================================================
   9. PORTAFOLIO
   ========================================================================== */
.portfolio-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
	gap: var(--cc-spacing-xl);
}

.portfolio-item {
	border-radius: var(--cc-radius-xl);
	overflow: hidden;
	position: relative;
	aspect-ratio: 4 / 3;
	background: var(--cc-color-gray-200);
}

.portfolio-item__link {
	display: block;
	width: 100%;
	height: 100%;
}

.portfolio-item__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--cc-transition-slow);
}

.portfolio-item__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(26, 26, 46, 0.9) 0%, rgba(26, 26, 46, 0.3) 50%, transparent 100%);
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: var(--cc-spacing-2xl);
	opacity: 0;
	transition: opacity var(--cc-transition-base);
}

.portfolio-item:hover .portfolio-item__image {
	transform: scale(1.05);
}

.portfolio-item:hover .portfolio-item__overlay {
	opacity: 1;
}

.portfolio-item__title {
	color: var(--cc-color-white);
	font-size: var(--cc-font-size-xl);
	margin-bottom: var(--cc-spacing-xs);
}

.portfolio-item__excerpt {
	color: rgba(255, 255, 255, 0.8);
	font-size: var(--cc-font-size-sm);
	margin-bottom: var(--cc-spacing-md);
}

.portfolio-item__cta {
	display: inline-flex;
	align-items: center;
	font-family: var(--cc-font-heading);
	font-weight: 600;
	font-size: var(--cc-font-size-sm);
	color: var(--cc-color-secondary);
}

.portfolio-empty {
	grid-column: 1 / -1;
	text-align: center;
	padding: var(--cc-spacing-3xl);
	color: var(--cc-color-gray-500);
}

/* ==========================================================================
   10. TESTIMONIOS
   ========================================================================== */
.testimonials-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: var(--cc-spacing-xl);
}

.testimonial-card {
	background: var(--cc-color-white);
	padding: var(--cc-spacing-2xl);
	border-radius: var(--cc-radius-xl);
	box-shadow: var(--cc-shadow-sm);
	transition: all var(--cc-transition-base);
}

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

.testimonial-card__quote {
	position: relative;
	margin-bottom: var(--cc-spacing-lg);
	color: var(--cc-color-gray-700);
	font-style: italic;
}

.testimonial-card__quote svg {
	position: absolute;
	top: -10px;
	left: -5px;
	color: var(--cc-color-primary);
}

.testimonial-card__author {
	display: flex;
	align-items: center;
	gap: var(--cc-spacing-md);
}

.testimonial-card__avatar {
	width: 50px;
	height: 50px;
	border-radius: var(--cc-radius-full);
	object-fit: cover;
}

.testimonial-card__name {
	font-family: var(--cc-font-heading);
	font-size: var(--cc-font-size-sm);
	color: var(--cc-color-dark);
}

/* ==========================================================================
   11. CTA BLOCK
   ========================================================================== */
.cta-block {
	text-align: center;
	padding: var(--cc-spacing-3xl);
}

.cta-block__title {
	color: var(--cc-color-white);
	font-size: clamp(2rem, 4vw, 2.75rem);
	margin-bottom: var(--cc-spacing-md);
}

.cta-block__description {
	color: rgba(255, 255, 255, 0.9);
	font-size: var(--cc-font-size-lg);
	max-width: 600px;
	margin: 0 auto var(--cc-spacing-2xl);
}

/* ==========================================================================
   12. CARDS (Posts Grid)
   ========================================================================== */
.posts-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
	gap: var(--cc-spacing-2xl);
	padding: var(--cc-spacing-3xl) 0;
}

.card {
	background: var(--cc-color-white);
	border-radius: var(--cc-radius-xl);
	overflow: hidden;
	box-shadow: var(--cc-shadow-sm);
	transition: all var(--cc-transition-base);
	border: 1px solid var(--cc-color-gray-200);
}

.card:hover {
	transform: translateY(-5px);
	box-shadow: var(--cc-shadow-lg);
	border-color: transparent;
}

.card__image {
	position: relative;
	overflow: hidden;
	aspect-ratio: 16 / 10;
}

.card__image-link {
	display: block;
	width: 100%;
	height: 100%;
}

.card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--cc-transition-slow);
}

.card:hover .card__img {
	transform: scale(1.05);
}

.card__category {
	position: absolute;
	top: var(--cc-spacing-md);
	left: var(--cc-spacing-md);
	padding: var(--cc-spacing-xs) var(--cc-spacing-md);
	background: var(--cc-gradient-primary);
	color: var(--cc-color-white);
	font-family: var(--cc-font-heading);
	font-size: var(--cc-font-size-xs);
	font-weight: 600;
	border-radius: var(--cc-radius-full);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.card__body {
	padding: var(--cc-spacing-xl);
}

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

.card__title a {
	color: var(--cc-color-dark);
	transition: color var(--cc-transition-fast);
}

.card__title a:hover {
	color: var(--cc-color-primary);
}

.card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--cc-spacing-md);
	margin-bottom: var(--cc-spacing-md);
	font-size: var(--cc-font-size-xs);
	color: var(--cc-color-gray-500);
}

.card__meta .icon {
	vertical-align: middle;
	margin-right: 2px;
}

.card__meta a {
	color: var(--cc-color-gray-500);
}

.card__meta a:hover {
	color: var(--cc-color-primary);
}

.card__excerpt {
	color: var(--cc-color-gray-600);
	font-size: var(--cc-font-size-sm);
	margin-bottom: var(--cc-spacing-lg);
}

.card__footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.card__read-more {
	display: inline-flex;
	align-items: center;
	gap: var(--cc-spacing-xs);
}

/* ==========================================================================
   13. SINGLE POST
   ========================================================================== */
.single-post__hero {
	position: relative;
	height: 50vh;
	min-height: 350px;
	overflow: hidden;
}

.single-post__hero .post-thumbnail--single img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.single-post__hero-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, transparent 40%, rgba(0, 0, 0, 0.5) 100%);
}

.single-post__header {
	padding-top: var(--cc-spacing-3xl);
	margin-bottom: var(--cc-spacing-2xl);
}

.single-post__title {
	font-size: clamp(2rem, 4vw, 3rem);
	line-height: 1.2;
}

.single-post__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--cc-spacing-lg);
	color: var(--cc-color-gray-500);
	font-size: var(--cc-font-size-sm);
}

.single-post__meta .icon {
	vertical-align: middle;
	margin-right: 4px;
}

.single-post__content {
	font-size: var(--cc-font-size-md);
	line-height: 1.8;
	margin-bottom: var(--cc-spacing-3xl);
}

.single-post__content p {
	margin-bottom: var(--cc-spacing-lg);
}

.single-post__content blockquote {
	border-left: 4px solid var(--cc-color-primary);
	padding: var(--cc-spacing-lg) var(--cc-spacing-xl);
	margin: var(--cc-spacing-2xl) 0;
	background: var(--cc-color-gray-50);
	border-radius: 0 var(--cc-radius-md) var(--cc-radius-md) 0;
	font-style: italic;
	color: var(--cc-color-gray-700);
}

.single-post__footer {
	padding: var(--cc-spacing-xl) 0;
	border-top: 1px solid var(--cc-color-gray-200);
	display: flex;
	flex-wrap: wrap;
	gap: var(--cc-spacing-md);
}

.single-post__footer .icon {
	vertical-align: middle;
	margin-right: 4px;
}

/* Post Navigation */
.post-navigation {
	background: var(--cc-color-gray-50);
	padding: var(--cc-spacing-2xl) 0;
}

.post-navigation .nav-links {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--cc-spacing-xl);
}

.post-navigation__label {
	display: block;
	font-size: var(--cc-font-size-xs);
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--cc-color-gray-500);
	margin-bottom: var(--cc-spacing-xs);
}

.post-navigation__title {
	font-family: var(--cc-font-heading);
	font-weight: 600;
	color: var(--cc-color-dark);
}

/* ==========================================================================
   14. PAGE CONTENT
   ========================================================================== */
.page-content__header {
	background: var(--cc-gradient-dark);
	padding: var(--cc-spacing-4xl) 0 var(--cc-spacing-3xl);
}

.page-content__title {
	color: var(--cc-color-white);
	font-size: clamp(2rem, 4vw, 3rem);
	margin-bottom: 0;
}

.page-content__body {
	padding: var(--cc-spacing-3xl) 0;
}

/* Archive Header */
.archive-header {
	background: var(--cc-gradient-dark);
	padding: var(--cc-spacing-4xl) 0 var(--cc-spacing-3xl);
}

.archive-header__title {
	color: var(--cc-color-white);
	font-size: clamp(2rem, 4vw, 3rem);
	margin-bottom: var(--cc-spacing-sm);
}

.archive-header__description {
	color: rgba(255, 255, 255, 0.8);
	font-size: var(--cc-font-size-lg);
}

/* Search Header */
.search-header {
	background: var(--cc-gradient-dark);
	padding: var(--cc-spacing-4xl) 0 var(--cc-spacing-3xl);
}

.search-header__title {
	color: var(--cc-color-white);
	font-size: clamp(1.5rem, 3vw, 2.5rem);
}

.search-header__term {
	color: var(--cc-color-secondary);
}

/* ==========================================================================
   15. 404
   ========================================================================== */
.error-404 {
	text-align: center;
	padding: var(--cc-spacing-5xl) 0;
}

.error-404__number {
	display: flex;
	justify-content: center;
	gap: var(--cc-spacing-md);
	margin-bottom: var(--cc-spacing-xl);
}

.error-404__digit {
	font-family: var(--cc-font-heading);
	font-size: clamp(5rem, 15vw, 10rem);
	font-weight: 800;
	line-height: 1;
	color: var(--cc-color-gray-200);
}

.error-404__digit--accent {
	background: var(--cc-gradient-primary);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.error-404__title {
	font-size: var(--cc-font-size-2xl);
	margin-bottom: var(--cc-spacing-md);
}

.error-404__description {
	color: var(--cc-color-gray-600);
	max-width: 500px;
	margin: 0 auto var(--cc-spacing-xl);
}

.error-404__search {
	max-width: 500px;
	margin: var(--cc-spacing-2xl) auto 0;
}

/* ==========================================================================
   16. SIDEBAR Y WIDGETS
   ========================================================================== */
.sidebar {
	padding: var(--cc-spacing-3xl) 0;
}

.widget {
	margin-bottom: var(--cc-spacing-2xl);
	padding: var(--cc-spacing-xl);
	background: var(--cc-color-gray-50);
	border-radius: var(--cc-radius-lg);
}

.widget-title {
	font-size: var(--cc-font-size-lg);
	margin-bottom: var(--cc-spacing-md);
	padding-bottom: var(--cc-spacing-sm);
	border-bottom: 2px solid var(--cc-color-primary);
}

.widget ul li {
	padding: var(--cc-spacing-sm) 0;
	border-bottom: 1px solid var(--cc-color-gray-200);
}

.widget ul li:last-child {
	border-bottom: none;
}

.widget ul li a {
	color: var(--cc-color-gray-700);
	font-size: var(--cc-font-size-sm);
}

.widget ul li a:hover {
	color: var(--cc-color-primary);
}

/* ==========================================================================
   17. FOOTER (UPWORK ENTERPRISE STYLE)
   ========================================================================== */
.site-footer--dark {
	background-color: transparent;
	padding: var(--cc-spacing-2xl) var(--cc-spacing-md) var(--cc-spacing-md) var(--cc-spacing-md);
	font-family: var(--cc-font-body);
}

.site-footer--dark .container {
	background-color: #141414; /* Tonalidad mate oscuro intenso */
	color: #ffffff;
	border-radius: 24px; /* Efecto Tarjeta/Isla redondeada */
	padding: var(--cc-spacing-4xl) var(--cc-spacing-3xl);
	max-width: var(--cc-container-max);
}

.footer-top {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--cc-spacing-2xl);
	margin-bottom: var(--cc-spacing-3xl);
}

.footer-col__title {
	color: #ffffff;
	font-size: var(--cc-font-size-md);
	font-weight: 500;
	margin-bottom: var(--cc-spacing-lg);
}

.footer-col__list {
	padding: 0;
	margin: 0;
}

.footer-col__list li {
	margin-bottom: 12px;
}

.footer-col__list a {
	color: #9b9b9b; /* Gris tenue para descanso visual */
	text-decoration: none;
	font-size: var(--cc-font-size-sm);
	transition: color var(--cc-transition-fast);
}

.footer-col__list a:hover {
	color: var(--cc-color-white);
	text-decoration: underline;
}

.footer-middle {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-bottom: var(--cc-spacing-xl);
	border-bottom: 1px solid #333333; /* Separador sutil */
	margin-bottom: var(--cc-spacing-xl);
}

.footer-social,
.footer-apps {
	display: flex;
	align-items: center;
	gap: var(--cc-spacing-xl);
}

.footer-social__label,
.footer-apps__label {
	color: #ffffff;
	font-size: var(--cc-font-size-sm);
	font-weight: 500;
}

.footer-social .social-links {
	display: flex;
	gap: var(--cc-spacing-md);
	padding: 0;
	margin: 0;
}

.footer-social .social-links a,
.footer-apps__link {
	color: #ffffff;
	display: inline-flex;
	transition: opacity var(--cc-transition-fast);
}

.footer-social .social-links a:hover,
.footer-apps__link:hover {
	opacity: 0.7;
}

.footer-bottom {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 13px;
	color: #9b9b9b;
	gap: var(--cc-spacing-xl);
	flex-wrap: wrap;
}

.footer-legal {
	display: flex;
	padding: 0;
	margin: 0;
	gap: var(--cc-spacing-lg);
	flex-wrap: wrap;
}

.footer-legal a {
	color: #ffffff;
	text-decoration: none;
	transition: color var(--cc-transition-fast);
}

.footer-legal a:hover {
	text-decoration: underline;
}

/* Redimensiones de Footer en Smartphone */
@media (max-width: 900px) {
	.footer-top {
		grid-template-columns: 1fr 1fr;
		gap: var(--cc-spacing-xl);
	}
	.footer-middle {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--cc-spacing-lg);
	}
	.footer-social, .footer-apps {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--cc-spacing-sm);
	}
}

@media (max-width: 480px) {
	.footer-top {
		grid-template-columns: 1fr;
	}
	.footer-bottom {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--cc-spacing-md);
	}
	.footer-legal {
		flex-direction: column;
		gap: 8px;
	}
}

/* ==========================================================================
   18. FORMULARIO DE BÚSQUEDA
   ========================================================================== */
.search-form {
	display: flex;
	gap: var(--cc-spacing-sm);
}

.search-form .search-field {
	flex: 1;
	padding: var(--cc-spacing-sm) var(--cc-spacing-md);
	border: 2px solid var(--cc-color-gray-300);
	border-radius: var(--cc-radius-full);
	font-family: var(--cc-font-body);
	font-size: var(--cc-font-size-base);
	outline: none;
	transition: border-color var(--cc-transition-fast);
}

.search-form .search-field:focus {
	border-color: var(--cc-color-primary);
}

.search-form .search-submit {
	padding: var(--cc-spacing-sm) var(--cc-spacing-lg);
	background: var(--cc-gradient-primary);
	color: var(--cc-color-white);
	border: none;
	border-radius: var(--cc-radius-full);
	font-family: var(--cc-font-heading);
	font-weight: 600;
	cursor: pointer;
	transition: all var(--cc-transition-base);
}

.search-form .search-submit:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(233, 30, 99, 0.3);
}

/* ==========================================================================
   19. PAGINACIÓN
   ========================================================================== */
.cusco-pagination {
	display: flex;
	justify-content: center;
	gap: var(--cc-spacing-xs);
	padding: var(--cc-spacing-2xl) 0;
}

.cusco-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 44px;
	padding: 0 var(--cc-spacing-md);
	border-radius: var(--cc-radius-full);
	font-family: var(--cc-font-heading);
	font-weight: 600;
	font-size: var(--cc-font-size-sm);
	color: var(--cc-color-gray-700);
	background: var(--cc-color-gray-100);
	transition: all var(--cc-transition-fast);
}

.cusco-pagination .page-numbers:hover,
.cusco-pagination .page-numbers.current {
	background: var(--cc-gradient-primary);
	color: var(--cc-color-white);
}

/* ==========================================================================
   20. COMENTARIOS
   ========================================================================== */
.comments-area {
	padding: var(--cc-spacing-3xl) 0;
}

.comments-title {
	font-size: var(--cc-font-size-2xl);
	margin-bottom: var(--cc-spacing-2xl);
}

.comment-list {
	list-style: none;
}

.comment-list .comment {
	margin-bottom: var(--cc-spacing-xl);
	padding: var(--cc-spacing-xl);
	background: var(--cc-color-gray-50);
	border-radius: var(--cc-radius-lg);
}

.comment-author .avatar {
	border-radius: var(--cc-radius-full);
	margin-right: var(--cc-spacing-sm);
	vertical-align: middle;
}

.cusco-comment-form .submit {
	background: var(--cc-gradient-primary);
	color: var(--cc-color-white);
	border: none;
	padding: var(--cc-spacing-sm) var(--cc-spacing-xl);
	border-radius: var(--cc-radius-full);
	font-family: var(--cc-font-heading);
	font-weight: 600;
	cursor: pointer;
	transition: all var(--cc-transition-base);
}

.cusco-comment-form .submit:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(233, 30, 99, 0.3);
}

.cusco-comment-form input[type="text"],
.cusco-comment-form input[type="email"],
.cusco-comment-form input[type="url"],
.cusco-comment-form textarea {
	width: 100%;
	padding: var(--cc-spacing-sm) var(--cc-spacing-md);
	border: 2px solid var(--cc-color-gray-300);
	border-radius: var(--cc-radius-md);
	font-family: var(--cc-font-body);
	font-size: var(--cc-font-size-base);
	outline: none;
	transition: border-color var(--cc-transition-fast);
}

.cusco-comment-form input:focus,
.cusco-comment-form textarea:focus {
	border-color: var(--cc-color-primary);
}

/* ==========================================================================
   21. HERO BANNER (SPLIT MASONRY)
   ========================================================================== */
.hero--split {
	background-color: var(--cc-color-dark); /* Azul Marino Profundo Corporativo */
	color: var(--cc-color-white);
	
	/* Ajuste de compresión milimétrica pedida por el cliente */
	padding-top: calc(var(--cc-header-height, 80px) + 20px);
	padding-bottom: 20px;
	padding-left: clamp(1.5rem, 6vw, 7rem);
	padding-right: clamp(1.5rem, 6vw, 7rem);
	box-sizing: border-box; /* Fundamental para no desbordar el cálculo del viewport */
	
	/* Eliminamos el corset de 80vh para que las cajas puedan respirar hacia abajo libremente */
	min-height: 100vh; 
	display: flex;
	align-items: center;
	overflow: hidden;
}

/* Eliminador de Padding Compuesto en la variante Split */
.hero--split .hero__content,
.hero--split .split-layout {
	padding-top: 0;
	padding-bottom: 0;
}

.split-layout {
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	gap: var(--cc-spacing-3xl);
	align-items: center;
	width: 100%;
}

/* Panel Izquierdo: Copy & CTA */
.hero__left-pane {
	text-align: left; /* Fuerzo la estructura a la izquierda en escritorio */
}

.hero__eyebrow {
	display: inline-block;
	color: var(--cc-color-secondary); /* Naranja Oficial */
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 2px;
	text-transform: uppercase;
	margin-bottom: var(--cc-spacing-md);
}

.hero__title--gradient {
	font-size: clamp(2.5rem, 4vw, 4.2rem);
	line-height: 1.15;
	font-weight: 800;
	margin-bottom: var(--cc-spacing-lg);
	color: #fff;
	background: var(--cc-gradient-primary); /* Degradado Magenta a Naranja Cusco Creativos */
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.hero__left-pane .hero__subtitle {
	font-size: 1.125rem;
	color: var(--cc-color-gray-300);
	line-height: 1.6;
	max-width: 90%;
	margin-bottom: var(--cc-spacing-2xl);
}

.btn--solid-gold {
	background: var(--cc-gradient-primary); 
	color: var(--cc-color-white);
	font-weight: 700;
	padding: var(--cc-spacing-md) var(--cc-spacing-2xl);
	border-radius: var(--cc-radius-full);
	transition: transform 0.3s ease, box-shadow 0.3s ease;
	display: inline-block;
	text-decoration: none;
	border: none;
}

.btn--solid-gold:hover {
	transform: translateY(-3px);
	box-shadow: var(--cc-shadow-glow);
	color: var(--cc-color-white);
}

/* Panel Derecho: Masonry Inteligente y Elástico */
.hero__right-pane {
	position: relative;
	width: 100%;
	height: 100%;
	min-height: 480px; /* Al menos dará al Masonry espacio en altura para dibujar su retícula interna */
	display: flex;
	align-items: center;
	justify-content: center;
}

.hero__masonry-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-template-rows: repeat(6, 1fr); /* ORO PURO: Fracciones matemáticas fluidas que absorben la altura y NUNCA se cortan */
	gap: clamp(8px, 1.5vw, 16px);
	width: 100%;
	height: 100%;
	max-height: clamp(400px, 80vh, 750px); /* Previene estiramientos artificiales */
}

.masonry-item {
	border-radius: 16px;
	overflow: hidden;
	position: relative;
	box-shadow: 0 10px 30px rgba(0,0,0,0.5);
	background: #1a1a1a;
}

.masonry-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.7s ease;
}

.masonry-item:hover img {
	transform: scale(1.05);
}

/* Distribución Celular Geométrica */
.img-tiger { grid-column: 1 / 3; grid-row: 1 / 3; }
.img-ballet { grid-column: 3 / 4; grid-row: 1 / 3; }
.img-rocket { grid-column: 1 / 2; grid-row: 3 / 6; }
.img-brush { grid-column: 2 / 3; grid-row: 3 / 5; }
.img-buildings { grid-column: 3 / 4; grid-row: 3 / 5; }
.img-boxing { grid-column: 2 / 4; grid-row: 5 / 7; }

/* Ajustes Responsivos */
@media (max-width: 1024px) {
	.split-layout {
		grid-template-columns: 1fr 1fr;
		gap: var(--cc-spacing-xl);
	}
	.hero__title--gradient {
		font-size: 2.8rem;
	}
}

@media (max-width: 768px) {
	.hero--split {
		height: auto; /* Se elimina restricción 100vh para permitir stack natural vertical celular */
		min-height: 100vh;
		padding: var(--cc-spacing-3xl) 0;
	}
	.split-layout {
		grid-template-columns: 1fr;
		height: auto;
	}
	.hero__left-pane {
		text-align: center;
		margin-bottom: var(--cc-spacing-2xl);
	}
	.hero__left-pane .hero__subtitle {
		margin-left: auto;
		margin-right: auto;
	}
	.hero__right-pane {
		height: 60vh; /* Altura generosa para el grid en celular */
		min-height: 400px;
	}
}

@media (max-width: 480px) {
	.hero__masonry-grid {
		gap: 8px;
	}
	.masonry-item {
		border-radius: 12px;
	}
}

/* ==========================================================================
   21.5. SEO TEXT & INTRO
   ========================================================================== */
.section--seo-intro {
	padding: var(--cc-spacing-4xl) 0 var(--cc-spacing-xl) 0;
	text-align: center;
	background: var(--cc-color-white); /* Limpio y elegante apoyando el texto */
}

.seo-intro__content {
	max-width: 1100px;
	margin: 0 auto;
}

.seo-intro__title {
	font-size: clamp(2rem, 3.5vw, 3rem);
	font-weight: 800;
	color: var(--cc-color-dark);
	margin-bottom: var(--cc-spacing-lg);
	line-height: 1.25;
	letter-spacing: -0.5px;
}

.text-gradient {
	background: var(--cc-gradient-primary); /* Magenta to Naranja Cusco Creativos */
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.seo-intro__lead {
	font-size: 1.25rem;
	color: var(--cc-color-gray-800);
	line-height: 1.7;
	margin-bottom: var(--cc-spacing-md);
	font-weight: 500;
}

.seo-intro__text {
	font-size: 1.1rem;
	color: var(--cc-color-gray-600);
	line-height: 1.6;
}

.seo-intro__text strong {
	color: var(--cc-color-secondary); /* Naranja Oficial para el Call-Out */
}

/* ==========================================================================
   22. SERVICIOS (GRID DE 4 COLUMNAS)
   ========================================================================== */
.section--services {
	padding: var(--cc-spacing-3xl) 0 var(--cc-spacing-4xl) 0; /* Padding dramáticamente acortado para encajar justo debajo del texto de SEO */
	background-color: var(--cc-color-gray-50);
}

.section__header {
	text-align: center;
	max-width: 720px;
	margin: 0 auto var(--cc-spacing-3xl) auto; /* Ajustado de 5xl a 3xl para reducir ese hueco masivo superior */
	display: flex;
	flex-direction: column;
	align-items: center;
}

.section__label {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	color: var(--cc-color-secondary); /* Naranja Oficial */
	font-weight: 800;
	letter-spacing: 3px;
	text-transform: uppercase;
	margin-bottom: var(--cc-spacing-xl);
	font-size: 13px;
	background: rgba(255, 152, 0, 0.08); /* Píldora translúcida asimétrica */
	padding: 6px 18px;
	border-radius: var(--cc-radius-full);
}

/* Líneas geométricas laterales para enmarcar el Label */
.section__label::before,
.section__label::after {
	content: '';
	display: inline-block;
	width: 16px;
	height: 2px;
	background-color: var(--cc-color-secondary);
	border-radius: 2px;
}

.section__title {
	font-size: clamp(2.5rem, 5vw, 3.8rem);
	color: var(--cc-color-dark);
	margin-bottom: var(--cc-spacing-lg);
	font-weight: 900;
	line-height: 1.1;
	letter-spacing: -1px;
}

/* Micro subrayado grueso de gradiente corporativo */
.section__title::after {
	content: '';
	display: block;
	width: 70px;
	height: 5px;
	background: var(--cc-gradient-primary); /* Degradado Magenta - Naranja */
	margin: var(--cc-spacing-xl) auto 0;
	border-radius: var(--cc-radius-full);
}

.section__description {
	font-size: 1.15rem;
	color: var(--cc-color-gray-600);
	line-height: 1.8;
	margin-bottom: 0;
}

/* Base de 4 Columnas forzadas por fila */
.services-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--cc-spacing-xl);
}

/* Tarjeta Premium de Servicio */
.service-card {
	background: var(--cc-color-white);
	padding: var(--cc-spacing-2xl) var(--cc-spacing-lg);
	border-radius: var(--cc-radius-xl);
	box-shadow: var(--cc-shadow-sm);
	transition: transform var(--cc-transition-base), box-shadow var(--cc-transition-base);
	display: flex;
	flex-direction: column;
	align-items: center;  /* Centrado de icono, textos y boton */
	text-align: center;   /* Alineación centrada de párrafos */
	height: 100%;
	border: 1px solid var(--cc-color-gray-100);
}

.service-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--cc-shadow-xl);
	border-color: var(--cc-color-primary-light);
}

.service-card__icon {
	color: var(--cc-color-primary); /* Magenta */
	margin-bottom: var(--cc-spacing-lg);
	display: inline-flex;
	padding: var(--cc-spacing-md);
	background: rgba(233, 30, 99, 0.08); /* Fondo rosado lavado elegante */
	border-radius: var(--cc-radius-lg);
}

.service-card__icon svg {
	width: 32px;
	height: 32px;
}

.service-card__title {
	font-size: var(--cc-font-size-xl);
	margin-bottom: var(--cc-spacing-sm);
	margin-top: 0;
	font-family: var(--cc-font-heading);
	color: var(--cc-color-gray-900);
	font-weight: 700;
}

.service-card__description {
	color: var(--cc-color-gray-600);
	line-height: 1.6;
	margin-bottom: var(--cc-spacing-lg);
	flex-grow: 1; /* Efecto Push-Down: Obliga al texto a expandir la tarjeta para que el Link CTA inferior siempre quede parejo abajo */
}

.service-card__link {
	display: inline-flex;
	align-items: center;
	gap: var(--cc-spacing-xs);
	color: var(--cc-color-secondary); /* Link naranja */
	font-weight: 600;
	text-decoration: none;
	transition: color var(--cc-transition-fast);
	margin-top: auto;
}

.service-card__link:hover {
	color: var(--cc-color-primary); /* Link pasa a Magenta al hacer hover */
}

.service-card__link svg {
	transition: transform var(--cc-transition-fast);
}

.service-card__link:hover svg {
	transform: translateX(4px); /* Micro-interacción: Flecha se mueve adelante */
}

/* Para Resoluciones Intermedias Grandes (Escritorio Pequeño - Laptops 13/14 pulgadas) */
@media (min-width: 1025px) and (max-width: 1400px) {
	.services-grid {
		gap: var(--cc-spacing-md); /* Achicar el espacio entre 4 cajas para que quepan en laptops */
	}
	.service-card {
		padding: var(--cc-spacing-xl) var(--cc-spacing-md);
	}
}
/* ==========================================================================
   24. NUESTRA TRAYECTORIA (TIMELINE HORIZONTAL)
   ========================================================================== */
.pinned-trajectory {
	/* Fondo oscuro premium que diferencia visualmente la sección del resto de la página */
	background: linear-gradient(160deg, #0f0c29 0%, #1a1a2e 45%, #16213e 100%);
	height: 400vh;
	position: relative;
}

.pinned-trajectory__sticky {
	position: sticky;
	top: 0;
	height: 100vh;
	width: 100%;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	justify-content: center;
	/* Padding exacto al header (80px) sin margen extra — elimina el bloque vacío superior */
	padding-top: var(--cc-header-height);
	padding-bottom: 16px;
	box-sizing: border-box;
}

.container--trajectory-header {
	margin-bottom: var(--cc-spacing-sm); /* Espacio mínimo entre el título y el carrusel */
}

/* Header alineado a la izquierda para Desktop — adaptado al fondo oscuro */
.section__header--left {
	text-align: left;
	max-width: 800px;
	margin-left: 0;
	margin-right: auto;
	align-items: flex-start;
}
.section__header--left .section__title::after {
	margin: var(--cc-spacing-md) 0 0 0; /* Subrayado más pegado */
}
/* En fondo oscuro ajustamos el label (pill) y el título */
.pinned-trajectory .section__label {
	background: rgba(255,255,255,0.08);
	color: rgba(255,255,255,0.8);
	border-color: rgba(255,255,255,0.15);
}
/* La parte normal del título (no gradiente) se vuelve blanca */
.pinned-trajectory .section__title {
	color: #ffffff;
}
/* El subtítulo o descripción del header también blanco si existiera */
.pinned-trajectory .section__subtitle {
	color: rgba(255,255,255,0.7);
}

.trajectory-track-container {
	width: 100%;
	flex-grow: 1; /* Ocupa el resto del espacio disponible bajo el header */
	display: flex;
	align-items: center; /* Centramos el timeline estrictamente en el espacio sobrante */
}

.trajectory-timeline--horizontal {
	display: flex;
	align-items: stretch; /* Permitimos que los item tomen la altura total del canal flex */
	height: 100%; /* Altura máxima posible */
	padding: 0 10vw; /* Padding inicial para que primer caja quede algo centrada/espaciada */
	width: max-content; /* Permite que el contenedor crezca horizontalmente infinito */
	will-change: transform;
	position: relative;
}

.trajectory-line {
	position: absolute;
	top: 50%;
	left: 0;
	right: -10vw; /* Hasta el final del track */
	height: 2px;
	transform: translateY(-50%);
	background: var(--cc-color-gray-300);
	border-top: 2px dashed var(--cc-color-gray-400);
	z-index: 1;
}

.trajectory-item {
	width: 480px; /* Ensanchado para que el texto fluya horizontalmente y consuma menos altura */
	flex-shrink: 0;
	position: relative;
	display: block; /* Children uses absolute pos anyway */
	height: 100%; /* Adaptable 100% al espacio remanente, NUNCA sobrepasando 100vh */
	z-index: 2;
	margin-right: var(--cc-spacing-3xl);
}

.trajectory-item--last {
	margin-right: 0;
}

/* El Marcador (Círculo de Año) sobre la línea */
.trajectory-item__marker {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 60px;
	height: 60px;
	border-radius: 50%;
	background: var(--cc-color-white);
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 900;
	font-size: 1rem;
	box-shadow: 0 5px 20px rgba(0,0,0,0.1);
	border: 5px solid var(--cc-color-gray-200);
	transition: transform 0.3s ease, box-shadow 0.3s ease;
	z-index: 3;
}

/* Colores de bordes (Timeline de la imagen) */
.trajectory-item__marker--yellow { border-color: #ffc107; color: #d39e00; }
.trajectory-item__marker--orange { border-color: #fd7e14; color: #d96400; }
.trajectory-item__marker--red { border-color: #dc3545; color: #b02a37; }
.trajectory-item__marker--pink { border-color: var(--cc-color-primary); color: var(--cc-color-primary); }

.trajectory-item:hover .trajectory-item__marker {
	transform: translate(-50%, -50%) scale(1.15);
	box-shadow: 0 10px 30px rgba(0,0,0,0.15);
}

/* Contenido de la tarjeta de historia */
.trajectory-item__content {
	background: var(--cc-color-white);
	padding: var(--cc-spacing-xl); /* Padding más compacto en los polos */
	border-radius: var(--cc-radius-lg);
	box-shadow: var(--cc-shadow-sm);
	border: 1px solid var(--cc-color-gray-100);
	width: 100%;
	max-width: 420px; /* Al permitir textos anchos, se reduce el número de líneas verticales */
	transition: transform var(--cc-transition-base), box-shadow var(--cc-transition-base);
	position: absolute;
}

/* Offset Arriba y Abajo del eje central más pegado a la línea */
.trajectory-item--top .trajectory-item__content {
	bottom: calc(50% + 40px);
}

.trajectory-item--bottom .trajectory-item__content {
	top: calc(50% + 40px);
}

/* Rama/Tallo estético más pequeño */
.trajectory-item--top .trajectory-item__content::after,
.trajectory-item--bottom .trajectory-item__content::before {
	content: '';
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	width: 2px;
	height: 15px; /* Tallo comprimido */
	background: var(--cc-color-gray-300);
}

.trajectory-item--top .trajectory-item__content::after {
	bottom: -15px;
}

.trajectory-item--bottom .trajectory-item__content::before {
	top: -15px;
}

.trajectory-item__content p {
	margin: 0;
	font-size: 0.95rem; /* Letra un pelo menor para cuidar pantalla pequeña */
	line-height: 1.55;
	color: var(--cc-color-gray-700);
}

.trajectory-item__content p strong,
.trajectory-item__content p em {
	color: var(--cc-color-dark);
}

.trajectory-item:hover .trajectory-item__content {
	box-shadow: var(--cc-shadow-lg);
	border-color: var(--cc-color-primary-light);
}
.trajectory-item--top:hover .trajectory-item__content { transform: translateY(-8px); }
.trajectory-item--bottom:hover .trajectory-item__content { transform: translateY(8px); }

/* ==== OVERRIDES PARA FONDO OSCURO ==== */
/* Las tarjetas adoptan efecto glassmorphism sutil sobre el oscuro */
.pinned-trajectory .trajectory-item__content {
	background: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.12);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	box-shadow: 0 4px 20px rgba(0,0,0,0.3);
}
.pinned-trajectory .trajectory-item__content p {
	color: rgba(255,255,255,0.85);
}
.pinned-trajectory .trajectory-item__content p strong,
.pinned-trajectory .trajectory-item__content p em {
	color: #ffffff;
}
/* La línea central es más visible sobre fondo oscuro */
.pinned-trajectory .trajectory-line {
	background: rgba(255,255,255,0.15);
	border-top-color: rgba(255,255,255,0.25);
}
/* Los tallos también más claros */
.pinned-trajectory .trajectory-item--top .trajectory-item__content::after,
.pinned-trajectory .trajectory-item--bottom .trajectory-item__content::before {
	background: rgba(255,255,255,0.25);
}
/* Marcadores con fondo oscuro levemente contrastado */
.pinned-trajectory .trajectory-item__marker {
	background: #1a1a2e;
	color: #ffffff;
}

/* ==== ADAPTACIÓN PARA PORTÁTILES O PANTALLAS DE POCA ALTURA (LAPTOPS) ==== */
@media (max-height: 850px) and (min-width: 1025px) {
	.pinned-trajectory__sticky {
		padding-top: 80px; /* Menor hueco al header */
	}
	.container--trajectory-header {
		margin-bottom: 0px; 
	}
	.trajectory-item {
		height: 320px; /* Super encogido para que los elementos no toquen los bordes */
	}
	.trajectory-item__content {
		padding: 15px 20px; /* Padding radicalmente más pequeño */
	}
	.trajectory-item__content p {
		font-size: 0.88rem; /* Letra más diminuta */
		line-height: 1.45;
	}
	/* Acercar todo violentamente hacia la línea central */
	.trajectory-item--top .trajectory-item__content {
		bottom: calc(50% + 28px);
	}
	.trajectory-item--bottom .trajectory-item__content {
		top: calc(50% + 28px);
	}
	.trajectory-item__marker {
		width: 45px;
		height: 45px;
		font-size: 0.85rem;
		border-width: 4px;
	}
	/* Tallos microscópicos */
	.trajectory-item--top .trajectory-item__content::after {
		bottom: -10px;
		height: 10px;
	}
	.trajectory-item--bottom .trajectory-item__content::before {
		top: -10px;
		height: 10px;
	}
}

/* ==== RESPONSIVE: Anular Scroll-Jacking y Convertir a Carrusel Nativo en Movil ==== */
@media (max-width: 1024px) {
	.pinned-trajectory {
		height: auto;
		padding: var(--cc-spacing-4xl) 0;
	}
	
	.pinned-trajectory__sticky {
		position: relative;
		height: auto;
		display: block;
		overflow: visible;
	}

	.section__header--left {
		text-align: center;
		margin-left: auto;
		margin-right: auto;
		align-items: center;
	}
	
	.section__header--left .section__title::after {
		margin: var(--cc-spacing-xl) auto 0;
	}

	.trajectory-track-container {
		/* En móviles forzamos scroll horizontal nativo tocado con dedo */
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scroll-snap-type: x mandatory;
		scrollbar-width: none;
		margin-top: var(--cc-spacing-2xl);
	}
	.trajectory-track-container::-webkit-scrollbar {
		display: none;
	}
	
	.trajectory-timeline--horizontal {
		padding: var(--cc-spacing-xl) 5vw;
	}
	
	.trajectory-item {
		scroll-snap-align: center; /* Centrar tarjeta en pantalla movil */
		width: 320px;
		height: 480px;
		margin-right: var(--cc-spacing-xl);
	}
}

@media (max-width: 600px) {
	.trajectory-item {
		width: 88vw; /* Asegurar que quepa casi un item en celular dando asomo al siguiente */
	}
	.trajectory-item__content {
		padding: var(--cc-spacing-xl);
		max-width: 100%; /* Tomar 100% de los 88vw */
	}
}

/* ==========================================================================
   26. PREGUNTAS FRECUENTES (FAQ) — REDISEÑO PREMIUM
   ========================================================================== */
.section--faqs {
	padding: var(--cc-spacing-5xl) 0 var(--cc-spacing-5xl) 0;
	background: var(--cc-color-white);
	margin-top: var(--cc-spacing-5xl); /* Separación extra de la sección oscura de Trayectoria */
}

/* Grid de 2 columnas para el acordeón */
.faqs-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--cc-spacing-xl) var(--cc-spacing-3xl);
	margin-top: var(--cc-spacing-3xl);
}

.faqs-col {
	display: flex;
	flex-direction: column;
	gap: var(--cc-spacing-md);
}

/* Item del acordeón */
.faq-item {
	border: 1px solid var(--cc-color-gray-200);
	border-radius: var(--cc-radius-lg);
	overflow: hidden;
	transition: border-color var(--cc-transition-base), box-shadow var(--cc-transition-base);
}

.faq-item[open] {
	border-color: var(--cc-color-primary-light);
	box-shadow: 0 4px 20px rgba(233,30,99,0.08);
}

/* Pregunta (summary) */
.faq-item__question {
	display: flex;
	align-items: center;
	gap: var(--cc-spacing-md);
	padding: var(--cc-spacing-xl);
	cursor: pointer;
	list-style: none;
	font-family: var(--cc-font-heading);
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--cc-color-dark);
	transition: background var(--cc-transition-fast);
	-webkit-user-select: none;
	user-select: none;
}
.faq-item__question::-webkit-details-marker { display: none; }

.faq-item:hover .faq-item__question,
.faq-item[open] .faq-item__question {
	background: var(--cc-color-gray-50);
}

/* Número de pregunta con gradiente de marca */
.faq-item__num {
	flex-shrink: 0;
	font-size: 0.75rem;
	font-weight: 800;
	letter-spacing: 0.5px;
	background: var(--cc-gradient-primary);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	line-height: 1;
}

/* Texto expandible ocupa todo el espacio */
.faq-item__text {
	flex: 1;
	line-height: 1.45;
}

/* Icono + / × */
.faq-item__icon {
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	border: 1.5px solid var(--cc-color-gray-300);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.2rem;
	font-weight: 300;
	color: var(--cc-color-gray-500);
	transition: all var(--cc-transition-base);
	line-height: 1;
	position: relative;
}
.faq-item__icon::before {
	content: '+';
	position: absolute;
	transition: opacity var(--cc-transition-fast), transform var(--cc-transition-base);
}
.faq-item[open] .faq-item__icon {
	border-color: var(--cc-color-primary);
	background: var(--cc-color-primary);
	color: #fff;
}
.faq-item[open] .faq-item__icon::before {
	content: '×';
}

/* Respuesta */
.faq-item__answer {
	padding: 0 var(--cc-spacing-xl) var(--cc-spacing-xl);
	padding-left: calc(var(--cc-spacing-xl) + 2rem + var(--cc-spacing-md)); /* Indenta bajo el número */
}

.faq-item__answer p {
	margin: 0;
	font-size: 0.92rem;
	line-height: 1.7;
	color: var(--cc-color-gray-600);
}

.faq-item__answer strong {
	color: var(--cc-color-dark);
	font-weight: 700;
}

/* Responsive */
@media (max-width: 900px) {
	.faqs-grid {
		grid-template-columns: 1fr;
		gap: var(--cc-spacing-md);
	}
}

/* ==========================================================================
   27. BLOG SCROLL-SNAP SLIDER (OPTIMIZED)
   ========================================================================== */
.section--blog-slider {
	padding: var(--cc-spacing-5xl) 0;
	background: var(--cc-color-gray-50);
	overflow: hidden; /* Frena salidas indeseadas del scroll infinito del carrousel en viejos PC */
}

/* Rompemos el contenedor base para permitir una sangría izquierda impecable sin detener el desliz derecho */
.cc-blog-slider-wrap {
	width: 100vw;
	position: relative;
	left: 50%;
	right: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
}

@media (min-width: 1200px) {
	.cc-blog-slider-wrap {
		width: 100%;
		left: auto;
		right: auto;
		margin-left: auto;
		margin-right: auto;
	}
}

/* FLECHAS DE NAVEGACION DEL SLIDER */
.cc-slider-arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 10;
	background: var(--cc-color-white);
	color: var(--cc-color-dark);
	border: 1px solid var(--cc-color-gray-200);
	width: 52px;
	height: 52px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	box-shadow: 0 4px 15px rgba(0,0,0,0.08); /* Sombra difusa fina */
	transition: all var(--cc-transition-base);
}

.cc-slider-arrow:hover {
	background: var(--cc-color-primary); /* Magenta corporativo puro */
	color: var(--cc-color-white);
	border-color: var(--cc-color-primary);
	transform: translateY(-50%) scale(1.1); /* Efecto burbuja visual */
	box-shadow: 0 10px 25px rgba(233, 30, 99, 0.4);
}

/* Ubicación Espacial Matemática (Pilar del encuadre central) */
.cc-slider-arrow--prev {
	left: max(1vw, calc((100vw - 1200px) / 2 - 26px));
}

.cc-slider-arrow--next {
	right: max(1vw, calc((100vw - 1200px) / 2 - 26px));
}

/* Ocultamiento Sensato en Celulares y Tablets limitadas */
@media (max-width: 1024px) {
	.cc-slider-arrow {
		width: 44px;
		height: 44px;
	}
}

@media (max-width: 768px) {
	.cc-slider-arrow {
		display: none; /* En celular mandamos a esconder esto porque el dedo (Scroll Drag Nativo) es 10x mas eficiente */
	}
}

/* Pista de Carreras (Slider core) */
.cc-blog-carousel {
	display: flex;
	gap: var(--cc-spacing-3xl);
	overflow-x: auto;
	scroll-snap-type: x mandatory; /* MAGIA NATIVA. Cero javascript puro CSS */
	padding: var(--cc-spacing-3xl) max(5vw, calc((100vw - 1200px) / 2));
	-webkit-overflow-scrolling: touch; /* Momentum de fricción suave para IOS de Apple */
	scrollbar-width: none; /* Firefox oculta barra sucia */
}

.cc-blog-carousel::-webkit-scrollbar {
	display: none; /* Chrome/Safari se oculta la pista inferior antiestetica */
}

/* CARDS ESTRUCTURA TRIDIMENSIONAL */
.cc-blog-card {
	flex: 0 0 360px; /* Ancho rígido asimétrico para deslizar comodamente sin dañar el layout flex */
	scroll-snap-align: center; /* Al soltar el dedo atrae un campo magnético la carta al centro del tel. */
	background: var(--cc-color-white);
	border-radius: var(--cc-radius-xl);
	box-shadow: 0 5px 20px rgba(0,0,0,0.06);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	border: 1px solid var(--cc-color-gray-100);
	transition: transform var(--cc-transition-base), box-shadow var(--cc-transition-base);
}

.cc-blog-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 40px rgba(0,0,0,0.12); /* Súper sombra emergente de UI/UX moderno */
}

.cc-blog-card__header {
	position: relative;
	display: block;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--cc-color-dark); /* Fondo en caso las imagenes tarden 0.3s la gente verá un fondo nocturno no blanco roto */
}

.cc-blog-card__cover {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.8s cubic-bezier(0.175, 0.885, 0.32, 1.275);
	opacity: 0.95;
}

.cc-blog-card:hover .cc-blog-card__cover {
	transform: scale(1.1); /* Efecto cinemático sutil de ampliación en el Header */
	opacity: 1;
}

.cc-blog-card__cover-fallback {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, var(--cc-color-dark), var(--cc-color-primary));
}

.cc-blog-card__badge {
	position: absolute;
	bottom: var(--cc-spacing-md);
	right: var(--cc-spacing-md);
	background: var(--cc-gradient-primary);
	color: var(--cc-color-white);
	padding: 6px 16px;
	border-radius: var(--cc-radius-full);
	font-size: 0.75rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 1px;
	box-shadow: 0 4px 10px rgba(0,0,0,0.3);
}

/* CARDS CONTENIDO TEXTUAL */
.cc-blog-card__body {
	padding: var(--cc-spacing-2xl);
	display: flex;
	flex-direction: column;
	flex-grow: 1;
}

.cc-blog-card__time {
	display: flex;
	align-items: center;
	gap: 6px;
	color: var(--cc-color-primary);
	font-size: 0.85rem;
	font-weight: 800;
	margin-bottom: var(--cc-spacing-sm);
	letter-spacing: 0.5px;
}

.cc-blog-card__title {
	font-size: 1.35rem;
	font-weight: 800;
	line-height: 1.25;
	margin-bottom: var(--cc-spacing-md);
}

.cc-blog-card__title a {
	color: var(--cc-color-dark);
	text-decoration: none;
	transition: color var(--cc-transition-fast);
}

.cc-blog-card__title a:hover {
	color: var(--cc-color-secondary);
}

.cc-blog-card__excerpt {
	color: var(--cc-color-gray-600);
	font-size: 1rem;
	line-height: 1.6;
	margin-bottom: var(--cc-spacing-xl);
}

/* El gatillo de Inversión / Leer Mas interactivo */
.btn-read-more {
	margin-top: auto;
	display: inline-flex;
	align-items: center;
	font-weight: 800;
	color: var(--cc-color-dark);
	text-transform: uppercase;
	font-size: 0.85rem;
	letter-spacing: 1.5px;
	text-decoration: none;
	transition: color var(--cc-transition-fast);
}

.btn-read-more .arrow {
	margin-left: 8px;
	font-size: 1.3rem;
	line-height: 0;
	transition: transform var(--cc-transition-fast);
}

.btn-read-more:hover {
	color: var(--cc-color-primary); /* Al tocar la tarjeta, el texto muta de negro a magenta the agency */
}

.btn-read-more:hover .arrow {
	transform: translateX(8px); /* La flecha te invita y "empuja" al proximo clic */
}

/* Célula Móvil Ajustes Críticos */
@media (max-width: 600px) {
	.cc-blog-card {
		flex: 0 0 85vw; /* Asomo horizontal sutil para enseñar el slider. En móvil ocupa el 85% y asoma el segundo elemento. */
		scroll-snap-align: center;
	}
	.cc-blog-carousel {
		padding: var(--cc-spacing-xl) 5vw;
	}
}

/* ==========================================================================
   26. FAQs ACORDEON (PREGUNTAS FRECUENTES)
   ========================================================================== */
.section--faqs {
	padding: 0 0 var(--cc-spacing-5xl) 0; /* Padding top nulo porque la placa header asumirá el contorno visual */
}

/* Placa estétita color Arena / Beish */
.faqs-header {
	background-color: #f6efe8; /* Color Crema/Arena derivado de tu mockup corporativo */
	padding: var(--cc-spacing-4xl) 0;
	margin-bottom: var(--cc-spacing-4xl);
}

.faqs-header__container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--cc-spacing-2xl);
}

.faqs-header__left {
	flex: 1.2;
}

.faqs-header__title {
	font-size: clamp(1.8rem, 2.5vw, 2.6rem);
	font-weight: 800;
	color: var(--cc-color-dark);
	line-height: 1.2;
	letter-spacing: -1px;
}

.faqs-header__center {
	flex: 0.5;
	text-align: center;
}

/* El elemento decorativo inclinado /// */
.faqs-header__decoration {
	font-size: 2rem;
	font-weight: 300;
	color: rgba(0, 0, 0, 0.1); /* Silueta ultra fina fantasma */
	letter-spacing: 5px;
	font-style: italic;
	user-select: none;
}

.faqs-header__right {
	flex: 1;
	text-align: right;
}

.faqs-header__text {
	font-size: 1.05rem;
	line-height: 1.6;
	color: var(--cc-color-gray-700);
}

/* Contenedor del Acordeón Mágico HTML5 */
.faqs-accordion {
	max-width: 900px;
	margin: 0 auto;
}

.faq-item {
	border-top: 1px solid var(--cc-color-gray-200); /* Delgadas líneas divisorias */
}

.faq-item:last-child {
	border-bottom: 1px solid var(--cc-color-gray-200);
}

.faq-item__question {
	padding: var(--cc-spacing-xl) 0;
	font-weight: 700;
	font-size: 1.15rem;
	color: var(--cc-color-dark);
	cursor: pointer;
	list-style: none; /* Anula el viejo icono triangular de Safari/Chrome nativo */
	position: relative;
	transition: color var(--cc-transition-fast);
}

/* Forzar en navegadores base esconder la flechita */
.faq-item__question::-webkit-details-marker {
	display: none;
}

.faq-item__question:hover {
	color: var(--cc-color-primary); /* Encender titulo en color Magenta */
}

/* Indicador UX Matemático (+ y -) a la derecha */
.faq-item__question::after {
	content: '+';
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	font-size: 1.6rem;
	color: var(--cc-color-gray-400);
	transition: transform 0.3s ease, color 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

/* Reacción fluida al dar clic usando puramente lógica selectora [open] HTML5 */
.faq-item[open] .faq-item__question::after {
	content: '−'; /* El menos verdadero más nítido (Minus sign) */
	color: var(--cc-color-primary);
	transform: translateY(-50%) rotate(180deg);
}

.faq-item__answer {
	padding-bottom: var(--cc-spacing-xl);
	padding-right: var(--cc-spacing-3xl); /* Dejar espacio para no chocar con el icono derecho +- */
	color: var(--cc-color-gray-600);
	font-size: 1.05rem;
	line-height: 1.7;
	animation: accordionSlideDown 0.35s ease-out backwards; /* Despliegue de cortina suave */
}

.faq-item__answer strong {
	color: var(--cc-color-dark);
}

/* Responsivo para el Acordeón y el Header Extra-ancho */
@media (max-width: 992px) {
	.faqs-header__container {
		flex-direction: column;
		text-align: center;
	}
	.faqs-header__right {
		text-align: center;
	}
	.faqs-header__center {
		display: none; /* Ocultando el '////' porque hace ruido visual en un celular pequeño */
	}
}

@keyframes accordionSlideDown {
	from { opacity: 0; transform: translateY(-10px); }
	to { opacity: 1; transform: translateY(0); }
}

/* ==========================================================================
   25. ANNIVERSARY POPUP (ENTERPRISE MODAL)
   ========================================================================== */
.cc-anniversary-popup {
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 999999;
	opacity: 0;
	pointer-events: none;
	visibility: hidden;
	transition: opacity 0.5s ease, visibility 0.5s ease;
}

.cc-anniversary-popup.is-active {
	opacity: 1;
	pointer-events: all;
	visibility: visible;
}

/* Oscurecimiento y Blur al fondo estilo cristal Premium */
.cc-anniversary-popup__overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(10, 15, 30, 0.7);
	backdrop-filter: blur(6px);
}

.cc-anniversary-popup__content {
	position: relative;
	background: var(--cc-color-white);
	width: 90%;
	max-width: 500px;
	padding: var(--cc-spacing-4xl) var(--cc-spacing-3xl);
	border-radius: var(--cc-radius-xl);
	box-shadow: 0 40px 60px -15px rgba(0, 0, 0, 0.5);
	text-align: center;
	transform: translateY(30px) scale(0.95);
	transition: transform 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275); /* Efecto pop elástico vertical */
	border: 1px solid rgba(255, 255, 255, 0.2);
	box-sizing: border-box; /* Previene el desbordamiento provocado por el padding giga */
}

@media (max-width: 768px) {
	.cc-anniversary-popup__content {
		padding: var(--cc-spacing-2xl) var(--cc-spacing-lg); /* Compresión milimétrica para móviles */
		width: 92%;
	}
	.cc-anniversary-popup__title {
		font-size: 2rem;
	}
	.cc-anniversary-popup__title .text-gradient {
		font-size: 2.2rem;
	}
	.cc-anniversary-popup__text {
		font-size: 0.95rem;
		padding: 0 5px;
	}
}

.cc-anniversary-popup.is-active .cc-anniversary-popup__content {
	transform: translateY(0) scale(1);
}

.cc-anniversary-popup__close {
	position: absolute;
	top: var(--cc-spacing-lg);
	right: var(--cc-spacing-lg);
	background: rgba(0,0,0,0.05); /* Botón suave */
	border: none;
	color: var(--cc-color-gray-600);
	cursor: pointer;
	padding: 8px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background var(--cc-transition-fast), color var(--cc-transition-fast), transform var(--cc-transition-fast);
}

.cc-anniversary-popup__close:hover {
	background: var(--cc-color-gray-200);
	color: var(--cc-color-dark);
	transform: rotate(90deg); /* Micro-interacción rotativa de UX */
}

.cc-anniversary-popup__badge {
	display: inline-block;
	background: var(--cc-gradient-primary);
	color: var(--cc-color-white);
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 2px;
	padding: 8px 20px;
	border-radius: var(--cc-radius-full);
	font-size: var(--cc-font-size-xs);
	margin-bottom: var(--cc-spacing-xl);
	box-shadow: var(--cc-shadow-glow);
}

.cc-anniversary-popup__title {
	font-size: var(--cc-font-size-3xl);
	font-weight: 900;
	color: var(--cc-color-dark);
	margin-bottom: var(--cc-spacing-lg);
	line-height: 1.1;
}

.cc-anniversary-popup__text {
	font-size: 1.15rem;
	color: var(--cc-color-gray-600);
	line-height: 1.6;
	margin-bottom: var(--cc-spacing-2xl);
	padding: 0 var(--cc-spacing-md);
}

/* ==========================================================================
   25.1. FLOATING PARTY BUTTON (TRIGGER)
   ========================================================================== */
.cc-anniversary-floating-btn {
	position: fixed;
	bottom: 24px; /* Pegado casi tocando la base */
	left: 24px; /* Anclado 100% al lado izquierdo */
	width: 64px;
	height: 64px;
	background: linear-gradient(135deg, var(--cc-color-white) 15%, var(--cc-color-secondary) 120%); /* Difuminado magistral de Blanco a Naranja Corporativo */
	border: 1px solid rgba(255, 152, 0, 0.4); /* Anillo muy sutil para proteger los bordes blancos */
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	z-index: 999998;
	box-shadow: 0 10px 25px rgba(233, 30, 99, 0.4);
	transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.cc-anniversary-floating-btn:hover {
	transform: scale(1.15) rotate(-5deg); /* Crece con la presión magnética del hover */
}

/* Pseudo elementos: Los "cañones" ocultos que escupen el confeti */
.cc-anniversary-floating-btn::before,
.cc-anniversary-floating-btn::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: transparent;
	z-index: -1;
	pointer-events: none;
	transform: translate(-50%, -50%);
}

.cc-anniversary-floating-btn::before {
	animation: fireworks-burst-a 2.5s cubic-bezier(0.25, 1, 0.5, 1) infinite;
}

.cc-anniversary-floating-btn::after {
	animation: fireworks-burst-b 2.5s cubic-bezier(0.25, 1, 0.5, 1) infinite;
	animation-delay: 1.25s; /* Disparo B retrasado para llenar de partículas la pantalla */
}

/* El interior del boton (emoji de festejo) */
.cc-party-icon {
	font-size: 32px;
	line-height: 1;
	display: inline-block;
	animation: party-wiggle-icon 4s ease-in-out infinite; /* El emoji sigue bailando sutilmente adentro */
	filter: drop-shadow(0 2px 4px rgba(0,0,0,0.3));
}

/* Explosión de Confetis y Cotillón Grupo A */
@keyframes fireworks-burst-a {
	0% {
		box-shadow: 0 0 0 0 #ff007f, 0 0 0 0 #ff9900, 0 0 0 0 #00e5ff, 0 0 0 0 #ff007f, 0 0 0 0 #ff9900, 0 0 0 0 #00e5ff;
		opacity: 1;
	}
	100% {
		/* Dispara 6 partículas geométricas hacia el perímetro */
		box-shadow: 
			-40px -40px 0 2px #ff007f, 
			40px -50px 0 3px #ff9900, 
			60px -10px 0 1px #00e5ff, 
			30px 40px 0 2px #ff007f,
			-10px 60px 0 1px #ff9900,
			-50px 20px 0 2px #00e5ff;
		opacity: 0;
	}
}

/* Explosión de Confetis y Cotillón Grupo B (Direcciones Inversas) */
@keyframes fireworks-burst-b {
	0% {
		box-shadow: 0 0 0 0 #00e5ff, 0 0 0 0 #ff007f, 0 0 0 0 #ff9900, 0 0 0 0 #00e5ff, 0 0 0 0 #ff007f, 0 0 0 0 #ff9900;
		opacity: 1;
	}
	100% {
		/* Dispara otras 6 partículas en rutas alternas cubriendo el botón */
		box-shadow: 
			0px -60px 0 1px #00e5ff, 
			50px 20px 0 3px #ff007f, 
			50px -30px 0 2px #ff9900, 
			0px 60px 0 1px #00e5ff,
			-40px 40px 0 2px #ff007f,
			-60px -20px 0 2px #ff9900;
		opacity: 0;
	}
}

/* Matemáticas del Sismo interno en el icono */
@keyframes party-wiggle-icon {
	0%, 80%, 100% { transform: rotate(0) scale(1); }
	85% { transform: rotate(-15deg) scale(1.15); }
	90% { transform: rotate(15deg) scale(1.15); }
	95% { transform: rotate(-10deg) scale(1.15); }
}

/* ==========================================================================

   23. ANIMACIONES
   ========================================================================== */
@keyframes float {
	0%, 100% { transform: translate(0, 0); }
	50% { transform: translate(20px, -20px); }
}

@keyframes bounce {
	0%, 100% { transform: translateX(-50%) translateY(0); }
	50% { transform: translateX(-50%) translateY(10px); }
}

@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(30px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Animate on scroll */
[data-animate] {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.6s ease, transform 0.6s ease;
}

[data-animate].animated {
	opacity: 1;
	transform: translateY(0);
}

/* ==========================================================================
   22. NO RESULTS
   ========================================================================== */
.no-results {
	padding: var(--cc-spacing-5xl) 0;
	text-align: center;
}

.no-results__title {
	font-size: var(--cc-font-size-2xl);
	margin-bottom: var(--cc-spacing-md);
}

.no-results__body {
	max-width: 500px;
	margin: 0 auto;
	color: var(--cc-color-gray-600);
}

/* ==========================================================================
   23. RESPONSIVE
   ========================================================================== */

/* Tablet */
@media (max-width: 1024px) {
	.services-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.portfolio-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* Mobile */
@media (max-width: 768px) {
	:root {
		--cc-header-height: 70px;
	}

	.container {
		padding-left: var(--cc-spacing-md);
		padding-right: var(--cc-spacing-md);
	}

	/* Mobile Navigation & Whatsapp UI Asimétrico */
	.site-header__container {
		gap: 0;
	}

	.site-header__whatsapp {
		flex: 1;
		display: flex !important; /* Fuerza la reactivación anulando el estado inactivo de escritorio */
		justify-content: flex-end; /* Alinea asimétricamente el logo a la Izquierda y Menu/CTA a la Derecha */
		margin: 0 var(--cc-spacing-md);
	}

	.btn-wa-header {
		padding: 10px; /* Tamaño de pulsación táctil (Touch Target) */
		border-radius: 50%; /* UI App-Like Circular */
		background: #25D366; /* Color Oficial WhatsApp */
		color: white;
		display: flex;
		align-items: center;
		justify-content: center;
		box-shadow: 0 4px 10px rgba(37, 211, 102, 0.3);
	}

	.btn-wa-header__text {
		display: none; /* Ahorra mucho espacio, prevaleciendo iconografía */
	}

	.menu-toggle {
		display: flex;
	}

	.nav__wrapper {
		position: fixed;
		top: var(--cc-header-height);
		left: 0;
		right: 0;
		height: calc(100vh - var(--cc-header-height)); /* Altura contundente forzada */
		background: #ffffff; /* Color sólido forzado para evitar superposición fallida del z-index */
		padding: var(--cc-spacing-md);
		transform: translateX(100%);
		transition: transform var(--cc-transition-base);
		overflow-y: auto;
		overflow-x: hidden;
		z-index: 99999; /* Máxima precedencia posible */
	}

	.nav__wrapper.toggled {
		transform: translateX(0);
	}

	.nav__list {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		width: 100%;
	}

	.nav__link {
		padding: var(--cc-spacing-md) 0;
		font-size: var(--cc-font-size-md);
		font-weight: 600;
		color: var(--cc-color-gray-800);
		border-bottom: 1px solid var(--cc-color-gray-100);
		border-radius: 0;
		text-align: left;
		display: block;
		width: 100%;
	}

	.nav__link::after {
		display: none;
	}

	/* Mobile: Submenú estándar */
	.nav__submenu {
		position: static;
		box-shadow: none;
		opacity: 1;
		visibility: visible;
		transform: none;
		padding-left: var(--cc-spacing-lg);
	}

	/* Mobile: Mega Menú Acordeón */
	.mega-menu {
		position: static;
		box-shadow: none;
		border-top: none;
		background: transparent;
		max-height: 0;
		overflow: hidden;
		opacity: 0;
		visibility: hidden;
		transition: max-height var(--cc-transition-slow), opacity var(--cc-transition-base), visibility var(--cc-transition-base);
		transform: none;
		padding: 0;
	}

	.nav__item--mega.is-open > .mega-menu {
		display: block;
		max-height: 2000px;
		opacity: 1;
		visibility: visible;
		margin-top: var(--cc-spacing-sm);
	}

	.mega-menu__container {
		padding: 0 0 0 var(--cc-spacing-lg);
		border-left: 2px solid rgba(233, 30, 99, 0.15); /* Indentación visual */
		margin-left: var(--cc-spacing-sm);
	}

	.mega-menu__section-items {
		grid-template-columns: 1fr;
		gap: var(--cc-spacing-xs);
	}

	.mega-menu__section {
		border-bottom: none;
		padding-bottom: var(--cc-spacing-md);
	}

	.mega-menu__section-title {
		font-size: var(--cc-font-size-xs);
		color: var(--cc-color-primary);
		margin-bottom: var(--cc-spacing-xs);
	}

	.mega-menu__item {
		padding: var(--cc-spacing-sm);
		background: transparent;
		border: none;
		border-radius: var(--cc-radius-sm);
	}

	.mega-menu__item:hover,
	.mega-menu__item:active {
		background: rgba(233, 30, 99, 0.05); /* Tap feedback */
		transform: none;
		box-shadow: none;
	}

	.mega-menu__item-icon {
		width: 32px;
		height: 32px;
	}

	.mega-menu__item-icon svg {
		width: 16px;
		height: 16px;
	}

	.mega-menu__item-desc {
		display: none;
	}

	.mega-menu-overlay {
		display: none; /* Desactivado en móvil */
	}

	/* Mobile: Nav arrow interaction */
	.nav__item--mega > .nav__link {
		display: flex;
		justify-content: space-between;
		align-items: center;
		width: 100%;
	}

	.nav__item--mega.is-open > .nav__link {
		color: var(--cc-color-primary);
		background: transparent;
	}

	.nav__item--mega.is-open .nav__arrow {
		transform: rotate(180deg);
		color: var(--cc-color-primary);
	}

	.site-header__cta {
		display: none;
	}

	/* Grids */
	.services-grid,
	.portfolio-grid,
	.testimonials-grid,
	.posts-grid {
		grid-template-columns: 1fr;
	}

	.footer-grid {
		grid-template-columns: 1fr;
	}

	.site-footer__bottom-inner {
		flex-direction: column;
		text-align: center;
	}

	/* Post Navigation */
	.post-navigation .nav-links {
		grid-template-columns: 1fr;
	}

	/* Hero */
	.hero {
		min-height: 80vh;
	}

	.hero__actions {
		flex-direction: column;
		align-items: center;
	}

	/* Section */
	.section {
		padding: var(--cc-spacing-3xl) 0;
	}
}

/* Small Mobile */
@media (max-width: 480px) {
	.posts-grid {
		grid-template-columns: 1fr;
	}

	.portfolio-grid {
		grid-template-columns: 1fr;
	}

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

/* ==========================================================================
   24. PRINT
   ========================================================================== */
@media print {
	.site-header,
	.site-footer,
	.menu-toggle,
	.hero__scroll-indicator,
	.post-navigation,
	.social-links,
	.cusco-pagination,
	.comments-area {
		display: none !important;
	}

	body {
		font-size: 12pt;
		color: #000;
		padding-top: 0;
	}

	.container {
		max-width: 100%;
	}

	a {
		color: #000;
		text-decoration: underline;
	}
}

/* ==========================================================================
   GLOBAL FIX: PADDING PARA SUB-LANDINGS (EVITA CHOQUE CON HEADER)
   ========================================================================== */
body:not(.home) .site-main > section:first-child:not(.svc-hero-v2):not(.hero):not(.page-nosotros):not(.ai-hero):not(.social-hero) {
	padding-top: calc(var(--cc-header-height, 100px) + 50px) !important;
}

/* ==========================================================================
   28. PAGE: DISEÑO WEB (LANDING SERVICE)
   ========================================================================== */
.page-diseno-web {
	background: var(--cc-color-white);
}

/* 1. HERO SERVICE V2 (REDESIGN PREMIUM) */
.svc-hero-v2 {
	background-color: #f7f8fa; /* El gris pálido exacto del tono de fondo escandinavo de tu referente */
	position: relative;
	/* Eliminamos min-height y flex centering que causan el guillotinazo invertido */
	display: block;
	
	/* Destrucción del 'Espacio en Blanco' del sistema Core jalando el gris hacia arriba */
	margin-top: calc(var(--cc-header-height, 100px) * -1); 
	/* Añadimos padding sumado artificial para simular el centering protegiendo la cabecera */
	padding-top: calc(var(--cc-header-height, 100px) + 80px);
	padding-bottom: 100px;
	box-sizing: border-box;
}

/* ONDAS PARABÓLICAS SVG DECORATIVAS */
.svc-hero-v2__bg-lines {
	position: absolute;
	top: 50%;
	right: -10%;
	width: 60%;
	height: 150%;
	transform: translateY(-50%);
	pointer-events: none;
	z-index: 1;
	opacity: 0.8;
}

.svc-hero-v2__container {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--cc-spacing-4xl);
	align-items: center;
	position: relative;
	z-index: 2;
}

/* Titular Denso */
.svc-hero-v2__title {
	font-size: clamp(3.2rem, 5vw, 4.5rem);
	font-weight: 900;
	line-height: 1.05;
	color: #1f2937; /* Tono asfalto apagado corporativo */
	margin-bottom: var(--cc-spacing-md);
	letter-spacing: -2px;
}

.svc-hero-v2__text {
	font-size: 1.15rem;
	color: var(--cc-color-gray-600);
	line-height: 1.6;
	margin-bottom: var(--cc-spacing-3xl);
	max-width: 90%;
}

/* EL FAMOSO FORMULARIO 'PILL' CTA */
.svc-hero-v2__pill-cta {
	display: flex;
	align-items: center;
	background: var(--cc-color-white);
	border-radius: 60px;
	padding: 12px 12px 12px 30px;   /* Mayor padding para que respire la bandera */
	box-shadow: 0 15px 35px rgba(0,0,0,0.05); /* Sombra elegante, no negra total */
	max-width: 580px; /* Más ancho para alojar prefijo + numero */
	transition: box-shadow var(--cc-transition-base);
}

.svc-hero-v2__pill-cta:focus-within {
	box-shadow: 0 20px 40px rgba(233, 30, 99, 0.15); /* Al escribir, brilla sutilmente en magenta */
}

.pill-cta__input-group {
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.pill-cta__input-group label {
	font-size: 0.75rem;
	text-transform: uppercase;
	font-weight: 800;
	color: var(--cc-color-gray-400);
	margin-bottom: 2px;
	letter-spacing: 0.5px;
	cursor: text;
}

/* CAJA DE TELEFONO (+51 + INPUT) */
.pill-cta__input-wrapper {
	display: flex;
	align-items: center;
	gap: 6px;
}

.country-code {
	font-size: 1.15rem;
	font-weight: 900;
	color: var(--cc-color-dark);
	border-right: 2px solid var(--cc-color-gray-200);
	padding-right: 8px;
	user-select: none;
}

.pill-cta__input-group input {
	border: none;
	outline: none;
	font-size: 1.15rem;
	font-weight: 700;
	color: var(--cc-color-dark);
	background: transparent;
	width: 100%;
	padding: 2px 0; /* Alineación milimétrica con el texto de código regional */
}

.pill-cta__input-group input::placeholder {
	color: var(--cc-color-gray-300);
	font-weight: 500;
	letter-spacing: 1px; /* Estética de números bien separados */
}

.pill-cta__btn {
	border-radius: 50px;
	padding: 14px 34px;
	font-size: 1rem;
	font-weight: 900;
	white-space: nowrap;
	border: none;
	background: var(--cc-gradient-primary); /* Magenta Corporativo Radiante */
	color: white;
	cursor: pointer;
	box-shadow: 0 5px 15px rgba(233, 30, 99, 0.35); /* Sombra Cusco Creativos */
	transition: background var(--cc-transition-base), transform var(--cc-transition-base), box-shadow var(--cc-transition-base);
}

.pill-cta__btn:hover {
	background: var(--cc-gradient-secondary); /* Hover Amarillo/Naranja Corporativo */
	transform: scale(1.04);
	color: var(--cc-color-dark); /* Máximo contraste corporativo al volver a amarillo */
	box-shadow: 0 10px 25px rgba(243, 195, 0, 0.4);
}

/* FOTOGRAFIA Y BURBUJAS (LADO DERECHO) */
.svc-hero-v2__image {
	position: relative;
	display: flex;
	justify-content: center;
}

.image-wrapper {
	position: relative;
	max-width: 550px;
	width: 100%;
}

/* Mezclador Mágico: Si la foto de chica teine un fondo blanco-grisacio, multiply borrará el límite creando un recorte perfecto en CSS puro sin recortes lentos JS */
.main-portrait {
	width: 100%;
	height: auto;
	filter: contrast(1.05) saturate(1.1); /* Efectos de luz correctiva del modelo */
	mix-blend-mode: multiply;   
}

/* AVATARES FLOTANTES (EFECTO ESPACIAL) */
.float-bubble {
	position: absolute;
	border-radius: 50%;
	border: 5px solid var(--cc-color-white);
	box-shadow: 0 15px 30px rgba(0,0,0,0.1);
	overflow: hidden;
	background: var(--cc-color-gray-100);
	animation: floatingAvatars 8s ease-in-out infinite;
	z-index: 4;
}

.float-bubble img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Configurando constelaciones y desfases milimetricos para no aparentar mecánica simetrica aburrida */
.fb-1 { width: 70px; height: 70px; top: 10%; left: -6%; animation-delay: 0s; }
.fb-2 { width: 50px; height: 50px; top: 45%; left: -12%; animation-delay: 2s; }
.fb-3 { width: 85px; height: 85px; top: 25%; right: 5%; animation-delay: 4.5s; }

@keyframes floatingAvatars {
	0% { transform: translateY(0) rotate(0); }
	50% { transform: translateY(-18px) rotate(3deg); }
	100% { transform: translateY(0) rotate(0); }
}

@media (max-width: 992px) {
	.svc-hero-v2 {
		height: auto; /* Desactivar 80vh en celular para evitar aplastamientos cuando colapsan ambos div */
		padding: calc(var(--cc-header-height, 80px) + var(--cc-spacing-2xl)) 0 var(--cc-spacing-4xl); /* Mantiene el empuje estructural sin revivir el espacio en blanco */
	}
	.svc-hero-v2__container {
		grid-template-columns: 1fr;
		text-align: center;
	}
	.svc-hero-v2__text {
		margin: 0 auto 30px;
	}
	
	/* Transmutación a Bloque Vertical del Formulario */
	.svc-hero-v2__pill-cta {
		margin: 0 auto 30px auto;
		flex-direction: column;
		border-radius: 24px;
		padding: 30px;
		gap: var(--cc-spacing-md);
		border: 1px solid var(--cc-color-gray-100);
	}
	.pill-cta__input-group {
		width: 100%;
		text-align: left;
	}
	.pill-cta__input-wrapper {
		justify-content: flex-start;
		padding: 5px 0;
		width: 100% !important;
	}
	.pill-cta__input-group input {
		width: 100% !important;
	}
	.pill-cta__btn {
		width: 100%;
		border-radius: 12px;
		padding: 16px;
	}

	.svc-hero-v2__bg-lines {
		width: 150%;
		right: -25%;
		height: 100%;
		top: 30%;
	}
}

/* 2. POR QUE ELEGIR (LISTAS CON AROS RADIANTES) */
.svc-why {
	padding: var(--cc-spacing-2xl) 0; /* Compactado a pedido del cliente */
	background: var(--cc-color-white);
}

/* Margen inferior compacto para la cabecera de la sección */
.svc-why .section__header {
	margin-bottom: var(--cc-spacing-md);
}

.svc-why__grid {
	display: grid;
	grid-template-columns: 1fr 400px 1fr;
	gap: var(--cc-spacing-2xl); /* Acercamiento de las columnas hacia la imagen */
	align-items: center;
	margin-top: 0; /* Choque de margen corregido para unir el título a la cuadrícula */
}
.svc-why__center-img img {
	width: 100%;
	border-radius: var(--cc-radius-xl);
	box-shadow: 0 10px 30px rgba(0,0,0,0.1);
}
.svc-list {
	list-style: none;
	padding: 0;
	margin: 0;
}
.svc-list li {
	display: flex;
	align-items: flex-start;
	margin-bottom: var(--cc-spacing-xl);
	gap: 15px;
}
.left-side .svc-list li {
	text-align: right;
	justify-content: flex-end;
}
.svc-list__icon {
	flex-shrink: 0;
	width: 24px;   height: 24px;
	border: 6px solid var(--cc-color-secondary);
	border-radius: 50%;
	margin-top: 4px;
	box-shadow: inset 0 0 0 2px var(--cc-color-white); /* Efecto Anillo Hueco (Ring Point) */
	background: var(--cc-color-secondary);
}
.svc-list__text {
	font-size: 1rem;
	color: var(--cc-color-gray-700);
	font-weight: 500;
	line-height: 1.5;
}
@media (max-width: 1024px) {
	.svc-why__grid { grid-template-columns: 1fr; text-align: center; }
	.left-side .svc-list li, .right-side .svc-list li { text-align: left; justify-content: flex-start; }
	.left-side .svc-list__icon { order: -1; }
	.svc-why__center-img { max-width: 400px; margin: 0 auto; order: -1; }
}

/* 3. TIMELINE DE DESARROLLO (SCROLL JACKING HORIZONTAL) */
.svc-process {
	/* La altura excesiva es intencional: Al bajar por ella, un JS transmutará esa longitud vertical en movimiento horizontal limpio */
	background: #f9fafb;
}

/* Base móvil y configuraciones iniciales que no cambian */
.timeline-window {
	width: 100%;
	overflow: hidden; /* Cortamos la visualización excesiva derecha horizontal */
}
.timeline {
	position: relative;
	margin: 0 auto;
	display: flex;
	flex-direction: column; /* Forzamos explícitamente el apilamiento vertical móvil */
	gap: var(--cc-spacing-xl);
}

.timeline__item {
	position: relative;
	width: 100%;
	padding: 0 0 30px 80px; 
}
.timeline__item.left, .timeline__item.right { left: auto; text-align: left; }

/* En móvil, la línea vertical (el pipeline clásico que amabas) */
.timeline__item::before {
	content: '';
	position: absolute;
	top: 0; bottom: 0; left: 30px; 
	width: 0; 
	border-top: none; 
	border-left: 2px dashed rgba(0,0,0,0.15); 
	height: auto;
	z-index: 1;
}

/* Nodos conectores */
.timeline__node {
	position: absolute;
	width: 48px; height: 48px;
	top: 0; left: 6px;
	background: var(--cc-color-primary);
	border-radius: 12px;
	box-shadow: 0 5px 15px rgba(0,0,0,0.15);
	display: flex; align-items: center; justify-content: center;
	color: white; z-index: 2;
}

/* Barra de Progreso Inferior */
.cc-progress-wrap { margin-top: var(--cc-spacing-lg); display: none; /* Inútil en teléfonos */ }
.timeline-progress {
	height: 6px;
	background: var(--cc-color-gray-200);
	border-radius: 4px;
	width: 100%;
	overflow: hidden;
	position: relative;
}
.timeline-progress-bar {
	height: 100%;
	width: 0%; /* Será controlado por el JS nativo */
	background: var(--cc-gradient-primary);
	border-radius: 4px;
}

/* Controladores Tácticos de Color */
.bg-yellow { background: #f3c300 !important; }
.bg-orange { background: #f47c36 !important; }
.bg-orange-dark { background: #d35400 !important; }
.bg-magenta { background: #e91e63 !important; }
.bg-purple { background: #b02a87 !important; }

.timeline__content {
	background: var(--cc-color-white);
	padding: var(--cc-spacing-lg);
	border-radius: var(--cc-radius-lg);
	box-shadow: var(--cc-shadow-sm);
	border: 1px solid var(--cc-color-gray-100);
	transition: transform var(--cc-transition-base), box-shadow var(--cc-transition-base);
}
.timeline__content h3 { font-size: 1.05rem; font-weight: 800; margin-bottom: 12px; color: var(--cc-color-dark); }
.timeline__content p { font-size: 0.9rem; color: var(--cc-color-gray-600); line-height: 1.5; margin: 0; }

/* =======================================================
   OVERRIDE PARA ESCRITORIO (LA MAGIA STICKY OCURRE ACÁ) 
   ======================================================= */
@media (min-width: 993px) {
	.svc-process {
		height: 300vh; /* Requiere scrollear 3 pantallas de longitud para salir de la fase */
		padding: 0; 
	}
	
	.svc-process__sticky-wrapper {
		position: sticky;
		top: 0; /* Al llegar a la esquina superior del monitor, se PEGA como goma */
		height: 100vh;
		display: flex;
		flex-direction: column;
		justify-content: center;
		overflow: hidden;
	}

	.section__header-sticky {
		margin-bottom: var(--cc-spacing-md);
	}
	
	/* Neutraliza el margen global de la cabecera adentro del wrapper */
	.section__header-sticky .section__header {
		margin-bottom: 0;
	}

	.timeline {
		width: max-content; /* Se expande lateralmente hasta el infinito necesario */
		flex-direction: row; /* Reactiva el pipeline secuencial horizontal */
		flex-wrap: nowrap;
		will-change: transform; /* Preparar tarjeta aceleradora gráfica para deslizado fluido */
		padding: 0 10vw; /* Padding para que el final no choque pared en seco */
		align-items: stretch;
	}

	.cc-progress-wrap {
		display: block; /* Se reactiva la barra roja inferior */
	}

	.timeline__item {
		flex: 0 0 400px; /* Más ancho genera menos altura de texto */
		padding: 60px 0 0 0; /* Menos espacio entre nodo y caja */
		text-align: center;
	}
	.timeline__item.left, .timeline__item.right { text-align: center; }
	
	/* Invertimos matriz para trazar línea horizontal */
	.timeline__item::before {
		top: 23px; /* Exactamente a la mitad del nodo (48px / 2 - 1) */
		left: 0;
		width: 100%;
		border-left: none;
		border-top: 2px dashed rgba(0,0,0,0.15);
		height: 0;
	}
	
	.timeline__node {
		top: 0;
		left: 50%;
		transform: translateX(-50%);
	}
	
	.timeline__content { height: 100%; }
	.timeline__content:hover {
		transform: translateY(-5px);
		box-shadow: var(--cc-shadow-md);
	}
}

/* 4. TABLAS DE PRECIOS VINTAGE-MODERNO (GRID DE 4 CILINDROS) */
.svc-pricing {
	padding: var(--cc-spacing-2xl) 0;
	background: var(--cc-color-white);
}

.svc-pricing .section__header, 
.svc-pricing .section__title {
	margin-bottom: 0 !important; /* Eliminador forzado de márgenes bootstrap tipo mb-5 o globales */
}

.pricing-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--cc-spacing-xl);
	margin-top: var(--cc-spacing-xl); /* Acercamiento dramático al título principal */
	align-items: flex-end;
}
.pricing-card {
	background: var(--cc-color-white);
	border-radius: var(--cc-radius-xl);
	box-shadow: var(--cc-shadow-md);
	overflow: hidden;
	transition: transform var(--cc-transition-base);
	border: 1px solid var(--cc-color-gray-100);
}
.pricing-card:hover { box-shadow: var(--cc-shadow-2xl); transform: translateY(-5px); }
.pricing-card.featured { transform: scale(1.05); z-index: 2; box-shadow: 0 20px 40px rgba(0,0,0,0.15); border-color: transparent; }
.pricing-card.featured:hover { transform: scale(1.05) translateY(-5px); }

/* Las Cabeceras de Color y Numerales */
.pricing-card__head { color: white; padding: var(--cc-spacing-2xl) var(--cc-spacing-xl); display: flex; flex-direction: column; justify-content: center; text-align: center; }
.pricing-card__head .price { font-size: 3.5rem; font-weight: 900; line-height: 1; margin-bottom: 5px; }
.pricing-card__head .price span { font-size: 1.5rem; vertical-align: super; }
.pricing-card__head .advance { font-size: 0.75rem; font-style: italic; opacity: 0.9; }

.pricing-card__title { font-size: 1.4rem; font-weight: 800; padding: var(--cc-spacing-lg) 0; margin: 0; background: var(--cc-color-gray-50); border-bottom: 1px solid var(--cc-color-gray-200); text-align: center; }

/* Características Individuales Checkeadas */
.pricing-card__features { list-style: none; margin: 0; padding: var(--cc-spacing-lg) var(--cc-spacing-xl); font-size: 0.85rem; text-align: left; }
.pricing-card__features li { padding: 8px 0; border-bottom: 1px solid var(--cc-color-gray-100); color: var(--cc-color-gray-700); position: relative; padding-left: 20px; }
.pricing-card__features li::before { content: '✓'; color: currentColor; font-weight: 900; position: absolute; left: 0; font-size: 0.9rem; }
.pricing-card__features li:last-child { border: none; }

/* Responsive del Tarifario */
@media (max-width: 1200px) { 
	.pricing-grid { grid-template-columns: repeat(2, 1fr); align-items: stretch; } 
	.pricing-card.featured { transform: scale(1); } 
	.pricing-card.featured:hover { transform: translateY(-5px); } 
}
@media (max-width: 600px) { 
	.pricing-grid { grid-template-columns: 1fr; } 
}
