/*
green - 0d382d
light green - C3D186
lightest green - far out in the uncharted backwaters
white - c6cfce
pink - F4C2C2
light pink - FFEEEE

yellow - FEC046
dark grey - 5b5c57
grey - c7c9ca
*/

body { padding: 0; color: #212529; font-size: 1.2em; font-family: "Barlow", sans-serif; background: #FFF; }
a, a:link, a:focus, a:active, a:visited { color: #0d382d; text-decoration: underline; }
a:hover  { color: #000; }
h1 { font-family: "Cardo"; color: #212529; margin-top: 0; padding-bottom: 10px; font-size: 2em; }
h2  { font-family: "Cardo"; color: #0d382d; font-size: 1.5em; padding-top: 10px; padding-bottom: 5px; }
h3  { font-size: 1.3em; }
strong { color: #0d382d; } 
.table { margin-bottom: 25px; }
.table thead>tr>th, .table tbody>tr>th, .table tfoot>tr>th, .table thead>tr>td, .table tbody>tr>td, .table tfoot>tr>td  { background-color: #FFF; border-top: 1px solid #757575; }
.table-striped > tbody > tr:nth-child(2n+1) > td, .table-striped > tbody > tr:nth-child(2n+1) > th { background-color: #FFF; border-top: 1px solid #757575; }
.table-bordered td, .table-bordered th { border: 1px solid #0d382d; }
img { max-width: 100%; display: block; } 
.row { margin: 0; }

@media all and (min-width: 0px) and (max-width: 768px) 
{
	body { font-size: 18px !important; }
	#container_header_full { background-color: #fff !important; height: auto !important; }
	.container_slideshow_full { background-color: #0d382d !important; }
	.container_home { background-color: #fff !important; }
	.container_content_full { background-color: #fff !important; }
	.container_banner_photo_full {  background-color: #0d382d !important; }
	#logo { float: none; margin: 20px auto 0 auto; width: 80% !important; }
	.quick_link  { display: none !important; }
	.navbar-nav .dropdown-menu { width: 100% !important; }
	.nav-item { border-bottom: 1px solid #0d382d; }
	.navbar-nav > li > a {  margin-top: 0 !important; }
	#nav-link-first { border-radius: 0 !important; }
	#nav-link-last { border-radius: 0 !important; }
	.navbar-nav > li:last-child > a, .navbar-nav > li:last-child > a:link, .navbar-nav > li:last-child > a:focus, .navbar-nav > li:last-child > a:active, .navbar-nav > li:last-child > a:visited { border-radius: 0 !important; }
	.container_intro_banner_full .container { padding: 1em 2em !important; }
	#main_content { padding-top: 20px !important; }
	.service_cell_description h3 { padding-top: 30px; }
	.service_cell { min-height: 400px !important; margin-bottom: 40px !important; }
	#footer_links ul li { padding: 14px 0 !important; }
	#footer_email { font-size: 0.8em; }
}

.container_header_full { margin: 0 auto; width: 100%; padding: 0; background: #0d382d; border-top: 5px solid #F4C2C2; }
#logo { width: 100%; }
.quick_link { display: flex; align-items: center; justify-content: center; height: 100%; text-decoration: none !important; color: #FFF !important; }
.quick_link:hover  { color: #C3D186; }

.container_menu_full { margin: 0 auto; width: 100%; padding: 0; background: #C3D186; color: #000; }
.navbar-nav > li > a { padding: 12px 15px 12px 15px; text-align: center; text-decoration: none; border-radius: 0; font-size: 1em; color: #000; letter-spacing: 1px; }
.navbar-nav > li > a.active, .navbar-nav > li > a:hover, .navbar-nav > li > a:active , .navbar-nav > li > a:focus,
.navbar-nav  .open > a, .navbar-nav  .open > a:hover, .navbar-nav  .open > a:focus { color: #000; text-decoration: underline; }
.navbar-nav .nav-link.active { color: #000; text-decoration: underline; }
.navbar-nav > li:first-child > a, .navbar-nav > li:last-child > a  { border-bottom: 0; }
.nav .caret { border-top-color: #FFF; border-bottom-color: #FFF; }
.navbar-nav .dropdown-menu { background: #C3D186; border-radius: 0; padding: 0; margin: 0; width: 260px; }
.navbar-nav .dropdown-menu > li { padding: 0; margin: 0; }
.navbar-nav .dropdown-menu > li  a { color: #000; padding: 10px 20px !important; width: 100%; display: block; border-bottom: 1px solid #FFF; font-size: 1em; text-decoration: none; text-align: left; }
.navbar-nav .dropdown-menu > li  a.active, .dropdown-menu > li  a:hover, .dropdown-menu > li  a:active , .dropdown-menu > li  a:focus { color: #000; background-color: #E4EAC5; text-decoration: none; }
.dropdown:hover .dropdown-menu { display: block; }
.navbar-toggler-icon { color: #FFF; background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255, 255, 255, 1)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important; }

.carousel-caption { bottom: 30%; left: 15%; text-align: center; }
.carousel-caption h5 { font-size: 3em; color: #F6F2ED; text-shadow: 2px 2px #000; }
.carousel-caption p { font-size: 1.5em; color: #F6F2ED; }
.btn-slideshow, .btn-slideshow:link, .btn-slideshow:focus, .btn-slideshow:active, .btn-slideshow:visited, .btn-slideshow[disabled] { padding: 10px 30px; background-color: transparent; background-repeat: no-repeat; cursor: pointer; overflow: hidden; outline: none; color: #FFF; border: 1px solid #FFF; text-decoration: none; }
.btn-slideshow:hover  { background: #0d382d; color: #FFF; }

.container_slideshow_full { position: relative;  }
.container_home { background: #FFF; color: #212529; padding-top: 40px; }
#main_content_home { padding: 40px 10px 80px 10px; }
.container_content_full .container { background: #FFF; color: #212529; }
#main_content { padding: 40px 10px 40px 10px; }
#main_content li { margin: 1em 0; }
#plain_page_photos { margin-top: 65px;  }
#plain_page_photos img { margin-bottom: 10px; }
#plain_page_photos p { font-size: 0.8em; }
.plain_page_photos_name { font-size: 0.9em; margin-bottom: 10px;  }
.form-label { margin-top: 10px; font-weight: bold; }
.form-label small { font-weight: normal; }

#home_content { padding: 60px 30px 20px 20px; }
#home_page_photo { padding: 0; margin: 0; }

/* services */
.container_service_heading_full { background: #0d382d; color: #FFF; padding: 60px 40px; }
.container_service_heading_full h2 { color: #FFF; font-size: 1.9em }
.container_service_heading_full p { color: #FFF; font-size: 1.2em; }
.container_services_full h2 { margin: 20px 0 40px 10px; }
.service_cell { display: none; }
.service_cell.active { display: block; }
.service_cell_description h3 { padding-bottom: 20px; }
.service_name_container {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.service_menu_item {
  width: 90%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border: 1px solid #ddd;
  border-radius: 4px;
  background-color: #fff;
  cursor: pointer;
  position: relative;
  transition: background 0.2s ease;
}

.service_menu_item:hover {
  background: #f9f9f9;
}

.service_menu_item a {
  text-decoration: none;
  color: inherit;
  flex-grow: 1;
}

.service_menu_item i {
  position: absolute;
  right: 16px;
  transition: transform 0.3s ease;
  transform: rotate(45deg); /* default: diagonal arrow */
}

/* Rotate arrow on hover or active */
.service_menu_item:hover i,
.service_menu_item.active i {
  transform: rotate(0deg); /* points right */
}

/* Optional: highlight active menu item */
.service_menu_item.active {
  background-color: #D4DDDA;
  border-color: #0d382d;
}

.service_cell_cta { text-align: right; margin: 20px 0 40px 0; }
.services_photos { margin-top: 65px;  }
.services_photos_name { font-size: 0.8em; margin-top: 2px; margin-bottom: 20px; }

/* faqs */
.container_home_faqs_full { margin: 60px 0 80px 0; }
.container_home_faqs_full h2 { margin-bottom: 40px; }
.container_home_faqs { margin: 0 20px; }
#faqs_cta { text-align: center; }
.faq_question { padding: 10px 20px; margin-bottom: 40px; }
.faq_question img { float: left; width: 20px; margin-right: 10px; }
.faq_question i { margin-right: 10px; }
.faq_answer { display: none; color: #212529; }
#faqs dd { display: none; padding: 5px 5px 5px 25px; }
#faqs dt { padding: 5px 5px 20px 5px; cursor: pointer; } 
#faqs dt i { float: right; } 
.carousel-indicators [data-bs-target] { background-color: #212529; }
.carousel-indicators .active { background-color: #000; }

.grecaptcha-badge { visibility: hidden; }
#recaptcha_help { font-size: 0.85em; }
label.error { font-weight: bold; color: #FF0000; padding: 2px 8px; margin-top: 2px; }
.btn-primary, .btn-primary:link, .btn-primary:focus, .btn-primary:active, .btn-primary:visited, .btn-primary[disabled] { padding: 10px 25px 10px 25px; background: #C3D186; color: #000 !important; border: none; border-radius: 0; text-decoration: none; }
.btn-primary:hover { background: #F4C2C2; color: #000; }
.btn-sm { margin-bottom: 5px; }

.container_footer_full { margin: 0 auto; width: 100%; padding: 10px 0; background: #0d382d; text-align: center; }
#footer_links { padding: 40px 0 10px 0; text-align: center; color: #FFF; font-size: 0.9em; }
#footer_links img { width: 400px; margin: 0 auto; }
#footer_links i { margin-right: 7px; }
#footer_contact { margin: 20px 20px 10px 20px; }
#footer_contact a, #footer_contact a:link, #footer_contact a:focus, #footer_contact a:active, #footer_contact a:visited { color: #FFF; }
#footer_contact a:hover { color: #F4C2C2; }
#footer_email { padding: 20px 0 10px 0; }
#footer_map{ margin-top: 15px; }
#footer_map iframe { filter: grayscale(100%); }
#footer_social_media { padding-top: 30px; }
.facebook_link { margin-right: 20px; }
#footer { color: #FFF; padding: 5px 0; }
#footer a, #footer a:link, #footer a:focus, #footer a:active, #footer a:visited { color: #FFF; text-decoration: none; font-weight: normal; }
#footer a:hover  { color: #0d382d; text-decoration: underline; }

.container_footer_credits_full { margin: 0 auto; width: 100%; padding: 10px 0; background: #C3D186; font-size: 0.85em; }
#copyright { padding-left: 0; }
#social_media { text-align: center; }
#credits { text-align: right; padding-right: 0; }


