@charset "utf-8";

/* HERO DEL MENÚ */
.menu-hero{
height:100vh;
min-height:500px;
background:url('../img/La-carta.jpg') center/cover no-repeat;
background-attachment:fixed;
position:relative;
display:flex;
align-items:center;
justify-content:center;
text-align:center;
}

.menu-hero-overlay{
background:rgba(0,0,0,0.5);
width:100%;
height:100%;
display:flex;
flex-direction:column;
justify-content:center;
}

.menu-main-title{
font-family:"MIlan Personal Use Only";
font-size:clamp(3rem,8vw,5rem);
color:#fff;
margin:0;
text-shadow:2px 2px 10px rgba(0,0,0,0.5);
}

/* CONTENEDOR GENERAL */
.menu-container{
max-width:1200px;
margin:auto;
padding:60px 20px;
}

/* FILTROS */
.menu-filters{
display:flex;
justify-content:center;
gap:12px;
margin-bottom:40px;
padding:10px;
overflow-x:auto;
white-space:nowrap;
scrollbar-width:none;
margin-top:60px;
}

.menu-filters::-webkit-scrollbar{
display:none;
}

.filter-btn{
padding:12px 24px;
border:1px solid #e0e0e0;
background:#fff;
color:#444;
border-radius:50px;
font-family:"Gotham Thin";
font-size:0.85rem;
font-weight:600;
cursor:pointer;
transition:all .3s ease;
box-shadow:0 2px 8px rgba(0,0,0,0.05);
}

.filter-btn:hover{
border-color:#006d44;
color:#006d44;
transform:translateY(-2px);
}

.filter-btn.active{
background:#006d44;
color:#fff;
border-color:#006d44;
box-shadow:0 4px 12px rgba(0,109,68,0.3);
}

/* GRID DEL MENÚ */
.menu-grid{
display:grid;
grid-template-columns:repeat(4,1fr);
gap:25px;
}

.menu-card{
position:relative;
background:#fff;
border-radius:15px;
overflow:hidden;
display:flex;
flex-direction:column;
height:100%;
border:1px solid rgba(0,0,0,0.05);
box-shadow:0 4px 20px rgba(0,0,0,0.05);
transition:all .35s ease;
}

/* borde mexicano muy sutil */
.menu-card::after{
content:"";
position:absolute;
inset:0;
border-radius:15px;
border:1px solid transparent;
background:linear-gradient(
90deg,
rgba(0,104,71,0.25),
rgba(255,255,255,0.4),
rgba(206,17,38,0.25)
) border-box;
-webkit-mask:
linear-gradient(#fff 0 0) padding-box,
linear-gradient(#fff 0 0);
-webkit-mask-composite:xor;
mask-composite:exclude;
opacity:0;
transition:opacity .35s ease;
}

.menu-card:hover{
transform:translateY(-6px);
box-shadow:0 14px 28px rgba(0,0,0,0.12);
}

.menu-card:hover::after{
opacity:1;
}

/* IMAGEN */
.card-img{
height:170px;
overflow:hidden;
position:relative;
}

.card-img img{
width:100%;
height:100%;
object-fit:cover;
transition:transform .6s ease;
}

.menu-card:hover .card-img img{
transform:scale(1.1);
}

/* RATING */
.card-rating{
position:absolute;
top:10px;
right:10px;
background:rgba(255,255,255,0.9);
padding:2px 8px;
border-radius:20px;
font-size:0.7rem;
font-weight:bold;
}

/* CONTENIDO */
.card-body{
padding:18px;
text-align:left;
}

.dish-title{
font-family:'Cinzel',serif;
font-size:1.1rem;
margin-bottom:8px;
height:2.4em;
}

.dish-desc{
font-size:0.85rem;
color:#555;
line-height:1.5;
margin-bottom:15px;
height:5.8em;
}

/* PRECIO */
.dish-price{
font-size:1.05rem;
font-weight:700;
color:#006d44;
background:rgba(0,109,68,0.06);
padding:5px 10px;
border-radius:8px;
display:inline-block;
}

/* TABLET */
@media (max-width:900px){

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

}

/* MÓVIL */
@media (max-width:600px){

.menu-grid{
grid-template-columns:1fr;
gap:25px;
}

.dish-title{
font-size:1rem;
}

.dish-desc{
font-size:0.82rem;
}

}