/* =========================
   RESET
========================= */

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

/* =========================
   COLORS
========================= */

:root{
    --dark:#11100e;
    --dark-soft:#1b1815;
    --gold:#c9a45c;
    --gold-light:#e4c985;
    --cream:#f8f1e6;
    --text:#d8d0c4;
    --white:#ffffff;
}

/* =========================
   GLOBAL
========================= */

html{
    scroll-behavior:smooth;
}

body{
    font-family:'Poppins', sans-serif;
    background:var(--dark);
    color:var(--text);
    overflow-x:hidden;
}

.container{
    width:90%;
    max-width:1200px;
    margin:auto;
}

img{
    max-width:100%;
    display:block;
}

.section-padding{
    padding:110px 0;
}

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

.site-header{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    z-index:9999;
    background:rgba(17,16,14,0.72);
    backdrop-filter:blur(18px);
    border-bottom:1px solid rgba(201,164,92,0.12);
    transition:0.4s;
}

.nav-wrapper{
    height:90px;
    display:flex;
    align-items:center;
    justify-content:space-between;
}

.logo img{
    height:64px;
}

/* =========================
   DESKTOP MENU
========================= */

.main-nav > ul{
    display:flex;
    align-items:center;
    gap:38px;
    list-style:none;
}

.main-nav a{
    position:relative;
    text-decoration:none;
    color:var(--cream);
    font-size:15px;
    font-weight:500;
    letter-spacing:0.4px;
    transition:0.3s;
}

.main-nav a::after{
    content:"";
    position:absolute;
    left:0;
    bottom:-8px;
    width:0;
    height:1px;
    background:var(--gold);
    transition:0.3s;
}

.main-nav a:hover{
    color:var(--gold);
}

.main-nav a:hover::after{
    width:100%;
}

/* =========================
   DROPDOWN MENU
========================= */

.dropdown{
    position:relative;
}

.dropdown-menu{
    position:absolute;
    top:38px;
    left:0;

    display:flex;
    flex-direction:column;
    gap:0;

    min-width:260px;
    padding:14px 0;

    background:rgba(15,15,15,0.98);
    border:1px solid rgba(201,164,92,0.18);
    border-radius:18px;

    opacity:0;
    visibility:hidden;
    transform:translateY(12px);
    transition:0.35s;

    box-shadow:0 22px 55px rgba(0,0,0,0.4);
    z-index:99999;

    list-style:none;
}

.dropdown:hover .dropdown-menu{
    opacity:1;
    visibility:visible;
    transform:translateY(0);
}

.dropdown-menu li{
    width:100%;
    list-style:none;
}

.dropdown-menu a{
    display:block;
    width:100%;
    padding:12px 24px;
    color:var(--cream);
    font-size:14px;
    text-decoration:none;
    transition:0.3s;
}

.dropdown-menu a::after{
    display:none;
}

.dropdown-menu a:hover{
    background:rgba(201,164,92,0.08);
    color:var(--gold);
}

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

.nav-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    height:48px;
    padding:0 26px;
    border-radius:50px;
    text-decoration:none;
    background:linear-gradient(135deg,var(--gold),var(--gold-light));
    color:var(--dark);
    font-size:14px;
    font-weight:600;
    transition:0.35s;
}

.nav-btn:hover{
    transform:translateY(-3px);
    box-shadow:0 14px 34px rgba(201,164,92,0.35);
}

/* =========================
   HAMBURGER
========================= */

.hamburger{
    width:46px;
    height:46px;
    display:none;
    border:none;
    background:transparent;
    cursor:pointer;
    position:relative;
}

.hamburger span{
    position:absolute;
    left:11px;
    width:24px;
    height:2px;
    background:var(--gold);
    border-radius:10px;
    transition:0.35s;
}

.hamburger span:nth-child(1){
    top:14px;
}

.hamburger span:nth-child(2){
    top:22px;
}

.hamburger span:nth-child(3){
    top:30px;
}

.hamburger.active span:nth-child(1){
    transform:rotate(45deg);
    top:22px;
}

.hamburger.active span:nth-child(2){
    opacity:0;
}

.hamburger.active span:nth-child(3){
    transform:rotate(-45deg);
    top:22px;
}

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

.hero{
    min-height:100vh;
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.94) 0%,
            rgba(17,16,14,0.72) 45%,
            rgba(17,16,14,0.35) 100%
        ),
        url('../img/hero.jpg') center/cover no-repeat;

    display:flex;
    align-items:center;
    position:relative;
    overflow:hidden;
}

.hero::before{
    content:"";
    position:absolute;
    width:500px;
    height:500px;
    border-radius:50%;
    background:rgba(201,164,92,0.08);
    filter:blur(80px);
    right:5%;
    bottom:-10%;
    animation:glowMove 6s ease-in-out infinite alternate;
}

.hero-content{
    position:relative;
    z-index:2;
    max-width:720px;
    padding-top:90px;
    animation:fadeUp 1.2s ease forwards;
}

.hero-small-title{
    color:var(--gold);
    letter-spacing:4px;
    text-transform:uppercase;
    font-size:14px;
    font-weight:500;
}

.hero h1{
    font-family:'Cormorant Garamond', serif;
    font-size:82px;
    line-height:0.95;
    color:var(--cream);
    margin:24px 0;
}

.hero p{
    font-size:19px;
    line-height:1.8;
    color:#e2d8ca;
    max-width:620px;
    margin-bottom:38px;
}

.hero-buttons{
    display:flex;
    gap:18px;
    flex-wrap:wrap;
}

.btn{
    display:inline-block;
    padding:15px 32px;
    border-radius:50px;
    text-decoration:none;
    font-weight:600;
    transition:0.35s;
}

.btn-primary{
    background:linear-gradient(135deg,var(--gold),var(--gold-light));
    color:var(--dark);
}

.btn-secondary{
    border:1px solid rgba(201,164,92,0.6);
    color:var(--gold-light);
}

.btn:hover{
    transform:translateY(-4px);
}

/* =========================
   SECTION TITLE
========================= */

.section-title{
    text-align:center;
    margin-bottom:60px;
}

.section-title span{
    color:var(--gold);
    text-transform:uppercase;
    letter-spacing:4px;
    font-size:13px;
}

.section-title h2{
    font-family:'Cormorant Garamond', serif;
    font-size:56px;
    color:var(--cream);
    margin-top:14px;
}

/* =========================
   SERVICES
========================= */

.services{
    background:linear-gradient(180deg,var(--dark),var(--dark-soft));
}

.service-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:28px;
}

.service-link{
    text-decoration:none;
    color:inherit;
    display:block;
}

.service-card{
    background:rgba(255,255,255,0.04);
    border:1px solid rgba(201,164,92,0.18);
    border-radius:24px;
    overflow:hidden;
    transition:0.4s;
    position:relative;
    height:100%;
}

.service-card:hover{
    transform:translateY(-10px);
    background:rgba(201,164,92,0.08);
    border-color:rgba(201,164,92,0.45);
    box-shadow:0 20px 50px rgba(0,0,0,0.35);
}

.service-img{
    width:100%;
    height:220px;
    overflow:hidden;
    position:relative;
    background:#222;
}

.service-img::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(
        to top,
        rgba(17,16,14,0.7),
        rgba(17,16,14,0.1)
    );
}

.service-img img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:0.5s;
}

.service-card:hover .service-img img{
    transform:scale(1.08);
}

.service-content{
    padding:30px 24px 34px;
}

.service-content h3{
    font-family:'Cormorant Garamond', serif;
    color:var(--gold-light);
    font-size:32px;
    margin-bottom:14px;
}

.service-content p{
    line-height:1.7;
    font-size:15px;
    color:#d2c8bb;
}

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

.site-footer{
    background:#0b0a09;
    border-top:1px solid rgba(201,164,92,0.15);
    padding:30px 0;
    text-align:center;
    font-size:14px;
    color:#b7aa97;
}

/* =========================
   ANIMATIONS
========================= */

@keyframes fadeUp{
    from{
        opacity:0;
        transform:translateY(40px);
    }

    to{
        opacity:1;
        transform:translateY(0);
    }
}

@keyframes glowMove{
    from{
        transform:translateY(0) scale(1);
    }

    to{
        transform:translateY(-30px) scale(1.08);
    }
}

/* =========================
   TABLET
========================= */

@media(max-width:992px){

    .nav-btn{
        display:none;
    }

    .hamburger{
        display:block;
    }

    .main-nav{
        position:fixed;
        top:90px;
        left:-100%;

        width:100%;
        height:calc(100vh - 90px);

        background:rgba(10,10,10,0.97);
        backdrop-filter:blur(14px);

        transition:0.45s;

        display:flex;
        align-items:center;
        justify-content:center;
    }

    .main-nav.active{
        left:0;
    }

    .main-nav > ul{
        flex-direction:column;
        gap:30px;
    }

    .main-nav a{
        font-size:24px;
        font-family:'Cormorant Garamond', serif;
    }

    .dropdown-menu{
        position:relative;
        top:0;
        left:0;

        min-width:auto;
        width:100%;

        background:transparent;
        border:none;
        border-radius:0;
        box-shadow:none;

        opacity:1;
        visibility:visible;
        transform:none;

        padding:14px 0 0;
    }

    .dropdown-menu a{
        font-size:18px;
        padding:8px 0;
        text-align:center;
        color:var(--gold-light);
    }

    .service-grid{
        grid-template-columns:repeat(2,1fr);
    }

    .hero h1{
        font-size:64px;
    }
}

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

@media(max-width:768px){

    .hero{
        text-align:center;
        background:
            linear-gradient(
                180deg,
                rgba(17,16,14,0.9),
                rgba(17,16,14,0.78)
            ),
            url('../img/hero.jpg') center/cover no-repeat;
    }

    .hero-content{
        margin:auto;
    }

    .hero h1{
        font-size:52px;
    }

    .hero p{
        font-size:17px;
    }

    .hero-buttons{
        justify-content:center;
    }

    .section-title h2{
        font-size:42px;
    }
}

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

@media(max-width:576px){

    .nav-wrapper{
        height:82px;
    }

    .logo img{
        height:52px;
    }

    .main-nav{
        top:82px;
        height:calc(100vh - 82px);
    }

    .hero h1{
        font-size:42px;
    }

    .hero p{
        font-size:16px;
    }

    .service-grid{
        grid-template-columns:1fr;
    }

    .section-padding{
        padding:80px 0;
    }

    .service-img{
        height:240px;
    }
}
/* =========================
   SERVICE SINGLE PAGE
========================= */

.service-page-hero{
    min-height:70vh;
    padding-top:140px;
    display:flex;
    align-items:center;
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.95),
            rgba(17,16,14,0.65)
        ),
        url('../img/masaze.jpg') center/cover no-repeat;
}

.service-page-hero span{
    color:var(--gold);
    text-transform:uppercase;
    letter-spacing:4px;
    font-size:14px;
}

.service-page-hero h1{
    font-family:'Cormorant Garamond', serif;
    font-size:68px;
    line-height:1;
    color:var(--cream);
    max-width:800px;
    margin:22px 0;
}

.service-page-hero p{
    max-width:620px;
    font-size:18px;
    line-height:1.8;
    color:#e2d8ca;
}

.service-detail{
    background:var(--dark);
}

.service-detail-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:60px;
    align-items:center;
}

.small-title{
    color:var(--gold);
    text-transform:uppercase;
    letter-spacing:3px;
    font-size:13px;
}

.service-detail-text h2{
    font-family:'Cormorant Garamond', serif;
    font-size:56px;
    color:var(--cream);
    margin:16px 0 22px;
}

.service-detail-text p{
    line-height:1.8;
    margin-bottom:18px;
    color:#d8d0c4;
}

.service-detail-text .btn{
    margin-top:18px;
}

.service-detail-image{
    border-radius:28px;
    overflow:hidden;
    border:1px solid rgba(201,164,92,0.25);
    box-shadow:0 25px 70px rgba(0,0,0,0.35);
}

.service-detail-image img{
    width:100%;
    height:520px;
    object-fit:cover;
}

.price-section{
    background:var(--dark-soft);
}

.price-table{
    max-width:850px;
    margin:auto;
    background:rgba(255,255,255,0.04);
    border:1px solid rgba(201,164,92,0.2);
    border-radius:24px;
    overflow:hidden;
}

.price-row{
    display:grid;

    grid-template-columns:1fr auto;

    align-items:center;

    gap:40px;

    padding:20px 28px;

    border-bottom:1px solid rgba(201,164,92,0.12);
}

.price-row div:last-child{
    text-align:right;
    font-weight:600;
    color:var(--gold-light);
}

.price-header{
    background:linear-gradient(135deg,var(--gold),var(--gold-light));
    color:var(--dark);
    font-weight:600;
}

.mini-gallery{
    background:var(--dark);
}

.mini-gallery-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:28px;
}

.mini-gallery-grid img{
    width:100%;
    height:280px;
    object-fit:cover;
    border-radius:24px;
    border:1px solid rgba(201,164,92,0.18);
}

/* RESPONSIVE SERVICE PAGE */

@media(max-width:992px){

    .service-detail-grid{
        grid-template-columns:1fr;
    }

    .service-page-hero h1{
        font-size:54px;
    }

    .mini-gallery-grid{
        grid-template-columns:1fr 1fr;
    }
}

@media(max-width:576px){

    .service-page-hero{
        min-height:65vh;
        text-align:center;
    }

    .service-page-hero h1{
        font-size:42px;
    }

    .service-detail-text h2{
        font-size:42px;
    }

    .price-row{
        grid-template-columns:1fr;
        gap:6px;
    }

    .mini-gallery-grid{
        grid-template-columns:1fr;
    }

    .service-detail-image img{
        height:360px;
    }
}
/* =========================
   NJEGA LICA HERO
========================= */

.njega-lica-hero{

    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.94),
            rgba(17,16,14,0.68)
        ),
        url('../img/njega-lica-cover.jpg')
        center/cover no-repeat;
}
.dermapen-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.94),
            rgba(17,16,14,0.68)
        ),
        url('../img/dermapen-cover.jpg') center/cover no-repeat;
}
.cta-section{
    padding:40px 0 90px;
}
.cta-box{
    max-width:700px;
}
.cta-box .btn{
    margin-top:30px;
}
.kolagen-niti-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.94),
            rgba(17,16,14,0.68)
        ),
        url('../img/kolagen-niti-cover.jpg') center/cover no-repeat;
}
.njega-ruku-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.94),
            rgba(17,16,14,0.68)
        ),
        url('../img/njega-ruku-cover.jpg') center/cover no-repeat;
}

.nails-gallery{
    grid-template-columns:repeat(3,1fr);
}

.nails-gallery img{
    height:320px;
    object-fit:cover;
}
.njega-stopala-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.94),
            rgba(17,16,14,0.68)
        ),
        url('../img/njega-stopala-cover.jpg') center/cover no-repeat !important;
}
.sminkanje-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.94),
            rgba(17,16,14,0.68)
        ),
        url('../img/sminkanje-cover.jpg') center/cover no-repeat;
}

.second-price-title{
    margin-top:80px;
}
.depilacija-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.94),
            rgba(17,16,14,0.68)
        ),
        url('../img/depilacija-cover.jpg') center/cover no-repeat;
}

.depilation-header,
.depilation-row{
    grid-template-columns:2.2fr 1fr 1.2fr;
}
.depilation-header div{
    white-space:nowrap;
}
.depilation-table .price-header{
    display:grid;
    grid-template-columns:2fr 1fr 1fr;
}

.depilation-table .price-header div{
    color:#111 !important;
    font-weight:700;
    opacity:1 !important;
    visibility:visible !important;
}

.depilation-table .price-row{
    display:grid;
    grid-template-columns:2fr 1fr 1fr;
}
.aparativni-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.82),
            rgba(17,16,14,0.55)
        ),
        url('../img/madero-cover.jpg') center/cover no-repeat;
}
..anticelulitni-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.82),
            rgba(17,16,14,0.55)
        ),
        url('../img/madero-cover.jpg') center/cover no-repeat;
}
.anticelulitni-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.82),
            rgba(17,16,14,0.55)
        ),
        url('../img/madero-cover.jpg') center/cover no-repeat;
}

.info-box{
    margin:28px 0;
    padding:26px 28px;
    border-radius:22px;
    background:rgba(255,255,255,0.04);
    border:1px solid rgba(201,164,92,0.18);
}

.info-box h3{
    font-family:'Cormorant Garamond', serif;
    font-size:30px;
    color:var(--gold-light);
    margin-bottom:14px;
}

.info-box p{
    margin-bottom:0;
}

.warning-box{
    border-color:rgba(201,164,92,0.35);
    background:rgba(201,164,92,0.06);
}

.service-list{
    margin-top:12px;
    padding-left:20px;
}

.service-list li{
    margin-bottom:12px;
    line-height:1.7;
}
.kriolipoliza-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.82),
            rgba(17,16,14,0.55)
        ),
        url('../img/kriolipoliza-cover.jpg') center/cover no-repeat;
}
.radiofrekvencija-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.82),
            rgba(17,16,14,0.55)
        ),
        url('../img/radiofrekvencija-cover.jpg') center/cover no-repeat;
}
.kavitacija-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.82),
            rgba(17,16,14,0.55)
        ),
        url('../img/kavitacija-cover.jpg') center/cover no-repeat;
}
.lipolaser-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.82),
            rgba(17,16,14,0.55)
        ),
        url('../img/lipolaser-cover.jpg') center/cover no-repeat;
}
.lipolaser-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.82),
            rgba(17,16,14,0.55)
        ),
        url('../img/lipolaser-cover.jpg') center/cover no-repeat;
}
.top-bar{
    background:#11100e;
    padding:10px 0;
    border-bottom:1px solid rgba(255,255,255,0.06);
}

.top-bar-content{
    display:flex;
    justify-content:flex-end;
    align-items:center;
}

.header-phone{
    color:#d6b56d;
    text-decoration:none;
    font-size:15px;
    font-weight:600;
    transition:0.3s;
}

.header-phone:hover{
    color:#fff;
}

.navbar{
    background:#161412;
    position:sticky;
    top:0;
    z-index:999;
}

.nav-container{
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:18px 0;
}

.logo img{
    max-height:70px;
}

.main-nav ul{
    display:flex;
    align-items:center;
    gap:35px;
    list-style:none;
}

.main-nav ul li{
    position:relative;
}

.main-nav ul li a{
    color:#fff;
    text-decoration:none;
    font-size:15px;
    font-weight:500;
    transition:0.3s;
}

.main-nav ul li a:hover{
    color:#d6b56d;
}

.dropdown-menu{
    position:absolute;
    top:100%;
    left:0;
    background:#1d1a17;
    min-width:260px;
    padding:15px 0;
    border-radius:14px;
    opacity:0;
    visibility:hidden;
    transition:0.3s;
    display:flex;
    flex-direction:column;
    gap:0;
}

.dropdown:hover .dropdown-menu{
    opacity:1;
    visibility:visible;
}

.dropdown-menu li{
    width:100%;
}

.dropdown-menu li a{
    display:block;
    padding:12px 22px;
    color:#fff;
}

.dropdown-menu li a:hover{
    background:#2a2622;
    color:#d6b56d;
}

.submenu{
    position:relative;
}

.submenu-menu{
    position:absolute;
    top:0;
    left:100%;
    background:#1d1a17;
    min-width:220px;
    padding:15px 0;
    border-radius:14px;
    opacity:0;
    visibility:hidden;
    transition:0.3s;
}

.submenu:hover .submenu-menu{
    opacity:1;
    visibility:visible;
}

.mobile-toggle{
    display:none;
    color:#fff;
    font-size:24px;
    cursor:pointer;
}

@media(max-width:991px){

    .main-nav{
        display:none;
    }

    .mobile-toggle{
        display:block;
    }

}
/* FIX DROPDOWN MENU */

.main-nav .dropdown-menu{
    gap:0 !important;
    padding:8px 0 !important;
    min-width:270px;
}

.main-nav .dropdown-menu li{
    width:100%;
    margin:0 !important;
    padding:0 !important;
}

.main-nav .dropdown-menu a{
    display:block;
    padding:9px 22px !important;
    line-height:1.3 !important;
    font-size:15px !important;
}

/* PODMENU */

.has-submenu{
    position:relative;
}

.has-submenu > a{
    padding-right:45px !important;
}

.has-submenu > a::before{
    content:"›";
    position:absolute;
    right:20px;
    color:var(--gold);
    font-size:22px;
    top:50%;
    transform:translateY(-50%);
}

.has-submenu .submenu-menu{
    position:absolute;
    top:0;
    left:100%;

    min-width:220px;

    background:rgba(15,15,15,0.98);
    border:1px solid rgba(201,164,92,0.18);
    border-radius:18px;

    padding:8px 0 !important;

    list-style:none;

    opacity:0;
    visibility:hidden;

    transform:translateX(8px);
    transition:0.25s;

    z-index:999999;
}

.has-submenu:hover .submenu-menu{
    opacity:1;
    visibility:visible;
    transform:translateX(0);
}

.has-submenu .submenu-menu li{
    margin:0 !important;
    padding:0 !important;
}

.has-submenu .submenu-menu a{
    padding:9px 22px !important;
    font-size:15px !important;
}
.submenu-menu{
    display:block !important;
}

.submenu-menu li{
    display:block !important;
    width:100%;
}

.submenu-menu li a{
    display:block;
    width:100%;
}
.service-card a{
    text-decoration:none;
    color:inherit;
    display:block;
    height:100%;
}
.kontakt-hero{
    background:
    linear-gradient(rgba(0,0,0,0.65), rgba(0,0,0,0.65)),
    url('../img/kontakt-cover.jpg') center/cover no-repeat;
}

.contact-page{
    background:#0f0b08;
}

.contact-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:60px;
    align-items:start;
}

.contact-info-box,
.contact-form-box{
    background:#171411;
    border:1px solid rgba(214,181,109,0.12);
    border-radius:30px;
    padding:50px;
}

.contact-info-box h2,
.contact-form-box h2{
    font-size:42px;
    color:#e0c27a;
    margin-bottom:20px;
}

.contact-info-box p{
    color:#d8d2c9;
    line-height:1.8;
    margin-bottom:15px;
}

.contact-item{
    margin-top:35px;
    padding-top:25px;
    border-top:1px solid rgba(255,255,255,0.08);
}

.contact-item h3{
    color:#e0c27a;
    font-size:22px;
    margin-bottom:12px;
}

.contact-item a{
    color:#fff;
    text-decoration:none;
    font-size:18px;
    transition:0.3s;
}

.contact-item a:hover{
    color:#e0c27a;
}

.contact-form{
    margin-top:25px;
}

.form-group{
    margin-bottom:22px;
}

.contact-form input,
.contact-form textarea{
    width:100%;
    background:#0f0b08;
    border:1px solid rgba(255,255,255,0.08);
    border-radius:16px;
    padding:18px 20px;
    color:#fff;
    font-size:16px;
    outline:none;
    transition:0.3s;
}

.contact-form input:focus,
.contact-form textarea:focus{
    border-color:#e0c27a;
}

.contact-form textarea{
    resize:none;
}

.contact-form button{
    border:none;
    cursor:pointer;
}

@media(max-width:991px){

    .contact-grid{
        grid-template-columns:1fr;
        gap:35px;
    }

    .contact-info-box,
    .contact-form-box{
        padding:35px;
    }

}

@media(max-width:768px){

    .contact-info-box h2,
    .contact-form-box h2{
        font-size:32px;
    }

    .contact-info-box,
    .contact-form-box{
        padding:28px;
        border-radius:24px;
    }

}
.contact-map{
    margin-top:35px;
    border-radius:24px;
    overflow:hidden;
    border:1px solid rgba(214,181,109,0.12);
}

.contact-map iframe{
    display:block;
    filter:grayscale(100%) contrast(1.1);
}
.contact-form button{
    border:none;
    cursor:pointer;
    margin-bottom:35px;
}

.contact-map{
    margin-top:10px;
    border-radius:24px;
    overflow:hidden;
    border:1px solid rgba(214,181,109,0.12);
}

.contact-map iframe{
    display:block;
    width:100%;
    height:340px;
    filter:grayscale(100%) contrast(1.05);
}
.solarij-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.86),
            rgba(17,16,14,0.58)
        ),
        url('../img/solarij-cover.jpg') center/cover no-repeat;
}
.solarij-hero{
    background:
        linear-gradient(
            rgba(15,12,10,0.65),
            rgba(15,12,10,0.65)
        ),
        url('../img/solarij-cover.jpg');

    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.solarij-hero{
    background:
        linear-gradient(
            rgba(15,12,10,0.65),
            rgba(15,12,10,0.65)
        ),
        url('../img/solarij-cover.jpg');

    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.price-table .price-row{
    grid-template-columns:2fr 1fr 1fr;
}

.price-table .price-header{
    grid-template-columns:2fr 1fr 1fr;
}
.price-header div{
    color:#111 !important;
    font-weight:700;
}
@media(max-width:991px){

    .main-nav{
        display:none;
        position:absolute;
        top:100%;
        left:0;
        width:100%;
        background:#11100e;
        padding:25px;
        z-index:9999;
    }

    .main-nav.active{
        display:block;
    }

    .main-nav ul{
        flex-direction:column;
        align-items:flex-start;
        gap:0;
    }

    .main-nav ul li{
        width:100%;
    }

    .main-nav ul li a{
        display:block;
        padding:14px 0;
    }

    .dropdown-menu,
    .submenu-menu{
        position:static !important;
        opacity:1 !important;
        visibility:visible !important;
        transform:none !important;
        display:none !important;
        background:#171411;
        width:100%;
        margin:0;
        padding:0 0 0 18px !important;
        border-radius:0;
        border:0;
    }

    .dropdown:hover .dropdown-menu,
    .has-submenu:hover .submenu-menu{
        display:block !important;
    }

    .hamburger{
        display:flex;
    }
}
.hamburger{
    display:none;
    flex-direction:column;
    gap:5px;
    background:none;
    border:none;
    cursor:pointer;
}

.hamburger span{
    width:28px;
    height:3px;
    background:#d9b86c;
    border-radius:10px;
}

@media(max-width:991px){

    .hamburger{
        display:flex;
    }

    .main-nav{
        display:none;
    }

    .main-nav.active{
        display:block;
    }

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

    .hero{
        background-position:center center;
    }

    .hero-overlay{
        background:rgba(0,0,0,0.45);
    }

}
.back-to-top{
    position:fixed;

    right:18px;
    bottom:140px;

    width:52px;
    height:52px;

    border:none;
    border-radius:50%;

    background:linear-gradient(135deg,#c9a45c,#e4c985);

    color:#11100e;

    font-size:22px;
    font-weight:700;

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

    cursor:pointer;

    opacity:0;
    visibility:hidden;

    transition:0.3s;

    z-index:999999;
}

.back-to-top.show{
    opacity:1;
    visibility:visible;
}
.reviews{
    background:#120f0d;
}

.reviews-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:30px;
    margin-top:50px;
}

.review-card{
    background:#1b1613;

    border:1px solid rgba(214,181,109,0.15);

    border-radius:28px;

    padding:35px;

    transition:0.3s;
}

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

.review-stars{
    color:#d6b56d;
    font-size:22px;
    margin-bottom:18px;
}

.review-card p{
    color:#d9d1c7;
    line-height:1.8;
    margin-bottom:22px;
}

.review-card h4{
    color:#f2e7d8;
    font-size:18px;
}

.reviews-button{
    text-align:center;
    margin-top:45px;
}

@media(max-width:991px){

    .reviews-grid{
        grid-template-columns:1fr;
    }

}
.cookie-box {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 9999;

    background: #ffffff;
    color: #333;
    padding: 18px 24px;
    max-width: 420px;
    width: calc(100% - 40px);

    border-radius: 12px;
    box-shadow: 0 8px 25px rgba(0,0,0,0.2);

    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 15px;
}

.cookie-box p {
    margin: 0;
    font-size: 14px;
}

.cookie-box button {
    background: #b88a8a;
    color: white;
    border: none;
    padding: 10px 16px;
    border-radius: 8px;
    cursor: pointer;
}

.cookie-box button:hover {
    background: #9f7373;
}
.dropdown-menu .submenu {
    list-style: none;
    padding-left: 18px;
    margin: 5px 0 10px;
}

.dropdown-menu .submenu li a {
    font-size: 14px;
    opacity: 0.9;
}

.menu-section > a {
    font-weight: 600;
}
.dropdown-menu {
    display: block;
}

.dropdown-menu li {
    display: block;
    width: 100%;
}

.submenu {
    display: block;
    margin-left: 20px;
    margin-top: 5px;
}

.submenu li {
    display: block;
    margin: 5px 0;
}
.dropdown-menu{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
}

.dropdown-menu > li{
    width:100%;
    display:block;
}

.submenu{
    display:block;
    margin:8px 0 12px 20px;
    padding:0;
    list-style:none;
}

.submenu li{
    display:block;
    width:100%;
    margin:6px 0;
}

.submenu li a{
    display:block;
    font-size:14px;
    color:#d8d0c4;
}

.menu-section > a{
    color:#e4c985;
    font-weight:600;
}
.dropdown-menu{
    display:flex !important;
    flex-direction:column !important;
    align-items:flex-start !important;
    gap:0 !important;
}

.dropdown-menu > li{
    display:block !important;
    width:100% !important;
}

.aparativni-submenu{
    display:block !important;
    margin:6px 0 14px 22px !important;
    padding:0 !important;
    list-style:none !important;
}

.aparativni-submenu li{
    display:block !important;
    width:100% !important;
    margin:0 !important;
}

.aparativni-submenu a{
    display:block !important;
    padding:7px 0 !important;
    font-size:15px !important;
}
.main-nav .dropdown-menu,
.main-nav .dropdown-menu ul,
.main-nav .dropdown-menu .aparativni-submenu{
    display:block !important;
    flex-direction:unset !important;
}

.main-nav .dropdown-menu li,
.main-nav .dropdown-menu ul li,
.main-nav .dropdown-menu .aparativni-submenu li{
    display:block !important;
    width:100% !important;
}

.main-nav .dropdown-menu .aparativni-submenu{
    margin:5px 0 15px 22px !important;
    padding:0 !important;
    list-style:none !important;
}

.main-nav .dropdown-menu .aparativni-submenu a{
    padding:7px 0 !important;
    font-size:15px !important;
}

/* =========================
   FINAL HERO IMAGE FIXES
========================= */

.madero-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.82),
            rgba(17,16,14,0.55)
        ),
        url('../img/madero-v2.jpg') center/cover no-repeat !important;
}

.vacuslim-hero{
    background:
        linear-gradient(
            90deg,
            rgba(17,16,14,0.82),
            rgba(17,16,14,0.55)
        ),
        url('../img/vacuslim.jpg?v=11') center/cover no-repeat !important;
}

@media(max-width:768px){

    .service-page-hero.madero-hero{
        background:
            linear-gradient(
                rgba(17,16,14,0.82),
                rgba(17,16,14,0.55)
            ),
            url('../img/madero-v2.jpg?v=11') center center / cover no-repeat !important;
    }

    .service-page-hero.vacuslim-hero{
        background:
            linear-gradient(
                rgba(17,16,14,0.82),
                rgba(17,16,14,0.55)
            ),
            url('../img/vacuslim.jpg?v=11') center center / cover no-repeat !important;
    }

}

/* =========================
   FINAL MOBILE MENU FIX
========================= */

@media(max-width:991px){

    html,
    body{
        height:100%;
    }

    body.menu-open{
        overflow:hidden !important;
    }

    #mainNav{
        display:none;
    }

    #mainNav.active{
        display:block !important;
        position:fixed !important;
        top:82px !important;
        left:0 !important;
        right:0 !important;
        bottom:0 !important;
        width:100% !important;
        height:auto !important;
        max-height:none !important;
        overflow-y:auto !important;
        overflow-x:hidden !important;
        -webkit-overflow-scrolling:touch !important;
        background:#11100e !important;
        padding:20px 25px 220px !important;
        z-index:999999 !important;
    }

    #mainNav.active > ul{
        display:block !important;
        width:100% !important;
        height:auto !important;
        padding-bottom:220px !important;
    }

    #mainNav.active li{
        display:block !important;
        width:100% !important;
    }

    #mainNav.active a{
        display:block !important;
        white-space:normal !important;
        text-align:left !important;
    }

    #mainNav .dropdown-menu,
    #mainNav .submenu-menu{
        position:static !important;
        display:block !important;
        opacity:1 !important;
        visibility:visible !important;
        transform:none !important;
        width:100% !important;
        height:auto !important;
        overflow:visible !important;
        margin:8px 0 20px !important;
        padding:10px 0 !important;
        background:#171411 !important;
        border:1px solid rgba(201,164,92,0.15) !important;
        border-radius:16px !important;
        box-shadow:none !important;
    }

    #mainNav .dropdown-menu a,
    #mainNav .submenu-menu a{
        text-align:left !important;
        font-size:20px !important;
        padding:11px 18px !important;
    }

    .has-submenu > a::before{
        display:none !important;
    }

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

    html.menu-open,
    body.menu-open{
        overflow:hidden !important;
        height:100% !important;
        position:fixed !important;
        width:100% !important;
        touch-action:none !important;
    }

    #mainNav.active{
        display:block !important;
        position:fixed !important;
        top:82px !important;
        left:0 !important;
        right:0 !important;
        bottom:0 !important;
        height:auto !important;

        overflow-y:scroll !important;
        overflow-x:hidden !important;
        overscroll-behavior:contain !important;
        -webkit-overflow-scrolling:touch !important;
        touch-action:pan-y !important;

        background:#11100e !important;
        padding:20px 25px 240px !important;
        z-index:999999 !important;
    }

    #mainNav.active > ul{
        display:block !important;
        padding-bottom:240px !important;
    }
}