/* =========================================================
   NAMO NATURALS — Theme Stylesheet
   Palette drawn from the brand's own product photography:
   deep ayurvedic forest green, warm turmeric gold, root-brown,
   and a soft cream background.
   ========================================================= */

:root {
	--forest:        #1F4E3C;
	--forest-dark:    #15362A;
	--leaf:           #3F7D52;
	--gold:           #C99B3D;
	--gold-light:     #E8C77A;
	--terracotta:     #A8552E;
	--cream:          #FAF6EC;
	--cream-deep:     #F1EAD6;
	--ink:            #20231F;
	--ink-soft:       #5B5F56;
	--white:          #FFFFFF;
	--danger:         #B3261E;

	--font-display:   'Fraunces', 'Georgia', serif;
	--font-body:      'Inter', system-ui, sans-serif;

	--radius-s:  8px;
	--radius-m:  16px;
	--radius-l:  28px;
	--shadow-card: 0 6px 24px rgba(31, 78, 60, 0.10);
	--container:  1180px;
}

/* ---------- Reset / base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
	margin: 0;
	font-family: var(--font-body);
	color: var(--ink);
	background: var(--cream);
	line-height: 1.6;
	font-size: 16px;
	-webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--forest); text-decoration: none; }
ul { list-style: none; margin: 0; padding: 0; }
h1, h2, h3, h4 {
	font-family: var(--font-display);
	color: var(--forest-dark);
	margin: 0 0 .5em;
	line-height: 1.15;
	font-weight: 600;
}
p { margin: 0 0 1em; }
.screen-reader-text {
	position: absolute !important;
	clip: rect(1px, 1px, 1px, 1px);
	overflow: hidden;
	height: 1px; width: 1px;
}
:focus-visible {
	outline: 3px solid var(--gold);
	outline-offset: 2px;
}

.namo-container {
	max-width: var(--container);
	margin: 0 auto;
	padding: 0 24px;
}

/* ---------- Buttons ---------- */
.namo-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--font-body);
	font-weight: 600;
	font-size: .95rem;
	padding: 14px 28px;
	border-radius: 999px;
	border: 2px solid transparent;
	cursor: pointer;
	transition: transform .15s ease, box-shadow .15s ease, background .2s ease;
}
.namo-btn--primary {
	background: var(--forest);
	color: var(--white);
}
.namo-btn--primary:hover { background: var(--forest-dark); transform: translateY(-1px); }
.namo-btn--ghost {
	background: transparent;
	border-color: var(--forest);
	color: var(--forest-dark);
}
.namo-btn--ghost:hover { background: var(--forest); color: var(--white); }

/* ---------- Topbar ---------- */
.namo-topbar { background: var(--forest-dark); color: var(--cream); font-size: .82rem; }
.namo-topbar__inner {
	display: flex; align-items: center; justify-content: space-between;
	gap: 16px; padding: 8px 24px; flex-wrap: wrap;
}
.namo-topbar__msg { margin: 0; opacity: .9; }
.namo-topbar__phone { color: var(--gold-light); display: inline-flex; gap: 6px; align-items: center; font-weight: 600; }

/* ---------- Header ---------- */
.namo-header {
	background: var(--cream);
	border-bottom: 1px solid var(--cream-deep);
	position: sticky;
	top: 0;
	z-index: 50;
}
.namo-header__inner {
	display: flex;
	align-items: center;
	gap: 24px;
	padding: 14px 24px;
}
.namo-brand { margin-right: auto; }
.namo-brand img { max-height: 56px; width: auto; }
.namo-logo-text {
	font-family: var(--font-display);
	font-size: 1.6rem;
	font-weight: 700;
	color: var(--forest-dark);
}
.namo-nav__list { display: flex; gap: 28px; }
.namo-nav__list a {
	font-weight: 600;
	color: var(--ink);
	font-size: .95rem;
	padding: 6px 0;
	border-bottom: 2px solid transparent;
}
.namo-nav__list a:hover,
.namo-nav__list .current-menu-item > a {
	color: var(--forest);
	border-color: var(--gold);
}
.namo-nav__list .sub-menu { display: none; }

.namo-header__actions { display: flex; align-items: center; gap: 14px; }
.namo-menu-toggle {
	display: none; flex-direction: column; gap: 4px;
	background: none; border: none; cursor: pointer; padding: 8px;
}
.namo-menu-toggle span { width: 22px; height: 2px; background: var(--ink); display: block; }

/* ---------- Hero ---------- */
.namo-hero { padding: 64px 0 24px; background: linear-gradient(180deg, var(--cream) 0%, var(--cream-deep) 100%); overflow: hidden; }
.namo-hero__grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 48px; align-items: center; }
.namo-eyebrow {
	font-family: var(--font-body); text-transform: uppercase; letter-spacing: .12em;
	font-size: .78rem; font-weight: 700; color: var(--terracotta); margin-bottom: 12px;
}
.namo-hero h1 { font-size: clamp(2.1rem, 4vw, 3.2rem); max-width: 12ch; }
.namo-hero__sub { max-width: 46ch; color: var(--ink-soft); font-size: 1.05rem; }
.namo-hero__cta { display: flex; gap: 14px; margin: 24px 0 28px; flex-wrap: wrap; }
.namo-badges { display: flex; gap: 18px; flex-wrap: wrap; }
.namo-badges__item {
	display: inline-flex; align-items: center; gap: 6px;
	font-size: .82rem; font-weight: 600; color: var(--forest-dark);
}
.namo-badges__icon { color: var(--gold); display: inline-flex; }

.namo-hero__art {
	position: relative;
	border-radius: var(--radius-l);
	overflow: hidden;
	box-shadow: var(--shadow-card);
	aspect-ratio: 4/5;
}
.namo-hero__art img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ---------- Section divider (root motif) ---------- */
.namo-divider { color: var(--gold); height: 30px; margin: 0 auto; max-width: var(--container); }
.namo-divider svg { width: 100%; height: 100%; }

/* ---------- Generic sections ---------- */
.namo-section { padding: 56px 0; }
.namo-section--tint { background: var(--cream-deep); }
.namo-section__title { font-size: 1.7rem; margin-bottom: 28px; }
.namo-section__head {
	display: flex; align-items: baseline; justify-content: space-between;
	margin-bottom: 28px; flex-wrap: wrap; gap: 12px;
}
.namo-section__head .namo-section__title { margin: 0; }
.namo-link { font-weight: 700; color: var(--forest); }

/* ---------- Category cards ---------- */
.namo-categories__grid {
	display: grid; grid-template-columns: repeat(6, 1fr); gap: 18px;
}
.namo-category-card { display: block; text-align: center; }
.namo-category-card__img {
	display: block; width: 100%; aspect-ratio: 1/1; border-radius: var(--radius-m);
	background-size: cover; background-position: center;
	box-shadow: var(--shadow-card); margin-bottom: 10px;
	background-color: var(--cream-deep);
}
.namo-category-card__label { font-weight: 700; color: var(--forest-dark); font-size: .9rem; }

/* ---------- USP strip ---------- */
.namo-strip { background: var(--forest-dark); color: var(--cream); }
.namo-strip__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }
.namo-strip__item svg { color: var(--gold); margin-bottom: 10px; }
.namo-strip__item h3 { color: var(--white); font-size: 1.05rem; margin-bottom: 6px; }
.namo-strip__item p { color: rgba(250,246,236,.78); font-size: .88rem; margin: 0; }
.namo-strip__item a { color: var(--gold-light); font-weight: 700; }

/* ---------- Custom product showcase (no WooCommerce loop markup) ---------- */
.namo-feature {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 56px;
	align-items: center;
	background: var(--white);
	border-radius: var(--radius-l);
	box-shadow: var(--shadow-card);
	overflow: hidden;
	margin-bottom: 40px;
}
.namo-feature:last-child { margin-bottom: 0; }
.namo-feature--reverse { grid-template-columns: 1fr 1fr; }
.namo-feature--reverse .namo-feature__media { order: 2; }
.namo-feature--reverse .namo-feature__body { order: 1; }

.namo-feature__media { position: relative; align-self: stretch; min-height: 420px; background: var(--cream-deep); }
.namo-feature__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.namo-feature__badge {
	position: absolute; top: 20px; left: 20px; z-index: 2;
	background: var(--terracotta); color: var(--white);
	font-size: .74rem; font-weight: 700; text-transform: uppercase;
	padding: 6px 14px; border-radius: 999px;
}
.namo-feature__badge--stock { background: var(--ink-soft); }
.namo-feature__badge--bestseller { background: var(--gold); color: var(--forest-dark); }

.namo-feature__body { padding: 48px 48px 48px 0; }
.namo-feature--reverse .namo-feature__body { padding: 48px 0 48px 48px; }
.namo-feature__title { font-size: 1.9rem; margin-bottom: 8px; }
.namo-feature__tagline {
	color: var(--terracotta); font-weight: 700; font-size: .9rem;
	margin-bottom: 18px;
}
.namo-feature__desc { color: var(--ink-soft); font-size: 1rem; margin-bottom: 22px; max-width: 46ch; }
.namo-feature__desc p:last-child { margin-bottom: 0; }
.namo-feature__meta { display: flex; align-items: center; gap: 20px; margin-bottom: 26px; flex-wrap: wrap; }
.namo-feature__price { font-family: var(--font-display); font-size: 1.7rem; font-weight: 700; color: var(--forest-dark); }
.namo-feature__price del { font-size: 1.05rem; opacity: .5; font-weight: 400; margin-right: 8px; }
.namo-feature__price ins { text-decoration: none; }
.namo-feature__shipping {
	display: inline-flex; align-items: center; gap: 6px;
	font-size: .82rem; font-weight: 700; color: var(--leaf);
}
.namo-feature .namo-order-now-btn--large { width: auto; min-width: 220px; }


.namo-product-grid,
ul.products.namo-product-grid {
	display: grid !important;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
	margin: 0 !important;
	padding: 0 !important;
}
.namo-product-card {
	background: var(--white);
	border-radius: var(--radius-m);
	overflow: hidden;
	box-shadow: var(--shadow-card);
	display: flex;
	flex-direction: column;
	transition: transform .2s ease, box-shadow .2s ease;
	list-style: none;
}
.namo-product-card:hover { transform: translateY(-4px); box-shadow: 0 14px 30px rgba(31,78,60,.16); }
.namo-product-card__media { position: relative; display: block; aspect-ratio: 1/1; overflow: hidden; background: var(--cream-deep); }
.namo-product-card__media img { width: 100%; height: 100%; object-fit: cover; }
.namo-badge {
	position: absolute; top: 12px; left: 12px; z-index: 2;
	font-size: .68rem; font-weight: 700; text-transform: uppercase;
	padding: 4px 10px; border-radius: 999px; color: var(--white);
}
.namo-badge--sale { background: var(--terracotta); }
.namo-badge--stock { background: var(--ink-soft); }
.namo-product-card__body { padding: 18px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.namo-product-card__cat { font-size: .72rem; text-transform: uppercase; letter-spacing: .06em; color: var(--leaf); margin: 0; }
.namo-product-card__title { font-size: 1.02rem; margin: 0; }
.namo-product-card__title a { color: var(--ink); }
.namo-product-card__price { font-weight: 700; color: var(--forest-dark); font-family: var(--font-display); font-size: 1.1rem; }
.namo-product-card__price del { color: var(--ink-soft); opacity: .6; font-weight: 400; margin-right: 6px; }
.namo-product-card__price ins { text-decoration: none; }
.namo-product-card__shipping {
	display: inline-flex; align-items: center; gap: 6px;
	font-size: .76rem; font-weight: 600; color: var(--leaf);
}
.namo-product-card__cta { margin-top: auto; padding-top: 10px; }
.namo-order-now-btn {
	display: inline-flex; width: 100%; justify-content: center;
	background: var(--terracotta); color: var(--white); border-radius: 999px;
	padding: 12px 16px; font-weight: 700; font-size: .9rem; border: none;
	cursor: pointer; text-align: center; font-family: var(--font-body);
	transition: background .2s ease, transform .15s ease;
}
.namo-order-now-btn:hover { background: #8c4322; transform: translateY(-1px); }
.namo-order-now-btn:disabled { background: var(--ink-soft); cursor: not-allowed; transform: none; }
.namo-order-now-btn--large { padding: 16px 36px; font-size: 1rem; }
.namo-order-now-btn--header {
	width: auto !important; flex-shrink: 0; padding: 10px 24px; font-size: .88rem;
	margin-left: 8px;
}

@media (max-width: 600px) {
	.namo-order-now-btn--header { padding: 8px 16px; font-size: .8rem; margin-left: 4px; }
}

/* ---------- Order Now modal ---------- */
body.namo-modal-lock { overflow: hidden; }
.namo-modal { position: fixed; inset: 0; z-index: 200; display: none; }
.namo-modal.is-open { display: block; }
.namo-modal__overlay { position: absolute; inset: 0; background: rgba(21, 54, 42, .55); }
.namo-modal__box {
	position: relative; max-width: 440px; margin: 8vh auto 0;
	background: var(--white); border-radius: var(--radius-m);
	padding: 32px 28px; box-shadow: 0 24px 60px rgba(0,0,0,.25);
	max-height: 84vh; overflow-y: auto;
}
.namo-modal__close {
	position: absolute; top: 14px; right: 16px; border: none; background: none;
	font-size: 1.6rem; line-height: 1; cursor: pointer; color: var(--ink-soft);
}
.namo-modal__box h3 { margin-bottom: 10px; }
.namo-modal__cod-badge {
	display: inline-flex; align-items: center; gap: 6px;
	background: var(--cream-deep); color: var(--forest-dark);
	font-size: .76rem; font-weight: 700; text-transform: uppercase; letter-spacing: .03em;
	padding: 5px 12px; border-radius: 999px; margin-bottom: 14px;
}
.namo-modal__cod-badge svg { color: var(--leaf); }

.namo-modal__product-card {
	display: flex; align-items: center; gap: 14px;
	background: var(--cream); border-radius: var(--radius-m);
	padding: 14px; margin-bottom: 22px;
}
.namo-modal__product-img {
	width: 64px; height: 64px; border-radius: var(--radius-s);
	object-fit: cover; flex-shrink: 0; background: var(--cream-deep);
}
.namo-modal__product-info { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.namo-modal__product-name { font-weight: 700; color: var(--forest-dark); font-size: .95rem; margin: 0; }
.namo-modal__product-price { font-family: var(--font-display); font-weight: 700; color: var(--terracotta); font-size: 1.1rem; }
.namo-modal__product-price del { font-size: .85rem; opacity: .5; font-weight: 400; margin-right: 6px; }
.namo-modal__product-price ins { text-decoration: none; }
.namo-modal__product-shipping {
	display: inline-flex; align-items: center; gap: 5px;
	font-size: .76rem; font-weight: 700; color: var(--leaf);
}
.namo-modal__field {
	display: block; font-size: .82rem; font-weight: 700; color: var(--forest-dark);
	margin-bottom: 14px;
}
.namo-modal__field input,
.namo-modal__field textarea {
	display: block; width: 100%; margin-top: 6px; padding: 12px 14px;
	border: 1px solid var(--cream-deep); border-radius: var(--radius-s);
	font-family: var(--font-body); font-size: .95rem; font-weight: 400; color: var(--ink);
	resize: vertical;
}
.namo-modal__field input:focus,
.namo-modal__field textarea:focus { outline: 2px solid var(--gold); border-color: var(--gold); }
.namo-modal__field.has-error input {
	border-color: var(--danger);
}
.namo-modal__field.has-error input:focus { outline-color: var(--danger); }
.namo-modal__field-error {
	display: none; color: var(--danger); font-size: .76rem; font-weight: 600;
	margin-top: 5px;
}
.namo-modal__field.has-error .namo-modal__field-error { display: block; }
.namo-modal__row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.namo-modal__row .namo-modal__field { margin-bottom: 14px; }
.namo-modal__submit { width: 100%; justify-content: center; margin-top: 6px; }
.namo-modal__note {
	display: flex; align-items: center; gap: 6px; justify-content: center;
	font-size: .78rem; color: var(--ink-soft); margin: 14px 0 0;
}
.namo-modal__error {
	background: #FBEAE8; color: var(--danger); border-radius: var(--radius-s);
	padding: 10px 12px; font-size: .85rem; margin-bottom: 14px;
}

/* ---------- Shop header / breadcrumbs ---------- */
.namo-breadcrumbs { font-size: .82rem; color: var(--ink-soft); margin: 18px 0; }
.namo-breadcrumbs a { color: var(--ink-soft); }
.namo-shop-header { padding: 28px 0 8px; }
.namo-shop-header__title { font-size: 2rem; }
.namo-shop-wrap { margin-top: 8px; }

/* WooCommerce result count / ordering / pagination */
.woocommerce-result-count,
.woocommerce-ordering { font-size: .85rem; color: var(--ink-soft); }
.woocommerce-ordering select {
	border: 1px solid var(--cream-deep); border-radius: var(--radius-s);
	padding: 8px 12px; font-family: var(--font-body);
}
.woocommerce-pagination ul.page-numbers { display: flex; gap: 8px; justify-content: center; margin: 36px 0; }
.woocommerce-pagination .page-numbers li a,
.woocommerce-pagination .page-numbers li span {
	display: grid; place-items: center; width: 38px; height: 38px;
	border-radius: 999px; background: var(--white); color: var(--forest-dark);
	font-weight: 700; box-shadow: var(--shadow-card);
}
.woocommerce-pagination .page-numbers li span.current { background: var(--forest); color: var(--white); }

/* ---------- Single product ---------- */
/* ---------- Single product (elegant, simplified) ---------- */
.single-product div.product {
	display: grid; grid-template-columns: 1fr 1fr; gap: 64px; padding: 48px 0 80px;
	align-items: start;
}
.single-product div.images { position: sticky; top: 96px; }
.single-product .woocommerce-product-gallery__image {
	border-radius: var(--radius-l); overflow: hidden; background: var(--white);
	box-shadow: var(--shadow-card);
}
.single-product .summary { padding-top: 8px; }
.single-product .summary h1.product_title {
	font-size: 2.3rem; margin-bottom: 12px; max-width: 16ch;
}
.single-product .price {
	font-family: var(--font-display); font-size: 1.9rem; font-weight: 700;
	color: var(--forest-dark); margin: 0 0 18px;
}
.single-product .price del { font-size: 1.15rem; opacity: .5; margin-right: 10px; font-weight: 400; }
.single-product .price ins { text-decoration: none; }
.single-product .woocommerce-product-details__short-description {
	color: var(--ink-soft); font-size: 1.02rem; margin-bottom: 26px; max-width: 48ch;
}
.namo-single-badges { display: flex; gap: 20px; margin-bottom: 18px; flex-wrap: wrap; }
.namo-single-badges span {
	display: inline-flex; align-items: center; gap: 6px;
	font-size: .82rem; font-weight: 700; color: var(--leaf);
}

/* Inline Order Now button — sits directly under price/badges (desktop). */
.namo-inline-cta { margin: 4px 0 22px; }
.namo-inline-cta .namo-order-now-btn--large { width: auto; }

@media (max-width: 760px) {
	.namo-inline-cta { display: none; }
}

/* Sticky bottom Order Now bar */
body.namo-has-sticky-cta { padding-bottom: 0; }
.namo-sticky-cta {
	display: none;
	position: fixed; left: 0; right: 0; bottom: 0; z-index: 120;
	background: var(--white);
	box-shadow: 0 -10px 30px rgba(31, 78, 60, .14);
	border-top: 1px solid var(--cream-deep);
}
.namo-sticky-cta__inner {
	display: flex; align-items: center; justify-content: space-between;
	gap: 18px; padding: 14px 24px;
}
.namo-sticky-cta__info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.namo-sticky-cta__name {
	font-size: .82rem; font-weight: 700; color: var(--ink-soft);
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 220px;
}
.namo-sticky-cta__price { font-family: var(--font-display); font-weight: 700; color: var(--forest-dark); font-size: 1.2rem; }
.namo-sticky-cta__price del { font-size: .9rem; opacity: .5; font-weight: 400; margin-right: 6px; }
.namo-sticky-cta__price ins { text-decoration: none; }
.namo-sticky-cta .namo-order-now-btn--large { flex-shrink: 0; min-width: 160px; }

@media (max-width: 760px) {
	body.namo-has-sticky-cta { padding-bottom: 92px; }
	.namo-sticky-cta { display: block; }
}

@media (max-width: 480px) {
	body.namo-has-sticky-cta { padding-bottom: 76px; }
	.namo-sticky-cta__inner { padding: 10px 16px; }
	.namo-sticky-cta__name { display: none; }
	.namo-sticky-cta .namo-order-now-btn--large { padding: 13px 22px; font-size: .92rem; min-width: 0; }
}
.single-product .stock.out-of-stock {
	display: inline-block; background: var(--cream-deep); color: var(--ink-soft);
	font-weight: 700; padding: 14px 32px; border-radius: 999px;
}
.single-product .namo-single-description {
	border-top: 1px solid var(--cream-deep); padding-top: 26px; margin-top: 8px;
	color: var(--ink-soft); font-size: .98rem; max-width: 52ch;
}
.single-product .namo-single-description p:last-child { margin-bottom: 0; }

/* ---------- Single product: ingredients & FAQ ---------- */
.namo-single-section__title {
	font-family: var(--font-display); font-size: 1.4rem; color: var(--forest-dark);
	margin: 0 0 16px;
}
.namo-single-ingredients {
	border-top: 1px solid var(--cream-deep); padding-top: 26px; margin-top: 26px;
	max-width: 52ch;
}
.namo-ingredients-list {
	list-style: none; margin: 0; padding: 0;
	display: flex; flex-direction: column; gap: 10px;
}
.namo-ingredients-list li {
	position: relative; padding-left: 26px; color: var(--ink-soft); font-size: .98rem;
}
.namo-ingredients-list li::before {
	content: ''; position: absolute; left: 0; top: 7px; width: 8px; height: 8px;
	border-radius: 50%; background: var(--gold);
}

.namo-single-faq {
	border-top: 1px solid var(--cream-deep); padding-top: 26px; margin-top: 26px;
	max-width: 62ch;
}
.namo-faq-accordion { display: flex; flex-direction: column; gap: 10px; }
.namo-faq-item {
	background: var(--white); border-radius: var(--radius-m);
	box-shadow: var(--shadow-card); padding: 4px 22px; overflow: hidden;
}
.namo-faq-item__question {
	cursor: pointer; list-style: none; padding: 16px 30px 16px 0; position: relative;
	font-weight: 600; color: var(--forest-dark); font-size: .98rem;
}
.namo-faq-item__question::-webkit-details-marker { display: none; }
.namo-faq-item__question::after {
	content: '+'; position: absolute; right: 0; top: 50%; transform: translateY(-50%);
	font-family: var(--font-display); font-size: 1.4rem; color: var(--gold);
	transition: transform .2s ease;
}
.namo-faq-item[open] .namo-faq-item__question::after { transform: translateY(-50%) rotate(45deg); }
.namo-faq-item__answer {
	color: var(--ink-soft); font-size: .95rem; padding-bottom: 18px; max-width: 56ch;
}
.namo-faq-item__answer p:last-child { margin-bottom: 0; }

/* ---------- Cart / Checkout / My account ---------- */
table.shop_table { width: 100%; border-collapse: collapse; margin-bottom: 28px; }
table.shop_table th { text-align: left; font-family: var(--font-display); color: var(--forest-dark); padding: 12px; border-bottom: 2px solid var(--cream-deep); }
table.shop_table td { padding: 12px; border-bottom: 1px solid var(--cream-deep); }
.cart .quantity input { width: 64px; padding: 8px; border: 1px solid var(--cream-deep); border-radius: var(--radius-s); }
.cart_totals, .checkout {
	background: var(--white); border-radius: var(--radius-m); padding: 28px;
	box-shadow: var(--shadow-card);
}
#payment .place-order .button,
.checkout-button,
.wc-proceed-to-checkout .button {
	background: var(--forest); color: var(--white); border-radius: 999px;
	padding: 14px 28px; font-weight: 700; border: none; cursor: pointer; width: 100%;
	display: inline-flex; justify-content: center;
}
.woocommerce-form-row input,
.woocommerce-form-row select,
.woocommerce-form-row textarea {
	width: 100%; padding: 12px 14px; border: 1px solid var(--cream-deep);
	border-radius: var(--radius-s); font-family: var(--font-body);
}
.woocommerce-message, .woocommerce-info, .woocommerce-error {
	border-radius: var(--radius-s); border: 1px solid var(--cream-deep);
	background: var(--white); padding: 14px 18px; list-style: none;
}
.woocommerce-message::before, .woocommerce-info::before { color: var(--forest); }
.woocommerce-error::before { color: var(--danger); }

.woocommerce-account .woocommerce-MyAccount-navigation ul { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 24px; }
.woocommerce-account .woocommerce-MyAccount-navigation a {
	background: var(--white); padding: 10px 16px; border-radius: 999px;
	font-weight: 700; box-shadow: var(--shadow-card); display: inline-block;
}
.woocommerce-account .woocommerce-MyAccount-navigation .is-active a { background: var(--forest); color: var(--white); }

/* ---------- Generic page / blog ---------- */
.namo-page { padding: 48px 0 64px; }
.namo-page--narrow { max-width: 760px; }
.namo-page__header h1 { font-size: 2.2rem; }
.namo-page__content { color: var(--ink-soft); }
.namo-article__thumb { border-radius: var(--radius-m); overflow: hidden; margin: 20px 0; }
.namo-post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.namo-post-card {
	background: var(--white); border-radius: var(--radius-m); overflow: hidden;
	box-shadow: var(--shadow-card);
}
.namo-post-card__link { display: block; padding-bottom: 18px; color: var(--ink); }
.namo-post-card__img { display: block; aspect-ratio: 16/10; overflow: hidden; }
.namo-post-card__img img { width: 100%; height: 100%; object-fit: cover; }
.namo-post-card h2 { font-size: 1.1rem; margin: 14px 18px 6px; }
.namo-post-card p { margin: 0 18px; color: var(--ink-soft); font-size: .9rem; }
.namo-404 { text-align: center; padding: 90px 0; }
.namo-404 form { margin: 24px auto; max-width: 420px; }

/* ---------- Footer ---------- */
.namo-footer { background: var(--forest-dark); padding: 22px 0; }
.namo-footer__bottom-inner p { margin: 0; font-size: .82rem; text-align: center; color: rgba(250,246,236,.7); }

@media (max-width: 600px) {
	.namo-footer__bottom-inner p { font-size: .78rem; }
}

/* ---------- About section ---------- */
.namo-about__grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 48px; align-items: start; }
.namo-about__list { display: grid; gap: 18px; }
.namo-about__list li {
	background: var(--white); border-radius: var(--radius-m); padding: 18px 20px;
	box-shadow: var(--shadow-card); color: var(--ink-soft); font-size: .94rem;
}
.namo-about__list strong { color: var(--forest-dark); display: block; margin-bottom: 2px; font-family: var(--font-display); font-size: 1.02rem; }

/* ---------- Contact section ---------- */
.namo-contact__grid { display: grid; grid-template-columns: 1.2fr .8fr; gap: 48px; align-items: center; }
.namo-contact__list { display: grid; gap: 16px; }
.namo-contact__list li {
	background: var(--white); border-radius: var(--radius-m); padding: 18px 20px;
	box-shadow: var(--shadow-card); font-size: .92rem; color: var(--ink-soft);
}
.namo-contact__list strong { color: var(--forest-dark); font-family: var(--font-display); display: block; margin-bottom: 4px; }
.namo-contact__list a { color: var(--forest); font-weight: 700; }

@media (max-width: 760px) {
	.namo-about__grid,
	.namo-contact__grid { grid-template-columns: 1fr; }
}

@media (max-width: 1024px) {
	.namo-hero__grid { grid-template-columns: 1fr; }
	.namo-hero__art { order: -1; aspect-ratio: 16/10; }
	.namo-feature,
	.namo-feature--reverse { grid-template-columns: 1fr; }
	.namo-feature--reverse .namo-feature__media,
	.namo-feature--reverse .namo-feature__body { order: 0; }
	.namo-feature__media { min-height: 300px; }
	.namo-feature__body,
	.namo-feature--reverse .namo-feature__body { padding: 32px; }
	.namo-categories__grid { grid-template-columns: repeat(3, 1fr); }
	.namo-product-grid, ul.products.namo-product-grid { grid-template-columns: repeat(3, 1fr); }
	.namo-strip__grid { grid-template-columns: repeat(2, 1fr); }
	.single-product div.product { grid-template-columns: 1fr; }
	.single-product div.images { position: static; top: auto; }
}

@media (max-width: 760px) {
	.namo-topbar__msg { display: none; }
	.namo-nav { position: fixed; top: 0; left: -100%; width: 78%; height: 100%;
		background: var(--white); padding: 90px 24px 24px; transition: left .25s ease; z-index: 60; box-shadow: 0 0 0 9999px rgba(0,0,0,0); }
	.namo-nav.is-open { left: 0; box-shadow: 0 0 40px rgba(0,0,0,.25); }
	.namo-nav__list { flex-direction: column; gap: 18px; }
	.namo-menu-toggle { display: flex; }
	.namo-categories__grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
	.namo-product-grid, ul.products.namo-product-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
	.namo-strip__grid { grid-template-columns: 1fr; gap: 20px; }
	.namo-post-grid { grid-template-columns: 1fr; gap: 18px; }

	/* -- Tighter, more elegant spacing across the board on mobile -- */
	.namo-container { padding: 0 18px; }
	.namo-topbar__inner { padding: 7px 18px; }
	.namo-header__inner { padding: 12px 18px; gap: 12px; }
	.namo-brand img { max-height: 44px; }
	.namo-logo-text { font-size: 1.3rem; }

	.namo-hero { padding: 36px 0 24px; }
	.namo-hero__grid { gap: 26px; }
	.namo-hero__sub { font-size: .98rem; }
	.namo-hero__cta { margin: 18px 0 20px; gap: 10px; }
	.namo-badges { gap: 12px 18px; }

	.namo-divider { height: 20px; margin: 0; }

	.namo-section { padding: 36px 0; }
	.namo-section__title { font-size: 1.4rem; margin-bottom: 18px; }
	.namo-section__head { margin-bottom: 18px; }

	.namo-feature { border-radius: var(--radius-m); margin-bottom: 20px; }
	.namo-feature__media { min-height: 220px; }
	.namo-feature__body,
	.namo-feature--reverse .namo-feature__body { padding: 22px; }
	.namo-feature__title { font-size: 1.5rem; }
	.namo-feature__tagline { margin-bottom: 12px; }
	.namo-feature__desc { margin-bottom: 16px; }
	.namo-feature__meta { margin-bottom: 18px; gap: 14px; }
	.namo-feature .namo-order-now-btn--large { width: 100%; min-width: 0; }

	.namo-product-card__body { padding: 14px; gap: 4px; }

	.namo-modal__box { padding: 24px 20px; margin: 6vh auto 0; max-height: 88vh; }
	.namo-modal__product-card { padding: 12px; margin-bottom: 18px; }
	.namo-modal__field { margin-bottom: 12px; }

	.namo-shop-header { padding: 18px 0 4px; }
	.namo-shop-header__title { font-size: 1.6rem; }

	.single-product div.product { padding: 24px 0 40px; gap: 28px; }
	.single-product .summary h1.product_title { font-size: 1.7rem; margin-bottom: 8px; }
	.single-product .price { font-size: 1.5rem; margin-bottom: 12px; }
	.single-product .woocommerce-product-details__short-description { margin-bottom: 18px; }
	.namo-single-badges { margin-bottom: 12px; gap: 14px; }
	.namo-single-ingredients,
	.namo-single-faq { padding-top: 18px; margin-top: 18px; }

	.namo-about__grid,
	.namo-contact__grid { gap: 24px; }
	.namo-about__list,
	.namo-contact__list { gap: 12px; }
	.namo-about__list li,
	.namo-contact__list li { padding: 14px 16px; }

	.namo-page { padding: 28px 0 40px; }
	.namo-page__header h1 { font-size: 1.7rem; }

	.namo-footer { padding: 16px 0; }
}

@media (max-width: 480px) {
	.namo-product-grid, ul.products.namo-product-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
	.namo-hero h1 { max-width: none; }

	.namo-container { padding: 0 16px; }
	.namo-hero { padding: 28px 0 20px; }
	.namo-section { padding: 28px 0; }
	.namo-feature__body,
	.namo-feature--reverse .namo-feature__body { padding: 18px; }
	.namo-feature__title { font-size: 1.32rem; }
	.namo-feature__price { font-size: 1.4rem; }
	.single-product .summary h1.product_title { font-size: 1.5rem; }
	.namo-modal__box { padding: 20px 16px; }
	.namo-modal__row { grid-template-columns: 1fr; gap: 0; }
}

@media (prefers-reduced-motion: reduce) {
	* { transition: none !important; animation: none !important; }
}
