.reservation-section {
  position: relative;
  width: 81%;
  background-color: var(--primary-dark);
  overflow: visible; 
  margin: 0 auto;
}

.reservation-container {
  display: flex;
  margin: 0 auto;
}

.reservation-left {
  flex: 0 0 40%;
  color: var(--text-color);
  padding: 8% !important;
  padding-right: 1% !important;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative; 
  z-index: 2; 
}

.reservation-label {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 2px;
  color: var(--text-color);
  position: relative;
  padding-left: 40px;
  margin-bottom: 20px;
  text-transform: uppercase;
}

.reservation-label::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  width: 30px;
  height: 1px;
  background-color: var(--text-color);
}

.reservation-title {
  font-family: var(--font-heading);
  font-size: 68px;
  font-weight: 700;
  color: var(--text-color);
  line-height: 1.2;
  margin-top: 15px;
  margin-bottom: 40px;
}

.reservation-button {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--text-color);
  background-color: transparent;
  border: 1px solid var(--text-color);
  padding: 12px 24px;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 2px;
  transition: all var(--transition-medium);
  position: relative;
  overflow: hidden;
  z-index: 1;
  align-self: flex-start;
}

.reservation-button::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 0%;
  height: 100%;
  background-color: var(--text-color);
  transition: width var(--transition-medium);
  z-index: -1;
}

.reservation-button:hover {
  color: var(--primary-dark);
}

.reservation-button:hover::before {
  width: 100%;
}

.reservation-right {
  flex: 0 0 50%;
  position: relative;
  background-image: url('../img/infoo.png');
  background-size: cover;
  background-position: center;
}

.reservation-box {
  position: absolute;
  top: 20%;
  left: 0;
  background-color: #fff;
  padding: 70px 80px;
  width: 500px; 
  max-width: 500px;
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.1);
  transform: translateX(-50px);
  z-index: 1;
}

.reservation-contact {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.reservation-phone {
  font-family: var(--font-heading);
  font-size: 34px;
  color: var(--primary-dark);
  margin-bottom: 10px;
}

.reservation-hours {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.reservation-hours-label {
  font-family: var(--font-body);
  font-size: 18px;
  color: var(--primary-dark);
  font-weight: 600;
}

.reservation-hours-time {
  font-family: var(--font-body);
  font-size: 16px;
  color: #666;
}

.reservation-left, .reservation-box {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

.reservation-left.animate {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 0.2s;
}

.reservation-box.animate {
  opacity: 1;
  transform: translateX(-50px) translateY(0);
  transition-delay: 0.4s;
}

@media (max-width: 1200px) {
  .reservation-title {
    font-size: 56px;
  }
  
  .reservation-box {
    padding: 40px 60px;
    width: 450px;
    max-width: 450px;
  }
}

@media (max-width: 1024px) {
  .reservation-title {
    font-size: 42px;
  }
  
  .reservation-left {
    padding: 80px 40px 80px 20px !important;
  }
  
  .reservation-box {
    padding: 30px 40px;
    width: 380px;
    max-width: 380px;
  }
  
  .reservation-phone {
    font-size: 28px;
  }
}

@media (max-width: 900px) {
  .reservation-left {
    flex: 0 0 45%;
  }
  
  .reservation-right {
    flex: 0 0 55%;
  }
  
  .reservation-box {
    width: 340px;
    max-width: 340px;
    padding: 25px 30px;
  }
}

@media (max-width: 768px) {
  .reservation-section {
    width: 90%; 
    overflow: visible; 
    margin-bottom: 60px; 
  }
  
  .reservation-container {
    flex-direction: column;
  }
  
  .reservation-left {
    flex: 0 0 100%;
    padding: 60px 20px !important;
    margin-bottom: 20px; 
  }
  
  .reservation-right {
    flex: 0 0 100%;
    min-height: 300px; 
    position: relative;
  }
  
  .reservation-title {
    font-size: 36px;
  }
  
  .reservation-box {
    position: relative; 
    top: -50px; 
    left: 0;
    transform: translateX(0);
    margin: 0 auto; 
    width: 85%;
    max-width: 450px;
  }
  
  .reservation-box.animate {
    transform: translateY(0); 
  }
}

@media (max-width: 480px) {
  .reservation-section {
    width: 95%; 
  }
  
  .reservation-left {
    padding: 50px 20px !important;
  }
  
  .reservation-right {
    min-height: 200px; 
  }
  
  .reservation-label {
    padding-left: 30px;
  }
  
  .reservation-label::before {
    width: 20px;
  }
  
  .reservation-title {
    font-size: 32px;
    margin-bottom: 25px;
  }
  
  .reservation-box {
    padding: 20px;
    width: 90%;
    top: -40px;
  }
  
  .reservation-phone {
    font-size: 24px;
  }
  
  .reservation-hours-label {
    font-size: 16px;
  }
  
  .reservation-hours-time {
    font-size: 14px;
  }
}