/* === Red Barn Media Group - Global Styles - Dutch Heating === */

body {
  width: 100%;
  height: 100%;
  color: #000;
  font-family: "Sen", sans-serif;
  font-weight: 400;
  font-style: normal;
  background-color: #fff;
}

html {
  width: 100%;
  overflow-x: hidden;
  height: 100%;
}

h1,
h2 {
  font-family: "Sen", sans-serif;
  font-weight: 600;
  font-style: normal;
  text-transform: uppercase;
}
h3,
h4,
h5,
h6 {
  font-family: "Sen", sans-serif;
  font-weight: 400;
  font-style: normal;

}


.fs-7 {
  font-size: 0.85rem;
}
.fs-8 {
  font-size: 0.65rem;
}
/* === Menu Styles :: BEGIN === */
.menu-container {
  background: #ffffff;
  margin-top: 0rem !important;
  border-bottom: 1px solid transparent;
}
.menu-container.shrink-menu {
  margin-top: 0rem !important;
  border-bottom: 1px solid #000;
}
.menu-container .container .row .col-12 nav.navbar-light {
  background: transparent !important;
  padding: 1rem;
}
.navbar-nav {
  width: 100%;
}
.navbar-light .navbar-nav .nav-link {
  color: #000 !important;
  font-family: "Sen", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 0.95rem;
}
.navbar-light .navbar-nav .nav-link:hover,
.navbar-light .navbar-nav .nav-link:active {
  color: #c72c1e!important;
}
.dropdown-item:focus,
.dropdown-item:hover {
  background-color: #eee !important;
  border-radius: 0.25rem;
}
.dropdown-item:hover,
.dropdown-item:active {
  color: #c72c1e!important;
  background-color: #ececec !important;
}
.dropdown-toggle::after {
  display: none;
}

/* CSS for dropdown submenu positioning and transitions */
.dropdown-submenu {
  position: relative;
}

.dropdown-submenu .dropdown-menu {
  top: 0;
  left: 100%;
  margin-top: 0;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
  display: block !important;
  transform: translateX(-10px);
}

.dropdown-submenu .dropdown-menu.show {
  opacity: 1;
  visibility: visible;
  transform: translateX(0);
}

/* Mobile adjustments for submenus */
@media (max-width: 1199.98px) {
  .dropdown-submenu .dropdown-menu {
    left: 0;
    top: 100%;
    transform: translateY(-10px);
  }
  
  .dropdown-submenu .dropdown-menu.show {
    transform: translateY(0);
    background-color: transparent;
    color:white;
  }
}

.navbar-expand-xl .navbar-nav .dropdown-menu.main-dropdown {
  top: 4.2rem;
  background: #fff;
  padding-top: 0.5rem;
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  padding-bottom: 0.5rem;
  border: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  border-bottom-left-radius: 1rem;
  border-bottom-right-radius: 1rem;
  box-shadow: 0 3rem 3rem rgba(0, 0, 0, 0.175);
  transition-duration: 0.25s;
}
.shrink-menu .navbar-expand-xl .navbar-nav .dropdown-menu.main-dropdown {
  top: 3.9rem;
  transition-duration: 0.25s;
}
.navbar-expand-xl .navbar-nav .dropdown-menu.sub-dropdown {
  background: #fff;
  padding: 0.5rem;
  border: 0;
  border-radius: 1rem;
  box-shadow: 0 3rem 3rem rgba(0, 0, 0, 0.175);
}
.menu-container .container-fluid.dutch-logo-row {
  transition-duration: 0.25s;
}
.menu-container.shrink-menu .container-fluid.dutch-logo-row {
  transition-duration: 0.25s;
}
.menu-container .container-fluid .row .dutch-logo-place {
  position: relative;
}

.navbar-nav {
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 6rem;
  transition-duration: 0.25s;
}
.shrink-menu .navbar-nav {
  height: 5.5rem;
  transition-duration: 0.25s;
}

.dutch-logo-desktop {
  position: absolute;
  width: 300px;
  height: 82px;
  top: -1.85rem;
  left: 0;
  margin-left: auto;
  right: 0;
  margin-right: auto;
  transition-duration: 0.25s;
}
.shrink-menu .dutch-logo-desktop {
  width: 263px;
  height: 70px;
  top: -1.7rem;
  transition-duration: 0.25s;
}
.jcha-menu-top-row .dutch-menu-top-col {
  color: #fff;
  margin-top: 0.65rem;
  margin-bottom: 0.65rem;
  transition-duration: 0.25s;
}
.shrink-menu .jcha-menu-top-row .dutch-menu-top-col {
  margin-top: 0.35rem;
  margin-bottom: 0.35rem;
  transition-duration: 0.25s;
}
.jcha-menu-top-row .dutch-menu-top-col p {
  font-size: 0.85rem;
  margin-bottom: 0;
}
.dropend .dropdown-item::after {
  display: none;
}
.nav-fill .nav-item .dropdown-item {
  text-align: left !important;
  color: #000;
}
.dropstart .dropdown-toggle::before {
  display: none !important;
}
/* === Menu Styles :: END === */
/* === Button Styles :: BEGIN === */
.btn {
  padding: 0.5rem 0.85rem !important; /* Lighter padding */
  font-family: "sen", sans-serif;
  font-weight: 400;
  font-style: normal;
  border-radius: 0rem; /* Consistent border-radius across all buttons */
}
.btn.btn-menu {
    border-radius: .55!important; /* Consistent border-radius across all buttons */
}
.btn.btn-lg {
  padding: 0.6rem 1.25rem !important;
  font-size: 1rem !important;
}
.btn.btn-xl {
  padding: 0.75rem 1.5rem !important;
  font-size: 1.5rem !important;
}

/* New black button class */
.btn-black {
  color: #fff;
  background: #000;
  border-color: #000;
  transition: all 0.3s ease;
}
.btn-black:hover, .btn-black:active, .btn-black:focus {
  color: #fff;
  background: #333;
  border-color: #333;
  box-shadow: 0 0.25rem 0.5rem rgba(0,0,0,0.15);
}

.btn-primary {
  color: #fff;
  background: #2574d3;
  border-color: #2574d3;
}
.btn-primary:hover {
  color: #fff;
  background: #1f65bb;
  border-color: #1f65bb;
}
.btn-dark {
  color: #fff;
  background: #000;
  border-color: #000;
}
.btn-dark:hover {
  color: #fff;
  background: #1a1a1a;
  border-color: #1a1a1a;
}
.btn-rollover {
  color: #2574d3;
  background: transparent;
  border: 1px solid #2574d3;
  font-family: poppins, sans-serif;
  font-weight: 600;
  font-size: 0.95rem;
  font-style: normal;
  text-transform: uppercase;
  height: 100%;
}
.btn-rollover:hover,
.btn-rollover.active {
  color: #fff !important;
  background: #000 !important;
  border: 1px solid #000;
}
.btn-danger {
  color: #fff;
  background: #c72c1e;
  border-color: #c72c1e;
}
.btn-danger:hover {
  color: #fff;
  background: #e33425;
  border-color: #c72c1e;
}

/* Burgundy Button Class */
.btn-burgundy {
  color: #fff;
  background: #33060d;
  border-color: #33060d;
  transition: all 0.3s ease;
}

.btn-burgundy:hover, .btn-burgundy:active, .btn-burgundy:focus {
  color: #fff;
  background: #4a0912;
  border-color: #4a0912;
  box-shadow: 0 0.25rem 0.5rem rgba(0,0,0,0.15);
}

.btn-outline-burgundy {
  color: #33060d;
  background: transparent;
  border-color: #33060d;
  transition: all 0.3s ease;
}

.btn-outline-burgundy:hover, .btn-outline-burgundy:active, .btn-outline-burgundy:focus {
  color: #fff;
  background: #33060d;
  border-color: #33060d;
  box-shadow: 0 0.25rem 0.5rem rgba(0,0,0,0.15);
}

/* === Button Styles :: END === */
/* === Color Styles :: BEGIN === */
.text-primary {
  color: #2574d3 !important;
}
.bg-primary {
  background: #2574d3 !important;
}
.border-primary {
  border-color: #2574d3 !important;
}

.text-primary.dark {
  color: #093159 !important;
}
.bg-primary.dark {
  background: #093159 !important;
}
.border-primary.dark {
  border-color: #093159 !important;
}

.text-primary.light {
  color: #ebf5ff !important;
}
.bg-primary.light {
  background: #ebf5ff !important;
}
.border-primary.light {
  border-color: #ebf5ff !important;
}

.text-light {
  color: #f5f5f7 !important;
}
.bg-light {
  background: #f5f5f7 !important;
}
.border-light {
  border-color: #f5f5f7 !important;
}

.text-dark {
  color: #000 !important;
}
.bg-dark {
  background: #000 !important;
}
.border-dark {
  border-color: #000 !important;
}

.text-666 {
  color: #666 !important;
}

/* Adding danger color classes with new hex value */
.text-danger {
  color: #c72c1e !important;
}
.bg-danger {
  background: #c72c1e !important;
}
.border-danger {
  border-color: #c72c1e !important;
}

/* Adding lighter and darker variants for consistency */
.text-danger.dark {
  color: #a12419 !important;
}
.bg-danger.dark {
  background: #a12419 !important;
}
.border-danger.dark {
  border-color: #a12419 !important;
}

.text-danger.light {
  color: #e33425 !important;
}
.bg-danger.light {
  background: #e33425 !important;
}
.border-danger.light {
  border-color: #e33425 !important;
}

/* Custom burgundy background color */
.bg-burgundy {
  background-color: #33060d;
}


/* === Color Styles :: END === */
/* === Footer Styles :: BEGIN === */
footer {
  background: #000;
}

.bg-rbmg {
  background: #352f36;
}
/* === Footer Styles :: END === */
/* === Utility Styles :: BEGIN === */

/* Burgundy Button Class */
.btn-burgundy {
  color: #fff;
  background: #33060d;
  border-color: #33060d;
  transition: all 0.3s ease;
}

.btn-burgundy:hover, .btn-burgundy:active, .btn-burgundy:focus {
  color: #fff;
  background: #4a0912;
  border-color: #4a0912;
  box-shadow: 0 0.25rem 0.5rem rgba(0,0,0,0.15);
}

.btn-outline-burgundy {
  color: #33060d;
  background: transparent;
  border-color: #33060d;
  transition: all 0.3s ease;
}

.btn-outline-burgundy:hover, .btn-outline-burgundy:active, .btn-outline-burgundy:focus {
  color: #fff;
  background: #33060d;
  border-color: #33060d;
  box-shadow: 0 0.25rem 0.5rem rgba(0,0,0,0.15);
}

.card-header.angle {
  position: relative;
  clip-path: polygon(0 0, 100% 0, 100% 86%, 0 100%);
}

a {
  text-decoration: none;
}
.dashed {
  border-style: dashed;
}

/* Accordion Styles */

.accordion-item {
  border: none;
  border-bottom: 1px solid #ccc;
  border-radius: 0;
}

.accordion-item:last-of-type,
.accordion-button {
  border-radius: 0 !important;
}
.accordion-button {
  background-color: transparent;
  box-shadow: none;
  font-family: figtree, sans-serif;
  font-weight: 400;
  color: black;
}

.accordion-button:not(.collapsed) {
  color: #fff;
}

.accordion-button:focus {
  box-shadow: none;
}
/*
.accordion-button::after {
  filter: invert(35%) sepia(81%) saturate(2026%) hue-rotate(187deg) brightness(95%) contrast(101%);
}
*/
.accordion-button::after {
  filter: none !important;
  color: #dc3545 !important;
  /* For Bootstrap 5, the arrow is an SVG background-image, so override it: */
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='%23dc3545' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e") !important;
}

.accordion-button:focus {
  box-shadow: none; /* Removes default Bootstrap focus glow */
}

.accordion-button:not(.collapsed) {
  background: #33060d!important;
}
/* === Utility Styles :: END === */
@media (max-width: 1600px) {
  .navbar-light .navbar-nav .nav-link {
    font-size: 1rem;
  }
  .btn.btn-menu {
    font-size: 0.8rem !important;
  }
}
@media (max-width: 1400px) {
  .dutch-logo-desktop {
    position: absolute;
    width: 300px;
    height: 75px;
    top: -1.25rem;
    left: 0;
    margin-left: auto;
    right: 0;
    margin-right: auto;
    transition-duration: 0.25s;
  }
  .shrink-menu .dutch-logo-desktop {
    width: 185px;
    height: 40px;
    top: -1rem;
    transition-duration: 0.25s;
  }

  .navbar-light .navbar-nav .nav-link {
  color: #000 !important;
  font-family: "Sen", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 0.85rem;
}

}
@media (max-width: 1199px) {
  .jcha-menu-top-row .dutch-menu-top-col {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    transition-duration: 0.25s;
  }
  .shrink-menu .jcha-menu-top-row .dutch-menu-top-col {
    padding-top: 0.35rem;
    padding-bottom: 0.35rem;
    transition-duration: 0.25s;
  }
  .navbar-expand-xl .navbar-nav .dropdown-menu.main-dropdown {
    top: 4.2rem;
    background: #33060d;
    padding-top: 0.5rem;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
    padding-bottom: 0.5rem;
    border: 0;
    border-radius: 1rem;
    box-shadow: none;
    transition-duration: 0.25s;
  }
  .navbar-expand-xl .navbar-nav .dropdown-menu.sub-dropdown {
    background: #fff;
    padding: 0.5rem;
    border: 0;
    border-radius: 1rem;
    box-shadow: none;
  }
  .nav-fill .nav-item .dropdown-item {
  text-align: left !important;
  color: #ffffff;
}
  .navbar-nav {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: fit-content;
    transition-duration: 0.25s;
    width: auto;
  }
  .shrink-menu .navbar-nav {
    height: fit-content;
    transition-duration: 0.25s;
  }
  .navbar {
    display: flex;
    height: 80px;
    transition-duration: 0.25s;
  }
  .shrink-menu .navbar {
    height: 65px;
    transition-duration: 0.25s;
  }
  .menu-container .container-fluid .row .dutch-logo-place a.dutch-logo {
    position: absolute;
    background: url(../img/dutch-heating-logo.svg);
    background-size: cover;
    width: 280px;
         height: 104px;
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
    top: 1rem;
    transition-duration: 0.25s;
    z-index: 10;
  }

  .menu-container.shrink-menu .container-fluid .row .dutch-logo-place a.dutch-logo {
            background: url(../img/dutch-heating-logo.svg);
        background-size: cover;
        width: 153px;
        height: 54px;
        top: .4rem;
        transition-duration: 0.25s;
  }
  .nav-fill .nav-item,
  .nav-fill > .nav-link {
    flex: 1 1 auto;
    text-align: left;
  }
  .rotate-at-mobile {
    transform: rotate(90deg);
  }
  .navbar-light .navbar-nav .nav-link {
    font-size: 0.95rem;
  }
}

@media (max-width: 991px) {
  .navbar-light .navbar-nav .nav-link {
    font-size: 1.35rem;
  }
}

@media (max-width: 767px) {
  .menu-container .container-fluid .row .dutch-logo-place a.dutch-logo {
    position: absolute;
    background: url(../img/dutch-heating-logo.svg);
    background-size: cover;
            width: 210px;
        height: 78px;
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
    top: 1.25rem;
    transition-duration: 0.25s;
  }
  .menu-container.shrink-menu .container-fluid .row .dutch-logo-place a.dutch-logo {
    background-size: cover;
   width: 139px;
        height: 50px;
        top: .5rem;
    transition-duration: 0.25s;
  }
}

@media (max-width: 576px) {

  
}

@media (max-width: 450px) {
}

/* Offcanvas styling */
.offcanvas {
  background-color: #f5f5f7!important;
}


