html{
scroll-behavior:smooth;
}

*{
margin:0;
padding:0;
box-sizing:border-box;
font-family:'Poppins',sans-serif;
}

body{

background:#0f0f0f;

color:white;

overflow-x:hidden;
}

a{
text-decoration:none;
color:white;
}

a:visited{
color:white;
}

.navbar{

position:fixed;

top:20px;

left:50%;

transform:translateX(-50%);

width:90%;

padding:20px 40px;

display:flex;

justify-content:space-between;

align-items:center;

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

backdrop-filter:blur(15px);

border-radius:20px;

z-index:999;
}

.logo{

font-size:1.7rem;

font-weight:700;

letter-spacing:2px;

color:#d4af37;
}

.navbar ul{

display:flex;

gap:30px;

list-style:none;
}

.navbar a{

transition:.3s;
}

.navbar a:hover{

color:#d4af37;
}

.hero{

height:100vh;

display:flex;

justify-content:center;

align-items:center;

text-align:center;

background-size:cover;

background-position:center;

position:relative;
}

.hero::before{

content:"";

position:absolute;

inset:0;

background:rgba(0,0,0,.45);
}

.hero-content{

display:none;
}

.hero h1{

font-size:6rem;

margin-bottom:20px;
}

.hero p{

font-size:1.4rem;

margin-bottom:30px;
}

.btn{

display:inline-block;

padding:18px 40px;

background:#d4af37;

border-radius:15px;

font-weight:600;

transition:.4s;
}

.btn:hover{

transform:translateY(-5px);

box-shadow:
0 15px 40px rgba(212,175,55,.4);
}

.section{

padding:120px 10%;
}

.section-title{

font-size:3rem;

text-align:center;

margin-bottom:60px;

color:#d4af37;
}

.grid{

display:grid;

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

gap:40px;
}

.card{

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

backdrop-filter:blur(15px);

padding:30px;

border-radius:25px;

transition:.5s;
}

.card:hover{

transform:
translateY(-10px);

box-shadow:
0 20px 50px rgba(0,0,0,.4);
}

.card img{

width:100%;

height:260px;

object-fit:cover;

border-radius:20px;

margin-bottom:20px;
}

.card h3{

margin-bottom:15px;

color:#d4af37;
}

.gallery{

display:grid;

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

gap:20px;
}

.gallery img{

width:100%;

height:350px;

object-fit:cover;

border-radius:20px;

transition:.5s;
}

.gallery img:hover{

transform:
scale(1.03);
}

footer{

margin-top:100px;

padding:60px;

background:#090909;

text-align:center;
}

.footer-content h3{

color:#d4af37;

margin-bottom:20px;
}

.socials{

margin-top:20px;

display:flex;

justify-content:center;

gap:30px;
}

.socials a{

color:#d4af37;
}

.page-header{

height:60vh;

display:flex;

justify-content:center;

align-items:center;

text-align:center;

background-size:cover;

background-position:center;

position:relative;
}

.page-header::before{

content:"";

position:absolute;

inset:0;

background:rgba(0,0,0,.5);
}

.page-header h1{

position:relative;

z-index:2;

font-size:5rem;
}

.contact-box{

max-width:800px;

margin:auto;

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

padding:50px;

border-radius:25px;

text-align:center;
}

.contact-box h2{

color:#d4af37;

margin-bottom:25px;
}

.menu-grid{

display:grid;

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

gap:25px;
}

.menu-item{

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

backdrop-filter:blur(20px);

padding:35px;

border-radius:25px;

text-align:center;

transition:.4s;
}

.menu-item:hover{

transform:
translateY(-10px)
scale(1.03);

box-shadow:
0 25px 60px rgba(0,0,0,.4);
}

.menu-item h3{

color:#d4af37;

font-size:1.4rem;

margin-bottom:15px;
}

.menu-item p{

font-size:1.3rem;

font-weight:700;
}

.card p{
line-height:1.8;
}
/* ===================================== */
/* TABLET */
/* ===================================== */

@media (max-width: 992px){

    .navbar{

        width:95%;

        padding:15px 20px;
    }

    .navbar ul{

        gap:15px;
    }

    .hero h1{

        font-size:4rem;
    }

    .page-header h1{

        font-size:3.5rem;
    }

    .section{

        padding:90px 6%;
    }

}

/* ===================================== */
/* SMARTPHONE */
/* ===================================== */

@media (max-width: 768px){

    .navbar{

        flex-direction:column;

        gap:15px;

        width:95%;

        padding:15px;

    }

    .logo{

        font-size:1.4rem;
    }

    .navbar ul{

        display:flex;

        gap:10px;

        flex-wrap:wrap;

        justify-content:flex-end;
    }

    .navbar a{

        font-size:0.95rem;
    }

    .hero{

         height:50vh;

         background-size:contain;

         background-repeat:no-repeat;

         background-position:center bottom;

         padding:100px 20px 30px 20px;

    }

    .hero h1{

        font-size:3rem;

        line-height:1.1;
    }

    .hero p{

        font-size:1rem;
    }

    .btn{

        padding:14px 24px;
    }

    .section{

        padding:80px 20px;
    }

    .section-title{

        font-size:2rem;

        margin-bottom:40px;
    }

    .grid{

        grid-template-columns:1fr;
    }

    .gallery{

        grid-template-columns:1fr;
    }

    .gallery img{

        height:240px;
    }

    .card{

        padding:20px;
    }

    .card img{

        height:220px;
    }

    .page-header{

        height:45vh;
    }

    .page-header h1{

        font-size:2.8rem;
    }

    .menu-grid{

        grid-template-columns:1fr;
    }

    .contact-box{

        padding:25px;
    }

    footer{

        padding:40px 20px;
    }

    .socials{

        flex-direction:column;

        gap:15px;
    }

}

/* ===================================== */
/* TELEFONI PICCOLI */
/* ===================================== */

@media (max-width: 480px){

    .navbar{

        top:10px;
    }

    .logo{

        font-size:1.2rem;
    }

    .navbar a{

        font-size:0.85rem;
    }

    .hero{

        min-height:45vh;
    }

    .hero h1{

        font-size:2.4rem;
    }

    .hero p{

        font-size:0.95rem;
    }

    .page-header h1{

        font-size:2.2rem;
    }

    .section-title{

        font-size:1.8rem;
    }

    .gallery img{

        height:200px;
    }

}
/* ===================================== */
/* MENU PREMIUM BAR SCALONI */
/* ===================================== */

.menu-grid{

display:grid;

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

gap:35px;

margin-top:40px;
}

.menu-item{

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

backdrop-filter:blur(20px);

-webkit-backdrop-filter:blur(20px);

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

padding:40px 35px;

border-radius:25px;

text-align:center;

transition:.4s;

overflow:hidden;

position:relative;
}

.menu-item::before{

content:"";

position:absolute;

top:0;

left:-100%;

width:100%;

height:100%;

background:
linear-gradient(
90deg,
transparent,
rgba(255,255,255,.08),
transparent
);

transition:.7s;
}

.menu-item:hover::before{

left:100%;
}

.menu-item:hover{

transform:
translateY(-10px)
scale(1.03);

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

.menu-item h3{

font-size:1.8rem;

margin-bottom:20px;

color:#d4af37;

letter-spacing:1px;
}

.menu-item p{

font-size:1.05rem;

line-height:1.9;

font-weight:400;

color:#f5f5f5;
}

.menu-item strong{

display:block;

margin-top:15px;

font-size:1.4rem;

color:#d4af37;

font-weight:700;
}

/* ===================================== */
/* HEADER PAGINA MENU */
/* ===================================== */

.page-header h1{

text-shadow:
0 5px 15px rgba(0,0,0,.6),
0 15px 40px rgba(0,0,0,.5);
}

/* ===================================== */
/* GALLERIA MENU */
/* ===================================== */

.gallery{

display:grid;

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

gap:25px;
}

.gallery img{

width:100%;

height:300px;

object-fit:cover;

border-radius:20px;

transition:.5s;
}

.gallery img:hover{

transform:
scale(1.04);

box-shadow:
0 20px 50px rgba(0,0,0,.4);
}

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

.contact-box{

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

backdrop-filter:blur(15px);

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

.contact-box p{

line-height:2;
}

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

@media (max-width:768px){

.menu-grid{

grid-template-columns:1fr;
}

.menu-item{

padding:30px 25px;
}

.menu-item h3{

font-size:1.5rem;
}

.menu-item p{

font-size:1rem;
}

.menu-item strong{

font-size:1.25rem;
}

.gallery{

grid-template-columns:1fr;
}

.gallery img{

height:240px;
}

}

@media (max-width:480px){

.menu-item{

padding:25px 20px;
}

.menu-item h3{

font-size:1.3rem;
}

.menu-item p{

font-size:.95rem;
}

.menu-item strong{

font-size:1.15rem;
}

}
.contact-box strong{

display:block;

margin-bottom:8px;

color:#d4af37;

font-size:1.2rem;
}
