::-webkit-scrollbar {
  width: 13px; }

::-webkit-scrollbar-track {
  background-color: darkgrey; }
::-webkit-scrollbar-thumb {
  background-color: dimgray; }

::-webkit-scrollbar-thumb:hover {
  background-color: darkslategray; }

html, body {
    height: 100%;
    margin: 0;
    padding: 0;
    background-color: white;
    overflow-x: hidden; /* <== Ensures sticky isn't broken by side-scroll */
}
.m0 {
	margin: 0px;
}
#blog-container-grid, .flex1 {
    flex: 1; /* This allows it to take remaining space and push footer down */
}
.noHead {
	 height: 100px !important;
	 
 }
.page {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at center, hsl(240,63.5%,26.86%, .9) 0%, hsl(240,63.5%,26.86%, .9) 100%);
  pointer-events: none;
  z-index: 999;
  clip-path: circle(0% at center);
  transition: clip-path 0.05s ease-out;
  opacity: .11; /* Optional: adjust if you want a semi-transparent overlay */
}

.page.active {
  clip-path: circle(150% at center);
}

footer {
	/*background-color: hsl(240,63.5%,26.86%);*/
}
h1 {
	font-weight: unset !important;
}
.title {
	font-size: 36px;
	margin-top: 0px;
	margin-bottom: 30px;
}
.dropdown {
	position: relative;
    display: inline-block;
}

.dropbtn {
    background-color: transparent;
    color: white;
    font-size: 16px;
    border: none;
    cursor: pointer;
    width: 72px;
}

.dropdown-content {
    display: none;
    position: absolute;
    left: -120px;
    background-color: hsl(240,63.5%,26.86%, .9);
    opacity: 0.97;
    min-width: 269px;
    padding: 10px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.2);
    z-index: 9999;
    border-radius: 4px;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: 5px;
    text-align: center;
}

.dropdown-content a {
    color: white;
    padding: 8px;
    text-decoration: none;
    display: block;
    border-radius: 4px;
}

.dropdown-content a:hover {
    background-color: rgba(255, 255, 255, 0.1);
}

.dropdown:hover .dropdown-content {
    display: grid;
    animation: fadeIn 0.3s ease-in-out;
}
.underline {
  display: inline-block;
  position: relative;
}

.underline::after {
  content: '';
  position: absolute;
  width: 100%;
  transform: scaleX(0);
  height: 2px;
  bottom: 0;
  left: 0;
  background-color: currentColor;
  transform-origin: bottom right;
  transition: transform 0.3s ease-out;
}

.underline:hover::after {
  transform: scaleX(1);
  transform-origin: bottom left;
}


@keyframes fadeIn {
    from { opacity: 0; transform: translateY(-5px); }
    to { opacity: 0.85; transform: translateY(0); }
}
.row {
	display: flex;
	flex-direction: row;
}
.col {
	display: flex;
	flex-direction: column;
}
.row-reverse {
	display: flex;
	flex-direction: row-reverse;
	margin-top: 50px;
}
.reverse_row {
	display: flex;
	flex-direction: row-reverse;
}
.head {
	position: relative;
	width: 100%;
	height: 500px;
	background-color: hsl(240,63.5%,26.86%);
    z-index: 0;
    margin-top: -100px;
}
.blog {
	height: 100px;
}
.home {
    background-image: url('/.img/banner_home.png');
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    transition: background-size 0.3s ease;
}
.home > * {
	position: relative;
	z-index: 1;
}
.ht {
	width: 674px !important;
	margin-bottom: 0px !important;
}
.review {
	background-image: url('/.img/banner_review.png') !important;
	background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    transition: background-size 0.3s ease;
}
.review > * {
	position: relative;
	z-index: 1;
}
.service-title {
	margin:auto;
	min-width: 448px;
	font-size: 33px;
	text-align: center;
}
div.service-title h1 {
	font-size: unset !important;
}
.service-value {
	margin:auto;
	max-width: 900px;
	font-size: 17px;
}
.service-space {
	width: 100%;
}
.service-space-inner {
	width: 33%;
}
.nav {
    height: 100px;
    width: 100%;
    position: sticky;
    top: 0;
    z-index: 99999;
    background-color: transparent;
    transition: background-color 0.3s;
}

#serviceHeading {
	margin-bottom: 33px;
}
.head-content {
	height: 400px;
	width: 100%;
}
.site-title {
	margin-top: 2%;
}
.nolink {
	text-decoration: none;
}
.font {
	font-family: 'Roboto', sans-serif;
	color: white;
}
.begin-navspace {
	width: 27%;
}
.smallnavspace {
	width: 27px;
}
.navspace {
	width: 100%;
}
.end-navspace {
	width: 17%;
}
.pre-phone {
	margin-right: 8px;
}
#title {
	display: block;
	width: 397px;
	font-size: 27px;
	justify-content: center;
	align-items: center;
}
#home {
	display: block;
	font-size: 17px;
	justify-content: center;
	align-items: center;
}
#phone {
	display: block;
	font-size: 17px;
	justify-content: center;
	align-items: center;
}
#services {
	display: block;
	font-size: 17px;
	justify-content: center;
	align-items: center;
}
#story {
	display: block;
	font-size: 17px;
	justify-content: center;
	align-items: center;
}
#staff {
	display: block;
	font-size: 17px;
	justify-content: center;
	align-items: center;
}
#reviews {
	display: block;
	font-size: 17px;
	justify-content: center;
	align-items: center;
}
#blog {
	display: block;
	font-size: 17px;
	justify-content: center;
	align-items: center;
}
#work {
	display: block;
	font-size: 17px;
	justify-content: center;
	align-items: center;
}
#contact {
	display: block;
	font-size: 17px;
	justify-content: center;
	align-items: center;
	background-color: transparent;
	border: none;
}
#contact-bottom {
	display: block;
	font-size: 17px;
	background-color: transparent;
	border: none;
	margin-left: -6px;
}
#contact-bottom:hover {
	cursor: pointer;
}
.logout {
	width: 54px;
}
#logout {
	display: block;
	font-size: 17px;
	justify-content: center;
	align-items: center;
}
.hamburger {
  display: none;
  cursor: pointer;
  font-size: 30px;
  padding: 10px;
  color: white;
  background: none;
  border: none;
}
.help-text {
	font-size: 23px;
    max-width: 622px;
    margin: auto;
    margin-top: 224px;
}
.help-text-bottom {
	font-size: 17px;
	margin-top: 0px;
	margin-bottom: 0px;
}
.help-btn {
	margin: auto;
	margin-top: 13px;
	height: 42px;
	cursor: pointer;
}
.center-text {
	text-align: center;
}
.wrap {
	white-space:pre-wrap;
}
.content {
	padding-top: 57px;
    overflow: visible;  /* <== Ensures sticky isn't broken by a parent */
}
.content-title {
	margin: auto;
	margin-top: 9px;
	color: black;
	font-size: 33px;
}
.carousel-container {
    position: relative;
    width: 88%;
    margin: auto;
    padding-top: 57px;
    overflow: visible;   /* <== Ensures sticky isn't broken by a parent */
}
.carousel-inner {
    overflow: hidden;
}
.carousel {
    display: flex;
    width: 100%;
    transition: transform 0.5s ease-in-out;
}
.carousel img {
    width: 100%;
    height: 700px;
    flex-shrink: 0;
    object-fit: contain;
}
.dots {
    text-align: center;
    padding: 10px;
}
.dot {
    height: 17px;
    width: 17px;
    margin: 15px;
    background-color: hsl(240,63.5%,26.86%, .33);
    display: inline-block;
    border-radius: 50%;
    border: solid 1px hsl(240,63.5%,26.86%);
    cursor: pointer;
}
.active { background-color: hsl(240,63.5%,26.86%, .89); }
.purp {
	color: hsl(240,63.5%,26.86%);
}
.black {
	color: black;
}
.best-text {
	font-size: 33px;
	padding-top: 13px;
}
.best-row {
	margin-left: 10%;
	margin-right: 10%;
	font-size: 22px;
	text-align: center;
}
.best-col {
	width: 400px;
	margin: auto;
}
.best-img {
	margin: auto;
	height: 130px;
	width: 130px;
}
.foot {
	padding-top: 22px;
	padding-bottom: 22px;
	background-color: hsl(240,63.5%,26.86%);
}
.footNotop {
	margin-top: unset !important;
}
.logo-container {
	margin: auto;
}
.logo {
	width: 300px;
}
.footspace {
	width: 100%;
}
.footspace-inner {
	width: 220%;
}
.hours {
	font-size: 17px !important;
}
.hours-title {
	width: 274px;
	font-size: 10px;
}
.explore-title {
	font-size: 10px;
}
.explore-links {
	width: 76px;
	font-size: 17px;
}
.social-title {
	width: 137px;
	font-size: 10px;
}
.insta {
	height: 22px;
}
.facebook {
	height: 22px;
}
.yelp {
	height: 22px;
}
.social-space {
	width: 20px
}
.contractor-info {
	font-size: 17px;
	text-align: left;
}
.review-link {
	margin: auto;
	margin-top: 20px;
	margin-bottom: 20px;
	padding: 3px;
	font-size: 33px;
	/*border: solid 1px;*/
	border-radius: 9px;
	background-color: white;
}
.review-link:hover {
	background-color: lightgray;
}
.review-container-title {
	font-size: 27px;
	margin: auto;
}
.review-container-reviews {
	padding: 9px;
}
#r-grid {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    grid-template-rows: auto auto;
    gap: 40px 32px; /* (row-gap column-gap) adjust for aesthetics */
    max-width: 1300px;
    margin: auto;
    align-items: end; /* THIS is the key: aligns all items to row bottom */
    justify-items: center;
}
#r-flex {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 10px;
}

.review-inner {
    border: 1px solid #ccc;
    padding: 10px;
    border-radius: 5px;
    background: #f9f9f9;
    /* Remove height: 100% or flex, if present */
}


/* Use these classes for exact cell positions */
.rg-top-left   { 
	grid-column: 1; 
	grid-row: 1; 
	align-self: end; 
	width: 375px;
}
.rg-center-img { 
grid-column: 2; 
grid-row: 1; 
display: flex; 
flex-direction: column; 
align-items: center; 
justify-content: center; 
width: 375px;
}
.rg-top-right  { 
grid-column: 3; 
grid-row: 1; 
align-self: end; 
width: 375px;
}
.rg-bottom-1   { 
grid-column: 1; 
grid-row: 2; 
width: 375px;
align-self: start; 
}
.rg-bottom-2   { 
grid-column: 2; 
grid-row: 2; 
width: 375px;
align-self: start; 
}
.rg-bottom-3   { 
grid-column: 3; 
grid-row: 2; 
width: 375px;
align-self: start; 
}

.review-flex {
	width: 423px;
}

.review-text {
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    margin: 5px;
}
.read-more-btn {
    background: none;
    border: none;
    cursor: pointer;
}
.review-end {
	margin-left: 5px;
}
.service-grid {
    margin: auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    max-width: fit-content;
    gap: 40px;
}

.service-content {
	margin-top: 30px;
}
.service-draincleaning {
	margin: auto;
	margin-top: 5px;
	width: 400px;
}
.service-plumbing {
	margin: auto;
	margin-top: 5px;
	width: 400px;
}
.service-replumbing {
	margin: auto;
	margin-top: 5px;
	width: 400px;
}
.service-img {
	margin: auto;
	width: 400px;
}
.service-img:hover {
	cursor: pointer;
}
.service-content {
    display: flex;
    flex-wrap: wrap;
    padding: 20px;
}

.dropdown-service {
	margin-top: 13px;
    margin-bottom: 15px;
}

.dropdown-content-service {
    max-height: 0;
    overflow: hidden;
    background: #fafafa;
    transition: max-height 0.4s ease, padding 0.4s ease, border 0.4s ease;
    padding: 0 15px;
    color: hsl(240,63.5%,26.86%);
    margin-bottom: 10px;
    border-radius: 0 0 5px 5px;
    border: none;
}

.dropdown-content-service.open {
    padding: 15px;
    border: 1px solid #ddd;
}

.dropdown-header-service-center,
.dropdown-header-service-left {
    display: flex;
    align-items: center;
    cursor: pointer;
    font-size: 21px;
    padding: 15px;
    width: 370px;
    height: fit-content;
    border-radius: 15px;
    background: white !important;
    color: hsl(240,63.5%,26.86%);
    transition: background 0.3s, margin-left 0.3s ease;
    margin-left: unset;
    margin: auto;
    margin-bottom: 9px;
}
div#drop2.dropdown-header-service-center,
div#drop2.dropdown-header-service-left {
	justify-content: center;
}
.dropdown-header-service-left:hover,
.dropdown-header-service-center:hover {
    background: #e2e2e2 !important;
}

.service-ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.service-li {
    padding: 10px 0;
    list-style-type: disc !important;
    list-style-position: inside;
}

.service-li:last-child {
}

.s_space2 {
	width: 40px;
}
/* Modal Background */
.modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 1000;
}
.modal-content {
	max-width: 700px;
    background-color: white;
    border: solid 1px;
    padding: 20px;
    border-radius: 10px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    text-align: left;
    position: relative;
}
.close-button {
    position: absolute;
    top: 10px;
    right: 10px;
    border: none;
    background: transparent;
    padding: 5px 10px;
    cursor: pointer;
}
.contact-title {
	font-size: 37px;
}
.labels {
	padding-right: 13px;
}
.form-control {
	padding: 3px;
	background-color: white;
	border: 1px  solid hsl(240,63.5%,26.86%);
}
.form-control:-webkit-autofill  {
	transition: background-color 5000s ease-in-out 0s;
}
.form-group {
	padding-top: 5px;
}
.form-msg {
	height: 130px;
}
.form-name {
	width: 300px;
	margin-left: 18px;
}
.form-email {
	width: 300px;
	margin-left: 21px;
}
.form-number {
	width: 300px;
	margin-left: 15px;
}
.form-address1 {
	width: 300px;
	margin-left: 6px;
}
.form-address2 {
	width: 300px;
	margin-left: 6px;
}
.form-city {
	width: 300px;
	margin-left: 36px;
}
.form-zip {
	width: 300px;
}
.submit-button {
	margin-top: 3px;
}
.gcap {
	margin-top: 9px;
}
#contact:hover {
	cursor: pointer;
}
.link-left {
	margin-left: 6px;
}
#hname {
	margin-left: 2px;
}
#hemail {
	margin-left: 5px;
}
.hire-button {
	width: fit-content;
	padding: 13px;
	margin-right: 232px;
	cursor: pointer;
	background: transparent;
	border: none;
	font-size: 37px;
}
.contact-body {
	font-size: 17px;
}
.login {
	background-color: silver;
	width: fit-content;
	padding: 33px;
	border-radius: 3px;
	margin: auto;
	margin-top: 150px;
}
.login-title {
	text-align: center;
}
.admin-panel {
	background-color: white;
	margin: auto;
	padding: 42px;
	border-radius: 3px;
}
.admin-container {
	background-color: white;
}
#lu, #lp, #username, #password {
    margin-bottom: 4px;
}
#password {
	margin-left: 2px;
}
.blog-grid {
	margin: auto;
	margin-top: 37px;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 37px;
	max-width: fit-content;	
}
.blog-grid-preview {
	margin: auto;
	margin-top: 37px;
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	gap: 37px;
	max-width: fit-content;	
}
.blog-post {
	max-width: 316px;
}
.blog-img {
	margin: auto;
	margin-top: 0px;
	margin-bottom: 0px;
	height: 200px;
	width: 200px;
}
.blog-date {
	margin: auto;
	margin-top: 3px;
	margin-bottom: 0px;
}
.blog-date-inner {
	margin-top: inherit;
	margin-bottom: inherit;
}
.blog-title {
	margin: auto;
	margin-top: 0px;
	margin-bottom: 0px;
	text-align: center;
}
.blog-title-inner {
	margin-top: inherit;
	margin-bottom: inherit;
	font-size: 18px;
}
.blog-hook {
	margin: auto;
        margin-top: 0px;
        margin-bottom: 0px;
}
.blog-hook-inner {
        margin-top: inherit;
        margin-bottom: inherit;
        font-size: 13px;
}
.blog-more {
	margin-top: 3px;
}
.blog-more-button {
	background-color: transparent;
	border: none;
}
.blog-more-button:hover {
	cursor: pointer;
}

.bmodal {
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    max-height: 100vh;
    overflow-y: auto; 
    overflow-x: hidden; 
}
.bmodal-content {
	margin: auto;
    background-color: white;
    text-align: center;
    overflow: auto;
    height: 100%;
    width: 100%;
}
.bclose {
    float: right;
    font-size: 24px;
    cursor: pointer;
    margin-right: 50px;
}
#bmodal-text {
  word-wrap: break-word;
  white-space: normal;
  overflow-wrap: break-word;
  overflow: visible;
  text-align: left;
  margin: auto;
  width: 90%;
}
.bhead {
	background-color: white !important;
}
.bfoot {
	background-color: white !important;
	margin-top: unset !important;
}
input#bdate {
	margin-left: 161px;
}
input#btitle {
	margin-left: 163px;
}
input#cover {
	margin-left: 6px;
}
textarea#bhook {
	width: 404px; 
	height: 178px;
}
textarea#btext {
	height: 556px;
}
.bgap {
	margin-top: 6px;
}
 .password {
	 margin-right: 6px;
 }
 .toggle-icon {
	 margin-right: 6px;
 }
 .Slide:hover {
	 cursor: pointer;
 }
 .contact-img {
    height: 252px;
    margin-left: 77px;
    border-radius: 15px;
    box-shadow: rgba(0, 0, 0, 0.25) 0px 54px 55px, rgba(0, 0, 0, 0.12) 0px -12px 30px, rgba(0, 0, 0, 0.12) 0px 4px 6px, rgba(0, 0, 0, 0.17) 0px 12px 13px, rgba(0, 0, 0, 0.09) 0px -3px 5px;
}
.hire-img {
    margin-top: 23px;
    height: 388px;
    margin-right: 1px;
    border-radius: 15px;
    box-shadow: rgba(0, 0, 0, 0.25) 0px 54px 55px, rgba(0, 0, 0, 0.12) 0px -12px 30px, rgba(0, 0, 0, 0.12) 0px 4px 6px, rgba(0, 0, 0, 0.17) 0px 12px 13px, rgba(0, 0, 0, 0.09) 0px -3px 5px;
}
 button#nextBtn {
	margin-left: 33%;
	background: none;
	border: none;
	height: 75px;
	width: 150px;
	font-size: 33px;	
 }
 button#prevBtn {
	margin-right: 33%;
	background: none;
	border: none;
	height: 75px;
	width: 150px;
	font-size: 33px;	
 }
 
 button#nextBtn:hover, button#prevBtn:hover {
	 cursor: pointer;
 }
 
 button#nextBtn:disabled, button#prevBtn:disabled {
	 opacity: .66;
	 cursor: not-allowed;
 }
 
 .blog_id {
	 font-size: 33px;
	 margin-top: 42px;
 }
 
 .story-text {
	 padding: 27px;
	 font-size: 17px;
 }
 
 
 .faq-container {
	 /*background-color: hsl(240,63.5%,26.86%);*/
	 height: fit-content;
	 width: 100%;
	 margin-top: 65px;
 }
 
 .faq-block {
    width: 90%;
    margin: 0 auto;
  }
   .faq-top {
	   margin-top: 10px;
   }
   .faq-item {
    margin-bottom: 10px;
    border: 1px solid #ddd;
    border-radius: 5px;
    overflow: hidden;
  }

  .faq-question {
    width: 100%;
    padding: 15px;
    text-align: left;
    font-size: 17px;
    font-weight: bold;
    background: white !important;
    border: none;
    cursor: pointer;
    outline: none;
    color: hsl(240,63.5%,26.86%);
    transition: background 0.3s;
  }

  .faq-question:hover {
    background: #e2e2e2;
  }

  .faq-answer {
    max-height: 0;
    overflow: hidden;
    background: #fafafa;
    transition: max-height 0.4s ease, padding 0.4s ease;
    padding: 0 15px;
    color: hsl(240,63.5%,26.86%);
  }

  .faq-answer.open {
    padding: 15px;
  }
 
 section {
	 margin: auto;
	 padding: 47px;
	 padding-top: 0px;
 }
 .sectionIMG {
	 width: 800px;
 }
 #sectionTextDivL {
	 width: 500px;
	 margin-right: 33px;
 }
 #sectionTextDivR {
	 width: 500px;
	 margin-left: 33px;
 }
 .sectionTextTitle {
	 text-align: left;
	 font-size: 33px;
 }
 .sectionText {
	 text-align: left;
	 font-size: 17px;
 }
 .box {
 border-radius: 15px;
 box-shadow: rgba(0, 0, 0, 0.25) 0px 54px 55px, rgba(0, 0, 0, 0.12) 0px -12px 30px, rgba(0, 0, 0, 0.12) 0px 4px 6px, rgba(0, 0, 0, 0.17) 0px 12px 13px, rgba(0, 0, 0, 0.09) 0px -3px 5px;
 }
 .hidden-section {
  opacity: 0;
  transform: translateY(50px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}
.visible-section {
  opacity: 1;
  transform: translateY(0);
}
 .staff-title {
	 width: 445px;
	 font-size: 33px;
 }
 .staff-value {
	 width: 222px;
	 margin-left: 107px;
	 margin-top: 33px;
 }
 
 #section-title {
	 padding: unset;
	 margin-bottom: 0px;
 }
 #office {
	 margin-top: 0px;
	 padding-top: 0px;
 }
 #service-section, #banner-overlay {
	 padding: unset;
 }
 .review-container-col {
	margin-top: 64px;
} 

.hide {
	display: none;
}
 .admin-title {
	 margin-left: 64px;
 }
 #admin-password {
	 padding: 9px;
	 padding-left: 0px;
 }
 
 #admin-content {
	 padding: 64px;
	 padding-top: 0px;
	 padding-bottom: 13px;
 }
 
 .page-break {
	 margin: auto;
	 max-width: 90vw;
	 height: 13%;
 }
 
 #draft-container {
	 padding: 9px;
	 padding-left: 0px;
 }
 
 .lg {
	 background-color: hsl(240,63.5%,26.86%);
 }
 
 
 
 
 
 
 
 

@media screen and (max-width: 825px) {
.row-reverse {
    display: none;
}
.dropdown-content {
    display: none;
    position: absolute; /* Positioned relative to the nearest non-static ancestor */
    top: -39px;
    left: -129px;
    background-color: hsl(240,63.5%,26.86%, .9);
    opacity: 100%;
    min-width: 130px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.2);
    z-index: 9999; /* High enough to be on top */
    border-radius: unset;
}
.dropdown-content a:hover {
	background-color: rgba(0, 0, 0, 0.9);
}
  .hamburger {
    display: block;
  }
.row-reverse.active {
    display: flex;
    flex-direction: column-reverse;
    background-color: hsl(240,63.5%,26.86%, .9);
    opacity: 85%;
    position: absolute;
    top: 53px;
    right: 0;
    width: 107px;
    z-index: 1000;
    text-align: center;
    padding-bottom: 15px;
}
.row-reverse.active .site-btn a {
    color: white;
    padding: 5px;
    text-decoration: none;
    font-size: 18px;
    display: block;
}
.row-reverse.active .site-btn a:hover {
	background-color: hsl(240,63.5%,26.86%, .9);
}
}
