/* ==========================================================================
   Kontra B2C Styles
   - Structure:
     1) Offcanvas (mobile menu)
     2) Product list (mobile and general)
     3) Accordion
     4) Horizontal navigation
     5) Header (mobile)
     6) Search (mobile)
     7) Mega menu (general)
	 8) Checkout
   - Notes:
     * Fixed @media / @keyframes typos.
     * Kept existing CSS variables.
     * Reduced duplication and normalized spacing.
========================================================================== */

/* ==========================================================================
   1) Offcanvas (Mobile Menu)
========================================================================== */

.offcanvas {
	width: 100vw;
	border-right: none;
	border-left: none;
}

	.offcanvas > .offcanvas-header {
		justify-content: space-between;
		padding: 24px 16px !important;
	}

	.offcanvas .offcanvas-heading {
		padding: 12px 16px 8px;
		font-size: 14px;
	}

	.offcanvas .nav {
		background-color: #ffffff;
	}

.close-canvas-btn {
	position: relative;
	right: -12px;
}

/* Base navigation container spacing */
.offcanvas > .offcanvas-body > .offcanvas-navigation,
.offcanvas-navigation .nav .sub-nav-check:checked ~ .sub-nav > div.sub-nav-inner {
	padding: 0 16px;
}

	/* Nav container: spacing and background */
	.offcanvas > .offcanvas-body > .offcanvas-navigation > .nav {
		margin-bottom: 1em;
		background-color: rgba(0, 0, 0, 0.2);
		border-radius: 8px;
	}

		/* Nav header styling */
		.offcanvas > .offcanvas-body > .offcanvas-navigation > .nav .nav-header {
			border-radius: 8px;
			background-color: var(--swift-button-secondary-background-color);
		}

/* Expanded sub nav container */
.offcanvas-navigation .nav .sub-nav-check:checked ~ .sub-nav > div {
	border-radius: 8px;
	height: fit-content !important;
}

/* Tertiary nav overrides */
.offcanvas > .offcanvas-body > .offcanvas-navigation > .nav.tertiary-nav {
	background: transparent;
}

.offcanvas > .offcanvas-body > .offcanvas-navigation .nav.tertiary-nav .nav-item-list {
	margin-top: 0px !important;
	margin-bottom: 32px;
}

.offcanvas > .offcanvas-body > .offcanvas-navigation > .nav.tertiary-nav .nav-item {
	border-bottom: 2px solid rgba(0, 0, 0, 0.2);
}

/* Theme specific overrides */
.kontra_basic_grey_alt > .offcanvas-body > .offcanvas-navigation > .nav.tertiary-nav .nav-item {
	border-bottom: none;
}

/* Nav link padding (links and label-toggles aligned) */
.offcanvas-navigation .nav a.nav-link,
.offcanvas-navigation .nav label.nav-link {
	padding: 24px;
}

.offcanvas-navigation .nav.tertiary-nav a.nav-link {
	padding-top: 8px;
	padding-bottom: 8px;
}

/* Divider lines between items */
.offcanvas-navigation .nav .nav-item .nav-item-divider {
	position: relative;
	width: 100%;
}

.offcanvas-navigation .nav .nav-item-list > .nav-item:not(:last-child) .nav-item-divider:after {
	content: "";
	background-color: #B2B2B2;
	height: 1px;
	display: block;
	position: absolute;
	width: calc(100% - 48px);
	bottom: 0;
	left: 24px;
}

.offcanvas-navigation .nav .nav-item-list > .nav-item:last-child .nav-item-divider:after {
	background-color: transparent;
	height: 0;
}

/* Theme: kontra_basic_grey_alt specific */
.offcanvas-navigation .nav .nav-header:before {
	background-color: transparent;
}

.kontra_basic_grey_alt > .offcanvas-body > .offcanvas-navigation > .nav {
	background-color: var(--swift-button-primary-background-color);
	border-radius: 8px;
}

.offcanvas-navigation .nav .sub-nav-check:checked ~ .sub-nav > div {
	background-color: transparent;
}

	.offcanvas-navigation .nav .sub-nav-check:checked ~ .sub-nav > div .nav-item-list {
		margin-top: 16px;
		background-color: var(--swift-button-primary-background-color);
		border-radius: 8px;
	}

.offcanvas-navigation .nav .sub-nav-check:checked ~ .sub-nav .tertiary-nav > .nav-item-list {
	background-color: transparent;
}

/* ==========================================================================
   2) Product List (Mobile and General)
========================================================================== */
/* Mobile product list adjustments */
@media screen and (width < 992px) {
	.product-short-text .grid {
		gap: unset;
	}
}

/* Truncated lines for short description */
div .ellipsis-short {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* Grid for product list (when no .productDesc-short) */
dl.grid:not(:has(.productDesc-short)) {
	display: grid;
	gap: 9px;
	margin: 0;
	padding: 9px 1.25rem;
}

/* Align dt/dd rows */
dl .grid dt,
dl.grid dd.productDesc-short {
	padding: 9px 0 !important;
	display: flex !important;
	align-items: center !important;
}

/* Brand line */
dl .gap-1.productbrand-plp dt,
dl.productbrand-plp dd {
	padding: 0 !important;
	display: flex !important;
	align-items: center !important;
	font-weight: 600 !important;
	margin-bottom: 0 !important;
}

/* Product name line */
dl .gap-1.productname-plp dt,
dl.productname-plp dd {
	padding: 0 !important;
	display: flex !important;
	align-items: center !important;
	font-weight: normal;
	margin-bottom: 0 !important;
	font-size: 0.9rem !important;
}

/* Product card container */
div .theme.kontra_basic_grey.item_swift_1columncomponentedit {
	background-color: var(--swift-background-color);
	border-radius: 12px;
	overflow: hidden;
	display: inline-block;
	padding: 8px;
}

/* Square button used in PLP */
.btn-square {
	width: 40px !important;
	height: 40px;
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 8.5px;
}

/* Short description */
div .item_swift_productshortdescription.ellipsis-short {
	font-size: 0.75rem !important;
}

/* Price emphasis */
span .text-price {
	font-weight: 600 !important;
}

/* Small opacity text */
div .g-col-12.opacity-75.fs-custom-65 {
	font-size: 0.65rem !important;
}

/* Product header */
h1.item_swift_productheader {
	line-height: 1.5;
}

/* ==========================================================================
   3) Accordion
========================================================================== */

.accordion-item {
	border: 2px solid rgba(var(--swift-foreground-color-rgb), 0.5);
}

	.accordion-item .accordion-header {
		font-family: var(--swift-body-font);
	}

/* plus/minus icons via mask */
.accordion-button:after {
	mask-image: url('/Files/icons/plus.svg');
	-webkit-mask-image: url('/Files/icons/plus.svg');
}

.accordion-button:not(.collapsed):after {
	mask-image: url('/Files/icons/minus.svg');
	-webkit-mask-image: url('/Files/icons/minus.svg');
}

/* focus styles */
.accordion-button:focus {
	-webkit-box-shadow: none;
	box-shadow: none;
}

.accordion-button:not(.collapsed):focus {
	-webkit-box-shadow: inset 0 -1px 0 rgba(var(--swift-foreground-color-rgb), 0.3);
	box-shadow: inset 0 -1px 0 rgba(var(--swift-foreground-color-rgb), 0.3);
}

/* flush borders */
.accordion-flush .accordion-item:first-child {
	border-top: 2px solid rgba(var(--swift-foreground-color-rgb), 0.5);
}

.accordion-flush .accordion-item:last-child {
	border-bottom: 2px solid rgba(var(--swift-foreground-color-rgb), 0.5);
}

div.accordion-body {
	padding: 0;
}

/* ==========================================================================
   4) Horizontal Navigation
========================================================================== */

.horizontal-navigation {
	-ms-overflow-style: none; /* IE10+ */
	scrollbar-width: none; /* Firefox */
	width: calc(100vw - 2em);
	overflow-x: scroll;
	padding-bottom: 0.5em;
}

	/* Hide scrollbar (WebKit) */
	.horizontal-navigation::-webkit-scrollbar {
		display: none;
	}

	.horizontal-navigation .nav-link {
		height: auto;
		padding: 0.25em;
		border-radius: 0.5em;
		border: 1px solid var(--swift-foreground-color);
		white-space: nowrap;
	}

		.horizontal-navigation .nav-link[aria-current=page] {
			background-color: var(--swift-foreground-color);
			color: var(--swift-background-color) !important;
		}

/* Slide-in animation */
@keyframes slideInFromLeft {
	0% {
		transform: translateX(-50px);
	}

	100% {
		transform: translateX(0);
	}
}

.horizontal-navigation .navbar {
	animation: 0.5s ease-out 0s 1 slideInFromLeft;
}

/* Image navigation variant */
.horizontal-navigation.image-navigation .image-link {
	border-radius: 50%;
	overflow: hidden;
	max-width: 80px;
}

	.horizontal-navigation.image-navigation .image-link img {
		max-height: 80px;
		max-width: 80px;
		object-fit: contain;
		border-radius: 50%;
	}

.horizontal-navigation.image-navigation .text-link {
	max-width: 80px;
	font-size: 12px;
	font-weight: 500;
	hyphens: auto;
	-ms-hyphens: auto;
	-webkit-hyphens: auto;
	-moz-hyphens: auto;
}

/* ==========================================================================
   5) Header (Mobile)
========================================================================== */

#page-header-mobile .custom-header-link a {
	position: relative;
	font-size: 12px;
	padding-top: 16px;
	padding-bottom: 16px;
	padding-left: 0;
	text-decoration: none;
	text-align: left;
	font-weight: 700;
}

	#page-header-mobile .custom-header-link a span {
		font-weight: 400;
	}

#page-header-mobile .item_swift_3columnsflex {
	padding-top: 0 !important;
}

/* ==========================================================================
   6) Search (Mobile)
========================================================================== */

#page-header-mobile .item_swift_searchfield .type-ahead-field {
	border-radius: 8px;
	margin-bottom: 16px;
	border-color: #B2B2B2;
}

a.btn-checkout-secondary {
	padding-inline: 0.9rem !important;
	border-radius: 8.5px;
}

a.btn-checkout-primary {
	padding-inline: 3rem !important;
	border-radius: 8.5px;
}

@media (max-width: 768px) {
	a.btn-checkout-secondary {
		padding-inline: 0.9rem !important;
		border-radius: 8.5px;
		max-width: 200px;
		flex-grow: 1;
	}

	a.btn-checkout-primary {
		padding-inline: 2.4rem !important;
		border-radius: 8.5px;
		max-width: 200px;
		flex-grow: 1;
	}
}

/* ==========================================================================
   7) Mega Menu (General)
========================================================================== */

.mega-menu-custom a.nav-link {
	font-size: 13px;
}

/* ==========================================================================
	8) Checkout
========================================================================== */

div .g-col-12.opacity-75.fs-custom-65 {
	font-size: 0.65rem !important;
}

span.label-group {
	display: inline-flex;
	align-items: baseline;
	gap: 0.25rem;
	/* controls spacing between Total and (incl. VAT) */
}

span.vat-text {
	font-weight: 400;
	/* not bold */
	color: #666;
	/* optional softer color */
}

span.text-price {
	font-weight: 600 !important;
	display: inline;
	/* ensure it behaves like text */
	color: inherit;
	/* don’t hide or recolor */
	visibility: visible;
	/* override any hidden/transparent rules */
}

div.vat-price {
	font-size: smaller !important;
	font-weight: 400 !important;
	margin-top: -0.25rem;
}

span.inc-vat-text {
	font-size: small !important;
}

h3.overrule-texttransform,
h4.overrule-texttransform,
h1.overrule-texttransform {
	text-transform: none;
}

/* MOBILE QUANTITY PICKER */
/* Mobile quantity UI */
@media (max-width: 767px) {
	.quantity-wrapper {
		position: relative;
		display: inline-block;
		width: 100%;
		max-width: 85px;
	}

		.quantity-wrapper .quantity-input {
			padding-left: 15px;
			padding-right: 15px;
		}

	.qty-btn {
		position: absolute;
		top: 0;
		width: 2rem;
		height: 100%;
		border: none;
		background: transparent;
		font-size: 1.4rem;
		line-height: 1;
		display: flex;
		align-items: center;
		justify-content: center;
		cursor: pointer;
		color: var(--swift-foreground-color, inherit);
	}

		.qty-btn.minus {
			left: 0;
			font-weight: 500;
		}

		.qty-btn.plus {
			right: 0;
		}
}

/* Desktop - do NOT change existing behavior */
@media (min-width: 768px) {
	.qty-btn {
		display: none;
	}
}
