@font-face {
	font-family: "Montserrat";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("/assets/nrp/fonts/montserrat-400.ttf") format("truetype");
}

@font-face {
	font-family: "Montserrat";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("/assets/nrp/fonts/montserrat-500.ttf") format("truetype");
}

@font-face {
	font-family: "Montserrat";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("/assets/nrp/fonts/montserrat-600.ttf") format("truetype");
}

@font-face {
	font-family: "Montserrat";
	font-style: normal;
	font-weight: 700;
	font-display: swap;
	src: url("/assets/nrp/fonts/montserrat-700.ttf") format("truetype");
}

@font-face {
	font-family: "Montserrat";
	font-style: normal;
	font-weight: 800;
	font-display: swap;
	src: url("/assets/nrp/fonts/montserrat-800.ttf") format("truetype");
}

:root {
	--brand-gold: #b8935e;
	--brand-gold-strong: #9f7948;
	--text-accent: #7a5524;
	--surface-accent-bg: #e7d2ad;
	--surface-accent-fg: #4b2b11;
	--surface-accent-border: rgba(111, 77, 38, 0.35);
	--surface-shell-bg: rgba(255, 255, 255, 0.96);
	--action-primary-bg: var(--brand-gold);
	--action-primary-bg-hover: var(--brand-gold-strong);
	--action-primary-fg: #2f1a09;
	--action-primary-shadow: rgba(184, 147, 94, 0.28);

	--theme-color: var(--brand-gold);
	--theme-color-strong: var(--brand-gold-strong);
	--theme-color-soft: #fdf7ec;
	--theme-color-muted: var(--surface-accent-bg);
	--theme-color-border: var(--surface-accent-border);

	--bg-light: #faf8f5;
	--card-bg: #ffffff;
	--text-dark: #4b2b11;
	--text-dim: #666666;
	--text-deep: #0b0b0f;
	--text-light: #f6f2eb;
	--text-inverse: #fdf9f3;
	--hero-content-bg: #4f351c3d;
	--border-color: #e5e5e5;
	--border-soft: rgba(0, 0, 0, 0.05);

	--accent-warn: #d97706;
	--accent-error: #b91c1c;
	--accent-info: #0369a1;
	--accent-muted: #6b7280;
	--accent-success: #10b981;

	--state-error-bg: #fee2e2;
	--state-info-bg: #e0f2fe;
	--state-sale-bg: #fef3c7;
	--state-sale-text: #b45309;
	--state-quick-add-disabled-bg: #cbc0af;
	--state-disabled-text: #6b7280;
	--state-quiet-text: #9ca3af;

	--hero-grad-start: #f7f2e8;
	--hero-grad-end: #e8dcc6;
	--overlay-dark: rgba(0, 0, 0, 0.3);
	--overlay-glass-border: rgba(255, 255, 255, 0.2);

	--ink-overlay: rgba(92, 74, 50, 0.7);
	--ink-overlay-strong: rgba(92, 74, 50, 0.9);
	--logo-filter-text-dark: brightness(0) saturate(100%) invert(13%) sepia(33%) saturate(1579%) hue-rotate(347deg)
		brightness(92%) contrast(93%);

	--spinner-ring: #d9c4a0;
	--spinner-highlight: #7a5524;
}

body.product-page {
	font-family: "Montserrat", sans-serif;
	background-color: var(--card-bg);
	color: var(--text-dark);
	overflow-x: hidden;
}

/* Hide the default site navbar just on this page */
header.navbar,
.web-navbar,
.navbar.navbar-light,
.navbar.navbar-default,
.navbar.navbar-expand-lg {
	display: none !important;
}

.nrp-shop-shell {
	max-width: 1400px;
	margin: 0 auto;
	padding: 2rem;
}

/* Override parent container margin */
.container.my-4 {
	margin-bottom: 0 !important;
	margin-top: 0 !important;
}

.page-breadcrumbs {
	display: none !important;
}
/* Ensure newsletter sticks to bottom */
body {
	margin-bottom: 0 !important;
	padding-bottom: 0 !important;
}

@media (max-width: 768px) {
	.nrp-shop-shell {
		padding: 1rem;
	}
}

/* SVG Icon utility */
.svg-icon svg {
	width: 100%;
	height: 100%;
}
body.nrp-navbar-mounted {
	padding-top: var(--nrp-navbar-height, 92px) !important;
}

.nrp-navbar {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1100;
	background: var(--surface-shell-bg);
	backdrop-filter: blur(12px);
	border-bottom: 1px solid var(--theme-color-border);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.05);
	border-radius: 0 0 20px 20px;
	transition: transform 0.28s ease, opacity 0.2s ease, box-shadow 0.28s ease;
	will-change: transform;
}

.nrp-navbar.is-hidden {
	transform: translateY(calc(-100% - 10px));
	opacity: 0.98;
	pointer-events: none;
	box-shadow: 0 6px 18px rgba(0, 0, 0, 0.04);
}

.nrp-nav-inner {
	font-family: 'Montserrat';
	max-width: 1400px;
	margin: 0 auto;
	padding: 0.85rem 2rem;
	display: flex;
	align-items: center;
	gap: 1.25rem;
	justify-content: space-between;
	position: relative;
}

.nrp-logo {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	text-decoration: none;
	color: var(--text-dark);
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 1px;
	font-size: 1.1rem;
}

.nrp-logo-img {
	max-height: 56px;
	width: auto;
	display: block;
	object-fit: contain;
	filter: var(--logo-filter-text-dark);
}

.nrp-nav-links {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	flex: 1;
}

.nrp-nav-link {
	color: var(--text-dark);
	text-decoration: none;
	font-weight: 600;
	padding: 0.5rem 0.85rem;
	border-radius: 10px;
	transition: color 0.2s ease, background 0.2s ease, transform 0.2s ease;
}

.nrp-nav-link:hover {
	color: var(--text-dark);
	background: var(--bg-light);
	transform: translateY(-1px);
}

.nrp-nav-link.active {
	color: var(--surface-accent-fg);
	background: var(--surface-accent-bg);
	border: 1px solid var(--surface-accent-border);
}

.nrp-nav-actions {
	display: flex;
	align-items: center;
	gap: 0.65rem;
}

.nrp-account-menu {
	position: relative;
}

.nrp-account-dropdown {
	position: absolute;
	top: calc(100% + 8px);
	right: 0;
	background: var(--card-bg);
	border: 1px solid var(--border-soft);
	box-shadow: 0 18px 30px rgba(0, 0, 0, 0.08);
	border-radius: 12px;
	min-width: 180px;
	padding: 0.35rem 0;
	display: none;
	z-index: 1200;
}

.nrp-account-dropdown.open {
	display: block;
}

.nrp-account-link {
	display: block;
	padding: 0.65rem 0.95rem;
	color: var(--text-dark);
	text-decoration: none;
	font-weight: 600;
	transition: background 0.15s ease, color 0.15s ease;
}

.nrp-account-link:hover {
	background: var(--bg-light);
	color: var(--text-accent);
}

.nrp-nav-icon {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--bg-light);
	color: var(--text-dark);
	text-decoration: none;
	border: 1px solid var(--border-soft);
	transition: all 0.2s ease;
	position: relative;
}

.nrp-nav-icon:hover {
	color: var(--text-accent);
	transform: translateY(-2px);
}

.nrp-nav-icon svg {
	width: 18px;
	height: 18px;
}

.nrp-nav-icon.is-open {
	background: var(--surface-accent-bg);
	color: var(--surface-accent-fg);
	border-color: var(--surface-accent-border);
}

.nrp-navbar-search-panel {
	position: absolute;
	top: calc(100% + 8px);
	right: 2rem;
	width: 0;
	opacity: 0;
	overflow: hidden;
	pointer-events: none;
	transition: width 0.25s ease, opacity 0.18s ease;
	z-index: 1250;
}

.nrp-navbar-search-panel.is-open {
	width: min(24vw, 300px);
	opacity: 1;
	pointer-events: auto;
	overflow: visible;
}

.nrp-navbar-search-inner {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.1rem 0.2rem 0.1rem 0.45rem;
	background: var(--bg-light);
	border: 1px solid var(--theme-color);
	border-radius: 999px;
	height: 44px;
	box-sizing: border-box;
	box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
}

.nrp-navbar-search-inner .nrp-navbar-search-input {
	flex: 1;
	min-width: 0;
	height: 34px !important;
	border: 0 !important;
	box-shadow: none !important;
	padding: 0.25rem 0.25rem !important;
	background: transparent;
	border-radius: 0;
	font-size: 0.92rem;
	appearance: none;
	-webkit-appearance: none;
	outline: none;
}

.nrp-navbar-search-close {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	border: 0;
	background: rgba(255, 255, 255, 0.65);
	color: var(--text-dark);
	font-size: 1rem;
	line-height: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background 0.2s ease, transform 0.2s ease;
}

.nrp-navbar-search-close:hover {
	background: var(--surface-accent-bg);
	transform: scale(1.03);
}

.nrp-navbar-search-menu {
	position: absolute;
	top: calc(100% + 6px);
	left: 0;
	right: 0;
	background: var(--card-bg);
	border: 1px solid var(--theme-color-border);
	border-radius: 10px;
	box-shadow: 0 14px 30px rgba(0, 0, 0, 0.12);
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	transform: translateY(-4px);
	pointer-events: none;
	transition: max-height 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
	z-index: 1300;
}

.nrp-navbar-search-menu.is-open {
	max-height: 300px;
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
	overflow-y: auto;
}

.nrp-navbar-search-option {
	display: block;
	padding: 0.55rem 0.75rem;
	color: var(--text-dark);
	text-decoration: none;
	font-size: 0.9rem;
	border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.nrp-navbar-search-option:last-child {
	border-bottom: 0;
}

.nrp-navbar-search-option:hover {
	background: var(--bg-light);
	color: var(--text-accent);
}

.nrp-pill-link {
	text-decoration: none;
	font-weight: 700;
	padding: 0.55rem 1.1rem;
	border-radius: 999px;
	border: 1px solid var(--theme-color-border);
	color: var(--text-dark);
	background: var(--card-bg);
	transition: all 0.2s ease;
	white-space: nowrap;
}

.nrp-pill-link:hover {
	border-color: var(--theme-color);
	color: var(--text-accent);
	box-shadow: 0 10px 24px rgba(207, 171, 113, 0.2);
}

.nrp-cta {
	background: var(--action-primary-bg);
	color: var(--action-primary-fg);
	border-color: var(--action-primary-bg);
	box-shadow: 0 12px 24px var(--action-primary-shadow);
}

.nrp-cta:hover {
	background: var(--action-primary-bg-hover);
	color: var(--action-primary-fg);
	border-color: var(--action-primary-bg-hover);
}

.nrp-nav-toggle {
	display: none;
	background: transparent;
	border: 1px solid var(--border-soft);
	width: 44px;
	height: 44px;
	border-radius: 50%;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	color: var(--text-dark);
	transition: all 0.2s ease;
}

.nrp-nav-toggle:hover {
	color: var(--text-accent);
	border-color: var(--theme-color-border);
}

.nrp-nav-toggle svg {
	width: 20px;
	height: 20px;
}

.nrp-nav-mobile-actions {
	display: none;
	gap: 0.75rem;
	width: 100%;
	margin-top: 0.25rem;
}

.nrp-cart-badge {
	position: absolute;
	top: -2px;
	right: -2px;
	background: var(--action-primary-bg);
	color: var(--action-primary-fg);
	border-radius: 999px;
	min-width: 18px;
	height: 18px;
	padding: 0 4px;
	font-size: 0.7rem;
	font-weight: 700;
	line-height: 18px;
	font-variant-numeric: tabular-nums;
	display: flex;
	align-items: center;
	justify-content: center;
	white-space: nowrap;
	opacity: 0;
	transform: scale(0);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.nrp-cart-badge.has-items {
	opacity: 1;
	transform: scale(1);
}

.nrp-cart-badge.is-updated {
	animation: nrp-cart-pop 0.5s ease;
}

@keyframes nrp-cart-pop {
	0% {
		transform: scale(1);
	}
	20% {
		transform: scale(1.18);
	}
	45% {
		transform: scale(0.92);
	}
	70% {
		transform: scale(1.05);
	}
	100% {
		transform: scale(1);
	}
}

@media (max-width: 1024px) {
	.nrp-nav-inner {
		padding: 0.75rem 1.25rem;
		flex-wrap: wrap;
		align-items: center;
	}

	.nrp-navbar-search-panel.is-open {
		width: min(78vw, 300px);
	}

	.nrp-nav-links {
		position: static;
		flex-basis: 100%;
		order: 3;
		background: rgba(255, 255, 255, 0.98);
		padding: 0.75rem 0 1rem 0;
		border-top: 1px solid var(--theme-color-border);
		box-shadow: none;
		flex-direction: column;
		align-items: flex-start;
		gap: 0.35rem;
		display: none;
	}

	.nrp-navbar.open .nrp-nav-links {
		display: flex;
	}

	.nrp-nav-actions {
		display: none;
	}

	.nrp-nav-mobile-actions {
		display: flex;
		flex-direction: column;
	}

	.nrp-nav-mobile-actions .nrp-nav-search-trigger {
		width: 100%;
		text-align: left;
	}

	.nrp-account-menu-mobile .nrp-account-dropdown {
		position: static;
		display: block;
		box-shadow: none;
		border: 1px solid var(--border-soft);
		border-radius: 12px;
	}

	.nrp-nav-toggle {
		display: inline-flex;
	}

	.nrp-nav-link {
		width: 100%;
	}

	.nrp-navbar-search-panel {
		right: 1.25rem;
	}
}

@media (max-width: 640px) {
	.nrp-logo {
		font-size: 1rem;
	}

	.nrp-nav-inner {
		gap: 0.75rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.nrp-navbar {
		transition: none;
	}
}
.nrp-newsletter-wrapper {
	margin-top: 2rem;
	margin-bottom: 0;
	flex: 0 0 auto;
	width: 100vw;
	max-width: 100vw;
	position: relative;
	left: 50%;
	right: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
	overflow-x: clip;
	box-sizing: border-box;
}

.newsletter-section {
	background: var(--text-dark);
	color: var(--text-inverse);
	padding-top: 3rem;
	margin: 0 !important;
	width: 100% !important; /* fill available width without overflow tricks */
	position: relative;
	left: auto;
	margin-left: 0 !important;
	margin-right: 0 !important;
	margin-bottom: 0 !important;
	clear: both;
	font-family: 'Montserrat';
}

.newsletter-content {
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 2rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 3rem;
}

.newsletter-left {
	flex: 1;
	max-width: 600px;
}

.newsletter-content .newsletter-title,
.newsletter-content .newsletter-form {
	max-width: 100%;
}

/* Social Media Icons */
.social-media {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	align-items: center;
	justify-content: center;
}

.social-media-title {
	font-size: 0.9rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.8);
	margin: 0;
	white-space: nowrap;
	text-align: center;
}

.social-icons {
	display: flex;
	gap: 1rem;
}

.social-icon {
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.1);
	border-radius: 50%;
	color: var(--text-inverse);
	text-decoration: none;
	transition: all 0.3s;
	border: 1px solid rgba(255, 255, 255, 0.2);
}

.social-icon:hover {
	background: var(--action-primary-bg);
	border-color: var(--action-primary-bg);
	color: var(--action-primary-fg);
	transform: translateY(-3px);
}

.social-icon svg {
	width: 20px;
	height: 20px;
	fill: currentColor;
}

/* Footer Bottom Bar */
.footer-bottom {
    background: var(--surface-accent-fg);
	border-top: 1px solid var(--surface-accent-border);
	padding: 1rem 2rem;
	margin-top: 2.5rem;
}

.footer-bottom-content {
	max-width: 1400px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 2rem;
}

.footer-copyright {
	color: var(--surface-accent-bg);
	font-size: 0.85rem;
	margin: 0;
}

.footer-links {
	display: flex;
	gap: 2rem;
	align-items: center;
}

.footer-links a {
	color: var(--surface-accent-bg);
    text-decoration: none;
    font-size: .85rem;
    transition: opacity .2s;
}

.footer-links a:hover {
	color: var(--text-accent);
}

.newsletter-title {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--text-inverse);
	margin: 0 0 1.5rem 0;
	text-align: left;
}

.newsletter-form {
	display: flex;
	gap: 1rem;
	align-items: center;
}

.newsletter-input {
	flex: 1;
	padding: 0.75rem 1rem;
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 8px;
	font-family: inherit;
	font-size: 0.9rem;
	outline: none;
	transition: border-color 0.2s;
	height: 48px;
	background: rgba(255, 255, 255, 0.1);
	color: var(--text-inverse);
}

.newsletter-input:focus {
	border-color: var(--theme-color);
	background: rgba(255, 255, 255, 0.15);
}

.newsletter-input::placeholder {
	color: rgba(255, 255, 255, 0.6);
}

.newsletter-btn {
	background: var(--action-primary-bg) !important;
	border: 1px solid var(--action-primary-bg) !important;
	color: var(--action-primary-fg) !important;
	font-weight: 600 !important;
	padding: 0.5rem 1.5rem !important;
	border-radius: 8px !important;
	transition: all 0.2s !important;
	height: 48px;
	cursor: pointer;
	white-space: nowrap;
	font-family: inherit;
	font-size: 0.9rem;
}

.newsletter-btn:hover {
	background: var(--action-primary-bg-hover) !important;
	border-color: var(--action-primary-bg-hover) !important;
	transform: translateY(-2px) !important;
}

@media (max-width: 768px) {
	.newsletter-section {
		padding: 2rem 0 !important;
	}

	.newsletter-content {
		padding: 0 1rem;
		flex-direction: column;
		align-items: flex-start;
		gap: 2rem;
	}

	.newsletter-left {
		max-width: 100%;
		width: 100%;
	}

	.newsletter-content .newsletter-title,
	.newsletter-content .newsletter-form {
		max-width: 100%;
	}

	.newsletter-form {
		flex-direction: column;
		align-items: stretch;
	}

	.newsletter-input,
	.newsletter-btn {
		width: 100%;
	}

	.social-media {
		width: 100%;
		gap: 1rem;
	}

	.social-icons {
		justify-content: center;
		flex-wrap: wrap;
	}

	.footer-bottom {
		padding: 1rem;
		margin-top: 2rem;
	}

	.footer-bottom-content {
		flex-direction: column;
		text-align: center;
		gap: 1rem;
	}

	.footer-copyright {
		font-size: 0.75rem;
	}

	.footer-links {
		gap: 1.5rem;
	}

	.footer-links a {
		font-size: 0.75rem;
	}
}

/* Keep Frappe dialogs above custom navbar/search layers */
.modal-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(33, 22, 11, 0.45);
	opacity: 1;
	z-index: 1400 !important;
}

.modal {
	position: fixed;
	inset: 0;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 1.5rem 1rem;
	overflow-y: auto;
	z-index: 1410 !important;
}

.modal.fade.show {
	display: flex !important;
}

.modal-dialog {
	position: relative;
	width: 100%;
	max-width: 560px;
	margin: 0 auto;
	pointer-events: none;
}

.modal-content {
	pointer-events: auto;
	background: #fff;
	border: 1px solid rgba(111, 79, 44, 0.18);
	border-radius: 18px;
	box-shadow: 0 22px 50px rgba(36, 24, 12, 0.22);
	overflow: hidden;
	font-family: "Montserrat", sans-serif;
	color: var(--theme-color-dark, #2f2114);
}

.modal-header,
.modal-footer {
	display: flex;
	align-items: center;
	padding: 1rem 1.25rem;
}

.modal-header {
	justify-content: space-between;
	border-bottom: 1px solid rgba(111, 79, 44, 0.12);
}

.modal-title {
	margin: 0;
	font-size: 1.15rem;
	font-weight: 700;
	color: var(--theme-color-dark, #2f2114);
}

.modal-body {
	padding: 1.15rem 1.25rem 1.25rem;
	max-height: min(70vh, 560px);
	overflow-y: auto;
}

.modal-footer {
	justify-content: flex-end;
	gap: 0.75rem;
	border-top: 1px solid rgba(111, 79, 44, 0.12);
}

.modal .close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	padding: 0;
	border: none;
	border-radius: 999px;
	background: transparent;
	color: rgba(47, 33, 20, 0.72);
	cursor: pointer;
}

.modal .close:hover {
	background: rgba(207, 171, 113, 0.12);
	color: var(--theme-color-dark, #2f2114);
}

.modal .close .icon {
	width: 1rem;
	height: 1rem;
}

.modal .btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 2.75rem;
	padding: 0.7rem 1.2rem;
	border-radius: 10px;
	border: 1px solid transparent;
	font-weight: 600;
	font-size: 0.94rem;
	text-decoration: none;
	cursor: pointer;
}

.modal .btn-secondary {
	background: #fff;
	border-color: rgba(111, 79, 44, 0.2);
	color: var(--theme-color-dark, #2f2114);
}

.modal .btn-primary {
	background: linear-gradient(135deg, #cfab71 0%, #b8944d 100%);
	color: #fff;
	box-shadow: 0 8px 18px rgba(207, 171, 113, 0.28);
}

.msgprint-dialog .msgprint {
	font-size: 0.95rem;
	line-height: 1.6;
	color: var(--theme-color-dark, #2f2114);
	word-break: break-word;
}

.msgprint-dialog .msgprint hr {
	margin: 0.85rem 0;
	border: 0;
	border-top: 1px solid rgba(111, 79, 44, 0.12);
}

.modal-footer.hidden,
.modal .hidden {
	display: none !important;
}
