/*
| Breakpoint | Width    |
| ---------- | -------- |
| **XS**     | 0–575px  |
| **SM**     | ≥ 576px  |
| **MD**     | ≥ 768px  |
| **LG**     | ≥ 992px  |
| **XL**     | ≥ 1200px |
| **XXL**    | ≥ 1400px |
*/

.content-xs {
    display: none;
}

.content-sm {
    display: none;
}

.content-md {
    display: none;
}

.content-lg {
    display: none;
}

.content-xl {
    display: none;
}

.content-xxl {
    display: block;
}

.table {
    display: table;
    padding: 0;
    margin: 0;

    min-width: 0px;
}

.table-row {
    display: table-row;
    padding: 0;
    margin: 0;

    min-width: 0px;
}

.table-cell {
    display: table-cell;
    padding: 0;
    margin: 0;

    min-width: 0px;
}

.text-align-left {
    text-align: left;
}

.text-align-center {
    text-align: center;
}

.cursor-pointer {
    cursor: pointer;
}

.padding-left-5 {
    padding-left: 5px;
}

.padding-left-10 {
    padding-left: 10px;
}

.padding-left-15 {
    padding-left: 15px;
}

.padding-right-5 {
    padding-right: 5px;
}

.padding-right-10 {
    padding-right: 10px;
}

.padding-right-15 {
    padding-right: 15px;
}

.padding-bottom-5 {
    padding-bottom: 5px;
}

.padding-bottom-10 {
    padding-bottom: 10px;
}

.padding-bottom-15 {
    padding-bottom: 15px;
}

.screen-width-meter{
    position: fixed;
    top: 200px;
    left: 20px;

    height: 30px;
    width: 100px;

    border-style: groove;
    border-width: 2px;

    border-color: black;
    background-color: white;

    color: purple;

    font-size: 20px;
    font-weight: 600;

    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;

    z-index: 30;
}


.sep-div {
    position: relative;
    padding: 0;
    margin: 0;
    overflow: hidden;
    width: 100vw;
    left: -3px;
    height: 5px;
    background-color: #3f3f3f;
    border-style: solid;
    border-width: 2px;
    border-color: #b8b8b8;
}

.spacer-div-10h {
    position: relative;
    padding: 0;
    margin: 0;
    overflow: hidden;
    width: 100vw;
    height: 10px;
}

.spacer-div-15h {
    position: relative;
    padding: 0;
    margin: 0;
    overflow: hidden;
    width: 100vw;
    height: 15px;
}

.spacer-div-20h {
    position: relative;
    padding: 0;
    margin: 0;
    overflow: hidden;
    width: 100vw;
    height: 20px;
}

.spacer-div-25h {
    position: relative;
    padding: 0;
    margin: 0;
    overflow: hidden;
    width: 100vw;
    height: 25px;
}

.spacer-div-30h {
    position: relative;
    padding: 0;
    margin: 0;
    overflow: hidden;
    width: 100vw;
    height: 30px;
}

.spacer-div-35h {
    position: relative;
    padding: 0;
    margin: 0;
    overflow: hidden;
    width: 100vw;
    height: 35px;
}

.spacer-div-40h {
    position: relative;
    padding: 0;
    margin: 0;
    overflow: hidden;
    width: 100vw;
    height: 40px;
}

.work-sans-nova {
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}

.montserrat-nova {
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.archivo-black-nova {
  font-family: "Archivo Black", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.josefin-sans-nova {
  font-family: "Josefin Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
}

.anton-regular {
  font-family: "Anton", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.cormorant-garamond-nova {
  font-family: "Cormorant Garamond", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}

.old-standard-tt-regular {
  font-family: "Old Standard TT", serif;
  font-weight: 400;
  font-style: normal;
}

.old-standard-tt-bold {
  font-family: "Old Standard TT", serif;
  font-weight: 700;
  font-style: normal;
}

.old-standard-tt-regular-italic {
  font-family: "Old Standard TT", serif;
  font-weight: 400;
  font-style: italic;
}

.nova-text {
    color: #d7d7d7;
}

.and-text {
    color: #7a7a7a;
}

body {
    background-color: #d3d3d3;
    font-family: "Montserrat", sans-serif;
    font-weight: 450;
    color: #260e0e;

    margin: 0;
    padding: 0;
    overflow-x: hidden;

    z-index: 0;
}

.top-menu-top-border-only {
    position: fixed;
    top: -10px;
    right: 0px;
    left: 0px;

    height: 10px;

    background-color: #3d3d3d;
    
    border-color: #3d3d3d;
    border-right-style: none;
    border-left-style: none;
    border-top-style: solid;
    border-bottom-style: none;
    border-width: 10px;

    z-index: 9;
}

.top-menu-top {
    position: fixed;
    top: 5px;
    right: 0px;
    left: 0px;

    height: 35px;
    padding: 5px;

    font-size: 30px;
    color: #a1a1a1;
    font-weight: 500;
    letter-spacing: 0px;

    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;

    border-width: 2px 0 4px 0;
    border-left-style: none;
    border-right-style: none;
    border-top-style: solid;
    border-bottom-style: solid;
    background-color: #3d3d3d;
    border-image: linear-gradient(to right, rgb(94, 94, 94), rgb(229, 229, 229), rgb(94, 94, 94)) 1;

    z-index: 10;
}

.top-menu-bottom {
    position: fixed;
    top: 55px;
    right: 0px;
    left: 0px;

    height: 20px;
    
    border-color: #3d3d3d;
    border-right-style: none;
    border-left-style: none;
    border-top-style: solid;
    border-bottom-style: none;
    border-width: 5px;

    background-image: linear-gradient(to bottom, #3d3d3d, #d3d3d3);

    opacity: 1;
    transition: opacity 2s;

    z-index: 10;
}

.top-menu-bottom-scroll {
    position: fixed;
    top: 55px;
    right: 0px;
    left: 0px;

    height: 5px;
    
    border-color: #3d3d3d;
    border-right-style: none;
    border-left-style: none;
    border-top-style: solid;
    border-bottom-style: none;
    border-width: 5px;

    background-image: linear-gradient(to bottom, #3d3d3d, #d3d3d3);

    opacity: 0;
    transition: opacity 2s;

    z-index: 10;
}

.top-menu-bottom-border-only {
    position: fixed;
    top: 55px;
    right: 0px;
    left: 0px;

    height: 5px;
    
    border-color: #3d3d3d;
    border-right-style: none;
    border-left-style: none;
    border-top-style: solid;
    border-bottom-style: none;
    border-width: 5px;

    z-index: 10;
}

.bottom-menu {
    position: fixed;
    bottom: 35px;
    right: 0px;
    left: 0px;

    height: 30px;
    
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;

    border-right-style: none;
    border-left-style: none;
    border-top-style: solid;
    border-bottom-style: solid;
    border-width: 3px;
    border-image: linear-gradient(to right, rgb(94, 94, 94), rgb(229, 229, 229), rgb(94, 94, 94)) 1;

    background-color: #3d3d3d;

    padding: 0;
    margin: 0;

    z-index: 9;
}

.bottom-menu-top-border {
    position: fixed;
    bottom: 64px;
    right: 0px;
    left: 0px;
    
    height: 5px;
    
    border-color: #3d3d3d;
    border-right-style: none;
    border-left-style: none;
    border-top-style: solid;
    border-bottom-style: none;
    border-width: 5px;

    z-index: 9;
}

.bottom-menu-bottom-border {
    position: fixed;
    bottom: 0px;
    right: 0px;
    left: 0px;
    
    height: 31px;

    background-color: #202020;
    
    border-color: #000000;
    border-right-style: none;
    border-left-style: none;
    border-top-style: none;
    border-bottom-style: solid;
    border-width: 5px;

    z-index: 8;
}

.phone-number {
    position: fixed;
    bottom: 0;
    left: 10%;

    height: 31px;
    display: flex;
    align-items: center;
    line-height: 1;

    font-size: 16px;
    font-weight: 700;
    letter-spacing: 1px;

    color: #5a5a5a;
    
    padding: 0px;
    margin: 0px;

    transition: all 0.3s ease;

    cursor: pointer;

    z-index: 9;
}

.phone-number:hover {
    color: #c3c3c3;
}

.e-mail {
    position: fixed;
    bottom: 0;
    right: 10%;

    height: 31px;
    display: flex;
    align-items: center;
    line-height: 1;

    font-size: 16px;
    font-weight: 700;
    letter-spacing: 1px;

    color: #5a5a5a;
    
    padding: 0px;
    margin: 0px;

    transition: all 0.3s ease;

    cursor: pointer;

    z-index: 9;
}

.e-mail:hover {
    color: #c3c3c3;
}

.e-mail-alt-color {
    color: #3e3e3e;

    cursor: pointer;
}

.e-mail-alt-color:hover {
    color: #8d8d8d;
}

.phone-number-alt-color {
    color: #3e3e3e;

    cursor: pointer;
}

.phone-number-alt-color:hover {
    color: #8d8d8d;
}

.top-padding-zone {
    position: relative;
    top: 0px;

    height: 80px;
    width: 97vw;

    border-color: purple;
    border-style: none;
    border-width: 2px;

    z-index: 0;
}

.top-padding-zone-project-examples {
    position: relative;
    top: 0px;

    height: 55px;
    width: 97vw;

    border-color: purple;
    border-style: none;
    border-width: 2px;

    z-index: 0;
}

.top-padding-zone-windows-and-doors {
    position: relative;
    top: 0px;

    height: 55px;
    width: 97vw;

    border-color: purple;
    border-style: none;
    border-width: 2px;

    z-index: 0;
}

.main-body-style {
    opacity: 0;
    transition: all 1s ease;
    background: linear-gradient(rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.6)), url('/images/nova.marble.and.stone.jpg') no-repeat center center fixed;
    background-size: cover;
}

.body-content {
    position: relative;
    width: 100vw;

    background-color: #d3d3d3;

    border-color: rgb(69, 69, 69);
    border-top-width: 5px;
    border-top-style: none;
    border-right-style: none;
    border-left-style: none;
    border-bottom-style: none;

    overflow: hidden;

    padding: 0;
    margin: 0;

    z-index: 4;
}

.living-images {
    position: relative;

    height: 500px;
    width: 100vw;

    border-style: none;

    overflow: hidden;
    padding: 0;
    margin: 0;

    justify-content: center;
    align-items: center;
    text-align: center;

    z-index: 1;
}

.living-images-holder-one {
    position: absolute;
    top: 0px;

    height: 500px;
    width: 100vw;

    border-style: none;

    background-image: url('/images/project_examples/nova-design-project-example-m11.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    padding: 0;
    margin: 0;

    transition: all 0.5s ease;

    z-index: 2;
}

.living-images-holder-two {
    position: absolute;
    top: 0px;

    height: 500px;
    width: 100vw;
    left: 0px;

    border-style: none;

    background-image: url('/images/remodeling_design_example_01.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    padding: 0;
    margin: 0;

    transition: all 0.5s ease;

    z-index: 1;
}

.living-images-overlay {
    position: absolute;
    top: 80px;
    left: -500px;

    width: 350px;

    background-color: #ffffff;

    border-style: solid;
    border-width: 1px;
    border-color: #cc795a;
    border-radius: 15px;

    opacity: 0.83;

    color: #2a0303;
    font-size: 24px;
    font-weight: 400;

    transition: all 0.3s ease;

    padding: 20px;

    z-index: 3;
}

.living-images-text {
    background-color: #e7e7e7;
    color: #2a0303;
    padding: 15px;
    margin: 0;
    text-align: left;
    border-radius: 5px;
    font-size: 18px;
    font-weight: 700;
    z-index: 3;
}

.living-images-contact-us-button {
    font-size: 20px;
    font-weight: 700;
    padding: 8px;
    color: #2a0303;
    background-color: #d27428;
    border-color: black;
    border-width: 1px;
    border-style: solid;
    border-radius: 5px;
    cursor: pointer;

    transition: all 0.3s ease;
}

.living-images-contact-us-button:hover {
    background-color:  #709dd1;
    border-color: #000000;
    color: #ffffff;
}

.button-sep-div {
    display: block;
    width: 0px;
    padding: 0;
    margin: 0;

    min-width: 0px;

    border-style: solid;
    border-color: pink;
    border-width: 1px;
}

.menu-button {
    display: inline-block;

    height: auto;
    padding: 4px 6px;

    font-family: "Montserrat", sans-serif;
    font-size: 15px;
    font-weight: 400;
    letter-spacing: 0.4px;
    color: #d1d1d1;

    justify-content: center;
    align-items: center;
    text-align: center;

    border-style: none;
    background-color: transparent;

    cursor: pointer;

    transition: color 0.2s ease;

    z-index: 10;
}

.menu-button:hover {
    color: #ececec;
    background-color: transparent;
}

.more-button {
    position: fixed;
    bottom: 41px;
    right: 10px;

    height: auto;
    padding: 4px 6px;

    font-family: "Montserrat", sans-serif;
    font-size: 15px;
    font-weight: 400;
    letter-spacing: 0.4px;
    color: #d1d1d1;

    justify-content: center;
    align-items: center;
    text-align: center;

    border-style: none;
    background-color: transparent;

    cursor: pointer;

    transition: color 0.2s ease;

    z-index: 10;
}

.more-button:hover {
    color: #ececec;
    background-color: transparent;
}

.more-button-center {
    position: fixed;
    bottom: 41px;

    height: auto;
    padding: 4px 6px;

    font-family: "Montserrat", sans-serif;
    font-size: 15px;
    font-weight: 400;
    letter-spacing: 0.4px;
    color: #d1d1d1;

    justify-content: center;
    align-items: center;
    text-align: center;

    border-style: none;
    background-color: transparent;

    cursor: pointer;

    transition: color 0.2s ease;

    z-index: 10;
}

.more-button-center:hover {
    color: #ececec;
    background-color: transparent;
}

.menu-table {
    position: relative;

    width: 100%;
    box-sizing: border-box;
}

/* ---------- Marble pop-up menu ---------- */

.sliding-menu-pane {
    position: fixed;
    bottom: 85px;
    right: 8px;

    visibility: hidden;

    width: 268px;
    min-height: 50px;
    max-height: calc(100vh - 110px);
    overflow-y: auto;
    overflow-x: hidden;

    padding: 0;

    text-align: left;
    color: #2c2a26;

    background: transparent;
    border: none;
    box-shadow: none;

    margin: 0;

    z-index: 20;
}

.sliding-menu-pane .menu-table {
    width: 100%;
    box-sizing: border-box;

    padding: 14px 12px 16px;

    background-color: #e4e6ea;

    border: 1px solid rgba(110,118,128,0.55);
    border-radius: 16px;

    box-shadow:
        inset 0 1.5px 0 rgba(255,255,255,0.85),
        inset 1px 0 0 rgba(255,255,255,0.45),
        inset 0 4px 8px rgba(255,255,255,0.18),
        inset 0 -1.5px 0 rgba(0,0,0,0.30),
        inset -1px 0 0 rgba(0,0,0,0.16),
        inset 0 -6px 12px rgba(0,0,0,0.16);
}

.slide-holder {
    display: block;
    width: 100%;

    text-align: center;

    padding: 0;
    margin: 0;
}

.slide-button {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 12px;

    box-sizing: border-box;
    width: 214px;
    max-width: 100%;
    min-height: 36px;
    padding: 7px 16px 7px 14px;

    font-family: "Montserrat", sans-serif;
    font-weight: 600;
    font-size: 14px;
    letter-spacing: 0.2px;
    color: #2c2a26;
    text-align: left;
    line-height: 1.1;
    white-space: nowrap;

    cursor: pointer;

    border: 1px solid rgba(110,118,128,0.50);
    border-radius: 999px;

    background-color: #f1f2f4;
    background-image: none;

    box-shadow:
        /* outer depth - drop shadow under the cut piece */
        0 4px 8px rgba(0,0,0,0.30),
        0 1px 2px rgba(0,0,0,0.20),
        /* light catching the top edge of the cut */
        inset 0 2px 0 rgba(255,255,255,0.90),
        inset 1px 0 0 rgba(255,255,255,0.55),
        inset 0 4px 7px rgba(255,255,255,0.30),
        /* shadow at bottom edge of the cut */
        inset 0 -2px 0 rgba(0,0,0,0.22),
        inset -1px 0 0 rgba(0,0,0,0.14),
        inset 0 -5px 9px rgba(0,0,0,0.14);

    transition:
        transform 0.12s ease,
        box-shadow 0.12s ease,
        background-color 0.12s ease,
        color 0.12s ease;
}

.slide-button::before {
    content: '';
    display: inline-block;
    flex: 0 0 auto;
    width: 22px;
    height: 22px;
    background-color: currentColor;
    -webkit-mask-image: var(--slide-icon, none);
            mask-image: var(--slide-icon, none);
    -webkit-mask-size: contain;
            mask-size: contain;
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
    -webkit-mask-position: center;
            mask-position: center;
}

.slide-button:hover {
    color: #1a1a1a;
    background-color: #dfe2e6;
    box-shadow:
        0 1px 2px rgba(0,0,0,0.20),
        inset 0 2px 6px rgba(0,0,0,0.28),
        inset 0 -1px 0 rgba(255,255,255,0.55),
        inset 1px 0 2px rgba(0,0,0,0.10);
    transform: translateY(1.5px);
}

.slide-financing {
    color: #1c160d;
    background-color: #b08d2e;
    background-image: linear-gradient(180deg, #fff4c4 0%, #ffe78a 10%, #ffd84a 22%, #e6bc42 38%, #b08d2e 68%, #8a6c1f 100%);
    border-color: rgba(70, 52, 18, 0.55);
}

.slide-button.slide-financing:hover {
    color: #120e08;
    background-color: #9a7a26;
    background-image: linear-gradient(180deg, #fff0b8 0%, #ffdf70 10%, #f0c43a 22%, #c9a236 38%, #9a7a26 68%, #75591a 100%);
    box-shadow:
        0 1px 2px rgba(0,0,0,0.22),
        inset 0 2px 6px rgba(0,0,0,0.22),
        inset 0 -1px 0 rgba(255,255,255,0.35),
        inset 1px 0 2px rgba(0,0,0,0.12);
    transform: translateY(1.5px);
}

/* ---- Per-item line-art icons (SVG via mask) ---- */

#slide-menu-button-about .slide-button {
    --slide-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='9'/><path d='M12 11v5'/><circle cx='12' cy='8' r='0.9' fill='black' stroke='none'/></svg>");
}

#slide-menu-button-projects .slide-button {
    --slide-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><path d='M3 5h6a3 3 0 0 1 3 3v12a2 2 0 0 0-2-2H3z'/><path d='M21 5h-6a3 3 0 0 0-3 3v12a2 2 0 0 1 2-2h7z'/></svg>");
}

#slide-menu-button-windows-and-doors .slide-button {
    --slide-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='3' width='8' height='18' rx='0.6'/><line x1='3' y1='12' x2='11' y2='12'/><line x1='7' y1='3' x2='7' y2='21'/><rect x='14' y='5' width='7' height='16' rx='0.6'/><circle cx='19' cy='13' r='0.8' fill='black' stroke='none'/></svg>");
}

#slide-menu-button-lifts .slide-button {
    --slide-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><rect x='4' y='3' width='16' height='18' rx='0.6'/><line x1='12' y1='3' x2='12' y2='21'/><polyline points='8 9 9.5 7 11 9'/><polyline points='8 15 9.5 17 11 15'/><polyline points='13 9 14.5 7 16 9'/><polyline points='13 15 14.5 17 16 15'/></svg>");
}

#slide-menu-button-planning .slide-button {
    --slide-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><rect x='5' y='5' width='14' height='16' rx='1'/><rect x='9' y='3' width='6' height='3' rx='0.6' fill='black' stroke='none'/><polyline points='8.5 13.5 11 16 16 10'/></svg>");
}

#slide-menu-button-design .slide-button {
    --slide-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><path d='M12 3l9 18H3z'/><circle cx='12' cy='6.5' r='1.4' fill='black' stroke='none'/></svg>");
}

#slide-menu-button-building .slide-button {
    --slide-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><line x1='6' y1='3' x2='6' y2='21'/><line x1='3' y1='21' x2='10' y2='21'/><line x1='6' y1='5' x2='20' y2='5'/><line x1='6' y1='8.5' x2='17' y2='8.5'/><line x1='20' y1='5' x2='17' y2='8.5'/><line x1='12' y1='5' x2='12' y2='10.5'/><rect x='10' y='10.5' width='4' height='4'/></svg>");
}

#slide-menu-button-remodeling .slide-button {
    --slide-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><path d='M14 5l5 5-3 3-5-5z'/><path d='M11 8L4 15v5h5l7-7'/></svg>");
}

#slide-menu-button-interior .slide-button {
    --slide-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><path d='M4 14v-3a3 3 0 0 1 3-3h10a3 3 0 0 1 3 3v3'/><rect x='2' y='13' width='20' height='6' rx='1.5'/><line x1='5' y1='19' x2='5' y2='21'/><line x1='19' y1='19' x2='19' y2='21'/></svg>");
}

#slide-menu-button-exterior .slide-button {
    --slide-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><path d='M3 11l9-8 9 8'/><path d='M5 10v10h14V10'/><rect x='10' y='14' width='4' height='6'/></svg>");
}

#slide-menu-button-retail .slide-button {
    --slide-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><path d='M3 9l1.5-4h15L21 9'/><path d='M4 9v11h16V9'/><path d='M3 9c0 1.5 1.3 3 3 3s3-1.5 3-3c0 1.5 1.3 3 3 3s3-1.5 3-3c0 1.5 1.3 3 3 3s3-1.5 3-3'/><rect x='10' y='13' width='4' height='7'/></svg>");
}

#slide-menu-button-commercial .slide-button {
    --slide-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><rect x='4' y='3' width='9' height='18'/><rect x='13' y='8' width='7' height='13'/><line x1='6.5' y1='7' x2='7.5' y2='7'/><line x1='9.5' y1='7' x2='10.5' y2='7'/><line x1='6.5' y1='11' x2='7.5' y2='11'/><line x1='9.5' y1='11' x2='10.5' y2='11'/><line x1='6.5' y1='15' x2='7.5' y2='15'/><line x1='9.5' y1='15' x2='10.5' y2='15'/><line x1='15.5' y1='12' x2='16.5' y2='12'/><line x1='17.5' y1='12' x2='18.5' y2='12'/><line x1='15.5' y1='16' x2='16.5' y2='16'/><line x1='17.5' y1='16' x2='18.5' y2='16'/></svg>");
}

#slide-menu-button-residential .slide-button {
    --slide-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><path d='M3 12l9-9 9 9'/><path d='M5 10v11h14V10'/><path d='M9 21v-6h6v6'/></svg>");
}

#slide-menu-button-office .slide-button {
    --slide-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='6' width='13' height='9' rx='0.6'/><line x1='3' y1='15' x2='3' y2='20'/><line x1='16' y1='15' x2='16' y2='20'/><circle cx='20' cy='12' r='2'/><line x1='20' y1='14' x2='20' y2='20'/></svg>");
}

#slide-menu-button-financing .slide-button {
    --slide-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='9'/><path d='M15 8.5a3 3 0 0 0-3-1.5c-1.7 0-3 1-3 2.5s1.3 2 3 2.5 3 1 3 2.5-1.3 2.5-3 2.5a3 3 0 0 1-3-1.5'/><line x1='12' y1='5.5' x2='12' y2='7'/><line x1='12' y1='17' x2='12' y2='18.5'/></svg>");
}

/* ---- Close pill ---- */

.close-menu {
    justify-content: center;
    align-items: center;
    text-align: center;

    padding: 6px 0 2px;
    margin: 0;
}

.close-menu-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;

    box-sizing: border-box;
    width: 214px;
    max-width: 100%;
    min-height: 32px;
    padding: 6px 14px;

    font-family: "Montserrat", sans-serif;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 1px;
    color: #2c2a26;

    cursor: pointer;

    border: 1px solid rgba(110,118,128,0.50);
    border-radius: 999px;

    background-color: #f1f2f4;
    background-image: none;

    box-shadow:
        0 4px 8px rgba(0,0,0,0.30),
        0 1px 2px rgba(0,0,0,0.20),
        inset 0 2px 0 rgba(255,255,255,0.90),
        inset 1px 0 0 rgba(255,255,255,0.55),
        inset 0 4px 7px rgba(255,255,255,0.30),
        inset 0 -2px 0 rgba(0,0,0,0.22),
        inset -1px 0 0 rgba(0,0,0,0.14),
        inset 0 -5px 9px rgba(0,0,0,0.14);

    opacity: 1;
    z-index: 10;

    transition:
        transform 0.12s ease,
        box-shadow 0.12s ease,
        background-color 0.12s ease,
        color 0.12s ease;
}

.close-menu-button:hover {
    color: #1a1a1a;
    background-color: #dfe2e6;
    box-shadow:
        0 1px 2px rgba(0,0,0,0.20),
        inset 0 2px 6px rgba(0,0,0,0.28),
        inset 0 -1px 0 rgba(255,255,255,0.55),
        inset 1px 0 2px rgba(0,0,0,0.10);
    transform: translateY(1.5px);
}

.financing-button {
    color: #d1d1d1;
    background-color: transparent;
    background-image: none;
    border: none;
}

.menu-button.financing-button:hover {
    color: #ececec;
    background-color: transparent;
    background-image: none;
}

.image-mask-div {
    position: relative;

    min-height: 300px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 1px;

    overflow: hidden;

    padding: 0;
    margin: 0;

    background-color: #7790a9;

    z-index: 1;
}

.image-mask-holder-one {
    position: absolute;
    top: -300px;
    left: 0px;
    right: 0px;
    height: 600px;

    background-image: url('/images/project_examples/nova.project.example.seaseme.inn.05.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

.image-mask-holder-two {
    position: absolute;
    top: -300px;
    left: 0px;
    right: 0px;
    height: 600px;

    background-image: url('/images/project_examples/nova.project.example.restaurant.s03.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

.image-mask-holder-three {
    position: absolute;
    top: -300px;
    left: 0px;
    right: 0px;
    height: 600px;

    background-image: url('/images/project_examples/nova.project.example.seaseme.inn.04.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

.image-mask-holder-four {
    position: absolute;
    top: -300px;
    left: 0px;
    right: 0px;
    height: 600px;

    background-image: url('/images/project_examples/nova.project.example.seaseme.inn.06.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

.about-us-holder {
    position: absolute;
    top: 390px;
    left: -100px;
    right: -100px;

    height: 245px;

    border-style: solid;
    border-left-style: none;
    border-right-style: none;
    border-width: 2px;
    border-color: #868686;
    background-color: white;

    color: #110f0f;
    font-size: 18px;
    font-weight: 380;

    justify-content: center;
    align-items: center;
    text-align: center;

    padding: 10px;

    opacity: 0.77;

    overflow: hidden;

    z-index: 11;
}

.about-div {
    position: relative;

    min-height: 400px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 1px;

    background-image: url('/images/nova.granite.and.stone.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    justify-content: center;
    align-items: center;
    text-align: center;

    overflow: hidden;
    margin: 0;

    z-index: 4;
}

.who-we-are {
    position: relative;

    min-height: 600px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 1px;

    background-image: url('/images/nova.granite.and.stone.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    justify-content: center;
    align-items: center;
    text-align: center;

    overflow: hidden;
    margin: 0;

    z-index: 4;
}

.who-we-are-text {
    position: absolute;
    top: 1090px;

    width: 350px;

    font-size: 18px;
    font-weight: 400;
    color: #251212;

    background-color: #ffecc7;
    
    border-style: solid;
    border-width: 1px;
    border-radius: 5px;
    border-color: #1b0202;

    padding: 10px;
    padding-left: 30px;
    padding-bottom: 20px;

    z-index: 21;
}

.what-we-do-div {
    position: relative;

    min-height: 450px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 1px;

    background-image: url('/images/nova.granite.and.stone.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    
    justify-content: center;
    align-items: center;
    text-align: center;

    overflow: hidden;
    margin: 0;

    z-index: 4;
}

.what-we-do-holder {
    position: absolute;
    top: 2015px;
    left: -100px;
    right: -100px;

    height: 320px;

    border-style: solid;
    border-left-style: none;
    border-right-style: none;
    border-width: 2px;
    border-color: #868686;
    background-color: white;

    color: #110f0f;
    font-size: 18px;
    font-weight: 380;

    justify-content: center;
    align-items: center;
    text-align: center;

    padding: 10px;

    opacity: 0.77;

    overflow: hidden;

    z-index: 11;
}

.what-we-do-list {
    position: absolute;
    top: 50px;

    max-width: 350px;

    color: #110f0f;
    font-size: 18px;
    font-weight: 380;

    padding: 20px;
    border-style: solid;
    border-width: 1px;
    border-radius: 5px;
    border-color: #050303;

    padding: 10px;
    padding-right: 20px;

    opacity: 0.77;

    overflow: hidden;

    z-index: 12;
}

.why-choose-nova-text {
    position: absolute;
    top: 2780px;
    left: -100px;
    right: -100px;

    height: 310px;

    border-style: solid;
    border-left-style: none;
    border-right-style: none;
    border-width: 2px;
    border-color: #868686;
    background-color: white;

    color: #110f0f;
    font-size: 18px;
    font-weight: 380;

    justify-content: center;
    align-items: center;
    text-align: center;

    padding: 10px;

    opacity: 0.77;

    overflow: hidden;

    z-index: 11;
}

.why-choose-nova-div {
    position: relative;

    min-height: 450px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 1px;

    background-image: url('/images/nova.granite.and.stone.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    justify-content: center;
    align-items: center;
    text-align: center;

    overflow: hidden;
    margin: 0;

    z-index: 4;
}

.materials-and-selections-holder {
    position: absolute;
    top: 3550px;

    height: 380px;
    left: 0px;
    right: 0px;

    border-style: solid;
    border-left-style: none;
    border-right-style: none;
    border-width: 2px;
    border-color: #868686;
    background-color: white;

    justify-content: center;
    align-items: center;
    text-align: center;

    color: #110f0f;
    font-size: 18px;
    font-weight: 380;

    padding: 10px;

    opacity: 0.77;

    overflow: hidden;

    z-index: 11;
}

.materials-and-selections {
    position: absolute;
    top: 50px;

    width: 350px;

    color: #110f0f;
    font-size: 18px;
    font-weight: 380;

    padding: 20px;
    border-style: solid;
    border-width: 1px;
    border-radius: 5px;
    border-color: #050303;

    padding: 10px;
    padding-right: 20px;

    opacity: 0.77;

    overflow: hidden;

    z-index: 12;
}

.materials-and-selections-div {
    position: relative;

    height: 520px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 1px;

    background-image: url('/images/nova.granite.and.stone.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    justify-content: center;
    align-items: center;
    text-align: center;

    overflow: hidden;
    margin: 0;

    z-index: 5;
}

.content-div {
    position: relative;

    min-height: 300px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 1px;

    overflow: hidden;
    margin: 0;

    padding: 20px;

    z-index: 4;
}

.content-header {
    position: absolute;
    width: 300px;

    background-color: #aeaeae;
    color: #2d1515;

    border-color: #222222;
    border-width: 1px;
    border-style: solid;

    font-size: 20px;
    font-weight: 500;

    padding: 10px;
    border-radius: 10px;

    z-index: 4;
}

.content-container {
    position: absolute;
    width: 350px;

    padding: 10px;

    background-color: #e3e3e3;
    color: #251a1a;
    border-style: solid;
    border-color: #393939;
    border-radius: 10px;

    text-align: left;
    font-size: 16px;
    font-weight: 380;

    z-index: 4;
}

.content-button {
    position: absolute;
    width: 250px;

    background-color: #2d1515;
    color: #aeaeae;

    border-color: #222222;
    border-width: 1px;
    border-style: solid;

    font-size: 20px;
    font-weight: 500;

    padding: 5px;
    border-radius: 5px;

    cursor: pointer;
    
    transition: all 0.3s ease;

    z-index: 4;
}

.content-button:hover {
    background-color: #aeaeae;
    color: #2d1515;
}

.content-div-project-example-background {
    background: url('/images/project_examples/nova.project.example.kitchen.a01.jpg');

    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    border-color: #180e0e;
    border-top-style: solid;
    border-left-style: none;
    border-right-style: none;
    border-bottom-style: none;
    border-width: 3px;

    overflow: hidden;
}

.content-shade {
    position: absolute;
    top: 0px;
    right: 0px;
    left: 0px;
    bottom: 0px;

    padding: 0;
    margin: 0;

    background-color: #aeaeae;

    background-image: url('/images/project_examples/nova-design-project-example-m12.jpg');

    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    opacity: 1;

    z-index: 20;
}

.living-images-shade {
    position: absolute;
    top: 0px;
    left: 0px;
    right: 0px;
    bottom: 0px;

    background-image: url('/images/project_examples/nova-design-project-example-m12.jpg');

    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    opacity: 0;

    padding: 0;
    margin: 0;

    z-index: 1;
}

.count-down-bar {
    position: absolute;
    top: 5px;
    left: -2px;

    width: 1px;
    height: 5px;

    background-color: #ffffff;
    border-style: solid;
    border-color: #000;
    border-width: 1px;

    opacity: 0.33;

    border-radius: 5px;

    z-index: 21;
}

.count-down-bar-total {
    position: absolute;
    top: 490px;
    left: -2px;

    width: 1px;
    height: 5px;

    background-color: #b3b3b3;
    border-style: solid;
    border-color: #000;
    border-width: 1px;

    opacity: 0.33;

    border-radius: 5px;

    z-index: 21;
}

.contact-button-overlay {
    position: relative;
    width: 250px;

    background-color: #2d1515;
    color: #aeaeae;

    border-color: #222222;
    border-width: 1px;
    border-style: solid;

    font-size: 20px;
    font-weight: 500;

    padding: 5px;
    border-radius: 5px;

    cursor: pointer;
    
    transition: all 0.3s ease;

    z-index: 11;
}

.contact-button-overlay:hover {
    background-color: #aeaeae;
    color: #2d1515;
}

.contact-button-overlay-about-us {
    top: 335px;
}

.contact-button-overlay-who-we-are {
    top: 540px;
}

.contact-button-overlay-what-we-do {
    top: 392px;
}

.contact-button-overlay-why-choose-nova {
    top: 392px;
}

.contact-button-overlay-materials-and-selections {
    top: 460px;
}

.contact-button-overlay-project-examples {
    top: 70px;
}

.button-project-examples-showroom-hours {
    position: absolute;
    top: 250px;
}

.contact-button-overlay-windows-and-doors {
    top: 70px;
}

.button-windows-and-doors-showroom-hours {
    position: absolute;
    top: 250px;
}

.map-div {
    position: relative;

    min-height: 400px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 1px;

    overflow: visible;
    margin: 0;
    padding: 0;

    z-index: 4;
}

.map-wrapper {
    width: 100%;
    height: 400px;
    border: 1px solid #ccc;
}

.map-wrapper iframe {
    width: 100%;
    height: 100%;
    border: none;
}

.showroom-hours-div {
    position: relative;

    height: 300px;
    left: 0px;
    right: 0px;

    border-color: black;
    border-style: none;
    border-width: 0px;

    background-image: url('/images/nova.granite.and.stone.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    
    justify-content: center;
    align-items: center;
    text-align: center;

    padding-top: 50px;
    padding-bottom: 50px;

    overflow: hidden;
    margin: 0;

    z-index: 5;
}

.showroom-hours-holder {
    position: absolute;
    top: 50px;

    height: 150px;

    background-color: #ffffff;

    border-style: solid;
    border-color: #0f0707;
    border-width: 1px;
    border-radius: 5px;

    font-size: 18px;
    font-weight: 500;

    padding: 20px;
    padding-right: 50px;
    padding-left: 50px;
    margin: 0;

    opacity: 0.66;

    overflow: hidden;
}

.completed-project-examples-div {
    position: relative;

    height: 450px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 1px;

    background-image: url('/images/nova.marble.and.stone.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.windows-and-doors-div {
    position: relative;

    height: 450px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 1px;

    background-image: url('/images/windows-and-doors/nova-design-works-windows-and-doors-design-example.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.contact-us-div {
    position: relative;

    height: 320px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 2px;

    background-image: url('/images/nova.granite.countertops.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.contact-us-text {
    position: absolute;
    top: 40px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.contact-us-input-box-desktop {
    padding: 10px;
    margin: 0;

    border-color: #211111;
    border-style: solid;
    border-width: 1px;
    border-radius: 10px;

    height: 20px;
    width: 250px;

    font-size: 18px;
    font-weight: 650;

    text-align: left;
}

.contact-us-input-box-phone-desktop {
    padding: 10px;
    margin: 0;

    border-color: #211111;
    border-style: solid;
    border-width: 1px;
    border-radius: 10px;

    height: 20px;
    width: 150px;

    font-size: 18px;
    font-weight: 650;

    text-align: left;
}

.contact-us-textarea-desktop {
    padding: 20px;
    margin: 0;

    border-color: #ccc;
    border-style: solid;
    border-width: 1px;
    border-radius: 10px;

    height: 200px;
    width: 700px;

    font-size: 18px;
    font-weight: 650;

    text-align: left;
}

.contact-us-input-box-mobile {
    padding: 10px;
    margin: 0;

    border-color: #211111;
    border-style: solid;
    border-width: 1px;
    border-radius: 10px;

    height: 20px;
    width: 250px;

    font-size: 18px;
    font-weight: 650;

    text-align: left;
}

.contact-us-input-box-phone-mobile {
    padding: 10px;
    margin: 0;

    border-color: #211111;
    border-style: solid;
    border-width: 1px;
    border-radius: 10px;

    height: 20px;
    width: 150px;

    font-size: 18px;
    font-weight: 650;

    text-align: left;
}

.contact-us-textarea-mobile {
    padding: 20px;
    margin: 0;

    border-color: #ccc;
    border-style: solid;
    border-width: 1px;
    border-radius: 10px;

    height: 150px;
    width: 350px;

    font-size: 18px;
    font-weight: 650;

    text-align: left;
}

.contact-us-desktop {
    height: 500px;
}

.contact-us-desktop {
    height: 700px;
}

.project-example-header {
    position: absolute;
    top: 30px;
}

.project-example-body {
    position: absolute;
    top: 100px;
}

.project-example-button {
    position: absolute;
    top: 280px;
}

.contact-us-submit-button {
    position: absolute;
    top: 680px;
}

.project-example-text {
    position: relative;
    top: 40px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.windows-and-doors-gallery-header {
    position: relative;
    width: 85vw;
    margin: 0 auto;
    padding: 18px 28px 20px;
    text-align: center;
    color: #1b0e0e;
    background-color: #ffffff;
    border: solid 2px #000000;
    border-radius: 15px;
    opacity: 0.92;
    box-sizing: border-box;
}

.windows-and-doors-gallery-header .archivo-black-nova {
    display: block;
    font-size: clamp(1.1rem, 2.2vw, 1.4rem);
    letter-spacing: 0.03em;
    margin-bottom: 10px;
}

.windows-and-doors-gallery-header-sub {
    display: block;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.5;
    max-width: 40em;
    margin: 0 auto;
}

.windows-and-doors-example-text {
    position: relative;
    top: 40px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.project-image-div {
    position: relative;
    height: 640;

    width: 85vw;

    padding: 0;
    margin: 0;

    background-color: #d5d5d5;
}

.project-image-holder {
    position: relative;
    left: -5px;

    height: 100%;

    padding: 0;
    margin: 0;
}

.project-image-border {
    border-style: solid;
    border-color: black;
    border-right-width: 8px;
    border-left-width: 8px;
    border-bottom-width: 4px;
    border-top-width: 4px;
}

.windows-and-doors-image-div {
    position: relative;
    height: 640;

    width: 85vw;

    padding: 0;
    margin: 0;

    background-color: #d5d5d5;
}

.windows-and-doors-image-holder {
    position: relative;
    left: -5px;

    height: 100%;

    padding: 0;
    margin: 0;
}

.windows-and-doors-image-border {
    border-style: solid;
    border-color: black;
    border-right-width: 8px;
    border-left-width: 8px;
    border-bottom-width: 4px;
    border-top-width: 4px;
}

.windows-and-doors-slide-pdf-header .windows-and-doors-gallery-header-sub {
    margin-bottom: 14px;
}

.contact-button-windows-and-doors-slide-pdf {
    margin: 14px auto 0;
}

.windows-and-doors-video-preview {
    width: min(85vw, 100%);
    max-width: 100%;
    margin: 0 auto;
    padding: 0;
    box-sizing: border-box;
}

.windows-and-doors-video-preview-title {
    display: block;
    font-size: clamp(1rem, 2vw, 1.25rem);
    margin-bottom: 10px;
    text-align: center;
    color: #1b0e0e;
}

.windows-and-doors-video-preview-inner {
    background: linear-gradient(rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.6)), url('/images/nova.marble.and.stone.jpg') no-repeat center center fixed;
    background-size: cover;
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
}

.windows-and-doors-video-preview-inner video {
    display: block;
    max-width: 100%;
    max-height: 80vh;
    max-height: 80dvh;
    width: auto;
    height: auto;
    box-sizing: border-box;
    object-fit: contain;
}

.windows-and-doors-slide-pdf-list {
    list-style: disc;
    margin: 0 auto;
    padding: 0 0 0 1.35em;
    max-width: 36em;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.65;
    color: #1b0e0e;
    text-align: left;
}

.windows-and-doors-slide-pdf-list li {
    margin: 0.35em 0;
}

.windows-and-doors-slide-pdf-list a {
    color: #1b0e0e;
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
    transition: color 0.2s ease;
}

.windows-and-doors-slide-pdf-list a:hover {
    color: #5c2a2a;
}

.design-example-image-div {
    position: relative;
    height: 640;

    width: 85vw;

    padding: 0;
    margin: 0;

    background-color: #d5d5d5;
}

.design-example-image-holder {
    position: relative;
    left: -5px;

    height: 100%;

    padding: 0;
    margin: 0;
}

.design-example-image-border {
    border-style: solid;
    border-color: black;
    border-right-width: 8px;
    border-left-width: 8px;
    border-bottom-width: 4px;
    border-top-width: 4px;
}

.email-error-spacer-div {
    height: 15px;
}

.email-error-div {
    width: 300px;

    font-size: 18px;
    font-weight: 700;

    background-color: black;
    color: rgb(255, 140, 79);

    border-color: #ffa764;
    border-width: 1px;
    border-style: dotted;
    border-radius: 5px;

    padding: 10px;
    margin: 0;   
}

/* planning-and-permits */
.planning-and-permits-div {
    position: relative;

    height: 600px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 2px;

    background-image: url('/images/nova.design.and.construction.planning.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.planning-and-permits-text {
    position: relative;
    top: 40px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.contact-button-overlay-planning-and-permits {
    top: 70px;
}

/* interior-exterior-design */
.interior-and-exterior-design-div {
    position: relative;

    height: 700px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 2px;

    background-image: url('/images/nova.design.and.construction.design.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.interior-and-exterior-design-text {
    position: relative;
    top: 40px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.contact-button-overlay-interior-exterior {
    top: 70px;
}

/* turn-key-construction */
.turn-key-construction-div {
    position: relative;

    height: 700px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 2px;

    background-image: url('/images/nova.design.and.construction.turn.key.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.turn-key-construction-text {
    position: relative;
    top: 40px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.contact-button-overlay-turn-key-construction {
    top: 70px;
}


/* complete-remodeling */
.complete-remodeling-div {
    position: relative;

    height: 700px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 2px;

    background-image: url('/images/nova.design.and.construction.remodeling.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.complete-remodeling-text {
    position: relative;
    top: 40px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.contact-button-overlay-complete-remodeling {
    top: 70px;
}

/* interior-innovations */
.interior-innovations-div {
    position: relative;

    height: 700px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 2px;

    background-image: url('/images/nova.design.and.construction.interior.innovations.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.interior-innovations-text {
    position: relative;
    top: 40px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.contact-button-overlay-interior-innovations {
    top: 70px;
}

/* exterior-renovations */
.exterior-renovations-div {
    position: relative;

    height: 700px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 2px;

    background-image: url('/images/nova.design.and.construction.exterior.renovations.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.exterior-renovations-text {
    position: relative;
    top: 40px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.contact-button-overlay-exterior-renovations {
    top: 70px;
}

/* retail-design */
.retail-build-and-design-div {
    position: relative;

    height: 700px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 2px;

    background-image: url('/images/nova.design.and.construction.retail.design.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.retail-build-and-design-text {
    position: relative;
    top: 40px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.contact-button-overlay-retail-build {
    top: 70px;
}

/* commercial-building-and-design */
.commercial-building-and-design-div {
    position: relative;

    height: 600px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 2px;

    background-image: url('/images/nova.design.and.construction.commercial.building.design.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.commercial-building-and-design-text {
    position: relative;
    top: 40px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.contact-button-overlay-commercial-design {
    top: 70px;
}

/* residential-building-and-design */
.residential-home-builds-div {
    position: relative;

    height: 600px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 2px;

    background-image: url('/images/nova.design.and.construction.residential.building.design.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.residential-home-builds-text {
    position: relative;
    top: 40px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.contact-button-residential-home-builds {
    top: 70px;
}

/* office-design */
.office-design-div {
    position: relative;

    height: 600px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 2px;

    background-image: url('/images/nova.design.and.construction.office.design.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.office-design-div-text {
    position: relative;
    top: 40px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.contact-button-overlay-office-design {
    top: 70px;
}

/* financing-available */
.finance-with-us-div {
    position: relative;

    height: 600px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 2px;

    background-image: url('/images/nova.design.and.construction.financing.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.finance-with-us-text {
    position: relative;
    top: 40px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.contact-button-overlay-finance-with-us {
    top: 70px;
}

/* accessibility */
.accessibility-div {
    position: relative;

    height: 600px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 2px;

    background-image: url('/images/nova.design.and.construction.accessibility.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.accessibility-text {
    position: relative;
    top: 30px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.contact-button-accessibility {
    top: 70px;
}

/* accessibility */
.accessibility-stair-lifts-div {
    position: relative;

    height: 400px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 2px;

    background-image: url('/images/nova.design.and.construction.wheelchair.lifts.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.accessibility-stair-lifts-text {
    position: relative;
    top: 30px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

/* accessibility */
.accessibility-vertical-wheelchair-lifts-div {
    position: relative;

    height: 400px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 2px;

    background-image: url('/images/wheelchair-lifts-and-ramps/vertical-wheelchair-lifts/wheel-chair-lift-example-01.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.accessibility-vertical-wheelchair-lifts-text {
    position: relative;
    top: 30px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.accessibility-sloped-wheelchair-ramps-div {
    position: relative;

    height: 400px;
    width: 100vw;

    border-color: black;
    border-style: none;
    border-width: 2px;

    background-image: url('/images/wheelchair-lifts-and-ramps/sloped-wheelchair-ramps/slope-wheel-chair-lift-example-02.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;

    overflow: hidden;
    margin: 0;

    opacity: 0.88;

    padding: 0px;

    z-index: 4;
}

.accessibility-sloped-wheelchair-ramps-text {
    position: relative;
    top: 30px;

    width: 500px;

    font-size: 18px;
    font-weight: 500;

    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 25px;
    padding-left: 25px;
    margin: 0;

    color: #1b0e0e;

    background-color: #ffffff;

    border-style: solid;
    border-color: #000000;
    border-width: 2px;

    opacity: 0.85;

    border-radius: 15px;

    overflow: hidden;

    z-index: 5;
}

.living-images-overlay-close {
    position: absolute;
    top: 10px;
    right: 10px;
    
    width: 30px;
    height: 30px;
    
    background-color: #ffffff;
    color: #2a0303;
    
    border: 1px solid #cc795a;
    border-radius: 50%;
    
    font-size: 24px;
    font-weight: 700;
    line-height: 1;
    
    cursor: pointer;
    
    display: flex;
    align-items: center;
    justify-content: center;
    
    padding: 0;
    margin: 0;
    
    opacity: 0.83;
    
    transition: all 0.3s ease;
    
    z-index: 4;
}

.living-images-overlay-close:hover {
    background-color: #cc795a;
    color: #ffffff;
    opacity: 1;
    transform: scale(1.1);
}

.living-images-overlay-close:active {
    transform: scale(0.95);
}

.living-images-nav-arrow {
    position: absolute;
    bottom: 20px;
    
    width: 24px;
    height: 53px;
    
    background-color: rgba(255, 255, 255, 0.2);
    border: 2px solid rgba(255, 255, 255, 0.8);
    border-radius: 2px;
    box-shadow: 0 0 4px rgba(255, 255, 255, 0.6), inset 0 0 2px rgba(255, 255, 255, 0.4);
    
    color: rgba(255, 255, 255, 0.8);
    font-size: 19px;
    font-weight: 300;
    line-height: 1;
    
    cursor: pointer;
    
    display: flex;
    align-items: center;
    justify-content: center;
    
    padding: 0;
    margin: 0;
    
    transition: all 0.3s ease;
    
    z-index: 4;
    
    user-select: none;
}

.living-images-nav-arrow:hover {
    background-color: rgba(255, 255, 255, 0.35);
    border-color: rgba(255, 255, 255, 1);
    box-shadow: 0 0 6px rgba(255, 255, 255, 0.8), inset 0 0 3px rgba(255, 255, 255, 0.5);
    color: rgba(255, 255, 255, 1);
    transform: scale(1.05);
}

.living-images-nav-arrow:active {
    transform: scale(0.95);
}

.living-images-nav-arrow-left {
    left: 20px;
}

.living-images-nav-arrow-right {
    right: 20px;
}
