/* Complete Custom CSS - All additions extracted from Bootstrap file */

/* ================================================
   CUSTOM CSS VARIABLES
   ================================================ */
:root {
	--font-family-tempus: "Tempus Sans ITC", sans-serif;
}

/* ================================================
   STANDARD CSS OVERRIDES
   ================================================ */
*::before,
*::after {
	box-sizing: border-box;
}

.row::after {
	content: "";
	clear: both;
	display: table;
}

html {
	font-family: "Tempus Sans ITC", "Tondo Signage", Tondo, "Montserrat Medium", "Montserrat ExtraBold";
	line-height: 1.15;
	-webkit-text-size-adjust: 100%;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

body {
	margin: 0;
	font-family: "Tempus Sans ITC", "Tondo Signage", Tondo, "Montserrat Medium", "Montserrat ExtraBold";
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
	color: #212529;
	text-align: center;
	background-color: #fff;
}

/* ================================================
   AREA LINK STYLES
   ================================================ */
area:link {
	cursor: url("../img/signs/Icons/CursorArrow1.png"), default;
}

area:visited {
	color: cornflowerblue;
}

area:hover {
	cursor: url("../img/signs/Icons/CursorArrow2.gif"), default;
}

/* ================================================
   CUSTOM LINK CLASSES
   ================================================ */

/* Link Class: .one */
a.one:link {
	color: #080956;
	cursor: url("../img/signs/Icons/CursorArrow1.png"), default;
}

a.one:visited {
	color: green;
}

a:hover {
	cursor: url("../img/signs/Icons/CursorArrow1.png"), default;
}

/* Link Class: .two */
a.two:link {
	color: #EA9F06;
	text-decoration: none;
}

a.two:visited {
	color: green;
}

a.two:hover {
	color: #70F060;
}

a.two:active {
	color: blue;
}

/* Link Class: .three */
a.three:link {
	color: #21F207;
	text-decoration: none;
}

a.three:visited {
	color: green;
}

a.three:hover {
	color: #0E055C;
	font-size: 110%;
}

a.three:active {
	color: blue;
}

/* Link Class: .four */
a.four:link {
	color: antiquewhite;
	text-decoration: none;
}

a.four:visited {
	color: antiquewhite;
	text-decoration: none;
}

a.four:hover {
	color: cyan;
	text-decoration: none;
}

a.four:active {
	color: aqua;
	text-decoration: none;
}

/* Additional Area Styles */
area:link {
	color: #ED090C;
}

area:visited {
	color: #CF1013;
}

area:hover {
	color: #866263;
	opacity: 20%;
}
/* ================================================
   CUSTOM CSS EXTRACTED FROM BOOTSTRAP FILE
   Add these to KMStyle.css
   ================================================ */

/* ================================================
   CUSTOM LINK STYLES
   ================================================ */

/* Area links */
area:link {
    cursor: url("../img/signs/Icons/CursorArrow1.png"), default;
}

area:visited {
    color: cornflowerblue;
}

area:hover {
    cursor: url("../img/signs/Icons/CursorArrow2.gif"), default;
}

/* Link Class: .one */
a.one:link {
    color: #080956;
    cursor: url("../img/signs/Icons/CursorArrow1.png"), default;
}

a.one:visited {
    color: green;
}

a:hover {
    cursor: url("../img/signs/Icons/CursorArrow1.png"), default;
}

/* Link Class: .two */
a.two:link {
    color: #EA9F06;
    text-decoration: none;
}

a.two:visited {
    color: green;
}

a.two:hover {
    color: #70F060;
}

a.two:active {
    color: blue;
}

/* Link Class: .three */
a.three:link {
    color: #21F207;
    text-decoration: none;
}

a.three:visited {
    color: green;
}

a.three:hover {
    color: #0E055C;
    font-size: 110%;
}

a.three:active {
    color: blue;
}

/* Link Class: .four */
a.four:link {
    color: antiquewhite;
    text-decoration: none;
}

a.four:visited {
    color: antiquewhite;
    text-decoration: none;
}

a.four:hover {
    color: #28FF00;
    font-size: 110%;
}

a.four:active {
    color: blue;
}

/* ================================================
   INTERLUDE SECTIONS
   ================================================ */

/* Global h1 and p styles - BE CAREFUL, these affect all h1/p tags */
h1 {
    color: #333;
    font-size: 28px;
    margin-bottom: 15px;
}

p {
    color: #424242;
    font-size: 10px;
    line-height: 1.6;
}

/* Shared base styles for all Interludes */
.Interlude1, .Interlude2, .Interlude3, .Interlude4 {
    width: 100%;
    position: relative;
    text-align: center;
    font-family: "Tempus Sans ITC", "Tondo Signage", Tondo, "Montserrat Medium", "Montserrat ExtraBold";
    border-radius: 8px;
    margin: 10px 0;
}

/* Individual Interlude variations */
.Interlude1 {
	background-color: #FFFFF5; /* Creamy beige */
    border-left: 1px solid #FFA998; /* Terracotta accent bar */
    padding-top: 0 1em;
    border-bottom: medium;
}
.Interlude1 h11 {
    font-size: 28px;
    color: #FFB700;  /* Brighter gold */
    font-weight: bold;
    text-shadow: 
        -1px -1px 0px rgba(255,255,255,0.3),  /* Highlight top-left */
        1px 1px 0px rgba(0,0,0,0.5),          /* Shadow bottom-right */
        2px 2px 3px rgba(0,0,0,0.3);          /* Depth shadow */
    font-family: 'Times New Roman', serif;
}

.Interlude2 {
    padding-top: 2em;
    padding-bottom: 2em;
    border-bottom: none;
    font-size: 30vw;
}

.Interlude3 {
    padding-top: 1.5em;
    padding-bottom: 1.5em;
    border-bottom: medium;
}

.Interlude4 {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
    text-align: center;
    background-color: #000000;
    border-bottom: medium;
    font-size: 3px;
    color: #FFFFFF;
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .Interlude1 h1,
    .Interlude4 h3 {
        font-size: 18px;
    }
    
    .Interlude1 p {
        font-size: 14px;
    }
	.Interlude1 p9 {
		font-size: 10px;
		color: #013222;
		line-height:normal;
		padding:0;
		margin-top:0;
	}
	.Interlude1 h11 {
		font-size: 16px;
	}
    
    .Interlude2 {
        font-size: 20vw;
    }
	.Interlude4 p {
		color: aliceblue;
		margin-bottom: 0;
	}
}

.interlude5 {
    width: 100%;
    background-color: #f9f5f5;
    padding-top: 2.5em;
    padding-bottom: 2.5em;
    border: #000000;
    border-bottom: thick medium medium medium;
    font-family: "Tempus Sans ITC", "Tondo Signage", Tondo, "Montserrat Medium", "Montserrat ExtraBold";
    font-size: 40px;
    text-align: justify;
}

.Interlude6 {
    width: 100%;
    background-color: #f9f5f5;
    background-position: center;
    padding-top: 1px;
    padding-bottom: 1px;
    border: #000000;
    border-bottom: thick medium medium medium;
    font-family: "Tempus Sans ITC", "Tondo Signage", Tondo, "Montserrat Medium", "Montserrat ExtraBold";
    font-size: 25px;
    color: #000000;
    text-align: center;
}

.Interlude7 {
    width: 100%;
    background-color: #f9f5f5;
    background-position: center;
    padding-top: 1em;
    padding-bottom: 1em;
    border: #000000;
    border-bottom: thick medium medium medium;
    font-family: "Tempus Sans ITC", "Tondo Signage", Tondo, "Montserrat Medium", "Montserrat ExtraBold";
    font-size: 25px;
    color: #000000;
    text-align: center;
}

/* ================================================
   SOCIAL MEDIA ICONS
   ================================================ */

.smicons {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    max-width: 100%;
}

.Interlude4 .smicon img,
.social-icon {
    width: 20px;
    max-width: 100%;
    height: auto;
	margin-top: 0;
}

.Interlude4 .smicon img[src*="youtube"],
.Interlude4 .smicon img[src*="yt_logo"] {
    width: 60px;
    max-width: 100%;
}

@media (min-width: 576px) {
    .smicon {
        padding: 0 px;
    }
}

/* ================================================
   SUBTITLE SECTIONS
   ================================================ */

.subtitle, subtitle1, subtitle2, subtitle3, subtitle4, subtitle5, subtitle6, subtitle7 {
    width: 100%;
    position: relative;
    font-color: #000000;
    font-family: "Tempus Sans ITC", "Tondo Signage", Tondo, "Montserrat Medium", "Montserrat ExtraBold"
}

.subtitle {
    top: 430px;
    left: 300px;
    font-size: 70px;
}

.subtitle1 {
    position: absolute;
    top: 320px;
    right: 300px;
    font-size: 70px;
}

.subtitle2 {
    top: 100px;
    right: 1300px;
    font-size: 100px;
}

.subtitle3 {
    top: 290px;
    left: 190px;
    font-size: 30px;
}

.subtitle4 {
    top: 350px;
    right: 185px;
    font-size: 30px;
}

.subtitle5 {
    font-size: 30px;
    align-content: center;
    margin-left: 0;
    margin-right: 5;
    text-align: center;
    padding: 20px;
}

.subtitle6 {
    top: 450px;
    right: 185px;
    font-size: 30px;
}

.subtitle7 {
    top: 105px;
    left: 190px;
    font-size: 30px;
}

.subtitle8 {
    position: absolute;
    top: 360px;
    left: 450px;
    font-family: "Tempus Sans ITC", "Tondo Signage", Tondo, "Montserrat Medium", "Montserrat ExtraBold";
    font-size: 30px;
    font-color: #dce4e3;
}

.subtitle9 {
    position: absolute;
    top: 650px;
    Right: 555px;
    font-family: "Tempus Sans ITC", "Tondo Signage", Tondo, "Montserrat Medium", "Montserrat ExtraBold";
    font-size: 30px;
    font-color: #dce4e3;
}

/* ================================================
   INSTRUCTIONS SECTIONS
   ================================================ */

.instructions1, instructions2, instructions3, instructions4, instructions5, instructions6 {
    width: 100%;
}

.instructions1 {
    background-color: #F9F5F5;
    padding-top: 1em;
    padding-bottom: 1em;
    font-size: 15px;
}

.instructions2 {
    background-color: #F9F5F5;
    padding-top: 1em;
    padding-bottom: 1em;
    font-size: 15px;
}

.instructions3 {
    background-color: #F9F5F5;
    padding-top: 1em;
    padding-bottom: 1em;
    font-size: 15px;
}

.instructions4 {
    background-color: #F9F5F5;
    padding-top: 1em;
    padding-bottom: 1em;
    font-size: 15px;
}

.instructions5 {
    background-color: #F9F5F5;
    padding: 1em;
    font-size: 15px;
    max-width: 350px;
}

@media (min-width: 350px) {
    .instructions5 {
        font-size: 15px;
        max-width: 444px;
    }
}

@media (min-width: 768px) {
    .instructions5 {
        font-size: 15px;
        max-width: 720px;
    }
}

@media (min-width: 992px) {
    .instructions5 {
        font-size: 20px;
        max-width: 1200px;
    }
}

@media (min-width: 1200px) {
    .instructions5 {
        font-size: 20px;
        max-width: 1200px;
    }
}

.instructions6 {
    background-color: #F9F5F5;
    padding-top: 1em;
    padding-bottom: 1em;
    font-size: 15px;
}

@media (min-width: 576px) {
    .instructions6 {
        width: 150px;
        max-width: 444px;
    }
}

@media (min-width: 768px) {
    .instructions6 {
        font-size: 15px;
        max-width: 720px;
    }
}

@media (min-width: 992px) {
    .instructions6 {
        font-size: 20px;
        max-width: 1200px;
    }
}

@media (min-width: 1200px) {
    .instructions6 {
        font-size: 20px;
        max-width: 1200px;
    }
}

/* ================================================
   CUSTOM BUTTON STYLES
   ================================================ */

.btn-restnt {
    color: #02A901;
    background-color: #FFFFFF;
    border-color: #000000;
}

.btn-restnt:hover {
    color: #DBF4BB;
    background-color: #8EE622;
    border-color: #0062cc;
}

.btn-restnt:focus, .btn-restnt.focus {
    color: #fff;
    background-color: #0069d9;
    border-color: #0062cc;
    box-shadow: 0 0 0 0.2rem rgba(38, 143, 255, 0.5);
}

.btn-restnt:not(:disabled):not(.disabled):active,
.btn-restnt:not(:disabled):not(.disabled).active,
.show > .btn-restnt.dropdown-toggle {
    color: #fff;
    background-color: #0062cc;
    border-color: #5DC802;
}

.btn-tertiary {
    color: #452D02;
    background-color: #FBCF05;
    border-color: #4B2C02;
    padding: 5 20 5 20;
}

.btn-tertiary:hover {
    color: #030303;
    background-color: #F58A09;
    border-color: #4B2C02;
}

.btn-tertiary:focus, .btn-tertiary.focus {
    color: #fff;
    background-color: #104801;
    border-color: #545b62;
    box-shadow: 0 0 0 0.2rem rgba(130, 138, 145, 0.5);
}

.btn-tertiary.disabled, .btn-tertiary:disabled {
    color: #fff;
    background-color: #6c757d;
    border-color: #6c757d;
}

.btn-tertiary:not(:disabled):not(.disabled):active,
.btn-tertiary:not(:disabled):not(.disabled).active,
.show > .btn-tertiary.dropdown-toggle {
    color: #fff;
    background-color: #545b62;
    border-color: #452D02;
}

.btn-tertiary:not(:disabled):not(.disabled):active:focus,
.btn-tertiary:not(:disabled):not(.disabled).active:focus,
.show > .btn-tertiary.dropdown-toggle:focus {
    box-shadow: 0 0 0 0.2rem rgba(130, 138, 145, 0.5);
}

.btn-tpar1 {
    position: absolute;
    top: 800px;
    left: 100px;
    color: transparent;
    background-color: transparent;
    border-color: #000000;
    padding: 5px;
}

.btn-tpar1:hover {
    color: transparent;
    background-color: transparent;
    border-color: #0062cc;
}

.btn-tpar1:focus, .btn-primary.focus {
    color: #fff;
    background-color: #0069d9;
    border-color: #0062cc;
    box-shadow: 0 0 0 0.2rem rgba(38, 143, 255, 0.5);
}

.btn-tpar1.disabled, .btn-primary:disabled {
    color: #fff;
    background-color: #007bff;
    border-color: #007bff;
}

.btn-tpar1:not(:disabled):not(.disabled):active,
.btn-primary:not(:disabled):not(.disabled).active,
.show > .btn-primary.dropdown-toggle {
    color: #fff;
    background-color: #0062cc;
    border-color: #005cbf;
}

.btn-tpar1:not(:disabled):not(.disabled):active:focus,
.btn-primary:not(:disabled):not(.disabled).active:focus,
.show > .btn-primary.dropdown-toggle:focus {
    box-shadow: 0 0 0 0.2rem rgba(38, 143, 255, 0.5);
}
/* ================================================
   BUTTON STYLES WITH HOVER EFFECTS
   ================================================ */

/* Primary Button - Brown/Orange gradient */
.btn-primary {
	background: linear-gradient(135deg, #653802 0%, #653803 100%);
	color: #f9d0a7;
	border: 1.5px solid #4a2701;
	padding: 10px;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s ease;
	text-align: center;
	text-decoration: none;
	display: inline-block;
	box-shadow: 0 2px 8px rgba(101, 56, 2, 0.3);
}

.btn-primary:hover {
	background: linear-gradient(135deg, #854a03 0%, #854a04 100%);
	border-color: #2d1800;
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(101, 56, 2, 0.5);
}

/* Secondary Button - Green/Orange */
.btn-secondary {
	background: #24FC02;
	color: #FFFCFC;
	border: 1.5px solid #020000;
	padding: 10px;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s ease;
	text-align: center;
	text-decoration: none;
	display: inline-block;
	box-shadow: 0 2px 8px rgba(36, 252, 2, 0.3);
}

.btn-secondary:hover {
	background: #FFB100;
	border-color: #000000;
	color: #000000;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(255, 177, 0, 0.5);
}

/* Tertiary Button - Blue gradient */
.btn-tertiary {
	background: linear-gradient(135deg, #1e3c72 0%, #2a5298 100%);
	color: #ffffff;
	border: 1.5px solid #162d54;
	padding: 10px;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s ease;
	text-align: center;
	text-decoration: none;
	display: inline-block;
	box-shadow: 0 2px 8px rgba(30, 60, 114, 0.3);
}

.btn-tertiary:hover {
	background: linear-gradient(135deg, #2a5298 0%, #3d6bbb 100%);
	border-color: #0f1e36;
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(30, 60, 114, 0.5);
}

/* Gold Button */
.btn-fourthiary {
	background: linear-gradient(135deg, #FFD700 0%, #FFA500 100%);
	color: #1a1a1a;
	border: 1.5px solid #B8860B;
	padding: 10px;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s ease;
	text-align: center;
	text-decoration: none;
	display: inline-block;
}

.btn-fourthiary:hover {
	background: linear-gradient(135deg, #FFA500 0%, #FF8C00 100%);
	border-color: #8B6914;
	color: #000000;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(255, 165, 0, 0.6);
}

/* Generic button base class */
.btn {
	padding: 10px;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s ease;
	text-align: center;
	text-decoration: none;
	display: inline-block;
}

/* ================================================
   HEADER & HAMBURGER MENU
   ================================================ */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	font-family: Arial, sans-serif;
}

/* Header with responsive background images */
header {
	/* Mobile header - default */
	background-image: url("/img/Headers_and_Footers/Crestonbanner2Ph.png");
	background-size: cover;
	background-position: center;
	height: 150px;
	color: #000000;
	padding: 1rem;
	position: relative !important;
	z-index: 10000 !important;
}

/* Desktop header - 769px and up */
@media (min-width: 769px) {
	header {
		background-image: url("/img/Headers_and_Footers/Balfour_Header1.png");
		background-size: cover;
		background-position:center;
		height: 600px; /* Adjust height for desktop if needed */
	}
}

/* Semi-transparent overlay (optional, helps text readability) */
header::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(186, 173, 173, 0.18);
	z-index: 50 !important;
}

/* Navigation container */
.nav-container {
	position: relative;
	z-index: 2;
	padding: 1rem;
}

/* Navigation menu - DESKTOP STYLE */
nav {
	display: block;
	z-index: 9999 !important;
}

nav ul {
	list-style: none;
	display: flex;
	gap: 2rem;
	justify-content: center;
	padding: 1rem 0;
}

nav ul li a {
	color: white;
	text-decoration: none;
	font-size: 1.1rem;
	text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
	font-weight: 500;
}

nav ul li a:hover {
	color: #ddd;
}

@media (min-width:769px) {
	nav {
		display: none !important;
	}
}
/* Hamburger button ONLY ON MOBILE (because I DON'T WANT IT on DT*/
.menu-toggle {
	display: none;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0.5rem;
	position: relative !important;
	top: 65px;
	left: 5px;
	z-index: 10000 !important;
	pointer-events: auto !important;
}

/* Make sure container/Bootstrap elements don't block clicks */
.container, .row, .col-lg-12 {
	pointer-events: none;
}

.container *, .row *, .col-lg-12 * {
	pointer-events: auto;
}

.menu-toggle span {
	display: block;
	width: 25px;
	height: 3px;
	background-color: white;
	margin: 5px 0;
	transition: 0.3s;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

/* Mobile styles */
@media (max-width: 768px) {
	.menu-toggle {
		display: block;
	}

	nav {
		position: absolute;
		top: 100%;
		left: 0;
		width: 100%;
		background-color: rgba(0, 0, 0, 0.9);
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.3s ease;
	}

	nav.active {
		max-height: 500px;
	}

	nav ul {
		flex-direction: column;
		gap: 0;
		padding: 1rem 0;
	}

	nav ul li {
		padding: 0.75rem 1rem;
		border-bottom: 1px solid rgba(255, 255, 255, 0.1);
	}

	nav ul li:last-child {
		border-bottom: none;
	}
}

/* ================================================
   SCROLL MENU
   ================================================ */
.map-container {
	position: relative;
}

.scroll-menu {
	position: absolute;
	top: 25%;
	left: 75%;
	z-index: 10;
}

.scroll-image {
	width: 250px;
	height: auto;
}

.scroll-link {
	position: absolute;
	color: #492902;
	text-decoration: none;
	font-family: 'Georgia', serif;
	font-size: 14px;
	font-weight: bold;
	transition: color 0.2s;
	white-space: nowrap;
}

.scroll-link:hover {
	color: #28FF00;
	text-decoration: underline;
}

/* Position each link */
.scroll-link:nth-child(2) { top: 25%; left: 25%; }
.scroll-link:nth-child(3) { top: 40%; left: 25%; }
.scroll-link:nth-child(4) { top: 55%; left: 25%; }
.scroll-link:nth-child(5) { top: 70%; left: 25%; }

/* ================================================
   NAV BANNER CONTAINER
   ================================================ */
.nav-banner-container {
	position: relative;
}

.banner-image {
	position: relative;
}

.scroll-buttons {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
}

.scroll-button {
	position: absolute;
	display: inline-block;
	text-decoration: none;
	transition: transform 0.2s;
	pointer-events: auto;
}

.scroll-button:hover {
	transform: scale(1.05);
}

.scroll-bg {
	width: 175px;
	height: auto;
	display: block;
}

.scroll-text {
	position: absolute;
	top: 50%;
	left: 43%;
	transform: translate(-50%, -50%);
	color: #FFF4DC;
	font-weight: bold;
	font-size: 0.8rem;
	white-space: nowrap;
	pointer-events: none;
	text-shadow: 0 1px 2px rgba(0,0,0,0.84);
}

/* Mobile adjustments */
@media (max-width: 768px) {
	.map-container {
		position: relative;
}

	.scroll-menu {
		position: absolute;
		top: 15%;
		left: 58%;
		z-index: 10;
	}
	
	.scroll-image {
		
		width: 130px;
	}
	.scroll-link {
		font-size: 10px;
	}
	.scroll-buttons {
		gap: 0.5rem;
	}
	
	.scroll-bg {
		width: 75px;
	}
	
	.scroll-text {
		font-size: 0.75rem;
	}
}

/* ================================================
   CARD COMPONENTS
   ================================================ */
.card-img-top {
	border-radius: 8px 8px 0 0;
}

.smicon {
	display: inline-block;
	margin: 5px;
}

/* Base card */
.card {
	position: relative;
	display: flex;
	flex-direction: column;
	min-width: 0;
	word-wrap: break-word;
	background-color: #E2AA2A;
	background-clip: border-box;
	border: 1px solid rgba(0, 0, 0, 0.125);
	border-radius: 8px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
	margin-bottom: 20px;
	max-width: 400px;
	margin: 0 auto;
}

.cardbanner1 {
	text-align: center;
	padding: 30px;
	background: #fff;
	border-radius: 8px;
	margin: 20px 0;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

/* Card banner variants */
.cardbanner1, .cardbanner2 {
	position: relative;
	display: flex;
	flex-direction: column;
	width: 100%;
	min-width: 370px;
	word-wrap: break-word;
	background-color: #FFFFFF;
	background-clip: border-box;
	text-align: center;
}

.cardbanner1 > hr,
.cardbanner2 > hr {
	margin-right: auto;
	margin-left: auto;
}

/* Transparent card for business listings */
.cardtpar {
	position: relative;
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	width: 100%;
	max-width: 1400px;
	min-height: 750px;
	word-wrap: break-word;
	background-color: transparent;
	border: 1px solid rgba(0, 0, 0, 0.005);
	border-radius: 0.25rem;
	margin-left: 5px;
	padding: 15px;
}

.cardtpar-header {
	width: 100%;
	padding: 0.75rem 1.25rem;
	margin-bottom: 0;
	background-color: rgba(0, 0, 0, 0.03);
	border-bottom: 1px solid rgba(0, 0, 0, 0.125);
}

.cardtpar-body {
	flex: 1 1 auto;
	min-height: 1px;
	padding: 1.25rem;
}

/* Responsive card layouts */
@media (max-width: 768px) {
	.cardtpar {
		min-width: 100%;
		min-height: auto;
		margin-left: 0;
	}
	
	.cardbanner1, .cardbanner2 {
		min-width: 100%;
	}
}

/* Card deck - only change layout on larger screens */
@media (min-width: 768px) {
	.card {
		display: flex;
		flex-flow: row wrap;
		margin-right: -15px;
		margin-left: -15px;
	}
	
	.card {
		flex: 1 0 0%;
		margin: 0 15px;
	}
}

.card-body .smicon {
	display: inline-block;
	width: 100px;
	margin: 5px;
	text-align: center;
	vertical-align: top;
}

.card-body .smicon img {
	width: 100%;
	max-width: 100px;
	height: auto;
}

.card-title {
	margin-bottom: 0.75rem;
}

.card-subtitle {
	margin-top: -0.375rem;
	margin-bottom: 0;
}

.card-text:last-child {
	margin-bottom: 0;
}

.card-link:hover {
	text-decoration: none;
}

.card-link + .card-link {
	margin-left: 1.25rem;
}

.card-header {
	padding: 0.75rem 1.25rem;
	margin-bottom: 0;
	background-color: rgba(0, 0, 0, 0.03);
	border-bottom: 1px solid rgba(0, 0, 0, 0.125);
}

.card-header:first-child {
	border-radius: calc(0.25rem - 1px) calc(0.25rem - 1px) 0 0;
}

.card-header + .list-group .list-group-item:first-child {
	border-top: 0;
}

.card-footer {
	padding: 0.75rem 1.25rem;
	background-color: rgba(0, 0, 0, 0.03);
	border-top: 1px solid rgba(0, 0, 0, 0.125);
}

.card-footer:last-child {
	border-radius: 0 0 calc(0.25rem - 1px) calc(0.25rem - 1px);
}

.card-header-tabs {
	margin-right: -0.625rem;
	margin-bottom: -0.75rem;
	margin-left: -0.625rem;
	border-bottom: 0;
}

.card-header-pills {
	margin-right: -0.625rem;
	margin-left: -0.625rem;
}

.card-img-overlay {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	padding: 1.25rem;
}

.card-img, .card-img-top, .card-img-bottom {
	flex-shrink: 0;
	width: 100%;
}

.card-img, .card-img-top {
	border-top-left-radius: calc(0.25rem - 1px);
	border-top-right-radius: calc(0.25rem - 1px);
}

.card-img, .card-img-bottom {
	border-bottom-right-radius: calc(0.25rem - 1px);
	border-bottom-left-radius: calc(0.25rem - 1px);
}

/* ================================================
   ACCORDION STYLES
   ================================================ */
.accordion > .card {
	overflow: hidden;
}

.accordion > .card:not(:last-of-type) {
	border-bottom: 0;
	border-bottom-right-radius: 0;
	border-bottom-left-radius: 0;
}

.accordion > .card:not(:first-of-type) {
	border-top-left-radius: 0;
	border-top-right-radius: 0;
}

.accordion > .card > .card-header {
	border-radius: 0;
	margin-bottom: -1px;
}

/* ================================================
   BREADCRUMB STYLES
   ================================================ */
.breadcrumb {
	display: flex;
	flex-wrap: wrap;
	padding: 0.75rem 1rem;
	margin-bottom: 1rem;
	list-style: none;
	background-color: #e9ecef;
	border-radius: 0.25rem;
}

.breadcrumb-item + .breadcrumb-item {
	padding-left: 0.5rem;
}

.breadcrumb-item + .breadcrumb-item::before {
	display: inline-block;
	padding-right: 0.5rem;
	color: #6c757d;
	content: "/";
}

.breadcrumb-item + .breadcrumb-item:hover::before {
	text-decoration: underline;
}

.breadcrumb-item + .breadcrumb-item:hover::before {
	text-decoration: none;
}

.breadcrumb-item.active {
	color: #6c757d;
}

/* ================================================
   PAGINATION STYLES
   ================================================ */
.pagination {
	display: flex;
	padding-left: 0;
	list-style: none;
	border-radius: 0.25rem;
}

/* ================================================
   RESPONSIVE DISPLAY UTILITIES
   Must be at end to ensure proper override
   ================================================ */
@media (min-width: 769px) {
	.mobile-only {
		display: none !important;
	}
	.desktop-only {
		display: block !important;
	}
}

@media (max-width: 768px) {
	.desktop-only {
		display: none !important;
	}
	.mobile-only {
		display: block !important;
	}
}