/* selector */
.selector-wrapper {
    position: relative;
    aspect-ratio: 1920/936;
    max-height: 936px;
    overflow: hidden;
    /*max-width: 1920px;*/
    /*margin: 0 auto;*/
}

.selector {
    position: relative;
    width: 100%;
    aspect-ratio: 1920/1080;
    z-index: 1;
    /*height: 100%;*/
}

#selector {
    height: inherit;
    position: relative;
    overflow: hidden;
    /*
    max-height: 895px;
    position: relative;
    overflow: hidden;
     */
}


#selector #flats-layer {
    display: none;
    z-index: 10;
}

#selector  #flats-background {
    z-index: 11;
    background-color: rgba(0,0,0,0.5);
}

#selector  #flat-areas {
    z-index: 12;
}

#selector-image {
    width: 100%;
    /*height: 100%;*/
    /*object-fit: cover;*/
    z-index: 1;
    pointer-events: none;
}

.selector .layer {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 2;
}

#selector svg {
    width: 100%;
    height: auto;
}

#selector-buildings-wrapper {
    z-index: 5;
    position: relative;
}

#selector-buildings-covers {
    z-index: 6;
}

#selector-buildings {
    z-index: 9;
}

#selector-floors-wrapper {
    z-index: 10;
    display: none;
}


.building-floors {
    display: none;
}
.building-floors.active {
    display: block;
}



.floor-info {
    position: absolute;
    display: block;
    bottom: 4%;
    left: 0;
    /*right: 5%;*/
    width: 100%;
    text-align: center;
    opacity: 0;
    transition-duration: 0.3s;
    transition-property: opacity;
    z-index: 8;
    color: #fff;
    /*width: 420px;*/
    pointer-events: none;
    /*font-size: 125%;*/
}

.flat-info-row {
    position: absolute;
    display: block;
    bottom: 14.5%;
    right: 5%;
    width: 100%;
    text-align: center;
    opacity: 0;
    transition-duration: 0.3s;
    transition-property: opacity;
    z-index: 8;
    color: #fff;
    /*width: 420px;*/
    pointer-events: none;
    /*font-size: 125%;*/
}


.floor-info.active {
    opacity: 1;
}
.flat-info-row.active {
    opacity: 1;
}

#flat-info-row.flat-info-row {
    opacity: 1;
    z-index: 13;
    display: block;
}

.floor-titles {
    pointer-events: none;
    display: block;
    z-index: 14;
}

.floor-info .title, .floor-info .status {
    font-size: 120%;
    font-weight: var(--font-medium);
    letter-spacing: 0.07em;
    color: #fff;
    position: relative;
}

.floor-info .title strong {
    font-weight: var(--font-bold);
}

.floor-info .title span:not(.triangle), .floor-info .status span:not(.triangle) {
    color: var(--color-green);
    position: relative;
    padding: 0 6px;
}

.floor-info .title span.triangle {
    display: inline-block;
    width: 0;
    height: 0;
    border-left: 8px solid var(--color-green);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    margin: 0 4px;
    transform: translateY(-2px);
}

.floor-info .status {
    margin-top: 6px;
}

.floor-label {
    position: absolute;
    z-index: 7;
    opacity: 0;
    transition-duration: 0.3s;
}

.floor-label.active {
    opacity: 1;
}

.floor-label .button {
    background-color: var(--color-green);
    color: #000;
    min-width: 160px;
    box-sizing: border-box;
    font-weight: var(--font-bold);
}


#floor-name > div {
    display: none;
}

#floor-name > div.active {
    display: block;
}

.floor-info .disp {
    margin-top: 40px;
    font-weight: var(--font-semibold);
}

.floor-info .disp span.bullet, .floor-info .status span.bullet, #flat-info .bullet {
    display: inline-block;
    margin: 0 6px;
    position: relative;
    color: var(--color-green);
}



/* SVG */
#selector #floor-areas {
    z-index: 6;
}

#floor-areas-gs g {
    opacity: 0;
}

#floor-covers g {
    /*opacity: 0;*/
    transition-duration: 0.3s;
}





g.flat-bg {
    z-index: 10;
}

g.flat-walls {
    z-index: 12;
}


#flats-layer-close, #floors-layer-close {
    display: inline-block;
    position: absolute;
    top: 16.6%;
    right: 40px;
    text-decoration: none;
    z-index: 15;
    transition-duration: 0.3s;
    text-transform: uppercase;
    color: #000;
    background-color: var(--color-green);
}


#flats-layer-close:hover, #floors-layer-close:hover {
    background-color: var(--color-tyrkys);
    color: #fff;
}


#flats-layer-open {
    display: inline-block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #fff;
    background-color: var(--color-tyrkys);
    z-index: 10;
    transition-duration: 0.3s;
    text-transform: uppercase;
    padding: 5px 20px;
}

#template-selector-image-floor {
    z-index: 12;
    position: relative;
}

.floor-link {
    text-align: right;
}


#flat-info-row .floor-link a {
    color: #fff;
    text-decoration: none;
    font-size: 200%;
    display: inline-block;
    position: relative;
    pointer-events: auto;
    text-align: right;
}

#flat-info-row .floor-link a:hover {
    color: var(--color-green);
}

#flat-info-row .floor-link a:after {
    display: inline-block;
    content: "";
    width: 0;
    height: 0;
    border-bottom: 13px solid var(--color-green);
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    transform-origin: center center;
    margin-left: 20px;
    margin-bottom: 3px;
    position: relative;
    /*position: absolute;*/
    /*top: 0;*/
    /*right: 50%;*/
    /*transform: translate(-50% , -5px ) rotate(-45deg);*/
}

#flat-info-row .floor-link a#lower-floor:after {
    border-bottom: 0;
    border-top: 13px solid var(--color-green);
}

#flat-info {
    color: #fff;
    font-size: 200%;
    text-align: right;
    /*letter-spacing: 0.07em;*/
    margin-top: 30px;
    margin-bottom: 30px;
    line-height: 1.4;
}

#flat-info .name {
    font-weight: var(--font-bold);
    color: var(--color-green)
}

#flat-info .disptext, #flat-info .area {
    color: inherit;
    font-weight: var(--font-medium);
}

#flat-info .status {
    color: var(--color-tyrkys);
    font-weight: var(--font-medium);
}
#flat-info .status1 {
    color: var(--color-green);
}


.floor-ident {
    position: absolute;
    display: block;
    z-index: 7;
    opacity: 0;
    right: 0;
    bottom: 0;
    border-top-right-radius: 12px;
    border-bottom-right-radius: 12px;
    width: 70px;
    height: 40px;
    line-height: 40px;
    text-align: center;
    font-size: 112.5%;
    font-weight: var(--font-medium);
    background-color: #fff;
    transition-duration: 0.3s;
}

.floor-ident:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    border-right: 20px solid #fff;
    border-top: 20px solid transparent;
    border-bottom: 20px solid transparent;
    transform: translateX(-20px);
}

.floor-ident.active {
    opacity: 1;
}


g.floors {
    display: none;
}

g.floors.active {
    display: block;
}

g.flat-cover-covers {
    z-index: 11;
    position: absolute;
}

g.flat-covers g {
    /*z-index: 11;*/
    fill-opacity: 1;
    transition-duration: 0.5s;
}

g.flat-covers g.active {
    fill-opacity: 1;
}

g.flat-areas {
    z-index: 13;
    position: absolute;
    cursor: pointer;
}




/* selector buildings */
#selector-buildings-svg g polygon,
#selector-buildings-svg g path,
#selector-buildings-svg g rect
{
    opacity: 0;
}


#selector-buildings-svg g.active polygon,
#selector-buildings-svg g.active path,
#selector-buildings-svg g.active rect
{
    stroke-width: 5;
    stroke-opacity: 1;
    stroke: var(--color-tyrkys);
    fill: transparent;
    opacity: 1;
}

#selector-buildings-svg g:hover {
    cursor: pointer;
}

#building-active-overlay {
    opacity: 0;
    background-color: rgba(0,0,0,0.6);
    transition-duration: 0.3s;
}

#building-active-overlay.active {
    opacity: 1;
}

#selector-buildings-covers > div {
    opacity: 0;
    transition-duration: 0.3s;
}

#selector-buildings-covers > div.active {
    opacity: 1;
}

#selector-buildings-covers .building-title {
    box-sizing: border-box;
    font-weight: bold;
    margin-top: 0;
}



#selector-buildings-covers .building-desc {
    position: absolute;
    font-weight: var(--font-medium);
    background-color: #bacc9e;
    color: #687958;
    border-radius: 100%;
    width: 170px;
    height: 170px;
    display: flex;
    flex-flow: column nowrap;
    justify-content: center;
    align-items: center;
}

#selector-buildings-covers .building-capacity {
    text-transform: uppercase;
    text-align: center;
}



/* selector floors */
.building-floors g polygon,
.building-floors g path,
.building-floors g rect
{
    opacity: 0;
    transition-duration: 0.3s;
    fill: var(--color-green);
    fill-opacity: 0.6;
}

.building-floors g.active polygon,
.building-floors g.active path,
.building-floors g.active rect
{
    opacity: 1;
    cursor: pointer;
}






#building-A1-cover .building-desc { left: 8%; top: 32% }
#building-A2-cover .building-desc { left: 21%; top: 33% }
#building-A3-cover .building-desc { left: 34%; top: 34% }
#building-A4-cover .building-desc { left: 47%; top: 35% }
#building-E4-cover .building-desc { right: 27%; top: 34% }
#building-B-cover .building-desc { right: 12%; top: 32% }


#A1-1NP-floorlabel, #A2-1NP-floorlabel, #A3-1NP-floorlabel, #A4-1NP-floorlabel { left: 6.5%; top: 79% }
#A1-2NP-floorlabel, #A2-2NP-floorlabel, #A3-2NP-floorlabel, #A4-2NP-floorlabel { left: 6.5%; top: 67.5% }
#A1-3NP-floorlabel, #A2-3NP-floorlabel, #A3-3NP-floorlabel, #A4-3NP-floorlabel { left: 6.5%; top: 56% }
#A1-4NP-floorlabel, #A2-4NP-floorlabel, #A3-4NP-floorlabel, #A4-4NP-floorlabel { left: 6.5%; top: 44.5% }
#A1-5NP-floorlabel, #A2-5NP-floorlabel, #A3-5NP-floorlabel, #A4-5NP-floorlabel { left: 6.5%; top: 32% }
#B-1PP-floorlabel { left: 12%; top: 84% }
#B-1NP-floorlabel { left: 12%; top: 79% }
#B-2NP-floorlabel { left: 12%; top: 74% }
#B-3NP-floorlabel { left: 12%; top: 68% }
#B-4NP-floorlabel { left: 12%; top: 62.5% }
#B-5NP-floorlabel { left: 12%; top: 57% }
#B-6NP-floorlabel { left: 12%; top: 51.5% }
#B-7NP-floorlabel { left: 12%; top: 46% }
#B-8NP-floorlabel { left: 12%; top: 40.5% }
#B-9NP-floorlabel { left: 12%; top: 35% }
#B-10NP-floorlabel { left: 12%; top: 29.5% }
#E4-1PP-floorlabel { left: 5%; top: 79% }
#E4-1NP-floorlabel { left: 5%; top: 67.5% }
#E4-2NP-floorlabel { left: 5%; top: 56% }
#E4-3NP-floorlabel { left: 5%; top: 44.5% }
#E4-4NP-floorlabel { left: 10%; top: 32% }



@media screen and (max-width: 1520px ) {
    #flats-layer-close {
        top: 20%;
    }
    .capacities {
        border-radius: 12px;
        padding: 4px 16px;
        font-size: 100%;
    }
}

@media screen and (max-width: 1280px ) {
    .floor-info .title, #floor-name {
        font-size: 200%;
    }
    .floor-ident {
        width: 60px;
        height: 32px;
        line-height: 32px;
        font-size: 100%;
        transition-duration: 0.3s;
    }
    .floor-ident:before {
        border-right: 16px solid #fff;
        border-top: 16px solid transparent;
        border-bottom: 16px solid transparent;
        transform: translateX(-16px);
    }

    .floor-info {
        bottom: 60px;
        width: 360px;
        font-size: 100%;
    }
}

@media screen and (max-width: 1280px) {
    .selector-wrapper {
        display: none;
    }
}


@media screen and (max-width: 1150px ) {
    .floor-info {
        width: 300px;
    }
    #flats-layer-close {
        top: 23%;
    }
}

@media screen and (max-width: 1023px ) {
    .selector, #selector {
    }

    #selector #selector-buildings { display: none; }

    #selector {
        #flats-layer-close { display: none; }
        #floors-layer-close { display: none; }
        #flat-info-row { display: none; }
        .floor-link { display: none; }
        .flat-areas { display: none; }
    }


    /*#selector #floor-areas { display: none; }*/
    /*#selector #flats-background { display: none; }*/
    /*#selector #flats-layer { display: none; }*/
    /*#selector #flats-layer-close { display: none; }*/
    /*#selector .flat-areas { display: none; }*/
    /*#selector #floor-covers { display: none; }*/

    #selector-image {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .selector-wrapper.detail , .selector-wrapper.detail  .selector, .selector-wrapper.detail  #selector  {
        height: 50vw;
    }

    /*#selector #flat-info-row,*/
    /*#selector #flat-areas,*/
    /*#selector .notices*/
    /*{*/
    /*    display: none;*/
    /*}*/
}

@media screen and (max-width: 900px ) {
    #selector {
        margin-top: 100px;
    }
    .capacities {
        display: none;
    }
}


@media screen and (max-width: 600px) {
    .building-button {
        font-size: 187.5%;
        width: 50px;
        height: 50px;
        line-height: 50px;
    }
}


/* selector flats */
.flat-covers g
{
    polygon, path, rect {
        opacity: 1;
        transition-duration: 0.3s;
        fill: #D2E391;
        fill-opacity: 1;
    }

    &.active {
        polygon, path, rect {
            fill: var(--color-tyrkys);
        }
    }

    &.status2 {
        polygon, path, rect {
            fill: #8a8a8a;
        }
    }
    &.status3 {
        polygon, path, rect {
            fill: #8a8a8a;
        }
    }
    &.status4 {
        polygon, path, rect {
            fill: #8a8a8a;
        }
    }
    &.status5 {
        polygon, path, rect {
            fill: #ccc;
        }
    }
    &.statusnull {
        polygon, path, rect {
            fill: #fff;
        }
    }
}




.flat-covers g polygon,
.flat-covers g path,
.flat-covers g rect {
    opacity: 1;
    transition-duration: 0.3s;
    fill: #D2E391;
    fill-opacity: 1;
}

.flat-covers g.active polygon,
.flat-covers g.active path,
.flat-covers g.active rect {
    fill: var(--color-green);
}
.flat-covers g.statusnull polygon,
.flat-covers g.statusnull path,
.flat-covers g.statusnull rect {
    fill: #fff;
}
.flat-covers g.status2 polygon,
.flat-covers g.status2 path,
.flat-covers g.status2 rect {
    fill: #8a8a8a;
}
.flat-covers g.status3 polygon,
.flat-covers g.status3 path,
.flat-covers g.status3 rect {
    fill: #8a8a8a;
}
.flat-covers g.status4 polygon,
.flat-covers g.status4 path,
.flat-covers g.status4 rect {
    fill: #8a8a8a;
}
.flat-covers g.status5 polygon,
.flat-covers g.status5 path,
.flat-covers g.status5 rect {
    fill: #ccc;
}


.flat-areas g  polygon,
.flat-areas g  path,
.flat-areas g  rect {
    fill: transparent;
    fill-opacity: 1;
}

