/*
Theme Name: LCPS
Author: Shariq Niazi
Author URI: 
Theme URI: 
Tags: full-site-editing, editor-style, block-styles, block-patterns
Text Domain: lcps
Requires at least: 6.3
Requires PHP: 7.4
Tested up to: 6.3
Version: 1.0.1

License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
*/

/* Styles intended only for the front.*/
@font-face {
	font-family: 'HankenGrotesk';
	src: url('./assets/fonts/Montserrat-VariableFont_wght.ttf');
	font-style: normal;
}

@font-face {
	font-family: 'FontAwesome-Brands';
	src: url('./assets/fonts/fa-brands-400.woff2');
}
@font-face {
	font-family: 'FontAwesome-Regular';
	src: url('./assets/fonts/fa-regular-400.woff2');
}
@font-face {
	font-family: 'FontAwesome-Solid';
	src: url('./assets/fonts/fa-solid-900.woff2');
}

:root{
	--Primary-Color:#18a99e;
	--Secondary-Color:#280569;
	--Tertiary-Color:#8232a1;
}

html {
	scroll-behavior: smooth;
}

.wp-element-button{
	color: #fff !important;
	border-radius: 2px;
	padding: 10px 20px;
	font-size: 1rem;
}

body {
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	font-size: 1.3rem;
	font-weight: 500;
	font-family: "HankenGrotesk", sans-serif !important;
}
.readonly{
	border: none !important;
	outline: none !important;
	background-color: #2a2a2a;
	color: #fff;
	padding: 8px;
	font-size: 0.8rem;
}
table td{
	font-size: 1.1rem;
}
table thead tr{
	background-color: rgb(48, 189, 158);
	color: #fff;
}
p,span,a,li,table tbody tr td, table thead tr th, table thead tr td{
	font-family: "HankenGrotesk", sans-serif;
}

h1,h2,h3,h4,h5,h6{
	font-family: "HankenGrotesk", sans-serif;
}
h5{
	font-size: 1.3rem !important;
}
h1{
	font-size: clamp(2rem, 1.5rem + 3vw, 2rem) !important;
}
.cart-contact-frm{
	display: flex;
	gap: 10px;
}

table{
	border: 1px solid #ccc;
	border-collapse: collapse;
}
table th,table td{
	border: 1px solid #ccc;
	padding: 7px;
}

.btn, a.btn{
	padding: 10px 20px;
	border: none;
	border-radius: 2px;
	cursor: pointer;
	transition: all 0.3s;
	text-decoration: none;
}
.btn-primary{
	color: #1bb9b9;
	transition:all 0.3s;
	box-shadow: 0.2em 0.2em 0 0 #1bb9b9, inset 0.2em 0.2em 0 0 #1bb9b9;
}
.btn-primary:hover{
	color: #fff;
	box-shadow: 0 0 0 0 #0c8b8b, inset 6em 3.5em 0 0 #0c8b8b;
}

.btn-enquiry{
	background-color: #181818;
	color: #fff !important;
	position: relative;
	font-size: 1.2rem;
	padding-left:28px !important;
}
.btn-enquiry::before {
    border: 2px solid #ffffff;
    border-radius: 100%;
    box-sizing: content-box;
    content: "";
    display: block;
    height: 10px;
    left: 9px;
    top: 12px;
    position: absolute;
    width: 10px;
}

.enrol-block button[type="submit"]{
	color: rgba(255,255,255,0.9);
	background: linear-gradient(-45deg, #ffa63d, #ff3d77, #338aff, #3cf0c5);
	background-size: 600%;
	-webkit-animation: anime 16s linear infinite;
			animation: anime 16s linear infinite;
	border: none;
	padding: 20px 20px;
	cursor: pointer;
	transition: all 0.3s;
	margin-bottom: 5px;
	width: 100%;
	font-size: 1.3rem;
	font-weight: 500;
	font-family: 'HankenGrotesk';
}
@-webkit-keyframes anime {
  0% {
    background-position: 0% 50%;
  }
  25% {
    background-position: 100% 50%;
  }
  50% {
    background-position: 0% 50%;
  }
  75% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

.enrol-block button[type="submit"]:hover{
	color: #fff;
}
.btn-enquiry:hover .btn-enquiry::before {
	border: 2px solid #fcc35a;
}
.single-product table:not(.payment-details){
	width: 100%;
}
.single-product .main-content h2,.heading-inverted{
	background-color: #000;
	color: #fff;
	padding: 10px 15px;

}
.btn-enquiry:hover{
	background-color: #0c0c0c;
	color: #fcc35a;
}
hr{
	border: 1px solid #ebebeb;
}
.top_bar{
	background-color: var(--Secondary-Color);
	padding:5px 20px;
	margin-bottom:8px;
	display:flex;
	justify-content:space-between;
	flex-wrap:wrap;
}
.top_bar a,.top_bar a:visited,.top_bar a:active,.top_bar a:focus,.top_bar a:link{
	color: #fff;
	text-decoration: none;
	font-weight: 400;
	transition: all 0.3s;
}
.top_bar a:hover{
	color: #fcc35a;
}


.wp-block-navigation ul li a,.wp-block-navigation ul li a:visited,.wp-block-navigation ul li a:active,.wp-block-navigation ul li a:focus,.wp-block-navigation ul li a:link{
	 color:black;
	 font-weight: 600;
	 text-decoration: none;
}

.main-footer{
	background-color: var(--Tertiary-Color);
	padding: 15px 0px;
}
main-footer p,main-footer ul li,main-footer ul li a{
	font-size: 1.1rem !important;
	color: #ffffff !important;
}

.main-footer a,.main-footer a:visited,.main-footer a:active,.main-footer a:focus,
.main-footer a:link,
.main-footer p,
.main-footer span,
.main-footer h3,
.main-footer h2,
.main-footer h1,
.main-footer h4{
	color: #ffffff !important;
}
form{
	margin: 0;
	padding: 0;

}
form input[type="text"],
form input[type="email"],
form input[type="tel"],
form input[type="password"],
form input[type="date"],
form input[type="file"],
form textarea {
	border: 1px solid #ccc;
	border-radius: 4px;
	padding: 17px 9px;
	width: 100%;
	box-sizing: border-box; /* Include padding and border in element's total width */
	margin-bottom: 10px; /* Space between fields */
}
form select{
	border: 1px solid #ccc;
	border-radius: 4px;
	padding: 17px 9px;
	width: 100%;
	box-sizing: border-box; /* Include padding and border in element's total width */
	margin-bottom: 10px; /* Space between fields */

}

.contact-us .header{
	display: flex;
    justify-content: space-between;
    align-items: center;
}
.contact-us .header .closeBtn{
	cursor:pointer;
}
.contact-us{
	width: 100%;
    max-width: 400px;
    padding: 10px;
    position: fixed;
    left: -419px;
	background-color: #fff;
	transition:all 0.3s;
	z-index: 9999;
	top: 20px;
	max-height: calc(100vh - 20px);
	overflow-y: auto;
	box-sizing: border-box;
	border-top: 13px solid #fdbe4c;
}
.floater{
	position: fixed;
	z-index: 9999;
    left: -0px;
	top: 200px;
    background-color: var(--Secondary-Color);
    color: #fff;
    padding: 11px 12px 11px;
    cursor: pointer;
    transition: all 0.3s;
    border-left: 11px solid #1d012b;
	display: flex;
	gap: 10px;
}
.floater span{
	font-size: 0.9rem;
	border-left: 3px solid #fff;
	padding-left:15px;
}
  
  /* Utility classes for grid layout */
.row {
	display: flex;
	flex-wrap: wrap;
}

.col {
	flex: 1;
	padding-right: 15px;
	padding-left: 15px;
	box-sizing: border-box;
}

.col-1 { flex: 0 0 8.33%; max-width: 8.33%; }
.col-2 { flex: 0 0 16.66%; max-width: 16.66%; }
.col-3 { flex: 0 0 25%; max-width: 25%; }
.col-4 { flex: 0 0 33.33%; max-width: 33.33%; }
.col-5 { flex: 0 0 41.66%; max-width: 41.66%; }
.col-6 { flex: 0 0 50%; max-width: 50%; }
.col-7 { flex: 0 0 58.33%; max-width: 58.33%; }
.col-8 { flex: 0 0 66.66%; max-width: 66.66%; }
.col-9 { flex: 0 0 75%; max-width: 75%; }
.col-10 { flex: 0 0 83.33%; max-width: 83.33%; }
.col-11 { flex: 0 0 91.66%; max-width: 91.66%; }
.col-12 { flex: 0 0 100%; max-width: 100%; }

/* Responsive adjustments for grid */
@media (max-width: 768px) { /* Tablet */
	.col-sm-1 { flex: 0 0 8.33%; max-width: 8.33%; }
	.col-sm-2 { flex: 0 0 16.66%; max-width: 16.66%; }
	.col-sm-3 { flex: 0 0 25%; max-width: 25%; }
	.col-sm-4 { flex: 0 0 33.33%; max-width: 33.33%; }
	.col-sm-5 { flex: 0 0 41.66%; max-width: 41.66%; }
	.col-sm-6 { flex: 0 0 50%; max-width: 50%; }
	.col-sm-7 { flex: 0 0 58.33%; max-width: 58.33%; }
	.col-sm-8 { flex: 0 0 66.66%; max-width: 66.66%; }
	.col-sm-9 { flex: 0 0 75%; max-width: 75%; }
	.col-sm-10 { flex: 0 0 83.33%; max-width: 83.33%; }
	.col-sm-11 { flex: 0 0 91.66%; max-width: 91.66%; }
	.col-sm-12 { flex: 0 0 100%; max-width: 100%; }
}

@media (max-width: 576px) { /* Mobile */
	.col-xs-1 { flex: 0 0 8.33%; max-width: 8.33%; }
	.col-xs-2 { flex: 0 0 16.66%; max-width: 16.66%; }
	.col-xs-3 { flex: 0 0 25%; max-width: 25%; }
	.col-xs-4 { flex: 0 0 33.33%; max-width: 33.33%; }
	.col-xs-5 { flex: 0 0 41.66%; max-width: 41.66%; }
	.col-xs-6 { flex: 0 0 50%; max-width: 50%; }
	.col-xs-7 { flex: 0 0 58.33%; max-width: 58.33%; }
	.col-xs-8 { flex: 0 0 66.66%; max-width: 66.66%; }
	.col-xs-9 { flex: 0 0 75%; max-width: 75%; }
	.col-xs-10 { flex: 0 0 83.33%; max-width: 83.33%; }
	.col-xs-11 { flex: 0 0 91.66%; max-width: 91.66%; }
	.col-xs-12 { flex: 0 0 100%; max-width: 100%; }
}

/* Responsive adjustments for large screens */
@media (min-width: 992px) { /* Large screens */
	.col-lg-1 { flex: 0 0 8.33%; max-width: 8.33%; }
	.col-lg-2 { flex: 0 0 16.66%; max-width: 16.66%; }
	.col-lg-3 { flex: 0 0 25%; max-width: 25%; }
	.col-lg-4 { flex: 0 0 33.33%; max-width: 33.33%; }
	.col-lg-5 { flex: 0 0 41.66%; max-width: 41.66%; }
	.col-lg-6 { flex: 0 0 50%; max-width: 50%; }
	.col-lg-7 { flex: 0 0 58.33%; max-width: 58.33%; }
	.col-lg-8 { flex: 0 0 66.66%; max-width: 66.66%; }
	.col-lg-9 { flex: 0 0 75%; max-width: 75%; }
	.col-lg-10 { flex: 0 0 83.33%; max-width: 83.33%; }
	.col-lg-11 { flex: 0 0 91.66%; max-width: 91.66%; }
	.col-lg-12 { flex: 0 0 100%; max-width: 100%; }
}

/* Responsive adjustments for extra-large screens */
@media (min-width: 1200px) { /* Extra-large screens */
	.col-xl-1 { flex: 0 0 8.33%; max-width: 8.33%; }
	.col-xl-2 { flex: 0 0 16.66%; max-width: 16.66%; }
	.col-xl-3 { flex: 0 0 25%; max-width: 25%; }
	.col-xl-4 { flex: 0 0 33.33%; max-width: 33.33%; }
	.col-xl-5 { flex: 0 0 41.66%; max-width: 41.66%; }
	.col-xl-6 { flex: 0 0 50%; max-width: 50%; }
	.col-xl-7 { flex: 0 0 58.33%; max-width: 58.33%; }
	.col-xl-8 { flex: 0 0 66.66%; max-width: 66.66%; }
	.col-xl-9 { flex: 0 0 75%; max-width: 75%; }
	.col-xl-10 { flex: 0 0 83.33%; max-width: 83.33%; }
	.col-xl-11 { flex: 0 0 91.66%; max-width: 91.66%; }
	.col-xl-12 { flex: 0 0 100%; max-width: 100%; }
}
  
  /* Responsive adjustments */
@media (max-width: 768px) { /* Example breakpoint for tablets */
	/* nav ul {
	  flex-direction: column; 
	} */
  
	.has-submenu:hover .submenu {
	  display: block; /* Simple block display on mobile */
	  width: auto; /* Allow content to dictate width */
	  left: 50%;
	  transform: translateX(-50%); /* Center the submenu */
	  flex-direction: column; /* Stack columns on mobile */
	}
  }

@media screen and (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}
}
.stats{
	background-color: var(--Secondary-Color);
	padding:40px 20px;
	text-align: center;
}


.main_menu > ul > li {
  display: inline-block;
  position: relative;
  margin: 0 -2px;
}
.main_menu ul li {
  position: relative;
}

.main_menu ul li a {
  font-size: 1.2rem;
  color: #353535;
  padding: 20px 9px;
  display: block;
  font-weight: 600;
}
.main_menu > ul > li > a {
  border-bottom: 3px solid rgba(1, 1, 1, 0);
}
.main_menu > ul > li > a:hover {
  border-bottom: 3px solid #280569;
  background-color: #ececec;
}
.main_menu .sub_menu a {
  padding: 6px 6px !important; 
}
.main_menu .sub_menu a:hover {
  background-color: #280569;
  color: #fff !important;
}

.main_menu ul li .active,
.main_menu ul li:hover > a {
  color: var(--hover-color);
}
/* Normal Dropdown menu */
.main_menu ul li ul {
  width: 234px;
  background: #fff;
  transition: 0.5s;
  box-shadow: 0px 5px 15px 0px rgba(212, 201, 201, 0.75);
  display: none;
}

.main-content a,.main-content a:link,.main-content a:visited,.main-content a:active ,.entry-content a,.entry-content a:link,.entry-content a:visited,.entry-content a:active{
  color: #280569;
  font-weight: 500;
  text-decoration: none;
}

.main_menu ul li ul li a {
  padding: 10px 25px;
  font-size: 15px;
}
.main_menu ul li ul li a i {
  float: right;
}

.main_menu ul li ul li ul {
  right: 100%;
  top: 0;
}

/* mega menu css */
.mega_menu_dropdown {
  position: static !important;
}
.mega_menu {
  left: 0;
  right: 0;
  background: #fff;
  display: flex;
  flex-wrap: wrap;
  transition: 0.2s;
  box-shadow: 0px 5px 15px 0px rgba(212, 201, 201, 0.75);
  z-index: 999999999999 !important;
}
.mega_menu_item {
  width: 15%;
  padding: 9px 9px;
}

.online-pathways-menu .mega_menu_item{
	width: 30% !important;
}
.main_menu ul li .mega_menu_item a {
  padding: 3px 0;
  font-size: 0.9rem;
}

.main_menu ul li .mega_menu_item a:hover {
  color: var(--hover-color);
}
.mega_menu_item h3 {
  margin-bottom: 15px;
  display: flex;
  align-items: center;
  font-size: 1rem;
}
.mega_menu_item img {
  width: 100%;
}

/* demo_2 css */
.mega_menu_demo_2 .mega_menu {
  left: 50%;
  transform: translateX(-50%);
  width: 1140px;
}

.mobile_btn {
  display: none;
}

/* responsive css */
@media (min-width: 992px) and (max-width: 1199.98px) {
  .container {
    width: 960px;
  }
  .mega_menu_demo_2 .mega_menu {
    width: 940px;
  }
  .main_menu ul li ul {
    width: 150px;
  }
}

@media (min-width: 768px) and (max-width: 991.98px) {
  .container {
    width: 720px;
  }
  .mega_menu_demo_2 .mega_menu {
    width: 700px;
  }
  .main_menu ul li a {
    font-size: 15px;
    padding: 20px 16px;
  }
  .main_menu ul li ul {
    width: 150px;
  }
}
@media (min-width: 768px) {
  .main_menu ul li ul {
    visibility: hidden;
    opacity: 0;
    position: absolute;
    margin-top: 50px;
  }
  .main_menu ul li .mega_menu {
    visibility: hidden;
    opacity: 0;
    position: absolute;
    margin-top: 50px;
	padding: 18px 6%;
  }
  .main_menu ul li:hover > ul {
    visibility: visible;
    opacity: 1;
    margin-top: 0px;
	display: block;
  }
  .main_menu ul li:hover > .mega_menu {
    visibility: visible;
    opacity: 1;
    margin-top: 0;
	display: flex;
  }
}



@media (max-width: 575.98px) {
  .mega_menu .mega_menu_item {
    width: 100%;
  }
}

nav a,nav a:link,nav a:visited,nav a:active{
	text-decoration: none;
}


.icon span{
	display: block;
}

.icon::before{
	
	font-weight: 400;
	display: block;
	margin-right: 4px;
	width: 20px;
	height: auto;
}

.icon.icon-whatsapp::before{
	content: "\f232";
	font-family:"FontAwesome-Brands";
}

.icon.icon-envelope::before{
	content: "\f0e0";
	font-family:"FontAwesome-Solid";
}
.icon.icon-tiktok::before{
	content: "\e07b";
	font-family:"FontAwesome-Brands";
}
.icon.icon-facebook::before{
	content: "\f39e";
	font-family:"FontAwesome-Brands";
}
.icon.icon-twitter::before{
	content: "\e61b";
	font-family:"FontAwesome-Brands";
}
.icon.icon-linkedin::before{
	content: "\f08c";
	font-family:"FontAwesome-Brands";
}
.icon.icon-instagram::before{
	content: "\e055";
	font-family:"FontAwesome-Brands";
}
.icon.icon-youtube::before{
	content: "\f167";
	font-family:"FontAwesome-Brands";
}


.accreditation-table img{
	height: auto;

}

.popular-categories{
	display: flex; 
	flex-wrap: wrap; 
	gap: 20px;
	justify-content: center;
}
.popular-categories .category-item{
	box-sizing: border-box; 
	text-align: center; 
	border-radius: 4px; 
	transition: box-shadow 0.3s ease; 
	box-shadow: 0px 2px 15px 4px rgba(0, 0, 0, 0.1);
	width: min-content;
	min-height: 340px;
	display: flex;
	flex-direction: column;
	padding-bottom: 20px;
}
.popular-categories .category-item h3{
	margin: 0px 0 0 0 ;
	text-align: left;
	color: #000000;
	padding-left: 20px;
}
.popular-categories .category-item .category-button{
	width: 100%;
	margin-top: auto;
	display: flex;
	justify-content: center;
}

.popular-categories .category-item .category-button a{
	width: 80%;
	text-align: center;
	color: var(--Tertiary-Color);
	border: none;
	border-radius: 2px;
	padding: 10px 20px;
	cursor: pointer;
	display: block;
	transition: all 0.3s;
	box-shadow: 0.2em 0.2em 0 0 var(--Tertiary-Color), inset 0.2em 0.2em 0 0 var(--Tertiary-Color);
}
.popular-categories .category-item .category-button a:hover{
	color: #fff !important;
	box-shadow: 0 0 0 0 var(--Secondary-Color), inset 6em 3.5em 0 0 var(--Secondary-Color);
}

#course_inquiry_frm{
	box-shadow: 0px 2px 15px 4px rgba(0, 0, 0, 0.1);
	padding: 15px;
	font-size: 1rem;
}
#course_inquiry_frm h3{
	margin: 5px auto;
}


.main_menu a.btn-link,.main_menu a.btn-link:link,.main_menu a.btn-link:visited{
	color:var(--Primary-Color);
}

.alert{
	padding: 10px 15px;
	margin-bottom: 15px;
	border-radius: 12px;
	display: none;
}
.alert.show{
	display: block;
}
.alert.alert-success{
	background-color: #a6ebce;
	color: #030303;
	border: 3px solid #0a5c3a;
}

.wp-block-woocommerce-product-sale-badge {
	display: none;
}







/* 	Products Archive	 */
.lcps-products-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}

.lcps-product {
    text-align: center;
}

.lcps-product img {
    width: 100%;
    height: auto;
}

.lcps-product .product-title {
    margin-top: 10px;
    font-size: 1rem;
}

.lcps-product a,.lcps-product a:link, .lcps-product a:visited, .lcps-product a:active {
	text-decoration: none;
	color: #000;
}

.lcps-product a:hover {
	text-decoration: underline;
}

@media (max-width: 1024px) {
    .lcps-products-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .lcps-products-grid {
        grid-template-columns: 1fr;
    }
}
/* Pagination wrapper */
.lcps-pagination{
    display: flex;
    align-items: center;
    gap: 0.6rem;
    flex-wrap: nowrap;
	justify-content: center;
}

/* Kill line breaks injected by paginate_links() */
.lcps-pagination br {
    display: none;
}

/* Page numbers */
.lcps-pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    padding: 0.4em 0.7em;
    text-decoration: none;
    white-space: nowrap;
}

/* Current page */
.lcps-pagination .page-numbers.current {
    font-weight: 600;
}

/* Optional hover */
.lcps-pagination a.page-numbers:hover {
    text-decoration: underline;
}

/* Always hidden */
.d-none {
  display: none !important;
}

/* Always block */
.d-block {
  display: block !important;
}

/* md breakpoint: ≥768px */
@media (min-width: 768px) {

  /* Hidden on md and up */
  .d-md-none {
    display: none !important;
  }

  /* Block on md and up */
  .d-md-block {
    display: block !important;
  }

}
.hero-banner img{
	width: 100% !important;
}

.decorative-block{
	position: relative;
	padding: 10px 10px 20px 10px;
}

.decorative-block::before{
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	border: 5px solid transparent; /* Adjust the thickness of the border */
	border-image: linear-gradient(129deg, #4158D0, #a250c8,#FFCC70) 1;
	border-radius: 5px; /* Optional: Add border radius */
	pointer-events: none; /* Ensure the border doesn't interfere with table interactions */
}
.elcas-card{
	box-shadow: 7px 10px 24px 0px #00000017;
	padding: 10px;
	height: -webkit-fill-available;
}


.elcas-card h2 {
    font-size: 1rem;
    color: #fff;
    background-color: #280569;
    width: fit-content;
    border-radius: 2px;
    padding: 4px 8px;
}
.elcas-card a, .elcas-card a:link, .elcas-card a:visited {
    font-size: 1rem;
}

.mega_menu_item h3 a, .mega_menu_item h3 a:link, .mega_menu_item h3 a:visited {
	font-weight: 700;
}