body{
    padding-top:88px;
}

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
    background:#edf3f9;
}


body{
    font-family:Arial,sans-serif;

    margin:0;

    padding-top:88px;

    color:#222;

    overflow-x:hidden;

    background:
        radial-gradient(circle at top left, rgba(16,36,63,.06) 0%, transparent 35%),
        radial-gradient(circle at bottom right, rgba(212,166,60,.05) 0%, transparent 35%),
        linear-gradient(180deg,#f9fbfd 0%,#f3f6fa 50%,#eef3f8 100%);

    background-attachment:fixed;
}
body::before{
    content:"";

    position:fixed;

    inset:0;

    z-index:-1;

    pointer-events:none;

    opacity:.35;

    background-image:
        linear-gradient(rgba(255,255,255,.45) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.45) 1px, transparent 1px);

    background-size:80px 80px;
}


/* ================= NAVBAR ================= */

.navbar{
    position:fixed;
    top:0;
    left:0;
    right:0;

    height:88px;

    padding:0 40px;

    display:flex;
    align-items:center;
    justify-content:space-between;

    background:linear-gradient(90deg,#0B1F38 0%,#132D4F 45%,#0B1F38 100%);

    box-shadow:0 8px 30px rgba(0,0,0,.18);

    z-index:1000;
}


.brand{
    display:flex;
    align-items:center;
    gap:16px;
    text-decoration:none;
    color:#16365f;
    transition:.3s;
}

.brand:hover{
    transform:translateY(-2px);
}

.logo{
    width:60px;
    height:60px;
    border-radius:50%;
    object-fit:cover;
}

.brand h2{
    margin:0;
    color:#ffffff;
    font-size:24px;
    font-weight:700;
}


nav{
    display:flex;
    align-items:center;
    gap:12px;
}


.navbar nav a{
    display:flex;
    align-items:center;
    justify-content:center;

    height:48px;
    padding:0 22px;

    border-radius:999px;

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

    color:#ffffff;

    text-decoration:none;

    font-size:16px;
    font-weight:600;

    transition:.3s;
}
.navbar nav a:hover{
    background:#D8A53A;
    color:#fff;
    transform:translateY(-2px);
}


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


.hero{

position:relative;

height:600px;

overflow:hidden;

}


.hero-image{
    width:100%;
    height:100%;
    object-fit:cover;
}


.hero:after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(
        90deg,
        rgba(0,0,0,.65),
        rgba(0,0,0,.25)
    );
    z-index:1;
}


.hero-text{
    position:absolute;
    top:50%;
    left:7%;
    transform:translateY(-50%);
    color:white;
    z-index:2;
}


.hero-text h1{
    font-size:75px;
    color:#002b7f;
    -webkit-text-stroke:2px white;
    font-weight:900;
}


.hero-text h2{
    margin:25px 0;
    font-size:40px;
    font-weight:900;
}


.hero-text p{
    font-size:28px;
    font-weight:700;
}


.btn{
    display:inline-block;
    margin-top:30px;
    background:#c89b3c;
    color:white;
    padding:15px 35px;
    border-radius:30px;
    text-decoration:none;
    font-weight:bold;
    transition:.3s;
    box-shadow:0 8px 20px rgba(0,0,0,.2);
}


.btn:hover{
    background:#002b55;
}



/* ================= PREMIUM BANNER BUTTON ================= */

.banner-btn{

    position:absolute;

    top:50%;

    transform:translateY(-50%);

    z-index:20;

    width:46px;

    height:46px;

    border-radius:50%;

    border:1px solid rgba(255,255,255,.15);

    cursor:pointer;

    font-size:20px;

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

    color:#111;

    backdrop-filter:blur(12px);

    transition:.35s;

    box-shadow:
        0 10px 35px rgba(0,0,0,.25);

}

.banner-btn:hover{

    background:#D4AF37;

    color:#111;

    transform:translateY(-50%) scale(1.08);

}

/* левая стрелка */

.left{

    left:36%;

}

/* правая стрелка */

.right{

    right:18px;

}


/* ================= PREMIUM DOTS ================= */

.banner-dots{

    position:absolute;

    left:50%;

    bottom:32px;

    transform:translateX(-50%);

    display:flex;

    align-items:center;

    gap:10px;

    z-index:30;

}

.dot{

    width:9px;

    height:9px;

    border-radius:50%;

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

    cursor:pointer;

    transition:.35s;

}

.dot:hover{

    background:#ffffff;

}

.dot.active{

    width:26px;

    border-radius:20px;

    background:#D4AF37;

}
/* ================= CARDS ================= */


.container{
    padding:60px 7%;
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:30px;
}


.card{
    display:flex;
    height:360px;
    background:white;
    border-radius:20px;
    overflow:hidden;
    box-shadow:0 8px 25px rgba(0,0,0,.12);
    transition:.3s;
}


.card:hover{
    transform:translateY(-5px);
}


.card-left{
    width:50%;
}


.object-img{
    width:100%;
    height:160px;
    object-fit:cover;
}



.card-info{
    padding:15px;
}


.card-info h2{
    color:#002b55;
    margin-bottom:10px;
    font-size:22px;
}


.price{
    font-size:20px;
    font-weight:bold;
    color:#c89b3c;
}


.card-info p{
    margin-top:6px;
    color:#555;
}



/* правая часть */


.card-right{
    width:50%;
    padding:20px;
    background:#fafafa;
    display:flex;
    flex-direction:column;
}


.card-right h3{
    font-size:22px;
    color:#002b55;
    margin-bottom:10px;
}



.description-text{
    line-height:1.7;
    font-size:15px;
    color:#444;
    flex:1;
    overflow:hidden;
    text-align:justify;
    display:-webkit-box;
    -webkit-line-clamp:8;
    -webkit-box-orient:vertical;
}



.card-btn{
    margin-top:auto;
    background:#002b55;
    color:white;
    padding:12px 25px;
    border-radius:10px;
    text-decoration:none;
    text-align:center;
    width:160px;
    transition:.3s;
}


.card-btn:hover{
    background:#c89b3c;
}
/* ================= ABOUT ================= */


.about{

    padding:90px 7%;

    background:transparent;

}


.about h2{
    font-size:35px;
    margin-bottom:20px;
    color:#002b55;
}


.about p{
    line-height:1.8;
    font-size:18px;
    color:#444;
}




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


.advantages{
    width:min(1500px,95%);
    margin:60px auto;
    padding:70px 60px;

    background:#ffffff;

    border-radius:32px;

    box-shadow:0 20px 60px rgba(15,31,51,.08);
}


.advantages h2{
    margin-bottom:40px;
    color:#002b55;
    font-size:35px;
}



.advantages-grid{
    display:grid;

    grid-template-columns:repeat(auto-fit,minmax(260px,1fr));

    gap:28px;

    margin-top:50px;
}



.advantage-card{
    padding:35px 28px;

    background:#F8FAFD;

    border:1px solid #E8EDF5;

    border-radius:24px;

    transition:.3s;

    text-align:center;
}


.advantage-card:hover{
    transform:translateY(-8px);

    box-shadow:0 20px 40px rgba(15,31,51,.10);
}



.advantage-card i{
    font-size:45px;
    color:#c89b3c;
}



.advantage-card h3{
    margin:15px 0;
    color:#002b55;
}



.advantage-card p{
    line-height:1.6;
    color:#555;
}




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


.footer{
    background:#111;
    color:white;
    padding:50px 7%;
}


.footer h2{
    margin-bottom:20px;
    font-size:35px;
}



.footer a{
    color:white;
    text-decoration:none;
    transition:.3s;
}



.footer a:hover{
    color:#c89b3c;
}



.social-links{
    margin-top:30px;
}



.social-links a{
    font-size:30px;
    margin-right:20px;
}



.map-box{
    margin-top:40px;
    border-radius:15px;
    overflow:hidden;
}
/* ================= WHATSAPP ================= */


.floating-whatsapp{

    position:fixed;

    right:25px;

    bottom:25px;

    width:60px;

    height:60px;

    background:#25d366;

    color:white;

    border-radius:50%;

    display:flex;

    align-items:center;

    justify-content:center;

    font-size:35px;

    z-index:999;

    text-decoration:none;

    transition:.3s;

    box-shadow:0 5px 20px rgba(0,0,0,.25);

}



.floating-whatsapp:hover{

    transform:scale(1.1);

}



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


.calculator-modal{

    display:none;

    position:fixed;

    right:30px;

    top:80px;

    width:100%;

    justify-content:flex-end;

    z-index:9999;

}



.calculator-box{

    position:relative;

    width:350px;

    max-height:85vh;

    overflow-y:auto;

    background:white;

    padding:18px;

    border-radius:15px;

    box-shadow:0 10px 30px rgba(0,0,0,.25);

}
.calculator-close{

    position:absolute;

    top:12px;

    right:12px;

    width:32px;

    height:32px;

    border:none;

    border-radius:50%;

    background:#f5f5f5;

    color:#555;

    font-size:18px;

    font-weight:bold;

    cursor:pointer;

    display:flex;

    align-items:center;

    justify-content:center;

    transition:.25s;

    box-shadow:0 2px 8px rgba(0,0,0,.15);

}

.calculator-close:hover{

    background:#e53935;

    color:#fff;

    transform:scale(1.08);

}

.calculator-close:active{

    transform:scale(.95);

}


.calculator-box h2{

    text-align:center;

    font-size:20px;

    color:#002b55;

    margin-bottom:18px;

}



.close-btn{

    float:right;

    font-size:28px;

    cursor:pointer;

    color:#777;

}



.calc-row{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:15px;

    margin-bottom:15px;

}



.calculator-box label{

    display:block;

    font-size:16px;

    font-weight:bold;

    color:#0b6b3a;

    margin-bottom:5px;

}



.calculator-box select,

.calculator-box input{

    width:100%;

    height:40px;

    padding:8px;

    border-radius:8px;

    border:1px solid #ccc;

    font-size:15px;

}



#room,
#meterPrice,
#discountPerMeter,
#usdRate,
#totalPrice,
#downPayment,
#remainingPayment,
#monthlyPayment{

    padding:10px;

    border-radius:8px;

    margin:10px 0;

    font-size:17px;

    font-weight:bold;

    background:#eafff1;

    color:#0b6b3a;

}



#monthlyPayment{

    background:#eaf3ff;

    color:#0057b8;

}



/* ================= LANGUAGE ================= */


.language-selector{

    position:relative;

    display:flex;

    align-items:center;

}



.selected-language{

    width:46px;

    height:46px;

    display:flex;

    align-items:center;

    justify-content:center;

    border-radius:50%;

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

    border:1px solid rgba(212,175,55,.18);

    cursor:pointer;

    transition:.3s;

}

.selected-language:hover{

    background:rgba(212,175,55,.12);

    border-color:#D4AF37;

}

.language-list{

    display:none;

    position:absolute;

    top:50px;

    right:0;

    min-width:190px;

    background:#181818;

    border:1px solid rgba(212,175,55,.18);

    border-radius:14px;

    box-shadow:0 20px 45px rgba(0,0,0,.45);

    overflow:hidden;

    z-index:9999;

}



.language-selector:hover .language-list{

    display:block;

}



.language-list a{

    display:flex;

    align-items:center;

    gap:14px;

    padding:14px 18px;

    text-decoration:none;

    color:#ffffff;

    font-size:15px;

    font-weight:600;

    background:transparent;

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

    transition:.3s;

}

.language-list a:last-child{

    border-bottom:none;

}

.language-list a:hover{

    background:rgba(212,175,55,.12);

    color:#D4AF37;

    padding-left:22px;

}



.lang-flag{

    width:30px;

    height:30px;

    border-radius:50%;

    object-fit:cover;

    border:2px solid rgba(255,255,255,.12);

}



.language-panel{

    display:none;

}
/* ================= MOBILE ================= */


@media(max-width:900px){


    .navbar{

        flex-direction:column;

        gap:15px;

        padding:15px 5%;

    }



    .navbar nav{

        flex-wrap:wrap;

        justify-content:center;

        gap:15px;

    }



    .navbar nav a{

        font-size:14px;

    }



    .container{

        grid-template-columns:1fr;

        padding:30px 5%;

    }



    .card{

        flex-direction:column;

        height:auto;

    }



    .card-left,
    .card-right{

        width:100%;

    }



    .object-img{

        height:220px;

    }



    .hero{

        height:450px;

    }



    .hero-text{

        left:5%;

        right:5%;

    }



    .hero-text h1{

        font-size:42px;

    }



    .hero-text h2{

        font-size:25px;

    }



    .hero-text p{

        font-size:18px;

    }



    .banner-btn{

        width:35px;

        height:35px;

        font-size:20px;

    }



    .left{

        left:10%;

    }



    .right{

        right:10px;

    }



    .about,
    .advantages{

        padding:35px 5%;

    }



    .footer{

        padding:35px 5%;

    }



    .calculator-modal{

        right:0;

        top:70px;

        padding:10px;

    }



    .calculator-box{

        width:100%;

    }



    .calc-row{

        grid-template-columns:1fr;

    }

}




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


.banner-slide{

    animation:fadeBanner .8s ease;

}



@keyframes fadeBanner{


    from{

        opacity:.3;

    }


    to{

        opacity:1;

    }

}




/* ================= EXTRA FIX ================= */


img{

    max-width:100%;

    display:block;

}



button{

    font-family:Arial,sans-serif;

}



a{

    transition:.3s ease;

}



section{

    scroll-margin-top:80px;

}



.card,
.advantage-card{

    will-change:transform;

}



/* ================= SMALL MOBILE ================= */


@media(max-width:500px){


    .brand{

        gap:8px;

    }



    .logo{

        width:50px;

        height:50px;

    }



    .hero-text h1{

        font-size:32px;

    }



    .hero-text h2{

        font-size:22px;

        margin:15px 0;

    }



    .hero-text p{

        font-size:16px;

    }



    .btn{

        padding:12px 25px;

        margin-top:20px;

    }



    .card-info h2{

        font-size:20px;

    }



    .card-btn{

        width:100%;

    }



    .social-links a{

        font-size:25px;

        margin-right:10px;

    }

}


.floors-side button:hover{

    background:#c89b3c;

    color:white;

}

.building-area{

    display:flex;

    align-items:stretch;

    justify-content:center;

    gap:30px;

    margin-top:30px;

}


.floors-side{

    display:flex;

    flex-direction:column;

    gap:10px;

    min-height:400px;

    justify-content:flex-start;

}


.block-3d-card + .floors-side{

    margin-top:0;

}
/* ================= 3D MAP ================= */

.site-map{
    width:min(1500px,95%);
    margin:60px auto;
    padding:60px;

    position:relative;
    overflow:hidden;
    isolation:isolate;
    background:#ffffff;

    border-radius:32px;

    box-shadow:
        0 20px 60px rgba(15,31,51,.08),
        0 8px 20px rgba(0,0,0,.05);
}
.site-map::before{
    content:"";
    position:absolute;
    top:-180px;
    right:-180px;
    width:420px;
    height:420px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(200,155,60,.12) 0%, transparent 70%);
    pointer-events:none;
}

.site-map::after{
    content:"";
    position:absolute;
    left:-150px;
    bottom:-150px;
    width:340px;
    height:340px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(0,43,85,.06) 0%, transparent 70%);
    pointer-events:none;
}

.site-map h2{
    text-align:center;
    margin-bottom:30px;
    color:#002b55;
    font-size:36px;
}

#map{
    width:100%;
    position:relative;
    overflow:hidden;
    border-radius:20px;
}

.block-3d-map{
    width:380px;
    height:380px;
}

.block-3d-map model-viewer{
    width:100%;
    height:100%;
    background:transparent;
    border-radius:15px;
    transition:.4s;
}

.block-3d-map model-viewer:hover{
    transform:scale(1.05);
}


/* ================= FLOORS ================= */

#floorsLeft,
#floorsRight{
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    display:flex;
    flex-direction:column;
    gap:8px;
    z-index:9999;
}

#floorsLeft{
    left:20px;
}

#floorsRight{
    right:20px;
}

.floor-btn{

    width:65px;

    height:28px;

    border:none;

    border-radius:8px;

    background:white;

    color:#002b55;

    font-size:12px;

    font-weight:bold;

    cursor:pointer;

    box-shadow:0 3px 10px rgba(0,0,0,.2);

    transition:.3s;

}

.floor-btn:hover{
    background:#c89b3c;
    color:white;
    transform:translateX(3px);
}


/* ================= APARTMENTS PANEL ================= */

.apartments-panel{
    position:fixed;
    top:120px;
    right:20px;
    width:220px;
    max-height:70vh;
    overflow-y:auto;
    background:white;
    border-radius:15px;
    padding:15px;
    box-shadow:0 10px 30px rgba(0,0,0,.25);
    z-index:10000;
}

.apartment-btn{
    width:100%;
    margin-bottom:12px;
    padding:14px;
    border:none;
    border-radius:12px;
    background:white;
    cursor:pointer;
    transition:.3s;
    text-align:left;
    box-shadow:0 3px 12px rgba(0,0,0,.12);
}

.apartment-btn:hover{
    background:#002b55;
    color:white;
    transform:translateX(5px);
}

.status-free{
    border-left:6px solid #27ae60;
}

.status-reserved{
    border-left:6px solid #f39c12;
}

.status-sold{
    border-left:6px solid #e74c3c;
    opacity:.65;
}

.apartment-number{
    font-size:18px;
    font-weight:700;
}

.apartment-area{
    margin-top:5px;
    font-size:15px;
}

.apartment-room{
    margin-top:3px;
    font-size:13px;
    opacity:.8;
}
/* ================= APARTMENT DETAIL ================= */

.apartment-preview {

    width: 100%;
    margin-top: 15px;
    border-radius: 12px;
    object-fit: cover;
    box-shadow: 0 5px 15px rgba(0,0,0,.15);

}

.apartment-buttons {

    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 18px;

}

.details-btn {

    width: 100%;
    padding: 12px;
    border: none;
    border-radius: 10px;
    background: #002b55;
    color: white;
    font-size: 15px;
    cursor: pointer;
    transition: .3s;

}

.details-btn:hover {

    background: #c89b3c;

}

.reserve-btn {

    display: block;
    width: 100%;
    padding: 12px;
    text-align: center;
    text-decoration: none;
    border-radius: 10px;
    background: #25D366;
    color: white;
    font-weight: bold;
    transition: .3s;

}

.reserve-btn:hover {

    background: #1fa851;

}
/* ================= DETAIL PAGE ================= */

.detail-page {

    padding: 50px 7%;

}

.detail-container {

    max-width: 1400px;
    margin: 0 auto;

}

.detail-header {

    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 35px;

}

.back-btn {

    display: inline-flex;
    align-items: center;
    gap: 10px;

    padding: 12px 24px;

    background: #002b55;
    color: #ffffff;

    text-decoration: none;

    border-radius: 10px;

    transition: .3s;

}

.back-btn:hover {

    background: #c89b3c;

}

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

.detail-gallery{

    display:flex;

    flex-direction:column;

    gap:20px;

    margin-bottom:35px;

}

.gallery-thumbs{

    display:flex;

    gap:10px;

    margin-top:14px;

    overflow-x:auto;

    scrollbar-width:none;

}

.gallery-thumbs::-webkit-scrollbar{

    display:none;

}

/* ========== END ACTIVE GALLERY IMAGE ========== */

/* ========== END DETAIL GALLERY ========== */
.detail-content {

    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 30px;

}

@media (max-width: 900px) {

    .detail-gallery,
    .detail-content {

        grid-template-columns: 1fr;

    }

    .detail-header {

        flex-direction: column;

        gap: 20px;

        align-items: flex-start;

    }

}
/* ========== SVG FLOOR PLAN ========== */

#floorPlanContainer{

    width:100%;

    display:flex;

    justify-content:center;

    align-items:center;

}

#floorPlan{

    width:100%;

    height:75vh;

    border:none;

    background:#ffffff;

    border-radius:18px;

}

/* ========== END SVG FLOOR PLAN ========== */
/* ================= FLOOR VIEWER ================= */

#floorViewer{
    display:none;
}

#floorViewer.active{
    display:block;
}
/* ========== APARTMENT PLAN ========== */

.plan-preview{

    margin-top:20px;

    border-radius:18px;

    overflow:hidden;

    box-shadow:0 10px 30px rgba(0,0,0,.12);

}

.plan-preview img{

    width:100%;

    display:block;

    cursor:pointer;

    transition:.3s;

}

.plan-preview img:hover{

    transform:scale(1.02);

}

.plan-button{

    width:100%;

    margin-top:20px;

    height:55px;

    border:none;

    border-radius:12px;

    background:#002b55;

    color:#ffffff;

    font-size:16px;

    font-weight:bold;

    cursor:pointer;

    transition:.3s;

}

.plan-button:hover{

    background:#c89b3c;

}

/* ========== END APARTMENT PLAN ========== */
/* ========== APARTMENT FEATURES ========== */

.features-grid{

    display:grid;

    grid-template-columns:repeat(auto-fit,minmax(160px,1fr));

    gap:14px;

    margin-top:20px;

}

/* =========================================
   СТРАНИЦА КАТАЛОГА КВАРТИР
========================================= */

.apartments-page{
    margin:50px auto;
}

/* =========================================
   ОСНОВНОЙ КОНТЕЙНЕР:
   СЛЕВА ФИЛЬТР, СПРАВА КАТАЛОГ
========================================= */

.apartments-wrapper{
    display:grid;
    grid-template-columns:280px 1fr;
    gap:30px;
    align-items:start;
}

/* =========================================
   ЛЕВАЯ ПАНЕЛЬ ФИЛЬТРОВ
========================================= */

.apartments-filter{
    background:#fff;
    border-radius:18px;
    padding:25px;
    box-shadow:0 10px 30px rgba(0,0,0,.08);
    position:sticky;
    top:100px;
}

/* =========================================
   ВЕРХ ФИЛЬТРА
   ЗАГОЛОВОК + КНОПКА СБРОСА
========================================= */

.filter-header{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:25px;
}

/* =========================================
   КНОПКА СБРОСА ФИЛЬТРОВ
========================================= */

.filter-reset{
    width:40px;
    height:40px;
    border:none;
    border-radius:10px;
    cursor:pointer;
    background:#f3f5f7;
    transition:.3s;
}

.filter-reset:hover{
    background:#0b8f43;
    color:#fff;
}

/* =========================================
   ПОДПИСИ ПОЛЕЙ ФИЛЬТРА
========================================= */

.apartments-filter label{
    display:block;
    margin-top:18px;
    margin-bottom:8px;
    font-weight:600;
}

/* =========================================
   SELECT И INPUT ФИЛЬТРА
========================================= */

.apartments-filter select,
.apartments-filter input{
    width:100%;
    padding:12px;
    border:1px solid #ddd;
    border-radius:10px;
    font-size:15px;
}

/* =========================================
   ПРАВАЯ ЧАСТЬ С КАРТОЧКАМИ КВАРТИР
========================================= */

.apartments-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:25px;
}

/* =========================================
   СОВРЕМЕННАЯ КАРТОЧКА КВАРТИРЫ
========================================= */

.card{
    background:#fff;
    border-radius:18px;
    overflow:hidden;
    box-shadow:0 10px 30px rgba(0,0,0,.08);
    transition:.3s;
}

.card:hover{
    transform:translateY(-6px);
    box-shadow:0 20px 40px rgba(0,0,0,.15);
}

.object-img{
    width:100%;
    height:210px;
    object-fit:cover;
    display:block;
}

.card-info{
    padding:20px;
}

.apartment-number{
    font-size:24px;
    font-weight:700;
    margin:15px 0;
    color:#222;
}

.apartment-info p{
    margin:6px 0;
    font-size:15px;
    color:#555;
}

.card-btn{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:10px;
    width:100%;
    margin-top:20px;
    padding:14px;
    background:#0b8f43;
    color:#fff;
    border-radius:10px;
    text-decoration:none;
    font-weight:600;
    transition:.3s;
}

.card-btn:hover{
    background:#087638;
}
/* =========================================
   ИСПРАВЛЕНИЕ КАРТОЧЕК КАТАЛОГА
========================================= */

.apartments-grid .card{
    display:block;
    height:auto;
    width:100%;
}

.apartments-grid .card-left{
    width:100%;
}

.apartments-grid .card-right{
    width:100%;
    padding:20px;
    background:#ffffff;
}
/* =========================================
   ПРАВАЯ КОЛОНКА КАТАЛОГА
========================================= */

.apartments-content{
    width:100%;
    min-width:0;
}
/* =========================================
   КАРТОЧКА КВАРТИРЫ
========================================= */

.apartment-card{
    background:#fff;
    border-radius:18px;
    overflow:hidden;
    box-shadow:0 10px 25px rgba(0,0,0,.08);
    transition:.3s;
    display:grid;
    grid-template-rows:235px 115px 60px;
    height:400px;
}

.apartment-card:hover{
    transform:translateY(-6px);
    box-shadow:0 20px 40px rgba(0,0,0,.15);
}

/* =========================================
   ФОТО КВАРТИРЫ
========================================= */

.apartment-image{
    grid-row:1;
    position:relative;
    width:100%;
    height:100%;
    overflow:hidden;
}

.apartment-image .object-img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:.4s;
}

.apartment-card:hover .object-img{
    transform:scale(1.05);
}

/* =========================================
   ИНФОРМАЦИЯ О КВАРТИРЕ
========================================= */

.apartment-info{
    grid-row:2;

    display:flex;
    flex-direction:column;
    justify-content:space-between;

    padding:18px 16px;

    overflow:hidden;
}
.apartment-price{
    margin:15px 0;
}

/* =========================================
   СТАТУС ПОВЕРХ ФОТО КВАРТИРЫ
========================================= */

.apartment-image{
    position:relative;
}

/* =========================================
   НАЗВАНИЕ + ЦЕНА
========================================= */

.apartment-header{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
}


/* =========================================
   ИНФОРМАЦИЯ О КВАРТИРЕ
========================================= */

.apartment-meta{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:12px 18px;
    margin-top:10px;
    margin-bottom:18px;
}

.meta-item{
    display:flex;
    align-items:center;
    gap:8px;
    font-size:14px;
    color:#555;
}

.meta-item i{
    width:18px;
    text-align:center;
    color:#159947;
    font-size:15px;
}

.meta-item span{
    font-weight:500;
}
/* =========================================
   РАЗДЕЛИТЕЛЬ КАРТОЧКИ
========================================= */

.apartment-divider{
    border:none;
    border-top:1px solid #ececec;
    margin:0 16px 12px;
}
/* =========================================
   ВЕРХНЯЯ ПАНЕЛЬ КАТАЛОГА
========================================= */

.apartments-topbar{
    display:flex;
    justify-content:flex-end;
    align-items:center;
    margin-bottom:20px;
}

#sortApartments{
    min-width:220px;
    height:46px;

    padding:0 15px;

    border:1px solid #e5e7eb;
    border-radius:12px;

    background:#fff;

    font-size:15px;
    font-weight:500;

    color:#333;

    cursor:pointer;

    transition:.3s;
}

#sortApartments:hover{
    border-color:#159947;
}

#sortApartments:focus{
    outline:none;
    border-color:#159947;
    box-shadow:0 0 0 3px rgba(21,153,71,.15);
}
/*==================================================
DETAIL PAGE NEW LAYOUT
==================================================*/

.detail-layout{
    width:100%;
    max-width:1780px;
    margin:35px auto;
    padding:0 25px;
    display:grid;
    grid-template-columns:290px minmax(0,1fr);
    gap:40px;
    align-items:start;
    align-items:flex-start;
}
.detail-sidebar{

    position:relative;

    align-self:flex-start;

    height:100%;

}


.detail-main{
    width:100%;
    min-width:0;
}
.sidebar-back{

    display:flex;

    align-items:center;

    gap:12px;

    padding-bottom:22px;

    margin-bottom:22px;

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

    color:#ffffff;

    font-size:18px;

    font-weight:700;

    text-decoration:none;

    transition:.3s;

}

.sidebar-back:hover{

    color:#D4AF37;

}

.sidebar-nav{
    display:flex;
    flex-direction:column;
    gap:6px;
}

.sidebar-nav a{

    display:flex;

    align-items:center;

    gap:14px;

    width:100%;

    height:56px;

    padding:0 18px;

    border-radius:14px;

    color:rgba(255,255,255,.88);

    background:transparent;

    text-decoration:none;

    font-size:16px;

    font-weight:600;

    transition:.25s;

}
.sidebar-nav{
    display:flex;
    flex-direction:column;
    gap:10px;
}

.sidebar-nav a i{

    width:24px;

    text-align:center;

    color:#D4AF37;

    font-size:18px;

}

.sidebar-nav a:hover{

    background:rgba(212,175,55,.12);

    color:#ffffff;

    transform:translateX(6px);

}

.sidebar-nav a:last-child{

    margin-top:18px;

    background:#25D366;

    color:#ffffff;

    font-weight:700;

}

.sidebar-nav a:last-child i{

    color:#ffffff;

}

.sidebar-nav a:last-child:hover{

    background:#1EBE5A;

    transform:none;

}
.sidebar-nav a:hover i{
    color:#c89b3c;
}


.gallery-main img{
    width:100%;
    height:500px;

    object-fit:cover;

    border-radius:16px;

    transition:opacity .25s ease;
}

.gallery-thumbs{
    display:flex;
    gap:10px;

    margin-top:14px;

    overflow-x:auto;

    scrollbar-width:none;
}

.gallery-thumbs::-webkit-scrollbar{
    display:none;
}

.gallery-thumb{
    width:120px;
    height:82px;

    object-fit:cover;

    border-radius:12px;

    cursor:pointer;

    border:2px solid transparent;

    transition:.25s;

    flex-shrink:0;
}

.gallery-thumb.active{
    border-color:#d79a17;
}

.gallery-thumb:hover{
    transform:translateY(-3px);
}

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

.apartment-summary{
    display:grid;
    grid-template-columns:repeat(5,1fr);
    gap:20px;
    margin-bottom:10px;
}

.installment-btn{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    gap:12px;

    min-width:270px;

    height:58px;

    padding:0 28px;

    border:none;

    border-radius:16px;

    background:linear-gradient(
        135deg,
        #169B45,
        #0E7C35
    );

    color:#ffffff;

    font-size:17px;

    font-weight:700;

    cursor:pointer;

    transition:.35s;

    box-shadow:
        0 15px 35px rgba(22,155,69,.30);

}
.installment-btn i{

    font-size:18px;

}

.installment-btn:hover{

    transform:translateY(-4px);

    background:linear-gradient(
        135deg,
        #1DB954,
        #169B45
    );

    box-shadow:
        0 22px 45px rgba(22,155,69,.40);

}
/* ================= ГЛАВНАЯ СТРАНИЦА - КВАРТИРЫ ================= */

#objects{
    width:min(1500px,95%);
    margin:60px auto;

    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));

    gap:30px;

    padding:0;
}

#objects .apartment-card{
    width:100%;
    margin:0;
    height:430px;
}

#objects .apartment-image{
    height:220px;
}

#objects .apartment-image img{
    width:100%;
    height:100%;
    object-fit:cover;
}

/* =========================================
   IMAGE FULLSCREEN
========================================= */

.image-modal{
    position:fixed;
    inset:0;

    display:none;

    align-items:center;
    justify-content:center;

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

    z-index:99999;

    animation:fadeIn .25s;
}

.image-modal.active{
    display:flex;
}

.image-modal img{
    max-width:92vw;
    max-height:92vh;

    border-radius:18px;

    box-shadow:0 20px 60px rgba(0,0,0,.45);
}

#closeImageModal{
    position:absolute;

    top:25px;
    right:35px;

    font-size:46px;

    color:#ffffff;

    cursor:pointer;

    transition:.25s;
}

#closeImageModal:hover{
    transform:scale(1.15);
    color:#D79A17;
}

@keyframes fadeIn{

    from{
        opacity:0;
    }

    to{
        opacity:1;
    }

}
.image-arrow{
    position:absolute;

    top:50%;
    transform:translateY(-50%);

    width:60px;
    height:60px;

    border:none;
    border-radius:50%;

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

    backdrop-filter:blur(10px);

    color:#ffffff;

    font-size:22px;

    cursor:pointer;

    transition:.25s;
}

.image-arrow:hover{
    background:#D79A17;
    transform:translateY(-50%) scale(1.08);
}

.image-arrow.left{
    left:35px;
}

.image-arrow.right{
    right:35px;
}
.image-counter{
    position:absolute;

    bottom:30px;
    left:50%;

    transform:translateX(-50%);

    padding:10px 18px;

    border-radius:30px;

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

    backdrop-filter:blur(12px);

    color:#ffffff;

    font-size:16px;
    font-weight:600;

    letter-spacing:.5px;
}
/* ================= GALLERY ARROWS ================= */

.gallery-main{
    position:relative;
}

.gallery-nav{
    position:absolute;

    top:50%;
    transform:translateY(-50%);

    width:54px;
    height:54px;

    border:none;
    border-radius:50%;

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

    backdrop-filter:blur(10px);

    color:#ffffff;

    font-size:20px;

    cursor:pointer;

    opacity:0;

    transition:.25s;

    z-index:20;
}

.gallery-main:hover .gallery-nav{
    opacity:1;
}

.gallery-nav:hover{
    background:#D79A17;
    transform:translateY(-50%) scale(1.08);
}

.gallery-prev{
    left:20px;
}

.gallery-next{
    right:20px;
}
/* =========================================
   SIMILAR APARTMENTS
========================================= */

.similar-grid{

    display:grid;

    grid-template-columns:repeat(auto-fit,minmax(240px,1fr));

    gap:20px;

    margin-top:24px;

}
