/*====================================
DESKTOP HIDE MOBILE MENU
====================================*/

.mobile-menu-btn,
.mobile-menu,
.mobile-close{

    display:none;

}

/*==================================================
        MUOSIR MOBILE V2
        PART 1
==================================================*/

@media screen and (max-width:992px){
    .mobile-menu-btn{

    display:flex;

}

/*====================================
BODY
====================================*/

body{

    padding-top:72px;

    overflow-x:hidden;

}

/*====================================
HEADER
====================================*/

.navbar{

    height:72px;

    padding:0 18px;

    display:flex;

    align-items:center;

    justify-content:space-between;

}

.brand{

    display:flex;

    align-items:center;

    gap:12px;

    flex:1;

    padding-top:6px;

}

.mobile-menu-btn{

    margin-left:auto;

}

.brand h2{

    display:block;

    color:#fff;

    font-size:18px;

    font-weight:700;

    white-space:nowrap;

    margin:0;

    line-height:1.2;

    position:relative;

    top:3px;

}

.logo{

    width:46px;

    height:46px;

    flex-shrink:0;

}

/* скрываем десктопное меню */

.navbar nav{

    display:none;

}

/*====================================
MOBILE BUTTON
====================================*/

.mobile-menu-btn{

    display:flex;

    width:46px;

    height:46px;

    align-items:center;

    justify-content:center;

    border:none;

    border-radius:12px;

    background:#D4AF37;

    color:#111;

    font-size:22px;

    cursor:pointer;

}

/*====================================
MOBILE MENU
====================================*/

.mobile-menu{

    position:fixed;

    top:0;

    right:-100%;

    width:320px;

    max-width:90%;

    height:100vh;

    background:#0B1F38;

    display:flex;

    flex-direction:column;

    padding:90px 25px 30px;

    transition:right .35s ease;

    z-index:99999;

}

.mobile-menu.show{

    right:0;

}

.mobile-close{

    position:absolute;

    top:20px;

    right:20px;

    width:46px;

    height:46px;

    display:flex;

    align-items:center;

    justify-content:center;

    border:none;

    border-radius:50%;

    background:#D4AF37;

    color:#111;

    font-size:24px;

    cursor:pointer;

    z-index:100000;

}

.mobile-menu a{

    color:#fff;

    text-decoration:none;

    padding:18px 0;

    font-size:18px;

    border-bottom:1px solid rgba(255,255,255,.08);

}

.mobile-menu hr{

    border:none;

    border-top:1px solid rgba(255,255,255,.12);

    margin:20px 0;

}

/*====================================
HERO
====================================*/

.hero{

    height:100vh;

    min-height:680px;

    padding-top:0;

}

.hero::before{

    background:

    linear-gradient(

        180deg,

        rgba(7,9,13,.35),

        rgba(7,9,13,.60),

        rgba(7,9,13,.95)

    );

}

.hero-text{

    position:absolute;

    left:0;

    right:0;

    width:100%;

    padding:0 22px;

    top:110px;

    bottom:auto;

    transform:none;

}

.hero-label{

    font-size:11px;

    padding:8px 14px;

    margin-bottom:18px;

}

.hero-text h1{

    font-size:34px;

    line-height:1.1;

}

.hero-description{

    margin-top:12px;

    font-size:15px;

    line-height:1.6;

}

.hero-features{

    display:grid;

    grid-template-columns:1fr;

    gap:14px;

    margin:28px 0;

}

.hero-feature{

    padding:14px;

    border-radius:16px;

    background:rgba(255,255,255,.05);

}

.hero-buttons{

    display:flex;

    flex-direction:column;

    gap:14px;

}

.hero-buttons .btn{

    width:100%;

    height:54px;

}

.hero-social{

    margin-top:24px;

}

.hero-social-icons{

    justify-content:center;

}

/*====================================
FOOTER
====================================*/

.footer{

    padding:55px 20px;

}

.footer h2{

    text-align:center;

    font-size:28px;

}

.footer p{

    text-align:center;

}

.social-links{

    justify-content:center;

    flex-wrap:wrap;

    gap:16px;

}

.social-links a{

    margin:0;

}

.map-box{

    margin-top:25px;

}

.map-box iframe{

    height:280px !important;

    width:100%;

}

}
/*==================================================
        MUOSIR MOBILE V2
        PART 2
==================================================*/

@media screen and (max-width:992px){

/*====================================
SECTIONS
====================================*/

.container,
.about,
.advantages,
.site-map{

    width:100%;

    padding-left:18px;

    padding-right:18px;

}

.section-header{

    margin-bottom:35px;

}

.section-title{

    font-size:32px;

    line-height:1.2;

}

.section-subtitle{

    font-size:16px;

    line-height:1.7;

}

/*====================================
ABOUT
====================================*/

.about{

    padding-top:60px;

    padding-bottom:60px;

}

.about h2{

    font-size:30px;

}

.about p{

    font-size:16px;

    line-height:1.8;

}

/*====================================
ADVANTAGES
====================================*/

.advantages{

    padding:30px 20px;

    border-radius:24px;

}

.advantages h2{

    font-size:30px;

    text-align:center;

}

.advantages-grid{

    grid-template-columns:1fr;

    gap:18px;

}

.advantage-card{

    padding:24px;

}

.advantage-card i{

    font-size:38px;

}

.advantage-card h3{

    font-size:20px;

}

.advantage-card p{

    font-size:15px;

}

/*====================================
MASTERPLAN
====================================*/

.site-map{

    padding:20px;

    border-radius:22px;

}

.site-map h2{

    font-size:28px;

}

.site-map-text{

    font-size:15px;

    margin-bottom:22px;

}

#map{

    border-radius:18px;

    overflow:hidden;

}

/*====================================
3D MODEL
====================================*/

#blocksContainer{

    width:75%;

    left:50%;

    bottom:8%;

}

#masterModel{

    height:230px;

}

/*====================================
FLOOR BUTTONS
====================================*/

#floorsLeft{

    left:8px;

    top:55%;

    transform:translateY(-50%);

}

#floorsRight{

    right:8px;

    left:auto;

    top:55%;

    transform:translateY(-50%);

}

.floor-btn{

    width:48px;

    height:28px;

    font-size:11px;

    border-radius:8px;

}

/*====================================
APARTMENT INFO
====================================*/

#apartmentInfo{

    position:relative;

    top:auto;

    right:auto;

    width:100%;

    margin-top:20px;

    border-radius:18px;

}

#apartmentInfo h2{

    font-size:22px;

}

#apartmentInfo p{

    font-size:14px;

}

/*====================================
FLOOR VIEWER
====================================*/

#floorHeader{

    padding:0 15px;

}

#floorTitle{

    font-size:20px;

}

#closeFloor{

    width:40px;

    height:40px;

}

.floorImage{

    max-width:100%;

}

/*====================================
APARTMENT BUTTONS
====================================*/

#apartmentsLayer{

    display:grid;

    grid-template-columns:repeat(2,1fr);

    gap:12px;

}

.apartmentButton{

    min-width:100%;

    height:50px;

    font-size:15px;

}

}
/*==================================================
        MUOSIR MOBILE V2
        PART 3
        APARTMENTS
==================================================*/

@media screen and (max-width:992px){

/*====================================
PAGE
====================================*/

.apartments-page{

    margin:25px auto;

    padding:0 16px;

}

.apartments-wrapper{

    display:flex;

    flex-direction:column;

    gap:22px;

}

/*====================================
FILTER
====================================*/

.apartments-filter{

    position:static;

    width:100%;

    padding:20px;

    border-radius:20px;

}

.filter-header{

    margin-bottom:18px;

}

.filter-header h2{

    font-size:22px;

}

.apartments-filter label{

    margin-top:16px;

    margin-bottom:8px;

    font-size:15px;

}

.apartments-filter select,

.apartments-filter input{

    width:100%;

    height:48px;

    font-size:15px;

    border-radius:12px;

}

/*====================================
RIGHT SIDE
====================================*/

.apartments-content{

    width:100%;

}

.apartments-topbar{

    display:flex;

    flex-direction:column;

    gap:15px;

    align-items:stretch;

    margin-bottom:20px;

}

#sortApartments{

    width:100%;

    height:48px;

}

/*====================================
GRID
====================================*/

.apartments-grid{

    display:grid;

    grid-template-columns:1fr;

    gap:24px;

}

/*====================================
CARD
====================================*/

.apartment-card{

    display:flex;

    flex-direction:column;

    height:auto;

    border-radius:22px;

    overflow:hidden;

    background:#fff;

}

.apartment-image{

    width:100%;

    height:240px;

}

.apartment-image img,

.apartment-image .object-img{

    width:100%;

    height:100%;

    object-fit:cover;

}

/*====================================
STATUS
====================================*/

.status-badge{

    top:14px;

    left:14px;

    padding:8px 14px;

    font-size:13px;

}

/*====================================
INFO
====================================*/

.apartment-info{

    padding:20px;

}

.apartment-header{

    display:flex;

    flex-direction:column;

    align-items:flex-start;

    gap:10px;

}

.apartment-title{

    font-size:20px !important;

    line-height:1.3;

}

.apartment-price{

    font-size:28px;

    font-weight:700;

}

/*====================================
META
====================================*/

.apartment-meta{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:14px;

    margin:18px 0;

}

.meta-item{

    padding:10px;

    border-radius:12px;

    background:#f7f8fa;

}

.meta-item i{

    font-size:16px;

}

.meta-item span{

    font-size:14px;

}

/*====================================
BUTTON
====================================*/

.card-btn,

.apartment-btn{

    width:100%;

    height:52px;

    border-radius:12px;

    justify-content:center;

    font-size:16px;

    margin-top:10px;

}

/*====================================
PAGINATION
====================================*/

.pagination{

    margin-top:30px;

    display:flex;

    justify-content:center;

    flex-wrap:wrap;

    gap:10px;

}

.pagination a,

.pagination span{

    width:42px;

    height:42px;

    display:flex;

    align-items:center;

    justify-content:center;

    border-radius:10px;

}

/*====================================
EMPTY
====================================*/

.empty-results{

    padding:50px 20px;

    text-align:center;

}

.empty-results h3{

    font-size:22px;

}

.empty-results p{

    font-size:15px;

}

}
/*==================================================
        MUOSIR MOBILE V2
        PART 4
        APARTMENT DETAIL
==================================================*/

@media screen and (max-width:992px){

/*====================================
PAGE
====================================*/

.detail-page{

    padding:20px 16px 50px;

}

.detail-layout{

    display:flex;

    flex-direction:column;

    gap:25px;

    padding:0;

}

.detail-sidebar{

    display:none;

}

.detail-main{

    width:100%;

    min-width:0;

}

/*====================================
HEADER
====================================*/

.detail-header{

    display:flex;

    flex-direction:column;

    align-items:flex-start;

    gap:18px;

}

.back-btn{

    width:100%;

    justify-content:center;

}

/*====================================
GALLERY
====================================*/

.detail-gallery{

    gap:14px;

}

.gallery-main{

    border-radius:20px;

    overflow:hidden;

}

.gallery-main img{

    width:100%;

    height:260px;

    object-fit:cover;

}

.gallery-thumbs{

    display:flex;

    gap:10px;

    overflow-x:auto;

    padding-bottom:4px;

}

.gallery-thumb{

    width:78px;

    height:62px;

    border-radius:10px;

    overflow:hidden;

    flex:none;

}

.gallery-thumb img{

    width:100%;

    height:100%;

    object-fit:cover;

}

/*====================================
PRICE
====================================*/

.apartment-price-bar{

    display:flex;

    flex-direction:column;

    gap:18px;

    padding:22px;

    border-radius:20px;

}

.price-row{

    display:flex;

    flex-direction:column;

    align-items:flex-start;

    gap:12px;

}

.price-main{

    font-size:34px;

    line-height:1;

}

.price-somoni{

    font-size:16px;

}

.price-right{

    width:100%;

}

.installment-btn{

    width:100%;

    height:54px;

    justify-content:center;

}

/*====================================
SUMMARY
====================================*/

.apartment-summary{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:14px;

}

.summary-item{

    padding:16px;

    border-radius:14px;

}

.summary-item strong{

    font-size:17px;

}

.summary-item span{

    font-size:13px;

}

/*====================================
DETAIL CARD
====================================*/

.detail-card{

    padding:22px;

    border-radius:20px;

}

.detail-card h2{

    font-size:24px;

    margin-bottom:18px;

}

/*====================================
TABLE
====================================*/

.detail-table{

    display:block;

}

.detail-table tbody{

    display:block;

}

.detail-table tr{

    display:block;

    margin-bottom:18px;

    padding-bottom:18px;

    border-bottom:1px solid #ececec;

}

.detail-table td{

    display:block;

    width:100%;

    padding:4px 0;

}

.detail-table td:first-child{

    color:#888;

    font-size:13px;

}

.detail-table td:last-child{

    font-size:16px;

    font-weight:600;

}

/*====================================
FEATURES
====================================*/

.features-grid{

    display:grid;

    grid-template-columns:1fr;

    gap:14px;

}

.feature-item{

    padding:16px;

    border-radius:14px;

}

/*====================================
PLAN
====================================*/

.plan-preview{

    border-radius:18px;

    overflow:hidden;

}

.plan-preview img{

    width:100%;

    height:auto;

}

.plan-button{

    width:100%;

    height:54px;

}

/*====================================
MODEL
====================================*/

model-viewer{

    width:100%;

    height:320px !important;

}

/*====================================
DOCUMENTS
====================================*/

.document-list{

    display:flex;

    flex-direction:column;

    gap:12px;

}

.document-btn{

    width:100%;

    justify-content:flex-start;

    min-height:52px;

}

/*====================================
SIMILAR
====================================*/

.similar-grid{

    display:grid;

    grid-template-columns:1fr;

    gap:22px;

}

/*====================================
CONTACT
====================================*/

.contact-box{

    padding:22px;

}

.contact-buttons{

    display:flex;

    flex-direction:column;

    gap:14px;

}

.contact-buttons a{

    width:100%;

    justify-content:center;

}

/*====================================
STICKY BUY
====================================*/

.mobile-buy-bar{

    position:fixed;

    left:0;

    right:0;

    bottom:0;

    background:#fff;

    padding:14px;

    box-shadow:0 -8px 25px rgba(0,0,0,.12);

    z-index:999;

}

.mobile-buy-bar .installment-btn{

    margin:0;

}

}
/*==================================================
        MUOSIR MOBILE V2
        PART 5
        FINAL
==================================================*/

@media screen and (max-width:992px){

/*====================================
CALCULATOR
====================================*/

.calculator-modal{

    position:fixed;

    top:0;

    left:0;

    right:0;

    bottom:0;

    display:none;

    align-items:flex-end;

    justify-content:center;

    padding:0;

    background:rgba(0,0,0,.55);

    z-index:999999;

}

.calculator-box{

    overflow-y:auto;

    position:relative;

}

.calculator-close{

    position:fixed;

    top:90px;

    right:28px;

    width:46px;

    height:46px;

    border-radius:50%;

    z-index:100001;

}

.calc-row{

    display:grid;

    grid-template-columns:1fr;

    gap:16px;

}

.calculator-box select,

.calculator-box input{

    height:52px;

    font-size:16px;

}

#calcResult{

    margin-top:20px;

}

#calcResult h3{

    font-size:19px;

}

#calcResult p{

    font-size:15px;

}

/*====================================
FORMS
====================================*/

input,
select,
textarea{

    font-size:16px;

}

textarea{

    min-height:120px;

}

/*====================================
BUTTONS
====================================*/

.btn,
button,
.card-btn,
.details-btn,
.plan-button,
.installment-btn{

    min-height:52px;

}

/*====================================
WHATSAPP
====================================*/

.floating-whatsapp{

    width:58px;

    height:58px;

    right:16px;

    bottom:16px;

    font-size:30px;

}

/*====================================
MAP
====================================*/

#map{

    width:100%;

    height:auto !important;

    aspect-ratio:16/9;

    overflow:hidden;

    border-radius:18px;

}

#masterplanImage{

    width:100%;

    height:100%;

    display:block;

    object-fit:cover;

}

.leaflet-control-container{

    transform:scale(.92);

    transform-origin:right bottom;

}

/*====================================
TABLES
====================================*/

table{

    display:block;

    overflow-x:auto;

    width:100%;

}

table::-webkit-scrollbar{

    height:6px;

}

/*====================================
IMAGES
====================================*/

img{

    max-width:100%;

    height:auto;

}

iframe{

    max-width:100%;

}

/*====================================
TEXT
====================================*/

h1{

    font-size:34px;

}

h2{

    font-size:28px;

}

h3{

    font-size:22px;

}

p{

    line-height:1.7;

}

/*====================================
SAFE AREA
====================================*/

body{

    padding-bottom:env(safe-area-inset-bottom);

}

.footer{

    padding-bottom:calc(35px + env(safe-area-inset-bottom));

}

/*====================================
OVERFLOW FIX
====================================*/

html,
body{

    overflow-x:hidden;

}

.container,
.detail-container,
.detail-layout,
.apartments-wrapper,
.site-map,
.about,
.advantages{

    max-width:100%;

}

*{

    word-wrap:break-word;

}

/*====================================
ANIMATION
====================================*/

.card,
.apartment-card,
.advantage-card,
.detail-card{

    transition:.3s;

}

}

/*====================================
PHONE
====================================*/

@media screen and (max-width:576px){

.hero{

    min-height:620px;

}

.hero-text h1{

    font-size:34px;

}

.hero-text h2{

    font-size:22px;

}

.hero-description{

    font-size:15px;

}

.price-main{

    font-size:30px;

}

.summary-item{

    padding:14px;

}

.apartment-summary{

    grid-template-columns:1fr;

}

}

/*====================================
SMALL PHONE
====================================*/

@media screen and (max-width:390px){

.logo{

    width:42px;

    height:42px;

}

.hero-text{

    padding:0 18px;

}

.hero-text h1{

    font-size:30px;

}

.hero-buttons .btn{

    height:50px;

}

.gallery-main img{

    height:230px;

}

.apartment-image{

    height:210px;

}

}

/*====================================
LANDSCAPE
====================================*/

@media screen and (max-height:500px) and (orientation:landscape){

.hero{

    min-height:520px;

}

.mobile-menu{

    overflow-y:auto;

}

}
/*====================================
MOBILE APARTMENTS GRID FIX
====================================*/

@media screen and (max-width:992px){

.apartments-grid{

    display:grid !important;

    grid-template-columns:1fr !important;

    gap:20px !important;

}

.apartment-card,
.card{

    width:100% !important;

    max-width:100% !important;

}

.apartment-image,
.object-img{

    width:100% !important;

    height:240px !important;

    object-fit:cover;

}

}
@media screen and (max-width:992px){

.container{

    grid-template-columns:1fr !important;

}

}
@media (max-width:992px){

.hero-text{

    top:55px !important;

}
}
@media (max-width:992px){

.apartments-home{

    display:flex !important;

    flex-direction:column !important;

    align-items:stretch !important;

}

.apartments-home > *{

    width:100% !important;

    max-width:100% !important;

    flex:none !important;

}

.apartment-card-link{

    width:100% !important;

}

.apartment-card{

    width:100% !important;

}

}
@media (max-width:992px){

.hero-social{

    position:relative;

    margin-top:20px;

    display:block;

}

.hero-social-icons{

    display:flex;

    justify-content:flex-start;

    gap:14px;

    flex-wrap:wrap;

}

}
@media (max-width:992px){

.hero-buttons{

    margin-top:18px;

}

.hero-buttons .btn{

    width:100%;

}

}
@media (max-width:992px){

.apartment-card{

    border-radius:22px;

    overflow:hidden;

}

.apartment-image{

    height:180px !important;

}

.apartment-info{

    padding:20px;

}

}
@media (max-width:992px){

.apartment-card-link,

.apartment-card-link:hover,

.apartment-card-link:visited{

    color:inherit !important;

    text-decoration:none !important;

}

.apartment-card-link *{

    text-decoration:none !important;

}

}
.price-value{

    color:#d4af37 !important;

    font-size:22px !important;

    font-weight:700;

    line-height:1.2;

}
.apartment-title{

    color:#fff !important;

    font-size:20px !important;

    font-weight:700;

    line-height:1.3;

    text-decoration:none !important;

}
.mobile-menu-btn{

    margin-top:-12px;

}
@media (max-width:992px){

    .calc-apartment-info{

        grid-template-columns:repeat(2,1fr);

        gap:12px;

    }

    .info-item{

        padding:14px;

    }

    .info-item strong{

        font-size:18px;

    }

}