/**
 * Hayder Voice — Home Page Styles
 */

@layer components {

	/* ============================================================
	 * HERO
	 * ============================================================ */

	.hero {
		position: relative;
		min-height: 100svh;
		display: grid;
		grid-template-columns: 1fr 1fr;
		align-items: center;
		overflow: hidden;
		padding: 0 6%;
		background: var(--c-void);
	}

	/* Grain effect */
	.hero__grain {
		position: absolute;
		inset: -10%;
		width: 120%;
		height: 120%;
		background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
		background-size: 200px 200px;
		opacity: 0.6;
		pointer-events: none;
		animation: grain-shift 8s steps(10) infinite;
	}

	/* Houdini paint worklet fallback */
	.hero__grain[data-grain="houdini"] {
		background-image: paint(grain);
		--grain-density: 0.04;
	}

	/* Ambient glow */
	.hero__glow {
		position: absolute;
		bottom: -20%;
		left: 50%;
		transform: translateX(-50%);
		width: 800px;
		height: 400px;
		background: radial-gradient(ellipse at center, var(--c-amber-glow) 0%, transparent 70%);
		pointer-events: none;
		will-change: transform;
	}

	/* Content */
	.hero__content {
		position: relative;
		z-index: 2;
		padding: 6rem 0;
		max-width: 580px;
	}

	.hero__inner {
		max-width: 580px;
	}

	.hero__eyebrow {
		font-family: 'Inter', sans-serif;
		font-size: 0.65rem;
		letter-spacing: 0.2em;
		text-transform: uppercase;
		color: #C4956A;
		display: block !important;
		margin-bottom: 1.5rem;
		writing-mode: horizontal-tb !important;
		text-orientation: mixed !important;
		white-space: normal !important;
		max-width: 100%;
		line-height: 1.8;
	}

	.hero__headline,
	.hero__title {
		font-family: 'Cormorant Garamond', Georgia, serif;
		font-size: clamp(3.5rem, 6.5vw, 8rem);
		font-weight: 300;
		line-height: 0.95;
		color: #F5F0E8;
		letter-spacing: -0.02em;
		writing-mode: horizontal-tb;
		white-space: normal;
		display: block;
		width: 100%;
		margin-bottom: 1.5rem;
	}

	.hero__subtext {
		font-family: 'Inter', sans-serif;
		font-size: clamp(0.95rem, 1.4vw, 1.05rem);
		color: #7A7870;
		line-height: 1.85;
		margin-top: 1.5rem;
		max-width: 400px;
		display: block !important;
		writing-mode: horizontal-tb !important;
		text-orientation: mixed !important;
		white-space: normal !important;
	}

	.hero__actions {
		display: flex;
		align-items: center;
		gap: 1rem;
		flex-wrap: wrap;
		margin-top: 2rem;
	}

	/* Right-side decorative quote column */
	.hero__right {
		display: flex;
		align-items: center;
		justify-content: center;
		padding-left: 8%;
		border-left: 1px solid rgba(196,149,106,0.1);
		height: 50%;
	}
	.hero__quote {
		font-family: 'Cormorant Garamond', serif;
		font-size: clamp(1.1rem, 1.8vw, 1.5rem);
		font-style: italic;
		font-weight: 300;
		color: rgba(245,240,232,0.1);
		line-height: 1.65;
		max-width: 320px;
	}

	@media (max-width: 1024px) {
		.hero { grid-template-columns: 1fr; padding: 0 5%; }
		.hero__right { display: none; }
		.hero__content { padding: 8rem 0 6rem; max-width: 100%; }
	}

	/* ============================================================
	 * HERO MARQUEE
	 * ============================================================ */

	.hero__marquee {
		position: absolute;
		bottom: 4rem;
		left: 0;
		right: 0;
		z-index: 2;
		display: flex;
		flex-direction: column;
		gap: 0.75rem;
		overflow: hidden;
		pointer-events: none;
	}

	/* Allow pointer events on pills */
	.hero__marquee .emotion-pill {
		pointer-events: auto;
	}

	.marquee {
		overflow: hidden;
		mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
		-webkit-mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
	}

	.marquee__track {
		display: flex;
		gap: 0.75rem;
		width: max-content;
	}

	.marquee--ltr .marquee__track {
		animation: marquee-ltr 40s linear infinite;
	}

	.marquee--rtl .marquee__track {
		animation: marquee-rtl 35s linear infinite;
	}

	/* Pause on hover/focus */
	.marquee:hover .marquee__track,
	.marquee:focus-within .marquee__track {
		animation-play-state: paused;
	}

	@media (prefers-reduced-motion: reduce) {
		.marquee--ltr .marquee__track,
		.marquee--rtl .marquee__track {
			animation: none;
		}
		.marquee__track {
			flex-wrap: wrap;
			width: 100%;
		}
	}

	/* ============================================================
	 * SCROLL HINT
	 * ============================================================ */

	.hero__scroll-hint {
		position: absolute;
		bottom: 2rem;
		right: var(--container-pad);
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: 0.5rem;
		z-index: 3;
	}

	.hero__scroll-line {
		width: 1px;
		height: 40px;
		background: linear-gradient(to bottom, var(--c-amber), transparent);
		animation: scroll-line 2s ease-in-out infinite;
	}

	@keyframes scroll-line {
		0%   { transform: scaleY(0); transform-origin: top; }
		50%  { transform: scaleY(1); transform-origin: top; }
		51%  { transform: scaleY(1); transform-origin: bottom; }
		100% { transform: scaleY(0); transform-origin: bottom; }
	}

	@media (prefers-reduced-motion: reduce) {
		.hero__scroll-line { animation: none; }
	}

	.hero__scroll-label {
		font-family: var(--font-sans);
		font-size: var(--text-2xs);
		letter-spacing: var(--ls-widest);
		color: var(--c-dust);
		text-transform: uppercase;
		/* Use transform instead of writing-mode to avoid affecting text flow context */
		transform: rotate(-90deg);
		transform-origin: center center;
		white-space: nowrap;
	}

	/* ============================================================
	 * FEATURED POST
	 * ============================================================ */

	.featured-post {
		position: relative;
		padding: clamp(4rem, 8vw, 8rem) 0;
		overflow: hidden;
	}

	.featured-post__ghost {
		position: absolute;
		top: -0.05em;
		right: -0.1em;
		font-family: var(--font-serif);
		font-size: clamp(8rem, 20vw, 24rem);
		font-weight: 700;
		color: transparent;
		-webkit-text-stroke: 1px var(--c-border);
		text-stroke: 1px var(--c-border);
		pointer-events: none;
		user-select: none;
		line-height: 0.8;
		opacity: 0.3;
	}

	.featured-post__header {
		margin-bottom: 3rem;
	}

	.featured-post__grid {
		display: grid;
		grid-template-columns: 3fr 2fr;
		gap: clamp(2rem, 5vw, 5rem);
		align-items: center;
	}

	.featured-post__content {
		position: relative;
		z-index: 1;
	}

	.featured-post__title {
		font-size: clamp(2rem, 4vw, 3.5rem);
		font-weight: 300;
		line-height: var(--lh-snug);
		letter-spacing: -0.02em;
		color: var(--c-heading);
		margin-bottom: 1.25rem;
	}

	.featured-post__title-link {
		color: inherit;
		text-decoration: none;
		transition: color var(--duration-fast) var(--ease-smooth);
	}

	.featured-post__title-link:hover { color: var(--c-amber); }

	.featured-post__excerpt {
		font-family: var(--font-sans);
		font-size: var(--text-base);
		color: var(--c-muted);
		line-height: var(--lh-relaxed);
		max-width: 55ch;
		margin-bottom: 1.5rem;
	}

	.featured-post__read-link {
		margin-top: 1.5rem;
	}

	.featured-post__image-wrap {
		position: relative;
	}

	.featured-post__image {
		aspect-ratio: 4 / 5;
		border-radius: var(--radius-lg);
		overflow: hidden;
		background: var(--c-surface);
	}

	.featured-post__img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		transition: transform var(--duration-slow) var(--ease-smooth);
	}

	.featured-post__image-link:hover .featured-post__img {
		transform: scale(1.04);
	}

	/* ============================================================
	 * EMOTIONS GRID
	 * ============================================================ */

	.emotions-grid {
		padding: clamp(4rem, 8vw, 8rem) 0;
		border-top: 1px solid var(--c-border);
	}

	.emotions-grid__header {
		text-align: center;
		margin-bottom: 3rem;
	}

	.emotions-grid__title {
		font-size: var(--text-3xl);
		font-weight: 300;
		color: var(--c-heading);
	}

	.emotions-grid__list {
		display: grid;
		grid-template-columns: repeat(auto-fill, minmax(min(180px, 100%), 1fr));
		gap: 0.75rem;
		list-style: none;
		padding: 0;
		margin: 0;
	}

	.emotion-card {
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 0.5rem;
		padding: 0.875rem 1.25rem;
		background: var(--c-surface);
		border: 1px solid var(--c-border);
		border-radius: var(--radius-lg);
		text-decoration: none;
		transition: var(--transition-base);
		position: relative;
		overflow: hidden;
	}

	.emotion-card::before {
		content: '';
		position: absolute;
		inset: 0;
		background: linear-gradient(135deg, var(--c-amber-overlay) 0%, transparent 100%);
		opacity: 0;
		transition: opacity var(--duration-base) var(--ease-smooth);
	}

	.emotion-card:hover {
		border-color: var(--c-amber-border);
		transform: translateY(-2px);
		box-shadow: var(--shadow-amber);
	}

	.emotion-card:hover::before { opacity: 1; }

	.emotion-card__name {
		font-family: var(--font-serif);
		font-size: var(--text-md);
		font-style: italic;
		color: var(--c-heading);
		transition: color var(--duration-fast) var(--ease-smooth);
		position: relative;
		z-index: 1;
	}

	.emotion-card:hover .emotion-card__name { color: var(--c-amber); }

	.emotion-card__count {
		font-family: var(--font-sans);
		font-size: var(--text-2xs);
		color: var(--c-dust);
		transition: color var(--duration-fast) var(--ease-smooth);
		position: relative;
		z-index: 1;
	}

	.emotion-card:hover .emotion-card__count { color: var(--c-amber-dim); }

	.emotion-card__arrow {
		color: var(--c-dust);
		opacity: 0;
		transform: translateX(-4px);
		transition: var(--transition-base);
		position: relative;
		z-index: 1;
	}

	.emotion-card:hover .emotion-card__arrow {
		opacity: 1;
		transform: translateX(0);
	}

	/* ============================================================
	 * RECENT ESSAYS
	 * ============================================================ */

	.recent-essays {
		padding: clamp(4rem, 8vw, 8rem) 0;
		border-top: 1px solid var(--c-border);
	}

	.recent-essays__header {
		display: flex;
		align-items: flex-end;
		justify-content: space-between;
		gap: 2rem;
		margin-bottom: 3rem;
	}

	.recent-essays__title {
		font-size: var(--text-3xl);
		font-weight: 300;
		color: var(--c-heading);
		margin-bottom: 0;
	}

	.recent-essays__grid {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		gap: clamp(1.5rem, 2.5vw, 2rem);
		container-type: inline-size;
	}

	/* ============================================================
	 * TALES SLIDER
	 * ============================================================ */

	.tales-slider {
		padding: clamp(4rem, 8vw, 8rem) 0;
		border-top: 1px solid var(--c-border);
		overflow: hidden;
	}

	.tales-slider__header {
		display: flex;
		align-items: flex-end;
		justify-content: space-between;
		gap: 2rem;
		margin-bottom: 2.5rem;
	}

	.tales-slider__title {
		font-size: var(--text-3xl);
		font-weight: 300;
		color: var(--c-heading);
		margin-bottom: 0.5rem;
	}

	.tales-slider__desc {
		font-family: var(--font-sans);
		font-size: var(--text-sm);
		color: var(--c-muted);
	}

	/* Horizontal scroll container */
	.tales-slider__track {
		display: flex;
		gap: 1.5rem;
		overflow-x: auto;
		scroll-snap-type: x mandatory;
		padding-inline: var(--container-pad);
		padding-bottom: 1rem;
		scrollbar-width: none;
		-ms-overflow-style: none;
		scroll-behavior: smooth;
		cursor: grab;
	}

	.tales-slider__track:active { cursor: grabbing; }
	.tales-slider__track::-webkit-scrollbar { display: none; }

	/* Slider items */
	.tales-slider__item {
		flex: 0 0 clamp(260px, 30vw, 340px);
		scroll-snap-align: start;
	}

	.tales-slider__item .post-card__image {
		aspect-ratio: 3 / 4;
	}

	/* ============================================================
	 * NEWSLETTER SECTION
	 * ============================================================ */

	.newsletter-section {
		padding: clamp(6rem, 10vw, 10rem) 0;
		border-top: 1px solid var(--c-border);
		position: relative;
		overflow: hidden;
	}

	.newsletter-section__grain {
		position: absolute;
		inset: 0;
		background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");
		pointer-events: none;
		animation: grain-shift 10s steps(10) infinite;
	}

	@media (prefers-reduced-motion: reduce) {
		.newsletter-section__grain { animation: none; }
	}

	.newsletter-section__inner {
		position: relative;
		z-index: 1;
		text-align: center;
		padding: 0 1rem;
	}

	.newsletter-section__eyebrow { text-align: center; margin-inline: auto; }

	.newsletter-section__title {
		font-size: clamp(2rem, 5vw, 3.5rem);
		font-weight: 300;
		color: var(--c-heading);
		margin-bottom: 1.5rem;
	}

	.newsletter-section__desc {
		font-family: var(--font-sans);
		font-size: var(--text-base);
		color: var(--c-muted);
		max-width: 50ch;
		margin: 0 auto 3rem;
		line-height: 1.9;
	}

	.newsletter-form--section {
		max-width: 480px;
		margin-inline: auto;
	}

	.newsletter-form--section .newsletter-form__privacy {
		text-align: center;
		margin-top: 1.25rem;
	}

	.newsletter-form--section .newsletter-form__row {
		gap: 0.75rem;
	}

	.newsletter-form--section .newsletter-form__input {
		padding: 0.85rem 1.25rem;
	}

	.newsletter-form--section .newsletter-form__btn {
		padding: 0.85rem 2rem;
	}

	/* ============================================================
	 * MOBILE — HOMEPAGE
	 * ============================================================ */

	@media (max-width: 767px) {
		.hero { grid-template-columns: 1fr; padding: 0 1.25rem; min-height: 100svh; }
		.hero__title { font-size: clamp(3rem, 12vw, 4.5rem); }
		.hero__content { padding: 7rem 0 5rem; }
		.section--featured {
			grid-template-columns: 1fr;
			gap: 2rem;
		}
		.posts-grid {
			grid-template-columns: 1fr;
			gap: 1.5rem;
		}
		.post-card--featured { grid-column: 1; }
		.emotions-grid {
			grid-template-columns: 1fr 1fr;
			gap: 0.5rem;
		}
		.section-title { font-size: clamp(2rem, 7vw, 3rem); }
	}

} /* @layer components */
