:root {
    --active-wood-color : '';
    --active-wood-color-horizontal : '';
    --color-black: #1e1e1e;
    --color-bronze: #53472e;
    --color-silver: #6b6969;
    --color-active: var(--color-black);
    --zoom: 1;
}

#configurator {
    position: relative;
    max-width: 1200px;
    margin: 0px auto;
    margin-top: 50px;
    height: calc(100% - 100px);
    background: #f9f9f9;
    display: flex;
    border-radius: 20px;
    overflow: hidden;
}

#configurator textarea,
#configurator  input {
    background: #f5f2ef;
    outline: none;
    border: 1px solid #e8e3df;
    padding: 10px 15px;
    border-radius: 3px;
    box-sizing: border-box;
    transition: border 500ms, box-shadow 500ms;
    width: 100%;
    text-align: center;
    font-size: 14px;
    position: relative;
}

#configurator textarea:focus,
#configurator input:focus {
    border: 1px solid #DB9B53;
    box-shadow: 0px 5px 10px rgba(219, 155, 83, 0.30);
    background: #fbe9d5;
}

#configurator textarea {
    text-align: left;
    outline: none;
    height: 150px;
    margin-bottom: 15px;
    font-family: Roboto;
    font-size: 13px;
}

#configurator > #categories {
    position: relative;
    flex: 1 0 40%;
    overflow-y: auto;
    box-sizing: border-box;
    padding: 30px 30px 100px 30px;
    border-right: 1px solid #eee;
}

#configurator > #categories > .category {
    background: white;
    border-radius: 10px;
    box-sizing: border-box;
    box-shadow: 0px 5px 20px rgba(0, 0, 0, 0.05);
    position: relative;
    margin-bottom: 25px;
}

#configurator > #categories > .category > .header {
    height: 95px;
    border-bottom: 1px solid #eee;
}

#configurator > #categories > .category > .header > .step {
    position: absolute;
    width: 26px;
    height: 26px;
    border-radius: 100px;
    background: #DB9B53;
    color: white;
    text-align: center;
    box-sizing: border-box;
    font-size: 14px;
    font-weight: 500;
    padding-top: 5px;
    margin-left: 20px;
    margin-top: 15px;
}

#configurator > #categories > .category > .header > .title {
    position: absolute;
    margin-left: 60px;
    font-size: 20px;
    font-weight: 600;
    margin-top: 16px;
}

#configurator > #categories > .category > .header > .description {
    position: absolute;
    margin-left: 60px;
    font-size: 14px;
    margin-top: 45px;
    line-height: 18px;
    color: #777;
    width: calc(100% - 80px);
}

#configurator > #categories > .category > .content {
    padding: 20px 25px 10px 25px;
}

#configurator > #categories > .category > .content .title {
    font-size: 16px;
    margin-bottom: 10px;
    font-weight: 500;

}

#configurator > #categories > .category > .content .options {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 20px;
    position: relative;
}

#configurator > #categories > .category > .content .options > .disabled {
    position: absolute;
    z-index: 1;
    width: calc(100% + 20px);
    height: calc(100% + 20px);
    background: rgba(255, 255, 255, .7);
    text-align: center;
    box-sizing: border-box;
    padding-top: 55px;
    backdrop-filter: blur(2px);
    font-weight: 500;
    display: none;
    top: -10px;
    left: -10px;
}

#configurator > #categories > .category > .content .options > .option {
    flex: 1 0;
    margin-right: 15px;
    background: #f5f2ef;
    border: 1px solid #f5f2ef;
    cursor: pointer;
    position: relative;
    height: 103px;
    border-radius: 3px;
    min-width: 100px;
    margin-bottom: 15px;
    transition: background-color 250ms, border 250ms, box-shadow 250ms;
}



#configurator > #categories > .category > .content .options > .option > .disabled {
    position: absolute;
    z-index: 1;
    width: calc(100% + 20px);
    height: calc(100% + 20px);
    background: rgba(255, 255, 255, .7);
    text-align: center;
    box-sizing: border-box;
    padding-top: 55px;
    backdrop-filter: blur(2px);
    font-weight: 500;
    display: none;
    top: -10px;
    left: -10px;
}

#configurator > #categories > .category > .content .options.x2 > .option {
    min-width: 130px;
}

#configurator > #categories > .category > .content .options.x4 > .option {
    min-width: 70px;
}

#configurator > #categories > .category > .content .options > .option:nth-child(3n),
#configurator > #categories > .category > .content .options > .option:last-of-type {
    margin-right: 0px;
}

#configurator > #categories > .category > .content .options.x4 > .option:nth-child(4n),
#configurator > #categories > .category > .content .options.x2 > .option:nth-child(2n){
    margin-right: 15px;
}

#configurator > #categories > .category > .content .options.x4 > .option:nth-child(3n) {
    margin-right: 7px;
}

#configurator > #categories > .category > .content .options.x4 > .option:nth-child(4n),
#configurator > #categories > .category > .content .options.x4 > .option:last-of-type {
    margin-right: 0px;
}

#configurator > #categories > .category > .content .options > .option .frame-thumb {
    height: 60px; width: 28px;
    background: rgba(255, 255, 255, 0.4);
    position: relative;
    display: inline-block;
    border: 2px solid black;
    left: 50%;
    transform: translateX(-50%);
    margin-top: 20px;
}

#configurator > #categories > .category > .content .options > .option .frame-thumb > .bar {
    background: black;
    position: absolute;
}

#configurator > #categories > .category > .content .options > .option .frame-thumb > .bar.horizontal {
    width: 100%;
    height: 2px;
}

#configurator > #categories > .category > .content .options > .option .frame-thumb > .bar.vertical {
    width: 2px;
    height: 100%;
}


#configurator > #categories > .category > .content .options > .option > i {
    position: absolute;
    right: 7px;
    top: 7px;
    font-size: 16px;
    opacity: .3;
    color: #817466;
    display: none;
}

#configurator > #categories > .category > .content .options > .option > i:hover {
    opacity: .7;
}

#configurator > #categories > .category > .content .options > .option.selected {
    background: #fbe9d5;
    box-shadow: 0px 5px 10px rgba(219, 155, 83, 0.30);
    font-weight: 500;
    border: 1px solid #e19f55;
}

#configurator > #categories > .category > .content .options > .option > img {
    width: 50px;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    margin-top: 15px;
    opacity: .4;
}

#configurator > #categories > .category > .content .options > .option.selected > img {
    opacity: .8;
}

#configurator > #categories > .category > .content .options > .option > img.rounded {
    width: 50px;
    height: 50px;
    border-radius: 50px;
    margin-top: 15px;
}


#configurator > #categories > .category > .content .options > .option > .bronze {
    width: 50px;
    height: 50px;
    position: absolute;
    left: 50%;
    background: rgb(153, 128, 100);
    transform: translateX(-50%);
    margin-top: 15px;
    border-radius: 50px;
}

#configurator > #categories > .category > .content .options > .option > .ral {
    width: 50px;
    height: 50px;
    position: absolute;
    left: 50%;
    background: linear-gradient(
            90deg,
            rgba(255, 0, 0, 1) 0%,
            rgba(255, 154, 0, 1) 10%,
            rgba(208, 222, 33, 1) 20%,
            rgba(79, 220, 74, 1) 30%,
            rgba(63, 218, 216, 1) 40%,
            rgba(47, 201, 226, 1) 50%,
            rgba(28, 127, 238, 1) 60%,
            rgba(95, 21, 242, 1) 70%,
            rgba(186, 12, 248, 1) 80%,
            rgba(251, 7, 217, 1) 90%,
            rgba(255, 0, 0, 1) 100%
    );
    transform: translateX(-50%);
    margin-top: 15px;
    border-radius: 50px;
}


#configurator > #categories > .category > .content .options > .option > .name {
    width: 100%;
    position: absolute;
    bottom: 15px;
    text-align: center;
}

#configurator > #categories > .category > .content table th,
#configurator > #categories > .category > .content table td {
    font-size: 14px;
    padding: 5px;
}

#configurator > #preview {
    flex: 1 0 60%;
    perspective: 600px;
    overflow: hidden;
}

#configurator > #preview > #watermark {
    position: absolute;
    z-index: 20;
    width: 23%;
    top: 5%;
    left: 5%;
    display: none;
}

#configurator > #preview > #touch {
    touch-action: none;
    user-select: none;
    position: absolute;
    z-index: 10;
    left: 0px;
    top: 0px;
    width: 100%;
    height: 100%;
}

#configurator > #preview > #custom_button {
    position: absolute;
    z-index: 100;
    top: 10px;
    right: 10px;
    background: #597ab9;
    padding: 7px 10px;
    border-radius: 5px;
    color: white;
    cursor: pointer;
    font-size: 14px;
}

#configurator > #preview > #custom_button > i {
    margin-right: 3px;
}

#configurator > #preview > #options {
    position: absolute;
    z-index: 100;
    bottom: 10px;
    right: 10px;
}

#configurator > #preview > #options > .option {
    display: inline-block;
    margin-right: 3px;
    height: 30px;
    width: 30px;
    border-radius: 3px;
    box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.2);
    background: white;
    overflow: hidden;
}

#configurator > #preview > #options > .option:hover {
    height: auto;
}

#configurator > #preview > #options > .option > .item {
    height: 30px;
    width: 30px;
    box-sizing: border-box;
    display: none;
    cursor: pointer;
}

#configurator > #preview > #options > .option > .item > .thumb {
    position: absolute;
    width: 26px;
    height: 26px;
    margin-left: 2px;
    margin-top: 2px;
    border-radius: 3px;
}

#configurator > #preview > #options > .option:hover > .item,
#configurator > #preview > #options > .option > .item.selected {
    display: block;
}

#configurator > #preview > #render {
    transform-style: preserve-3d;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 800px;
    height: 800px;
    transform: translate(calc(-50% + 20px), calc(-50% + 30px)) rotateY(10deg) scale(var(--zoom));
}

#configurator > #preview > #render.swivel {
    animation: render-swivel 15s infinite ease-in-out alternate;
}

@keyframes render-swivel {
    from {
        transform: translate(calc(-50%), calc(-50% + 30px)) rotateY(10deg) scale(var(--zoom));
    }

    to {
        transform: translate(calc(-50%), calc(-50% + 30px)) rotateY(-10deg) scale(var(--zoom));
    }
}

#configurator > #preview > #render > #floor {
    position: absolute;
    width: 2000px;
    height: 1200px;
    transform: rotateX(90deg);
    margin-left: -800px;
}

#configurator > #preview > #render > #floor.visgraat {
    background: url(/img/floors/visgraat.jpg) center;
}

#configurator > #preview > #render > #floor.beton {
    background: linear-gradient(0deg, #d5d5d5, #ababab);
    background-size: auto;
}

#configurator > #preview > #render > #wall {
    position: absolute;
    width: 1200px;
    height: 600px;
    margin-left: -200px;
}

#configurator > #preview > #render > #background {
    position: absolute;
    width: 2600px;
    height: 1000px;
    margin-top: -400px;
    margin-left: -900px;
    background: linear-gradient(0deg, #c7baab 50%, transparent 100%);
    transform: translateZ(-600px);
}

#configurator > #preview > #render > #background.blurred {
    filter: blur(6px);
}

#configurator > #preview > #render > #background > .watermark {
    position: absolute;
    top: 600px;
    left: 880px;
}

#configurator > #preview > #render > #wall > .left {
    width: 500px;
    height: 100%;
    background: linear-gradient(90deg, #f1eae1, #d5c7b5);
    position: absolute;
}

#configurator > #preview > #render.animate > #wall > .left {
    transition: width 1s;
}

#configurator > #preview > #render > #wall > .right {
    width: 500px;
    height: 100%;
    background: linear-gradient(90deg, #cbbca8, #b9a78f);
    position: absolute;
    margin-left: 700px;
}

#configurator > #preview > #render > #wall > .right > .ruler {
    position: absolute;
    left: 15px;
    border-top: 2px solid black;
    padding-top: 5px;
    text-align: center;
    margin-left: 15px;
    transform: rotate(-90deg);
    transition: width 1s;
    transform-origin: left;
    bottom: 0px;
    z-index: 1;
}

#configurator > #preview > #render.animate > #wall > .right {
    transition: width 1s, margin-left 1s;
}

#configurator > #preview > #render > #wall > .top {
    width: 200px;
    height: 70px;
    background: linear-gradient(90deg, #d5c7b5, #cbbca8);
    position: absolute;
}

#configurator > #preview > #render > #wall > .top > .ruler {
    position: absolute;
    bottom: 15px;
    width: calc(100% + 10px);
    border-bottom: 2px solid black;
    text-align: center;
    margin-left: -5px;
    padding-bottom: 5px;
}

#configurator > #preview > #render.animate > #wall > .top {
    transition: width 1s, height 1s, margin-left 1s;
}

#configurator > #preview > #render > #wall > .left > .plint,
#configurator > #preview > #render > #wall > .right > .plint,
#configurator > #preview > #render > #background > .plint {
    position: absolute;
    height: 33px;
    background: linear-gradient(359deg, #e3e3e3, #dfdfdf);
    width: 100%;
    bottom: 0px;
    box-shadow: 0px 0px 0px 2px hwb(0deg 0% 100% / 10%)
}

#configurator > #preview > #render > .panel {
    position: absolute;
    width: 170px;
    height: 440px;
    left: 50%;
    margin-top: 160px;
    transform-style: preserve-3d;
    background: rgba(255, 255, 255, 0.35);
    display: none;
}

#configurator > #preview > #render > .panel.taats {

}

#configurator > #preview > #render.animate > .panel {
    transition: margin-left 1s, width 1s, height 1s, margin-top 1s, border-bottom-width 1s;
}



#configurator > #preview > #render > .panel > .reflection {
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: 0;
    background: url(/img/reflection.png) no-repeat left top;
}

#configurator > #preview > #render > #frame {
    position: absolute;
    width: 200px;
    height: 440px;
    left: 50%;
    transform: translateX(-50%);
    margin-top: 160px;
    transform-style: preserve-3d;
    border-top-right-radius: 3px;
    border-top-left-radius: 3px;
}

#configurator > #preview > #render.animate > #frame {
    transition: width 1s, height 1s, margin-top 1s;
}

#configurator > #preview > #render > #frame.bordered {
    border: 6px solid var(--color-active);
    border-bottom: 0px;
}

#configurator > #preview > #render > #frame.profile {
    top: -6px;
    border: 12px solid var(--color-active);
    border-bottom: 0px;
}

#configurator > #preview > #render > .panel.profile {
    top: -6px;
    border: 12px solid var(--color-active);
    border-bottom: 8px solid var(--color-active);
}

#configurator > #preview > #render > #frame > .slide-left {
    height: 10px;
    background-color: var(--color-active);
    position: absolute;
    transform: translate(-50%, -10px);
    display: none;
}

#configurator > #preview > #render > #frame > .slide-right {
    height: 10px;
    background-color: var(--color-active);
    position: absolute;
    transform: translate(0%, -10px);
    display: none;
}

#configurator > #preview > #render > #frame > .door {
    position: absolute;
    height: 100%;
    width: 200px;
    box-sizing: border-box;
    border-radius: 3px;
}

#configurator > #preview > #render > .panel .border-1,
#configurator > #preview > #render > #frame > .door .border-1 {
    background: var(--active-wood-color-horizontal);
    position: absolute;
    height: 20px;
    width: 100%;
    z-index: 1;
    background-position: center;
    border-top-left-radius: 3px;
    border-top-right-radius: 3px;
}

#configurator > #preview > #render > .panel .border-2,
#configurator > #preview > #render > #frame > .door .border-2 {
    background: var(--active-wood-color-horizontal);
    position: absolute;
    height: 20px;
    width: 100%;
    z-index: 1;
    bottom: 0px;
    background-position: center;
    border-bottom-right-radius: 3px;
    border-bottom-left-radius: 3px;
}

#configurator > #preview > #render > .panel .border-3,
#configurator > #preview > #render > #frame > .door .border-3 {
    background: var(--active-wood-color);
    position: absolute;
    height: 100%;
    width: 10px;
    right: 0px;
    z-index: 1;
    background-position: center;
}

#configurator > #preview > #render > .panel .border-4,
#configurator > #preview > #render > #frame > .door .border-4 {
    background: var(--active-wood-color);
    position: absolute;
    height: 100%;
    width: 10px;
    left: 0px;
    z-index: 1;
    background-position: center;
}

#configurator > #preview > #render > .panel > .frame,
#configurator > #preview > #render > #frame > .door > .frame {
    position: absolute;
    width: 100%;
    height: 100%;
}

#configurator > #preview > #render > .panel > .frame.flip,
#configurator > #preview > #render > #frame > .door > .frame.flip {

    transform: rotateY(180deg);
}

#configurator > #preview > #render > #frame > .door.pivot-right > .frame {
    transform: rotateY(180deg);
}

#configurator > #preview > #render.animate > #frame > .door {
    transition: transform 2s, box-shadow 1s, width 1s, opacity 500ms;
}

#configurator > #preview > #render > #frame > .door.glass-blanco,
#configurator > #preview > #render > .panel.glass-blanco {
    background: linear-gradient(7deg, rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.05));
}

#configurator > #preview > #render > #frame > .door.glass-gray,
#configurator > #preview > #render > .panel.glass-gray{
    background: linear-gradient(7deg, rgba(0, 0, 0, 0.4), rgba(0, 0, 0, 0.20));
}

#configurator > #preview > #render > #frame > .door.glass-black,
#configurator > #preview > #render > .panel.glass-black {
    background: rgba(40, 40, 40, 1);
}

#configurator > #preview > #render > #frame > .door.glass-bronze,
#configurator > #preview > #render > .panel.glass-bronze {
    background: linear-gradient(7deg, rgba(87, 70, 34, 0.41), rgba(87, 70, 34, 0.20));
}

#configurator > #preview > #render > .panel.glass-mat-blanco,
#configurator > #preview > #render > #frame > .door.glass-mat-blanco {
    background: rgb(167 167 167 / 50%);
}

#configurator > #preview > #render > .panel.glass-mat-gray,
#configurator > #preview > #render > #frame > .door.glass-mat-gray {
    background: rgba(66, 66, 66, 0.6);
}

#configurator > #preview > #render > .panel.glass-mat-black,
#configurator > #preview > #render > #frame > .door.glass-mat-black {
    background: rgba(40, 40, 40, 1);
}

#configurator > #preview > #render > .panel.glass-canele,
#configurator > #preview > #render > #frame > .door.glass-canele {
    background-image: repeating-linear-gradient(90deg, rgba(209, 215, 220, 0.49), rgba(112, 138, 143, 0.35) 5px);
}

#configurator > #preview > #render > .panel.glass-mat-bronze,
#configurator > #preview > #render > #frame > .door.glass-mat-bronze {
    background: rgba(121, 99, 59, 0.6);
}


#configurator > #preview > #render > #frame > .door > .reflection {
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: 0;
    background: url(/img/reflection.png) no-repeat left top;
}

#configurator > #preview > #render > #frame > .door.pivot-left {
    transform-origin: left;
}

#configurator > #preview > #render > #frame > .door.pivot-right {
    transform-origin: right;
    right: 0px;
}

/** HINGE */
#configurator > #preview > #render > #frame > .door.pivot-left.hinge.open {
    transform: rotateY(-40deg);
    box-shadow: 0px 30px 30px rgba(0, 0, 0, 0.2);
}

#configurator > #preview > #render > #frame > .door.pivot-right.hinge.open {
    transform: rotateY(40deg);
    box-shadow: 0px 30px 30px rgba(0, 0, 0, 0.2);
}

/** HINGE */
#configurator > #preview > #render > #frame > .door.pivot-left.slide.open {
    transform: translateX(-100%);
    box-shadow: 0px 0px 30px rgba(0, 0, 0, 0.2);
}

#configurator > #preview > #render > #frame > .door.pivot-right.slide.open {
    transform: translateX(100%);
    box-shadow: 0px 0px 30px rgba(0, 0, 0, 0.2);
}


/** TAATS */
#configurator > #preview > #render > #frame > .door.pivot-left.taats {
    transform-origin: 25px 0px;
}

#configurator > #preview > #render > #frame > .door.pivot-right.taats {
    transform-origin: calc(100% - 25px) 0px;
}

#configurator > #preview > #render > #frame.profile > .door.slide,
#configurator > #preview > #render > #frame.profile > .door.taats {
    height: calc(100% - 6px);
}

#configurator > #preview > #render > #frame > .door.pivot-left.taats.open {
    transform: rotateY(-40deg);
}

#configurator > #preview > #render > #frame > .door.pivot-right.taats.open {
    transform: rotateY(40deg);
}

#configurator > #preview > #render > #frame > .door.pivot-left.taats.open.inset {
    transform: rotateY(40deg);
}

#configurator > #preview > #render > #frame > .door.pivot-right.taats.open.inset {
    transform: rotateY(-40deg);
}

#configurator > #preview > #render > .panel > .frame,
#configurator > #preview > #render > #frame > .door > .frame {
    display: none;
}

#configurator > #preview > #render > .panel > .frame > .bar,
#configurator > #preview > #render > #frame > .door > .frame > .bar {
    position: absolute;
}

#configurator > #preview > #render > .panel > .frame > .bar.horizontal,
#configurator > #preview > #render > #frame > .door > .frame > .bar.horizontal {
    width: 100%;
    height: 7px;
    background: var(--active-wood-color-horizontal);
    background-position: center;
}

#configurator > #preview > #render > .panel > .frame > .bar.vertical,
#configurator > #preview > #render > #frame > .door > .frame > .bar.vertical {
    width: 7px;
    height: 100%;
    background: var(--active-wood-color);
    background-position: center;
}

#configurator > #image {
    position: absolute;
    width: 500px;
    height: 500px;
    z-index: 4;
    background: white;
    border-radius: 30px;
    box-shadow: 0px 10px 30px rgba(0, 0, 0, 0.2);
    margin-left: calc(40% - 20px);
    margin-top: 100px;
    display: none;
    border: 4px solid white;
    background-size: cover;
    background-position: center;
}

#configurator > #image:after {
    right: 100%;
    top: 50%;
    border: solid transparent;
    content: "";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
    border-color: rgba(136, 183, 213, 0);
    border-right-color: #ffffff;
    border-width: 20px;
    margin-top: -20px;
}

#configurator > #footer {
    text-align: center;
    position: absolute;
    bottom: 0px;
    z-index: 5;
    width: 450px;
    background: #f7efe8;
    padding: 12px 15px 15px 15px;
    font-size: 14px;
}

#configurator > #footer > #button_quote_popup {
    margin-top: 7px;
}

.button-primary {
    background: #db9b53;
    color: white;
    font-weight: 600;
    text-align: center;
    padding: 10px 0px;
    text-shadow: 0px 1px 3px rgba(0, 0, 0, 0.4);
    font-size: 18px;
    cursor: pointer;
    box-shadow: 0px 5px 10px rgba(219, 155, 83, 0.30);
}

.button-primary:hover {
    background: #e3aa6a;
}

#custom {
    font-size: 16px;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 275px;
    padding: 30px;
    background: white;
    box-shadow: 0px 10px 30px rgba(0, 0, 0, 0.3);
    z-index: 10;
    border-radius: 15px;
    transform: translate(-50%, -50%);
    display: none;
}

#custom > i {
    position: absolute;
    right: 0px;
    background: black;
    padding: 10px 12px;
    border-radius: 40px;
    color: white;
    font-size: 17px;
    top: 0px;
    transform: translate(50%, -50%);
    cursor: pointer;
}

#custom > .title {
    text-align: center;
    font-size: 26px;
    font-weight: 800;
    margin-bottom: 20px;
}


#quote {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 275px;
    padding: 30px;
    background: white;
    box-shadow: 0px 10px 30px rgba(0, 0, 0, 0.3);
    z-index: 10;
    border-radius: 15px;
    transform: translate(-50%, -50%);
    display: none;
}

#quote > i {
    position: absolute;
    right: 0px;
    background: black;
    padding: 10px 12px;
    border-radius: 40px;
    color: white;
    font-size: 17px;
    top: 0px;
    transform: translate(50%, -50%);
    cursor: pointer;
}

#quote > .title {
    text-align: center;
    font-size: 26px;
    font-weight: 800;
    margin-bottom: 20px;
}

#quote > .input-name {
    font-size: 16px;
    margin-bottom: 5px;
    font-weight: 600;
}

#quote > input {
    margin-bottom: 15px;
}


/* RAL PICKER */
#ralPicker {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 350px;
    padding: 30px;
    background: white;
    box-shadow: 0px 10px 30px rgba(0, 0, 0, 0.3);
    z-index: 10;
    border-radius: 15px;
    transform: translate(-50%, -50%);
    display: none;
}

#ralPicker > i {
    position: absolute;
    right: 0px;
    background: black;
    padding: 10px 12px;
    border-radius: 40px;
    color: white;
    font-size: 17px;
    top: 0px;
    transform: translate(50%, -50%);
    cursor: pointer;
}

#ralPicker > .title {
    text-align: center;
    font-size: 26px;
    font-weight: 800;
    margin-bottom: 20px;
}

#ralPicker > .options {
    height: 500px;
    overflow-y: auto;
    display: flex;
    flex-wrap: wrap;
}

#ralPicker > .options > .option {
    flex: 1 0;
    max-width: 60px;
    height: 70px;
    min-width: 50px;
    margin: 5px;
    text-align: center;
    cursor: pointer;
}

#ralPicker > .options > .option > .preview {
    aspect-ratio: 1 / 1;
    border-radius: 100%;
}

/* BRONZE PICKER */
#bronzePicker {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 350px;
    padding: 30px;
    background: white;
    box-shadow: 0px 10px 30px rgba(0, 0, 0, 0.3);
    z-index: 10;
    border-radius: 15px;
    transform: translate(-50%, -50%);
    display: none;
}

#bronzePicker > i {
    position: absolute;
    right: 0px;
    background: black;
    padding: 10px 12px;
    border-radius: 40px;
    color: white;
    font-size: 17px;
    top: 0px;
    transform: translate(50%, -50%);
    cursor: pointer;
}

#bronzePicker > .title {
    text-align: center;
    font-size: 26px;
    font-weight: 800;
    margin-bottom: 20px;
}

#bronzePicker > .options {
    height: 500px;
    overflow-y: auto;
    display: flex;
    flex-wrap: wrap;
}

#bronzePicker > .options > .option {
    flex: 1 0;
    max-width: 60px;
    height: 70px;
    min-width: 50px;
    margin: 5px;
    text-align: center;
    cursor: pointer;
}

#bronzePicker > .options > .option > .preview {
    aspect-ratio: 1 / 1;
    border-radius: 100%;
}

/* PREVIEW */
#configurator.preview > #preview > #options,
#configurator.preview > #categories,
#configurator.preview > #footer,
#configurator.preview > #preview > #custom_button {
    display: none;
}

#configurator.preview > #preview > #watermark {
    display: block;
}

#configurator.preview {
    border-radius: 0px;
    width: 100%;
    height: 100%;
    max-width: 1000px;
    max-height: 600px;
    margin: 0px;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}


/* width */
::-webkit-scrollbar {
    width: 5px;
}

/* Track */
::-webkit-scrollbar-track {
    background: #f1f1f1;
}

/* Handle */
::-webkit-scrollbar-thumb {
    background: #888;
}

/* Handle on hover */
::-webkit-scrollbar-thumb:hover {
    background: #555;
}



@media (max-width: 1000px) {
    #configurator {
        max-width: 1200px;
        margin-top: 0px;
        height: 100%;
        display: inherit;
        border-radius: 0px;
    }

    #configurator > #footer {
        width: 100%;
        box-sizing: border-box;
        padding: 1px 5px 5px 5px;
        box-shadow: 0px -4px 10px rgba(0, 0, 0, 0.2);
    }

    #configurator > #footer > .label {
        display: none;
    }

    #configurator > #preview {
        position: absolute;
        width: 100%;
        top: 0px;
        left: 0px;
        height: 260px;
        border-bottom: 3px solid black;
    }

    #configurator > #categories {
        position: absolute;
        width: 100%;
        left: 0px;
        top: 260px;
        height: calc(100% - 310px);
        padding: 15px;
    }

    #configurator > #categories > .category > .content {
        padding: 10px 15px 10px 15px;
    }

    #configurator > #categories > .category > .content > .options > .option {
        margin-right: 7px;
        min-width: 80px;
        margin-bottom: 5px;
    }

    #configurator > #categories > .category > .content > .options > .option > i {
        display: none;
    }

    #bronzePicker,
    #ralPicker {
        position: absolute;
        left: 50%;
        top: 50%;
        width: 260px;
        padding: 20px;
    }

    #configurator > #preview > #render {
        transform: translate(calc(-50% + 30px), calc(-50% + 20px)) rotateY(10deg) scale(var(--zoom));
    }

    @keyframes render-swivel {
        from {
            transform: translate(calc(-50%), calc(-50% + 20px)) rotateY(10deg) scale(var(--zoom));
        }

        to {
            transform: translate(calc(-50%), calc(-50% + 20px)) rotateY(-10deg) scale(var(--zoom));
        }
    }

    #configurator > #categories > .category > .header > .title {
        font-size: 16px;
        margin-top: 18px;
    }
}