@import url('https://fonts.googleapis.com/css?family=Roboto+Condensed:300,400,700&display=swap');

body {
    overflow-x: hidden !important;
}

/*****SCHOOL BRANDING*****/
#schoolInfo .schoolName {
    color: #123c60;
    font-size: 30px;
    font-weight: 600;
    line-height: 1em;
    padding-bottom: 5px;
    margin-bottom: 4px;
    border-bottom: 3px solid #2ca3cb;
}
#schoolInfo .storeName {
    color: #cf3d40;
    font-weight: 300;
    font-size: 24px;
    line-height: 1em;
    padding-bottom: 0px !important;
    padding-top: 1px;
}
/*****SCHOOL BRANDING END*****/
#customMenuCart {
    float: left;
    margin: -2px 0 0 22px;
    font-size: 16px;
}
#customMenuCart ul.cart_list, #customMenuCart ul.product_list_widget {
	max-height: calc(90vh - 249px);
	overflow-y: auto;
	overflow-x: hidden;
    list-style: none outside;
    padding: 10px 0px 0px 0px;
    margin: 0;
}
#customMenuCart ul.woocommerce-mini-cart::-webkit-scrollbar-track {
	-moz-box-shadow: inset 0px 0px 3px rgba(0, 0, 0, 0.4);
	-webkit-box-shadow: inset 0px 0px 3px rgba(0, 0, 0, 0.4);
	box-shadow: inset 0px 0px 3px rgba(0, 0, 0, 0.4);
    border-radius: 20px;
    background-color: #efefef;
}

#customMenuCart ul.woocommerce-mini-cart::-webkit-scrollbar {
	width: 8px;
    background-color: #F5F5F5;
}

#customMenuCart ul.woocommerce-mini-cart::-webkit-scrollbar-thumb {
	border-radius: 20px;
    background-color: #d12421;
    background-image: -webkit-linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.5) 100%, transparent, rgba(0, 0, 0, 0.5) 0%);
}
#customMenuCart ul.cart_list li img, #customMenuCart ul.product_list_widget li img {
    float: unset !important;
    margin-left: 0px !important;
    width: 100% !important;
    height: auto;
    box-shadow: none;
}
#customMenuCart ul.cart_list li a, #customMenuCart ul.product_list_widget li a {
    font-weight: 700;
}
#customMenuCart #content .quantity, #customMenuCart .quantity, .woocommerce-page .quantity, #customMenuCart .quantity {
    width: 100px;
    margin: 0;
}
#customMenuCart ul.cart_list li::after, #customMenuCart ul.cart_list li::before, #customMenuCart ul.product_list_widget li::after, #customMenuCart ul.product_list_widget li::before {
    content: ' ';
    display: table;
}
#customMenuCart ul.cart_list li::after, #customMenuCart ul.product_list_widget li::after {
    clear: both;
}
#customMenuCart a.remove {
    display: block;
    font-size: 14px;
    height: 22px;
    width: 22px;
    margin: auto;
    text-align: center;
    line-height: 24px;
    border-radius: 100%;
    color: #b91f1f !important;
    text-decoration: none;
    border: 0;
}
#customMenuCart a.remove:hover {
	background-color: #b91f1f;
	color: #fff !important;
}
#customMenuCart .widget_shopping_cart .cart_list li, #customMenuCart .cart_list li {
    padding-left: 2em;
    position: relative;
    padding-top: 0;
}
#customMenuCart ul.cart_list li, #customMenuCart ul.product_list_widget li, #customMenuCart ul.cart_list li, #customMenuCart ul.product_list_widget li {
	display: -ms-grid;
    display: grid;
	-ms-grid-rows: auto;
	grid-template-rows: auto;
	-ms-grid-columns: 93% 7%;
    grid-template-columns: 93% 7%;
	padding: 6px 10px 6px 0px;
}
#customMenuCart .remove.remove_from_cart_button {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
	grid-row: 1;
	-ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-column: 2;
}
#customMenuCart .miniCartWrap {
	-ms-grid-row: 1;
    -ms-grid-row-span: 1;
	grid-row: 1;
	-ms-grid-column: 1;
    -ms-grid-column-span: 1;
    grid-column: 1;
}
#customMenuCart .dropdown-menu.dropdown-menu-right.show {
    width: 350px;
	padding: 0px 0px 10px 10px;
	max-height: calc(90vh - 122px);
	-moz-box-shadow: 0px 3px 5px rgba(0, 0, 0, 0.3);
	-webkit-box-shadow: 0px 3px 5px rgba(0, 0, 0, 0.3);
	box-shadow: 0px 3px 5px rgba(0, 0, 0, 0.3);
}
#main-header, #main-header.et-fixed-header {
	-moz-box-shadow: 0px 3px 5px rgba(0, 0, 0, 0.3) !important;
	-webkit-box-shadow: 0px 3px 5px rgba(0, 0, 0, 0.3) !important;
	box-shadow: 0px 3px 5px rgba(0, 0, 0, 0.3) !important;
}
#customMenuCart .miniCartWrap {
	display: -ms-grid;
    display: grid;
	-ms-grid-rows: auto auto;
    grid-template-rows: auto auto;
	-ms-grid-columns: 20% 80%;
    grid-template-columns: 20% 80%;
}
#customMenuCart .miniCart-Thumb {
	-ms-grid-column: 1;
    -ms-grid-column-span: 1;
    grid-column: 1;
	-ms-grid-row: 1;
    -ms-grid-row-span: 2;
    grid-row: 1 / 3;
}
.miniCart-Name {
	-ms-grid-row: 1;
	-ms-grid-row-span: 1;
	grid-row: 1;
	-ms-grid-column: 2;
	-ms-grid-column-span: 1;
	grid-column: 2;
	margin-top: auto;
    padding-left: 10px;
}

.quantity {
	-ms-grid-row: 2;
	-ms-grid-row-span: 1;
	grid-row: 2;
	-ms-grid-column: 2;
	-ms-grid-column-span: 1;
	grid-column: 2;
	margin-bottom: auto;
    padding-left: 10px;
	color: #000 !important;
}
#sliderSection::after {
	content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: -10px;
    height: 10px;
	background: rgb(97,201,255);
	background: -moz-linear-gradient(left,  rgba(97,201,255,1) 50%, rgba(0,128,168,1) 50%);
	background: -webkit-linear-gradient(left,  rgba(97,201,255,1) 50%,rgba(0,128,168,1) 50%);
	background: linear-gradient(to right,  rgba(97,201,255,1) 50%,rgba(0,128,168,1) 50%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#61c9ff', endColorstr='#0080a8',GradientType=1 );
}
#schoolInfo {
    display: inline-block;
    margin: auto 0px auto 25px;
    vertical-align: middle;
}
#customMenuCart .woocommerce-mini-cart__total.total .woocommerce-Price-amount.amount {
	float: right;
    color: #d12421;
    font-size: 20px;
}
#customMenuCart .woocommerce-mini-cart__total.total {
	border-top: 1px solid #707070;
	margin-top: 15px;
	padding-top: 15px;
}
#customMenuCart .woocommerce-mini-cart__buttons.buttons .button {
	display: inline-block;
    width: calc(50% - 5px);
    text-align: center;
    font-size: 18px;
    color: #fff;
    background-color: #171796;
    border-radius: 5px;
    border: 2px solid #171796;
    font-weight: 500;
    padding: .3em 1em;
    line-height: 1.7em!important;
    position: relative;
	margin: 0;
	cursor: pointer;
	text-decoration: none;
    overflow: visible;
	left: auto;
	box-shadow: none;
    text-shadow: none;
	-webkit-transition: all 0.5s ease-in-out;
    -moz-transition: all 0.5s ease-in-out;
    -o-transition: all 0.5s ease-in-out;
    transition: all 0.5s ease-in-out;
}
#customMenuCart .woocommerce-mini-cart__buttons.buttons .button:hover {
	padding: .3em 1em !important;
	background-color: #d12421;
    border: 2px solid #d12421;
	-webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}
#customMenuCart .woocommerce-mini-cart__buttons.buttons a:nth-child(1) {
	margin-right: 5px;
}
#customMenuCart .woocommerce-mini-cart__buttons.buttons a:nth-child(2) {
	margin-left: 5px;
}
#customMenuCart .woocommerce-mini-cart__buttons.buttons .button::after {
	display: none;
	content: unset !important;
}
#customMenuCart .woocommerce-mini-cart__total.total,
#customMenuCart .woocommerce-mini-cart__buttons.buttons {
	margin-right: 10px;
}

/* ======================================================
FORM & CHECKOUT
====================================================== */

.woocommerce-shipping-fields, .woocommerce-additional-fields, #order_comments_field {
	display: none;
}

.orderSticky {
	position: -webkit-sticky;
	position: sticky;
	top: 0;
}

/* ======================================================
RESPONSIVE
====================================================== */

@media (max-width: 768px)
{
	.hiw-col .et_pb_image img {
		max-width: 100px;
	}
	.hiw-col:nth-child(3) .et_pb_image .et_pb_image_wrap::after {
		height: 0px !important;
		background-color: transparent;
	}
	.hiw-col:not(:last-child) .et_pb_image .et_pb_image_wrap::after {
		left: 200%;
		transform: translate(-120%, -50%);
	}
	.et_mobile_menu li a, .nav li li a {
		font-size: 18px;
	}
}

@media (max-width: 550px)
{
	#schoolInfo .schoolName {
		font-size: 20px;
	}
	#schoolInfo .storeName {
		font-size: 16px;
	}
	#main-header > .container {
		width: 100%;
	}
	#schoolInfo {
		margin: auto 0px auto 15px;
	}
}

@media (max-width: 479px)
{
	#schoolInfo .schoolName {
		font-size: 18px;
		padding-bottom: 3px;
		margin-bottom: 2px;
	}
	#schoolInfo .storeName {
		font-size: 14px;
		padding-top: 1px;
	}
	.hiw-col .et_pb_image .et_pb_image_wrap::after {
		content: '';
		position: absolute;
		left: 50% !important;
		top: -25% !important;
		transform: translate(-50%, -50%) !important;
		width: 150% !important;
		height: 1px !important;
		background-color: #d6d6d6 !important;
	}
	.hiw-col:nth-child(3) .et_pb_image .et_pb_image_wrap::after {
		height: 1px !important;
	}
	#customMenuCart .dropdown-menu.dropdown-menu-right.show {
		width: 97vw;
	}
}
/*=========================================================*/
/* Logan code */
/* Force the entire checkout form into a strict 2-column grid on desktop */
@media (min-width: 992px) {
    form.checkout.woocommerce-checkout {
        display: grid !important;
        grid-template-columns: 55% 40% !important;
        justify-content: space-between !important;
        align-items: start !important;
    }

    /* Force Customer Details (Billing/Shipping) into the Left Column */
    .woocommerce-checkout #customer_details {
        grid-column: 1 / 2 !important;
        grid-row: 1 / 3 !important;
        width: 100% !important;
        float: none !important;
    }

    /* Force the "Your Order" Heading into the Right Column */
    .woocommerce-checkout #order_review_heading {
        grid-column: 2 / 3 !important;
        grid-row: 1 / 2 !important;
        margin-top: 0 !important;
        width: 100% !important;
    }

    /* Force the Order Review Table into the Right Column */
    .woocommerce-checkout #order_review {
        grid-column: 2 / 3 !important;
        grid-row: 2 / 3 !important;
        width: 100% !important;
        float: none !important;
    }
}

/* Clear floats just in case your theme is using older layout methods */
.woocommerce-checkout::after {
    content: "";
    display: table;
    clear: both;
}

/* 1. Break the theme's inline layout and force normal stacking */
.woocommerce-checkout .form-row {
    display: block !important; /* Stops labels from sitting next to inputs */
    margin-bottom: 20px !important;
    width: 100% !important;
    float: none !important;
}

/* 2. Put First Name and Last Name neatly side-by-side */
@media (min-width: 768px) {
    .woocommerce-checkout .form-row-first {
        width: 48% !important;
        float: left !important;
        clear: both !important;
    }
    .woocommerce-checkout .form-row-last {
        width: 48% !important;
        float: right !important;
        clear: none !important;
    }
}

/* 3. Force labels to sit on top and look clean */
.woocommerce-checkout .form-row label {
    display: block !important;
    width: 100% !important;
    margin-bottom: 8px !important;
    font-weight: 600 !important;
    text-align: left !important;
    color: #1a2b4c !important; /* Matches your heading color */
}

/* 4. Make the input boxes full width, padded, and bordered */
.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
    width: 100% !important;
    max-width: 100% !important;
    padding: 12px 15px !important;
    box-sizing: border-box !important;
    border: 1px solid #dcdcdc !important;
    border-radius: 4px !important;
    background-color: #f9f9f9 !important;
    font-size: 16px !important;
    height: auto !important;
}

/* 5. Clearfix to prevent layout breaks after floating elements */
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper::after,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper::after {
    content: "";
    display: table;
    clear: both;
}
/* Logan code eindig */
/*=========================================================*/

/*Jarrod code start */ 
/*=========================================================*/
/* 1. Force the Divi Section and Row to be edge-to-edge */
.woocommerce-account .et_pb_section,
.woocommerce-account .et_pb_row {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* 2. Target the specific 4_4 column that is causing the purple margin */
.woocommerce-account .et_pb_column_4_4,
.woocommerce-account .et_pb_column {
    width: 100% !important;
    max-width: 100% !important;
    margin-right: 0 !important;
}

/* 3. Remove the width restriction on the Text Module */
.woocommerce-account .et_pb_module.et_pb_text {
    width: 100% !important;
    max-width: 100% !important;
}

/* 4. The Login/Register Layout (Flexbox) */
.u-columns.col2-set {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important; 
    gap: 40px !important; 
    width: 100% !important;
    margin: 0 auto !important;
}

/* 5. Form Box Sizing */
.u-column1, .u-column2 {
    flex: 0 1 450px !important; 
    min-width: 320px !important;
}

/* 6. Buttons & Checkbox (from your previous code) */
button[name="login"], button[name="register"] {
    width: 100% !important;
    padding: 12px !important;
    background-color: #003366 !important;
    color: white !important;
    border-radius: 4px !important;
    font-weight: bold !important;
}
.woocommerce-form-login__rememberme {
    display: block !important;
    margin-bottom: 15px !important;
}
/* Jarrod code end */
/*=========================================================*/