:root {
    /* Generic Defaults */
    --red: #D0011B;
    --box-shadow: 0 0 8px 0 rgba(0,0,0,0.08), 0 12px 20px -4px rgba(0,0,0,0.1);
    --grey: #eee;
    --dark-grey: #ccc;
    --lightest-grey: #f8f8f8;

    /** Merchant Theme Settings Defaults */
    --cta: #61D001;
    --cta-light: #ABE27B;
    --button-text: #333;
    --second: #0084C7;
    --second-light: #EBF9FF;
    --tertiary: #142156;
}
@font-face {font-family: "Font Awesome 7 Free";font-style: normal;font-weight: 900;font-display: block;src: url(../css/webfonts/fa-solid-900.woff2) format("woff2");}
@keyframes fa-spin {0% { transform: rotate(0deg);}100% { transform: rotate(360deg);}}
.fa-solid {font-family: "Font Awesome 7 Free", serif;}
.fa, .fa-solid {-moz-osx-font-smoothing: grayscale;-webkit-font-smoothing: antialiased;display: inline-block;font-style: normal;font-variant: normal;line-height: 1;text-rendering: auto;}
.fa-star:before{content:"\f005"}
.fa-spinner:before{content:"\f013"}
.fa-spin{animation-delay:0s;animation-direction:normal;}
.fa-spin{animation-name:fa-spin;animation-duration:2s;animation-iteration-count:infinite;animation-timing-function:linear;}
.fa-info:before{content:"\f129"}
.fa-scissors:before{content:"\f0c4"}
.fa-eraser:before{content:"\f12d"}
.fa-circle-plus:before{content:"\f055"}
.fa-circle-minus:before{content:"\f056"}
.fa-circle-play:before{content:"\f144";color: #FF0000;}
.fa-circle-info:before{content:"\f05a";color:var(--tertiary);}
.fa-minus:before{content:"\f068"}
.fa-plus:before{content:"\2b"}
.fa-circle-notch:before{content:"\f1ce"}
.fa-circle-check:before{content:"\f058";}
.fa-check:before{content:"\f00c";}
.fa-circle:before{content:"\f111";}
.fa-truck-fast:before{content:"\f48b";}
.fa-weight-hanging:before{content:"\f5cd";}
.fa-expand:before{content:"\f065";}
.fa-pencil:before{content:"\f303";}
.fa-sliders:before{content:"\f1de";}
.fa-thumbs-up:before{content:"\f164";}
.fa-thumbs-down:before{content:"\f165";}
.fa-circle-question:before{content:"\f059";}
/* exo-2-300 - latin */
@font-face {
    font-display: swap;
    font-family: 'Exo 2';
    font-style: normal;
    font-weight: 300;
    src: url('../fonts/exo-2-v20-latin-300.woff2') format('woff2');
}
/* exo-2-400 - latin */
@font-face {
    font-display: swap;
    font-family: 'Exo 2';
    font-style: normal;
    font-weight: 400;
    src: url('../fonts/exo-2-v20-latin-regular.woff2') format('woff2');
}
/* exo-2-600 - latin */
@font-face {
    font-display: swap;
    font-family: 'Exo 2';
    font-style: normal;
    font-weight: 600;
    src: url('../fonts/exo-2-v20-latin-600.woff2') format('woff2');
}
body {
    font-family: "Exo 2", sans-serif;
}
.text-right {
    text-align: right;
}
.font-weight-100 {
    font-weight: 100;
}
.font-weight-300 {
    font-weight: 300;
}
.no-margin {
    margin: 0 !important;
}
.system-notification {
    background-color: red;
    position: fixed;
    width: 100%;
    z-index: 9999;
}
body .system-notification p {
    color: #fff;
    text-align: center;
    font-size: 15px;
    font-weight: 300;
    margin: 0;
    padding: 4px 0;
}
.loader {
    height: 48px;
    display: flex;
    justify-content: center; /* horizontal centering */
    align-items: center;     /* vertical centering */
}
.loader  .fa-spin {
    font-size: 32px;
    color: var(--second);
}
h1 {
    font-weight: 300;
    font-size: 24px;
    margin-bottom: 1em;
}
h2 {
    font-size: 18px;
    font-weight: 300;
}
h4 {
    font-size: 22px;
    font-weight: 600;
    margin: 0 0 16px 0;
}
dd, dt {
    float: left;
}
.container {
    overflow-x: hidden;
}
.no-padding {
    padding: 0 !important;
}
.extra-margin-bottom {
    margin-bottom: 90px !important;
}
nav > li > a:hover,
nav > li > a:active {
    background: none;
}
.price {
    float: right;
    font-size: 14px;
}
.price .price-base {
    display: block;
    text-align: right;
    font-weight: bold;
}
.main-container {
    overflow:visible;
}
.step-container {
    margin:5px 0 40px 0;
}
.alert {
    border: none;
    border-radius: 0;
}
.alert.payment_completed {
    background-color: #EFFAE5;
    border-left: solid 4px var(--cta);
    text-align: center;
}
#alertModal.modal .modal-dialog {
    max-width: 350px;
}
.main-message {
    font-size: 23px;
    line-height: 1em;
    margin-bottom: 30px;
}
.main-message .pre-message {
    display: block;
    font-size: 17px;
    font-weight: 300;
}
.validation {
    display: none;
}
.validation.on {
    display: block;
}
.validation p {
    color:#333;
    text-align: center;
    font-weight: 600;
    background-color: #EDF4FC;
    border-left: solid 4px var(--second);
    padding: 12px;
    line-height: 22px;
    margin: 16px 0;
    display: block;
}
.validation p.error {
    background-color: #FAE5E8;
    border-color: var(--red);
}

/***********************************************************************/
/** Font definitions **/
/***********************************************************************/
dd, dt,
.step-input-data p {
    font-size: 16px;
    font-weight: 300;
    color: #444444;
}
dt {
    font-weight: 600;
}
/***********************************************************************/


.step-summary .summary .price .price-base,
.step-view #kit-view .price .price-base {
    font-size: 19px;
    line-height: 1.2em;
    font-weight: normal;
}
div.step-container .diagram-title {
    font-size: 32px;
    color: white;
    font-weight: 300;
    width: 100%;
    margin: 0.7em -50% 2.5rem -50%;
}
div.step-container div.error-box {
    border-radius: 5px;
    -webkit-border-radius: 5px;
    position: absolute;
    top: 10px;
    max-height: 100%;
    font-size: 16px;
}
div.step-container div.error-box div.error-message {
    color: white;
    height: 100%;
    display: block;
    margin: 15px;
}
div.step-container div.error-box:before {
    margin-top: -23px;
    left: 50%;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
    border: 14px solid transparent;
    border-bottom: 10px inherit;
    margin-left: -14px;
}
.step-view h1 {
    display: block;
    margin: 6px 0 15px;
}
.step-view p {
    font-style: italic;
}
.left-nav .stepsIndicatorContainer {
    margin-bottom: 10px;
}
/** merchant header bar **/
header {
    padding: 15px 0 10px;
    margin-bottom: 16px;
    position: relative;
    width: 100%;
    background: #fff;
}
header a.merchant {
    padding: 0;
    display: inline-block;
}
header a.merchant img {
    max-width: 200px;
    max-height: 200px;
}
header .kitbuildr {
    color: var(--tertiary);
    font-family: "Exo 2", sans-serif;
    font-size: 22px;
    letter-spacing: 0;
    line-height: 48px;
    text-align: center;
}
header .kitbuildr img {
    max-width: 212px;
    width: 100%;
    margin-left: 10px;
}
header .telephone {
    font-family: "Exo 2", sans-serif;
    font-size: 24px;
    color: var(--tertiary);
    font-weight: bold;
}
header p.telephone {
    font-size: 18px;
    margin: 0;
}

.logo-container {
    white-space: nowrap;
    position: relative;
    text-align: center;
}
.logo-container .logo {
    display: inline-block;
    font-size: 24px;
    width: 2.1em;
    height: 2.1em;
}
.logo-container .logo img {
    width: 100%;
}
.logo-container .logo-text {
    display: inline-block;
    vertical-align: middle;
    font-weight: 400;
    font-size: 22px;
    text-align: left;
    margin: 0 0 0 4px;
}
.modal-lg {width:1000px}
div.modal-header {
    padding: 16px;
    border-bottom: none;
}
div.modal-header h4.modal-title {
    font-size: 26px;
    margin-bottom: 0;
    font-weight: 300;
    line-height: 30px;
}
div.modal-header button.close {
    opacity: 1;
    font-size: 22px;
    font-weight:300;
    line-height:10px;
    margin-top:6px;
    border-radius:50px;
    height:32px;
    width:32px;
    padding:0 0 6px;
    text-shadow: none;
}
.modal {
    margin-top:95px;
}
.modal-footer {
    border: none;
}
.modal-dialog {
    margin:0 auto;
}
.modal-body,
.modal-footer {
    padding: 0 16px 16px;
}
#modalVideo {
    margin-top: 0;
    overflow:unset;
}

#modal-auto-buy .modal-body img.loader {
    width: 100px;
    display: block;
    margin: auto;
}
#postToBasketModal .modal-content {
    padding: 30px 0;
}
#postToBasketModal .modal-dialog {
    width: 400px;
}
#postToBasketModal .modal-header,
#postToBasketModal .modal-body,
#postToBasketModal .modal-footer {
    text-align: center;
}
#postToBasketModal .post-attempt-info {
    width: 100px;
    height: 100px;
    border-radius: 100%;
    margin: 0 auto;
    position: absolute;
    left: 144px;
    top: 0;
    border: 5px solid rgba(88, 202, 85, 0.3);
}
#postToBasketModal .modal-footer {
    padding-bottom: 20px;
}
#postToBasketModal .modal-footer h5 {
    font-style: italic;
    font-size: 13px;
    line-height: 1.7rem;
    margin: 0;
}
@keyframes rotating {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}

.step-newkit,
.step-edges,
.step-surface,
.step-temperature,
.step-incline,
.step-colour,
.step-trim-colour,
.step-review,
.step-summary {
    display:none;
}

/* Save kit modal */
#modalSaveKit {
    z-index:9999;
}
#modalSaveKit .modal-dialog {
    width: 400px;
}
#modalSaveKit .modal-header {
    padding-bottom: 16px;
}
#modalSaveKit .modal-body {
    padding: 0 32px 0;
}
#modalSaveKit p.intro {
    margin-bottom: 24px;
}
#modalSaveKit .kit-save-success {
    text-align: center;
    color: var(--tertiary);
    display:none;
    font-weight: 300;
    margin: 0 0 32px 0;
}
#modalSaveKit button {
    margin-top: 16px;
    width: calc(50% - 4px);
    padding: 12px;
}
#modalSaveKit button.secondary {
    margin-right: 2px;
}
#modalSaveKit button.success {
    margin-left: 2px;
}

form .form-group.required label:first-child::after {
    content: '\f069';
    color: #FF5252;
    font-family: "Font Awesome 7 Free", serif;
    font-weight: 600;
    font-size: 6px;
    position: relative;
    top: -7px;
    left: 2px;
}
form .form-group.error input,
form .form-group.error select {
    border-color:#FF5252;
    border-width: 2px;
    margin-bottom: 0;
}
form .error-text {
    color:#FF5252;
    margin: 0;
    font-size:14px;
    line-height: 24px;
    font-weight: 300;
}
button:disabled,
button[disabled] {
    background-color: #cccccc;
    color: #666666;
    cursor: not-allowed;
    pointer-events: none;
}

/* Chrome, Safari, Edge, Opera */
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/**********************************************************************************************************************/
/** Button Styles **/
button {
    font-family: "Exo 2", sans-serif;
    font-size: 16px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 20px;
    border-radius: 8px;
    padding: 12px 24px;
    transition: all 300ms ease-in-out;
    text-transform: capitalize;
    background-color: #fff;
    color: var(--button-text);
    border: solid 2px #fff;
}
button:hover {
    cursor: pointer;
}
button.icon {
    content: "\f054";
    font-family: "Font Awesome 7 Free", serif;
    font-size: 14px;
    display: inline-block;
    line-height: 16px;
    margin: 0 0 0 8px;
}
/* Outline */
button.outline {
    border: solid 2px #333;
    color: #333;
}
button.outline:hover {
    background-color: #dfdfdf;
}
/* CTA */
button.success {
    background-color: var(--cta);
    color: var(--button-text);
}
button.success,
.option-selectable.selected {
    border-color: var(--cta);
}
button.success:hover,
.roof-designer .toolbox .tool.toggle.on,
.roof-designer .toolbox .tool:hover,
.roof-designer .toolbox .tool.toggle.on:hover,
.option-selectable.selected {
    background-color: var(--cta-light);
}
/** Selectable Option **/
.option-selectable,
div.option-selectable {
    border-color: #ccc;
}
.option-selectable:hover {
    background-color: var(--cta-light);
}
.option-selectable.selected {
    box-shadow: 0 0 8px 0 rgba(0,0,0,0.08), 0 12px 20px -4px rgba(0,0,0,0.1);
}

/** Disabled **/
button[disabled],
button.disabled,
button[disabled]:hover,
button.disabled:hover {
    color: #A0A0A0;
    border-color: #eee;
    cursor: default;
    background-color: #fff;
}
/**********************************************************************************************************************/

.step {
    display: none;
}
.step.active {
    display: block;
}
.step-newkit .innerContainer {
    padding:32px;
    border-radius: 16px;
    background-color: #FFFFFF;
    box-shadow: 0 0 8px 0 rgba(0,0,0,0.08), 0 12px 20px -4px rgba(0,0,0,0.1);
    text-align:center;
}
.step-newkit .titleBar {
    color: var(--tertiary);
    font-family: "Exo 2", sans-serif;
    font-size:30px;
    letter-spacing: 0;
    line-height: 48px;
    text-align:center;
    margin:0 0 24px 0;
    padding:0 16px;
}
.step-newkit .titleBar img.logo {
    max-width:212px;
    width:100%;
}
.step-newkit .introPara {
    width: 100%;
    color: #444444;
    font-family: "Exo 2", sans-serif;
    font-size: 16px;
    font-weight: 300;
    letter-spacing: 0;
    line-height: 24px;
    text-align: center;
    margin-bottom:32px;
    min-height: 75px;
}
.step-newkit img.illustration {
    margin:auto auto 32px;
    display: block;
    width:100%;
    max-width:480px;
}
.step-newkit img.footer_logo {
    margin:32px auto auto;
    display: block;
    width: 100%;
    height: 18px;
}


.fixed-bottom-toolbutton {
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%;
    padding: 20px 0;
    margin: 0;
    background-color: #fff;
    z-index: 9999;
}
.fixed-bottom-toolbutton button.success,
.fixed-bottom-toolbutton button.previous {
    width: 145px;
}
.step-input-data .fixed-bottom-toolbutton .button-container button {
    margin: 0;
}
/********************/

/** Step Input Data column **/
.step-input-data {
    border-radius: 16px;
    background-color: #FFFFFF;
    padding: 24px;
    box-shadow: 0 0 8px 0 rgba(0,0,0,.08), 0 12px 20px -4px rgba(0,0,0,.1);
    margin: 0 0 150px 0;
}
.step .step-input-data.review-block {
    margin: 0;
}
.step-input-data h2 {
    font-size: 30px;
    font-weight: 600;
    padding:0;
    margin:0 0 24px 0;
    color: var(--tertiary);
    line-height: 32px;
}
.step-input-data p {
    padding:0;
    margin: 0 0 24px 0;
    width: 100%;
}
.step-input-data .button-container {
    text-align: center;
}
.step-input-data .button-container button {
    margin-top:16px;
}
/** Step Information Block **/
.important-info {
    width: 100%;
    padding: 8px 12px;
    border: solid 1px var(--second);
    background-color: var(--second-light);
    border-radius: 8px;
    margin: 16px 0 0 0;
}
.important-info p {
    font-size: 14px;
    line-height: 22px;
    margin: 0 0 4px 0;
}
/** Information blocks and pill links in introPara **/
.introPara .info {
    margin: 8px 0 4px;
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
    width: 100%;
}

.introPara .info p,
.introPara .info .pill {
    margin: 0;
    text-decoration: none;
    outline: none;
}

.introPara .info .pill {
    cursor: pointer;
    border-radius: 24px;
    background-color: var(--second);
    color: #fff;
    font-size: 12px;
    padding: 5px 8px 6px;
    font-weight: 600;
    line-height: 12px;
    width: 140px;
    margin-top: 4px;
    display: flex;
    justify-content: space-between;
}

.introPara .info .pill:hover {
    background-color: #1BA2E7;
}

.introPara .info .pill::after {
    font-family: "Font Awesome 7 Free", serif;
    margin-left: 8px;
}

.introPara .info .pill.web-link::after {
    content: '\f08e';
}

.introPara .info .pill.video::after {
    content: '\f04b';
}

/** Step Option Select Button **/
button.select-this-option {
    height: 80px;
    padding: 0 8px;
    float: left;
    margin: 4px;
    outline: 0;
    width: 100%;
    max-width: calc(50% - 8px);
}
button.select-this-option img,
button.select-this-option div.thumb {
    margin: 8px 0;
    max-width: 56px;
    height: 56px;
    width: 56px;
    border-radius: 8px;
}
button.select-this-option div.thumb {
    margin: 10px 0;
}
button.select-this-option.no-description div.thumb + .title {
    top: 26px;
}
button.select-this-option .title,
button.select-this-option .description {
    color: var(--tertiary);
    font-size: 16px;
    letter-spacing: 0;
    line-height: 20px;
    text-align: left;
    width: calc(100% - 72px);
    position: relative;
    height: auto;
    float:right;
    text-transform: none;
    margin:0 0 0 16px;
}
button.select-this-option .description {
    font-size: 14px;
    font-weight: 300;
    margin: 0;
    white-space: inherit;
}

/* options that have no description text */
button.select-this-option.no-description p.title {
    top: 22px;
}

/* Temperature options step */
#temperature-selection-container button.select-this-option {
    height: 120px;
}
#temperature-selection-container button.select-this-option .title {
    top: 10px;
}
#temperature-selection-container button.select-this-option .description {
    top: -42px;
}
/* Extra Items options step */
#extraItemsContainer.selection-container button.select-this-option {
    width: 100%;
    max-width: 100%;
    height: auto;
    min-height: 105px;
    padding: 8px;
}
#extraItemsContainer.selection-container button i.fa-circle-play {
    float: right;
    font-size: 18px;
}
#extraItemsContainer.selection-container button.select-this-option .thumb,
#extraItemsContainer.selection-container button.select-this-option .title,
#extraItemsContainer.selection-container button.select-this-option .description,
#extraItemsContainer.selection-container button.select-this-option .qty-and-sizes {
    float: left;
    margin: 0;
    padding: 0;
    position: initial;
}
#extraItemsContainer.selection-container button.select-this-option img {
    max-width: 80px;
    width: 100%;
    height: 100%;
    border-radius: 8px;
}
#extraItemsContainer.selection-container button.select-this-option .title,
#extraItemsContainer.selection-container button.select-this-option .description,
#extraItemsContainer.selection-container button.select-this-option .qty-and-sizes {
    float: right;
    height: auto;
    width: calc(100% - 96px);
}
#extraItemsContainer.selection-container button.select-this-option .description {
    margin-bottom: 16px;
}
#extraItemsContainer.selection-container button.select-this-option .description.hide {
    display: inline-block !important;
}
#extraItemsContainer.selection-container button.select-this-option .title {
    margin: 0 0 4px 0;
}
#extraItemsContainer.selection-container button.select-this-option .qty-and-sizes .size-option {
    margin: 4px 0;
    text-align: right;
    display: inline-block;
    width: 100%;
}
#extraItemsContainer.selection-container button.select-this-option .qty-and-sizes label {
    font-size: 12px;
    height: auto;
    font-weight: 300;
    margin: 4px 4px 0 0;
    color: var(--tertiary);
}
#extraItemsContainer.selection-container button.select-this-option .qty-and-sizes .quantity {
    float: right;
    margin: 2px 0 0;
}
#extraItemsContainer.selection-container button.select-this-option .qty-and-sizes .quantity * {
    float: left;
}
#extraItemsContainer.selection-container button.select-this-option .qty-and-sizes .quantity i,
#extraItemsContainer.selection-container button.select-this-option .qty-and-sizes .quantity .amount {
    border: solid 1px var(--grey);
    height: 26px;
    padding: 0 6px 0 7px;
    background-color: #fff;
}
#extraItemsContainer.selection-container button.select-this-option .qty-and-sizes .quantity i {
    font-size: 12px;
    padding-top: 6px;
    color: #333;
    transition: all 200ms ease-in-out;
    border-radius: 4px;
    background-color: #fff;
}
#extraItemsContainer.selection-container button.select-this-option .qty-and-sizes .quantity i.decrease {
    border-right: none;
    border-bottom-right-radius: 0;
    border-top-right-radius: 0;
}
#extraItemsContainer.selection-container button.select-this-option .qty-and-sizes .quantity i.increase {
    border-left: none;
    border-bottom-left-radius: 0;
    border-top-left-radius: 0;
}
#extraItemsContainer.selection-container button.select-this-option .qty-and-sizes .quantity i:hover {
    background-color: #ccc
}
#extraItemsContainer.selection-container button.select-this-option .qty-and-sizes .quantity i.disabled,
#extraItemsContainer.selection-container button.select-this-option .qty-and-sizes .quantity i.disabled:hover {
    color: #ccc;
    cursor: default;
    background-color: #fff;
}
#extraItemsContainer.selection-container button.select-this-option .qty-and-sizes .quantity .amount {
    padding: 1px 4px 0 4px;
    text-align: center;
    font-weight: 600;
    width: 26px;
    font-size: 12px;
    color: #333;
}
#extraItemsContainer.selection-container button.select-this-option.no-multiples.no-sizes i {
    font-family: "Exo 2", sans-serif;
    text-transform: uppercase;
    padding: 5px 10px;
}
#extraItemsContainer.selection-container button.select-this-option.no-multiples.no-sizes i:before {
    content: '';
}
#extraItemsContainer.selection-container button.select-this-option.no-multiples.no-sizes .amount {
    display: none;
}
#extraItemsContainer.selection-container .moreInfo {
    display: none;
}

/* Colour options */
button.select-this-option div.thumb {
    background-color:#fff;
    border-radius:50px;
    border:solid 1px var(--tertiary);
}
button.select-this-option div.thumb {
    display:inline-block;
}
button.select-this-option div.thumb.black,
.black:before {
    background-color: #000;
}
button.select-this-option div.thumb.dark-grey,
.dark-grey:before {
    background-color: #696969;
}
button.select-this-option div.thumb.light-grey,
.light-grey:before {
    background-color: #d3d3d3;
}
button.select-this-option div.thumb.anthracite-grey,
.anthracite-grey:before {
    background-color: #3D3F43;
}
button.select-this-option div.thumb.black_plastic {
    background-color: #000;
}
button.select-this-option div.thumb.black_metal {
    background: linear-gradient( 45deg, #fff 10%, #000 10%, #000 30%, #fff 50%, #000 70%, #333 80%, #000 95% );
}
/** modal dialog options **/
.modal button.select-this-option {
    max-width:100%;
}
.modal button.select-this-option .button-text {
    display: block;
    float: left;
    width: calc(100% - 112px);
    margin:0 0 0 16px;
}
.modal button.select-this-option .button-text span {
    position: inherit;
    margin:0;
    width:100%;
}
.form-group {
    margin-bottom: 5px;
}
.form-group input.form-control {
    border:solid 2px #d5d5d5;
    border-radius:4px;
    background-color: #fff;
    padding:16px;
    font-size:16px;
    color:#444;
    font-weight: 300;
    box-shadow: none;
    margin-bottom: 8px;
}
.form-group.name-fields {
    display: inline-block;
    width: 100%;
}
.form-group.name-fields .field {
    width: calc(50% - 5px);
    display: inline-block;
    float: left;
}
.form-group.name-fields .field:first-child {
    margin-right: 10px;
}
.form-group.name-fields .field input {
    margin-bottom: 0;
}

/* Step: System Types*/
.step-system-types button.select-this-option {max-width:none;}

/* Step: Roof Shapes */
#loader_roof-shape-selection-container {
    margin: 25px calc(50% - 25px);
}
.step-roof-shapes button.select-this-option img {
    border-radius: 50%;
}
.step-roof-shape .button-container button.previous {display: none;}
/* Step: Review */
.step-review .step-input-data.review-block {
    padding:24px 32px 0 32px;
    width: 100%;
}
.step-review .review-block:nth-child(n+1){
    border-radius: unset;
    border-bottom: solid 2px #ebebeb;
}
.step-review .review-block:nth-child(1) {
    border-radius:16px;
}
.step-review .review-block:nth-child(2) {
    padding:0;
}
.step-review .review-block:first-child {
    border-radius: 16px 16px 0 0;
    border-bottom: none;
}
.step-review .review-block:last-child {
    border-radius:0 0 16px 16px;
}
.step-review .review-block {
    display: inline-block;
}
.step-review .review-block .stepsIndicatorContainer,
.step-review .review-block #reviewRoofContainer {
    padding: 0;
}
.step-review .review-block #reviewRoofContainer #reviewRoof {
    float: right;
}
.step-review .step-input-data.toolbutton {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    z-index: 9999;
    position: relative;
    box-shadow: 0 0 0 0 rgba(0,0,0,0.08), 0 18px 15px 0 rgba(0,0,0,0.1);
    padding-top: 0;
}

/*****************************************************************************/
/** Summary Step **/
/*****************************************************************************/
.step-summary .summary-container {
    background-color: #f6f6f6;
    border-radius: 16px;
    padding-top: 16px;
    padding-bottom: 16px;
}
.step-summary .step-input-data.basket p {
    margin-bottom: 16px;
}
.step-summary .kit-locked {
    display: none;
    padding: 10px;
    background-color: #FFFAE5;
    border-left: solid 4px #FFD400;
    text-align: center;
    font-size: 14px;
    line-height: 18px;
}
.step-summary .step-input-data.basket {
    box-shadow: none;
    overflow:hidden;
    background-color: transparent;
    padding: 0;
    border-radius: 0;
    margin-bottom: 0;
}
.step-summary #loader_summary-container {
    margin: 32px 0;
}
.step-summary .kit-container h3 {
    color: var(--tertiary);
    font-family: "Exo 2",sans-serif;
    font-size: 32px;
    font-weight: 300;
    letter-spacing: 0;
    line-height: 40px;
    margin:0 0 13px 0;
}
.step-summary .kit-container .specification {
    font-size: 16px;
    font-weight: 300;
    margin: 0 0 32px 0;
    float: left;
    width: 100%;
    min-height: 87px;
}
.step-summary .kit-container .specification dt {
    width: 75px;
}
.step-summary .kit-container .specification dd {
    width: calc(100% - 75px);
}
.step-summary .basket-summary-container {
    min-height: 237px;
}
.step-summary .basket-summary .note {
    font-size: 12px;
    text-align: left;
    margin: 8px 0 0;
    line-height: 16px;
}
.step-summary .tierItem .fake-radio::before {
    content: ' ';
    width: 9px;
    height: 9px;
    display: block;
    border-radius: 50px;
    top: 4px;
    position: relative;
    left: 4px;
}
.step-summary .fake-radio.checkbox::before {
    content: '\f00c';
    font-family: "Font Awesome 7 Free", serif;
    font-weight: 600;
    top:-1px;
    left:3px;
    font-size: 20px;
    color: #fff;
}
.step-summary .fake-radio.checkbox {
    border-radius: 4px;
}
.step-summary .fake-radio {
    border:solid 2px var(--tertiary);
    width: 21px;
    height: 21px;
    border-radius: 50px;
    cursor: pointer;
}
.step-summary #upsells-container-header {
    margin-top: 28px;
}
.step-container #summary-container #your-kit-container h4.choose-layer:before,
.step-summary #upsells-container-header:before {
    content: '1.';
    font-size: 16px;
    margin: 0 8px 0 0;
}
.step-summary #upsells-container-header:before {
    content: '2.';
}

/*****************************************************************************/
/** Tier Items/Upsell Items */
/*****************************************************************************/
.step-summary .tierItem,
.step-summary .upsellItem {
    background-color: #fff;
    border-width: 2px;
    border-style: solid;
    padding: 16px;
    border-radius: 8px;
    margin:0 0 8px 0;
    overflow: hidden;
}
.step-summary .tierItem:not(:only-child) {
    float: left;
    width: calc(50% - 8px);
    margin: 0 16px 0 0;
    cursor:pointer;
}
.step-summary .tierItem:last-child {
    margin: 0;
}
.step-summary .tierItem .feefo-product-stars-widget {
    border-bottom: solid 1px #d9d9d9;
    margin: 0 0 16px 0;
}
.step-summary .tierItem .selector {
    width: 25px;
    float: left;
}
.step-summary .tierItem .text {
    float: right;
    width: calc(100% - 36px);
}
.step-summary .tierItem .text label b,
.step-summary .tierItem .price {
    color: #333;
    font-weight: 600;
    font-size: 18px;
}
.step-summary .tierItem .price {
    width: 100%;
    line-height: 16px;
    margin: 0 0 16px 0;
    text-align: left;
}
.step-summary .tierItem .radio {
    width: 24px;
    height: 24px;
    border: solid 2px #333;
    border-radius: 50px;
    margin: 0;
}
.step-summary .tierItem.selected .radio,
.step-summary .tierItem .fa-check {
    display: none;
}
.step-summary .tierItem .radio,
.step-summary .tierItem.selected .fa-check {
    display: inline-block;
}
.step-summary .tierItem label,
.step-summary .upsellItem label {
    color: #444444;
    font-size: 20px;
    letter-spacing: 0;
    line-height: 18px;
    cursor:pointer;
    width: calc(100% - 55px);
    margin: 0;
}
.step-summary .tierItem label {
    width: 100%;
    margin-bottom: 4px;
}
body .step-container.classicbond .step-summary .tierItem .tier-item-boost-tag {
    background-color: #ffd000;
    display: inline-block;
    text-align: center;
    padding: 2px 16px 3px;
    font-size: 12px;
    color: #333;
    font-weight: 600;
    border-radius: 16px;
    position: relative;
    max-width: 110px;
    margin-bottom: 16px;
}
.step-summary .tierItem .product-list {
    list-style-type: none;
    padding: 0;
    margin: 0;
}
.step-summary .tierItem .product-list li {
    color: #4b4b4b;
    font-weight: 300;
    line-height: 16px;
    margin: 0 0 8px 0;
    font-size: 12px;
}
.step-summary .tierItem .product-list li span {
    color: #888;
    font-size: 12px;
}
body .step-container.classicbond .step-summary .tierItem .tier-item-boost-tag[data-code='1_5mm_membrane'] {
    background-color: #61D001;
}
.step-summary .tierItem .description,
.step-summary .tierItem .feefo-product-stars-widget,
body .step-container.classicbond .step-summary .tierItem .tier-item-boost-tag {
    width: calc(100% + 37px);
    margin-left: -37px;
}
.step-summary .tierItem input[type=radio],
.step-summary .upsellItem input[type=checkbox],
.step-summary .fake-radio + input[type=checkbox] {
    display:none;
}

.step-summary .tierItem .moreInfo {
    float: left;
    width: 100%;
    background-color: #f5f5f5;
    border-radius: 8px;
    border: 1px solid #eee;
}
.step-summary .tierItem .moreInfo h5 {
    display: block;
    padding: 0;
    margin: 8px;
}
.step-summary .tierItem .moreInfo h5:after {
    content: '\f106';
    font-family: "Font Awesome 7 Free", serif;
    float: right;
}
.step-summary .tierItem .moreInfo.hide h5:after {
    content: '\f107';
}
.step-summary .tierItem.selected .moreInfo h5:after {
    content: '\f107';
}
.step-summary .tierItem .moreInfo .product-list {
    background-color: white;
    padding: 10px;
}
.step-summary .tierItem .moreInfo.hide {
    display:block !important;
}
.step-summary .tierItem .moreInfo.hide ul.product-list {
    display:none;
}
.step-summary .tierItem.selected .moreInfo.hide ul.product-list {
    display:block !important;
}
.step-summary .tierItem .moreInfo ul.product-list {
    width: 100%;

}
.step-summary .upsellItem {
    padding: 12px;
}
.step-summary .upsellItem .video {
    display: inline-block;
    margin: 0 0 0 10px;
}
.step-summary .upsellItem img,
.step-summary .upsellItem .no-image {
    display: block;
    width: 75px;
    float:left;
    overflow:hidden;
    margin: 0 16px 0 0;
    border-radius: 8px;
}
.step-summary .upsellItem .name,
.step-summary .upsellItem .moreInfo,
.step-summary .upsellItem .description {
    width: calc(100% - 75px - 16px);
}
.step-summary .upsellItem .description {
    float: right;
    margin: 0 0 8px 0;
}
.step-summary .upsellItem .price {
    width: calc(100% - 75px);
    margin-top:2px;
}
.step-summary .upsellItem .no-image {
    border: solid 1px var(--grey);
    height: 50px;
}
.step-summary .upsellItem .name {
    float: left;
    margin-bottom: 4px;
}
.step-summary .upsellItem .name label span {
    padding-right: 0;
}
.step-summary .upsellItem .left-col,
.step-summary .upsellItem .right-col {
    width: 100%;
    float: right;
}
.step-summary .upsellItem .right-col {
    width: calc(100% - 75px - 16px);
    margin-top:10px;
}
.step-summary .upsellItem .right-col .feefo-product-stars-widget {
    height: 20px;
}
.step-summary .upsellItem .left-col {
    float: left;
}
.step-summary .upsellItem .moreInfo {
    font-weight: 300;
    text-align: left;
    color: #0088c1;
    font-size: 13px;
    float: right;
    height: auto;
    text-decoration: underline;
    cursor: pointer;
}
.step-summary .upsellItem .instock {
    font-weight: 600;
    text-align: left;
    color: black;
    height: auto;
    width: auto;
    background-color: #d4f1fc;
    font-size: 12px;
    padding: 0 5px;
    display: inline-block;
}
.step-summary .upsellItem .options {
    width: 100%;
    float: left;
    margin: 4px 0;
}
.step-summary .description {
    color: #000;
    font-weight: 300;
    display: inline-block;
    width: 100%;
    
    font-size: 14px;
}
.step-summary .tierItem .description {
    min-height: fit-content;
    padding: 0 0 16px 0;
    margin-bottom: 16px;
    margin-top: 8px;
    border-bottom: solid 1px #d6d6d6;
}
.step-summary .description ul {
    column-count: 2;
    padding: 0 0 0 16px;
}
.step-summary .description ul li {
    line-height: 16px;
    margin-bottom: 4px;
}
.step-summary .upsellItem .quantity {
    width: 75px;
    float: left;
    padding: 0;
}
.step-summary .upsellItem .feefo-product-stars-widget {
    float: right;
    margin-top: 3px;
}
.feefo-rating-stars svg {
    width: 16px;
}
.step-summary .upsellItem .quantity button,
.step-summary .upsellItem .quantity input {
    border: solid 1px #d6d6d6;
    height: 30px;
    width: 25px;
    background-color: #fff;
    color: var(--tertiary);
    font-size: 14px;
    padding: 0 4px;
}
.step-summary .upsellItem .quantity button:first-child {
    border-radius: 4px 0 0 4px;
}
.step-summary .upsellItem .quantity button:last-child {
    border-radius: 0 4px 4px 0;
}
.step-summary .upsellItem .quantity input {
    border-left: none;
    border-right: none;
    font-weight: 600;
    text-align: center;
}
.step-summary .upsellItem .quantity button:hover {
    background-color: var(--grey);
    box-shadow: none;
}
.step-summary .upsellItem .quantity button.disabled,
.step-summary .upsellItem .quantity button.disabled:hover,
.step-summary .upsellItem .quantity button.loading {
    color: var(--grey);
    background-color: #fff;
    cursor: default;
    box-shadow: none;
}
.step-summary .upsellItem .quantity button.loading i.fa-spinner {
    color: var(--tertiary);
    font-size: 14px;
    width: auto;
}
.step-summary .tierItem.selected .selector .fa-check {
    background-color: var(--cta);
    color: #fff;
    font-size: 15px;
    border-radius: 50px;
    width: 24px;
    height: 24px;
    padding: 4px 0 0 5px;
}
.step-summary .upsellItem span.price-label {
    width: 100px;
    display: block;
    float: left;
    font-size: 16px;
    margin: 0;
}
.step-summary .upsellItem label {
    font-size: 16px;
    font-weight: 400;
    display: block;
    float: left;
}
.step-summary .upsellItem label span {
    float: left;
    width: 110px;
    text-align: right;
    padding: 0 5px 0 0;
}
.step-summary .upsellItem .options label {
    font-size: 14px;
}
.step-summary .upsellItem .options button {
    font-size: 12px;
    font-weight: 300;
    padding: 4px 12px;
    height: auto;
    margin:5px 10px 5px 0;
    border:solid 1px #ccc;
    background-color: #fff;
}
.step-summary .upsellItem .options button.selected {
    border-color:var(--cta);
    background-color:var(--cta);
    box-shadow: 0 0 4px 0 rgba(0,0,0,0.08), 0 8px 8px -4px rgba(0,0,0,0.1);
}
.step-summary .upsellItem[data-multiples=false] .name {
    float: left;
}
.step-summary .upsellItem[data-multiples=false] .name label .price-label {
    font-weight: 600;
}
.step-summary .upsellItem[data-multiples=false] .right-col .price {
    display: none;
}
.step-summary .upsellItem i.fa-check-circle {
    display:none;
    float:right;
    font-size:20px;
    color:var(--cta);
    position:relative;
    top:-10px;
    right:-10px;
}
.step-summary .upsellItem i {
    display:inline-block;
}
.step-summary .upsellItem[data-multiples=true] .price {
    margin-top: 10px;
}
.step-summary .tierItem .price {
    display: block;
    width: 100%;
    line-height: 16px;
    position: relative;
    font-size: 20px;
    margin: 4px 0 0;
}

.step-input-data .basket-summary {
    display:inline-block;
}
.step-summary .basket-summary .delivery-info {
    width: 100%;
    display: inline-block;
    margin: 8px 0 0 0;
}
.step-summary .basket-summary .delivery-info * {
    float: left;
    color: #666;
}
.step-summary .basket-summary .delivery-info .right {
    float:right;
}
.step-summary .basket-summary .delivery-info div {
    position: relative;
    top: 7px;
}
.step-summary .basket-summary .delivery-info div div {
    position: initial;
}
.step-summary .basket-summary .delivery-info svg {
    margin: 0 8px 0 0;
}

.step-summary .basket-summary .items {
    color: #444;
    margin: 0 0 16px 0;
}
.step-summary .basket-summary .item {
    display: flex;
    justify-content: space-between;
    margin: 0 0 4px 0;
}
.step-summary .basket-summary .item .name {
    flex: 2;
}
.step-summary .basket-summary .item .quantity {
    flex: 0.25;
    text-align: left;
}
.step-summary .basket-summary .item .price {
    flex: 0.5;
    text-align: right;
}

.step-summary .basket-summary h2 {
    font-size: 32px;
    font-weight:300;
}
.step-summary h3 {
    color: var(--tertiary);
    font-size: 24px;
    font-weight: 300;
    letter-spacing: 0;
    line-height: 30px;
}
.step-summary .feefo-rating {
    display: block;
    width: 100%;
}
.step-summary .feefo-rating img {
    max-width: 225px;
    display: block;
    margin: 16px auto 16px;
}
.step-summary .basket-summary button {
    width:100%;
}

.step-summary .basket-summary button#btnBackToHome {
    display: none;
}
.step-summary .basket-summary button#btnBackToHome {
    margin: 0 0 0 4px;
    float: right;
}
.step-summary .basket-summary label.or {
    width:100%;
    text-align: center;
    margin:8px 0;
    font-size:20px;
    font-weight:300;
    color:#222;
}
.step-summary .basket-summary #total-container {
    margin: 0 0 8px 0;
}
.step-summary .basket-summary .totals {
    width:100%;
    display:inline-block;
}
.step-summary .basket-summary .totals label,
.step-summary .basket-summary .totals div {
    width:50%;
    display: inline-block;
    color: var(--tertiary);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 20px;
    margin:0 0 4px 0;
    text-align: left;
}
.step-summary .basket-summary .totals div {
    color:#444;
    text-align: right;
}
.step-summary .basket-summary .totals .total-row label {
    width: 55%;
}
.step-summary .basket-summary .totals .total-row .total.price {
    width: 45%;
}
.step-summary .basket-summary .totals .total-row {
    padding: 0 16px;
    margin: 0 0 0 -16px;
    width: calc(100% + 32px);
}
.step-summary .basket-summary .totals .total-row label {
    text-align: left;
}
.step-summary .basket-summary .totals .total-row label,
.step-summary .basket-summary .totals .total-row div {
    margin: 0;
    font-size: 26px;
}
.step-summary .basket-summary .totals .total-row.rrp-price label,
.step-summary .basket-summary .totals .total-row.rrp-price div {
    width: 55%;
}
.step-summary .basket-summary .totals .total-row.rrp-price label,
.step-summary .basket-summary .totals .total-row.rrp-price div,
.step-summary .basket-summary .totals .total-row.rrp-price div.total.price {
    font-size: 16px;
    font-weight: 300;
    color: #ccc;
}
.step-summary .tierItem .price:first-letter,
.step-summary .upsellItem .price-label:not(.from):first-letter,
.step-summary .upsellItem .price:first-letter,
.step-summary .basket-summary .totals .price::first-letter {
    font-size: 12px;
}
.step-summary .basket-summary .delivery-info .price:first-letter {
    font-size: 10px;
}
.step-summary .upsellItem .price-label:first-letter {
    font-weight: 300;
}
.step-summary .basket-summary .totals .total-row .total.price.loading {
    color: var(--grey);
}
.step-summary .basket-summary .totals .vat-label {
    font-size:10px;
}
.step-summary .tierItem .pound-sign {
    font-size: 12px !important;
}
.step-summary #terms-selection-container {
    margin: 0;
}
.step-summary #terms-selection-container .form-check {
    display: inline-block;
    margin-bottom: 16px;
}
.step-summary #terms-selection-container .form-check label {
    width:calc(100% - 50px);
    cursor:pointer;
    font-weight: 300;
    margin: 0;
    line-height: 18px;
}
.step-summary #terms-selection-container .fake-radio label,
.step-summary #terms-selection-container .fake-radio.checkbox {
    float: left;
}
.step-summary #terms-selection-container .fake-radio.checkbox {
    margin: 0 8px 0 0;
    width: 16px;
    height: 16px;
    top: 3px;
    border-color: var(--second);
}
.step-summary #terms-selection-container .fake-radio.checkbox::before {
    color: #fff;
    top: -5px;
    position: relative;
    font-size: 11px;
    left: 1px;
}
.step-summary #terms-selection-container .selected .fake-radio.checkbox {
    background-color: var(--second);
}
.step-summary #terms-selection-container .form-check p {
    float: left;
    width:100%;
    color: #9d9d9d;
    font-size: 12px;
    letter-spacing: 0;
    line-height: 14px;
    margin: 6px 0 0;
}
.step-summary #terms-selection-container .form-check:hover p {
    color: #333;
}
body .step-summary button#btnBuyKit {
    background-color: var(--cta);
    color: #fff;
}
body .step-summary button#btnBuyKit:hover {
    background-color: var(--cta-light);
}
.step-summary button#btnBuyKit.success::after {
    display: none;
}
.step-summary button#btnBuyKit.loading {
    opacity: 0.5;
    cursor: default;
}
.step-summary button#btnBuyKit.loading:hover {
    box-shadow: none;
}
.step-summary button#btnBuyKit.loading i {
    animation: rotating 1.2s linear infinite;
}
body .step-summary button#btnBuyKit[disabled] {
    color: #b2b2b2;
    background-color: #eee;
}
body .step-summary  .step-input-data.basket .step-input-data.basket-summary.secondary-buttons {
    border-radius: 0;
    background: transparent;
    width: 100%;
    box-shadow: none;
    margin: 16px 0 0;
    padding: 0;
}
.step-summary .step-input-data.basket-summary.secondary-buttons #btnSaveKit {
    float: right;
}
.step-summary .basket-summary.secondary-buttons button {
    margin-bottom: 0;
    width: auto;
}
body.saved .step-summary #summary-container .tierItem,
body.saved .step-summary #upsells-container .upsellItem {
    border-color: #333;
    background-color: #fff;
}
body.saved .step-summary #upsells-container .upsellItem .quantity button,
body.saved .step-summary #upsells-container .upsellItem:not([data-multiples='false']) .name label .price-label {
    display: none;
}
body.saved .step-summary #upsells-container .upsellItem .quantity input {
    margin-top: 10px;
}
body.saved .step-summary #upsells-container .upsellItem .quantity::before {
    content: 'Qty:';
    font-weight: 600;
    font-size: 14px;
}
body.saved .step-summary #upsells-container .upsellItem .right-col * {
    border: none;
}
.step-summary .basket-summary button#btnPurchaseOrder {
    margin: 0 0 24px 0;
}
.step-summary .basket-summary button#btnPurchaseOrder:after {
    display: none;
}
.step.step-summary .step-input-data.basket-summary.primary {
    background-color: var(--second-light);
    padding: 16px;
    margin: 0;
    box-shadow: 0 0 8px 0 rgba(0,0,0,0.3), 0 12px 20px -4px rgba(0,0,0,0.1);
}
/*****************************************************************************/

.discountMessage {
    background-color: var(--cta);
    color: var(--button-text);
    height: 48px;
    border-radius: 8px;
    font-family: "Exo 2", sans-serif;
    font-size: 16px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 20px;
    border: 0;
    padding: 12px 24px;
    transition: all 200ms ease-in-out;
    text-align: center;
}

/** Steps Indicator **/
.stepsIndicatorContainer h2 {
    color: var(--tertiary);
    font-size: 20px;
    font-weight: 300;
    letter-spacing: 0;
    line-height: 30px;
    margin: 0 0 16px 0;
}
.stepsIndicatorContainer ul.steps_list {
    counter-reset: li;
    list-style-type: none;
    font-size: 14px;
    line-height: 18px;
    padding-left:0;
    margin-bottom: 0;
}
.stepsIndicatorContainer ul.steps_list li {
    position: relative;
    color: var(--tertiary);
    font-size: 16px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 24px;
    overflow:hidden;
    padding: 0 0 20px 0;
}
.stepsIndicatorContainer ul.steps_list li .number::before {
    content: ' ';
    width: 30px;
    height: 30px;
    border-radius: 50px;
    display: block;
    position: absolute;
    top:8px;
    left:8px;
}
.stepsIndicatorContainer ul.steps_list li.blue .number::before {
    content: unset;
    transition: all 350ms ease-in-out;
}
.stepsIndicatorContainer ul.steps_list li .number {
    background-color: white;
    height: 46px;
    width: 46px;
    border-radius: 50%;
    color: var(--tertiary);
    font-family: "Font Awesome 7 Free", serif;
    font-size: 12px;
    font-weight: 600;
    text-align: center;
    padding-top: 10px;
    float:left;
    border:solid 2px #A1A5B9;
    transition: all 350ms ease-in-out;
}
.stepsIndicatorContainer ul.steps_list li.grey {
    color: #A1A5B9;
}
.stepsIndicatorContainer ul.steps_list li.grey .number {
    border-color: #A1A5B9;
    color: #A1A5B9;
}

.step-review .review-block .stepsIndicatorContainer ul.steps_list li.blue .number {
    border-color: var(--cta);
}
.stepsIndicatorContainer ul.steps_list li.blue .line {
    border-color: var(--second);
}
.stepsIndicatorContainer ul.steps_list li.blue .number {
    border: 2px solid var(--second);
    padding-top: 10px;
    color: #fff;
    background-color: var(--second);
}
.stepsIndicatorContainer ul.steps_list li.green .line {
    border-color: var(--cta);
}
.stepsIndicatorContainer ul.steps_list li .line {
    border:solid 1px #A1A5B9;
    position: absolute;
    height: 100%;
    top: 46px;
    left: 23px;
}
.stepsIndicatorContainer ul.steps_list li:last-child .line {
    display: none;
}
.stepsIndicatorContainer ul.steps_list li .title {
    margin: 0 0 0 16px;
    float:left;
}
.stepsIndicatorContainer ul.steps_list li.green .title {
    width: 40%;
}
.stepsIndicatorContainer ul.steps_list li .blob {
    color: #444444;
    font-size: 14px;
    font-weight: 300;
    letter-spacing: 0;
    line-height: 20px;
    float:left;
    margin:0 0 0 16px;
    width:calc(100% - 64px)
}
.stepsIndicatorContainer ul.steps_list li .blob b {
    display:inline-block;
    min-width: 20px;
}
.stepsIndicatorContainer ul.steps_list li .blob.step-extra-item-blob br {
    margin: 0 0 6px 0;
}
.stepsIndicatorContainer ul.steps_list li.green .number {
    border-color: var(--cta);
    /*font-family: "Font Awesome 7 Free", serif;
    font-weight: 900;*/
    color: #fff;
}
.stepsIndicatorContainer ul.steps_list li.green .number:before {
    content: '\f00c';
    color: var(--cta);
    padding: 4px;
}
.stepsIndicatorContainer ul.steps_list li.green:hover {
    cursor: pointer;
}
.stepsIndicatorContainer ul.steps_list li.green:hover .number {
    background-color: var(--cta);
    color: var(--cta);
}
.stepsIndicatorContainer ul.steps_list li.green:hover .number:before {
    color: #fff;
}
/* hide the reivew and summary nav items as we don't really need to display them */
.stepsIndicatorContainer ul.steps_list li:last-child,
.stepsIndicatorContainer ul.steps_list li:nth-last-child(2),
.stepsIndicatorContainer ul.steps_list li:last-child .line,
.stepsIndicatorContainer ul.steps_list li:nth-last-child(2) .line,
.stepsIndicatorContainer ul.steps_list li:nth-last-child(3) .line {
    display:none;
}
/************/

.step-review .button-container{
    text-align:center;
}

/** iframe styling **/
body.mode-embed .modal {
    margin-top: 0;
}
body.modal-open header,
body.modal-open .step.active .left-nav,
body.modal-open .step.active .step-input-data .titleBar,
body.modal-open .step.active .step-input-data .introPara,
body.modal-open .step.active .step-input-data .selection-container,
body.modal-open .step.active .step-input-data .fixed-bottom-toolbutton,
body.modal-open .step.active .step-input-data roof-designer .roof-designer:first-of-type,
body.modal-open .step.active .step-input-data .stepsIndicatorContainer,
body.modal-open .step.step-summary {
    filter: blur(8px);
}
body.modal-open .roof-designer.modal {
    isolation: isolate;
}
body.mode-embed .container {
    padding-left:0;
    padding-right:0;
    overflow: visible;
}

/* EPOS landing page */
.epos {
    background: linear-gradient(to bottom, #212830 165px, #E8E9EA 165px);
    margin: 0;
    min-height: 100vh;
}
.epos .validation p {
    padding: 16px 0;
    margin: 16px 0 0 0;
}
.epos form {
    padding: 16px 16px 0 16px;
    margin: 0;
}
.epos form label {
    margin: 0 0 4px 0;
    text-align: left;
    font-weight: 300;
}
.epos form input[type=text],
.epos form input[type=password],
.epos form label,
.epos form button {
    width: 100%;
    max-width: 80%;
}
.epos form input[type=text],
.epos form input[type=password] {
    padding: 8px;
    border: solid 1px #ccc;
    border-radius: 4px;
    display: block;
    margin: 0 auto 8px;
}
.epos form button {
    background-color: var(--second);
    color: #fff;
    margin: 8px 0 0;

}
.epos .container-fluid{padding:0;}
.epos .logo {
    max-width: 300px;
    display: block;
    margin: 32px auto 0 auto;

}
.epos .bottomLeftBgImage {
    position: fixed;
    left: 0;
    bottom: 0;
    z-index: -1;
}
.epos .lightGreyBg {
    background-color: #212830;
}
.epos h1 {
    font-weight: 600;
    font-size: 42px;
    margin:0;
    padding:0;
    color: #202830;
}
.epos h2 {
    font-weight: 400;
    font-size: 24px;
    margin:0;
    padding:0;
    color: #4D5359;
}
.epos h3 {
    font-weight: 600;
    font-size: 18px;
    padding:0;
    color: #4D5359;
}
.epos h3 a{
    color: #4D5359;
}
.epos h5 {
    font-size: 20px;
}
.epos p {
    margin:15px 0 0 0;
    padding:0;
    color: #4D5359;
    font-size:16px;
    font-weight: 300;
}
.epos hr {border-top:1px solid #D2D4D6;}
.epos img.system-logo {
    max-width: 128px;
}
.epos ul{
    list-style-type: none;
    margin-left:0;
    padding-left:0;
}
.epos ul li{
    display: flex;
    align-items: center;
    margin-left:0;
    color: #4D5359;
    font-size: 16px;
}
.epos ul li i {
    width: 18px;
    height: 18px;
    border-radius: 50px;
    font-size: 12px;
    padding: 3px;
    color: black;
    margin-right:10px;
    background-color: #AEEA00;
}
.epos .footer {
    padding: 20px;
    text-align: center;
    margin-top:30px;
}
.epos .footer p{
    color: white;
    margin: 0;
    font-weight: 300;
}
.epos .footer p strong{
    font-weight: 600;
}
.epos .leftContent{margin: 25px auto 25px auto;text-align: left;padding:0 35px 0 35px}
.epos .whiteBox.roundedCorners{
    width: 80%;
    background-color: white;
    border-radius: 8px;
    margin: 25px auto 0 auto;
    display: block;
    text-align: center;
    padding: 25px;
    max-width: 928px;
}
.epos .whiteBox.roundedCorners.lightGreyBg{
    background-color: #F4F4F4;
}
.epos .whiteBox.roundedCorners.shadows{
    box-shadow: 0 0 4px 0 rgba(0,0,0,0.08), 0 8px 8px -4px rgba(0,0,0,0.1);
    overflow: hidden;
}
.epos .bottomPaddingOnly{
    padding: 0 !important;
    padding-bottom:25px !important;
}

.epos .classification {display: inline-block;width: 100%;}
.epos a.button {
    width: calc(100%/3 - 16px);
    border-radius: 8px;
    display: block;
    margin: 0 16px 16px 0;
    font-weight: 600;
    box-shadow: 0 0 4px 0 rgba(0,0,0,0.08), 0 8px 8px -4px rgba(0,0,0,0.1);
    padding: 16px;
    float: left;
    min-height: 105px;
    text-decoration: none;
    outline: 0;
}
.epos a.button:hover {
    box-shadow: 0 0 6px 0 rgba(0,0,0,0.08), 0 10px 16px -4px rgba(0,0,0,0.1);
}
.epos a.button img {
    margin: 0 20px 0 0;
    max-width: 128px;
}
.epos .classification {
    margin: 0;
    border-bottom: solid 1px #eee;
    padding: 32px 0;
}
.epos .classification h2 {
    font-weight: 600;
    font-size: 24px;
    margin: 0 0 8px 0;
}
.epos .classification p {
    font-size: 16px;
    padding-right: 40px;
}
.epos .classification ul,
.epos .classification ul li {
    padding: 0;
    margin: 0;
    list-style: none;
}
.epos .classification .content {
    width: 100%;
    display: inline-block;
    margin: 10px 0 40px;
}
.epos .classification p,
.epos .classification ul {
    width: 50%;
    float: left;
    font-size: 16px;
    text-align: left;
    display: inline-block;
}
.epos .classification ul li:before {
    content: "\f058";
    font-family: "Font Awesome 7 Free", serif;
    margin: 0 8px 0 0;
}
.epos .demo-unavailable {
    opacity: 0.3;
}
.epos .demo-unavailable img,
.epos .demo-unavailable a {
    text-decoration: none;
    cursor: default;
}


/*****************************************************************************/
/* Purchase Order Modal */
/*****************************************************************************/
.modal#modalPurchaseOrder .details {
    border-right: solid 1px #eee;
}
.modal#modalPurchaseOrder h4 {
    margin: -10px 0 15px 0;
    font-size: 16px;
}
.modal#modalPurchaseOrder .toolbar {
    margin: 24px 0 0;
    text-align: right;
}
.modal#modalPurchaseOrder .form-check {
    margin-top: 10px;
}
.modal#modalPurchaseOrder .form-check .fake-radio.checkbox {
    margin-right: 5px;
    top: -4px;
    border-color: #d5d5d5;
}
.modal#modalPurchaseOrder .form-check label {
    width: calc(100% - 30px);
    line-height: 16px;
    float: right;
    margin: 0;
    font-weight: 300;
    font-size: 13px;
}
#modalPurchaseOrder #frmPurchaseOrder .step-summary .fake-radio.checkbox {
    float: left;
    margin: 2px 0 0 3px;
}
#modalPurchaseOrder #frmPurchaseOrder .step-summary .fake-radio.checkbox::before {
    position: relative;
    top: -2px;
    font-size: 12px;
}

/**** Purchase Order Form  ****/
table.purchase-order {
    max-width: 100%;
    margin: 50px 0;
}
table.purchase-order .primary-data td + td {
    border: none;
}
table.purchase-order tbody tr td {
    border: none;
}
table.purchase-order .header {
    font-size: 22px;
    text-transform: uppercase;
}
table.purchase-order .label {
    display: inline-block;
    float: left;
    background-color: transparent;
    color: #333;
    border: none;
}
table.purchase-order table.items thead tr td {
    text-transform: uppercase;
    color: #333;
    background-color: #eee;
}
body .step-container #summary-container #your-kit-container .layer_video_url_container {
    text-align:center;
    padding: 0;
    cursor: pointer;
    margin: 0 0 16px 0;
}
body .step-container .layer_video_url_container i {
    margin-right:5px;
}

/***********************************************************/
/** iframe fixed footer layout **/
body.mode-embed .fixed-bottom-toolbutton {
    padding: 16px 0;
    height: fit-content;
}
body.mode-embed .step .step-input-data {
    margin-bottom: 100px;
}
body.mode-embed .step.step-review {
    margin-bottom: 20px;
}
body.mode-embed .step.step-summary .step-input-data,
body.mode-embed .step.step-review .step-input-data.review-block {
    margin: 0;
}

/** Toggle Switch styling **/
.toggle {
    display: inline-block;
}
.toggle .switch {
    background-color: #ccc;
    border-radius: 8px;
    height: 24px;
    width: 40px;
    cursor: pointer;
    padding: 2px;
}
.toggle .switch button {
    width: 20px;
    height: 20px !important;
    margin: 0 !important;
    padding: 0;
    background-color: #fff;
    border-radius: 7px;
    transition: left 0.1s linear;
    position: relative;
}
.toggle .switch.on {
    background-color: var(--cta);
}
.toggle .switch.on button {
    left: calc(100% - 21px);
}
#kitLoading.kit-loading {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    z-index: 9999;
    padding: 0 32px;
}
#kitLoading.kit-loading .loader {
    font-size: 3rem;
    color: #fff;
    margin-bottom: 1rem;
}
#kitLoading.kit-loading p {
    font-size: 30px;
    text-align: center;
    font-weight: 100;
    color: var(--second);
    margin: 16px 0;
}
/*******************************************************************************************************************************************************************************************/
/** Media Queries **/
/*******************************************************************************************************************************************************************************************/
/** all screen widths <= 992px **/
@media (max-width: 992px) {
    button.select-this-option.horizontal {
        max-width: 100%;
        margin: 4px 0;
    }
    body .step-summary {
        margin-bottom: 150px;
    }
    body.mode-embed .main-container .step.step-summary .step-input-data.basket-summary.primary {
        position: fixed;
        bottom: 0;
        left: 0;
        width: 100%;
        top: auto;
        box-shadow: none;
        margin: 0;
        border-radius: 0;
    }
    body .step-summary .upsellItem[data-selected=true] .left-col::before {
        content: '';
        display: none;
    }
    body .step.step-summary .step-input-data.basket-summary.primary {
        position: fixed;
        bottom: 0;
        z-index: 9999;
        left: 0;
        width: 100%;
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
    }
    body .step-summary .basket-summary-container,
    body .step-summary .tierItem .description {
        min-height: auto;
    }
}

/***************************************************************************/
/** all screen widths <= 767px **/
@media (max-width: 767px) {
    .alert {
        margin-bottom: 35px;
    }
    body {
        overflow: visible;
    }
    body header .logo {
        text-align: center;
    }
    body.modal-open {
        position: fixed;
    }
    body .main-container {
        padding-left: 0;
        padding-right: 0;
    }
    body .main-container .step-container,
    body .main-container .step > .row {
        margin: 0;
    }
    body .step-summary .step-input-data {
        padding: 0;
    }
    body .step-summary .step-input-data.basket {
        margin-bottom: 8px;
    }
    body .step-summary .kit-container .specification,
    body .step-summary .description {
        min-height: auto;
    }
    body .step-summary .tierItem:not(:only-child)  {
        width: 100%;
         margin: 0 0 16px 0;
    }
    body .step-summary .tierItem .product-list li {
        font-size: 12px;
        margin: 0;
    }
    body .step-summary .basket-summary.secondary-buttons button {
        margin-bottom: 8px;
    }
    body .main-container .step .step-input-data {
        box-shadow: none;
        padding: 0;
    }
    body.mode-embed .main-container .step .step-input-data.basket {
        background-color: transparent;
    }
    body .step-review .stepsIndicatorContainer ul.steps_list li {
        padding: 0 16px 16px 16px;
    }
    body .step-review .stepsIndicatorContainer ul.steps_list li .number::before {
        left: 24px;
    }
    body .step-review .stepsIndicatorContainer ul.steps_list li .line {
        left: 38px;
    }
    /** Summary Step **/
    body .step-summary .step-input-data h2 {
        font-size: 24px;
        margin-bottom: 8px;
    }
    body .step-summary .step-input-data p {
        font-size: 15px;
        line-height: 20px;
    }
    body .step-summary .basket-summary.secondary-buttons button {
        width: 100%;
    }
    body .step-summary .step-input-data p {
        margin-bottom: 16px;
    }
    body .step-summary #upsells-container-header {
        margin:0 0 16px 16px;
    }
    body.mode-embed .step-summary #upsells-container-header {
        margin-top: 0;
    }
    body.mode-embed .step-summary .basket-summary.external {
        position: fixed;
        left: 0;
        bottom: 0;
        width: 100%;
        height: fit-content;
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
        box-shadow: none;
        padding: 8px;
    }
    /** Save Kit form */
    #modalSaveKit .modal-dialog {
        width: 100%;
    }
    #modalSaveKit .modal-dialog .modal-content {
        border: none;
        box-shadow: none;
        border-radius: 0;
        height: 100vh;
    }
    .modal-lg {
        width:auto;
    }
    /* Roof Designer */
    body .modal,
    body .roof-designer.modal,
    body .roof-designer.void.modal {
        margin: 0;
        border-radius: 0;
        height: 100vh;
        width: 100%;
        padding: 16px;
    }
    body .modal {
        padding: 0;
    }
    body .roof-designer.modal .input-fields .options {
        column-count: 1;
    }
    body .roof-designer.modal .options button {
        height: 80px;
    }
    body .roof-designer.modal .options img {
        width: 56px;
    }
    body .roof-designer.modal .options p {
        width: calc(100% - 70px);
    }
    /* EPOS */
    .epos a.button img {
        max-width: 100%;
        margin: 10px 0;
    }
    .epos a.button span {
        display: none;
    }
    /* Video Modal */
    body .step-container #modalVideo {
        top: 0 !important;
        z-index: 99999;
    }
    body .step-container #modalVideo .modal-content {
        box-shadow: none;
        border: none;
        height: 100vh;
    }
    body .step-container #modalVideo .modal-footer {
        bottom: 0;
        width: 100%;
    }
}

/***************************************************************************/
/** all screen widths <= 536px **/
@media (max-width: 536px) {
    body .roof-designer .toolbox .tool {
        border-bottom: solid 1px #eee;
    }
    body .roof-designer .toolbox .tool#roofInfo {
        float: left;
    }
    body .roof-designer .toolbox .tool#roofInfo .roof-information {
        left: 0;
    }
    body .roof-designer .toolbox .tool label {
        display: none;
    }
    body .roof-designer .toolbox .tool#membraneCuts {
        width: 50px;
    }
    body .roof-designer .toolbox .tool#addVoid {
        width: 43px;
        padding-right: 0;
    }
}

/***************************************************************************/
/** all screen widths <= 400px **/
@media (max-width: 400px) {
    body .step .fixed-bottom-toolbutton button {
        width: calc(50% - 6px);
        padding: 6px 12px;
    }
    body .step-summary .description ul {
        column-count: 1;
    }
    body #extraItemsContainer.selection-container button.select-this-option .description.hide {
        display: none !important;
    }
    body #extraItemsContainer.selection-container .moreInfo {
        width: calc(100% - 80px - 16px);
        display: inline-block;
    }
    body #extraItemsContainer.selection-container .moreInfo {
        font-weight: 300;
        text-align: left;
        color: #0088c1;
        font-size: 13px;
        float: right;
        height: auto;
        text-decoration: underline;
        cursor: pointer;
    }
    body dialog button {
        padding: 8px;
        font-size: 14px;
    }
    body .roof-designer .toolbox .tool#roofInfo .roof-information {
        left: -150px;
    }
    body .roof-designer.modal .options img {
        width: 48px;
        margin-right: 4px;
    }
    body .roof-designer.modal .options p {
        width: calc(100% - 56px)
    }
}
