.experiencia {
    background: linear-gradient(135deg, #f8f8f8, #ffffff);
    padding: 80px 30px;
}

.experiencia h2 {
    text-align: center;
    margin-bottom: 15px;
}

.experiencia p.top-text {
    text-align: center;
    margin-bottom: 50px;
    font-size: 18px;
}

.experiencia-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 30px;
    max-width: 1200px;
    margin: auto;
}

.experiencia-card {
    background: white;
    border-radius: 18px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.08);
    overflow: hidden;
    transition: 0.3s;
}

.experiencia-card:hover {
    transform: translateY(-8px);
}

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

.experiencia-content {
    padding: 30px;
    text-align: center;
}

.experiencia-content h3 {
    margin-bottom: 15px;
    color: #3aa39c;
}

.experiencia-content p {
    margin-bottom: 25px;
    line-height: 1.6;
}
.mobile-reserva {
gap: 10px;
}

.mobile-reserva .material-symbols-outlined {
font-size: 22px;
}
@media (max-width: 768px) {
  .experiencia-card img {
    height: 160px;
  }
  .mobile-reserva {
display: flex;
position: fixed;
bottom: 0;
left: 0;
width: 100%;
height: 62px;
background: #3aa39c;
color: white;
text-decoration: none;
align-items: center;
justify-content: center;
font-size: 18px;
font-weight: 700;
z-index: 99999;
box-shadow: 0 -6px 20px rgba(0,0,0,0.18);
}

body {
padding-bottom: 70px;
}

.whatsapp-float {
bottom: 85px;
right: 18px;
}
.local-card {
padding: 18px;
font-size: 14px;
}
  .experiencia-content {
    padding: 18px;
  }

  .experiencia-content h3 {
    font-size: 20px;
    margin-bottom: 10px;
  }

  .experiencia-content p {
    font-size: 15px;
    margin-bottom: 18px;
    line-height: 1.5;
  }

  .experiencia-content .btn {
    padding: 12px 22px;
    font-size: 15px;
  }
  footer {
padding: 50px 20px 20px;
}

.footer-grid {
gap: 28px;
}
  .reserva-card {
padding: 22px;
}
.urgencia-box {
font-size: 15px;
padding: 18px;
line-height: 1.5;
}
  .hero-buttons {
flex-direction: column;
align-items: center;
gap: 12px;
}

.hero-buttons .btn {
width: 240px;
text-align: center;
}
}
.hero-buttons {
display: flex;
justify-content: center;
gap: 16px;
margin-top: 30px;
flex-wrap: wrap;
}

.btn-primary {
background: #3aa39c;
}

.btn-secondary {
background: rgba(255,255,255,0.18);
border: 1px solid rgba(255,255,255,0.35);
backdrop-filter: blur(8px);
}

.btn-secondary:hover {
background: rgba(255,255,255,0.28);
}
.card {
position: relative;
}

.price-badge {
position: absolute;
top: 14px;
right: 14px;
background: #3aa39c;
color: white;
padding: 10px 14px;
border-radius: 999px;
font-size: 13px;
font-weight: 600;
z-index: 10;
box-shadow: 0 6px 18px rgba(0,0,0,0.18);
}
.gallery-item {
position: relative;
break-inside: avoid;
margin-bottom: 20px;
border-radius: 16px;
overflow: hidden;
}

.gallery-item img {
margin-bottom: 0 !important;
display: block;
width: 100%;
transition: 0.35s ease;
}

.gallery-item:hover img {
transform: scale(1.04);
}

.gallery-item span {
position: absolute;
bottom: 14px;
left: 14px;
background: rgba(0,0,0,0.65);
backdrop-filter: blur(6px);
color: white;
padding: 8px 14px;
border-radius: 999px;
font-size: 13px;
font-weight: 500;
z-index: 5;
}
.reservas-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
gap: 22px;
margin-top: 40px;
}

.reserva-card {
background: white;
padding: 30px;
border-radius: 20px;
text-align: center;
text-decoration: none;
color: #2b2b2b;
box-shadow: 0 12px 30px rgba(0,0,0,0.08);
transition: 0.3s ease;
border: 1px solid rgba(58,163,156,0.10);
}

.reserva-card:hover {
transform: translateY(-8px);
box-shadow: 0 18px 40px rgba(0,0,0,0.12);
}

.reserva-icon {
width: 64px;
height: 64px;
margin: 0 auto 18px;
background: rgba(58,163,156,0.12);
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
color: #3aa39c;
}

.logo-completa {
height: 64px;
width: auto;
display: block;
object-fit: contain;
}

.reserva-icon .material-symbols-outlined {
font-size: 32px;
}

.reserva-card h3 {
color: #3aa39c;
margin-bottom: 12px;
font-size: 22px;
}

.reserva-card p {
font-size: 14px;
line-height: 1.6;
color: #666;
}
.urgencia {
padding: 30px 20px;
background: linear-gradient(135deg, #fff8ef, #fff3df);
}

.urgencia-box {
max-width: 900px;
margin: auto;
background: white;
padding: 22px 28px;
border-radius: 18px;
text-align: center;
font-size: 18px;
font-weight: 600;
color: #8a5a00;
box-shadow: 0 10px 28px rgba(0,0,0,0.06);
border: 1px solid rgba(255,180,0,0.15);
}
.faq {
padding: 90px 30px;
max-width: 1000px;
margin: auto;
}

.faq h2 {
text-align: center;
margin-bottom: 40px;
color: #3aa39c;
}

.faq-item {
background: white;
border-radius: 16px;
margin-bottom: 16px;
overflow: hidden;
box-shadow: 0 8px 24px rgba(0,0,0,0.06);
border: 1px solid rgba(58,163,156,0.08);
}

.faq-question {
width: 100%;
background: none;
border: none;
padding: 22px 24px;
text-align: left;
font-size: 17px;
font-weight: 600;
cursor: pointer;
color: #2b2b2b;
}

.faq-answer {
max-height: 0;
overflow: hidden;
transition: 0.35s ease;
}

.faq-answer p {
padding: 0 24px 22px;
color: #666;
line-height: 1.6;
}
.localizacao-info {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
gap: 18px;
margin-top: 30px;
}

.local-card {
background: white;
padding: 22px;
border-radius: 18px;
text-align: center;
font-weight: 600;
color: #2b2b2b;
box-shadow: 0 10px 26px rgba(0,0,0,0.06);
border: 1px solid rgba(58,163,156,0.08);
transition: 0.3s ease;
}

.local-card:hover {
transform: translateY(-6px);
}
footer {
background: linear-gradient(135deg, #2c7f79, #3aa39c);
color: white;
padding: 70px 30px 25px;
margin-top: 50px;
}

.footer-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
gap: 35px;
max-width: 1200px;
margin: auto;
}

.footer-grid h3,
.footer-grid h4 {
margin-bottom: 16px;
}

.footer-grid p {
line-height: 1.7;
font-size: 14px;
opacity: 0.95;
}

.footer-grid a {
color: white;
text-decoration: none;
}

.footer-grid a:hover {
text-decoration: underline;
}

.footer-copy {
text-align: center;
margin-top: 40px;
padding-top: 20px;
border-top: 1px solid rgba(255,255,255,0.20);
font-size: 13px;
opacity: 0.85;
}
