/* ═══════════════════════════════════════════════════
   VI NATURAL — PAGES DE CONTINGUT
   vinatural.org · 2026
   ═══════════════════════════════════════════════════ */

/* ═══════════ HERO CONTINGUT ═══════════ */

.content-hero {
	background: var(--blanc);
	padding: calc(var(--sp-xl) + 4rem) var(--gutter) var(--sp-xl);
}

.content-hero-inner {
	max-width: var(--max-w);
	margin: 0 auto;
}

.content-hero-label {
	font-family: var(--font-body);
	font-size: clamp(0.65rem, 0.8vw, 0.75rem);
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--terra);
	margin-bottom: var(--sp-2xs);
}

.content-hero h1 {
	font-family: var(--font-display);
	font-size: clamp(2.4rem, 5vw, 4rem);
	font-weight: 300;
	line-height: 1.1;
	color: var(--vi-profund);
	margin-bottom: var(--sp-sm);
}

.content-hero h1 em {
	font-weight: 600;
	font-style: italic;
}

.content-hero-intro {
	max-width: 60ch;
	font-family: var(--font-display);
	font-size: clamp(1.05rem, 1.4vw, 1.25rem);
	font-weight: 300;
	line-height: 1.8;
	color: var(--carbó);
}

/* ═══════════ IMAGE SÉPARATEUR ═══════════ */

.content-img {
	width: 100%;
	overflow: hidden;
	line-height: 0;
}

.content-img img {
	width: 100%;
	height: clamp(200px, 28vw, 400px);
	object-fit: cover;
	display: block;
}

/* ═══════════ SECTION CLAIRE (serif) ═══════════ */

.content-light {
	background: var(--blanc);
	padding: var(--sp-xl) var(--gutter);
}

.content-light-inner {
	max-width: var(--max-w);
	margin: 0 auto;
}

.content-light h2 {
	font-family: var(--font-display);
	font-size: clamp(1.8rem, 3.5vw, 2.8rem);
	font-weight: 300;
	line-height: 1.15;
	color: var(--vi-profund);
	margin-top: var(--sp-xl);
	margin-bottom: var(--sp-xs);
}

.content-light-prose h3 {
	font-family: var(--font-body);
	font-size: 0.85rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--carbó);
	margin-top: var(--sp-md);
	margin-bottom: var(--sp-2xs);
}

.content-light-prose p {
	font-family: var(--font-body);
	font-size: clamp(0.9rem, 1.1vw, 1rem);
	line-height: 1.75;
	color: var(--carbó);
	max-width: 60ch;
	margin-bottom: var(--sp-sm);
}

.content-light-prose a {
	color: var(--vi-profund);
}

.content-light h2 em {
	font-weight: 600;
	font-style: italic;
}

.content-light-text {
	max-width: 60ch;
	font-family: var(--font-display);
	font-size: clamp(1rem, 1.3vw, 1.15rem);
	font-weight: 400;
	line-height: 1.8;
	color: var(--carbó);
}

.content-light-text p + p {
	margin-top: var(--sp-sm);
}

/* ═══════════ SECTION SOMBRE (sans-serif) ═══════════ */

.content-dark {
	background: var(--carbó);
	color: var(--blanc);
	padding: var(--sp-xl) var(--gutter);
}

.content-dark-inner {
	max-width: var(--max-w);
	margin: 0 auto;
}

.content-dark h2 {
	font-family: var(--font-display);
	font-size: clamp(1.8rem, 3.5vw, 2.8rem);
	font-weight: 300;
	line-height: 1.15;
	margin-bottom: var(--sp-md);
}

.content-dark h2 em {
	font-weight: 600;
	font-style: italic;
}

.content-dark-text {
	max-width: 60ch;
	font-family: var(--font-body);
	font-size: clamp(0.88rem, 1vw, 0.95rem);
	line-height: 1.8;
	opacity: 0.65;
}

.content-dark-text p + p {
	margin-top: var(--sp-sm);
}

/* ═══════════ GRILLE 2 COLONNES ═══════════ */

.content-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--sp-lg);
	align-items: start;
}

.content-grid img {
	width: 100%;
	height: auto;
	border-radius: 0.5rem;
	display: block;
}

/* ═══════════ NOTE / APARTÉ ═══════════ */

.content-note {
	margin-top: var(--sp-md);
	padding-top: var(--sp-sm);
	border-top: 1px solid rgba(245, 240, 232, 0.06);
	font-family: var(--font-display);
	font-size: clamp(0.92rem, 1.1vw, 1rem);
	font-weight: 300;
	font-style: italic;
	opacity: 0.4;
	line-height: 1.7;
	max-width: 60ch;
}

.content-light .content-note {
	border-top-color: rgba(42, 36, 32, 0.1);
	opacity: 0.5;
	color: var(--carbó);
}

/* ═══════════ RETOUR ═══════════ */

.content-back {
	background: var(--carbó);
	padding: 0 var(--gutter) var(--sp-lg);
}

.content-back a {
	font-family: var(--font-display);
	font-size: clamp(0.88rem, 1vw, 0.95rem);
	color: var(--blanc);
	opacity: 0.3;
	text-decoration: none;
	transition: opacity 0.3s;
}

.content-back a:hover {
	opacity: 0.7;
}

/* ═══════════ RESPONSIVE ═══════════ */

@media (max-width: 768px) {
	.content-grid {
		grid-template-columns: 1fr;
	}
}
