:root{
	/* Project color tokens */
	--primary-color: #214072;
	--secondary-color: #FECC22;
	--white-color: #ffffff;
	--black-color: #0f0f0f;
	/* Back-compat variables used in existing CSS */
	--pz-primary: var(--primary-color);
	--pz-accent: var(--secondary-color);
	--pz-muted: #6c757d;
}
html{ min-height: 100%; }
body{
	font-family: system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}
main{ flex: 1 0 auto; }
h1{ color: var(--primary-color); }
.navbar .nav-link{ padding: .5rem .75rem; }
.hero{ padding: 3rem 0 2rem; background: linear-gradient(180deg, #f8fafc, #fff); }
.hero h1{ font-weight: 700; letter-spacing: -0.02em; color: var(--primary-color); }
.hero .lead{ color: var(--pz-muted); }
.category-grid .card{ transition: transform .2s ease, box-shadow .2s ease; }
.category-grid .card:hover{ transform: translateY(-3px); box-shadow: 0 10px 25px rgba(16,24,40,.08); }
.category-card{ border: 2px solid rgba(33,64,114,.3); border-radius: 12px; overflow: hidden; background: #fff; }
.category-card .ratio{ border-radius: 10px; }
.object-fit-cover{ object-fit: cover; }
.category-badge{
	position: absolute; left: 16px; bottom: 16px;
	background: var(--primary-color);
	color: var(--white-color);
	padding: .35rem .75rem;
	border-radius: .75rem;
	font-weight: 700; letter-spacing: .02em; font-size: .9rem;
	box-shadow: 0 4px 12px rgba(16,24,40,.15);
}
.product-card{ transition: transform .2s ease, box-shadow .2s ease; }
.product-card:hover{ transform: translateY(-3px); box-shadow: 0 12px 30px rgba(16,24,40,.1); }
.section-title{ font-weight: 700; margin-bottom: 1rem; color: var(--primary-color); }
.map-placeholder{ background:#eef2f7; border-radius: .5rem; min-height: 320px; display:flex; align-items:center; justify-content:center; color:#9aa4b2; }

/* Buttons: use secondary color as brand action with white text */
.btn-primary,
.btn-danger{ /* align main CTA styles */
	background-color: var(--secondary-color) !important;
	border-color: var(--secondary-color) !important;
	color: var(--white-color) !important;
}
.btn-primary:hover,
.btn-danger:hover{
	background-color: #e6b800 !important; /* slightly darker than #FECC22 */
	border-color: #e6b800 !important;
	color: var(--white-color) !important;
}

/* Outline buttons: light text with secondary border; fill on hover */
.btn-outline-primary,
.btn-outline-secondary{
	color: #9aa4b2 !important; /* light gray text */
	border-color: var(--secondary-color) !important;
}
.btn-outline-primary:hover,
.btn-outline-secondary:hover{
	background-color: var(--secondary-color) !important;
	border-color: var(--secondary-color) !important;
	color: var(--white-color) !important;
}

/* Header-based carousel controls */
.carousel-header-controls .btn{ border-radius: .5rem; }

/* --- E-shop sidebar styling --- */
.eshop-sidebar {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.eshop-panel {
	background: #ffffff;
	border-radius: 1rem;
	border: 1px solid rgba(33, 64, 114, 0.08);
	box-shadow: 0 18px 36px rgba(15, 24, 44, 0.06);
}

.eshop-panel__header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
	padding: 1.25rem 1.5rem 0.75rem;
}

.eshop-panel__body {
	padding: 0.5rem 1.5rem 1.5rem;
}

.eshop-panel__title {
	display: block;
	font-weight: 600;
	color: #1d2848;
}

.eshop-panel__subtitle {
	display: block;
	font-size: 0.85rem;
	color: #6f7d95;
	margin-top: 0.25rem;
}

.eshop-panel__action {
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--primary-color);
	text-decoration: none;
	font-weight: 600;
	padding-top: 0.3rem;
}

.eshop-panel__action:hover {
	text-decoration: underline;
}

.eshop-panel__empty {
	font-size: 0.85rem;
	color: #8893ab;
	background: rgba(33, 64, 114, 0.05);
	border-radius: 0.75rem;
	padding: 0.75rem 1rem;
}

.eshop-category-node {
	--node-level: 0;
	padding-left: calc(var(--node-level) * 1.25rem);
	margin-bottom: 0.25rem;
}

.eshop-category-node__row {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	border-radius: 0.75rem;
	padding: 0.55rem 0.75rem;
	transition: background-color 0.2s ease, box-shadow 0.2s ease;
}

.eshop-category-link {
	flex: 1;
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	text-decoration: none;
	font-weight: 500;
	color: #27324f;
}

.eshop-category-link:hover {
	color: var(--primary-color);
}

.eshop-category-bullet {
	width: 0.45rem;
	height: 0.45rem;
	border-radius: 50%;
	background: rgba(33, 64, 114, 0.35);
	transition: transform 0.2s ease, background-color 0.2s ease;
}

.eshop-category-label {
	line-height: 1.35;
}

.eshop-category-toggle {
	border: none;
	width: 1.75rem;
	height: 1.75rem;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: rgba(33, 64, 114, 0.05);
	color: #5f6b86;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.eshop-category-toggle:hover {
	background: rgba(33, 64, 114, 0.12);
	color: var(--primary-color);
}

.eshop-category-children {
	display: none;
	padding-left: 0.75rem;
	padding-top: 0.25rem;
}

.eshop-category-children.show {
	display: block;
}

.eshop-category-node.is-active > .eshop-category-node__row {
	background: rgba(33, 64, 114, 0.08);
	box-shadow: inset 0 0 0 1px rgba(33, 64, 114, 0.2);
}

/* --- Subpages: services & contact --- */
.subpage-hero{
	background: linear-gradient(135deg, rgba(33,64,114,0.08), rgba(254,204,34,0.08));
}
.subpage-hero-card{
	border: 1px solid rgba(33,64,114,0.08);
}
.service-card{
	transition: transform .2s ease, box-shadow .2s ease;
}
.service-card:hover{
	transform: translateY(-4px);
	box-shadow: 0 20px 45px rgba(15,24,44,0.12);
}
.service-icon{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3.5rem;
	height: 3.5rem;
	border-radius: 1rem;
	background: rgba(33,64,114,0.08);
	font-size: 1.6rem;
}
.timeline-grid{
	display: grid;
	gap: 1.5rem;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.timeline-number{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 3rem;
	border-radius: 0.75rem;
	background: rgba(254,204,34,0.2);
	color: var(--primary-color);
	font-weight: 700;
	margin-bottom: 1rem;
}
.benefit-dot{
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: var(--secondary-color);
	box-shadow: 0 0 0 4px rgba(254,204,34,0.3);
}
.service-cta{
	background: linear-gradient(135deg, #214072, #14294b);
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.contact-card{
	border: 1px solid rgba(33,64,114,0.08);
	transition: transform .2s ease, box-shadow .2s ease;
	color: inherit;
}
.contact-card:hover{
	transform: translateY(-3px);
	box-shadow: 0 18px 40px rgba(15,24,44,0.12);
	color: inherit;
}
.contact-icon{
	width: 3rem;
	height: 3rem;
	border-radius: 1rem;
	background: rgba(33,64,114,0.12);
	color: var(--primary-color);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 1.4rem;
}
.support-card{
	border: 1px solid rgba(33,64,114,0.08);
}
.branch-map{
	height: 420px;
	border-radius: 1.25rem;
	overflow: hidden;
}
.branch-list{
	max-height: 520px;
	overflow-y: auto;
	padding-right: .25rem;
}
.branch-card{
	border: 1px solid rgba(33,64,114,0.08);
	transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
	background: #fff;
}
.branch-card:hover{
	transform: translateY(-3px);
	box-shadow: 0 15px 35px rgba(15,24,44,0.12);
}
.branch-card.is-active{
	border-color: var(--secondary-color);
	box-shadow: 0 0 0 4px rgba(254,204,34,0.25);
}
.branch-card .badge{
	font-size: .65rem;
	letter-spacing: .08em;
}
@media (max-width: 991.98px) {
	.branch-map{
		height: 320px;
		margin-bottom: 1rem;
	}
	.branch-list{
		max-height: none;
	}
}

.eshop-category-node.is-active .eshop-category-bullet {
	background: var(--primary-color);
	transform: scale(1.4);
}

.eshop-category-node.is-open > .eshop-category-node__row {
	background: rgba(33, 64, 114, 0.06);
}

@media (max-width: 991.98px) {
	.eshop-sidebar {
		flex-direction: row;
		gap: 1rem;
		overflow-x: auto;
		padding-bottom: 0.5rem;
	}

	.eshop-panel {
		min-width: 260px;
	}
}

/* --- Product detail styling --- */
.product-media .product-thumb img {
	width: 80px;
	height: 80px;
	object-fit: cover;
}

.product-media .product-thumb {
	border-radius: 0.75rem;
	border: 1px solid rgba(33, 64, 114, 0.2);
	background: #fff;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.product-media .product-thumb.is-active,
.product-media .product-thumb:hover {
	border-color: var(--primary-color);
	box-shadow: 0 0 0 3px rgba(33, 64, 114, 0.12);
}

.product-media-main {
	background: linear-gradient(135deg, rgba(33, 64, 114, 0.08), rgba(254, 204, 34, 0.08));
}

.product-summary .badge {
	background: rgba(33, 64, 114, 0.12) !important;
	color: var(--primary-color) !important;
	letter-spacing: 0.12em;
}

.product-price {
	color: var(--primary-color);
}

.product-summary .btn {
	font-weight: 600;
}

.product-attributes dt {
	letter-spacing: 0.08em;
	font-weight: 600;
}

.product-attributes dd {
	margin-bottom: 0;
}

.product-summary .border-top {
	border-color: rgba(33, 64, 114, 0.12) !important;
}

@media (max-width: 991.98px) {
	.product-media .product-thumb img {
		width: 64px;
		height: 64px;
	}
}
