: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";}
.fa-arrow-left:before{content:"\f060";}
.fa-arrow-up-right-from-square:before{content:"\f08e";}
.fa-box-open:before{content:"\f49e";}
.fa-arrow-right:before{content:"\f061";}
/* 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;
}
#modalVideo .modal-header,
#modalVideo .modal-body {
  padding: 0;
}
#modalVideo .modal-footer {
  padding: 8px;
}
#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 p.intro {
    margin-bottom: 16px;
}
#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: 4px;
    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.select-this-option:hover {
  cursor: default;
}
#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;
    cursor: pointer;
}
#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;
}

/* 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% );
}
/** Dialog Modal **/
dialog.video {
  height: 400px;
  width: 70%;
}
dialog.video iframe {
  border: none;
  width: 100%;
  height: 300px;
  margin: 0 0 16px 0;
}
/** 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,
#reviewRoofContainer {
    padding: 0;
}
#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 **/
/*****************************************************************************/
body[data-step='step-summary'] {
  background-color: #f6f6f6;
}
body[data-step='step-summary'] .container.main-container {
  max-width: 1323px;
  width: 100%;
}
body.saved .step-summary .tier-item-container h4,
body.saved .step-summary .tier-item-container a,
body.saved .step-summary #upsells-container-header,
body.saved .step-summary #upsells-container-header + p,
body.saved .step-summary .upsellItem a {
  display: none;
}
.step-summary {
    max-width: 1348px;
    width: 100%;
}

.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 16px 0;
    float: left;
    width: 100%;
    min-height: 87px;
}
.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;
}
 #upsells-container-header {
    margin: 28px 0 8px 0;
}
 #upsells-container-header + p {
     color: #8e8e8e;
     line-height: 16px;
     font-size: 14px;
 }
#upsells-container.scrollable i {
  display: none;
}
.step-container #summary-container #your-kit-container h4.choose-layer:before {
    content: 'Step 1.';
    margin: 0 8px 0 0;
}
.step-summary .upsellProductName {
    min-height:50px;
    margin-bottom: 4px !important;
}
.step-summary .step-input-data.basket p.upsellPrice {
    min-height: auto;
    margin-bottom: 0;
}
.step-summary .basket-summary-container {
    position: fixed;
    bottom: 0;
    width: 100vw;
    left: 0;
    min-height: auto;
    background-color: #fff;
    box-shadow: var(--box-shadow);
}
.step-summary .basket-summary.primary {
  width: 100%;
  margin: 0 auto;
  border: none; 
}
/*****************************************************************************/
/** Tier Items/Upsell Items */
/*****************************************************************************/
.step-summary .tierItem,
.upsellItem {
    background-color: #fff;
    border-width: 2px;
    border-style: solid;
    padding: 16px;
    border-radius: 8px;
    margin: 8px 8px 0 0;
    overflow: hidden;
    float:left;
    width: calc(25% - 6px);
}

.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 .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;
}
.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 {
    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;
}
.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 input[type=radio],
.step-summary .fake-radio + input[type=checkbox] {
    display:none;
}
/*************************************************************/
/** Upsell Item **/
.upsellItem {
    padding: 8px;
    transition: all 200ms ease-in;
}
.upsellItem:last-child {
  margin-right: 0;
}
.upsellItem.option-selectable.selected,
.upsellItem:hover {
    background-color: #fff;
    box-shadow: var(--box-shadow);
}
.upsellItem > div {
    float: left;
}
.upsellItem > div:nth-child(1) {
    width: 88px;
}
.upsellItem > div:nth-child(2) {
    width: calc(100% - 88px);
}
.upsellItem img,
.upsellItem .no-image {
    width: 80px;
    height: 80px;
    border-radius: 8px;
    border: solid 1px var(--grey);
    background-color: #fff;
}
.upsellItem .video {
    font-size: 44px;
    position: absolute;
    left: 42px;
    opacity: 0.7;
    cursor: pointer;
    margin-top: 18px;
}
.upsellItem .video.fa-circle-play:before {
    color: #fff;
}
.upsellItem p {
    font-size: 14px;
    font-weight: 300;
    line-height: 16px;
    float: none;
    margin: 0 0 4px 0;
}
.upsellItem p.description {
    font-size: 12px;
}
.upsellItem a {
    width: 100%;
    display: inline-block;
    font-weight: 100;
    text-decoration: underline;
    cursor: pointer;
    margin: 0 0 4px 0;
}
.upsellItem .quantity-container {
    width: 100%;
}
.upsellItem .quantity-container * {
    float: left;
}
.upsellItem .quantity-container button {
    width: 32px;
    height: 32px;
    padding: 4px;
    cursor: pointer;
    border: solid 1px var(--dark-grey);
}
.upsellItem .quantity-container button.disabled:after,
.upsellItem .quantity-container button.disabled:hover {
    color: var(--grey);
    background-color: #fff;
    cursor: default;
    box-shadow: none;
}
.upsellItem .quantity-container button:hover {
    background-color: var(--grey);
}
.upsellItem .quantity-container button:after {
    font-family: "Font Awesome 7 Free", serif;
    content: "\f068";
    font-size: 14px;
    color: #333;
}
.upsellItem .quantity-container button.decrease {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-right: none;
}
.upsellItem .quantity-container button.increase {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-left: none;
}
.upsellItem .quantity-container button.increase:after {
    content: "\2b";
}
.upsellItem .quantity-container div.amount {
    width: 32px;
    height: 32px;
    padding: 5px;
    text-align: center;
    border: solid 1px var(--dark-grey);
    font-weight: 600;
    background-color: #fff;
    cursor: default;
}
.upsellItem dialog {
    width: 350px;
}
.upsellItem .options button {
    border: solid 1px var(--dark-grey);
    font-size: inherit;
    padding: 4px 8px;
    margin: 0 8px 8px 0;
    font-weight: 300;
}
.upsellItem .options button.selected,
.upsellItem .options button.selected:hover {
    background-color: var(--cta-light);
}
.upsellItem .options button:hover {
    background-color: var(--grey);
}
body.saved .upsellItem button {
    display: none;
}
body.saved .upsellItem button.selected {
    display: inline-block;
}
body.saved .upsellItem .quantity-container div.amount {
    border: none;
    text-align: left;
    width: 100%;
    padding: 0;
    height: auto;
}
body.saved .upsellItem .quantity-container div.amount::before {
    content: 'Qty: ';
    font-weight: 600;
    font-size: 14px;
}
/********************************************************************************/

.step-summary .description {
    color: #000;
    font-weight: 300;
    display: inline-block;
    width: 100%;
    font-size: 14px;
}
.step-summary .tierItem .description {
    padding: 0 0 16px 0;
    margin-bottom: 16px;
    margin-top: 8px;
    border-bottom: solid 1px #d6d6d6;
    min-height: 77px;
}
.step-summary .description ul {
    column-count: 2;
    padding: 0 0 0 20px;
}
.step-summary .description ul li {
    line-height: 20px;
    margin-bottom: 12px;
    font-size: 14px;
    padding: 0 10px 0 0;
}
.step-summary dialog {
  padding: 24px 32px;
}
.step-summary dialog h5 {
  font-size: 22px;
  margin: 0 0 16px 0;
}
.step-summary .tierItem.selected .selector .fa-check {
    background-color: var(--cta);
    color: #fff;
    font-size: 13px;
    border-radius: 50px;
    width: 24px;
    height: 24px;
    padding: 5px 0 0 6px;
}
.step-summary .tierItem .price {
    display: block;
    width: 100%;
    line-height: 16px;
    position: relative;
    font-size: 20px;
    margin: 4px 0 0;
}

/** Delivery Info **/
.step-summary .delivery-info {
  float: right;
  margin: 0 24px 0 0;
}
.step-summary .delivery-info p {
  margin: 0 0 4px 0;
  font-size: 14px;
}
.step-summary .delivery-info p i {
  color: var(--cta);
  margin: 0 6px 0;
}
/** ************* **/

.step-input-data .basket-summary {
    display:inline-block;
}
.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 .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: 3px 8px 0 0;
    width: 125px;
    float: right;
    display: inline-block;
    text-align: right;
}
.step-summary .basket-summary .totals {
    width:100%;
    display:inline-block;
}
.step-summary .basket-summary .totals label,
.step-summary .basket-summary .totals div {
    display: inline-block;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 20px;
}
.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 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 {
  width: 100%;
}
.step-summary .basket-summary .totals .total-row.rrp-price * {
    font-size: 16px;
    font-weight: 100;
    text-decoration: line-through;
    color: #333;
}
.step-summary .basket-summary .totals .total-row div.totalPrice {
  width: 125px;
}
.step-summary .basket-summary .totals .total-row .totalPrice.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;
}
#btnSaveKit {
  width: 100%;
  margin-bottom: 16px;
}

.step-summary #btnEditKit {
  border-width: 1px;
  font-weight: 300;
}
.step-summary .basket-summary.secondary-buttons button {
    margin-bottom: 0;
    width: auto;
}
body.saved .step-summary .tierItem.selected,
body.saved .step-summary .upsellItem.selected {
  border-color: #333;
  box-shadow: 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 {
    padding: 16px;
    border-radius:0px;
    border:none;
    box-shadow: none;
    overflow:hidden;
    margin: 0 auto;
}
/**********Step Summary design updates***********/
.step-summary .kit-container .specificationContainer {
    background-color: #fff;
    padding: 8px 16px;
    overflow: hidden;
    max-width: 100%;
    width: 100%;
    border-radius: 8px;
    margin-bottom: 24px;
}
.step-summary .kit-container .specificationContainer h2.titleBar {
    font-size: 22px;
    margin-bottom: 0;
}
.step-summary .kit-container .specification dd {
  margin: 0 0 8px 0;
}
.step-summary .kit-container .specification dt,
.step-summary .kit-container .specification dd {
  font-size: 14px;
  width: 100%;
}
.step-summary .kit-container .specification dt.kit-ref {
  width: initial;
  margin-right: 8px;
}
.step-summary .kit-container .specification dt.kit-ref + dd {
    width: calc(100% - 100px);
}
.step-summary .kit-container .specification dt.kit-ref,
.step-summary .kit-container .specification dt.kit-ref + dd {
  font-size: 16px;
  margin-bottom: 16px;
}
.step-summary .kit-container dd.edgesReadable b {
    display: inline-block;
    min-width: 20px;
}
.step-summary .specificationContainer {
    float:left;
    clear:left;
}
.step-summary .specificationContainer .viewKitImageBtn,
.step-summary .prdInThisKitBtn {
    float:left;
    clear:left;
    border:1px solid #d6d6d6;
    border-radius: 8px;
    color: black;
    font-size:12px;
    font-weight: 300;
    border-radius: 4px;
    padding: 2px 8px;
    margin: 11px 0 0;
}
.step-summary .specificationContainer .viewKitImageBtn i {
    margin-right: 8px;
}

.step-summary .prdInThisKitBtn {
    float:right;
    text-transform: none;
    margin: 0;
}


.step-summary .tier-item-container {
    float:right;
    clear:right;
}
.step-summary .tier-item-container h4 {
    margin: 24px 0 8px 0;
}
.step-summary .tier-item-container a:before {
  content: '\f144';
  font-family: 'Font Awesome 7 Free', serif;
  color: red;
  opacity: 0.7;
  margin-right: 4px;
}
.step-summary .tier-item-container a {
  font-size: 14px;
  color: #8e8e8e;
  line-height: 20px;
  margin-bottom: 16px;
  display: inline-block;
  cursor: pointer;
  width: 100%;
}
.step-summary .tier-item-container a:hover {
  text-decoration: none; 
  color: #333;
}
.step-summary .tier-item-container a:hover:before {
  opacity: 1;
}
.step-summary .step-input-data.basket .titleBar,
.step-summary .step-input-data.basket .introPara,
.step-summary .step-input-data.basket .note{
    display:none;
}

.step-summary #your-kit-container .specificationContainer .titleBar,
.step-summary #your-kit-container .specificationContainer .introPara,
.step-summary #your-kit-container .specificationContainer .note{
    display:block;
}
.step-summary #btnBuyKit {
    width:40%;
    float:right;
    clear:right;
}
.step-summary .basket-summary #btnEditKit {
    width: 140px;
    padding: 16px 0 0 16px;
    border: none;
    text-align: left;
}
.step-summary .basket-summary #btnEditKit:hover {
  background-color: #fff;
}
.step-summary .basket-summary #btnEditKit i {
  margin: 0 8px 0 0; 
}
.step-summary .basket-summary .subtotalPrice {
    font-size:14px !important;
    font-weight: 100;
    display: inline-block;
    text-align: right;
}
#loader_btnBuyKit {
    float:right;
    clear:right;
    width:40%;
}
/*****************************************************************************/

.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;
}

body.mode-embed .step.step-summary .basket-summary.primary {
  border: solid 1px var(--grey);
  border-top: none;
  margin: 0;
}

/** 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;
}

/* 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;
}
.whats-the-difference {
  cursor: pointer;
  font-weight: 100;
  color: var(--tertiary);
  font-size: 20px;
}

/** 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 **/
/*******************************************************************************************************************************************************************************************/
@media (max-width: 1200px) {
  .upsellItem {
    width: calc(33% - 4px);
  }
  .upsellItem:nth-child(3) {
    margin-right: 0;
  }
}
@media (width > 991px) and (width < 1220px) {
    .step-summary .specificationContainer #btnSaveKit,
    .step-summary .specificationContainer .viewKitImageBtn {
        float:none;
        width: 100%;
        margin-top:10px;
    }
}
/** all screen widths < 1071px **/
@media (width < 1071px) {
    body .step-summary .basket-summary #btnEditKit  {
        width: 18px;
        padding: 16px 0 0;
    }
    body .step-summary #btnEditKit span.editThisKit {
        display:none;
    }
}
/** all screen widths <= 992px **/
@media (width < 992px) {
    button.select-this-option.horizontal {
        max-width: 100%;
        margin: 4px 0;
    }
    body .step-summary {
        margin-bottom: 150px;
        max-width: none;
        width:100%;
    }
    body[data-step='step-summary'] .container.main-container {
        width:100%;
    }
    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;
        box-shadow: var(--box-shadow);
    }
    body .step-summary .basket-summary-container,
    body .step-summary .tierItem .description {
        min-height: auto;
    }
    body .step-summary .specificationContainer {
      height: 80px;
    }
    body.saved .step-summary .specificationContainer {
      margin-bottom: 16px;
    }
    body .step-summary .specificationContainer dl.specification {
        margin-bottom:0px;
        min-height: auto;
    }
    body .step-summary .specificationContainer .viewKitImageBtn {
        display:none;
    }
    body .step-summary .specificationContainer dl.specification dt,
    body .step-summary .specificationContainer dl.specification dd {
        display:none;
    }
    body .step-summary .specificationContainer dl.specification dt.kit-ref,
    body .step-summary .specificationContainer dl.specification dt.kit-ref + dd {
        display:block;
        margin-bottom: 0;
    }
    body .step-summary .specificationContainer .titleBar,
    body .step-summary .specificationContainer dl.specification {
        max-width: 60%;
    }
    body .step-summary .specificationContainer #btnSaveKit {
        float:right;
        clear:right;
        position: relative;
        top: -25px;
        width: 40%;
    }
    body .step-summary .specificationContainer .specification dt.kit-ref + dd {
        margin-bottom:0px;
    }
    body .step-summary .tier-item-container h4 {
        margin-top: 16px;
    }
    body .step-summary .tier-item-container .tierItem {
        width:100%;
        margin-bottom:16px;
    }
}

/***************************************************************************/
/** all screen widths <= 767px **/
@media (max-width: 767px) {
    .alert {
        margin-bottom: 35px;
    }
    body .upsellItem dialog {
      width: inherit;
    }
    body dialog {
      height: 100vh;
      margin: 0;
      border: 0;
      border-radius: 0;
      max-width: 100%;
      width: 100%;
      position: fixed;
    }
    body roof-designer dialog {
      transform: none;
      height: fit-content;
      margin: auto;
      max-width: 100%;
      width: calc(100% - 16px);
    }
    body dialog.video {
      transform: none;
      width: calc(100% - 32px);
      top: 15%;
      margin: 0 auto;
    }
    body .step-summary .kit-container .description ul {
      column-count: 1;
    }
    body .kit-container dialog button.outline {
      position: absolute;
      bottom: 0;
      right: 0;
      margin: 16px;
    }
    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.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.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,
    body #modalRoofImage{
        top: 0 !important;
        z-index: 99999;
    }
    body .step-container #modalVideo .modal-content,
    body #modalRoofImage .modal-content{
        box-shadow: none;
        border: none;
        height: 100vh;
    }
    body .step-container #modalVideo .modal-footer,
    body #modalRoofImage .modal-footer{
        bottom: 0;
        width: 100%;
    }

    /*************************************************************/
    /** Upsell Item for Mobile with carousel **/
    .upsells-container {
        border: solid 1px #d9d9d9;
        padding: 12px 16px;
        background-color: #fff;
        border-radius: 8px;
        width: calc(100% - 30px);
        margin-left: 15px;
    }
    body.saved .upsells-container {
      padding: 0;
      border: none;
      background-color: transparent;
    }
    #upsells-container-header {
        margin: 0 0 12px;
    }
    #upsells-container {    
        overflow-x: scroll;
    }
    #upsells-container > div {
        display: inline-flex;
        width: max-content;
    }
    #upsells-container.scrollable i {
      display: inline-block;
      color: #888;
      position: absolute;
      background-color: rgba(255, 255, 255, 0.7);
      padding: 8px;
      top: 50%;
      right: 8px;
      border-radius: 50px;
      backdrop-filter: blur(2px);
    }
    .upsellItem {
        border-width: 1px;
        margin: 0 8px 0 0 !important;
    }
    body.saved .upsellItem {
      border-width: 2px;
    }
    .upsellItem,
    .upsells-container .upsellItem div {
        width: 100%;
        max-width: 140px;
    }
    .upsellItem img {
        margin: 0 50%;
        translate: -50% 0%;
    } 
    .upsellItem p {
        margin-top: 8px;        
    }
    .upsellItem p:first-of-type {
        height: 48px;
    }
    .upsellItem a {
        margin-bottom: 16px;
    }
    /*************************************************************/
  body .step-summary .delivery-info {
    margin: 24px 0 0;
    width: 100%;
    text-align: center;
  }
  body .step-summary .delivery-info p {
    font-size: 14px;
  }
}

/***************************************************************************/
/** 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;
    }
    body.saved .step-summary p.kit-locked {
      margin-top: 16px;
    }
    body .step-summary .kit-container .specificationContainer h2.titleBar {
      font-size: 19px;
    } 
    body .step-summary .kit-container .specification dt.kit-ref + dd {
      width: calc(100% - 80px);
    }
    body .step-summary .kit-container .specificationContainer {
        position: fixed;
        top: 0;
        left: 0;
        height: 77px;
        box-shadow: var(--box-shadow);
        z-index: 9999;
        border-radius: 0;
    }
    body .step-summary .basket-summary #total-container {
        width:123px !important;
    }
    .step-summary #btnBuyKit {
        width: 60%;
    }
    #loader_btnBuyKit {
        width:60%;
    }
}

/***************************************************************************/
/** all screen widths <= 400px **/
@media (max-width: 420px) {
  body .step-summary #btnBuyKit {
    width: 50%;
  }
  body .step .fixed-bottom-toolbutton button {
      width: calc(50% - 6px);
  }
  body .step-summary .description ul {
      column-count: 1;
  }
  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)
  }
}
/***************************************************************************/
/** all screen widths <= 360px **/
@media (max-width: 360px) {
}
