/* **** FONT OPTIONS **** */
@import url("https://fonts.googleapis.com/css2?family=Open+Sans:wght@300;400;700&family=Raleway:wght@100;200;300;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Open Sans:wght@400;500;700&family=Righteous&display=swap");

html {
    overflow-x: hidden;
}
body {
    overflow-x: hidden;
}

h1,
h2,
.h2,
h3,
h4,
h5,
h6,
h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
    font-family: "Open Sans";
    font-weight: 700;
}
h2,
.h2 {
    margin-top: 0;
}
p,
ul,
ol {
    font-family: "Open Sans", sans-serif;
    font-size: 16px;
    font-weight: normal;
    line-height: 26px;
    color: #555;
}
p.lead {
    font-family: "Open Sans", sans-serif;
    font-weight: 500;
    font-size: 18px;
    color: #003150;
    font-style: italic;
}

/*
h1 {font-size: 64px;}
  @media (max-width: 1199px) {h1 {font-size: 28px;}}
h2 {font-size: 48px;}
  @media (max-width: 1199px) {h2 {font-size: 24px;}}
h3 {font-size: 36px;}
  @media (max-width: 1199px) {h3 {font-size: 20px;}}
h4 {font-size: 24px;}
  @media (max-width: 1199px) {h4 {font-size: 18px;}}
h5 {font-size: 20px;}
  @media (max-width: 1199px) {h5 {font-size: 16px;}}
h6 {font-size: 20px;}
  @media (max-width: 1199px) {h6 {font-size: 16px;}}
*/

/* 
    PRIMARY / blue:         #B1B6B6
    SECONDARY / bright-purple ##B1B6B6
    DARK GRAY:      #353739 
    MEDIUM GRAY:    #666666     (TEXT)
    font-family: 'Open Sans', sans-serif;
*/

h1 {
    font-size: 85px;
    color: #ffffff;
    text-transform: uppercase;
}
@media (max-width: 768px) {
    /* Adjust the breakpoint as needed for your mobile devices */
    h1 {
        font-size: 40px;
    }
}
h1 span.over {
    font-size: 30px;
    color: #ffffff;
    font-weight: 100;
    text-transform: uppercase;
}

h2,
.h2,
.h2-size {
    font-size: 55px;
    color: #212121;
    text-transform: uppercase;
}

/* Media query for mobile devices */
@media (max-width: 767px) {
    h2,
    .h2,
    .h2-size {
        font-size: 40px; /* Smaller font size for mobile */
    }
}

h2 span.over,
.h2 span.over {
    font-size: 35px;
    color: #212121;
    font-weight: 100;
    text-transform: uppercase;
    line-height: 100%;
    display: block;
}
h3 {
    font-size: 38px;
    font-weight: 900;
}
h3 span.over {
    font-size: 20px;
    color: #212121;
    font-weight: 100;
    text-transform: uppercase;
    line-height: 100%;
    display: block;
}
@media (max-width: 992px) {
    h3 {
        font-size: 30px; /* Smaller font size for mobile */
    }
}
h4 {
    font-size: 29px;
}
h4 span.over {
    font-size: 16px;
    font-weight: 100;
    text-transform: uppercase;
    display: block;
    color: #212121;
}
h4 span.under {
    font-size: 16px;
    font-weight: 100;
    text-transform: uppercase;
    padding-top: 3px;
    display: block;
    color: #212121;
}

/* LOCATION PAGES DO NOT DELETE */
.AWS-links h4 {
    font-size: 1.2em;
}
.locationAWS .AWS-links h4 a:hover {
    color: #fff;
}
/* LOCATION PAGES DO NOT DELETE */

p.pullout {
    font-size: 1.5em;
    font-style: italic;
    padding: 8px 0;
    margin: 20px 0;
    border-top: 2px solid #cccccc;
    border-bottom: 2px solid #cccccc;
}
p.small,
p.sm,
.text-small {
    font-size: 0.875em;
}
p.xs {
    font-size: 0.75em;
}

a {
    font-family: "Open Sans", sans-serif;
    color: #003150;
}
a:hover {
    color: #000;
}
.over {
    font-family: "Open Sans", sans-serif;
    color: #cccccc;
    text-transform: uppercase;
    display: block;
}

.decoration-primary,
.decoration-primary-h2 {
    display: block;
    width: 32px;
    height: 5px;
    margin-top: 24px;
    margin-bottom: 24px;
    background-color: #cccccc;
}
.decoration-primary-h3,
.decoration-purple-h3 {
    display: block;
    width: 50px;
    height: 2px;
    margin-top: 16px;
    margin-bottom: 16px;
    background-color: #cccccc;
}

.bg-primary {
    background: #003150;
}
.bg-secondary {
    background: #111;
}
.bg-cta {
    background: #003150;
}
.bg-warranty {
    background: #003150;
}
.bg-dark {
    background: #111;
}
.bg-gray,
.bg-grey {
    background: #616161;
}
.bg-black {
    background: #111;
}
.bg-white {
    background: #fff;
}
.bg-alt,
.section-light-border {
    background: #f3f3f3;
    border-top: 1px solid #ccc;
    border-bottom: 1px solid #ccc;
}
.bg-light-grey,
.bg-light-gray {
    background: #ccc;
}

.text-primary,
.text-red {
    color: #003150;
}
.text-secondary {
    color: #111;
}
.text-default,
.text-gray {
    color: #353739;
}
.text-black {
    color: #000;
}
.text-white {
    color: #fff;
}

/* By default, hide mobile text and show desktop text */
.btn .mobile-text {
    display: none;
}
.btn .desktop-text {
    display: inline;
}

/* Media query for screens up to 768px width (typical mobile screens) */
@media (max-width: 768px) {
    .btn .mobile-text {
        display: inline; /* Show mobile text */
    }
    .btn .desktop-text {
        display: none; /* Hide desktop text */
    }
}

.btn-primary {
    background: #003150;
    border: 1px solid #003150;
    color: #fff;
}
.btn-primary:hover {
    background: #222;
    border-color: #222;
    color: #fff;
}

.btn-secondary {
    background: #111;
    border: 1px solid #111;
    color: #fff;
}
.btn-secondary:hover {
    background: #003150;
    border-color: #003150;
    color: #fff;
}

.btn-white {
    background: #fff;
    border: 1px solid #fff;
    color: #003150;
}
.btn-white:hover {
    background: #003150;
    border-color: #fff;
    color: #fff;
}

.btn-dark {
    background: #222;
    border: 1px solid #222;
    color: #fff;
}
.btn-dark:hover {
    background: #003150;
    border-color: #003150;
    color: #222;
}

.btn-dark-open {
    border: 2px solid #222;
    color: #222;
}
.btn-dark-open:hover {
    background: #222;
    color: #fff;
}

.btn-primary-open {
    border: 2px solid #003150;
    color: #003150;
}
.btn-primary-open:hover {
    background: #003150;
    color: #fff;
}

.btn-white-open {
    border: 2px solid #fff;
    color: #fff;
}
.btn-white-open:hover {
    background: #003150;
    color: #fff;
}

.btn {
    font-size: 1em;
}
.btn-lg {
    font-size: 1.125em;
}
.btn-sm {
    font-size: 0.85em;
    margin-top: 8px;
    margin-bottom: 8px;
    padding: 4px 8px;
}

.btn,
.btn-lg {
    display: inline-block;
    border-radius: 0;
    padding: 1rem 2rem; /* rem for consistent spacing */
    font-weight: bold;
    text-transform: uppercase;
    margin: 2.5em 0;
    line-height: normal; /* Adjust line height as necessary */
    text-align: center; /* Ensure the text is aligned to the center */
}

/* Media Queries for Mobile */
@media (max-width: 768px) {
    .btn,
    .btn-lg,
    .btn-primary,
    .btn-white {
        font-size: 11px;
        padding: 8px 16px;
        margin: 1.5em 0;
    }
}

/* Media query for screens up to 768px width (typical mobile screens) */
@media (max-width: 768px) {
    .btn-primary,
    .btn-white,
    .btn-secondary,
    .btn-dark,
    .btn-lg,
    .btn-dark-open,
    .btn-primary-open,
    .btn-white-open {
    display: inline-block;
    border-radius: 0;
    padding: 1rem 2rem; /* rem for consistent spacing */
    font-weight: bold;
    text-transform: uppercase;
    margin: 2.5em 0;
    line-height: normal; /* Adjust line height as necessary */
    text-align: center; /* Ensure the text is aligned to the center */
    font-size: 14px;
    }
}

.inner {
    padding: 0 5%;
}

.text-block-white {
    background: #fff;
    padding: 15px 20px;
}
.text-block-white-90 {
    background: rgba(255, 255, 255, 0.9);
    padding: 15px 20px;
}
.text-block-white-70 {
    background: rgba(255, 255, 255, 0.7);
    padding: 15px 20px;
}
.text-block-white-50 {
    background: rgba(255, 255, 255, 0.5);
    padding: 15px 20px;
}

.text-block-lightgray {
    background: rgba(243, 243, 243, 1);
    padding: 15px 20px;
}
.text-block-lightgray-90 {
    background: rgba(243, 243, 243, 0.9);
    padding: 15px 20px;
}
.text-block-lightgray-70 {
    background: rgba(243, 243, 243, 0.7);
    padding: 15px 20px;
}
.text-block-lightgray-50 {
    background: rgba(243, 243, 243, 0.5);
    padding: 15px 20px;
}

.item-divider-md,
.item-divider {
    border-bottom: 1px dotted #ccc;
    margin: 20px 0;
}

.subpage-lead {
    width: 70%;
    font-size: 1.5em;
    font-style: italic;
    text-align: center;
    padding-top: 20px;
    padding-bottom: 20px;
    margin: auto;
}
@media (max-width: 767px) {
    .subpage-lead {
        width: 90%;
    }
}

.col-left-md {
    border-right: 1px solid #ccc;
    padding-right: 40px;
}
@media (max-width: 992px) {
    .col-left-md {
        border-right: none;
        padding-right: 0;
    }
}
.col-right-md {
    padding-left: 40px;
}
@media (max-width: 992px) {
    .col-right-md {
        padding-left: 0;
    }
}

/* Common Styling */

.clearfix::before,
.clearfix::after {
    content: " ";
    display: table;
}

.clearfix::after {
    clear: both;
}

.mytable {
    display: table;
    width: 100%;
    height: 100%;
}
.table-cell,
.table-cell-xs,
.table-cell-sm,
.table-cell-md,
.table-cell-lg,
.table-cell-xl {
    display: table-cell;
}
@media (max-width: 767px) {
    .table-cell-md,
    .table-cell-lg,
    .table-cell-xl {
        display: block;
        width: 100%;
    }
}
@media (max-width: 992px) {
    .table-cell-lg,
    .table-cell-xl {
        display: block;
        width: 100%;
    }
}
@media (max-width: 1200px) {
    .table-cell-xl {
        display: block;
        width: 100%;
    }
}

.va-top {
    vertical-align: top;
}
.va-middle {
    vertical-align: middle;
}
.va-bottom {
    vertical-align: bottom;
}

a {
    outline: none !important;
    transition: all 0.7s ease-out;
    font-weight: bold;
}
a,
a:hover,
a:link,
a:visited,
a:focus {
    text-decoration: none;
}

a:focus {
    color: #003150;
}

.fill {
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

/* UTILITIES */
.overflow-hidden {
    overflow: hidden;
}
.float-left {
    float: left;
}

/* Specific Styling */

/* ### Topbar Section ### */
.topbar {
    background: #cccccc;
    padding-top: 10px;
    padding-bottom: 10px;
}
.topbar p {
    color: #fff;
    font-size: 1em;
    margin: 4px 0 0 0;
    padding: 0;
}
.topbar a {
    color: #fff;
    font-size: 1em;
    text-transform: uppercase;
    text-decoration: underline;
    font-weight: bold;
}

/* ### HERO ### */
.hero-spacer {
    height: 1px;
    margin-top: 200px;
}
@media only screen and (max-width: 480px) {
    .hero-spacer {
        height: 1px;
        margin-top: 40px;
    }
}

.hero {
    background: url("../images/sarasota-florida-fence-company-hero.jpg")
        no-repeat left center;
    background-size: cover;
    background-position: bottom left;
    position: relative;
    z-index: 1;
}

.hero h1 {
    color: #003150;
    /*text-shadow: #000 1px 1px 5px;*/
    font-size: 180px;
    font-weight: 800;
    padding: 0;
    margin: 0;
    text-transform: uppercase;
    text-align: center;
}
.hero h2 {
    /*text-shadow: #000 1px 1px 5px;*/
    color: #003150;
    font-family: "Open Sans", serif;
    font-size: 40px;
    font-weight: 800;
    padding: 0;
    margin: 0;
    text-transform: uppercase;
    text-align: center;
    text-shadow: #000 1px 1px 5px;
}
.hero h1 {
    display: block;
    color: #fff;
    font-size: 80px;
    text-transform: capitalize;
    font-weight: 800;
    padding: 0;
    margin: 0;
    text-align: center;
    text-shadow: #000 1px 1px 5px;
    margin-bottom: 20px;
}
.hero p.lead {
    font-family: "Open Sans", serif;
    text-shadow: #000 1px 1px 5px;
    font-size: 32px;
    color: #fff;
    font-style: italic;
}

@media only screen and (max-width: 480px) {
    .hero h1 {
        font-size: 42px;
        font-weight: 800;
        padding: 0;
    }
    .hero h2 {
        font-size: 20px !important;
        font-weight: 800;
        padding: 0;
        margin-top: 40px;
    }
    .hero p {
        font-size: 24px;
    }
}

/* .hr {
    background: url("../images/hr.png") repeat-x;
    background-position:bottom left;
    height:11px;
  }  
  .hr-top {
    background: url("../images/hr-top.png") repeat-x;
    background-position:bottom left;
    height:10px;
  }  
  .hr-bottom {
    background: url("../images/hr-bottom.png") repeat-x;
    background-position:bottom left;
    height:10px;
  }   */

/* Testimonials */
.testimonial-wrapper {
    margin: 10px 0 60px 0;
    padding: 32px 20px 16px;
    background-color: #fff;
    border-radius: 0px;
    border: 3px solid #fff;
    box-shadow: 0 0 40px rgba(0, 0, 0, 0.22);
    text-align: center;
    color: #232323;
}

@media (min-width: 767px) {
    .testimonial-wrapper {
        min-height: 500px;
    }
}

.testimonials-titlebox {
    margin: 10px 0 60px 0;
    padding: 32px 20px 16px;
    background-color: #003150;
    border-radius: 0px;
    border: 3px solid #003150;
    box-shadow: 0 0 40px rgba(0, 0, 0, 0.22);
    text-align: center;
}

.testimonial-photo {
    margin-right: 12px;
}
.testimonial-wrapper h4 {
    margin-bottom: 20px;
}
.testimonial-stars {
    display: block;
    margin: auto;
    margin-bottom: 20px;
    width: 100px;
}
.testimonial-disclaimer {
    margin-top: 40px;
    font-size: 0.85em;
    color: #aaa;
    text-align: center;
}

/* ### BENEFIT LIST ### */
.benefit-list img {
    float: left;
    margin-right: 20px;
    margin-bottom: 30px;
}
.benefit-list h3 {
    font-size: 2em;
    margin: 0 0 5px 0;
}
.benefit-list p {
    font-size: 1em;
    margin-right: 20px;
}
.benefit-list p.last {
    margin-right: 0;
}

/* ### Logo Navigation Section ### */
.logo-navigation .navigation {
    text-align: right;
    margin-left: -15px;
    margin-right: -15px;
}
.logo-navigation .navigation ul {
    margin-bottom: 0;
    display: inline-block;
    vertical-align: middle;
}
.logo-navigation .navigation ul li {
    display: block;
    float: left;
    padding: 15px;
    position: relative;
}
.logo-navigation .navigation ul li a {
    display: block;
    transition: all 0.7s ease-out;
}
.navigation ul.cta li {
    text-align: center;
}
.navigation ul.cta li a {
    padding: 5px 7px;
}

.logo-navigation .navigation ul li ul {
    position: absolute;
    z-index: 2;
    top: calc(100% + 5px);
    left: 0;
    min-width: 220px;
    white-space: nowrap;
    text-align: left;
    opacity: 0;
    visibility: hidden;

    transition: all 0.7s ease-out;
}
.logo-navigation .navigation ul li:hover ul {
    opacity: 1;
    visibility: visible;
}
.logo-navigation .navigation ul li ul li {
    display: block;
    float: none;
    padding: 0;
}
.logo-navigation .navigation ul li ul li a {
    padding: 10px 15px;
    display: block;
}
.logo-navigation .navigation ul li ul li:last-child a {
    border-bottom: 0;
}

/* ### Banner Section ### */
.banner {
    background-size: cover;
    background-repeat: no-repeat;
    position: relative;
}
.banner-filter {
    height: 100%;
    width: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    padding: 70px;
}
/* Media query for mobile devices */
@media (max-width: 768px) {
    .banner-filter {
        padding: 0px;
    }
}

.banner h1 {
    color: #fff;
    font-size: 64px;
    font-weight: 800;
    padding: 0;
    margin: 60px 0 10px 0;
}
@media (max-width: 768px) {
    /* Adjust the breakpoint as needed for your mobile devices */
    .banner h1 {
        font-size: 40px;
    }
}

.banner p {
    font-size: 18px;
    color: rgba(255, 255, 255, 1);
    font-style: italic;
    margin-bottom: 50px;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5); /* Adding text shadow */
}
/* By default, hide mobile text and show desktop text */
.banner p .mobile-text {
    display: none;
}
.banner p .desktop-text {
    display: inline;
}

/* Media query for screens up to 768px width (typical mobile screens) */
@media (max-width: 768px) {
    .banner p .mobile-text {
        display: inline; /* Show mobile text */
    }
    .banner p .desktop-text {
        display: none; /* Hide desktop text */
    }
}

/* Default styles for .banner h1 and .banner p */
.banner h1,
.banner p {
    max-width: 60%;
}

/* Media query with a unique class selector */
@media (max-width: 767px) {
    .banner h1,
    .banner p {
        max-width: 100%;
        padding: 20px;
    }
}

div.icon-list {
    margin-top: 15px;
}
.icon-list img {
    width: 35px;
    float: left;
    margin-top: 15px;
    padding-right: 5px;
}
.icon-list h3 {
    margin-left: 42px;
    margin-bottom: 5px;
    margin-top: 0;
}
.icon-list p {
    margin-left: 42px;
    margin-top: 0;
}

/* h3 span {
  font-size:.7em;
  color:#ccc;
} */
/* h4 span {
  font-family: 'Open Sans', serif;
  font-size:.5em;
  color:#ccc;
} */

.featupurple-list-1 {
    list-style-type: none;
}
.featupurple-list-1 li {
    background-image: URL(../images/bullet-01.png);
    background-repeat: no-repeat;
    background-position: 0 16px;
    padding-left: 50px;
}
.featupurple-list-1 h4 {
    margin: 0;
    padding-top: 12px;
}
.featupurple-list-1 li {
    border-top: 1px dotted #ccc;
}
.featupurple-list-1 li:first-of-type {
    border-top: none;
}

.cta-primary {
    background: #003150;
    color: #fff !important;
    padding: 12px 0;
}
.cta-primary a {
    display: block;
}

.cta-primary h3,
.cta-primary h4,
.cta-primary h5,
.cta-primary a {
    color: #fff !important;
}
.cta-primary a:hover div {
    background: #333;
}

.subnav {
    margin-top: 20px;
    margin-bottom: 20px;
}
@media (max-width: 767px) {
    .subnav {
        margin-bottom: 40px;
        width: 100%;
    }
}

.subnav-header {
    display: block;
    width: 100%;
    padding: 4px 12px;
    margin-bottom: 6px;
    background: #cccccc;
    color: #464646;
    font-weight: 600;
    font-size: 1em;
}
.subnav a {
    display: block;
    width: 100%;
    padding: 8px 12px;
    margin-bottom: 2px;
    background: #cccccc;
    color: #fff;
    font-weight: 600;
    font-size: 1.2em;
}
.subnav a:hover {
    background: #464646;
    color: #fff;
}
.subnav a.active {
    background: #63a33c;
    color: #fff;
}

.funfact {
    display: block;
    margin: auto;
    margin-top: 40px;
    margin-bottom: 40px;
    padding: 20px 10%;
    background: #f3f3f3;
    border-top: 1px solid #ccc;
    border-bottom: 1px solid #ccc;
}
.fftitle {
    display: inline-block;
    font-style: italic;
    font-size: 0.85em;
    color: #fff;
    background: #cccccc;
    padding: 2px 6px;
}
.funfact p {
    font-style: italic;
    font-size: 1.5em;
}
.ffcitation {
    color: #666666;
}
.tbl-finance {
    width: 100%;
    margin: 40px 0;
    text-align: center;
    font-size: 1.2em;
    font-family: "Open Sans", sans-serif;
    color: #666666;
}
.tbl-finance th {
    vertical-align: bottom;
    text-align: center;
    border: 3px solid #f3f3f3;
    background: #fff;
    padding-top: 15px;
}
.tbl-finance td {
    padding: 12px 0;
    border: 3px solid #f3f3f3;
    background: #fff;
}
.tag {
    background: #353739;
    padding: 3px 6px;
    font-size: 0.6em;
    color: #fff;
    display: inline-block;
}
.title-tag {
    background: #434343;
    padding: 3px 10px;
    font-size: 0.7em;
    color: #fff;
    display: inline-block;
    margin-bottom: 6px;
    margin-top: 20px;
}
.testimonial-box {
    margin: 20px 10px;
    padding: 20px 30px;
    border: 1px solid #e0e0e0;
    border-radius: 40px 0;
    background: #fff;
}
.testimonial-box h4 {
    margin-left: 60px;
    margin-right: 10px;
}
.testimonial-box p {
    margin-left: 60px;
    margin-right: 10px;
    margin-top: 8px;
    font-size: 1em;
    font-style: italic;
    line-height: 1em;
}
.testimonial-icon {
    float: left;
}
.testimonials-stars {
    margin-left: 14px;
}
.byline {
    font-weight: bold;
    color: #333;
    font-style: normal;
}
.benefit-grid {
    border: 1px solid #ccc;
    padding: 10px 10px;
    width: 50%;
    float: left;
    height: 180px;
}
.breakout {
    padding: 20px 20px;
}
.breakout h4 {
    height: 2em;
}
.breakout p {
    font-size: 0.9em;
    height: 3em;
}
.headline {
    font-size: 50px;
    color: #212121;
    text-transform: uppercase;
    font-family: "Open Sans", cursive;
    font-weight: 700;
    margin-top: 20px;
    margin-bottom: 10px;
    line-height: 1.1;
}
.headline span.over {
    font-size: 25px;
    color: #212121;
    font-weight: 100;
    text-transform: uppercase;
    line-height: 100%;
    display: block;
}

/* ### Breakouts Section ### */

.breakouts .each-bo {
    position: relative;
}
.breakouts .each-bo:after {
    background-color: rgba(0, 0, 0, 0.5);
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    content: "";
    z-index: 1;
}
.breakouts .each-bo .eb-image {
    overflow: hidden;
}
.breakouts .each-bo .eb-image img,
.breakouts .each-bo .eb-content,
.breakouts .each-bo .eb-content > div {
    transition: all 0.5s ease-out;
}
.breakouts .each-bo:hover .eb-image img {
    transform: scale(1.1);
}
.breakouts.breakouts-version-one .each-bo:hover .eb-content {
    padding-top: 35px;
}
.breakouts.breakouts-version-one .each-bo:hover .eb-content > div {
    transform: translateY(-20px);
}
.breakouts .each-bo .eb-content {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2;
}
.breakouts .each-bo .eb-content > div {
    padding: 15px;
}
.breakouts.breakouts-version-one .each-bo .eb-content {
    background-color: rgba(0, 0, 0, 0.5);
}
.breakouts.breakouts-version-two .each-bo .eb-content {
    top: 0;
}
.breakouts.breakouts-version-two .each-bo .eb-content > div {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    transform: translate(-50%, -50%);
    text-align: center;
}
.breakouts .each-bo .eb-content h3 {
    margin: 0;
}
.breakouts .each-bo .eb-content p {
    margin-bottom: 0;
    margin-top: 10px;
}
.topbar-link {
    font-size: 1.3em;
}
.footer-links {
    display: block;
    font-size: 1.2em;
    border-bottom: 1px dotted rgba(255, 255, 255, 0.3);
    padding: 5px 0;
}
.footer-links i {
    margin-right: 8px;
}
.footer-links a {
    font-weight: normal;
    color: rgba(255, 255, 255, 1);
}
.footer-links a:hover {
    color: #003150;
}

.footer-link-2 a {
    color: #fff !important;
}

.footer-link-2 a:hover {
    color: #aaa !important;
}
.social-link {
    font-size: 16px;
    height: 28px;
    width: 28px;
    text-align: center;
    padding: 6px;
    border-radius: 50%;
    background: #fff;
    color: #222;
    margin-right: 6px;
    margin-left: 6px;
    transition: all 0.7s ease-out;
}
.social-link:hover {
    background: #fff;
    transition: all 0.7s ease-out;
}

/* ***************************** */
/* FORMS */
.form-fields {
    display: block;
    width: 100%;
    padding: 6px 12px;
    font-size: 18px;
    line-height: 1.42857143;
    color: #555;
    background-color: #fff;
    background-image: none;
    border: 1px solid #ccc;
    border-radius: 0;
    margin-bottom: 20px;
    -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
    -webkit-transition: border-color ease-in-out 0.15s,
        -webkit-box-shadow ease-in-out 0.15s;
    -o-transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s;
    transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s;
}
.btn-form {
    width: 100%;
    text-align: center;
}
.form-fields:focus {
    border-color: #66afe9;
    outline: 0;
    -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075),
        0 0 8px rgba(102, 175, 233, 0.6);
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075),
        0 0 8px rgba(102, 175, 233, 0.6);
}
.form-fields::-moz-placeholder {
    color: #999;
    opacity: 1;
}
.form-fields:-ms-input-placeholder {
    color: #999;
}
.form-fields::-webkit-input-placeholder {
    color: #999;
}
.form-fields[disabled],
.form-fields[readonly],
fieldset[disabled] .form-fields {
    background-color: #eee;
    opacity: 1;
}
.form-fields[disabled],
fieldset[disabled] .form-fields {
    cursor: not-allowed;
}
textarea.form-fields {
    height: auto;
}
input[type="search"] {
    -webkit-appearance: none; /* For older versions of Chrome, Safari, etc. */
    appearance: none; /* Standard syntax */
}

@media screen and (-webkit-min-device-pixel-ratio: 0) {
    input[type="date"],
    input[type="time"],
    input[type="datetime-local"],
    input[type="month"] {
        line-height: 34px;
    }
    input[type="date"].input-sm,
    input[type="time"].input-sm,
    input[type="datetime-local"].input-sm,
    input[type="month"].input-sm,
    .input-group-sm input[type="date"],
    .input-group-sm input[type="time"],
    .input-group-sm input[type="datetime-local"],
    .input-group-sm input[type="month"] {
        line-height: 30px;
    }
    input[type="date"].input-lg,
    input[type="time"].input-lg,
    input[type="datetime-local"].input-lg,
    input[type="month"].input-lg,
    .input-group-lg input[type="date"],
    .input-group-lg input[type="time"],
    .input-group-lg input[type="datetime-local"],
    .input-group-lg input[type="month"] {
        line-height: 46px;
    }
}
.form-fields {
    box-shadow: inset 0px 1px 3px 0px rgba(0, 0, 0, 0.055);
}

.form-fields[type="button"],
.form-fields[type="submit"],
.form-fields[type="reset"] {
    -webkit-appearance: none; /* For older versions of Chrome, Safari, etc. */
    appearance: none; /* Standard syntax */
    cursor: pointer;
}

.form-fields::-moz-placeholder {
    color: #838383;
    opacity: 1;
}

.form-fields:-ms-input-placeholder {
    color: #838383;
}

.form-fields::-webkit-input-placeholder {
    color: #838383;
}

.form-fields:focus {
    box-shadow: none;
    border: 1px solid #007a92 !important;
}

.form-content {
    height: 50px;
    border: 1px #acacac solid;
    width: 100%;
    color: #acacac;
    padding-left: 10px;
    margin-bottom: 10px;
}

textarea.form-content {
    border: 1px #acacac solid;
    width: 100%;
    color: #acacac;
    padding-left: 10px;
    height: 100px;
}

select.form-content {
    width: 100%;
    border: 1px #acacac solid;
    height: 50px;
}

/*
  MEDIA QUERIES
*/

/* Small devices (tablets, 768px and up) */
@media (min-width: 768px) {
    #quote-carousel {
        margin-bottom: 0;
        padding: 0 40px 30px 40px;
    }
}

/* Small devices (tablets, up to 768px) */
@media (max-width: 768px) {
    /* Make the indicators larger for easier clicking with fingers/thumb on mobile */

    #quote-carousel .carousel-indicators {
        bottom: -20px !important;
    }
    #quote-carousel .carousel-indicators li {
        display: inline-block;
        margin: 0px 5px;
        width: 15px;
        height: 15px;
    }
    #quote-carousel .carousel-indicators li.active {
        margin: 0px 5px;
        width: 20px;
        height: 20px;
    }
}

/* Responsive Css */
@media all and (min-width: 1024px) {
    .offcanvas,
    .body-inactive,
    .toggle {
        display: none !important;
    }
    .navigation {
        /* display:inline-block;  REDUNDANT CHRIS KEEPING JUST INCASE LOL */
        float: right;
    }
}
@media (max-width: 1023px) {
    .item-video .banner-caption {
        display: none;
    }
    .breakouts.breakouts-version-one .each-bo:hover .eb-content {
        padding-top: 0;
    }
    .breakouts.breakouts-version-one .each-bo:hover .eb-content > div,
    .audience .each-aud:hover .ea-content > div {
        transform: translateY(0);
    }
    .breakouts .each-bo .eb-content h3 {
        font-size: 18px;
    }
    .breakouts .each-bo .eb-content p {
        font-size: 14px;
    }

    .logo-navigation {
        padding: 10px 0;
    }
    .logo-navigation .navigation {
        display: none;
    }
}

@media (max-width: 767px) {
    .banner.banner-version-one .item {
        height: 100vh;
    }
    .banner .banner-caption h2 {
        font-size: 28px;
    }
}

@media (max-width: 480px) {
    .banner .action-buttons li {
        display: block;
        padding: 5px 0;
    }

    .offcanvas {
        width: 100%;
    }
}
.parallax {
    background-color: #333;
    background-attachment: fixed;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}
.text-white {
    color: #fff;
}
.text-white-30 {
    color: rgba(255, 255, 255, 0.3);
}
.text-white-50 {
    color: rgba(255, 255, 255, 0.5);
}
.text-white-70 {
    color: rgba(255, 255, 255, 0.7);
}
.text-black {
    color: #000;
}
.text-black-30 {
    color: rgba(0, 0, 0, 0.3);
}
.text-black-50 {
    color: rgba(0, 0, 0, 0.5);
}
.text-black-70 {
    color: rgba(0, 0, 0, 0.7);
}
.video-container {
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 30px;
    height: 0;
    overflow: hidden;
}
.video-container iframe,
.video-container object,
.video-container embed,
.iframe-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.form-field-subtle {
    background: RGBA(255, 255, 255, 0.1);
    border: 1px solid RGBA(255, 255, 255, 0.2);
    height: 40px;
}
.btn-special-1 {
    border: 1px solid #003150;
    color: #003150;
    padding: 4px 6px;
    font-size: 12px;
    margin-left: 70px;
}
.btn-special-1:hover {
    background: #003150;
    color: #fff;
}
.icon-blocks img {
    float: left;
}
.icon-blocks h3 {
    margin-left: 70px;
    margin-right: 20px;
    margin-top: 0;
}
.icon-blocks p {
    margin-left: 70px;
    margin-right: 20px;
}

.relative {
    position: relative;
}
.image-left-50 {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
    bottom: 120px;
    height: 75%;
    left: 6%;
    max-height: 670px;
    width: 37%;
    position: absolute;
}
.w50-text-right {
    width: 50%;
    min-width: 320px;
    text-align: right;
    margin-right: 30px;
}

.bo-1,
.bo-2,
.bo-3,
.bo-4 {
    background-size: cover;
    background-position: bottom left;
    position: relative;
    float: left;
    text-align: center;
    color: white !important;
}

p.text-normal {
    color: #353739;
    font-weight: normal;
}
.features-list li {
    padding-bottom: 10px;
    margin-bottom: 10px;
    border-bottom: 2px dotted #cccccc;
}
.features-list li:last-of-type {
    border-bottom: none;
}
.hr1 {
    margin: 30px 0;
    padding: 10px 10px;
    border-top: 2px dotted #ccc;
    border-bottom: 2px dotted #ccc;
    background: rgba(255, 255, 255, 0.95);
}

.col-md-fifth {
    position: relative;
    min-height: 1px;
    padding-left: 15px;
    padding-right: 15px;
}
@media (min-width: 992px) {
    .col-md-fifth {
        float: left;
        width: 20%;
    }
}

.col-lg-fifth {
    position: relative;
    min-height: 1px;
    padding-left: 15px;
    padding-right: 15px;
}
@media (min-width: 1420px) {
    .col-lg-fifth {
        float: left;
        width: 20%;
    }
}

@media (max-width: 1418px) and (min-width: 991px) {
    .col-md-offset-2-custom {
        margin-left: 16.66%;
    }
}

/* Changes Edits 30th September 2021 */
@media (max-width: 992px) {
    .template-nav-v1 .header {
        margin-top: 5px;
        margin-bottom: 5px;
    }
}
.template-nav-v1 .header .my-menu ul {
    float: none;
    display: table;
    margin-left: auto;
    margin-right: auto;
}
.template-nav-v1 .header .my-menu ul li:first-child {
    margin-left: 0;
}

.topbar .icon-contact-table {
    width: auto;
    float: right;
    text-align: left;
    position: relative;
}
.topbar .icon-contact-table .table-cell:first-child {
    padding-right: 15px;
}
.topbar .icon-contact-table h6,
.topbar .icon-contact-table h4 {
    margin: 0;
}
.topbar .icon-contact-table h4 {
    margin-top: 4px;
}

.topbar .icon-contact-table.ict-location {
    margin-right: 30px;
    padding-right: 30px;
}
.topbar .icon-contact-table.ict-location::after {
    right: 0;
    position: absolute;
    top: 50%;
    height: 20px;
    background-color: #fff;
    width: 2px;
    content: "";
    transform: translateY(-50%);
}
@media (max-width: 992px) {
    .topbar .icon-contact-table.ict-location::after {
        display: none;
    }
}

.img-icon-hover {
    overflow: hidden;
    position: relative;
}
.img-icon-hover img:first-child,
.img-icon-hover img:last-child {
    transition: 0.25s ease-out;
    position: absolute;
    top: 0;
    left: 0;
}
.img-icon-hover > img {
    max-width: 100%;
}
.img-icon-hover img:last-child {
    opacity: 0;
    visibility: hidden;
}
.img-icon-hover:hover > img:first-child {
    opacity: 0;
    visibility: hidden;
}
.img-icon-hover:hover > img:last-child {
    opacity: 1;
    visibility: visible;
}

.title1 {
    line-height: 1em;
    height: 3.1em;
    border-bottom: 1px solid #fff;
    margin-bottom: 1em;
}

.title2 {
    line-height: 1em;
    height: 3.1em;
    margin-bottom: 1em;
}

/* Wood Stain and Seal Color CSS */

.stain-colors-collection .panel {
    background-color: transparent;
}
.stain-colors-collection .panel .panel-heading {
    padding: 0;
    border-radius: 0;
}
.stain-colors-collection .panel .panel-heading .panel-title a {
    display: block;
    padding: 20px 40px 20px 20px;
    background-color: #003150;
    color: #fff;
    position: relative;
    font-size: 20px;
    font-weight: bold;
}

.stain-colors-collection .panel .panel-heading .panel-title a:after {
    position: absolute;
    right: 20px;
    font: normal normal normal 14px/1 FontAwesome;
    z-index: 1;
    font-size: 24px;
    top: 50%;
    content: "";
    transform: translateY(-50%);
}
@media (max-width: 600px) {
    .stain-colors-collection .panel .panel-heading .panel-title a {
        font-size: 18px;
    }
    .stain-colors-collection .panel .panel-heading .panel-title a:after {
        font-size: 20px;
    }
}
.stain-colors-collection
    .panel
    .panel-heading
    .panel-title
    a[aria-expanded="true"]:after {
    content: "\f077";
}
.stain-colors-collection
    .panel
    .panel-heading
    .panel-title
    a[aria-expanded="false"]:after {
    content: "\f078";
}
.stain-colors-collection .panel .panel-body {
    padding: 0 0 30px;
}
.stain-colors-collection .panel .row:not(.pre-stain) [class*="col-"] {
    margin-top: 30px;
}
.row.pre-stain img.img-responsive,
.stain-colors-collection
    .panel
    .row:not(.pre-stain)
    [class*="col-"]
    img.img-responsive {
    width: 100%;
}
.stain-colors-collection
    .panel
    .row:not(.pre-stain)
    [class*="col-"]
    .color-name {
    font-weight: bold;
    margin-top: 7px;
}
.stain-colors-collection
    .panel
    .row:not(.pre-stain)
    [class*="col-"]
    .color-name
    p {
    margin-bottom: 0;
}

@media (min-width: 992px) {
    .row.pre-stain {
        display: flex;
        flex-direction: row;
        align-items: center;
    }
}

@media (max-width: 767px) {
    .hide-on-small-screen {
        display: none;
    }
}

.center-image {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.center-content {
    text-align: center;
}

.responsive-button {
    max-width: 100%;
    height: auto;
}

/* Default styles for the iframe container */
.iframe-container {
    position: relative;
    overflow: hidden;
    padding-bottom: 56.25%; /* 16:9 aspect ratio for responsive height */
    max-width: 100%; /* Ensures the iframe doesn't overflow its container */
    margin: 0 auto; /* Centers the container */
    height: 400px;
}

/* Styles for the iframe */
.iframe-container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 400px;
}

/* Media query for smaller screens (adjust the breakpoint as needed) */
@media (max-width: 768px) {
    .iframe-container {
        padding-bottom: 75%; /* Adjust the aspect ratio for smaller screens */
    }
}

.footer-link-2:hover {
    color: #fff !important;
}

/* This changes the hover color of the links in the Header Contact */
.headercontact .contactholder a:hover {
    background-color: transparent !important;
    color: #999999 !important;
}
/* END OF This changes the hover color of the links in the Header Contact */

/* Back To Top Button */

#backTop {
    display: inline-block;
    width: 50px;
    height: 50px;
    text-align: center;
    border-radius: 0px;
    position: fixed;
    bottom: 30px;
    right: 30px;
    transition: background-color 0.3s, opacity 0.5s, visibility 0.5s;
    opacity: 0;
    visibility: hidden;
    z-index: 999;
}
#backTop::after {
    content: "\f077";
    font-family: FontAwesome;
    font-weight: normal;
    font-style: normal;
    font-size: 30px;
    line-height: 50px;
    color: #fff;
}
@media (max-width: 768px) {
    #backTop {
        font-size: 30px;
        padding: 0;
        margin: 0;
    }

    #backTop::after {
        position: relative;
        top: -3px;
        left: 0px;
    }
}
#backTop:hover {
    cursor: pointer;
    background-color: #1b1b1b;
}
#backTop:active {
    background-color: #555;
}
#backTop.show {
    opacity: 1;
    visibility: visible;
}
.circle {
    border-radius: 0px;
    box-shadow: 0px 0px 1px 1px #fafafa;
}
.pulse {
    animation: pulse-animation 1s infinite;
}

@keyframes pulse-animation {
    0% {
        box-shadow: 0 0 0 0px rgba(0, 0, 0, 0.2);
    }
    100% {
        box-shadow: 0 0 0 20px rgba(0, 0, 0, 0.2);
    }
}
/* Back To Top Button END */

/* Contact us page */

.contactus-link,
.contactus-link > h4 span {
    font-size: 22px;
    display: inline-flex;
    align-items: center;
    color: #003150;
}

.square-icon,
.rounded-icon,
.circle-icon {
    font-size: 30px;
    background-color: #003150;
    padding: 10px;
    transition: transform 0.5s ease;
    text-align: center;
}

div.row.footer-icon-link > i.square-icon,
div.row.footer-icon-link > i.rounded-icon,
div.row.footer-icon-link > i.circle-icon {
    font-size: 22px;
    background-color: #003150;
    color: #fff !important;
    padding: 10px;
    transition: transform 0.5s ease;
    width: 40px;
    height: 40px;
    text-align: center;
}

.square-icon {
    border-radius: 0px;
}

.rounded-icon {
    border-radius: 10px;
}

.circle-icon {
    border-radius: 50%;
}

.contactus-link:hover .square-icon,
.contactus-link:hover .rounded-icon,
.contactus-link:hover .circle-icon {
    transform: rotate(15deg);
}

a.contactus-link > p,
div.contactus-link > p {
    font-size: 18px;
    color: #222;
    margin-bottom: 0px;
}

/* Contact us page end */

h6.footerh6 {
    display: inline-block;
    font-size: 20px;
    line-height: 20px;
    /* vertical-align: bottom;
  margin-bottom: 0px !important; */
}

h6.footerh6 a {
    color: #fff;
}
h6.footerh6 a:hover {
    color: #aaa;
}

.footer-container-border {
    border-bottom: 5px #003150 solid;
}

/* MOBILE NAV ICON */
.mobile-nav {
    font-size: 45px; /* Adjust size as needed */
}

#phone-icon.mobile-nav {
    --fa-primary-opacity: 0;
    --fa-secondary-color: #003150;
    --fa-secondary-opacity: 1;
}

#close-img.mobile-nav {
    color: #003150;
}
/* END MOBILE NAV ICON */

/* Photo Gallery makes all the images the same size */
.img-responsive-pg {
    width: 100%; /* Image scales within its container */
    max-width: 600px;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 15px;
}

.opo-slider.bg-dark {
    background-color: #003150 !important;
}

/* About page Team Photo */
.section-banner {
    position: relative;
}
.section-banner .banner-filter {
    position: absolute;
}
.section-banner img {
    width: 100%;
}

/* photo strip images */
.single-image-modal img.img-responsive {
    aspect-ratio: 4 / 3;
    object-fit: cover;
}


/* Wood Stain Showcase Styles */

.stain-showcase .stain-img {
    /* padding-right: 5rem; */
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
    border: 4px solid #fff;
    transition: transform 0.4s ease;
}

.stain-showcase .stain-img:hover {
    transform: scale(1.03);
}

.stain-content{
    padding-left: 5rem;
}

@media (max-width: 991px) {
    .stain-content, .stain-showcase .stain-img { padding: auto; }
}

.stain-steps {
    counter-reset: step;
    margin: 25px 0 0;
    padding: 0;
    list-style: none;
}
.stain-steps li {
    position: relative;
    padding-left: 52px;
    margin-bottom: 18px;
}
.stain-steps li:before {
    counter-increment: step;
    content: counter(step);
    position: absolute;
    left: 0;
    top: 0;
    width: 38px;
    height: 38px;
    background: #003150;
    color: #fff;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    /* border-radius: 50%; */
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.25);
}
@media (max-width: 767px) {
    .stain-showcase {
        padding: 40px 0;
    }
    .stain-showcase .product-badge {
        position: static;
        display: inline-block;
        margin-bottom: 10px;
    }
    .stain-steps li {
        padding-left: 46px;
    }
}
/* Wood Stain Section END */



/* Custom Fabrication Collage media container */
.fab-media { position: relative; min-height: 430px; }

/* Base figure styling */
.fab-media .fab-photo { 
    position: absolute; 
    top: var(--y); 
    left: var(--x); 
    width: var(--w); 
    margin:0; 
    padding:0; 
    border:6px solid #fff; 
    background:#fff; 
    box-shadow:0 18px 46px -12px rgba(12,32,56,.28);
    transform: rotate(var(--rot)) translateZ(0); 
    transform-origin: 50% 50%;
    transition: transform .55s cubic-bezier(.22,.68,.37,1), box-shadow .55s, filter .55s; 
}

/* Layering order */
.fab-media .fab-back { z-index:1; }
.fab-media .fab-front { z-index:2; }

/* Image fill */
.fab-media .fab-photo img { 
    display:block; 
    width:100%; 
    height:100%; 
    object-fit:cover; 
}

/* Interactive polish */
.fab-media .fab-photo:hover { 
    /* transform: rotate(var(--rot)) scale(1.06);  */
    box-shadow:0 28px 64px -14px rgba(12,32,56,.42); 
    z-index:20; 
}
.fab-media .fab-photo:focus-within { outline:2px solid #1b6dc1; outline-offset:4px; }

/* Gentle float animation on first image for a bit of life */
@keyframes fabFloat { 
    0%,100% { transform: rotate(var(--rot)) translateY(0); } 
    50% { transform: rotate(calc(var(--rot) + 1deg)) translateY(-6px); } 
}
.fab-media .fab-back { animation: fabFloat 11s ease-in-out infinite; }

/* Larger screens: give more vertical space so rotated image stays within section */
@media (min-width: 1200px) {
    .fab-media { min-height: 560px; }
}

/* Responsive: stack on small & medium (<992px) screens to prevent overlap */
@media (max-width: 991px) {
    .fab-media { min-height: unset; }
    .fab-media .fab-photo { 
        position: static; 
        width:100% !important; 
        transform:none !important; 
        animation:none; 
        margin:0 0 1.25rem; 
    }
    .fab-media .fab-photo img { height:auto; }
}

/* Respect prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
    .fab-media .fab-photo, .fab-media .fab-back { animation:none !important; transition:none; }
}
/* Custom Fabrication Collage media container END */
