/* =========================================================================
   PURA — sections.css
   Estilos das seções da home: hero, marquee, mission, differentials, CTA.
   ========================================================================= */

/* -------------------------------------------------------------------------
   0. Reveal on scroll (compartilhado)
   ------------------------------------------------------------------------- */
[data-reveal] {
	opacity: 0;
	transform: translateY(20px);
	transition:
		opacity var(--dur-slow) var(--ease) var(--reveal-delay, 0s),
		transform var(--dur-slow) var(--ease) var(--reveal-delay, 0s);
	will-change: opacity, transform;
}

[data-reveal].is-revealed {
	opacity: 1;
	transform: translateY(0);
}

.eyebrow--inverted {
	color: var(--moss-2);
}

.site-main--home {
	padding: 0;
	min-height: 0;
}

/* =========================================================================
   1. HERO
   ========================================================================= */
.hero {
	position: relative;
	background: var(--paper);
	padding: clamp(var(--space-5), 4vw, var(--space-7)) 0 clamp(var(--space-8), 10vw, var(--space-10));
	overflow: hidden;
}

.hero::after {
	/* halo radial sutil pra dar profundidade no canto direito */
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse 60% 50% at 80% 30%, rgba(47, 74, 51, 0.06), transparent 70%);
	pointer-events: none;
}

.hero__inner {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
	gap: clamp(var(--space-6), 5vw, var(--space-8));
	align-items: center;
}

.hero__content {
	max-width: 620px;
}

.hero__index {
	font-family: var(--font-display);
	font-style: italic;
	font-size: 0.84rem;
	color: var(--ink-mute);
	letter-spacing: 0.06em;
	margin: 0 0 var(--space-5);
	font-variation-settings: 'opsz' 14, 'SOFT' 100;
}

.hero__badge {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: 0.5em 1em;
	border: 1px solid var(--line);
	border-radius: var(--radius-pill);
	background: rgba(255, 255, 255, 0.4);
	font-family: var(--font-body);
	font-weight: 500;
	font-size: 0.78rem;
	letter-spacing: 0.05em;
	color: var(--ink-2);
	margin: 0 0 var(--space-6);
}

.hero__badge-dot {
	width: 8px;
	height: 8px;
	background: var(--moss);
	border-radius: 50%;
	animation: hero-pulse 2.4s ease-in-out infinite;
}

@keyframes hero-pulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50%      { opacity: 0.55; transform: scale(0.85); }
}

.hero__title {
	font-size: var(--fs-display-xl);
	line-height: 1.02;
	letter-spacing: -0.02em;
	margin: 0 0 var(--space-6);
	font-variation-settings: 'opsz' 144, 'SOFT' 90, 'wght' 400;
	color: var(--ink);
}

.hero__title-line {
	display: block;
}

.hero__title em {
	color: var(--moss);
	font-style: italic;
	font-variation-settings: 'opsz' 144, 'SOFT' 100, 'wght' 400;
}

.hero__lede {
	font-size: var(--fs-body-lg);
	line-height: 1.6;
	color: var(--ink-2);
	max-width: 52ch;
	margin: 0 0 var(--space-6);
}

.hero__pillars {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	margin: 0 0 var(--space-7);
	padding: 0;
}

.hero__pillars li {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: 0.45em 0.95em;
	border: 1px solid var(--line);
	border-radius: var(--radius-pill);
	background: var(--paper-2);
	font-family: var(--font-body);
	font-size: 0.82rem;
	color: var(--ink-2);
	letter-spacing: 0.02em;
}

.hero__pillars li .icon {
	color: var(--moss);
}

.hero__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
}

/* ---------- Hero stage (lado direito) ---------- */
.hero__stage {
	position: relative;
	aspect-ratio: 4 / 5;
	min-height: 520px;
}

.hero__frame {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse 65% 50% at 50% 30%, rgba(255, 255, 255, 0.18), transparent 70%),
		linear-gradient(165deg, #3a5a40 0%, #2a3f2d 60%, #1f3023 100%);
	border-radius: 220px 180px 240px 160px / 200px 160px 220px 140px;
	overflow: hidden;
	color: rgba(232, 221, 198, 0.85);
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow:
		inset 0 0 80px rgba(0, 0, 0, 0.35),
		0 40px 60px -30px rgba(27, 34, 28, 0.45);
}

.hero__frame::after {
	/* grão dentro da moldura também — coerência com o body */
	content: '';
	position: absolute;
	inset: 0;
	pointer-events: none;
	opacity: 0.18;
	mix-blend-mode: overlay;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

.hero__botanical {
	position: relative;
	width: 60%;
	max-width: 320px;
	height: auto;
	color: var(--paper-warm);
	z-index: 1;
	animation: hero-sway 9s ease-in-out infinite;
	transform-origin: 50% 95%;
}

@keyframes hero-sway {
	0%, 100% { transform: rotate(-1.2deg); }
	50%      { transform: rotate(1.2deg); }
}

.hero__frame-label {
	position: absolute;
	bottom: 28px;
	left: 28px;
	right: 28px;
	z-index: 2;
	display: flex;
	align-items: baseline;
	gap: 0.5em;
	font-family: var(--font-display);
	color: rgba(242, 234, 219, 0.78);
	font-size: 0.85rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.hero__frame-label em {
	font-style: italic;
	font-weight: 400;
	letter-spacing: 0.04em;
	text-transform: none;
	font-variation-settings: 'opsz' 14, 'SOFT' 100;
	font-size: 0.95rem;
	color: var(--paper-warm);
}

.hero__frame-label strong {
	font-weight: 500;
}

/* Cartões flutuantes pinned na moldura */
.hero__note {
	position: absolute;
	background: var(--paper-2);
	border: 1px solid var(--line);
	border-radius: var(--radius-4);
	padding: var(--space-4) var(--space-5);
	box-shadow: var(--shadow-card);
	max-width: 240px;
	font-size: 0.88rem;
	line-height: 1.45;
	margin: 0;
	animation: hero-float 6s ease-in-out infinite;
}

.hero__note-eyebrow {
	display: block;
	font-family: var(--font-display);
	font-style: italic;
	font-size: 0.7rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--moss);
	margin-bottom: var(--space-2);
	font-variation-settings: 'opsz' 14, 'SOFT' 30;
}

.hero__note blockquote {
	margin: 0;
	font-family: var(--font-display);
	font-size: 1rem;
	color: var(--ink);
	line-height: 1.4;
	font-variation-settings: 'opsz' 24, 'SOFT' 70;
}

.hero__note blockquote em {
	color: var(--moss);
	font-style: italic;
	font-variation-settings: 'opsz' 24, 'SOFT' 100;
}

.hero__note p {
	margin: 0;
}

.hero__note strong {
	display: block;
	font-family: var(--font-display);
	font-size: 2.2rem;
	font-weight: 500;
	color: var(--ink);
	line-height: 1;
	margin-block: 4px;
	font-variation-settings: 'opsz' 144, 'SOFT' 80;
}

.hero__note-mute {
	color: var(--ink-mute);
	font-size: 0.78rem;
}

.hero__note:nth-child(2) {
	top: 8%;
	right: -12px;
	animation-delay: -2s;
}

.hero__note--alt {
	bottom: 6%;
	left: -16px;
	max-width: 220px;
	animation-duration: 7s;
	animation-delay: -3s;
}

@keyframes hero-float {
	0%, 100% { transform: translateY(0); }
	50%      { transform: translateY(-8px); }
}

/* Hero responsivo */
@media (max-width: 980px) {
	.hero__inner {
		grid-template-columns: 1fr;
	}
	.hero__stage {
		min-height: 460px;
		max-width: 460px;
		margin-inline: auto;
		width: 100%;
	}
	.hero__note:nth-child(2) {
		right: 0;
	}
	.hero__note--alt {
		left: 0;
	}
}

@media (max-width: 540px) {
	.hero__stage {
		min-height: 380px;
	}
	.hero__note {
		padding: var(--space-3) var(--space-4);
		font-size: 0.8rem;
	}
}

/* =========================================================================
   2. MANIFESTO MARQUEE
   ========================================================================= */
.manifesto {
	background: var(--moss);
	color: var(--paper);
	overflow: hidden;
	padding-block: var(--space-5);
	border-top: 1px solid rgba(0, 0, 0, 0.15);
	border-bottom: 1px solid rgba(0, 0, 0, 0.15);
}

.manifesto__track {
	display: flex;
	gap: var(--space-7);
	width: max-content;
	animation: manifesto-scroll 32s linear infinite;
}

.manifesto:hover .manifesto__track {
	animation-play-state: paused;
}

.manifesto__group {
	display: flex;
	align-items: center;
	gap: var(--space-7);
	flex-shrink: 0;
}

.manifesto__item {
	font-family: var(--font-display);
	font-style: italic;
	font-size: clamp(1.05rem, 1.4vw, 1.4rem);
	letter-spacing: 0.02em;
	color: var(--paper);
	font-variation-settings: 'opsz' 144, 'SOFT' 90;
	white-space: nowrap;
}

.manifesto__sep {
	color: var(--moss-2);
	font-size: 0.9rem;
	flex-shrink: 0;
}

@keyframes manifesto-scroll {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}

/* =========================================================================
   3. MISSION (bloco escuro editorial)
   ========================================================================= */
.mission {
	background: var(--ink);
	color: var(--paper);
	padding-block: clamp(var(--space-8), 12vw, var(--space-10));
	position: relative;
	overflow: hidden;
}

.mission::before {
	/* leve textura interna pra dar profundidade no escuro */
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse 50% 40% at 80% 0%, rgba(90, 123, 94, 0.18), transparent 60%),
		radial-gradient(ellipse 50% 40% at 0% 100%, rgba(162, 74, 40, 0.10), transparent 60%);
	pointer-events: none;
}

.mission__inner {
	position: relative;
}

.mission__header {
	max-width: 880px;
	margin-bottom: var(--space-8);
}

.mission__title {
	font-size: clamp(2.4rem, 5vw + 1rem, 4.8rem);
	line-height: 1.02;
	color: var(--paper);
	margin: var(--space-4) 0 0;
	font-variation-settings: 'opsz' 144, 'SOFT' 80;
	letter-spacing: -0.015em;
}

.mission__title em {
	color: var(--moss-2);
	font-style: italic;
	font-variation-settings: 'opsz' 144, 'SOFT' 100;
}

.mission__body {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
	gap: clamp(var(--space-6), 6vw, var(--space-8));
	align-items: start;
}

.mission__copy {
	color: rgba(242, 234, 219, 0.78);
	font-size: var(--fs-body-lg);
	line-height: 1.7;
	max-width: 56ch;
}

.mission__copy strong {
	color: var(--paper);
	font-weight: 600;
}

.mission__copy em {
	color: var(--moss-2);
	font-style: italic;
}

.mission__lede {
	font-size: clamp(1.1rem, 0.6vw + 1rem, 1.3rem);
	line-height: 1.6;
	color: rgba(242, 234, 219, 0.92);
	margin-bottom: var(--space-5);
}

.dropcap {
	float: left;
	font-family: var(--font-display);
	font-size: 4.6em;
	line-height: 0.85;
	margin: 0.06em 0.12em 0 -0.04em;
	color: var(--moss-2);
	font-style: italic;
	font-variation-settings: 'opsz' 144, 'SOFT' 100;
	font-weight: 500;
}

.mission__link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	margin-top: var(--space-5);
	color: var(--paper);
	text-decoration: none;
	font-family: var(--font-body);
	font-weight: 600;
	font-size: 0.88rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	border-bottom: 1px solid rgba(242, 234, 219, 0.4);
	padding-bottom: 4px;
	transition: border-color var(--dur-quick) var(--ease), gap var(--dur-base) var(--ease);
}

.mission__link:hover {
	border-bottom-color: var(--paper);
	gap: var(--space-3);
}

.mission__stats {
	list-style: none;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1px;
	background: rgba(242, 234, 219, 0.12);
	border: 1px solid rgba(242, 234, 219, 0.12);
	padding: 0;
	margin: 0;
}

.mission__stat {
	background: var(--ink);
	padding: var(--space-6) var(--space-5);
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	min-height: 200px;
}

.mission__stat--accent {
	background: linear-gradient(180deg, rgba(47, 74, 51, 0.6), rgba(47, 74, 51, 0.2));
}

.mission__stat--mark {
	background: linear-gradient(180deg, rgba(162, 74, 40, 0.4), rgba(162, 74, 40, 0.1));
}

.mission__stat-num {
	font-family: var(--font-display);
	font-size: clamp(3rem, 6vw, 5rem);
	line-height: 0.9;
	color: var(--paper);
	font-variation-settings: 'opsz' 144, 'SOFT' 80, 'wght' 400;
	letter-spacing: -0.02em;
	display: inline-flex;
	align-items: baseline;
	gap: 0.05em;
}

.mission__stat-num sub {
	font-size: 0.4em;
	font-style: italic;
	color: var(--moss-2);
	font-variation-settings: 'opsz' 14, 'SOFT' 100;
	transform: translateY(-0.3em);
	font-weight: 400;
}

.mission__stat--mark .mission__stat-num {
	color: var(--terra-2);
}

.mission__stat--mark .mission__stat-num .icon {
	width: 56px;
	height: 56px;
}

.mission__stat-cap {
	color: rgba(242, 234, 219, 0.7);
	font-size: 0.88rem;
	line-height: 1.5;
}

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

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

/* =========================================================================
   4. DIFFERENTIALS
   ========================================================================= */
.differentials {
	background: var(--paper-2);
	padding-block: clamp(var(--space-8), 10vw, var(--space-10));
	border-bottom: 1px solid var(--line);
}

.differentials__header {
	max-width: 780px;
	margin-bottom: var(--space-8);
}

.differentials__title {
	font-size: clamp(2rem, 3.5vw + 1rem, 3.4rem);
	margin: var(--space-3) 0 0;
	font-variation-settings: 'opsz' 144, 'SOFT' 80;
	max-width: 18ch;
}

.differentials__title em {
	color: var(--moss);
	font-style: italic;
	font-variation-settings: 'opsz' 144, 'SOFT' 100;
}

.differentials__grid {
	list-style: none;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	border-top: 1px solid var(--line);
	padding: 0;
	margin: 0;
}

.differential {
	padding: var(--space-7) var(--space-5) var(--space-6);
	border-right: 1px solid var(--line);
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
	position: relative;
	transition: background var(--dur-base) var(--ease);
}

.differential:last-child {
	border-right: 0;
}

.differential:hover {
	background: var(--paper);
}

.differential__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	border: 1px solid var(--moss);
	color: var(--moss);
	transition: background var(--dur-base) var(--ease), color var(--dur-base) var(--ease);
}

.differential:hover .differential__icon {
	background: var(--moss);
	color: var(--paper);
}

.differential__title {
	font-family: var(--font-display);
	font-size: 1.35rem;
	line-height: 1.2;
	margin: 0;
	color: var(--ink);
	font-variation-settings: 'opsz' 36, 'SOFT' 70;
	font-weight: 500;
}

.differential__body {
	color: var(--ink-2);
	font-size: 0.95rem;
	line-height: 1.6;
	margin: 0;
}

@media (max-width: 980px) {
	.differentials__grid {
		grid-template-columns: 1fr 1fr;
	}
	.differential:nth-child(odd) {
		border-right: 1px solid var(--line);
	}
	.differential:nth-child(even) {
		border-right: 0;
	}
	.differential:nth-child(-n+2) {
		border-bottom: 1px solid var(--line);
	}
}

@media (max-width: 540px) {
	.differentials__grid {
		grid-template-columns: 1fr;
	}
	.differential {
		border-right: 0;
		border-bottom: 1px solid var(--line);
	}
	.differential:last-child {
		border-bottom: 0;
	}
}

/* =========================================================================
   5. CTA NEWSLETTER
   ========================================================================= */
.cta-news {
	background: var(--moss);
	color: var(--paper);
	position: relative;
	overflow: hidden;
	padding-block: clamp(var(--space-8), 10vw, var(--space-10));
}

.cta-news::before {
	/* gradient interno sutil */
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse 60% 60% at 100% 0%, rgba(232, 201, 179, 0.18), transparent 60%),
		radial-gradient(ellipse 60% 60% at 0% 100%, rgba(162, 74, 40, 0.18), transparent 60%);
	pointer-events: none;
}

.cta-news__leaf {
	position: absolute;
	width: 360px;
	height: 360px;
	color: var(--paper-warm);
	pointer-events: none;
	opacity: 0.55;
}

.cta-news__leaf--tl {
	top: -80px;
	right: -60px;
	transform: rotate(15deg);
}

.cta-news__leaf--br {
	bottom: -80px;
	left: -60px;
	transform: rotate(-10deg);
}

.cta-news__inner {
	position: relative;
	z-index: 1;
}

.cta-news__content {
	max-width: 720px;
	margin: 0 auto;
	text-align: center;
}

.cta-news__title {
	font-size: clamp(2.2rem, 4vw + 1rem, 3.8rem);
	margin: var(--space-4) 0 var(--space-5);
	color: var(--paper);
	font-variation-settings: 'opsz' 144, 'SOFT' 90;
	letter-spacing: -0.015em;
	line-height: 1.05;
}

.cta-news__title em {
	color: var(--terra-2);
	font-style: italic;
	font-variation-settings: 'opsz' 144, 'SOFT' 100;
}

.cta-news__lede {
	font-size: var(--fs-body-lg);
	line-height: 1.65;
	color: rgba(242, 234, 219, 0.85);
	max-width: 56ch;
	margin: 0 auto var(--space-7);
}

.cta-news__lede strong {
	color: var(--paper);
	font-weight: 700;
	background: rgba(232, 201, 179, 0.18);
	padding: 0.05em 0.4em;
	border-radius: var(--radius-2);
}

.cta-news__form {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	max-width: 520px;
	margin: 0 auto;
}

.cta-news__form input[type="email"] {
	flex: 1 1 240px;
	background: rgba(255, 255, 255, 0.08);
	border: 1.5px solid rgba(255, 255, 255, 0.22);
	border-radius: var(--radius-pill);
	padding: 0.95em 1.3em;
	color: var(--paper);
	font-size: 0.95rem;
	transition: border-color var(--dur-base) var(--ease), background var(--dur-base) var(--ease);
}

.cta-news__form input[type="email"]::placeholder {
	color: rgba(242, 234, 219, 0.55);
}

.cta-news__form input[type="email"]:focus {
	outline: 0;
	border-color: var(--paper);
	background: rgba(255, 255, 255, 0.14);
}

.cta-news__form .btn {
	flex: 0 0 auto;
}

.cta-news__fineprint {
	margin-top: var(--space-4);
	font-size: 0.78rem;
	color: rgba(242, 234, 219, 0.55);
	letter-spacing: 0.04em;
}

.cta-news__feedback {
	min-height: 1.5em;
	margin: var(--space-3) auto 0;
	max-width: 520px;
	font-family: var(--font-body);
	font-size: 0.92rem;
	line-height: 1.4;
	transition: color var(--dur-base) var(--ease);
}

.cta-news__feedback:empty {
	display: none;
}

.cta-news__feedback.is-success {
	color: var(--terra-2);
	font-family: var(--font-display);
	font-style: italic;
	font-size: 1.05rem;
	font-variation-settings: 'opsz' 24, 'SOFT' 80;
}

.cta-news__feedback.is-error {
	color: #FFB397;
}

[data-newsletter-submit].is-loading {
	opacity: 0.7;
	pointer-events: none;
}

@media (max-width: 540px) {
	.cta-news__form .btn {
		width: 100%;
	}
}
