@CHARSET "ISO-8859-1";

/* CSS variables for Vibrant Ingredients brand colors and typography */
:root {
	--graphicus-cond-light: "GraphicusDTCond-Light", sans-serif;
	--graphicus-cond-regular: "GraphicusDTCond-Regular", sans-serif;
	--graphicus-cond-bold: "GraphicusDTCond-Bold", sans-serif;
	--graphicus-cond-book: "GraphicusDTCond-Book", sans-serif;
	--graphicus-cond-demi: "GraphicusDTCond-Demi", sans-serif;

	/* Brand palette – HEX */
	--color-pure-white: #ffffff;
	--color-baf-red: rgb(239, 71, 62);
	--color-baf-red-hover: rgb(231, 30, 19);
	--color-baf-light-blue: #41B6E6;
	--color-baf-ice-blue: rgb(218, 237,250);
	--color-baf-dark-blue: #004B87;
	--color-baf-yellow: #f9C12F;
	--color-swiss-chard: #9c2557;

	/* Semantic aliases for legacy compatibility */
	--overlay-white: rgba(255, 255, 255, 0.6);
	--overlay-black: rgba(0, 0, 0, 0.5);
	--overlay-green: rgba(39, 89, 55, 0.7);
}

body {
	/* background-color: var(--color-baf-dark-blue); */
	font-family: var(--graphicus-cond-regular) !important;
	font-weight: 400;
	font-style: normal;
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	/* Add padding to account for fixed logo + nav height */
	padding-top: 140px;
}

/* Sticky footer layout: keep footer at bottom when content is short */
html,
body {
	height: 100%;
}

/* Decorative page images: moved from inline view styles */
.body-img{
    position:fixed;
    top:10%;
    max-width:30vw;
    width:220px;
    pointer-events:none;
    z-index:0;
}
.body-img-right{
  right:0;
  /* lower the right decorative image slightly */
  top:55%;
  /* move half the element off the viewport to the right */
  transform:translateX(25%);
}
.body-img-left{
  left:0;
  /* raise the left decorative image slightly */
  top:40%;
  transform:translateX(-50%);
}
@media (max-width:576px){
    .body-img{display:none}
}


.video-background-container {
	position: relative;
	width: 100%;
	height: 0px;
	overflow: visible;
}
.hero-video-wrapper {
	/* place absolutely so it can sit behind the header and not affect document flow */
	position: absolute;
	top: 0;
	/* center and extend to viewport edges without using 100vw (avoids scrollbar overflow)
	   technique: position at 50% and use negative 50vw side margins to create true full-bleed
	*/
	/* Use left/right:0 so the wrapper spans the viewport exactly without involving `vw` units
	   which can include scrollbar width and cause horizontal overflow on some browsers. */
	left: 0;
	right: 0;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	overflow: hidden;
	z-index: 0;
	pointer-events: none; /* don't intercept pointer events */
}

.hero-video-wrapper .hero-video {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	display: block; /* avoid inline whitespace/rounding issues */
	width: 100%;
	max-width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
	z-index: 0;
	pointer-events: none; /* avoid interfering with header interactions */
}

.hero-video-wrapper + main header {
	position: relative;
	z-index: 2; /* ensure header content sits above the video */
	padding-bottom: 20px;
	padding-top: 95px;
}

/* Optional: hide video on small devices to save bandwidth; remove if you want mobile video */
@media (max-width: 576px) {
	.hero-video-wrapper .hero-video { display: none; }
}

main.container-fluid {
	flex: 1 0 auto;
	z-index: 1;
	max-width: 1265px;
}

footer {
	flex-shrink: 0;
}

/* Apply base family to form controls and common elements */
html,
body,
input,
textarea,
select,
button {
	font-family: var(--graphicus-cond-regular) !important;
	font-weight: 400;
	font-style: normal;
}

/* Regular italic */
em,
i,
.font-italic {
	font-family: var(--graphicus-cond-regular);
	font-weight: 400;
	font-style: italic;
}

/* Medium italic (500 italic) */
.medium-italic,
.font-medium-italic {
	font-family: var(--graphicus-cond-book);
	font-weight: 500;
	font-style: italic;
}

/* Bold headings and strong text */
strong,
b,
h1,
h2,
h3,
h4,
h5,
h6,
.font-bold {
	font-family: var(--graphicus-cond-bold);
	font-weight: 900;
	font-style: normal;
}

.font-rockwell {
	font-family: "rockwell", sans-serif !important;
	font-weight: 800 !important;
	font-style: normal;
}

/* Bold italic */
strong em,
b em,
.bold-italic,
.font-bold-italic {
	font-family: var(--graphicus-cond-bold);
	font-weight: 700;
	font-style: italic;
}

.hidden {
	display: none !important;
}

.alert .material-icons {
	line-height: 1.5;
}

.pointer {
	cursor: pointer;
}

a {
	color: var(--color-baf-dark-blue);
}

.dropdown-item:active {
	background-color: transparent;
}

p,
h1,
h2,
h3,
h4,
h5 {
	color: var(--color-baf-dark-blue);
}

.btn-group-header a,
.btn-group-header ul i {
	color: var(--color-baf-dark-blue) !important;
}

.btn {
	border-radius: .3rem !important;
}

.bg-brown {
	background-color: var(--color-swiss-chard);
}

.bg-vanilla {
	background-color: var(--color-baf-light-blue);
}

.bg-white {
	background-color: var(--color-pure-white);
}

.btn-lg {
	border-radius: .3rem !important;
}

.btn.btn-brown {
	color: var(--color-pure-white) !important;
	background-color: var(--color-swiss-chard);
	border-color: var(--color-swiss-chard);
}
.btn-warning {
	background-color: var(--color-baf-yellow) !important;
	border-color: var(--color-baf-yellow) !important;
}

.btn-outline-primary,
a.btn-outline-primary {
	border-color: var(--color-baf-dark-blue) !important;
}

.btn-outline-primary:hover {
	color: var(--color-pure-white) !important;
	background-color: var(--color-baf-dark-blue);
	border-color: var(--color-baf-dark-blue);
}

.btn.btn.btn-primary,
a.btn.btn.btn-primary {
	color: var(--color-pure-white) !important;
	background-color: var(--color-baf-light-blue) !important;
	border-color: var(--color-baf-light-blue) !important;
}

.btn.btn.btn-primary:hover {
	color: var(--color-pure-white) !important;
	background-color: var(--color-baf-dark-blue) !important;
	border-color: var(--color-baf-dark-blue) !important;
}

.btn.btn-secondary,
a.btn.btn-secondary {
	color: var(--color-pure-white) !important;
	background-color: var(--color-baf-dark-blue) !important;
	border-color: var(--color-baf-dark-blue) !important;
}

.btn.btn-secondary:hover {
	color: var(--color-baf-dark-blue) !important;
	background-color: var(--color-pure-white) !important;
	border-color: var(--color-pure-white) !important;
}

.btn.btn-yellow {
	color: var(--color-pure-white) !important;
	background-color: var(--color-baf-yellow);
	border-color: var(--color-baf-yellow);
}

.color-red {
	color: var(--color-baf-red);
}

.btn.btn-yellow:hover {
	color: var(--color-pure-white) !important;
	background-color: var(--color-baf-yellow);
	border-color: var(--color-baf-yellow);
}

.btn.btn-red {
	color: var(--color-pure-white) !important;
	background-color: var(--color-baf-red);
	border-color: var(--color-baf-red);
}

.btn.btn-red:hover {
	color: var(--color-pure-white) !important;
	background-color: var(--color-baf-red-hover);
	border-color: var(--color-baf-red-hover);
}

.btn.btn-turquoise {
	color: var(--color-pure-white) !important;
	background-color: var(--color-baf-yellow);
	border-color: var(--color-baf-yellow);
}

.btn.btn-turquoise:hover {
	color: var(--color-pure-white) !important;
	background-color: var(--color-baf-yellow);
	border-color: var(--color-baf-yellow);
}

.btn.btn-magenta {
	color: var(--color-pure-white) !important;
	background-color: var(--color-baf-red);
	border-color: var(--color-baf-red);
}

.btn.btn-green {
	color: var(--color-pure-white) !important;
	background-color: var(--color-baf-yellow);
	border-color: var(--color-baf-yellow);
}

.label>a {
	color: var(--color-pure-white);
}

.label>a:hover {
	color: var(--color-pure-white);
}

.container-main {
	max-width: 1280px;
	padding-top: 40px;
}

.search-container {
	margin-bottom: 40px;
}

/*---- ------------------  NAV STYLES  --------------------*/
nav {
	position: relative; /* needed for overlay pseudo-element */
	/* Gradient background from dark blue to light blue (left to right) */
	background: linear-gradient(to right, var(--color-baf-dark-blue) 0%, var(--color-baf-light-blue) 100%) !important;
	background-color: var(--color-baf-light-blue) !important;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
	padding-top: 35px !important;
	padding-bottom: 35px !important;
	margin-top: 0px !important;
}

#navbarCollapse {
	position: absolute;
	top: 80px;
	padding: 0.5rem;
	background-color: var(--color-baf-dark-blue); 
	border-radius: 5px;
	border: 1px solid var(--color-pure-white);
	width: 17rem;
	z-index: 1160;
}

/* Logo positioning: center it above the nav bar */
nav .navbar-brand {
	position: fixed !important;
	top: 37px !important; /* Position logo at very top of viewport */
	left: 50% !important;
	transform: translateX(-50%) !important;
	margin: 0 !important;
	z-index: 1050; /* Higher than Bootstrap's fixed-top (1030) */
}

/* Make logo larger */
nav .navbar-brand img {
	filter: none;
	height: 120px !important; /* Increased from 60px */
	display: block;
}

/* Ensure nav links are readable with white color on gradient background */
nav a,
nav .nav-link,
nav .navbar-nav .nav-item .nav-link a
{
	color: var(--color-pure-white) !important;
}

nav .nav-item > a {
	color: var(--color-baf-dark-blue) !important;
}

/* Hamburger menu toggle: show in normal state */
nav .navbar-toggler {
	filter: brightness(0) invert(1); /* Make it white on colored background */
	position: relative;
	z-index: 101;
	margin-left: 15px;
}

/* Cart and user menu positioning */
nav .ml-auto {
	position: relative;
	z-index: 101;
	margin-right: 15px !important;
}

/* Keep dropdown indicators/icons readable with white color */
nav .nav-link .material-icons {
	color: var(--color-pure-white) !important;
}
/* subtle overlay to improve contrast when video plays behind the nav */

nav::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	/* Hide overlay for static light nav */
	opacity: 0;
	z-index: 1;
}

/* ensure nav content sits above the overlay */
/* nav * { position: relative; z-index: 2; } */

/* Smooth transitions for background and overlay */
nav {
	transition: background 240ms ease, background-color 240ms ease;
}

nav::before {
	transition: opacity 240ms ease, background 240ms ease;
}

/* On hover, maintain gradient background */
nav:hover {
	background: linear-gradient(to right, var(--color-baf-dark-blue) 0%, var(--color-baf-light-blue) 100%) !important;
	background-color: var(--color-baf-light-blue) !important;
}

nav:hover::before {
	opacity: 0;
}

/* Keep white text on hover for readability on gradient */
nav:hover a,
nav:hover .nav-link,
nav:hover .nav-item > a,
nav:hover .material-icons,
nav:hover .nav-link .material-icons {
	/* color: var(--color-pure-white) !important; */
}

/* When page is scrolled past threshold, maintain gradient background */
nav.nav-scrolled {
	background: linear-gradient(to right, var(--color-baf-dark-blue) 0%, var(--color-baf-light-blue) 100%) !important;
	background-color: var(--color-baf-light-blue) !important;
	transition: background 300ms ease, background-color 300ms ease;
}

nav.nav-scrolled::before {
	opacity: 0;
	transition: opacity 300ms ease;
}

nav.nav-scrolled a,
nav.nav-scrolled .nav-link,
nav.nav-scrolled .nav-item > a,
nav.nav-scrolled .material-icons,
nav.nav-scrolled .nav-link .material-icons {
	color: var(--color-pure-white) !important;
	transition: color 300ms ease;
}

nav a {
	font-weight: 600 !important;
}

/*------------------ Responsive nav adjustments ------------------*/
@media screen and (max-width: 850px) {

	nav .navbar-brand {
		padding: 30px 25px 15px 25px;
		/* top: -10px !important; */
	}

	nav .navbar-brand img {
		height: 80px !important;
	}
}

@media screen and (max-width: 576px) {
	/* Adjust logo size and positioning for mobile */
	body {
		padding-top: 100px;
	}

	nav {
		margin-top: 0px !important;
		padding-top: 80px !important;
		padding-bottom: 0px !important;
	}

	nav #navbarCollapse {
		top: 130px;
	}

	nav .navbar-brand {
		padding: 0px 25px 15px 25px;
		top: -10px !important;
	}

	nav .navbar-brand img {
		height: 80px !important;
	}

	nav .nav-link {
		display: inline-block;
		text-align: left;
		z-index: 1;
	}

	nav .btn-group {
		display: block;
		justify-content: space-between;
		position: relative;
	}

	nav .nav-link.dropdown-toggle {
		text-align: right;
		position: absolute;
		right: 0px;
		width: 35%;
		z-index: 0;
		/*display: inline-flex;*/
	}

	nav .nav-link.dropdown-toggle:active {
		z-index: 0;
		/*display: inline-flex;*/
	}

	nav .dropdown-submenu .dropdown-toggle::after {
		transform: rotate(0deg);
	}

	nav .dropdown-item {
		white-space: normal;
	}
}

@media screen and (min-width: 576px) {
	.btn-group.show ul.dropdown-menu.show {
		position: absolute;
	}

	nav .nav-link {
		padding-right: 0px !important;
	}

	nav .nav-link.dropdown-toggle {
		padding-left: 0px !important;
	}

	.nav-item {
		padding: 0px 10px;
	}
}

.dropdown-menu {
	background-color: var(--color-pure-white);
}

.dropdown-menu .dropdown-item a {
	position: relative;
	color: var(--color-baf-dark-blue) !important;
}

.dropdown-menu .dropdown-item a:hover {
	background-color: var(--color-baf-ice-blue);
	color: var(--color-baf-dark-blue) !important;
}

.dropdown-menu .material-icons {
	position: relative;
	top: 6px;
	color: var(--color-baf-dark-blue) !important;
}

/*-------------------- search input -------------------- */
#searchInput {
	color: var(--color-baf-dark-blue);
	/* background-color: var(--color-baf-light-blue); */
	border: 1px solid var(--color-baf-dark-blue);
	caret-color: #2b0071;
	cursor: pointer;
}

#searchInput::placeholder {
	color: var(--color-baf-dark-blue);
}

#srchform button {
	border-top-left-radius: 0 !important;
	border-bottom-left-radius: 0 !important;
}

#srchform .input-group-append {
	z-index: 0;
}

/*--------------------- submenu nav -------------------- */
.dropdown-submenu {
	position: relative;
}

.dropdown-submenu a *:hover {
	text-decoration: underline;
}

.dropdown-submenu .dropdown-toggle {
	cursor: pointer;
}

.dropdown-submenu .dropdown-toggle::after {
	transform: rotate(-90deg);
	position: absolute;
	right: 6px;
	top: .8em;
}

.dropdown-submenu .dropdown-menu {
	top: 0;
	left: 100%;
	margin-left: .1rem;
	margin-right: .1rem;
}

/*--------------------- breadcrumb -------------------- */
.breadcrumb {
	margin-bottom: 10px !important;
}

/*--------------------- main content -------------------- */
.row-main-content {
	max-width: 1600px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 50px;
}

.title-container {
	max-width: 750px;
	margin-left: auto;
	margin-right: auto;
	background-color: var(--color-baf-dark-blue);
	border-top-left-radius: 100px;
	border-top-right-radius: 100px;
	border-bottom-left-radius: 100px;
	border-bottom-right-radius: 100px;
	padding-top: 30px;
	padding-bottom: 40px;
	margin-bottom: 30px;
}

.title-container h1,
.title-container h2 {
	color: var(--color-pure-white);
	margin-bottom: 0px !important;
}

.title-container h1.title {
	font-size: 60px;
	font-weight: 900;
	margin-bottom: 15px;
}



/* -------------------- right column ------------------ */
.card-header {
	background-color: var(--color-baf-dark-blue);
	color: var(--color-pure-white);
	font-weight: 900;
}

.card-header .btn.btn-primary:hover {
	border-color: var(--color-pure-white) !important;
}


/* --------------------- footer styles ----------------- */
footer {
	background-color: var(--color-baf-light-blue);
	color: var(--color-pure-white);
	padding: 20px;
	position: relative;
	overflow-x: hidden;
}

footer .logo {
	display: inline-block;
	max-width: 200px;
}

footer .footer-img {
	position: absolute;
	width: 150px;
	height: auto;
}

footer .footer-img-left {
    left: -102px;
    bottom: 35px;
}

footer .footer-img-right {
	right: -111px;
	bottom: -90px;
}

footer .footer-row {
	margin: 0 auto;
	width: 100%;
	box-sizing: border-box;
	padding-left: 1rem;
	padding-right: 1rem;
}

/* Vertically center footer content */
footer {
	display: block;
	/* keep default for compatibility */
}

footer>section {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

/* Make the inner footer-row behave as a flex line so columns are vertically centered */
footer .footer-row {
	display: flex;
	align-items: center;
}

/* On small screens stack footer columns */
@media (max-width: 576px) {
	footer .footer-row {
		max-width: 100%;
		height: 100%;
	}

	footer>section {
		align-items: flex-start;
	}

	footer .footer-row {
		flex-direction: column;
		text-align: center;
	}

	footer .footer-row .col {
		width: 100%;
		margin-bottom: 0.5rem;
	}

	footer .footer-text {
		text-align: center !important;
	}
}

@media (min-width: 577px) {
	footer .footer-row {
			max-width: 520px;
	}
	footer .footer-text {
		text-align: right !important;
	}
}
@media (min-width: 720px) {
	footer {
		height: 132px;
		overflow:hidden
	}
}
@media (min-width: 768px) {
	footer .footer-row {
		max-width: 775px;
	}
}

@media (min-width: 992px) {
	footer .footer-row {
		max-width: 1000px;
	}
}

@media (min-width: 1200px) {
	footer .footer-row {
		max-width: 1200px;
	}
}

/* --------------------- dialog box ----------------- */
.dialog {
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: 30000;
	background-color: var(--overlay-black);
	overflow: hidden;
}

.dialog>.wrapper {
	position: absolute;
	left: 50%;
	top: 200px;
	width: 350px;
	margin-left: -175px;
	background-color: var(--color-pure-white);
	box-sizing: border-box;
	padding: 15px;
	border: 1px solid var(--color-baf-dark-blue);
	box-shadow: 2px 2px 10px var(--overlay-black);
}

.dialog .message {
	margin-bottom: 10px;
	white-space: pre;
}

.dialog .action {
	font-weight: bold;
	margin-bottom: 15px;
}

.dialog .title {
	font-weight: bold;
	margin-bottom: 5px;
}

.dialog a+a {
	margin-left: 5px;
}

.dialog .btn-danger {
	float: right;
}

/* Remove default margins from header element that wraps nav */
header {
	margin: 0;
	padding: 0;
}