/**
 * Okidi - Custom CSS
 * Compartido por todas las páginas custom (home, servicios, etc.)
 */

/* ========== Smooth scroll ========== */
html {
	scroll-behavior: smooth;
}

/* ========== Header navigation - desktop/mobile ========== */
.okidi-desktop-nav {
	display: flex !important;
}

.okidi-mobile-only {
	display: none !important;
}

.okidi-mobile-nav-closed {
	display: none !important;
}

.okidi-mobile-nav-open {
	display: block !important;
}

@media (max-width: 767px) {
	.okidi-desktop-nav {
		display: none !important;
	}

	.okidi-mobile-only {
		display: block !important;
	}
}

/* ========== Ocultar elementos del tema padre en páginas custom ========== */
.okidi-home .aux-top-header,
.okidi-home .site-header-section,
.okidi-home .aux-wrapper > .aux-container,
.okidi-home .page-title-section,
.okidi-home .aux-footer,
.okidi-home .aux-subfooter,
.okidi-home .okidi-legal-footer,
.okidi-home #comments {
	display: none !important;
}

/* ========== Reset estilos tema padre en footer y header custom ========== */
.okidi-home footer a,
.okidi-home footer span,
.okidi-home footer li,
.okidi-home footer ul,
.okidi-home footer p,
.okidi-home footer h4,
.okidi-home header a:not(.okidi-cta-btn),
.okidi-home header nav a:not(.okidi-cta-btn),
.okidi-home header button {
	border: none !important;
	outline: none !important;
	box-shadow: none !important;
	background-color: transparent !important;
	background-image: none !important;
	text-decoration: none !important;
}

.okidi-home footer li {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

.okidi-home footer ul {
	padding: 0 !important;
	margin: 0 !important;
}


/* ========== Dropdown menu ========== */
.okidi-nav-dropdown .okidi-dropdown-menu {
	display: none;
	opacity: 0;
	transform: translateY(4px);
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.okidi-nav-dropdown:hover .okidi-dropdown-menu,
.okidi-nav-dropdown:focus-within .okidi-dropdown-menu {
	display: block;
	opacity: 1;
	transform: translateY(0);
}

/* ========== Animaciones de entrada ========== */
@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes fadeIn {
	from { opacity: 0; }
	to { opacity: 1; }
}

.okidi-home section {
	animation: fadeIn 0.5s ease-out;
}

/* ========== Service cards hover lift ========== */
.okidi-home .grid > div[class*="border"]:hover {
	transform: translateY(-3px);
	transition: transform 0.3s ease, border-color 0.3s ease;
}

/* ========== Stats counter animation ========== */
@keyframes countUp {
	from { opacity: 0; transform: translateY(10px); }
	to { opacity: 1; transform: translateY(0); }
}

.okidi-home #nosotros .grid > div {
	animation: countUp 0.5s ease-out forwards;
}

.okidi-home #nosotros .grid > div:nth-child(2) {
	animation-delay: 0.1s;
}

.okidi-home #nosotros .grid > div:nth-child(3) {
	animation-delay: 0.2s;
}

/* ========== GDPR info styling ========== */
.okidi-home .okidi-gdpr-info {
	padding: 12px 14px;
	background: rgba(46, 26, 107, 0.04);
	border-radius: 8px;
	border: 1px solid #E8E4DF;
}

/* ========== Focus visible for accessibility ========== */
.okidi-home a:focus-visible,
.okidi-home button:focus-visible,
.okidi-home input:focus-visible,
.okidi-home textarea:focus-visible {
	outline: 2px solid #2E1A6B;
	outline-offset: 2px;
	border-radius: 4px;
}

/* ========== Mobile responsive fixes ========== */
@media (max-width: 767px) {
	.okidi-home header {
		position: sticky;
		top: 0;
		z-index: 50;
	}

	.okidi-home #nosotros .grid {
		grid-template-columns: repeat(3, 1fr);
		gap: 16px;
	}

	.okidi-home #nosotros .grid span {
		font-size: 20px;
	}
}

/* ========== Scrollbar styling ========== */
.okidi-home::-webkit-scrollbar {
	width: 6px;
}

.okidi-home::-webkit-scrollbar-track {
	background: #FAF8F5;
}

.okidi-home::-webkit-scrollbar-thumb {
	background: #2E1A6B;
	border-radius: 3px;
}

/* ========== Service page specific ========== */
.okidi-service-card {
	transition: transform 0.3s ease, border-color 0.3s ease;
}

.okidi-service-card:hover {
	transform: translateY(-3px);
}

/* ========== Blog cards ========== */
.okidi-blog-card {
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.okidi-blog-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 30px rgba(46, 26, 107, 0.08);
}

.line-clamp-3 {
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* ========== Single post content ========== */
.okidi-post-content {
	font-family: 'Poppins', sans-serif;
	font-size: 16px;
	line-height: 1.8;
	color: #2D2D2D;
}

.okidi-post-content p {
	margin-bottom: 1.25em;
}

.okidi-post-content h2 {
	font-size: 1.6em;
	font-weight: 700;
	color: #2D2D2D;
	margin: 1.8em 0 0.6em;
	line-height: 1.3;
}

.okidi-post-content h3 {
	font-size: 1.3em;
	font-weight: 600;
	color: #2D2D2D;
	margin: 1.5em 0 0.5em;
	line-height: 1.35;
}

.okidi-post-content h4 {
	font-size: 1.1em;
	font-weight: 600;
	color: #2D2D2D;
	margin: 1.3em 0 0.4em;
}

.okidi-post-content strong,
.okidi-post-content b {
	font-weight: 600;
	color: #1E0E4A;
}

.okidi-post-content a {
	color: #2E1A6B;
	text-decoration: underline;
	text-underline-offset: 3px;
	transition: color 0.2s;
}

.okidi-post-content a:hover {
	color: #E83C7B;
}

.okidi-post-content ul,
.okidi-post-content ol {
	margin: 1em 0 1.25em 1.5em;
	padding: 0;
}

.okidi-post-content ul {
	list-style-type: disc;
}

.okidi-post-content ol {
	list-style-type: decimal;
}

.okidi-post-content li {
	margin-bottom: 0.4em;
	padding-left: 0.25em;
}

.okidi-post-content blockquote,
.okidi-post-content .wp-block-quote {
	border-left: 4px solid #2E1A6B;
	padding: 1em 1.5em;
	margin: 1.5em 0;
	background: rgba(46, 26, 107, 0.04);
	border-radius: 0 12px 12px 0;
	font-style: italic;
	color: #5A5A5A;
}

.okidi-post-content blockquote p {
	margin-bottom: 0.5em;
}

.okidi-post-content blockquote cite {
	display: block;
	font-style: normal;
	font-weight: 600;
	font-size: 0.9em;
	color: #2E1A6B;
	margin-top: 0.5em;
}

.okidi-post-content img {
	max-width: 100%;
	height: auto;
	border-radius: 12px;
	margin: 1em 0;
}

.okidi-post-content figure {
	margin: 1.5em 0;
}

.okidi-post-content figcaption {
	font-size: 0.85em;
	color: #8A8A8A;
	text-align: center;
	margin-top: 0.5em;
}

.okidi-post-content .wp-block-media-text {
	display: grid;
	gap: 1.5em;
	margin: 1.5em 0;
	align-items: center;
}

.okidi-post-content .wp-block-media-text__media img {
	border-radius: 12px;
}

.okidi-post-content .wp-block-media-text__content p {
	font-size: 15px;
}

@media (max-width: 767px) {
	.okidi-post-content .wp-block-media-text.is-stacked-on-mobile {
		grid-template-columns: 1fr !important;
	}

	.okidi-post-content .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__media {
		grid-column: 1;
		grid-row: 1;
	}

	.okidi-post-content .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__content {
		grid-column: 1;
		grid-row: 2;
	}
}

/* Reset inline color spans from Gutenberg */
.okidi-post-content .has-inline-color {
	color: inherit !important;
}

.okidi-post-content .has-very-dark-gray-color,
.okidi-post-content .has-black-color {
	color: #2D2D2D !important;
}
