:root {
    --tp-yellow-main: #FFD43B;
    --tp-yellow-dark: #F5B000;
    --tp-yellow-bg: #FFE873;
    --tp-blue-outline: #0B5ED7;
    --tp-blue-dark: #083D77;
    --tp-red: #E63946;
    --tp-white: #ffffff;
    --font-display: 'Luckiest Guy', cursive;
    --font-secondary: 'Fredoka', sans-serif;
    --font-body: 'Baloo 2', cursive;
    --golden-ratio: 1.618;
    --text-stroke: 0.03em var(--tp-blue-outline);
    --text-shadow: 0.05em 0.05em 0px var(--tp-blue-dark);
    --tilt: 8vw;
    --tilt-angle: -4.5deg;
    --header-height: 80px;
    --border-radius: 55px;
    --transition: 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

@keyframes trampoline-jump {
    0% { transform: scale(1); }
    30% { transform: scale(0.85); }
    60% { transform: scale(1.15); }
    80% { transform: scale(0.95); }
    100% { transform: scale(1.05); }
}

.trampoline-hover:hover, 
.nav-links li a:hover,
.nav-links li a.active,
.nav-cta:hover, 
.hero-cta:hover, 
.social-btn:hover img {
    animation: trampoline-jump 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
}

.nav-links li a.active {
    color: var(--tp-yellow-main);
}
* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: var(--font-body); line-height: 1.6; background-color: var(--tp-yellow-bg); color: var(--tp-blue-outline); overflow-x: hidden; }
a { text-decoration: none; color: inherit; transition: var(--transition); }
ul { list-style: none; }
h1, h2, h3, h4, h5, .logo-text { font-family: var(--font-display); color: var(--tp-yellow-main); -webkit-text-stroke: var(--text-stroke); text-shadow: var(--text-shadow); text-transform: uppercase; letter-spacing: 1px; line-height: 1.1; }
h1 { font-size: clamp(2.5rem, 10vw, 5rem); }
h2 { font-size: clamp(2rem, 8vw, 3.1rem); }
h3 { font-size: clamp(1.5rem, 6vw, 1.9rem); }
h4 { font-size: clamp(1.2rem, 4vw, 1.2rem); }
p { font-size: clamp(1rem, 2vw, 1.1rem); line-height: 1.6; }

#header-upj { position: fixed; top: 0; left: 0; width: 100%; z-index: 1000; background: rgba(8, 61, 119, 0.9); transition: var(--transition); }
.sede-switcher { background: var(--tp-blue-dark); color: var(--tp-white); text-align: center; font-size: 12px; padding: 5px 0; font-family: var(--font-secondary); letter-spacing: 1px; }
.sede-switcher span { margin-right: 10px; opacity: 0.8; }
.sede-switcher a { color: var(--tp-white); }
.sede-switcher a.active { font-weight: bold; color: var(--tp-yellow-main); }
.header-container { display: flex; justify-content: space-between; align-items: center; min-height: var(--header-height); padding: 5px 40px; }
.logo-text { font-size: clamp(1.5rem, 4vw, 2.2rem); max-width: 300px; display: inline-block; }
.nav-links { display: flex; gap: 21px; align-items: center; color: var(--tp-white); font-family: var(--font-secondary); font-weight: 600; font-size: 15px; text-transform: uppercase; }
.nav-links li a:hover { color: var(--tp-yellow-main); }
.nav-cta { background: var(--tp-red); color: var(--tp-white) !important; padding: 8px 21px; border-radius: var(--border-radius); border: 2px solid var(--tp-white); font-family: var(--font-display); font-size: 15px; box-shadow: 0 4px 0px var(--tp-blue-dark); transition: var(--transition); display: inline-block; letter-spacing: 1px; -webkit-text-stroke: 0; text-shadow: none; }
.nav-cta:hover { transform: translateY(2px); box-shadow: 0 2px 0px var(--tp-blue-dark); }
.mobile-toggle { display: none; color: var(--tp-white); font-size: 38px; cursor: pointer; width: 48px; height: 48px; align-items: center; justify-content: center; }

.hero { position: relative; height: 100vh; display: flex; align-items: center; justify-content: center; overflow: hidden; background-color: var(--tp-blue-dark); clip-path: polygon(0 0, 100% 0, 100% 100%, 0 calc(100% - var(--tilt))); z-index: 2; }
.hero-video-container { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; }
.hero-video-container video { width: 100%; height: 100%; object-fit: cover; opacity: 0.5; }
.hero-content { position: relative; z-index: 2; text-align: center; padding: 20px; padding-top: 80px; }
.hero-content h1 { margin-bottom: 21px; }
.hero-cta { background: var(--tp-red); color: var(--tp-white); font-family: var(--font-display); font-size: clamp(0.9rem, 3.5vw, 1.4rem); padding: clamp(8px, 1.8vh, 12px) clamp(20px, 4vw, 40px); border-radius: var(--border-radius); border: clamp(2px, 0.4vw, 3px) solid var(--tp-white); box-shadow: 0 clamp(3px, 0.6vw, 6px) 0px var(--tp-blue-dark); display: inline-block; transition: 0.2s ease; letter-spacing: 1px; }
.hero-cta:hover { transform: translateY(2px); box-shadow: 0 clamp(1px, 0.2vw, 3px) 0px var(--tp-blue-dark); }

.container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.crack-grid, .info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: center; }
.image-decor { display: flex; justify-content: center; align-items: center; }
.image-decor img { max-width: 100%; height: auto; display: block; }
h2 { margin-bottom: 1.5rem; }

/* Section01 - Crack (Impar) */
.Section01 { padding: 50px 0; background-color: var(--tp-yellow-main); background-image: radial-gradient(rgba(0,0,0,0.1) 2px, transparent 2px); background-size: 15px 15px; clip-path: polygon(0 0, 100% var(--tilt), 100% calc(100% - var(--tilt)), 0 100%); margin-top: calc(var(--tilt) * -1); position: relative; z-index: 3; }

/* Section02 - Attractions (Par - Ascendente) */
.Section02 { padding: 80px 0 50px 0; background-color: var(--tp-red); background-image: radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.18) 0%, transparent 70%), radial-gradient(circle at 50% 50%, var(--tp-red) 0%, transparent 45%), repeating-conic-gradient(from 0deg at 50% 50%, var(--tp-red) 0deg 5deg, #c92c39 5deg 10deg); position: relative; clip-path: polygon(0 var(--tilt), 100% 0, 100% calc(100% - var(--tilt)), 0 100%); margin-top: calc(var(--tilt) * -1); z-index: 4; color: var(--tp-white); }
.Section02::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: radial-gradient(rgba(0,0,0,0.35) 2.2px, transparent 2.2px); background-size: 15px 15px; -webkit-mask-image: radial-gradient(circle, black 0%, transparent 12%); mask-image: radial-gradient(circle, black 0%, transparent 12%); pointer-events: none; z-index: 0; }
.Section02 .container, .Section02 .carousel-container { position: relative; z-index: 1; }
.Section02 h2 { text-align: center; margin-bottom: 0.5rem; display: block; transform: rotate(var(--tilt-angle)); }

.carousel-container { width: 100%; overflow: hidden; padding: 10px 0 40px 0; position: relative; transform: rotate(var(--tilt-angle)); }
.carousel-track { display: flex; gap: 18px; width: max-content; animation: scroll-diagonal-fixed 30s linear infinite; }
@keyframes scroll-diagonal-fixed { 0% { transform: translateX(-50%); } 100% { transform: translateX(0); } }
.attraction-card { width: clamp(250px, 20vw, 350px); aspect-ratio: 3/4; position: relative; background: var(--tp-blue-dark); clip-path: polygon(0 0, 85% 0, 100% 15%, 100% 100%, 0 100%, 0 85%); box-shadow: 10px 10px 0px var(--tp-blue-outline); overflow: hidden; border: 3px solid var(--tp-white); transition: var(--transition); -webkit-mask-image: -webkit-radial-gradient(white, black); isolation: isolate; }
.attraction-card img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(1.2) contrast(1.1); transform: scale(1.3); backface-visibility: hidden; -webkit-backface-visibility: hidden; transition: opacity 0.3s ease; }
.card-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 40%; background: linear-gradient(rgba(8, 61, 119, 0.8), transparent); display: flex; align-items: flex-start; justify-content: flex-start; padding: 25px; pointer-events: none; }
.card-overlay h3 { font-size: clamp(1.1rem, 2.5vw, 1.4rem); margin: 0; color: var(--tp-yellow-main); text-align: left; }

/* Section03 - Cumples Epicos (Impar) */
.Section03 { padding: 100px 0; background-color: var(--tp-yellow-main); background-image: radial-gradient(rgba(0,0,0,0.1) 2px, transparent 2px); background-size: 15px 15px; clip-path: polygon(0 var(--tilt), 100% 0, 100% 100%, 0 calc(100% - var(--tilt))); margin-top: calc(var(--tilt) * -1); position: relative; z-index: 5; }

/* Section04 - Info (Par - Descendente) */
.Section04 { padding: 100px 0 0 0; background-color: var(--tp-blue-outline); background-image: radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.15) 0%, transparent 70%), radial-gradient(circle at 50% 50%, var(--tp-blue-outline) 0%, transparent 45%), repeating-conic-gradient(from 0deg at 50% 50%, var(--tp-blue-outline) 0deg 5deg, #083D77 5deg 10deg); position: relative; clip-path: polygon(0 0, 100% var(--tilt), 100% 100%, 0 calc(100% - var(--tilt))); margin-top: calc(var(--tilt) * -1); z-index: 6; color: var(--tp-white); }
.Section04::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: radial-gradient(rgba(0,0,0,0.2) 2.2px, transparent 2.2px); background-size: 15px 15px; -webkit-mask-image: radial-gradient(circle, black 0%, transparent 15%); mask-image: radial-gradient(circle, black 0%, transparent 15%); pointer-events: none; z-index: 0; }
.Section04 .container { position: relative; z-index: 1; } .Section04 .info-grid { gap: 34px; align-items: center; } .Section04 .text-block { transform: translateY(-34px); text-align: center; } .Section04 .image-decor { align-self: end; display: flex; align-items: flex-end; } .Section04 .image-decor img { margin-bottom: 0; display: block; }
.Section04 h2 { color: var(--tp-yellow-main); margin-bottom: 1.3rem; text-align: center; transform: none; }

/* Section05 - Crack (Impar) */
.Section05 { padding: 50px 0; background-color: var(--tp-yellow-main); background-image: radial-gradient(rgba(0,0,0,0.1) 2px, transparent 2px); background-size: 15px 15px; clip-path: polygon(0 0, 100% var(--tilt), 100% calc(100% - var(--tilt)), 0 100%); margin-top: calc(var(--tilt) * -1); position: relative; z-index: 7; }

/* Footer */
footer { background-color: var(--tp-blue-dark); color: var(--tp-white); padding: 120px 0 60px 0; clip-path: polygon(0 var(--tilt), 100% 0, 100% 100%, 0 100%); margin-top: calc(var(--tilt) * -1); position: relative; z-index: 8; text-align: center; }
.footer-reserva { display: none; }
.footer-content h3 { color: var(--tp-yellow-main); margin-bottom: 20px; }
.social-icons { display: flex; justify-content: center; gap: clamp(13px, 3vw, 21px); margin: 30px 0; }
.social-btn img { width: clamp(55px, 8vw, 144px); height: clamp(55px, 8vw, 144px); transition: var(--transition); filter: drop-shadow(0 4px 4px rgba(0,0,0,0.2)); }
.social-btn:hover img { filter: drop-shadow(0 8px 8px rgba(0,0,0,0.3)); }
.footer-links { display: flex; justify-content: center; gap: 40px; margin-top: 30px; font-family: var(--font-secondary); font-weight: 600; text-transform: uppercase; }
.footer-links a:hover { color: var(--tp-yellow-main); }
.copyright { margin-top: 40px; font-size: 14px; opacity: 0.7; }

@media (max-width: 896px) {
    .header-container { padding: 10px 20px; }
    .mobile-toggle { display: flex; }
    .main-nav { display: none; position: absolute; top: 100%; left: 0; width: 100%; background: var(--tp-blue-dark); flex-direction: column; padding: 40px 0; border-top: 1px solid rgba(255, 255, 255, 0.1); }
    .main-nav.active { display: flex; }
    .nav-links { flex-direction: column; align-items: center; gap: 25px; font-size: 24px; }
    .Section01, .Section05 { padding: 30px 0 60px 0; }
    .crack-grid, .info-grid { grid-template-columns: 1fr; text-align: center; gap: 10px; }
    .image-decor { order: -1; justify-content: center; }
    .Section03, .Section04 { padding: 60px 0 80px 0; }
    .Section02 { padding: 60px 0 40px 0; }
    .Section02 h2 { margin-bottom: 0.8rem; }
    .carousel-container { padding: 25px 0 40px 0; }
    .attraction-card { width: 220px; }
    .footer-links { flex-direction: column; gap: 15px; }
    footer { padding-top: 50px; } .footer-reserva { display: inline-block; position: relative; margin-bottom: 30px; }
    .footer-reserva { position: relative; top: 0; left: 0; margin-bottom: 30px; transform: none; }
    .social-icons { gap: 15px; }
}


