.elementor-5216 .elementor-element.elementor-element-1f865ebf{--display:flex;--min-height:80px;--flex-direction:row;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:space-between;--align-items:center;--gap:1% 3%;--row-gap:1%;--column-gap:3%;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0%;--padding-bottom:0%;--padding-left:4%;--padding-right:4%;--z-index:9999;}.elementor-5216 .elementor-element.elementor-element-1f865ebf:not(.elementor-motion-effects-element-type-background), .elementor-5216 .elementor-element.elementor-element-1f865ebf > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0B0B0B;}.elementor-theme-builder-content-area{height:400px;}.elementor-location-header:before, .elementor-location-footer:before{content:"";display:table;clear:both;}@media(max-width:1024px){.elementor-5216 .elementor-element.elementor-element-1f865ebf{--gap:2% 2%;--row-gap:2%;--column-gap:2%;--padding-top:0%;--padding-bottom:0%;--padding-left:3%;--padding-right:3%;}}/* Start custom CSS for html, class: .elementor-element-77aa95c *//* === VARIABLES === */
.rtve-v2.rtve-reservas {
    --h-brand: 22; --s-brand: 90%; --l-brand: 54%;
    --color-brand-primary: hsl(var(--h-brand), var(--s-brand), var(--l-brand));
    --color-white: #ffffff;
    --color-light-gray: #e0e0e0;
    --header-height: 80px;
    --max-width: 1200px;
    --transition-fast: 0.2s ease;
    --font-heading: 'Outfit', sans-serif;
    --font-body: 'Inter', sans-serif;
}

/* === HEADER === */
.rtve-reservas .header {
    position: fixed; top: 0; left: 0; width: 100%; height: var(--header-height);
    background: rgba(10, 10, 15, 0.85); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1); z-index: 99999;
    display: flex; align-items: center;
}
.rtve-reservas .header::before {
    content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 3px;
    background: var(--color-brand-primary); z-index: 10;
}
.rtve-reservas .header-inner {
    display: flex; justify-content: space-between; align-items: center;
    width: 100%; max-width: var(--max-width); margin: 0 auto; padding: 0 2rem;
}

/* === LOGO === */
.rtve-reservas .header-logo {
    height: 45px; width: auto; display: block;
    transition: opacity var(--transition-fast);
}
.rtve-reservas .header-logo:hover { opacity: 0.7; }

/* === NAVEGACIÓN DESKTOP === */
.rtve-reservas .nav { display: flex; gap: 2.5rem; }
.rtve-reservas .nav a {
    position: relative; color: var(--color-light-gray); font-family: var(--font-body);
    font-size: 0.9rem; font-weight: 500; text-transform: uppercase;
    text-decoration: none; padding: 0.5rem 0; transition: color var(--transition-fast);
}
.rtve-reservas .nav a::after {
    content: ""; position: absolute; bottom: 0; left: 0; width: 0; height: 2px;
    background: var(--color-brand-primary); transition: width 0.3s ease;
}
.rtve-reservas .nav a:hover,
.rtve-reservas .nav a.active { color: var(--color-white); }
.rtve-reservas .nav a:hover::after,
.rtve-reservas .nav a.active::after { width: 100%; }

/* === CARRITO === */
.rtve-reservas .header-right { display: flex; align-items: center; gap: 2rem; }
.rtve-reservas .cart-link {
    position: relative; display: inline-flex; align-items: center; justify-content: center;
    width: 44px; height: 44px; border-radius: 50%;
    background: rgba(255, 255, 255, 0.05); border: 1px solid rgba(255, 255, 255, 0.1);
    color: white !important; text-decoration: none;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.rtve-reservas .cart-link:hover {
    background: rgba(242, 111, 33, 0.1); border-color: var(--color-brand-primary);
    transform: translateY(-2px) scale(1.05);
}
.rtve-reservas .cart-badge {
    position: absolute; top: -2px; right: -2px; background: var(--color-brand-primary);
    color: white; font-size: 0.65rem; font-weight: 800; width: 18px; height: 18px;
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    box-shadow: 0 0 10px rgba(242, 111, 33, 0.4);
}

/* === LOGO DERECHA === */
.rtve-reservas .header-logo-right-link {
    display: flex; align-items: center; transition: transform 0.3s ease;
}
.rtve-reservas .header-logo-right-link:hover { transform: scale(1.05); }
.rtve-reservas .header-logo-right { height: 32px; width: auto; opacity: 0.9; }

/* === HAMBURGUESA === */
.rtve-reservas .menu-toggle {
    display: none; flex-direction: column; gap: 6px;
    background: none; border: none; cursor: pointer; padding: 10px; z-index: 10001;
}
.rtve-reservas .menu-toggle span {
    display: block; width: 28px; height: 2px; background-color: #fff;
    transition: 0.3s; border-radius: 2px;
}
.rtve-reservas .menu-toggle.active span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.rtve-reservas .menu-toggle.active span:nth-child(2) { opacity: 0; }
.rtve-reservas .menu-toggle.active span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

/* === MENÚ MÓVIL === */
.rtve-reservas .mobile-menu {
    position: fixed; top: var(--header-height); left: 0; width: 100%; height: 0;
    background: rgba(10, 10, 15, 0.98); backdrop-filter: blur(25px);
    overflow: hidden; transition: height 0.4s cubic-bezier(0.16, 1, 0.3, 1); z-index: 9998;
}
.rtve-reservas .mobile-menu.active {
    height: auto !important; padding-bottom: 30px;
    border-bottom: 1px solid var(--color-brand-primary);
}
.rtve-reservas .mobile-nav {
    display: flex; flex-direction: column; padding: 40px 2rem; gap: 2rem;
}
.rtve-reservas .mobile-nav a {
    color: #fff; font-size: 1.5rem; font-family: var(--font-heading);
    font-weight: 700; text-decoration: none; text-transform: uppercase;
    letter-spacing: 1px; padding-left: 15px; border-left: 2px solid transparent;
    transition: all 0.3s ease;
}
.rtve-reservas .mobile-nav a:hover,
.rtve-reservas .mobile-nav a:active {
    border-left-color: var(--color-brand-primary); color: var(--color-brand-primary);
    padding-left: 20px;
}

/* === RESPONSIVE === */
@media (max-width: 991px) {
    .rtve-reservas .desktop-only { display: none !important; }
    .rtve-reservas .menu-toggle { display: flex; }
    .rtve-reservas .header-logo { height: 35px; }
    .rtve-reservas .header-inner { padding: 0 1.5rem; }
    .rtve-reservas .header-right { gap: 0.5rem; }
}/* End custom CSS */