/* Fuentes*/
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400..900;1,400..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&family=Playfair+Display:ital,wght@0,400..900;1,400..900&display=swap');

:root{
    /*Principales*/
    --cafe-brown: #6F4E37;
    --cafe-light-brown: #A67C52;
    --cafe-bg: #FFF9F2; /*Segunda opción beige arena #EADBC8*/
    --cafe-purple: #8e44ad;
    --cafe-oliva: #A3B18A;

    /*Secundarios*/
    --cafe-blanco: #F7F3EF;
    --cafe-crema: #FFF9F2;
    --cafe-gris-200: #E5E1DC;
    --cafe-gris-400: #A8A29E;
    --cafe-gris-900: #2C2C2C;

    /*Apoyo*/
    --cafe-terracota: #D9896B;
    --cafe-rosa: #EBC7C1;
    --cafe-amarillo: #F2C97D;
    --cafe-menta:#CDE1C6;
    --cafe-azul: #A7B6C7;

    /*Fonts*/
    --font-title: 'Playfair Display', serif;
    --font-body: 'Montserrat', sans-serif;

    /* UI */
    --cafe-radius-sm: 10px;
    --cafe-radius-md: 16px;
    --cafe-radius-lg: 24px;
    --cafe-radius-pill: 999px;

    --cafe-shadow-sm: 0 4px 14px rgba(44, 44, 44, 0.08);
    --cafe-shadow-md: 0 8px 24px rgba(44, 44, 44, 0.12);

    --cafe-transition: all 0.6s ease;

    /*Bootstrap Override*/
    --bs-body-font-family: var(--font-body);
    --bs-heading-font-family: var(--font-title);
    --bs-body-bg: var(--cafe-bg);
    --bs-body-color: var(--cafe-gris-900);

    --bs-primary: var(--cafe-purple);
    --bs-secondary: var(--cafe-brown);
    --bs-dark: var(--cafe-gris-900);
    --bs-light: var(--cafe-crema);

    --bs-border-color: var(--cafe-gris-200);
    --bs-border-radius: var(--cafe-radius-sm);
    --bs-border-radius-lg: var(--cafe-radius-md);

    --bs-link-color: var(--cafe-brown);
    --bs-link-hover-color: var(--cafe-purple);
}


*,*::before, *::after{
    box-sizing: border-box;
}

html{
    width: 100%;
    min-width: 320px;
    scroll-behavior: smooth;
}

body{
    width: 100%;
    min-width: 320px;
    margin: 0;
    overflow-x: hidden;

    font-family: var(--font-body);
    background-color: var(--cafe-bg);
    color: var(--cafe-gris-900);

    font-size: 16px;
    line-height: 1.5;
}

img,svg{
    display: block;
    max-width: 100%;
    height: auto;
}

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

button,input,textarea,select{
    font: inherit;
}

button,a {
    -webkit-tap-highlight-color: transparent;
}

button{
    cursor: pointer;
    border: var(--cafe-border);
}

h1,h2,h3,h4,h5,h6{
    font-family: var(--font-title);
    color: var(--cafe-gris-900);
    line-height: 1.2;
    margin-top: 0;
}

p{
    margin-top: 0;
}

.container {
    padding-left: 16px;
    padding-right: 16px;
}

.row {
    margin-left: 0;
    margin-right: 0;
}

[class*="col-"] {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.btn {
    max-width: 100%;
    white-space: normal;
    border-radius: var(--cafe-radius-sm);
    font-weight: 700;
    transition: var(--cafe-transition);
}

/*Estados Funcionales*/

/*Menu debe estar oculto por defecto, se muestra al hacer click en el boton del menu*/

.vista-menu {
    display: none;
}

.vista-menu.activa {
    display: block;
}

.panelBebida {
    display: none;
}

.panelBebida.activo {
    display: block;
}

/*Botones*/

.btn-main {
    background-color: var(--cafe-purple);
    color: #fff;
    border: 1px solid var(--cafe-purple);
}

.btn-main:hover {
    background-color: #7b3998;
    border-color: #7b3998;
    color: #fff;
}

.btn-alt {
    background-color: var(--cafe-crema);
    color: var(--cafe-gris-900);
    border: 1px solid var(--cafe-gris-900);
}

.btn-alt:hover {
    background-color: var(--cafe-brown);
    color: #fff;
}

.btnVolver {
    display: inline-block;
    margin-bottom: 1rem;
    color: var(--cafe-brown);
    font-weight: 700;
    font-size: 0.9rem;
}

img{
    border-radius: var(--cafe-radius-sm);
}

/*heroe*/
.heroe {
    min-height: 100dvh;
    position: relative;
    overflow: hidden;

    background-image: url('../assets/images/hero/fachada.webp');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.heroe-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;

    background: linear-gradient(
        120deg,
        rgba(44, 44, 44, 0.78) 0%,
        rgba(111, 78, 55, 0.56) 45%,
        rgba(142, 68, 173, 0.40) 100%
    );
}

.heroe .container {
    position: relative;
    z-index: 3;
}

.heroe-card {
    text-align: center;
    color: var(--cafe-blanco);
    padding: 4rem 1rem 3rem;
    margin-top:6rem;
}

.heroe-title {
    color: var(--cafe-blanco);
    font-size: clamp(1.2rem, 3vw, 1.4rem);
    font-family: var(--font-title);
    font-weight: 600;
    line-height: 1.35;
    max-width: 310px;
    margin: 3rem auto;
    /*margin: 0 auto 1.8rem;*/
}

.heroe-logo {
    max-width: 180px;
    margin: 0 auto 2rem;
}

.heroe-description{
    display: grid;
    gap: 0.35rem;
    margin-top: 2.5rem;
    /*margin-bottom: 2.2rem;*/
}

.heroe-description h4 {
    color: var(--cafe-blanco);
    margin-bottom: 0;
    font-size: clamp(1.2rem, 2.5vw, 1.4rem);
    font-weight: 500;
    letter-spacing: 0.2px;
}

.heroe-slogan h4{
    margin-top: 2.5rem;
    color: var(--cafe-blanco);
    font-size: clamp(1rem, 1.5vw, 1.2rem);
    font-style: italic;
    letter-spacing: 0.5px;
}

.heroe-buttons {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 1rem;
    margin-top: 0rem;
    justify-content: center;
    align-items: center;
}

.heroe-buttons .btn {
    flex: 0 0 auto;
    min-width: 112px;
    padding: 0.7rem 1.2rem;
    font-size: 0.95rem;
}

/*Header*/
.headerRecomendados {
    background-color: var(--cafe-crema);
    border-bottom: 1px solid var(--cafe-gris-200);
    z-index: 1000;
    margin-top: 1rem;
    margin-bottom: 0.5rem;
}

.logoImg {
    width: 64px;
}

.navbar-toggler {
    border: none;
}

.navbar-toggler:focus {
    box-shadow: none;
}

.nav-link {
    color: var(--cafe-brown);
    font-weight: 700;
}

.nav-link:hover {
    color: var(--cafe-purple);
}

/*Scciones*/

.recomendados, .menu{
    padding:2rem 0;
}

.recomTitle, .menuTitle{
    margin-bottom: 2rem;
    margin-top: 0;
}

.recomTitle h2, .menuTitle h2{
    font-size: clamp(1.5rem, 5vw, 2.5rem);
    color: var(--cafe-gris-900);
    font-weight: 900;
    margin-bottom: 0.5rem;
}

.recomTitle p{
    color: var(--cafe-gris-400);
    font-size: 1rem;
    margin-top: 0;
}

.menuTitle p{
    color: var(--cafe-gris-900);
    font-size: 1rem;
    margin-top: 0;
    font-weight: 400;
}

/*Recomendados*/

.gridRecom {
    align-items: stretch;
}

.cardRecom {
    display: flex;
}

.platilloRecom{
    border: 1px solid var(--cafe-gris-200);
    border-radius: var(--cafe-radius-md);
    overflow: hidden;
    box-shadow: var(--cafe-shadow-sm);
    background-color: var(--cafe-crema);
    height: 100%;
    width: 100%;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.platilloRecom:hover {
    transform: translateY(-3px);
    box-shadow: var(--cafe-shadow-md);
}

.platilloRecom .row {
    min-height: 168px;
    height: 100%;
}

.platilloRecom .col-5 {
    padding: 0.55rem;
}

.platilloRecom img {
    width: 100%;
    height: 100%;
    min-height: 148px;
    object-fit: cover;
    border-radius: var(--cafe-radius-sm);
}

.platilloRecom .card-body {
    padding: 1rem;
    height: 100%;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.platilloRecom .card-title {
    font-size: clamp(0.98rem, 2vw, 1.12rem);
    line-height: 1.15;
    font-weight: 800;
    margin-bottom: 0;
    min-height: 2.55em;
}

.platilloRecom .card-text {
    color: var(--cafe-gris-400);
    display: -webkit-box;
    font-size: 0.82rem;
    line-height: 1.35;
    margin-bottom: 0;
    min-height: 4.05em;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.platilloRecom .card-price {
    color: var(--cafe-brown);
    font-size: 1.12rem;
    font-weight: 400;
    margin-top: auto;
}

.recomBtn{
    background-color: var(--cafe-light-brown);
    color: var(--cafe-blanco);
    border: 1px solid var(--cafe-light-brown);

}

/*Menu principal*/
.menuCategorias {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.categoriaBtn {
    min-height: 90px;
    position: relative;
    overflow: hidden;

    border: none;
    border-radius: var(--cafe-radius-md);
    padding: 1.25rem;

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

    color: var(--cafe-blanco);
    font-family: var(--font-title);
    font-size: 1.3rem;
    font-weight: 600;

    background-size: cover;
    background-position: center;
    box-shadow: var(--cafe-shadow-sm);

}

.categoriaBtn::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;

    background: linear-gradient(
        90deg,
        rgba(44, 44, 44, 0.76),
        rgba(111, 78, 55, 0.58)
    );
}

.categoriaBtn span {
    position: relative;
    z-index: 2;
}

.cookiecup {
    background-image: url('../assets/images/products/cookiecup.webp');
    background-size: 115%;
    background-position: center 45%;
}

.lunch {
    background-image: url('../assets/images/products/lunch.webp');
}

.brunch {
    background-image: url('../assets/images/products/focaccia.webp');
}

.bebidas {
    background-image: url('../assets/images/products/bebidas/coldBrewFA.webp');
    background-size: 120%;
    background-position: center 65%;
}

.panaderia {
    background-image: url('../assets/images/products/wafflitoTropico.webp');
}

.adiciones {
    background-image: url('../assets/images/products/adiciones.webp');
}

/*Cards Productos*/
.card {
    border: 1px solid var(--cafe-gris-200);
    border-radius: var(--cafe-radius-md);
    overflow: hidden;
    background-color: var(--cafe-crema);
    box-shadow: var(--cafe-shadow-sm);
}

.card-img-top {
    width: 100%;
    height: 130px;
    object-fit: cover;
}

.card-img-top.imagen-contain {
    object-fit: cover;
    object-position: center 48%;
    background-color: var(--cafe-crema);
}

.card-img-top.imagen-coldbrew-tonic {
    object-fit: cover;
    object-position: center 48%;
    background-color: var(--cafe-crema);
}

.card-img-top.imagen-milo-frio {
    object-position: center 35%;
}

.card-img-top.imagen-flat-white {
    object-position: center 38%;
}

.card-img-top.imagen-ice-flat-white {
    object-position: center 34%;
}

.card-img-top.imagen-infusion-casa {
    object-position: 80% center;
}

.productoModalImagen.imagen-contain {
    height: min(72vh, 620px);
    object-fit: cover;
    object-position: center 48%;
    background-color: var(--cafe-crema);
}

.productoModalImagen.imagen-coldbrew-tonic {
    height: min(72vh, 620px);
    object-fit: cover;
    object-position: center 48%;
    background-color: var(--cafe-crema);
}

.productoModalImagen.imagen-flat-white {
    object-position: center 38%;
}

.productoModalImagen.imagen-ice-flat-white {
    object-position: center 34%;
}

.card-body {
    padding: 0.85rem;
}

.card-title {
    font-size: 1rem;
    font-weight: 800;
    margin-bottom: 0.45rem;
}

.card-text {
    font-size: 0.78rem;
    color: var(--cafe-gris-400);
    margin-bottom: 0.5rem;
}

.card-price {
    font-family: var(--font-body);
    font-size: 0.95rem;
    font-weight: 400;
    color: var(--cafe-gris-900);
    margin-bottom: 0;
}

.productoCardClickeable {
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.productoCardClickeable:hover,
.productoCardClickeable:focus-visible {
    transform: translateY(-3px);
    box-shadow: var(--cafe-shadow-md);
}

.productoCardClickeable:focus-visible {
    outline: 3px solid var(--cafe-purple);
    outline-offset: 3px;
}

.cookieCard {
    height: 100%;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.cookieCard:hover {
    transform: translateY(-3px);
    box-shadow: var(--cafe-shadow-md);
}

.cookieCard .card-img-top {
    height: clamp(118px, 22vw, 150px);
}

.cookieCard .card-body {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    height: 100%;
}

.cookieCard .card-title {
    min-height: 2.4em;
    margin-bottom: 0;
    line-height: 1.18;
}

.cookieCard .card-text {
    display: -webkit-box;
    min-height: 4.05em;
    margin-bottom: 0;
    overflow: hidden;
    line-height: 1.35;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.cookieCard .card-price {
    color: var(--cafe-brown);
    font-weight: 400;
    margin-top: auto;
}

#vistaLunch .card {
    height: 100%;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#vistaLunch .card:hover {
    transform: translateY(-3px);
    box-shadow: var(--cafe-shadow-md);
}

#vistaLunch .card-img-top {
    height: clamp(118px, 22vw, 150px);
}

#vistaLunch .card-body {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    height: 100%;
}

#vistaLunch .card-title {
    min-height: 2.4em;
    margin-bottom: 0;
    line-height: 1.18;
}

#vistaLunch .card-text {
    display: -webkit-box;
    min-height: 4.05em;
    margin-bottom: 0;
    overflow: hidden;
    line-height: 1.35;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

#vistaLunch .cremasCard .card-title,
#vistaLunch .cremasCard .card-text {
    min-height: 0;
}

#vistaLunch .card-price {
    color: var(--cafe-brown);
    font-weight: 400;
    margin-top: auto;
}

#vistaBrunch .card {
    height: 100%;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#vistaBrunch .card:hover {
    transform: translateY(-3px);
    box-shadow: var(--cafe-shadow-md);
}

#vistaBrunch .card-img-top {
    height: clamp(118px, 22vw, 150px);
}

#vistaBrunch .card-body {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    height: 100%;
}

#vistaBrunch .card-title {
    min-height: 2.4em;
    margin-bottom: 0;
    line-height: 1.18;
}

#vistaBrunch .card-text {
    display: -webkit-box;
    min-height: 4.05em;
    margin-bottom: 0;
    overflow: hidden;
    line-height: 1.35;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

#vistaBrunch .card-price {
    color: var(--cafe-brown);
    font-weight: 400;
    margin-top: auto;
}

#vistaBebidas .card {
    height: 100%;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#vistaBebidas .card:hover {
    transform: translateY(-3px);
    box-shadow: var(--cafe-shadow-md);
}

#vistaBebidas .card-img-top {
    height: clamp(118px, 22vw, 150px);
}

#vistaBebidas .card-body {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    height: 100%;
}

#vistaBebidas .card-title {
    min-height: 2.4em;
    margin-bottom: 0;
    line-height: 1.18;
}

#vistaBebidas .card-text {
    display: -webkit-box;
    min-height: 4.05em;
    margin-bottom: 0;
    overflow: hidden;
    line-height: 1.35;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

#vistaBebidas .card-price {
    color: var(--cafe-brown);
    font-weight: 400;
    margin-top: auto;
}

#vistaPanaderia .card {
    height: 100%;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#vistaPanaderia .card:hover {
    transform: translateY(-3px);
    box-shadow: var(--cafe-shadow-md);
}

#vistaPanaderia .card-img-top {
    height: clamp(118px, 22vw, 150px);
}

#vistaPanaderia .card-body {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    height: 100%;
}

#vistaPanaderia .card-title {
    min-height: 2.4em;
    margin-bottom: 0;
    line-height: 1.18;
}

#vistaPanaderia .card-text {
    display: -webkit-box;
    min-height: 4.05em;
    margin-bottom: 0;
    overflow: hidden;
    line-height: 1.35;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

#vistaPanaderia .card-price {
    color: var(--cafe-brown);
    font-weight: 400;
    margin-top: auto;
}

#vistaAdiciones .card {
    height: 100%;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#vistaAdiciones .card:hover {
    transform: translateY(-3px);
    box-shadow: var(--cafe-shadow-md);
}

#vistaAdiciones .card-img-top {
    height: clamp(118px, 22vw, 150px);
}

#vistaAdiciones .card-body {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    height: 100%;
}

#vistaAdiciones .card-title {
    min-height: 2.4em;
    margin-bottom: 0;
    line-height: 1.18;
}

#vistaAdiciones .card-text {
    display: -webkit-box;
    min-height: 4.05em;
    margin-bottom: 0;
    overflow: hidden;
    line-height: 1.35;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

#vistaAdiciones .card-price {
    color: var(--cafe-brown);
    font-weight: 400;
    margin-top: auto;
}

.productoModal {
    position: fixed;
    inset: 0;
    z-index: 2000;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 1.25rem;
}

.productoModal.activo {
    display: flex;
}

.productoModalBackdrop {
    position: absolute;
    inset: 0;
    background-color: rgba(44, 44, 44, 0.72);
}

.productoModalDialog {
    position: relative;
    z-index: 1;
    width: min(92vw, 520px);
    max-height: 90vh;
    overflow: auto;
    border-radius: var(--cafe-radius-md);
    background-color: var(--cafe-crema);
    box-shadow: var(--cafe-shadow-md);
}

.productoModalClose {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    z-index: 2;
    width: 42px;
    height: 42px;
    border: none;
    border-radius: 50%;
    background-color: rgba(247, 243, 239, 0.92);
    color: var(--cafe-gris-900);
    font-size: 1.8rem;
    line-height: 1;
    cursor: pointer;
    box-shadow: var(--cafe-shadow-sm);
}

.productoModalClose:focus-visible {
    outline: 3px solid var(--cafe-purple);
    outline-offset: 2px;
}

.productoModalImagen {
    width: 100%;
    height: min(52vh, 380px);
    object-fit: cover;
    background-color: var(--cafe-gris-200);
}

.productoModalInfo {
    padding: 1.25rem;
}

.productoModalInfo h3 {
    margin: 0 0 0.65rem;
    color: var(--cafe-brown);
    font-family: var(--font-title);
    font-size: clamp(1.45rem, 4vw, 2rem);
    font-weight: 800;
}

.productoModalInfo p {
    margin: 0;
}

.productoModalInfo #productoModalDescripcion {
    color: var(--cafe-gris-900);
    font-size: 0.98rem;
}

.productoModalInfo #productoModalPrecio {
    margin-top: 1rem;
    color: var(--cafe-purple);
    font-size: 1.25rem;
    font-weight: 800;
}

.productoModalAdiciones {
    margin-top: 1.1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--cafe-gris-200);
}

.productoModalAdiciones h4 {
    margin: 0 0 0.75rem;
    color: var(--cafe-brown);
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 800;
}

.productoModalAdiciones ul {
    display: grid;
    gap: 0.45rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.productoModalAdiciones li {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid rgba(229, 225, 220, 0.75);
    color: var(--cafe-gris-900);
    font-size: 0.9rem;
}

.productoModalAdiciones li:last-child {
    border-bottom: none;
}

.productoModalAdiciones p {
    color: var(--cafe-gris-400);
    font-size: 0.9rem;
}

.productoModalAdiciones strong {
    flex: 0 0 auto;
    color: var(--cafe-purple);
    font-weight: 800;
}

/*Acordeon*/

.accordion {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.accordion-item {
    border: 1px solid var(--cafe-gris-200);
    border-radius: var(--cafe-radius-md);
    overflow: hidden;
    background-color: var(--cafe-crema);
    box-shadow: var(--cafe-shadow-sm);
}

.accordion-button {
    background-color: var(--cafe-crema);
    color: var(--cafe-brown);
    font-family: var(--font-title);
    font-weight: 600;
}

.accordion-button:not(.collapsed) {
    background-color: var(--cafe-purple);
    color: var(--cafe-blanco);
    font-weight: 700;
}

.accordion-button::after {
    transition: var(--cafe-transition);
}

.accordion-button:not(.collapsed)::after {
    transform: rotate(180deg);
}

.accordionCompacto {
    padding: 0.85rem 1rem;
    font-size: 0.95rem;
}

.accordion-body {
    background-color: var(--cafe-blanco);
    padding: 1rem;
}

.accordion-button:focus,
.accordion-button:active,
.accordion-button:not(.collapsed) {
    box-shadow: none !important;
    outline: none !important;
}

/* Animaciones de desplazamiento del acordeón */

.accordion-collapse {
    transition: all 0.6s ease;
}

.accordion-collapse.show {
    animation: slideDownOpen 0.8s ease-out;
}

@keyframes slideDownOpen {
    from {
        opacity: 0;
        transform: translateY(-12px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/*Bebidas*/

.bebidasFiltros {
    display: flex;
    gap: 0.5rem;
    overflow-x: auto;
    padding-bottom: 0.75rem;
    margin-bottom: 1.5rem;
}

.filtroBebida {
    flex: 0 0 auto;
    border: 1px solid var(--cafe-brown);
    background-color: var(--cafe-crema);
    color: var(--cafe-brown);
    padding: 0.65rem 0.8rem;
    border-radius: var(--cafe-radius-pill);
    font-weight: 800;
    transition: var(--cafe-transition);
}

.filtroBebida.activo {
    background-color: var(--cafe-purple);
    border-color: var(--cafe-purple);
    color: var(--cafe-blanco);
    font-family: var(--font-title);
    font-weight: 700;
}

/*Listas Compactas*/

.listaCompacta {
    background-color: var(--cafe-crema);
    border-radius: var(--cafe-radius-sm);
    padding: 0.75rem;
}

.itemLista {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--cafe-gris-200);
}

.itemLista:last-child {
    border-bottom: none;
}

.itemLista strong {
    color: var(--cafe-brown);
}

/*Responsive*/
@media (max-width: 576px) {
    body {
        font-size: 15px;
    }

    .container {
        max-width: 100%;
        padding-left: 14px;
        padding-right: 14px;
    }

    .recomendados,
    .menu {
        padding: 2.5rem 0;
    }

    .platilloRecom .row {
        min-height: 154px;
    }

    .platilloRecom .col-5 {
        padding: 0.45rem;
    }

    .platilloRecom img {
        min-height: 136px;
    }

    .platilloRecom .card-body {
        padding: 0.8rem 0.75rem;
        gap: 0.25rem;
    }

    .platilloRecom .card-title {
        font-size: 0.98rem;
        min-height: 2.35em;
    }

    .platilloRecom .card-text {
        font-size: 0.76rem;
        -webkit-line-clamp: 3;
    }

    .platilloRecom .card-price {
        font-size: 1rem;
    }

    .card-img-top {
        height: 110px;
    }

    .card-body {
        padding: 0.75rem;
    }

    .card-title {
        font-size: 0.92rem;
    }

    .card-text {
        font-size: 0.74rem;
    }

    .categoriaBtn {
        min-height: 86px;
        font-size: 1.25rem;
    }

    .heroe-logo {
        max-width: 150px;
    }
}

@media (min-width: 768px) {
    .card-img-top {
        height: 150px;
    }
}

@media (min-width: 992px) {
    .recomendados,
    .menu {
        padding: 5rem 0;
    }

    .layoutMenu,
    .layoutRecom {
        max-width: 960px;
    }

    .platilloRecom .row {
        min-height: 188px;
    }

    .platilloRecom .col-5 {
        padding: 0.7rem;
    }

    .platilloRecom img {
        min-height: 164px;
    }

    .platilloRecom .card-body {
        padding: 1.1rem;
    }

    .platilloRecom .card-text {
        -webkit-line-clamp: 4;
    }

    .categoriaBtn {
        min-height: 110px;
    }
}

.app-section {
    display: none;
}

.app-section.activa {
    display: block;
}

.app-header {
    display: none;
}

.app-header.activa {
    display: block;
}

/* =========================
   TRANSICIONES DE SECCIONES
========================= */

.app-section {
    display: none;
    opacity: 0;
    transform: translateY(10px);
}

.app-section.activa {
    display: block;
    opacity: 1;
    transform: translateY(0);
    animation: fadeInSection 0.8s ease-out;
}

@keyframes fadeInSection {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

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


/* =========================
   TRANSICIONES DE VISTAS MENU
========================= */

.vista-menu {
    display: none;
    opacity: 0;
    transform: translateY(8px);
}

.vista-menu.activa {
    display: block;
    opacity: 1;
    transform: translateY(0);
    animation: fadeInView 0.8s ease-out;
}

@keyframes fadeInView {
    from {
        opacity: 0;
        transform: translateY(8px);
    }

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


/*Transiciones*/

.panelBebida {
    display: none;
    opacity: 0;
    transform: translateY(6px);
}

.panelBebida.activo {
    display: block;
    opacity: 1;
    transform: translateY(0);
    animation: fadeInPanel 0.8s ease-out;
}

@keyframes fadeInPanel {
    from {
        opacity: 0;
        transform: translateY(6px);
    }

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

.tituloCards h3{
    margin-top: 1rem;
}

.footerCafe {
    display: none;
    max-width: calc(100% - 2rem);
    margin: 0 auto 1rem;
    background-color: var(--cafe-purple);
    border-radius: var(--cafe-radius-md);
    padding: 0.6rem 0;
    overflow: hidden;
}

.footerCafe.activa {
    display: block;
}

.footerCafeLayout {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
}

.footerCafeLogo img {
    width: 96px;
    border-radius: 0;
}

.footerCafeSocial {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.footerSocialLink {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border: 1px solid rgba(247, 243, 239, 0.45);
    border-radius: 50%;
    background-color: var(--cafe-bg);
    color: var(--cafe-bg);
    font-weight: 800;
    transition: transform 0.2s ease, background-color 0.2s ease;
}

.footerSocialLink:hover,
.footerSocialLink:focus-visible {
    transform: translateY(-2px);
    background-color: var(--cafe-bg);
    color: var(--cafe-blanco);
}

.footerSocialLink img {
    width: 22px;
    height: 22px;
    object-fit: contain;
    border-radius: 0;
}

.footerSocialLink[aria-label="Instagram"] img {
    width: 25px;
    height: 25px;
}

.footerSocialText {
    font-family: var(--font-title);
    font-size: 1.05rem;
}

@media (max-width: 576px) {
    .footerCafeLayout {
        flex-direction: column;
        justify-content: center;
    }
}
