/* ==========================================================================
   components.css — Button, card, badge, form, hero, modal
   --------------------------------------------------------------------------
   BEM-vari naming: .block, .block__element, .block--modifier
   Bütün componentler base.css'teki token'ları kullanır.
   ========================================================================== */

/* ==========================================================================
   Button
   ========================================================================== */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	padding: 0.875rem 1.75rem;
	font-family: var(--font-body);
	font-size: var(--text-base);
	font-weight: 600;
	line-height: 1;
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	text-decoration: none;
	border: 1px solid transparent;
	border-radius: var(--radius);
	cursor: pointer;
	transition:
		background-color var(--duration-2) var(--ease),
		border-color var(--duration-2) var(--ease),
		color var(--duration-2) var(--ease),
		transform var(--duration-2) var(--ease);
	user-select: none;
	white-space: nowrap;
}

.btn:disabled,
.btn[aria-disabled="true"] {
	opacity: 0.5;
	cursor: not-allowed;
}

/* Variants */
.btn--primary {
	background-color: var(--brand-primary);
	color: var(--brand-white);
	border-color: var(--brand-primary);
}
.btn--primary:hover,
.btn--primary:focus-visible {
	background-color: var(--brand-primary-hover);
	border-color: var(--brand-primary-hover);
	color: var(--brand-white);
}

.btn--secondary {
	background-color: transparent;
	color: var(--brand-dark);
	border-color: var(--brand-dark);
}
.btn--secondary:hover,
.btn--secondary:focus-visible {
	background-color: var(--brand-dark);
	color: var(--brand-cream);
}

.btn--ghost {
	background-color: transparent;
	color: var(--brand-dark);
	border-color: transparent;
}
.btn--ghost:hover,
.btn--ghost:focus-visible {
	background-color: var(--brand-border);
	color: var(--brand-dark);
}

.btn--link {
	padding: 0;
	background: transparent;
	border: 0;
	color: var(--brand-primary);
	text-transform: none;
	letter-spacing: var(--tracking-normal);
	font-size: var(--text-md);
}
.btn--link:hover,
.btn--link:focus-visible {
	color: var(--brand-primary-hover);
	text-decoration: underline;
	text-underline-offset: 0.2em;
}

/* Size */
.btn--sm { padding: 0.625rem 1.25rem; font-size: var(--text-sm); }
.btn--lg { padding: 1.125rem 2.25rem; font-size: var(--text-md); }
.btn--block { width: 100%; }

/* ==========================================================================
   Card — base + variants (product, producer, blog, category)
   ========================================================================== */
.card {
	display: flex;
	flex-direction: column;
	background-color: var(--brand-white);
	border: 1px solid var(--brand-border);
	border-radius: var(--radius-md);
	overflow: hidden;
	transition:
		transform var(--duration-3) var(--ease),
		box-shadow var(--duration-3) var(--ease),
		border-color var(--duration-3) var(--ease);
}

.card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-md);
	border-color: transparent;
}

.card__media {
	position: relative;
	overflow: hidden;
	aspect-ratio: 4 / 3;
	background-color: var(--brand-border);
}

.card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--duration-3) var(--ease);
}

/* Image scale on hover kaldırıldı — sade + profesyonel pivot (2026-05-09).
   Kart hover'ı zaten translateY + gölge ile zaten sinyal veriyor; resim
   scale'i ekstra "fancy" hissi katıyordu. */

.card__body {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
	padding: var(--space-5);
	flex: 1;
}

.card__eyebrow {
	font-size: var(--text-xs);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	color: var(--brand-muted);
}

.card__title {
	font-family: var(--font-heading);
	font-size: var(--text-xl);
	font-weight: 600;
	line-height: var(--lh-snug);
	color: var(--brand-dark);
	margin: 0;
}

.card__title a {
	color: inherit;
}

.card__title a:hover {
	color: var(--brand-primary);
}

.card__excerpt {
	font-size: var(--text-sm);
	line-height: var(--lh-snug);
	color: var(--brand-muted);
	margin: 0;
}

.card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-3);
	margin-top: auto;
	padding-top: var(--space-3);
}

/* Fiyat — WC nested span'lara (`.amount`, `.woocommerce-Price-amount`,
   `.woocommerce-Price-currencySymbol`, `del`, `ins`) sıkı font override.
   Parent tema veya WC default CSS'i Caveat/cursive-style font veriyor olabilir;
   her seviyede zorla Inter (sans-serif) — sayılar net okunsun. */
.card__price,
.card__price .amount,
.card__price .woocommerce-Price-amount,
.card__price .woocommerce-Price-currencySymbol,
.card__price del,
.card__price ins {
	font-family: var(--font-body);
	font-style: normal;
}

.card__price {
	display: inline-flex;
	flex-direction: column;
	gap: 2px;
	font-size: var(--text-lg);
	font-weight: 600;
	line-height: 1.2;
	color: var(--brand-dark);
}

/* Eski fiyat (varsa) — üstte küçük, üstü çizgili, soluk */
.card__price del {
	font-size: 0.8em;
	font-weight: 500;
	color: var(--brand-muted);
	text-decoration: line-through;
	order: -1;
}

.card__price del .amount {
	color: inherit;
}

/* Yeni fiyat — ana fiyat, terracotta */
.card__price ins {
	text-decoration: none;
	color: var(--brand-primary);
}

.card__price ins .amount {
	color: inherit;
}

/* Variant: category — overlay üstünde başlık.
   Title 24→17px, padding 24→16px, gradient yumuşatıldı. Card daha kompakt,
   "ana sayfa şablonuna ait" hissini koruyor (önceden kategori kartları
   "başka sayfadan kopyalanmış" gibi büyük gözüküyordu). */
.card--category {
	position: relative; /* card__body absolute pozisyonlandırması için ANCESTOR */
	border: 0;
	border-radius: var(--radius-md);
	display: block; /* base .card flex idi; burada flow gerekmiyor */
}

.card--category .card__media {
	aspect-ratio: 1 / 1;
	height: 100%;
}

.card--category .card__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 55%, rgba(26, 26, 26, 0.65) 100%);
	z-index: 1;
	pointer-events: none;
}

.card--category .card__body {
	position: absolute;
	inset: auto 0 0 0;
	padding: var(--space-4);
	color: var(--brand-cream);
	z-index: 2;
}

.card--category .card__title {
	font-size: var(--text-md); /* 18px — eskiden --text-xl (24px), heavy hissediyor */
	font-weight: 600;
	letter-spacing: var(--tracking-normal);
	text-transform: none; /* parent CSS uppercase yapıyor olabilir, override */
	color: var(--brand-cream);
}

.card--category .card__eyebrow {
	font-size: 0.6875rem; /* 11px — daha hafif eyebrow */
	color: var(--brand-cream);
	opacity: 0.85;
}

/* Variant: producer — yuvarlak portre */
.card--producer .card__media {
	aspect-ratio: 1 / 1;
}

/* ==========================================================================
   Badge — yöre, coğrafi işaret, indirim
   ========================================================================== */
.badge {
	display: inline-flex;
	align-items: center;
	gap: var(--space-1);
	padding: 0.35em 0.7em;
	font-size: var(--text-xs);
	font-weight: 600;
	line-height: 1;
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	border-radius: var(--radius-full);
	background-color: var(--brand-cream);
	color: var(--brand-dark);
	border: 1px solid var(--brand-border);
}

.badge--region {
	background-color: var(--brand-cream);
	color: var(--brand-dark);
}

.badge--gi {
	background-color: var(--brand-secondary);
	color: var(--brand-dark);
	border-color: transparent;
}

.badge--sale {
	background-color: var(--brand-primary);
	color: var(--brand-white);
	border-color: transparent;
}

/* ==========================================================================
   Form — input, textarea, select, checkbox
   ========================================================================== */
.field {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.field__label {
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--brand-dark);
}

.field__hint {
	font-size: var(--text-xs);
	color: var(--brand-muted);
}

.field__error {
	font-size: var(--text-xs);
	color: var(--brand-primary);
}

.input,
.textarea,
.select {
	width: 100%;
	padding: 0.875rem 1rem;
	font-family: var(--font-body);
	font-size: var(--text-base);
	line-height: 1.4;
	color: var(--brand-text);
	background-color: var(--brand-white);
	border: 1px solid var(--brand-border);
	border-radius: var(--radius);
	transition:
		border-color var(--duration-2) var(--ease),
		box-shadow var(--duration-2) var(--ease);
}

.input::placeholder,
.textarea::placeholder {
	color: var(--brand-muted);
}

.input:focus,
.textarea:focus,
.select:focus {
	outline: none;
	border-color: var(--brand-primary);
	box-shadow: 0 0 0 3px rgba(200, 75, 49, 0.15);
}

.textarea {
	min-height: 8rem;
	resize: vertical;
}

.select {
	appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%232C3E2D' d='M6 8 0 0h12z'/></svg>");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	padding-right: 2.5rem;
}

/* Checkbox & radio — custom style */
.checkbox,
.radio {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	cursor: pointer;
	font-size: var(--text-sm);
}

.checkbox input,
.radio input {
	width: 1.125rem;
	height: 1.125rem;
	accent-color: var(--brand-primary);
}

/* Inline form — input + button yan yana (bülten kayıt vb.) */
.form-inline {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
}

.form-inline .input {
	flex: 1;
	min-width: 16rem;
}

/* ==========================================================================
   Hero — Split layout (2026-05-09 pivot, "shop banner" pattern)
   --------------------------------------------------------------------------
   Anasayfa hero. Sol metin + sağ ürün görseli. Açık zemin, dark overlay yok.
   Referans: organikgurme.com / kiralarsin.com banner kalıbı.
   Mobile'da stack — content önce, görsel altta.
   ========================================================================== */
.hero {
	background-color: var(--brand-cream);
	padding-block: var(--space-8);
	overflow: hidden;
}

@media (min-width: 768px) {
	.hero {
		padding-block: var(--space-9);
	}
}

.hero__split {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-7);
	align-items: center;
}

@media (min-width: 768px) {
	.hero__split {
		grid-template-columns: 1.1fr 1fr;
		gap: var(--space-8);
	}
}

@media (min-width: 1024px) {
	.hero__split {
		gap: var(--space-9);
	}
}

.hero__content {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
	max-width: 32rem;
}

.hero__eyebrow {
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--brand-primary);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	margin-bottom: 0;
}

.hero__title {
	font-size: var(--text-5xl);
	color: var(--brand-dark);
	margin: 0;
}

.hero__lede {
	font-size: var(--text-lg);
	line-height: var(--lh-normal);
	color: var(--brand-text);
	margin: 0;
}

.hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	margin-top: var(--space-3);
}

.hero__media {
	position: relative;
	border-radius: var(--radius-md);
	overflow: hidden;
	background-color: var(--brand-border);
	aspect-ratio: 4 / 3;
}

.hero__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Hero görseli yokken — sage + terracotta gradient placeholder. Watermarklı
   stok foto kullanmaktan iyidir; admin Customizer'dan yükleyince kaybolur. */
.hero__placeholder {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--space-3);
	background:
		linear-gradient(135deg, var(--brand-cream) 0%, var(--brand-border) 100%);
	color: var(--brand-dark);
	opacity: 0.6;
}

.hero__placeholder svg {
	width: 80px;
	height: 80px;
	opacity: 0.6;
}

.hero__placeholder span {
	font-size: var(--text-sm);
	font-weight: 500;
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	color: var(--brand-muted);
}

/* Hero variants — anasayfa için
   Diğer tüm sayfalar `.page-hero` (aşağıda) bileşenini kullanır. */
.hero--compact { padding-block: var(--space-7); }
.hero--small   { padding-block: var(--space-6); }

/* ==========================================================================
   Page Hero — STANDART
   --------------------------------------------------------------------------
   Anasayfa dışındaki TÜM sayfaların başlık alanı için tek bileşen.
   Cart, Checkout, Hesabım, Hakkımızda, İletişim, Shop archive, Kategori,
   Blog archive, Tek yazı (header) hepsi bu kuralla çalışır.

   Yapı:
   <section class="section section--cream page-hero">
     <div class="container">
       <div class="page-hero__inner">
         <span class="eyebrow">…</span>      (opsiyonel)
         <h1 class="page-hero__title">…</h1>
         <p class="page-hero__lede">…</p>     (opsiyonel)
       </div>
       <nav class="page-hero__filters">…</nav> (opsiyonel — blog/shop için)
     </div>
   </section>
   ========================================================================== */
.page-hero {
	padding-block: var(--space-6) var(--space-5);
}

@media (min-width: 768px) {
	.page-hero {
		padding-block: var(--space-7) var(--space-6);
	}
}

.page-hero__inner {
	max-width: 48rem;
	margin-inline: auto;
	text-align: center;
}

.page-hero .eyebrow {
	display: inline-block;
	margin-bottom: var(--space-3);
}

.page-hero__title {
	/* h1 zaten --font-display (Playfair) — explicit override yapmıyoruz, h1 default'u
	   yeterli. Editorial dokunuş "page-hero" gibi büyük marka anlarında kalır.
	   --text-3xl: clamp 28-36px (eski --text-4xl 32-44 idi, /hesabim/ sayfasında
	   çok büyük gözüküyordu). */
	font-size: var(--text-3xl);
	font-weight: 700;
	line-height: var(--lh-tight);
	letter-spacing: var(--tracking-tight);
	color: var(--brand-dark);
	margin: 0 0 var(--space-3);
	/* WC kategori adı admin'de "BAL POLEN" gibi all-caps kaydedilmişse de
	   görsel olarak title-case render et (text-transform: none yetmez,
	   `text-transform: capitalize` da değiştirmez gerçek karakterleri).
	   Burada sadece parent CSS uppercase'i ezmek için. */
	text-transform: none;
}

.page-hero__lede {
	font-size: var(--text-lg);
	line-height: var(--lh-snug);
	color: var(--brand-muted);
	max-width: 38rem;
	margin: 0 auto;
}

/* Hero altındaki opsiyonel filtre nav'ı (blog kategori, shop sıralama vb.) */
.page-hero__filters {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space-2);
	margin-top: var(--space-6);
}

.page-hero__filters .tag.tag--active,
.page-hero__filters .tag[aria-pressed="true"] {
	background-color: var(--brand-dark);
	border-color: var(--brand-dark);
	color: var(--brand-cream);
}

/* ==========================================================================
   Modal — bülten, hızlı görüntüleme
   ========================================================================== */
.modal {
	position: fixed;
	inset: 0;
	z-index: var(--z-modal);
	display: none;
	align-items: center;
	justify-content: center;
	padding: var(--space-5);
	background-color: rgba(26, 26, 26, 0.55);
}

.modal[aria-hidden="false"] { display: flex; }

.modal__panel {
	background-color: var(--brand-white);
	border-radius: var(--radius-md);
	max-width: 32rem;
	width: 100%;
	padding: var(--space-7);
	position: relative;
	box-shadow: var(--shadow-lg);
}

.modal__close {
	position: absolute;
	top: var(--space-3);
	right: var(--space-3);
	width: 2.5rem;
	height: 2.5rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--radius-full);
	color: var(--brand-muted);
	transition: background-color var(--duration-2) var(--ease);
}

.modal__close:hover {
	background-color: var(--brand-cream);
	color: var(--brand-dark);
}

/* ==========================================================================
   Tag list — kategori filtreleri, etiketler
   ========================================================================== */
.tag {
	display: inline-flex;
	align-items: center;
	padding: 0.5rem 1rem;
	font-size: var(--text-sm);
	font-weight: 500;
	color: var(--brand-dark);
	background-color: transparent;
	border: 1px solid var(--brand-border);
	border-radius: var(--radius-full);
	transition:
		background-color var(--duration-2) var(--ease),
		border-color var(--duration-2) var(--ease),
		color var(--duration-2) var(--ease);
}

.tag:hover,
.tag[aria-pressed="true"] {
	background-color: var(--brand-dark);
	border-color: var(--brand-dark);
	color: var(--brand-cream);
}

/* ==========================================================================
   Site Header — 3 satır yapı (2026-05-10 pivot)
   --------------------------------------------------------------------------
   Row 1: promo bar (koyu yeşil, beyaz metin, ince)
   Row 2: main — logo + büyük search + utilities (sipariş takip, hesabım, sepet)
   Row 3: nav — kategori linkleri (basit, mega menü değil)
   Sticky tüm header. Mobilde Row 3 drawer'a düşer, utility label'ları gizlenir.
   ========================================================================== */
.site-header {
	position: sticky;
	top: 0;
	z-index: var(--z-sticky);
	background-color: var(--brand-white);
	padding: 0; /* parent envo-shop `padding: 15px 0` veriyor — üst beyaz boşluğu yaratıyordu */
	transition: box-shadow var(--duration-2) var(--ease);
}

.site-header.is-scrolled {
	box-shadow: var(--shadow-sm);
}

/* Header containers full-width; section'lardan farklı padding ile nefes alır */
.site-header .container {
	max-width: none;
	padding-inline: clamp(1rem, 3.5vw, 4rem);
}

/* ----- Row 1: Promo bar -------------------------------------------------- */
.site-header__promo {
	background-color: var(--brand-dark);
	color: var(--brand-cream);
	font-size: var(--text-xs);
	letter-spacing: var(--tracking-wide);
}

.site-header__promo-text {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	margin: 0;
	padding-block: 0.5rem;
	color: inherit;
	font-weight: 500;
}

.site-header__promo-text svg {
	flex-shrink: 0;
	opacity: 0.85;
}

/* ----- Row 2: Main header ----------------------------------------------- */
.site-header__main {
	background-color: var(--brand-white);
}

.site-header__main-inner {
	display: grid;
	/* Mobile'da basit auto-1fr-auto, search çok yer kaplamasın.
	   Desktop'ta 1fr ortada 1fr — search sayfanın ortasında simetrik durur,
	   logo ve utilities yan kolonların farklı genişliği simetriyi bozmaz. */
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: var(--space-4);
	min-height: 4rem;
	padding-block: var(--space-3);
}

@media (min-width: 768px) {
	.site-header__main-inner {
		/* `minmax(0, 1fr)` — `1fr`'in default `minmax(auto, 1fr)` davranışı 1fr
		   kolonları içerik genişliğinden küçültmüyor. Logo ve utilities'in farklı
		   genişlikleri varsa (utilities daha geniş) sağ kolon sol kolondan büyük
		   çıkıyor → search sola kayıyor. minmax(0, 1fr) ile her iki yan kolon
		   sıfıra kadar shrink edebilir, free space gerçekten 50/50 paylaşılır. */
		grid-template-columns: minmax(0, 1fr) minmax(auto, 32rem) minmax(0, 1fr);
		min-height: 4.5rem;
		gap: var(--space-5);
	}
}

@media (min-width: 1024px) {
	.site-header__main-inner {
		min-height: 5rem;
	}
}

/* Logo sol kolonda kendine yer bulur, utilities sağ kolonda end'e hizalanır.
   Bu sayede search merkez kolonda görsel simetride kalır. */
@media (min-width: 768px) {
	.site-header__brand {
		justify-self: start;
	}
	.site-header__utilities {
		justify-self: end;
	}
}

.site-header__brand {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: 700;
	color: var(--brand-dark);
	text-decoration: none;
	line-height: 1;
}

@media (min-width: 768px) {
	.site-header__brand {
		font-size: var(--text-2xl);
	}
}

.site-header__brand:hover {
	color: var(--brand-primary);
}

.site-header__brand img {
	max-height: 48px;
	width: auto;
}

/* ----- Row 3: Nav row --------------------------------------------------- */
.site-header__nav-row {
	background-color: var(--brand-white);
	display: none;
}

@media (min-width: 1024px) {
	.site-header__nav-row {
		display: block;
	}
}

.site-header__nav-row .site-nav__list {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-7);
	margin: 0;
	padding: 0.625rem 0;
	list-style: none;
}

.site-nav__list {
	display: flex;
	align-items: center;
	gap: var(--space-6);
	margin: 0;
	padding: 0;
	list-style: none;
}

.site-nav__list > li {
	position: relative; /* dropdown için anchor */
}

.site-nav__list > li > a {
	display: inline-block;
	padding: var(--space-2) 0;
	font-family: var(--font-body);
	font-size: 0.9375rem; /* 15px — kompakt nav, modern e-comm tonu */
	font-weight: 500;
	color: var(--brand-dark);
	letter-spacing: var(--tracking-normal);
	text-transform: none;
	position: relative;
}

.site-nav__list > li > a::after {
	content: "";
	position: absolute;
	left: 0;
	right: 100%;
	bottom: -2px;
	height: 2px;
	background-color: var(--brand-primary);
	transition: right var(--duration-3) var(--ease);
}

.site-nav__list > li > a:hover,
.site-nav__list > li.current-menu-item > a,
.site-nav__list > li.current_page_item > a,
.site-nav__list > li.current-menu-ancestor > a {
	color: var(--brand-primary);
}

.site-nav__list > li > a:hover::after,
.site-nav__list > li.current-menu-item > a::after,
.site-nav__list > li.current_page_item > a::after,
.site-nav__list > li.current-menu-ancestor > a::after {
	right: 0;
}

/* ----- Submenu dropdown (depth 2) -------------------------------------- */
.site-nav__list .sub-menu {
	position: absolute;
	top: 100%;
	left: -0.5rem;
	min-width: 14rem;
	margin: 0;
	padding: var(--space-2);
	list-style: none;
	background-color: var(--brand-white);
	border: 1px solid var(--brand-border);
	border-radius: var(--radius);
	box-shadow: var(--shadow-md);
	z-index: var(--z-overlay);

	/* Görünürlük — opacity + visibility ile yumuşak geçiş */
	opacity: 0;
	visibility: hidden;
	transform: translateY(-4px);
	transition:
		opacity var(--duration-2) var(--ease),
		visibility var(--duration-2) var(--ease),
		transform var(--duration-2) var(--ease);
	pointer-events: none;
}

.site-nav__list > li:hover > .sub-menu,
.site-nav__list > li:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: none;
	pointer-events: auto;
}

/* Hover hedefini büyütmek için "hayalet köprü" — alt menüye geçişte boşluk olmasın */
.site-nav__list > li > a {
	padding-bottom: var(--space-3);
}

.site-nav__list .sub-menu li {
	display: block;
}

.site-nav__list .sub-menu a {
	display: block;
	padding: var(--space-2) var(--space-3);
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: 500;
	color: var(--brand-dark);
	border-radius: var(--radius-sm);
	letter-spacing: var(--tracking-normal);
	text-transform: none;
}

.site-nav__list .sub-menu a:hover,
.site-nav__list .sub-menu .current-menu-item > a {
	background-color: var(--brand-cream);
	color: var(--brand-primary);
}

/* Caret — dropdown'lı parent item'da, yazıdan SONRA.
   `::before` kullanıyoruz çünkü base hover-underline `::after`'a sahip;
   aynı pseudo'yu paylaşmak çakışma yaratıyor. Triangle CSS border ile çiziliyor. */
.site-nav__list > li.menu-item-has-children > a {
	padding-right: 0.95em; /* caret için yer */
}

.site-nav__list > li.menu-item-has-children > a::before {
	content: "";
	position: absolute;
	right: 0;
	top: 50%;
	margin-top: -2px;
	width: 0;
	height: 0;
	border-left: 4px solid transparent;
	border-right: 4px solid transparent;
	border-top: 4px solid currentColor;
	opacity: 0.6;
	transition: transform var(--duration-2) var(--ease);
	transform-origin: 50% 25%;
}

.site-nav__list > li.menu-item-has-children:hover > a::before,
.site-nav__list > li.menu-item-has-children:focus-within > a::before {
	transform: rotate(180deg);
}

/* ----- Header utilities (sipariş takip + hesabım + sepet + hamburger) ---
   Row 2'nin sağında. Her utility = icon (üst) + label (alt). Mobile'da label
   gizlenir, hamburger görünür. Desktop ≥1024px label görünür. */
.site-header__utilities {
	display: flex;
	align-items: center;
	gap: var(--space-1);
	justify-self: end;
}

@media (min-width: 768px) {
	.site-header__utilities {
		gap: var(--space-3);
	}
}

.utility {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 4px;
	min-width: 2.75rem;
	min-height: 2.75rem;
	padding: 0.375rem 0.5rem;
	border-radius: var(--radius);
	color: var(--brand-dark);
	background-color: transparent;
	text-decoration: none;
	font-family: var(--font-body);
	font-size: var(--text-xs);
	font-weight: 500;
	line-height: 1;
	transition: color var(--duration-2) var(--ease), background-color var(--duration-2) var(--ease);
	position: relative;
}

.utility:hover,
.utility:focus-visible {
	color: var(--brand-primary);
	background-color: var(--brand-cream);
}

.utility svg {
	width: 22px;
	height: 22px;
}

.utility__label {
	display: none; /* mobile/tablet: sadece icon */
}

@media (min-width: 1024px) {
	.utility__label {
		display: inline;
		font-size: var(--text-xs);
		letter-spacing: 0.02em;
	}
}

/* Sepet ikon + count badge */
.utility__icon-wrap {
	position: relative;
	display: inline-flex;
}

.utility__count {
	position: absolute;
	top: -6px;
	right: -8px;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-body);
	font-size: 11px;
	font-weight: 600;
	line-height: 1;
	color: var(--brand-white);
	background-color: var(--brand-primary);
	border-radius: var(--radius-full);
}

/* Mobile: sipariş takip linkini gizle (sınırlı yer), desktop'ta görünür */
.utility--track {
	display: none;
}

@media (min-width: 768px) {
	.utility--track {
		display: inline-flex;
	}
}

/* Geriye dönük uyumluluk — eski .site-header__actions hâlâ kullanılırsa */
.site-header__actions {
	display: flex;
	align-items: center;
	gap: var(--space-1);
	justify-self: end;
}

/* ----- Header search bar — Row 2 ortasında, büyük ve belirgin ----------
   Desktop ≥768px: inline visible. Mobile <768px: icon-btn modal trigger devreye
   girer (`.header-search__toggle`). */
.header-search {
	display: none;
	align-items: center;
	gap: var(--space-2);
	width: 100%;
	max-width: 32rem;
	margin-inline: auto;
	padding: 0.625rem 1rem;
	background-color: var(--brand-cream);
	border: 1px solid transparent;
	border-radius: var(--radius-full);
	transition: border-color var(--duration-2) var(--ease), box-shadow var(--duration-2) var(--ease), background-color var(--duration-2) var(--ease);
}

.header-search:focus-within {
	background-color: var(--brand-white);
	border-color: var(--brand-dark);
	box-shadow: 0 0 0 3px rgba(44, 62, 45, 0.10);
}

.header-search__icon {
	flex-shrink: 0;
	width: 18px;
	height: 18px;
	color: var(--brand-muted);
}

/* Parent envo-shop `input[type="search"]` global'i bizim input'a 1px #bbb border,
   10px border-radius, 8px padding, beyaz bg veriyor. Specificity'sini ezmek için
   `.header-search` ancestor + `input[type="search"]` ile (0,2,1) > parent (0,1,1). */
.header-search input[type="search"].header-search__input,
.header-search__input {
	flex: 1;
	min-width: 0;
	width: auto;
	border: 0;
	border-radius: 0;
	outline: none;
	background: transparent;
	background-image: none;
	font-family: var(--font-body);
	font-size: var(--text-sm);
	color: var(--brand-text);
	padding: 0;
	display: block;
}

.header-search__input::placeholder {
	color: var(--brand-muted);
}

.header-search__input::-webkit-search-cancel-button {
	-webkit-appearance: none;
	appearance: none;
}

@media (min-width: 768px) {
	.header-search {
		display: flex;
	}
	/* `.icon-btn` selector'ünün display: inline-flex'ini ezmek için
	   specificity bump (iki class). Aksi halde toggle desktop'ta görünür. */
	.icon-btn.header-search__toggle {
		display: none;
	}
}

.icon-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.75rem;
	height: 2.75rem;
	border-radius: var(--radius-full);
	color: var(--brand-dark);
	background-color: transparent;
	transition: background-color var(--duration-2) var(--ease), color var(--duration-2) var(--ease);
	position: relative;
}

.icon-btn:hover,
.icon-btn:focus-visible {
	background-color: var(--brand-border);
	color: var(--brand-primary);
}

.icon-btn svg {
	width: 22px;
	height: 22px;
}

.icon-btn__count {
	position: absolute;
	top: 4px;
	right: 4px;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-body);
	font-size: 11px;
	font-weight: 600;
	line-height: 1;
	color: var(--brand-white);
	background-color: var(--brand-primary);
	border-radius: var(--radius-full);
}

/* Hamburger sadece mobilde görünür */
.menu-toggle {
	display: inline-flex;
}

@media (min-width: 1024px) {
	.menu-toggle {
		display: none;
	}
}

.menu-toggle__bars {
	display: inline-flex;
	flex-direction: column;
	gap: 5px;
	width: 22px;
}

.menu-toggle__bars span {
	display: block;
	height: 2px;
	background-color: currentColor;
	border-radius: 2px;
	transition: transform var(--duration-2) var(--ease), opacity var(--duration-2) var(--ease);
}

.menu-toggle[aria-expanded="true"] .menu-toggle__bars span:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}
.menu-toggle[aria-expanded="true"] .menu-toggle__bars span:nth-child(2) {
	opacity: 0;
}
.menu-toggle[aria-expanded="true"] .menu-toggle__bars span:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

/* ----- Mobile menü drawer ----------------------------------------------- */
.mobile-menu {
	position: fixed;
	inset: 6rem 0 0 0; /* mobile'da promo (32px) + main row (64px) toplamı ~96px */
	z-index: calc(var(--z-sticky) - 1);
	background-color: var(--brand-cream);
	transform: translateX(100%);
	transition: transform var(--duration-3) var(--ease);
	overflow-y: auto;
	padding: var(--space-6) var(--container-pad);
}

.mobile-menu.is-open {
	transform: translateX(0);
}

@media (min-width: 1024px) {
	.mobile-menu {
		display: none;
	}
}

.mobile-menu ul {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.mobile-menu a {
	display: block;
	padding: var(--space-3) 0;
	font-family: var(--font-heading);
	font-size: var(--text-2xl);
	font-weight: 600;
	color: var(--brand-dark);
	border-bottom: 1px solid var(--brand-border);
}

.mobile-menu a:hover,
.mobile-menu .current-menu-item > a {
	color: var(--brand-primary);
}

body.has-menu-open {
	overflow: hidden;
}

/* ----- Search modal ----------------------------------------------------- */
.search-modal .modal__panel {
	max-width: 36rem;
}

.search-modal .input {
	font-size: var(--text-lg);
}

/* ==========================================================================
   Site Footer
   --------------------------------------------------------------------------
   Üst: 4 sütun (marka açıklaması + 3 link kolonu).
   Alt: telif, KVKK / Mesafeli Satış / Çerez linkleri, ödeme ikonları.
   ========================================================================== */
.site-footer {
	background-color: var(--brand-dark);
	color: var(--brand-cream);
	padding-block: var(--space-8) var(--space-6);
	margin-top: auto;
}

/* Footer container header ile aynı genişlik kuralını kullanır:
   tam genişlik zemin, içerik fluid padding ile (clamp 16-64px). */
.site-footer > .container {
	max-width: none;
	padding-inline: clamp(1rem, 3.5vw, 4rem);
}

.site-footer a {
	color: var(--brand-cream);
}

.site-footer a:hover,
.site-footer a:focus-visible {
	color: var(--brand-secondary);
}

.site-footer__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-7);
	padding-bottom: var(--space-7);
	border-bottom: 1px solid rgba(255, 255, 255, 0.14);
}

@media (min-width: 640px) {
	.site-footer__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.site-footer__grid {
		grid-template-columns: 1.5fr repeat(3, 1fr);
		gap: var(--space-8);
	}
}

.site-footer__col-title {
	font-family: var(--font-heading);
	font-size: var(--text-2xl);
	font-weight: 600;
	color: var(--brand-cream);
	margin-bottom: var(--space-5);
}

.site-footer__brand {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	max-width: 24rem;
}

.site-footer__brand-name {
	font-family: var(--font-display);
	font-size: 2rem;
	font-weight: 700;
	color: var(--brand-cream);
	letter-spacing: var(--tracking-tight);
}

.site-footer__about {
	font-size: var(--text-base);
	line-height: var(--lh-normal);
	color: rgba(255, 255, 255, 0.85);
	margin: 0;
}

.site-footer__list {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.site-footer__list a {
	font-size: var(--text-base);
	color: rgba(255, 255, 255, 0.85);
	transition: color var(--duration-2) var(--ease);
}

.site-footer__list a:hover {
	color: var(--brand-secondary);
}

.site-footer__contact {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	font-size: var(--text-base);
	color: rgba(255, 255, 255, 0.9);
	line-height: var(--lh-normal);
}

.site-footer__contact strong {
	color: var(--brand-cream);
	font-weight: 600;
}

.site-footer__social {
	display: flex;
	gap: var(--space-2);
	margin-top: var(--space-3);
}

.site-footer__social a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: var(--radius-full);
	background-color: rgba(255, 255, 255, 0.10);
	color: var(--brand-cream);
	transition: background-color var(--duration-2) var(--ease), color var(--duration-2) var(--ease);
}

.site-footer__social a:hover {
	background-color: var(--brand-secondary);
	color: var(--brand-dark);
}

.site-footer__social svg {
	width: 18px;
	height: 18px;
}

.site-footer__bottom {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3) var(--space-5);
	align-items: center;
	justify-content: space-between;
	padding-top: var(--space-5);
}

.site-footer__copy {
	font-size: var(--text-base);
	color: rgba(255, 255, 255, 0.75);
	margin: 0;
}

.site-footer__legal {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-5);
}

.site-footer__legal a {
	font-size: var(--text-base);
	color: rgba(255, 255, 255, 0.75);
}

/* ==========================================================================
   Reveal — Intersection Observer ile fade-in
   JS .is-visible class'ı ekler.
   ========================================================================== */
.reveal {
	opacity: 0;
	transform: translateY(16px);
	transition:
		opacity var(--duration-3) var(--ease-out),
		transform var(--duration-3) var(--ease-out);
}

.reveal.is-visible {
	opacity: 1;
	transform: none;
}
