/* ============================================================
   Sip25 — Minimalist, modern, light theme
   ============================================================ */

/* Design tokens */
:root {
	--c-bg: #faf7f2;
	--c-bg-alt: #f3ede2;
	--c-surface: #ffffff;
	--c-ink: #1a1410;
	--c-ink-soft: #4a4038;
	--c-ink-muted: #8a8278;
	--c-line: #e6dfd2;
	--c-accent: #c97a3f;          /* warm copper */
	--c-accent-ink: #8c4f24;
	--c-cream: #efe6d6;
	--c-coffee: #2b1b10;

	--radius-sm: 6px;
	--radius: 12px;
	--radius-lg: 24px;

	--shadow-sm: 0 1px 2px rgba(26,20,16,.04), 0 1px 1px rgba(26,20,16,.04);
	--shadow:    0 8px 24px rgba(26,20,16,.06);
	--shadow-lg: 0 24px 60px rgba(26,20,16,.12);

	--container: 1200px;
	--container-narrow: 760px;
	--gutter: clamp(16px, 4vw, 40px);

	--ff-display: 'Fraunces', 'Times New Roman', serif;
	--ff-body: 'Inter', -apple-system, system-ui, sans-serif;

	--fs-h1: clamp(2.4rem, 4.6vw, 4.4rem);
	--fs-h2: clamp(1.8rem, 3.2vw, 2.8rem);
	--fs-h3: clamp(1.2rem, 2vw, 1.5rem);
	--fs-lead: clamp(1.05rem, 1.4vw, 1.2rem);

	--ease: cubic-bezier(.2, .7, .2, 1);
}

/* Reset / base */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	font-family: var(--ff-body);
	font-size: 16px;
	line-height: 1.6;
	color: var(--c-ink);
	background: var(--c-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
img, svg, picture, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color .2s var(--ease), opacity .2s var(--ease); }
a:hover { color: var(--c-accent-ink); }
button { font: inherit; cursor: pointer; border: 0; background: transparent; color: inherit; }
input, textarea, select { font: inherit; color: inherit; }

h1, h2, h3, h4 {
	font-family: var(--ff-display);
	font-weight: 400;
	font-variation-settings: "opsz" 144;
	letter-spacing: -0.02em;
	line-height: 1.1;
	margin: 0 0 .6em;
}
h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); font-weight: 500; letter-spacing: -0.01em; line-height: 1.25; }
p  { margin: 0 0 1em; }
em { font-style: italic; color: var(--c-accent-ink); }

.eyebrow {
	font-family: var(--ff-body);
	font-size: 0.78rem;
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--c-accent-ink);
	margin: 0 0 .8em;
}

.lead, .hero__lead, .section-head__lead { font-size: var(--fs-lead); color: var(--c-ink-soft); }

.text-center { text-align: center; }
.screen-reader-text {
	position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0,0,0,0); border: 0;
}
.skip-link {
	position: absolute; left: -9999px; top: 0; padding: 12px 16px; background: var(--c-ink); color: var(--c-bg); z-index: 100;
}
.skip-link:focus { left: 0; }

/* Layout */
.container { width: 100%; max-width: var(--container); margin: 0 auto; padding-left: var(--gutter); padding-right: var(--gutter); }
.container.narrow { max-width: var(--container-narrow); }

/* Buttons */
.sip25-btn {
	display: inline-flex; align-items: center; gap: .5em;
	padding: .85em 1.4em;
	font-family: var(--ff-body);
	font-size: .92rem;
	font-weight: 500;
	letter-spacing: .02em;
	border-radius: 999px;
	border: 1px solid transparent;
	transition: transform .15s var(--ease), background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease);
	will-change: transform;
}
.sip25-btn:hover { transform: translateY(-1px); }
.sip25-btn:active { transform: translateY(0); }
.sip25-btn--primary { background: var(--c-ink); color: #fff; }
.sip25-btn--primary:hover { background: var(--c-coffee); color: #fff; }
.sip25-btn--ghost { background: transparent; color: var(--c-ink); border-color: var(--c-line); }
.sip25-btn--ghost:hover { background: #fff; border-color: var(--c-ink); }
.sip25-btn--light { background: #fff; color: var(--c-ink); }
.sip25-btn--light:hover { background: var(--c-cream); }
.sip25-btn--link { background: transparent; padding-left: 0; padding-right: 0; border-radius: 0; border-bottom: 1px solid currentColor; }
.sip25-btn--link:hover { color: var(--c-accent-ink); }

/* Icons */
.sip25-icon { display: inline-flex; width: 1.1em; height: 1.1em; }
.sip25-icon svg { width: 100%; height: 100%; }

/* ============================================================
   Header
   ============================================================ */
.site-header {
	position: sticky; top: 0; z-index: 50;
	background: rgba(250,247,242,.85);
	backdrop-filter: saturate(140%) blur(10px);
	-webkit-backdrop-filter: saturate(140%) blur(10px);
	border-bottom: 1px solid transparent;
	transition: border-color .2s var(--ease), background .2s var(--ease);
}
.site-header.is-scrolled { border-color: var(--c-line); background: rgba(250,247,242,.95); }
.site-header__bar {
	display: flex; align-items: center; gap: 24px;
	padding-top: 18px; padding-bottom: 18px;
}
.site-header__brand .site-header__logo {
	font-family: var(--ff-display);
	font-size: 1.55rem;
	letter-spacing: -0.03em;
	color: var(--c-ink);
}
.site-header__mark span { color: var(--c-accent); }

.site-header__nav { margin-left: auto; }
.site-header__nav .menu {
	list-style: none; padding: 0; margin: 0;
	display: flex; gap: 28px;
}
.site-header__nav .menu a {
	font-size: .94rem;
	font-weight: 500;
	color: var(--c-ink-soft);
	position: relative;
	padding: 4px 0;
}
.site-header__nav .menu a:hover,
.site-header__nav .menu .current-menu-item > a { color: var(--c-ink); }
.site-header__nav .menu a::after {
	content: ""; position: absolute; left: 0; right: 0; bottom: -2px;
	height: 1px; background: var(--c-ink); transform: scaleX(0); transform-origin: left;
	transition: transform .25s var(--ease);
}
.site-header__nav .menu a:hover::after,
.site-header__nav .menu .current-menu-item > a::after { transform: scaleX(1); }

.site-header__actions { display: flex; align-items: center; gap: 16px; }
.site-header__cart {
	position: relative;
	display: inline-flex; align-items: center; justify-content: center;
	width: 40px; height: 40px;
	border-radius: 999px;
}
.site-header__cart:hover { background: var(--c-bg-alt); color: var(--c-ink); }
.site-header__cart .sip25-icon { width: 1.2em; height: 1.2em; }
.cart-count {
	position: absolute; top: -2px; right: -4px;
	min-width: 20px; height: 20px; padding: 0 6px;
	background: var(--c-accent); color: #fff;
	font-size: .72rem; font-weight: 600;
	border-radius: 999px;
	display: inline-flex; align-items: center; justify-content: center;
}

/* Language switcher */
.sip25-langs {
	list-style: none; padding: 0; margin: 0;
	display: flex; gap: 4px;
	font-size: .82rem; font-weight: 500;
}
.sip25-langs li { display: inline; }
.sip25-langs a, .sip25-langs span {
	display: inline-block; padding: 4px 8px; border-radius: 6px;
	color: var(--c-ink-muted); text-transform: uppercase; letter-spacing: .05em;
}
.sip25-langs a:hover { color: var(--c-ink); }
.sip25-langs .active a, .sip25-langs .active span,
.sip25-langs .current-lang a { color: var(--c-ink); background: var(--c-bg-alt); }

/* Mobile toggle */
.site-header__toggle {
	display: none;
	width: 40px; height: 40px; border-radius: 999px;
}
.site-header__toggle:hover { background: var(--c-bg-alt); }
.site-header__toggle .icon-close { display: none; }
body.is-nav-open .site-header__toggle .icon-menu { display: none; }
body.is-nav-open .site-header__toggle .icon-close { display: inline-flex; }

@media (max-width: 900px) {
	.site-header__toggle { display: inline-flex; }
	.site-header__nav {
		position: fixed; inset: 72px 0 0;
		background: var(--c-bg);
		padding: 32px var(--gutter);
		transform: translateX(100%);
		transition: transform .3s var(--ease);
	}
	.site-header__nav .menu { flex-direction: column; gap: 16px; font-size: 1.4rem; }
	.site-header__nav .menu a { font-size: 1.4rem; }
	body.is-nav-open .site-header__nav { transform: translateX(0); }
	body.is-nav-open { overflow: hidden; }
}

/* ============================================================
   Hero
   ============================================================ */
.hero { padding: 80px 0 60px; }
.hero__inner {
	display: grid; grid-template-columns: 1.1fr .9fr; gap: 60px;
	align-items: center;
}
.hero__title {
	font-size: var(--fs-h1);
	margin-bottom: .4em;
}
.hero__title em { font-style: italic; color: var(--c-accent-ink); font-weight: 300; }
.hero__lead { max-width: 46ch; }
.hero__actions { display: flex; flex-wrap: wrap; gap: 12px; margin: 28px 0 36px; }

.hero__meta {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-wrap: wrap; gap: 24px;
	font-size: .9rem; color: var(--c-ink-soft);
}
.hero__meta li { display: inline-flex; align-items: center; gap: 8px; }
.hero__meta .sip25-icon { color: var(--c-accent); width: 1.05em; height: 1.05em; }

.hero__image { position: relative; }
.hero__img, .hero__placeholder svg {
	width: 100%; height: auto;
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow);
	overflow: hidden;
}
.hero__placeholder { position: relative; }
.hero__placeholder-note {
	position: absolute; bottom: 16px; left: 16px; right: 16px;
	background: rgba(255,255,255,.85);
	padding: 8px 12px; border-radius: 8px;
	font-size: .78rem; color: var(--c-ink-muted);
	margin: 0;
}

@media (max-width: 900px) {
	.hero { padding: 40px 0; }
	.hero__inner { grid-template-columns: 1fr; gap: 40px; }
}

/* ============================================================
   Values strip
   ============================================================ */
.values { padding: 64px 0; border-top: 1px solid var(--c-line); border-bottom: 1px solid var(--c-line); }
.values__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 48px; }
.values__num {
	display: inline-block;
	font-family: var(--ff-display);
	font-size: 1rem; color: var(--c-accent);
	letter-spacing: .1em;
	margin-bottom: 12px;
}
.values__item h3 { margin-bottom: 8px; }
.values__item p { color: var(--c-ink-soft); margin: 0; max-width: 38ch; }

@media (max-width: 800px) {
	.values__grid { grid-template-columns: 1fr; gap: 32px; }
}

/* ============================================================
   Section heads
   ============================================================ */
.section-head {
	display: flex; align-items: end; justify-content: space-between;
	gap: 24px; margin-bottom: 40px;
}
.section-head--center { flex-direction: column; align-items: center; text-align: center; }
.section-head--center .section-head__lead { max-width: 56ch; }
.section-head h2 { margin: 0; }
.section-head__more {
	display: inline-flex; align-items: center; gap: 8px;
	font-size: .92rem; font-weight: 500; color: var(--c-ink-soft);
	white-space: nowrap;
}
.section-head__more:hover { color: var(--c-ink); }

/* ============================================================
   Featured products
   ============================================================ */
.featured-products { padding: 80px 0; }
.featured-products__grid { margin-bottom: 24px; }
.featured-products__fallback {
	font-size: .85rem; color: var(--c-ink-muted); margin: 0;
}

/* WC product card overrides */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	background: var(--c-surface);
	border-radius: var(--radius);
	padding: 16px !important;
	box-shadow: var(--shadow-sm);
	transition: box-shadow .25s var(--ease), transform .25s var(--ease);
	text-align: left;
	margin-bottom: 24px !important;
}
.woocommerce ul.products li.product:hover { box-shadow: var(--shadow); transform: translateY(-2px); }
.woocommerce ul.products li.product img { border-radius: var(--radius-sm); margin-bottom: 16px !important; }
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--ff-display) !important;
	font-size: 1.2rem !important;
	font-weight: 500 !important;
	letter-spacing: -.01em !important;
	padding: 0 !important;
	margin-bottom: 6px !important;
}
.woocommerce ul.products li.product .price {
	color: var(--c-ink) !important;
	font-weight: 600 !important;
	font-size: 1rem !important;
}
.woocommerce ul.products li.product .price del { color: var(--c-ink-muted) !important; }
.woocommerce ul.products li.product .price ins { background: transparent !important; color: var(--c-accent-ink) !important; font-weight: 600; }
.woocommerce ul.products li.product .button {
	background: var(--c-ink) !important;
	color: #fff !important;
	border-radius: 999px !important;
	padding: .75em 1.2em !important;
	margin-top: 12px !important;
	font-weight: 500 !important;
}
.woocommerce ul.products li.product .button:hover { background: var(--c-coffee) !important; }

.sip25-badge {
	display: inline-block;
	font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 600;
	padding: 4px 10px; border-radius: 999px;
	position: absolute; top: 24px; left: 24px; z-index: 2;
}
.sip25-badge--sale { background: var(--c-accent); color: #fff; }
.sip25-badge--new  { background: var(--c-ink); color: #fff; }
.woocommerce span.onsale { display: none; } /* hide default flash, we use ours */

/* ============================================================
   Story
   ============================================================ */
.story { padding: 80px 0; background: var(--c-bg-alt); }
.story__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.story__placeholder svg, .story__media img {
	width: 100%; border-radius: var(--radius-lg); box-shadow: var(--shadow);
}
@media (max-width: 800px) { .story__grid { grid-template-columns: 1fr; } }

/* ============================================================
   Methods
   ============================================================ */
.methods { padding: 80px 0; }
.methods__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.methods__card {
	background: var(--c-surface);
	border: 1px solid var(--c-line);
	border-radius: var(--radius);
	padding: 32px;
	color: var(--c-ink);
	display: flex; flex-direction: column; gap: 12px;
	transition: border-color .2s var(--ease), transform .25s var(--ease), box-shadow .25s var(--ease);
}
.methods__card:hover { border-color: var(--c-ink); transform: translateY(-2px); box-shadow: var(--shadow); color: var(--c-ink); }
.methods__icon { width: 48px; height: 48px; color: var(--c-accent); }
.methods__icon svg { width: 100%; height: 100%; }
.methods__card h3 { margin: 0; }
.methods__card p { margin: 0; color: var(--c-ink-soft); font-size: .94rem; }

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

/* ============================================================
   Testimonials
   ============================================================ */
.testimonials { padding: 80px 0; background: var(--c-bg-alt); }
.testimonials__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.testimonials__item {
	background: var(--c-surface); border-radius: var(--radius);
	padding: 32px; margin: 0;
	box-shadow: var(--shadow-sm);
}
.testimonials__item blockquote { margin: 0 0 24px; }
.testimonials__item blockquote p {
	font-family: var(--ff-display);
	font-size: 1.15rem;
	font-weight: 400; line-height: 1.4;
	color: var(--c-ink); margin: 0;
}
.testimonials__item figcaption { font-size: .9rem; color: var(--c-ink-soft); }
.testimonials__item figcaption strong { color: var(--c-ink); display: block; }

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

/* ============================================================
   B2B banner
   ============================================================ */
.b2b-banner { padding: 100px 0; background: var(--c-coffee); color: #fff; }
.b2b-banner h2 { color: #fff; }
.b2b-banner p { color: rgba(255,255,255,.78); }
.b2b-banner .eyebrow { color: var(--c-accent); }
.b2b-banner__inner {
	display: grid; grid-template-columns: 1fr auto;
	gap: 40px; align-items: center;
}
.b2b-banner__copy h2 { max-width: 18ch; margin-bottom: .4em; }
@media (max-width: 800px) { .b2b-banner__inner { grid-template-columns: 1fr; } }

/* ============================================================
   About page
   ============================================================ */
.about-hero { padding: 80px 0 40px; }
.about-hero__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.about-hero__placeholder svg, .about-hero__img {
	width: 100%; border-radius: var(--radius-lg); box-shadow: var(--shadow);
}
.about-story { padding: 80px 0; }
.about-story__grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 60px; align-items: start; }
.about-story__sidebar {
	background: var(--c-bg-alt); padding: 32px; border-radius: var(--radius);
}
.about-story__sidebar dl { margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 20px 16px; }
.about-story__sidebar dt {
	font-size: .75rem; text-transform: uppercase; letter-spacing: .15em;
	color: var(--c-ink-muted); margin-bottom: 4px;
}
.about-story__sidebar dd { margin: 0; font-weight: 500; }

.about-values { padding: 80px 0; background: var(--c-bg-alt); }
.about-values__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }
.about-values__grid h3 { margin-bottom: 8px; }
.about-values__grid p { color: var(--c-ink-soft); margin: 0; }

.about-team { padding: 80px 0; }
.about-team__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.about-team figure { margin: 0; text-align: center; }
.about-team__photo {
	width: 100%; aspect-ratio: 1; border-radius: var(--radius-lg);
	background: linear-gradient(135deg, var(--c-cream), var(--c-bg-alt));
	margin-bottom: 16px;
}
.about-team figcaption strong { display: block; font-family: var(--ff-display); font-size: 1.1rem; }
.about-team figcaption span { color: var(--c-ink-muted); font-size: .9rem; }

@media (max-width: 900px) {
	.about-hero__grid, .about-story__grid { grid-template-columns: 1fr; }
	.about-values__grid { grid-template-columns: repeat(2, 1fr); }
	.about-team__grid { grid-template-columns: 1fr; }
}

/* ============================================================
   B2B page
   ============================================================ */
.b2b-hero { padding: 80px 0; }
.b2b-hero__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start; }
.b2b-hero__perks { list-style: none; padding: 0; margin: 32px 0 0; display: grid; gap: 20px; }
.b2b-hero__perks li { display: flex; gap: 16px; align-items: flex-start; }
.b2b-hero__perks .sip25-icon {
	flex-shrink: 0; width: 40px; height: 40px; padding: 10px;
	background: var(--c-bg-alt); border-radius: 12px;
	color: var(--c-accent);
}
.b2b-hero__perks strong { font-family: var(--ff-display); font-size: 1.1rem; display: block; margin-bottom: 4px; }
.b2b-hero__perks p { margin: 0; color: var(--c-ink-soft); font-size: .94rem; }

.b2b-hero__form {
	background: var(--c-surface);
	border: 1px solid var(--c-line);
	border-radius: var(--radius-lg);
	padding: 36px;
	box-shadow: var(--shadow);
}
.b2b-hero__form h2 { font-size: 1.6rem; margin-bottom: .3em; }
.b2b-hero__form > p { color: var(--c-ink-soft); margin-bottom: 24px; }

.b2b-faq { padding: 80px 0; background: var(--c-bg-alt); }
.b2b-faq__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; max-width: 880px; margin: 0 auto; }
.b2b-faq details {
	background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--radius);
	padding: 20px 24px;
	transition: border-color .2s var(--ease);
}
.b2b-faq details[open] { border-color: var(--c-ink); }
.b2b-faq summary {
	cursor: pointer; font-weight: 500; font-family: var(--ff-display); font-size: 1.05rem;
	list-style: none; position: relative; padding-right: 24px;
}
.b2b-faq summary::-webkit-details-marker { display: none; }
.b2b-faq summary::after {
	content: "+"; position: absolute; right: 0; top: 0;
	font-size: 1.4rem; color: var(--c-accent); transition: transform .2s var(--ease);
}
.b2b-faq details[open] summary::after { content: "−"; }
.b2b-faq details p { margin: 12px 0 0; color: var(--c-ink-soft); }

@media (max-width: 900px) {
	.b2b-hero__grid, .b2b-faq__grid { grid-template-columns: 1fr; }
}

/* ============================================================
   Form
   ============================================================ */
.sip25-form__grid {
	display: grid; grid-template-columns: 1fr 1fr; gap: 16px 16px;
	margin-bottom: 16px;
}
.sip25-form__field { display: flex; flex-direction: column; gap: 6px; }
.sip25-form__field--full { grid-column: 1 / -1; margin-bottom: 16px; }
.sip25-form__field span {
	font-size: .85rem; font-weight: 500; color: var(--c-ink-soft);
}
.sip25-form input,
.sip25-form select,
.sip25-form textarea {
	width: 100%;
	padding: 12px 14px;
	background: var(--c-bg);
	border: 1px solid var(--c-line);
	border-radius: 8px;
	font-size: .95rem;
	transition: border-color .2s var(--ease), background .2s var(--ease);
}
.sip25-form input:focus,
.sip25-form select:focus,
.sip25-form textarea:focus {
	outline: 0;
	border-color: var(--c-ink);
	background: #fff;
}
.sip25-form textarea { resize: vertical; min-height: 120px; }
.sip25-form__hp { position: absolute; left: -10000px; }
.sip25-form__consent {
	display: flex; align-items: flex-start; gap: 10px;
	font-size: .85rem; color: var(--c-ink-soft);
	margin-bottom: 24px;
}
.sip25-form__consent input { width: auto; margin-top: 4px; }
.sip25-form__consent a { color: var(--c-ink); text-decoration: underline; }
.sip25-form button[type="submit"] { width: 100%; justify-content: center; }
.sip25-form__status { min-height: 1.4em; margin-top: 12px; font-size: .9rem; text-align: center; }
.sip25-form__status.is-success { color: #2f7a3a; }
.sip25-form__status.is-error { color: #b8463c; }
.sip25-form.is-loading button[type="submit"] { opacity: .6; pointer-events: none; }

@media (max-width: 600px) {
	.sip25-form__grid { grid-template-columns: 1fr; }
	.b2b-hero__form { padding: 24px; }
}

/* ============================================================
   Footer
   ============================================================ */
.site-footer {
	background: var(--c-ink);
	color: #d8d2c8;
	padding: 80px 0 32px;
}
.site-footer h2, .site-footer h3 { color: #fff; }
.site-footer__cta {
	display: grid; grid-template-columns: 1fr auto;
	gap: 32px; align-items: center;
	padding-bottom: 60px; border-bottom: 1px solid rgba(255,255,255,.1);
	margin-bottom: 60px;
}
.site-footer__cta h2 { font-size: clamp(1.6rem, 2.4vw, 2.4rem); margin: 0; max-width: 22ch; }
.site-footer__cta .eyebrow { color: var(--c-accent); }

.site-footer__cols {
	display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.6fr;
	gap: 48px;
	margin-bottom: 60px;
}
.site-footer__col h3 {
	font-family: var(--ff-body);
	font-size: .82rem; font-weight: 500;
	letter-spacing: .15em; text-transform: uppercase;
	color: rgba(255,255,255,.5);
	margin-bottom: 20px;
}
.site-footer__logo {
	font-family: var(--ff-display); font-size: 1.6rem;
	color: #fff; display: inline-block; margin-bottom: 16px;
}
.site-footer__logo span { color: var(--c-accent); }
.site-footer p { color: rgba(255,255,255,.65); }
.site-footer .footer-menu, .site-footer .legal-menu {
	list-style: none; padding: 0; margin: 0; display: grid; gap: 12px;
}
.site-footer .footer-menu a:hover, .site-footer .legal-menu a:hover { color: #fff; }

.site-footer__social {
	list-style: none; padding: 0; margin: 24px 0 0;
	display: flex; gap: 12px;
}
.site-footer__social a {
	display: inline-flex; align-items: center; justify-content: center;
	width: 38px; height: 38px; border-radius: 999px;
	background: rgba(255,255,255,.06);
	color: #fff;
}
.site-footer__social a:hover { background: var(--c-accent); }

.site-footer__newsletter {
	display: flex; gap: 8px; margin-bottom: 24px;
}
.site-footer__newsletter input {
	flex: 1; padding: 12px 14px;
	background: rgba(255,255,255,.06);
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 999px; color: #fff;
	font-size: .92rem;
}
.site-footer__newsletter input::placeholder { color: rgba(255,255,255,.4); }
.site-footer__newsletter input:focus { outline: 0; border-color: var(--c-accent); background: rgba(255,255,255,.1); }
.site-footer__newsletter .sip25-btn--ghost {
	background: transparent; color: #fff; border-color: rgba(255,255,255,.2);
}
.site-footer__newsletter .sip25-btn--ghost:hover { background: rgba(255,255,255,.06); border-color: #fff; }
.site-footer__contact { font-size: .9rem; line-height: 1.7; }
.site-footer__contact a:hover { color: #fff; }

.site-footer__bottom {
	display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px;
	padding-top: 32px; border-top: 1px solid rgba(255,255,255,.08);
	font-size: .85rem; color: rgba(255,255,255,.5);
}
.site-footer__bottom .legal-menu { display: flex; gap: 24px; }
.site-footer__bottom .legal-menu a { color: rgba(255,255,255,.5); }

@media (max-width: 900px) {
	.site-footer__cta { grid-template-columns: 1fr; }
	.site-footer__cols { grid-template-columns: 1fr 1fr; gap: 40px; }
}
@media (max-width: 600px) {
	.site-footer__cols { grid-template-columns: 1fr; }
}

/* ============================================================
   Shop hero (WC pages)
   ============================================================ */
.shop-hero { padding: 60px 0 40px; text-align: center; border-bottom: 1px solid var(--c-line); margin-bottom: 40px; }
.shop-hero__title { margin-bottom: .3em; }
.shop-hero__lead { max-width: 56ch; margin: 0 auto; color: var(--c-ink-soft); }

.woocommerce-main { padding-bottom: 80px; }
.woocommerce .woocommerce-result-count,
.woocommerce-page .woocommerce-result-count { font-size: .9rem; color: var(--c-ink-muted); }

/* WC single product */
.woocommerce div.product .product_title {
	font-family: var(--ff-display) !important;
	font-size: 2.4rem !important;
	font-weight: 400 !important;
	letter-spacing: -.02em !important;
	margin-bottom: .3em !important;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	color: var(--c-ink) !important;
	font-size: 1.4rem !important;
	font-weight: 600 !important;
}
.woocommerce div.product form.cart .button {
	background: var(--c-ink) !important;
	color: #fff !important;
	border-radius: 999px !important;
	padding: .9em 1.6em !important;
	font-weight: 500 !important;
}
.woocommerce div.product form.cart .button:hover { background: var(--c-coffee) !important; }
.woocommerce .woocommerce-tabs ul.tabs { border-bottom: 1px solid var(--c-line) !important; padding: 0 !important; }
.woocommerce .woocommerce-tabs ul.tabs::before { display: none; }
.woocommerce .woocommerce-tabs ul.tabs li {
	background: transparent !important; border: 0 !important; border-radius: 0 !important;
	margin: 0 !important; padding: 0 !important;
}
.woocommerce .woocommerce-tabs ul.tabs li a {
	font-family: var(--ff-body) !important; font-weight: 500 !important;
	padding: 16px 20px !important; color: var(--c-ink-muted) !important;
	border-bottom: 2px solid transparent !important;
}
.woocommerce .woocommerce-tabs ul.tabs li.active a { color: var(--c-ink) !important; border-bottom-color: var(--c-accent) !important; }
.woocommerce .woocommerce-tabs ul.tabs li::before, .woocommerce .woocommerce-tabs ul.tabs li::after { display: none !important; }
.woocommerce .quantity .qty {
	border: 1px solid var(--c-line) !important; border-radius: 8px !important;
	padding: 8px 10px !important;
}

.sip25-origin { display: grid; grid-template-columns: 160px 1fr; gap: 12px 24px; margin: 0; }
.sip25-origin dt {
	font-size: .8rem; text-transform: uppercase; letter-spacing: .12em;
	color: var(--c-ink-muted); align-self: center;
}
.sip25-origin dd { margin: 0; font-weight: 500; }

/* Cart, Checkout */
.woocommerce table.shop_table {
	border: 1px solid var(--c-line) !important; border-radius: var(--radius) !important;
	overflow: hidden; border-collapse: separate !important; border-spacing: 0;
}
.woocommerce table.shop_table th { background: var(--c-bg-alt); }
.woocommerce-cart .wc-proceed-to-checkout .checkout-button {
	background: var(--c-ink) !important; color: #fff !important;
	border-radius: 999px !important; padding: 1em 1.6em !important;
}
.woocommerce-cart .wc-proceed-to-checkout .checkout-button:hover { background: var(--c-coffee) !important; }

.woocommerce-message, .woocommerce-info, .woocommerce-error {
	border-top-color: var(--c-accent) !important;
	background: var(--c-bg-alt) !important;
	border-radius: var(--radius) !important;
}
.woocommerce-message::before, .woocommerce-info::before { color: var(--c-accent) !important; }

/* ============================================================
   Blog
   ============================================================ */
.page-header { padding: 60px 0 40px; text-align: center; }
.post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; margin-bottom: 60px; }
.post-card {
	background: var(--c-surface); border-radius: var(--radius);
	overflow: hidden; box-shadow: var(--shadow-sm);
	transition: box-shadow .25s var(--ease), transform .25s var(--ease);
}
.post-card:hover { box-shadow: var(--shadow); transform: translateY(-2px); }
.post-card__media img { aspect-ratio: 4 / 3; object-fit: cover; }
.post-card__body { padding: 24px; }
.post-card__title { font-size: 1.3rem; margin-bottom: 4px; }
.post-card__title a { color: var(--c-ink); }
.post-card__meta { font-size: .8rem; color: var(--c-ink-muted); margin-bottom: 12px; letter-spacing: .05em; text-transform: uppercase; }
.post-card__excerpt p { color: var(--c-ink-soft); font-size: .94rem; margin: 0; }

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

/* Pagination */
.pagination, .woocommerce nav.woocommerce-pagination {
	display: flex; justify-content: center; gap: 8px; padding: 24px 0;
}
.nav-links { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; }
.nav-links .page-numbers,
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	padding: 8px 14px; border-radius: 8px;
	background: transparent; color: var(--c-ink-soft);
	font-weight: 500; min-width: 40px; text-align: center;
}
.nav-links .page-numbers.current,
.woocommerce nav.woocommerce-pagination ul li span.current { background: var(--c-ink); color: #fff; }
.nav-links a.page-numbers:hover { background: var(--c-bg-alt); color: var(--c-ink); }
.woocommerce nav.woocommerce-pagination ul { border: 0 !important; display: flex !important; gap: 8px !important; }
.woocommerce nav.woocommerce-pagination ul li { border: 0 !important; }

/* Single post */
.single-article__head { text-align: center; padding: 60px 0 40px; }
.single-article__title { margin-bottom: 0; }
.single-article__media { margin: 0 0 32px; }
.single-article__media img { border-radius: var(--radius-lg); width: 100%; }
.single-article__content { font-size: 1.05rem; line-height: 1.8; }
.single-article__content h2 { margin-top: 1.6em; }

/* Page article */
.page-article__head { text-align: center; padding: 60px 0 40px; }

/* 404 */
.error-404 { padding: 100px 0; }
.error-404 .eyebrow { color: var(--c-accent); font-size: 4rem; letter-spacing: 0; margin-bottom: 0; }
.error-404__actions { display: flex; gap: 12px; justify-content: center; margin-top: 32px; }

/* Reveal anim */
[data-reveal] { opacity: 0; transform: translateY(16px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
[data-reveal].is-visible { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { transition: none !important; animation: none !important; }
	[data-reveal] { opacity: 1; transform: none; }
}
