/* =========================================================================
   Kuda Mas — Stylesheet utama (fondasi theme)
   ========================================================================= */

/* ---------- Font self-hosted: Glacial Indifference ---------- */
@font-face {
	font-family: 'Glacial Indifference';
	src:
		url('../fonts/GlacialIndifference-Regular.woff2') format('woff2'),
		url('../fonts/GlacialIndifference-Regular.woff') format('woff');
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: 'Glacial Indifference';
	src:
		url('../fonts/GlacialIndifference-Bold.woff2') format('woff2'),
		url('../fonts/GlacialIndifference-Bold.woff') format('woff');
	font-weight: 700;
	font-style: normal;
	font-display: swap;
}

/* ---------- CSS Variables (brand palette) ---------- */
:root {
	--color-burgundy: #4b0b15;
	--color-italian-roast: #370009;
	--color-vintage-beige: #9f8f87;
	--color-champagne-beige: #f2e2c6;
	--color-black: #000000;
	--color-white: #ffffff;
	/* Aksen emas — dipakai terbatas untuk elemen "premium" tertentu (label
	   Distributor, hero homepage), bukan pengganti palet utama di atas. */
	--color-gold: #d4af37;

	--color-bg: var(--color-italian-roast);
	--color-text: var(--color-champagne-beige);

	--font-heading: 'Cinzel Decorative', serif;
	--kudamas-font-product: 'Cinzel', serif;
	--font-body: 'Glacial Indifference', 'Montserrat', system-ui, sans-serif;

	--container-width: 1200px;
	--transition-fast: 0.2s ease;
	--transition-base: 0.35s ease;
}

/* ---------- Reset ringan ---------- */
*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	background-color: var(--color-bg);
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: 16px;
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
}

img {
	display: block;
	max-width: 100%;
	height: auto;
}

a {
	color: inherit;
	text-decoration: none;
	transition: color var(--transition-fast), opacity var(--transition-fast);
}

ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

button {
	font-family: inherit;
	cursor: pointer;
}

/* ---------- Aksesibilitas ---------- */
.screen-reader-text {
	position: absolute !important;
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	overflow: hidden;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	word-wrap: normal !important;
	border: 0;
}

/* ---------- Layout helpers ---------- */
.kudamas-container {
	width: 100%;
	max-width: var(--container-width);
	margin: 0 auto;
	padding: 0 24px;
}

/* ---------- Tipografi display (HANYA untuk heading besar: hero, judul section) ---------- */
.kudamas-heading-display {
	font-family: var(--font-heading);
	font-weight: 700;
	line-height: 1.25;
	letter-spacing: 0.04em;
	color: var(--color-champagne-beige);
}

/* ---------- Button dasar ---------- */
.btn-primary {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 32px;
	border: 1px solid var(--color-burgundy);
	border-radius: 8px;
	background-color: var(--color-burgundy);
	color: var(--color-champagne-beige);
	font-size: 15px;
	letter-spacing: 0.02em;
	transition: background-color var(--transition-base), color var(--transition-base), transform var(--transition-fast);
}

.btn-primary:hover,
.btn-primary:focus-visible {
	transform: translateY(-1px);
	background-color: var(--color-champagne-beige);
	color: var(--color-italian-roast);
}

.btn-outline {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 32px;
	border: 1px solid var(--color-champagne-beige);
	border-radius: 8px;
	background-color: transparent;
	color: var(--color-champagne-beige);
	font-size: 15px;
	letter-spacing: 0.02em;
	transition: background-color var(--transition-base), color var(--transition-base), transform var(--transition-fast);
}

.btn-outline:hover,
.btn-outline:focus-visible {
	transform: translateY(-1px);
	background-color: var(--color-champagne-beige);
	color: var(--color-italian-roast);
}

.btn-gold {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 32px;
	border: 2px solid var(--color-champagne-beige);
	border-radius: 6px;
	background-color: var(--color-champagne-beige);
	color: var(--color-italian-roast);
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	transition: background-color var(--transition-base), color var(--transition-base), transform var(--transition-fast);
}

.btn-gold:hover,
.btn-gold:focus-visible {
	transform: translateY(-1px);
	background-color: var(--color-vintage-beige);
	border-color: var(--color-vintage-beige);
}

/* =========================================================================
   Header
   ========================================================================= */
.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	width: 100%;
	/* Gradient gelap tipis ke transparan: header tetap "tidak terlihat" tapi
	   teks menu terbaca di atas latar apa pun tanpa perlu background solid. */
	background: linear-gradient(to bottom, rgba(10, 0, 3, 0.55) 0%, transparent 100%);
	transition: background var(--transition-base), box-shadow var(--transition-base), backdrop-filter var(--transition-base), transform var(--transition-base);
}

.site-header.is-scrolled {
	background: rgba(20, 0, 4, 0.45);
	backdrop-filter: blur(8px);
	box-shadow: 0 2px 18px rgba(0, 0, 0, 0.35);
}

.site-header.is-hidden {
	transform: translateY(-100%);
}

.site-header__inner {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 22px 36px;
	transition: padding var(--transition-base);
}

.site-header.is-scrolled .site-header__inner {
	padding: 14px 36px;
}

/* Logo ikon kecil pojok kiri atas — di homepage, sengaja disembunyikan
   selama section hero (yang sudah punya logo besarnya sendiri) lalu
   muncul dengan fade + geser halus begitu user scroll masuk ke section
   "Our Story" dan seterusnya (lihat data-section di initScrollSpy(),
   homepage-animate.js). Di halaman lain (tanpa scroll-spy ini) elemen
   tetap tersembunyi secara default. */
.site-header__icon-logo {
	position: absolute;
	left: 36px;
	top: 50%;
	z-index: 1;
	display: inline-flex;
	opacity: 0;
	transform: translateY(-50%) translateX(-10px);
	transition: opacity 0.6s ease, transform 0.6s ease;
	pointer-events: none;
}

.site-header__icon-logo img {
	display: block;
	height: 32px;
	width: auto;
}

/* Homepage: logo muncul begitu scroll melewati section hero (scroll-spy). */
body.home .site-header[data-section]:not([data-section="home"]) .site-header__icon-logo {
	opacity: 1;
	transform: translateY(-50%) translateX(0);
	pointer-events: auto;
}

/* Semua halaman lain: logo selalu terlihat (tidak ada scroll-spy). */
body:not(.home) .site-header__icon-logo {
	opacity: 1;
	transform: translateY(-50%) translateX(0);
	pointer-events: auto;
}

/* Single produk: body bg disamakan dengan hero (#0a0002) agar header transparan
   tidak memperlihatkan warna body yang berbeda di belakang nav. */
body.single-produk {
	background-color: #0a0002;
}

body.single-produk .site-header:not(.is-scrolled) {
	background: transparent;
}

/* Our Story: header transparan di atas hero — gambar terlihat di balik nav dari y=0. */
body.page-template-template-our-story-php .site-header:not(.is-scrolled) {
	background: transparent;
}

/* Saat admin bar aktif, WP menambahkan margin-top: 32px pada <html> sehingga
   seluruh konten turun 32px. Kompensasi tambahan supaya hero tetap menutupi
   area di balik header tanpa celah tipis di bagian atas. */
html.admin-bar .kudamas-story-hero {
	margin-top: calc(-100px - 32px);
	padding-top: calc(150px + 32px);
}

@media (prefers-reduced-motion: reduce) {
	.site-header__icon-logo {
		transition: none;
	}
}

.site-header__nav {
	display: flex;
}

.kudamas-nav-menu {
	display: flex;
	align-items: center;
	gap: 36px;
}

.kudamas-nav-menu a {
	position: relative;
	display: inline-block;
	padding: 6px 0;
	color: var(--color-champagne-beige);
	font-size: 16px;
	letter-spacing: 0.01em;
}

.kudamas-nav-menu a::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: 0;
	width: 0;
	height: 1px;
	background-color: var(--color-champagne-beige);
	transition: width var(--transition-base);
}

.kudamas-nav-menu a:hover::after,
.kudamas-nav-menu a:focus-visible::after {
	width: 100%;
}

.kudamas-nav-menu .current-menu-item > a::after,
.kudamas-nav-menu .current_page_item > a::after {
	width: 100%;
}

/* Di homepage, underline statis current-menu-item digantikan scroll-spy
   dinamis (lihat .is-scroll-active) supaya cuma satu indikator yang aktif. */
body.home .kudamas-nav-menu .current-menu-item > a::after,
body.home .kudamas-nav-menu .current_page_item > a::after {
	width: 0;
}

.kudamas-nav-menu a.is-scroll-active::after {
	width: 100%;
}

/* ---------- Nav: aksen emas di semua halaman saat header transparan (belum
   discroll). Begitu discroll, nav kembali ke champagne-beige standar. ---------- */
.site-header:not(.is-scrolled) .kudamas-nav-menu a {
	color: var(--color-gold);
}

.site-header:not(.is-scrolled) .kudamas-nav-menu a::after {
	background-color: var(--color-gold);
}

/* Indikator scroll-spy (titik + bold) khusus homepage. */
body.home .site-header:not(.is-scrolled) .kudamas-nav-menu a.is-scroll-active {
	font-weight: 700;
}

body.home .site-header:not(.is-scrolled) .kudamas-nav-menu a.is-scroll-active::before {
	content: '\2726';
	position: absolute;
	left: 50%;
	bottom: -16px;
	font-size: 9px;
	color: var(--color-gold);
	transform: translateX(-50%);
}

/* ---------- Header: tint transparan-gelap elegan berlaku di semua halaman
   (background 45% diset langsung pada .site-header.is-scrolled di atas).
   Di homepage, scroll-spy underline "mengalir" mengikuti section aktif. ---------- */

.site-header__toggle {
	display: none;
	flex-direction: column;
	gap: 5px;
	padding: 6px;
	background: none;
	border: none;
}

.site-header__toggle-bar {
	width: 24px;
	height: 2px;
	background-color: var(--color-champagne-beige);
	transition: transform var(--transition-base), opacity var(--transition-base);
}

.site-header__toggle.is-active .site-header__toggle-bar:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

.site-header__toggle.is-active .site-header__toggle-bar:nth-child(2) {
	opacity: 0;
}

.site-header__toggle.is-active .site-header__toggle-bar:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

@media (max-width: 880px) {
	.site-header__toggle {
		display: flex;
	}

	.site-header__nav {
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		max-height: 0;
		flex-direction: column;
		overflow: hidden;
		background-color: rgba(20, 0, 4, 0.97);
		transition: max-height var(--transition-base);
	}

	.site-header__nav.is-open {
		max-height: 480px;
	}

	.kudamas-nav-menu {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		padding: 12px 24px 20px;
	}

	.kudamas-nav-menu li {
		border-bottom: 1px solid rgba(242, 226, 198, 0.12);
	}

	.kudamas-nav-menu a {
		display: block;
		padding: 14px 0;
	}
}

/* =========================================================================
   Konten dasar (index.php fallback)
   ========================================================================= */
.site-main {
	padding: 64px 0;
	min-height: 50vh;
}

.kudamas-entry {
	margin-bottom: 48px;
	padding-bottom: 48px;
	border-bottom: 1px solid rgba(242, 226, 198, 0.12);
}

.kudamas-entry__title {
	margin: 0 0 16px;
	font-size: 24px;
}

.kudamas-entry__empty {
	color: var(--color-vintage-beige);
}

/* =========================================================================
   Footer
   ========================================================================= */
.site-footer {
	margin-top: 56px;
	padding: 36px 24px 18px;
	background-color: #1a0306;
	color: var(--color-vintage-beige);
}

.site-footer__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 64px;
	max-width: var(--container-width);
	margin: 0 auto;
}

.site-footer__brand,
.site-footer__contact,
.site-footer__legal {
	text-align: center;
}

@media (max-width: 760px) {
	.site-footer__inner {
		flex-direction: column;
		gap: 28px;
	}
}

/* ---------- Kolom brand ---------- */
.site-footer__brand-icon {
	width: auto;
	height: 40px;
	margin: 0 auto 10px;
}

.site-footer__name-logo {
	width: auto;
	height: 26px;
	margin: 0 auto 8px;
}

.site-footer__tagline {
	margin: 0;
	color: var(--color-vintage-beige);
	font-size: 13px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

/* ---------- Heading section ("Get In Touch" / "Policies") ---------- */
.site-footer__heading {
	margin: 0 0 14px;
	color: var(--color-gold);
	font-weight: 700;
	font-size: 13px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

/* ---------- Kolom contact (WhatsApp + sosial media sebaris, hemat tinggi) ---------- */
.site-footer__contact-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 16px;
}

.site-footer__whatsapp {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: var(--color-vintage-beige);
}

.site-footer__whatsapp:hover,
.site-footer__whatsapp:focus-visible {
	color: var(--color-champagne-beige);
}

.site-footer__whatsapp-number {
	color: var(--color-champagne-beige);
	font-size: 15px;
	font-weight: 600;
}

.site-footer__social-group {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
}

.site-footer__icon-badge {
	display: inline-flex;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border: 1px solid rgba(212, 175, 55, 0.5);
	border-radius: 50%;
	color: var(--color-gold);
}

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

.site-footer__social {
	display: flex;
	align-items: center;
	gap: 10px;
}

.site-footer__social a:hover .site-footer__icon-badge,
.site-footer__social a:focus-visible .site-footer__icon-badge {
	color: var(--color-champagne-beige);
}

.site-footer__handle {
	margin: 0;
	font-size: 13px;
}

/* ---------- Kolom legal/policies (2 baris: Privacy+Cookie, lalu
   Responsible Consumption sendiri — tingginya jadi sebanding dengan kolom
   brand & contact, jadi rata tengah footer terasa lebih seimbang). ---------- */
.site-footer__legal-row {
	display: flex;
	align-items: center;
	justify-content: center;
}

.site-footer__legal-row + .site-footer__legal-row {
	margin-top: 8px;
}

.site-footer__legal-dot {
	width: 4px;
	height: 4px;
	margin: 0 14px;
	border-radius: 50%;
	background-color: rgba(242, 226, 198, 0.3);
}

.site-footer__legal a {
	font-size: 13px;
}

.site-footer__legal a:hover,
.site-footer__legal a:focus-visible {
	color: var(--color-champagne-beige);
}

.site-footer__copyright {
	max-width: var(--container-width);
	margin: 20px auto 0;
	padding-top: 14px;
	border-top: 1px solid rgba(242, 226, 198, 0.15);
	text-align: center;
	font-size: 12px;
}

/* ---------- Floating WhatsApp button ---------- */
.kudamas-whatsapp-float {
	position: fixed;
	right: 24px;
	bottom: 24px;
	z-index: 200;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	background-color: #25d366;
	border: none;
	color: #ffffff;
	box-shadow: 0 6px 20px rgba(37, 211, 102, 0.4), 0 2px 8px rgba(0, 0, 0, 0.35);
	transition: transform var(--transition-fast), box-shadow var(--transition-fast), background-color var(--transition-fast);
}

.kudamas-whatsapp-float:hover,
.kudamas-whatsapp-float:focus-visible {
	background-color: #20ba5a;
	transform: scale(1.08) translateY(-2px);
	box-shadow: 0 10px 28px rgba(37, 211, 102, 0.5), 0 4px 12px rgba(0, 0, 0, 0.35);
}

.kudamas-whatsapp-float svg {
	width: 28px;
	height: 28px;
}

/* =========================================================================
   Page wrapper dasar (dipakai page.php dan template Page lain)
   ========================================================================= */
.kudamas-page__inner {
	max-width: 760px;
	margin: 0 auto;
}

.kudamas-page__header {
	margin: 80px 0 40px;
}

.kudamas-page__title {
	margin: 0;
	font-size: clamp(32px, 4vw, 48px);
}

.kudamas-page__content {
	margin-bottom: 80px;
}

/* ---------- Prose (konten the_content() yang diketik admin di editor) ---------- */
.kudamas-prose {
	color: var(--color-champagne-beige);
	line-height: 1.8;
}

.kudamas-prose p {
	margin: 0 0 24px;
}

.kudamas-prose h2,
.kudamas-prose h3,
.kudamas-prose h4 {
	margin: 40px 0 16px;
	color: var(--color-champagne-beige);
	font-family: var(--font-body);
	font-weight: 700;
}

.kudamas-prose ul,
.kudamas-prose ol {
	margin: 0 0 24px;
	padding-left: 1.4em;
}

.kudamas-prose li {
	margin-bottom: 8px;
}

.kudamas-prose a {
	color: var(--color-champagne-beige);
	border-bottom: 1px solid var(--color-vintage-beige);
	transition: opacity var(--transition-fast);
}

.kudamas-prose a:hover,
.kudamas-prose a:focus-visible {
	opacity: 0.75;
}

.kudamas-prose img {
	margin: 24px 0;
	border-radius: 4px;
}

.kudamas-prose blockquote {
	margin: 32px 0;
	padding-left: 24px;
	border-left: 2px solid var(--color-burgundy);
	color: var(--color-vintage-beige);
	font-style: italic;
}

/* ---------- Header koleksi (dipakai archive produk & listing Journal) ---------- */
.kudamas-archive-header {
	padding: 96px 0 64px;
	text-align: center;
}

.kudamas-archive-header__brand {
	margin: 0 0 16px;
	color: var(--color-vintage-beige);
	font-size: 13px;
	letter-spacing: 0.25em;
	text-transform: uppercase;
}

.kudamas-archive-header__title {
	margin: 0 0 12px;
	font-size: clamp(36px, 5vw, 56px);
}

.kudamas-archive-header__subtitle {
	margin: 0;
	color: var(--color-vintage-beige);
	font-size: 14px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

/* ---------- Animasi masuk generik (fade + naik halus) ----------
   Dipakai oleh kartu produk (Collection) dan section homepage. Class
   "kudamas-fade-init" ditambahkan via JS; tanpa JS atau dengan
   prefers-reduced-motion aktif, elemen tetap tampil normal. */
.kudamas-fade-init {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity 0.7s ease, transform 0.7s ease;
}

.kudamas-fade-init.is-visible {
	opacity: 1;
	transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
	.kudamas-fade-init {
		opacity: 1 !important;
		transform: none !important;
		transition: none !important;
	}
}

/* ---------- Product grid & card (dipakai "Our Wines" homepage & Collection archive) ----------
   Flexbox (bukan CSS Grid) supaya baris parsial otomatis rata tengah lewat
   justify-content:center. Lebar kartu dihitung dari --kudamas-grid-cols. */
.kudamas-product-grid {
	--kudamas-grid-gap: 28px;
	--kudamas-grid-cols: 5;
	position: relative;
	z-index: 1;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--kudamas-grid-gap);
	padding-bottom: 80px;
}

@media (max-width: 1400px) {
	.kudamas-product-grid {
		--kudamas-grid-cols: 4;
	}
}

@media (max-width: 1100px) {
	.kudamas-product-grid {
		--kudamas-grid-cols: 3;
	}
}

@media (max-width: 820px) {
	.kudamas-product-grid {
		--kudamas-grid-cols: 2;
	}
}

@media (max-width: 460px) {
	.kudamas-product-grid {
		--kudamas-grid-cols: 1;
	}
}

/* max-width 260px keras supaya kartu tidak ikut melar membesar saat kolom
   sedikit/container lebar — lebar sebenarnya dipakai juga sebagai acuan
   @container query font judul di bawah. */
.kudamas-product-card {
	container-type: inline-size;
	container-name: kudamas-card;
	flex: 0 0 min(calc((100% - (var(--kudamas-grid-cols) - 1) * var(--kudamas-grid-gap)) / var(--kudamas-grid-cols)), 260px);
	max-width: min(calc((100% - (var(--kudamas-grid-cols) - 1) * var(--kudamas-grid-gap)) / var(--kudamas-grid-cols)), 260px);
	display: flex;
	flex-direction: column;
	overflow: hidden;
	border: 1px solid rgba(212, 175, 55, 0.45);
	border-radius: 6px;
	transition: transform 0.45s ease, box-shadow 0.45s ease;
}

.kudamas-product-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 22px 40px rgba(0, 0, 0, 0.4);
}

/* Elemen pemutus baris non-visual — hanya aktif di layout 5-kolom (desktop
   lebar). Di viewport lebih kecil disembunyikan supaya flexbox bebas menyusun
   ulang baris secara natural tanpa break paksa yang merusak formasi 4/3/2-col.
   Lihat kudamas_get_triangle_break_positions() di functions.php. */
.kudamas-product-grid__break {
	display: none;
}

@media (min-width: 1401px) {
	.kudamas-product-grid__break {
		display: block;
		flex-basis: 100%;
		width: 100%;
		height: 0;
		margin-top: calc(var(--kudamas-grid-gap) * -1);
	}
}

.kudamas-product-card__media {
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 1 / 1.25;
	overflow: hidden;
	padding: 1px;
	background: radial-gradient(ellipse at center, var(--color-burgundy) 0%, #1a0306 65%, #070303 100%);
}

.kudamas-product-card__media img {
	max-width: 100%;
	max-height: 100%;
	width: auto;
	height: auto;
	object-fit: contain;
	transition: transform 0.5s ease;
}

.kudamas-product-card:hover .kudamas-product-card__media img {
	transform: scale(1.06);
}

.kudamas-product-card__placeholder {
	display: block;
	width: 100%;
	height: 100%;
}

.kudamas-product-card__body {
	display: flex;
	flex: 1;
	flex-direction: column;
	padding: 22px 22px;
	background-color: var(--color-champagne-beige);
	text-align: center;
}

/* Cinzel (non-Decorative) khusus nama produk. Nama panjang SENGAJA dibiarkan
   membungkus ke baris kedua (rata tengah) alih-alih dipaksa satu baris atau
   diperkecil supaya muat — yang wajib dijaga di sini cuma containment-nya:
   tidak pernah terpotong/meluber keluar panel. */
.kudamas-product-card__title {
	margin: 0 0 6px;
	color: var(--color-burgundy);
	font-family: var(--kudamas-font-product);
	font-weight: 600;
	font-size: 14px;
	line-height: 1.3;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	text-wrap: balance;
	overflow-wrap: break-word;
	hyphens: auto;
}

@container kudamas-card (min-width: 230px) {
	.kudamas-product-card__title {
		font-size: 16px;
	}
}

.kudamas-product-card__subtitle {
	margin: -2px 0 16px;
	color: rgba(75, 11, 21, 0.7);
	font-size: 12px;
	font-style: italic;
	line-height: 1.5;
}

.kudamas-product-card__cta {
	align-self: center;
	margin-top: auto;
	padding: 6px 18px;
	border-radius: 12px;
	font-size: 11px;
}

/* ---------- Pagination (dipakai archive produk & listing Journal) ---------- */
.kudamas-pagination {
	padding-bottom: 96px;
	text-align: center;
}

.kudamas-pagination .nav-links {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 10px;
}

.kudamas-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 10px;
	border: 1px solid rgba(242, 226, 198, 0.25);
	border-radius: 2px;
	color: var(--color-champagne-beige);
	font-size: 13px;
	transition: background-color var(--transition-fast), color var(--transition-fast);
}

.kudamas-pagination .page-numbers.current {
	background-color: var(--color-burgundy);
	border-color: var(--color-burgundy);
}

.kudamas-pagination .page-numbers:hover,
.kudamas-pagination .page-numbers:focus-visible {
	background-color: var(--color-champagne-beige);
	color: var(--color-italian-roast);
}

/* ---------- Journal grid & card (dipakai homepage preview & listing Journal) ---------- */
.kudamas-journal-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
}

@media (max-width: 880px) {
	.kudamas-journal-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 600px) {
	.kudamas-journal-grid {
		grid-template-columns: 1fr;
	}
}

.kudamas-journal-card {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	border: 1px solid rgba(212, 175, 55, 0.45);
	border-radius: 4px;
	background-color: rgba(0, 0, 0, 0.18);
	transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.kudamas-journal-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 16px 32px rgba(0, 0, 0, 0.35);
}

.kudamas-journal-card__media {
	display: block;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background-color: var(--color-black);
}

.kudamas-journal-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-base);
}

.kudamas-journal-card:hover .kudamas-journal-card__media img {
	transform: scale(1.04);
}

.kudamas-journal-card__placeholder {
	display: block;
	width: 100%;
	height: 100%;
}

.kudamas-journal-card__body {
	display: flex;
	flex: 1;
	flex-direction: column;
	padding: 24px;
}

/* Label kategori post di atas judul, dengan garis bawah pendek sebagai
   aksen — data kategori sudah ada lewat WP (get_the_category), hanya baru
   ditampilkan di kartu Journal. */
.kudamas-journal-card__category {
	position: relative;
	display: inline-block;
	margin: 0 0 12px;
	padding-bottom: 6px;
	color: var(--color-gold);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.kudamas-journal-card__category::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: 0;
	width: 28px;
	height: 1px;
	background-color: var(--color-gold);
}

.kudamas-journal-card__title {
	margin: 0 0 10px;
	font-size: 25px;
}

.kudamas-journal-card__excerpt {
	margin: 0 0 16px;
	color: var(--color-vintage-beige);
	font-size: 14px;
	line-height: 1.7;
}

.kudamas-journal-card__link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	align-self: flex-start;
	margin-top: auto;
	padding-bottom: 2px;
	border-bottom: 1px solid var(--color-champagne-beige);
	color: var(--color-champagne-beige);
	font-size: 12px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.kudamas-journal-card__link-arrow {
	width: 14px;
	height: 14px;
	flex-shrink: 0;
}

/* ---------- Journal: tombol "Lihat Semua Artikel" di bawah grid ---------- */
.kudamas-journal__more {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 28px;
	border: 1px solid var(--color-gold);
	border-radius: 999px;
	color: var(--color-gold);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	transition: background-color var(--transition-base), color var(--transition-base), transform var(--transition-fast);
}

.kudamas-journal__more:hover,
.kudamas-journal__more:focus-visible {
	background-color: var(--color-gold);
	color: var(--color-italian-roast);
	transform: translateY(-2px);
}

.kudamas-journal__more-icon,
.kudamas-journal__more-arrow {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}

/* ---------- Distributor band (dipakai homepage & Our Story) ---------- */
.kudamas-distributor-band {
	background-color: var(--color-burgundy);
}

.kudamas-distributor-band__inner {
	max-width: 640px;
	margin: 0 auto;
	text-align: center;
}

.kudamas-distributor-band__inner p {
	margin: 16px 0 32px;
	color: var(--color-champagne-beige);
}

/* ---------- Distributor band: varian berpeta (homepage) ---------- */

/* Label "KUDA MAS" menggunakan logo wordmark (img.kudamas-distributor-band__label-logo)
   — bukan teks lagi. */
.kudamas-distributor-band__label-logo {
	display: block;
	height: 28px;
	width: auto;
	margin: 0 auto 12px;
}

.kudamas-distributor-band--map .kudamas-distributor-band__inner p {
	margin: 0 auto 0;
	max-width: 480px;
	color: var(--color-champagne-beige);
	font-size: 16px;
}

/* Radial glow + fade vertikal tipis di atas/bawah supaya transisi ke
   section tetangga (Our Wines/Journal) halus, tidak ada garis sambungan
   yang kentara. Band polos di halaman Our Story tidak disentuh. */
.kudamas-distributor-band--map {
	background:
		linear-gradient(to bottom, var(--color-bg) 0%, transparent 10%, transparent 90%, var(--color-bg) 100%),
		radial-gradient(ellipse 900px 480px at 50% 0%, #7a1726 0%, var(--color-burgundy) 55%, var(--color-italian-roast) 100%);
}

.kudamas-distributor-band--map .kudamas-heading-display {
	margin: 0 0 10px;
	font-size: 30px;
}

/* =========================================================================
   Age Gate (verifikasi usia 21+) — tampil di setiap halaman depan.
   Lihat assets/js/age-gate.js untuk logika tampil/sembunyi.
   ========================================================================= */
body.kudamas-age-gate-active {
	overflow: hidden;
}

.kudamas-age-gate {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
	background-color: rgba(20, 0, 4, 0.82);
	backdrop-filter: blur(10px);
	transition: opacity var(--transition-base);
}

/* Class ini ditambahkan ke <html> oleh script inline di <head> (lihat
   kudamas_age_gate_inline_check() di functions.php), jauh sebelum
   age-gate.js sempat jalan di DOMContentLoaded — supaya pengunjung yang
   sudah verifikasi tidak melihat overlay ini kedip sekejap saat reload. */
html.kudamas-age-verified .kudamas-age-gate {
	display: none;
}

.kudamas-age-gate--hidden {
	opacity: 0;
	pointer-events: none;
}

.kudamas-age-gate__logo {
	position: absolute;
	top: 32px;
	left: 32px;
	opacity: 0.7;
}

.kudamas-age-gate__logo img {
	width: auto;
	max-height: 40px;
}

.kudamas-age-gate__logo-text {
	font-family: var(--font-heading);
	font-size: 18px;
	letter-spacing: 0.06em;
	color: var(--color-champagne-beige);
}

.kudamas-age-gate__modal {
	width: 100%;
	max-width: 560px;
	padding: 48px 40px;
	border: 1px solid rgba(242, 226, 198, 0.18);
	border-radius: 12px;
	background-color: #15100d;
	text-align: center;
}

.kudamas-age-gate__brand {
	margin: 0 0 16px;
	color: var(--color-champagne-beige);
	font-size: 13px;
	letter-spacing: 0.3em;
	text-transform: uppercase;
}

.kudamas-age-gate__title {
	margin: 0 0 20px;
	font-size: clamp(28px, 4vw, 36px);
}

.kudamas-age-gate__text {
	max-width: 420px;
	margin: 0 auto 32px;
	color: var(--color-vintage-beige);
	line-height: 1.7;
}

.kudamas-age-gate__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 16px;
	margin-bottom: 28px;
}

.kudamas-age-gate__actions .btn-outline {
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.kudamas-age-gate__disclaimer {
	margin: 0;
	color: var(--color-vintage-beige);
	font-size: 12px;
	line-height: 1.7;
}

.kudamas-age-gate__disclaimer a {
	color: var(--color-vintage-beige);
	border-bottom: 1px solid var(--color-vintage-beige);
}

.kudamas-age-gate__disclaimer a:hover,
.kudamas-age-gate__disclaimer a:focus-visible {
	color: var(--color-champagne-beige);
	border-color: var(--color-champagne-beige);
}
