@import ur[](https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400..900;1,400..900&display=swap);

@font-face {
	font-family: "Poppins";
	src: url(../fonts/poppins-light-webfont.eot);
	src: url("../fonts/poppins-light-webfontd41d.eot#iefix") format("embedded-opentype"), url(../fonts/poppins-light-webfont.woff2) format("woff2"), url(../fonts/poppins-light-webfont.woff) format("woff"), url(../fonts/poppins-light-webfont.ttf) format("truetype");
	font-weight: 300;
	font-display: swap
}

@font-face {
	font-family: "Poppins";
	src: url(../fonts/poppins-regular-webfont.eot);
	src: url("../fonts/poppins-regular-webfontd41d.eot#iefix") format("embedded-opentype"), url(../fonts/poppins-regular-webfont.woff2) format("woff2"), url(../fonts/poppins-regular-webfont.woff) format("woff"), url(../fonts/poppins-regular-webfont.ttf) format("truetype");
	font-weight: 400;
	font-display: swap
}

@font-face {
	font-family: "Poppins";
	src: url(../fonts/poppins-semibold-webfont.eot);
	src: url("../fonts/poppins-semibold-webfontd41d.eot#iefix") format("embedded-opentype"), url(../fonts/poppins-semibold-webfont.woff2) format("woff2"), url(../fonts/poppins-semibold-webfont.woff) format("woff"), url(../fonts/poppins-semibold-webfont.ttf) format("truetype");
	font-weight: 600;
	font-display: swap
}

@font-face {
	font-family: "Poppins";
	src: url(../fonts/poppins-bold-webfont.eot);
	src: url("../fonts/poppins-bold-webfontd41d.eot#iefix") format("embedded-opentype"), url(../fonts/poppins-bold-webfont.woff2) format("woff2"), url(../fonts/poppins-bold-webfont.woff) format("woff"), url(../fonts/poppins-bold-webfont.ttf) format("truetype");
	font-weight: 700;
	font-display: swap
}

body {
	font-family: "Poppins", sans-serif;
	color: #fff;
	font-size: 16px;
	line-height: 1.75;
	font-weight: 500;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	background: url(../images/bg.webp)
}

html,
body {
	overflow-x: hidden
}

h1,
h2,
h3,
h4,
h5,
p,
ul {
	margin: 0 0 18px
}

h2:last-child,
h4:last-child,
p:last-child,
ul:last-child {
	margin-bottom: 0
}

h1,
h2,
h3,
h4,
h5 {
	font-family: "Playfair Display", serif;
	line-height: 1.3;
	font-weight: 600;
	color: #fbbf24
}

h1 {
	font-size: 2.5em
}

h2 {
	font-size: 1.875em
}

h3,
h4 {
	font-size: 1.5em
}

h4 {
	font-size: 1.25em;
	margin-bottom: 12px
}

h5 {
	font-size: 1.1em;
	margin-bottom: 8px
}

ul {
	padding: 0;
	margin: 0
}

ul li {
	list-style: none
}

p+h2,
p+h3 {
	margin-top: 35px
}

ul+p {
	margin-top: 35px
}

b,
strong {
	font-weight: 600
}

a {
	outline: 0;
	transition: all 0.5s;
	color: #fce690
}

a:link,
a:visited {
	text-decoration: none
}

a:hover,
a:focus,
a:active {
    background-color: transparent !important;
    background: none !important;
    opacity: 1;
    color: #fce690 !important;
}

img {
	outline: 0;
	border: 0 none;
	max-width: 100%;
	height: auto;
	vertical-align: top;
	-ms-border-radius: 0;
	border-radius: 40px
}

.center {
	text-align: center
}

.section-pad-sm {
	padding-top: 40px;
	padding-bottom: 40px
}

.section-pad-md {
	padding-top: 60px;
	padding-bottom: 60px
}

.row-vm {
	align-items: center;
	display: flex
}

.pd-x3 {
	padding: 30px
}

.pd-x5 {
	padding: 50px
}

.mt-x3 {
	margin-top: 30px
}

.mt-x5 {
	margin-top: 50px
}

.bg-dark {
	background: #2d3f5e
}

.bg-grey {
	background: #000;
	border-top: solid 1px #e4e4e4;
	border-bottom: solid 1px #e4e4e4;
	margin-bottom: 20px
}

.navbar-toggle {
	margin-right: 0
}

.panel-group .panel {
	border-radius: 0;
	box-shadow: none;
	border-bottom: 1px solid #eee;
	border: none
}

.panel-default>.panel-heading {
	padding: 0;
	border-radius: 0;
	color: #212121;
	background-color: #fff0;
	border: 0
}

.panel-title {
	font-size: 20px
}

.panel-title>a {
	display: block;
	padding: 15px;
	text-decoration: none
}

.panel-default>.panel-heading+.panel-collapse>.panel-body {
	border-top-color: #eee
}

.content .list-style li {
	position: relative;
	padding-left: 18px;
	margin-left: 0;
	margin-bottom: 8px
}

.content .list-style li:last-child {
	margin-bottom: 0
}

.content .list-style li:before {
	font-family: "FontAwesome";
	content: "\f105";
	color: #fbbf24;
	position: absolute;
	left: 1px;
	top: 3px;
	font-size: 16px;
	line-height: 18px
}

.content .list-style.dots li:before {
	content: "\f111";
	font-size: 6px;
	top: 5px
}

.accordion .panel {
	background-color: #fff0;
	border-bottom: 1px solid rgb(0 0 0 / .1);
	box-shadow: 0 0 15px rgb(0 0 0 / .08);
	margin-bottom: 10px
}

.accordion .panel:last-child {
	border-bottom: 0 none
}

.accordion .panel+.panel {
	margin-top: 0
}

.accordion .panel-title {
	position: relative;
	font-size: 18px;
	font-family: "Poppins", sans-serif;
	font-weight: 400
}

.accordion .panel-title a {
	color: #860b3a;
	padding: 16px 30px 17px 0
}

.accordion .panel-title a .plus-minus {
	opacity: .4
}

.accordion .panel-title a.collapsed {
	color: #596570
}

.accordion .panel-title a.collapsed:hover {
	opacity: .7
}

.accordion .panel-title a.collapsed:hover .plus-minus {
	opacity: .4
}

.accordion .panel-title a.collapsed .plus-minus {
	opacity: .7
}

.accordion .panel-title a.collapsed .plus-minus span:before {
	transform: rotate(-180deg)
}

.accordion .panel-title a.collapsed .plus-minus span:after {
	transform: rotate(0deg)
}

.accordion .panel-title a:hover {
	opacity: 1
}

.accordion .panel-title a:hover .plus-minus {
	opacity: 1
}

.accordion .panel-body {
	padding-right: 0;
	padding-left: 0;
	padding-bottom: 30px
}

.accordion .plus-minus {
	opacity: .8;
	cursor: pointer;
	transition: opacity 350ms;
	display: block;
	position: absolute;
	right: 0;
	top: 50%;
	height: 18px;
	width: 18px;
	margin-top: -9px
}

.accordion .plus-minus span {
	position: relative;
	height: 100%;
	display: block
}

.accordion .plus-minus span:before,
.accordion .plus-minus span:after {
	content: "";
	position: absolute;
	background: #666;
	transition: transform 100ms
}

.accordion .plus-minus span:before {
	height: 2px;
	width: 100%;
	left: 0;
	top: 50%;
	margin-top: -1px;
	transform: rotate(180deg)
}

.accordion .plus-minus span:after {
	height: 100%;
	width: 2px;
	top: 0;
	left: 50%;
	margin-left: -1px;
	transform: rotate(90deg)
}

.accordion .plus-minus:hover {
	opacity: .3
}

.accordion.filled .panel:last-child {
	border-bottom: 0
}

.accordion.filled .panel-title {
	background-color: #f5f5f5
}

.accordion.filled .panel-title a {
	background: #860b3a;
	padding-left: 20px;
	color: #fff;
	font-weight: 700
}

.accordion.filled .panel-title a .f-h {
	background: #860b3a;
	color: #fff;
	padding: 0 12px;
	margin-right: 20px
}

.accordion.filled .panel-title a.collapsed {
	background-color: #fff0;
	color: #596570
}

.accordion.filled .panel-title a.collapsed:hover {
	opacity: .7
}

.accordion.filled .panel-body {
	padding-right: 20px;
	padding-left: 20px;
	padding-bottom: 20px
}

.accordion.filled .plus-minus {
	right: 20px
}

.panel-group:last-child {
	margin-bottom: 0
}

.site-header .navbar {
	border-radius: 0;
	border: 0 none;
	min-width: 300px;
	padding: 20px 0 0;
	color: #36454e;
	background: #860b3a;
	margin: 0;
	z-index: 9
}

.site-header .navbar-brand {
	height: auto;
	padding: 0
}

.logo {
	font-size: 40px;
	font-weight: 700;
	color: #fff
}

.header-s2 .navbar {
	padding: 0
}

.header-s2 .navbar-brand {
	margin-top: 30px;
	margin-bottom: 10px;
	margin-left: 0px !important
}

.footer-widget {
	background: #000 url(../images/footer-bg.jpg) fixed top;
	color: #fff;
	font-size: 14px;
	line-height: 1.75;
	background-repeat: no-repeat;
	background-size: cover
}

.footer-widget a {
	color: inherit;
	text-decoration: none
}

.footer-widget a:hover,
.footer-widget a:focus {
    background-color: transparent !important;
    color: #8890a4;
}

.footer-widget .wgs-footer {
	margin-bottom: 40px
}

.footer-widget .wgs-footer:last-child {
	margin-bottom: 0
}

.footer-widget .wgs-title {
	font-size: 24px;
	color: #fff;
	font-weight: 400;
	text-transform: capitalize;
	margin: 0 0 20px
}

.footer-widget .wgs-content ul {
	list-style: none;
	margin: 0
}

.footer-widget .wgs-content ul li {
	padding-top: 10px
}

.footer-widget .wgs-content ul li:last-child {
	padding-bottom: 0
}

.footer-widget .wgs-menu .menu li {
	position: relative;
	border-bottom: 1px solid #828282
}

.footer-widget .wgs-menu .menu li:hover a:before {
	left: 3px
}

.copyright {
	background: #4d0420;
	padding: 10px 0;
	color: #fff;
	font-size: 13px;
	line-height: 1.75
}

.copyright .site-copy p {
	margin-bottom: 5px
}

.copyright .site-copy p:last-child {
	margin-bottom: 0
}

.copyright>.container {
	padding-left: 0;
	padding-right: 0
}

.flex-container {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap
}

.flex-container a {
	width: 19%;
	margin: .5%;
	display: flex;
	flex-direction: column;
	background: #5a0e2c;
	padding: 0;
	border-radius: 6px;
	border: 3px solid #870036
}

.flex-container a img {
	width: 100%;
	height: auto
}

.catUplayer {
	position: absolute;
	display: flex;
	background: #6d1639;
	color: #fff;
	z-index: 1;
	text-transform: uppercase;
	padding: 3px 22px 2px 6px;
	-webkit-clip-path: polygon(0 0, 92% 0, 100% 100%, 0 100%);
	clip-path: polygon(0 0, 92% 0, 100% 100%, 0 100%)
}

.flex-container a .name {
	padding: 5px
}

.catName {
	font-size: 12px;
	font-weight: 700;
	display: block;
	align-items: center
}

.sdnam {
	color: #fff;
	font-size: 18px;
	font-weight: 400;
	text-transform: capitalize;
	background: #a1184f;
	border-radius: 0 10px 0 10px;
	padding: 0 10px 0 10px
}

.rating {
	float: right
}

.rating i {
	color: gold;
	font-size: 17px
}

.responsive {
	width: 100%
}

.nowcalling {
	display: block;
	position: fixed;
	bottom: 0;
	width: 100%;
	z-index: 9999
}

.lcol {
	background-color: #b30000
}

.lcol {
	float: left;
	width: 50%
}

.lcol:last-child {
	background-color: #0D5929
}

.lcol a {
	display: block;
	padding: 10px;
	border-radius: 5px;
	text-align: center;
	color: #fff
}

.lcol a {
	display: block;
	padding: 10px 0;
	text-align: center;
	text-decoration: none;
	color: #fff
}

@media screen and (min-width:1600px) {

	.section-pad-sm {
		padding-top: 60px;
		padding-bottom: 60px
	}

	.section-pad-md {
		padding-top: 80px;
		padding-bottom: 80px
	}
}

@media only screen and (min-width:1200px) {

	.pad-r {
		padding-right: 60px
	}

	.row-vm [class*="col-"].pad-r {
		padding-right: 45px
	}
}

@media only screen and (min-width:992px) and (max-width:1199px) {
	.pad-r {
		padding-right: 45px
	}

	.row-vm [class*="col-"].pad-r {
		padding-right: 30px
	}
}

@media only screen and (max-width:1199px) {
	body {
		font-size: 15px
	}

	.footer-widget {
		font-size: 12px;
		line-height: 22px
	}
}

@media only screen and (max-width:991px) {
	body {
		font-size: 14px;
		-webkit-text-size-adjust: 100%
	}

	.container {
		max-width: 720px
	}

	.res-m-bttm {
		margin-bottom: 30px
	}

	.site-copy {
		width: 100%;
		font-size: 12px
	}

	.content .list-style li:before {
		top: 1px
	}

	.footer-widget {
		font-size: 14px;
		line-height: 24px
	}
}

@media only screen and (min-width:768px) and (max-width:991px) {

	.header-s2 .navbar-brand {
		margin-top: 15px;
		margin-bottom: 15px
	}

	.row-vm {
		align-items: baseline
	}
}

@media only screen and (max-width:767px) {
	.row-vm {
		display: block
	}

	.navbar-toggle {
		float: left;
		margin-top: 8px;
		margin-bottom: 8px;
		padding: 10px 12px;
		background-color: #860b3a
	}

	.navbar-toggle .icon-bar {
		background-color: #fff
	}

	.navbar-header {
		background: #860b3a;
		clear: both;
		width: 100%;
		padding: 0 15px
	}

	.site-header .navbar-header {
		float: left;
		margin: 5px 0 0
	}

	.header-s2 .navbar .container {
		padding-left: 0;
		padding-right: 0
	}

	.header-s2 .navbar-brand {
		position: absolute;
		left: 15px;
		width: 290px;
		margin-top: 15px;
		margin-bottom: 15px
	}

	.header-s2 .navbar-toggle {
		float: right;
		margin: 10px 15px 10px 0;
		-ms-border-radius: 2px;
		border-radius: 2px;
		padding: 12px
	}

	.header-s2 .navbar-header {
		background: none;
		padding: 0;
		margin-top: 0
	}

	.accordion .panel-title {
		font-size: 1.125em;
		font-weight: 400
	}

	.copyright {
		text-align: center
	}

	.copyright>.container {
		padding-left: 15px;
		padding-right: 15px
	}
}

@media only screen and (max-width:599px) {

	.logo {
		font-size: 20px
	}

	.flex-container a {
		width: 48% !important;
		margin: 1%
	}

	.site-copy {
		line-height: 30px
	}

	.col-md-12,
	.col-md-3,
	.col-md-4,
	.col-md-5,
	.col-md-7,
	.col-md-8,
	.col-sm-12,
	.col-sm-6 {
		position: relative;
		min-height: 1px;
		padding-right: 10px;
		padding-left: 10px
	}
}

@media only screen and (max-width:480px) {
	body {
		min-width: 320px
	}

	.pd-x3,
	.pd-x5 {
		padding: 25px
	}
}

@media only screen and (max-width:375px) {

	h1 {
		font-size: 1.875em
	}

	h2 {
		font-size: 1.5em
	}
}

@media only screen and (min-width:479px) and (max-width:991px) {
	.footer-widget.section-pad-md {
		padding-top: 40px;
		padding-bottom: 40px
	}

	.footer-widget .footer-col:nth-child(3) {
		clear: left
	}

	.footer-widget .footer-col:not([class*="col-xs"]) {
		width: 50%;
		float: left;
		margin-top: 20px;
		margin-bottom: 20px
	}
}

/* Banner Section Styles */
.banner-section {
    position: relative;
    width: 100%;
    height: 500px;
    background: linear-gradient(rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.6)), url('../images/banner-bg.jpg') no-repeat center center/cover;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 0 20px;
    margin: 0;
}

.banner-section {
    background-image: linear-gradient(rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.6)), url('../images/banner-bg.jpg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.banner-container {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
}

.banner-content {
    max-width: 800px;
}

.banner-title {
    font-size: 2.5rem;
    font-weight: bold;
    margin-bottom: 20px;
    text-transform: uppercase;
    line-height: 1.2;
}

.banner-subtitle {
    font-size: 1.2rem;
    margin-bottom: 30px;
    line-height: 1.5;
}

.banner-cta {
    display: inline-block;
    padding: 12px 30px;
    background-color: #1a73e8;
    color: #fff;
    text-decoration: none;
    border-radius: 5px;
    font-size: 1.1rem;
    font-weight: bold;
    transition: background-color 0.3s, transform 0.3s;
}

.banner-cta:hover {
    background-color: #d81b60;
    transform: scale(1.05);
}

@media (max-width: 768px) {
    .banner-section {
        height: 300px;
        background-image: linear-gradient(rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.7)), url('../images/banner-bg-mobile.jpg');
        background-size: cover;
        background-position: center;
        background-repeat: no-repeat;
    }

    .banner-title {
        font-size: 1.8rem;
    }

    .banner-subtitle {
        font-size: 1rem;
    }

    .banner-cta {
        padding: 10px 20px;
        font-size: 1rem;
    }
}

@media (max-width: 480px) {
    .banner-section {
        height: 250px;
    }

    .banner-title {
        font-size: 1.5rem;
    }

    .banner-subtitle {
        font-size: 0.9rem;
        margin-bottom: 20px;
    }

    .banner-cta {
        padding: 8px 15px;
        font-size: 0.9rem;
    }
}

header.site-header {
    margin-bottom: 0;
}

.section-services {
    margin-top: 0;
}

/* Inline styles in HTML footer override - added specific rules for custom styled footer links */
section[style*="background: linear-gradient"] a {
    color: #fff !important;
    text-decoration: none;
    display: block;
    padding: 8px 12px;
    margin: 5px auto;
    background-color: #1a73e8 !important;
    border-radius: 5px;
    border: 1px solid #0d47a1;
    transition: background-color 0.3s, transform 0.3s;
    max-width: 200px;
}

section[style*="background: linear-gradient"] a:hover {
    background-color: #d81b60 !important;
    color: #fff !important;
    transform: scale(1.05);
}

section[style*="background: linear-gradient"] .footer-col {
    flex: 1;
    min-width: 220px;
    background-color: #e6f3fa;
    padding: 20px;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}

section[style*="background: linear-gradient"] .footer-col:nth-child(2) {
    background-color: #e8f5e9;
}

section[style*="background: linear-gradient"] .footer-col:nth-child(2) a {
    background-color: #2e7d32 !important;
    border: 1px solid #1b5e20;
}

section[style*="background: linear-gradient"] .footer-col:nth-child(3) {
    background-color: #fff3e0;
}

section[style*="background: linear-gradient"] .footer-col:nth-child(3) a {
    background-color: #ef6c00 !important;
    border: 1px solid #e65100;
}

section[style*="background: linear-gradient"] .footer-col:nth-child(4) {
    background-color: #f3e5f5;
}

section[style*="background: linear-gradient"] .footer-col:nth-child(4) a {
    background-color: #8e24aa !important;
    border: 1px solid #6a1b9a;
}

@media (max-width: 768px) {
    section[style*="background: linear-gradient"] .footer-col {
        flex: 100%;
        margin-bottom: 20px;
    }
}