/**
 * Global Styles - Variables, Typography, Layout, Utilities
 *
 * @package CreadiNegocio
 */

/* -----------------------------------------------
   CSS Custom Properties
----------------------------------------------- */
:root {
	/*
	 * Paleta de colores
	 * Primario  : #871F78  (púrpura oscuro)
	 * Secundario: #A3358C  (rosa púrpura)
	 * Terciario : #7F12A3  (violeta)
	 * Blanco / Negro
	 */
	--color-primary: #871F78;
	--color-primary-dark: #6b1860;
	--color-primary-light: #f3e0ef;
	--color-secondary: #A3358C;
	--color-secondary-dark: #7f2a6d;
	--color-secondary-light: #f5e2f0;
	--color-tertiary: #7F12A3;
	--color-tertiary-dark: #620e7e;
	--color-tertiary-light: #f0dff6;

	--color-white: #ffffff;
	--color-black: #000000;

	--color-text: #1a1a1a;
	--color-text-light: #555555;
	--color-text-inverse: #ffffff;

	--color-bg: #ffffff;
	--color-bg-alt: #f9f5f8;
	--color-bg-dark: #1a0a17;

	--color-border: #e8dce5;
	--color-border-dark: #c9b3c4;

	--color-success: #22c55e;
	--color-error: #ef4444;

	/*
	 * Typography  (1rem = 10px  — see reset.css)
	 * Headings : Montserrat  — h1 600 / h2-h6 500
	 * Body     : Poppins 400 — variaciones 300, 400, 500, 600, 700
	 */
	--font-primary: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	--font-heading: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	--font-mono: "SF Mono", "Fira Code", "Fira Mono", "Roboto Mono", monospace;

	/* Escala tipográfica (rem base = 10px) */
	--text-xs: 1.2rem;    /* 12px */
	--text-sm: 1.4rem;    /* 14px */
	--text-base: 1.6rem;  /* 16px */
	--text-lg: 1.8rem;    /* 18px */
	--text-xl: 2rem;      /* 20px */
	--text-2xl: 2.4rem;   /* 24px */
	--text-3xl: 3rem;     /* 30px */
	--text-4xl: 3.6rem;   /* 36px */

	/* Escala de headings h1-h6 */
	--text-h1: 4.8rem;    /* 48px */
	--text-h2: 3.6rem;    /* 36px */
	--text-h3: 3rem;      /* 30px */
	--text-h4: 2.4rem;    /* 24px */
	--text-h5: 2rem;      /* 20px */
	--text-h6: 1.8rem;    /* 18px */

	/* Font weights */
	--font-light: 300;
	--font-normal: 400;
	--font-medium: 500;
	--font-semibold: 600;
	--font-bold: 700;

	/* Spacing (rem base = 10px) */
	--space-1: 0.4rem;    /* 4px */
	--space-2: 0.8rem;    /* 8px */
	--space-3: 1.2rem;    /* 12px */
	--space-4: 1.6rem;    /* 16px */
	--space-5: 2rem;      /* 20px */
	--space-6: 2.4rem;    /* 24px */
	--space-8: 3.2rem;    /* 32px */
	--space-10: 4rem;     /* 40px */
	--space-12: 4.8rem;   /* 48px */
	--space-16: 6.4rem;   /* 64px */
	--space-20: 8rem;     /* 80px */

	/* Títulos de sección + puntos (noticias, separador, FAQ, por qué, separador 2, contacto home…) */
	--home-section-title-size: clamp(2.6rem, 2vw + 2rem, var(--text-h2, 3.6rem));
	--home-section-title-weight: var(--font-bold, 700);
	--home-section-title-lh: 1.2;
	--home-section-title-tracking: -0.02em;
	--home-section-dots-gap: 0.75rem;
	--home-section-dots-margin: var(--space-3, 1.2rem) 0 var(--space-5, 2rem);
	--home-section-dot-size: 0.65rem;

	/* Layout */
	--container-max: 1440px;
	--container-padding: 3.2rem; /* 32px en todos los dispositivos */
	--container-narrow: 76.8rem; /* 768px */
	/* Altura barra del header (.header-inner); responsive.css la reduce en ≤480px */
	--site-header-height: 7.2rem;

	/* Borders */
	--radius-sm: 0.4rem;
	--radius-md: 0.8rem;
	--radius-lg: 1.2rem;
	--radius-xl: 1.6rem;
	--radius-full: 9999px;

	/* Shadows */
	--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
	--shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
	--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
	--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);

	/* Transitions */
	--transition-fast: 150ms ease;
	--transition-base: 250ms ease;
	--transition-slow: 350ms ease;
}

/* -----------------------------------------------
   Base Typography
----------------------------------------------- */
body {
	margin: 0;
	padding: 0;
	font-family: var(--font-primary);
	font-weight: var(--font-normal);
	color: var(--color-text);
	background-color: var(--color-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-heading);
	color: var(--color-secondary);
}

h1 {
	font-size: var(--text-h1);
	font-weight: var(--font-semibold); /* Montserrat 600 */
}

h2 {
	font-size: var(--text-h2);
	font-weight: var(--font-medium); /* Montserrat 500 */
}

h3 {
	font-size: var(--text-h3);
	font-weight: var(--font-medium);
}

h4 {
	font-size: var(--text-h4);
	font-weight: var(--font-medium);
}

h5 {
	font-size: var(--text-h5);
	font-weight: var(--font-medium);
}

h6 {
	font-size: var(--text-h6);
	font-weight: var(--font-medium);
}

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

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

p {
	margin-bottom: var(--space-4);
}

/* -----------------------------------------------
   Layout
----------------------------------------------- */
.container {
	width: 100%;
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--container-padding);
}

.container.site-archive-bounds {
	padding-inline: 0;
}

.site-archive-bounds__grid {
	padding-inline: var(--container-padding);
}

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

.site-main {
	flex: 1;
	padding-block: var(--space-12);
}

.site-main > .container,
.site-archive-bounds__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-12);
}

/* 70% contenido · 30% barra lateral (proporción dentro de --container-max + padding) */
.site-main > .container:has(#secondary),
.site-archive-bounds__grid:has(#secondary) {
	grid-template-columns: minmax(0, 70fr) minmax(0, 30fr);
	gap: var(--space-8);
	align-items: start;
}

.site-main > .container:has(#secondary) .content-area,
.site-main > .container:has(#secondary) .sidebar,
.site-archive-bounds__grid:has(#secondary) .content-area,
.site-archive-bounds__grid:has(#secondary) .sidebar {
	min-width: 0;
}

.site-main > .container:has(#secondary) .sidebar,
.site-archive-bounds__grid:has(#secondary) .sidebar {
	position: sticky;
	top: 8.8rem;
	align-self: start;
	max-height: calc(100vh - 8.8rem);
	overflow-y: auto;
	overscroll-behavior: contain;
}

body.admin-bar .site-main > .container:has(#secondary) .sidebar,
body.admin-bar .site-archive-bounds__grid:has(#secondary) .sidebar {
	top: 11.2rem;
	max-height: calc(100vh - 11.2rem);
}

/* Blog/archivo: columna vertical hero + main dentro del ancho del .container */
.site-archive-bounds {
	display: flex;
	flex-direction: column;
	width: 100%;
}

.content-area--full {
	grid-column: 1 / -1;
}

/* -----------------------------------------------
   Accessibility
----------------------------------------------- */
.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute !important;
	height: 1px;
	width: 1px;
	overflow: hidden;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: var(--color-bg);
	border-radius: var(--radius-sm);
	box-shadow: var(--shadow-md);
	clip: auto !important;
	color: var(--color-primary);
	display: block;
	font-size: var(--text-sm);
	font-weight: var(--font-bold);
	height: auto;
	left: var(--space-2);
	line-height: normal;
	padding: var(--space-4) var(--space-6);
	text-decoration: none;
	top: var(--space-2);
	width: auto;
	z-index: 100000;
}

.skip-link:focus {
	z-index: 100001;
}

:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

/* -----------------------------------------------
   Page Headers
----------------------------------------------- */
.page-header {
	margin-bottom: var(--space-10);
	padding-bottom: var(--space-6);
	border-bottom: 2px solid var(--color-border);
}

.page-title {
	font-size: var(--text-h2);
	margin-bottom: var(--space-2);
}

.archive-description {
	color: var(--color-text-light);
	font-size: var(--text-lg);
}

/* -----------------------------------------------
   Pagination
----------------------------------------------- */
.pagination,
.nav-links {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: var(--space-2);
	margin-top: var(--space-12);
	flex-wrap: wrap;
}

.page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5rem;
	height: 2.5rem;
	padding: var(--space-1) var(--space-3);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	font-size: var(--text-sm);
	font-weight: var(--font-medium);
	color: var(--color-text);
	transition: all var(--transition-fast);
}

.page-numbers:hover {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-text-inverse);
}

.page-numbers.current {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-text-inverse);
}

/* -----------------------------------------------
   Post Navigation (single)
----------------------------------------------- */
.post-navigation {
	margin-top: var(--space-12);
	padding-top: var(--space-8);
	border-top: none;
}

.post-navigation .nav-links {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-6);
	justify-content: initial;
}

.post-navigation .nav-subtitle {
	display: block;
	font-size: var(--text-xs);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-text-light);
	margin-bottom: var(--space-1);
}

.post-navigation .nav-title {
	font-weight: var(--font-semibold);
}

.post-navigation .nav-next {
	text-align: right;
}

/* -----------------------------------------------
   Search Form
----------------------------------------------- */
.search-form {
	display: flex;
	max-width: 480px;
}

.search-field {
	flex: 1;
	padding: var(--space-3) var(--space-4);
	border: 2px solid var(--color-border);
	border-right: none;
	border-radius: var(--radius-md) 0 0 var(--radius-md);
	font-size: var(--text-base);
	transition: border-color var(--transition-fast);
}

.search-field:focus {
	outline: none;
	border-color: var(--color-primary);
}

.search-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-3) var(--space-4);
	background-color: var(--color-primary);
	color: var(--color-text-inverse);
	border: 2px solid var(--color-primary);
	border-radius: 0 var(--radius-md) var(--radius-md) 0;
	transition: background-color var(--transition-fast);
}

.search-submit:hover {
	background-color: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
}

/* -----------------------------------------------
   Read More Link
----------------------------------------------- */
.read-more {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	font-weight: var(--font-semibold);
	font-size: var(--text-sm);
	color: var(--color-primary);
	transition: gap var(--transition-fast), color var(--transition-fast);
}

.read-more:hover {
	gap: var(--space-3);
	color: var(--color-primary-dark);
}

/* -----------------------------------------------
   Error 404
----------------------------------------------- */
.error-404 {
	text-align: center;
	padding-block: var(--space-16);
}

.error-404 .page-title {
	font-size: var(--text-h1);
	margin-bottom: var(--space-6);
}

.error-404 .page-content > p {
	font-size: var(--text-lg);
	color: var(--color-text-light);
	margin-bottom: var(--space-8);
}

.error-404 .search-form {
	margin-inline: auto;
	margin-bottom: var(--space-12);
}

.error-404-widgets {
	text-align: left;
	max-width: var(--container-narrow);
	margin-inline: auto;
}

/* -----------------------------------------------
   WordPress Core Alignment
----------------------------------------------- */
.alignleft {
	float: left;
	margin-right: var(--space-6);
	margin-bottom: var(--space-4);
}

.alignright {
	float: right;
	margin-left: var(--space-6);
	margin-bottom: var(--space-4);
}

.aligncenter {
	display: block;
	margin-inline: auto;
	margin-bottom: var(--space-4);
}

.alignwide {
	max-width: calc(var(--container-max) + var(--space-12));
	margin-inline: calc(-1 * var(--space-6));
}

.alignfull {
	max-width: 100vw;
	margin-inline: calc(50% - 50vw);
	width: 100vw;
}

/* WordPress captions & galleries */
.wp-caption {
	max-width: 100%;
	margin-bottom: var(--space-6);
}

.wp-caption-text {
	font-size: var(--text-sm);
	color: var(--color-text-light);
	padding-top: var(--space-2);
}

/* Sin Bootstrap row (p. ej. admin): rejilla propia. Con .row, manda la galería Bootstrap. */
.gallery:not(.row) {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: var(--space-4);
	margin-bottom: var(--space-6);
}

.gallery-item {
	margin: 0;
}
