/* Responsive layout para pages/tour.php */

.wrapper-title-details-itinerary-tour {
  width: min(1200px, calc(100% - 32px));
}

.tour-description-flex {
  display: flex;
  gap: 40px;
  align-items: flex-start;
  margin-bottom: 40px;
}

.tour-description-left {
  flex: 2;
}

.tour-description-right {
  flex: 1;
}

.tour-info-card {
  background: #E9E9E9;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
  overflow: hidden;
}

.tour-info-card__title {
  margin: 0;
  padding: 14px 18px;
  font-size: 1rem;
  font-weight: 700;
  color: #2a4a47;
  border-bottom: 1px solid #dddddd;
  background: #ececec;
}

.tour-info-card__list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  list-style: none;
  margin: 0;
  padding: 14px 12px;
  gap: 10px 12px;
}

.tour-info-card__list li {
  display: flex;
  gap: 8px;
  align-items: flex-start;
}

.tour-info-card__list li i {
  color: #d19831;
  font-size: 0.5rem;
  margin-top: 7px;
}

.tour-info-card__list li strong {
  display: block;
  color: #2a4a47;
  font-size: 1rem;
  line-height: 1.2;
}

.tour-info-card__list li span {
  display: block;
  color: #5c5c5c;
  font-size: 1rem;
  line-height: 1.2;
}

.tour-info-card__form {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin: 0;
}

.tour-info-card__form input,
.tour-info-card__form textarea {
  width: 100%;
  border: none;
  border-bottom: 1px solid #dddddd;
  background: #f3f3f3;
  padding: 12px 14px;
  font-size: 0.88rem;
  color: #383838;
  outline: none;
}

.tour-info-card__form input::placeholder,
.tour-info-card__form textarea::placeholder {
  color: #7a7a7a;
}

.tour-info-card__form textarea {
  min-height: 110px;
  resize: vertical;
}

.tour-info-card__form button {
  width: fit-content;
  min-width: 96px;
  margin: 14px auto 12px;
  border: none;
  background: #d19831;
  color: #fff;
  font-weight: 700;
  font-size: 1.05rem;
  padding: 8px 16px;
  cursor: pointer;
  transition: background 0.2s;
}

.tour-info-card__form button:hover {
  background: #b9852a;
}

.tour-info-card__note {
  margin: 0;
  text-align: center;
  color: #4d4d4d;
  font-size: 0.82rem;
  line-height: 1.35;
  padding: 6px 14px 14px;
}

.tour-info-card__map {
  padding: 10px;
  border-top: 1px solid #dddddd;
  background: #f3f3f3;
}

.tour-info-card__map img {
  width: 100%;
  height: auto;
  display: block;
  border: 1px solid #d9d9d9;
  border-radius: 6px;
}

.tour-info-card__map-placeholder {
  width: 100%;
  min-height: 210px;
  border: 2px dashed #cfcfcf;
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: #7a7a7a;
  background: #fafafa;
}

.tour-info-card__map-placeholder i {
  font-size: 1.5rem;
  color: #b1b1b1;
}

/* Ajustes generales para tablet */
@media (max-width: 1100px) {
  .tour-description-flex {
    flex-direction: column !important;
    gap: 24px !important;
  }

  .tour-description-left,
  .tour-description-right {
    width: 100%;
    flex: 1 1 100% !important;
  }

  .wrapper-main-itinerary-tour {
    flex-direction: column;
    gap: 20px;
  }

  .wrapper-text-itinerary-tour,
  .wrapper-aditionals-itinerary-tour {
    width: 100%;
    padding-left: 0;
    padding-right: 0;
  }

  #wrapper-nav-titles-tour-page {
    justify-content: flex-start !important;
    overflow-x: auto;
    white-space: nowrap;
    padding: 0 10px;
    gap: 8px !important;
    scrollbar-width: thin;
  }

  #wrapper-nav-titles-tour-page .tour-tab-button {
    flex: 0 0 auto !important;
    min-width: 165px;
    padding: 12px 14px;
  }
}

/* Mobile */
@media (max-width: 900px) {
  section.wrapper-banner-itinerary-tour {
    margin-top: 0;
  }

  img.banner-img-tour-page {
    min-height: 320px;
    object-fit: cover;
  }

  .wrapper-title-details-itinerary-tour {
    bottom: 40%;
    transform: translate(-50%, 50%);
    width: calc(100% - 24px);
  }

  .wrapper-title-details-itinerary-tour h1 {
    font-size: 1.7rem;
    margin-bottom: 8px;
  }

  .wrapper-title-details-itinerary-tour span {
    font-size: 1rem;
  }

  .wrapper-title-details-itinerary-tour span i {
    font-size: 1.2rem;
  }

  .tour-summary-bar {
    position: static;
    transform: none;
    width: 100%;
    margin-top: 0;
  }

  .tour-summary-bar__item,
  .tour-summary-bar__item--video {
    min-height: 64px;
  }

  .tour-description-section {
    margin-top: 16px;
  }

  .wrapper-article-itinerary-page {
    padding: 14px;
    border-radius: 12px;
  }

  .tour-description-right {
    padding: 16px !important;
    border-radius: 10px !important;
  }

  .tour-info-card__list {
    grid-template-columns: 1fr;
  }

  .tour-description-right form {
    gap: 8px !important;
  }

  .tour-description-right input,
  .tour-description-right textarea,
  .tour-description-right button {
    font-size: 0.95rem;
  }

  #wrapper-nav-titles-tour-page {
    min-height: 50px !important;
    justify-content: flex-start !important;
  }

  #wrapper-nav-titles-tour-page .tour-tab-button {
    min-width: 150px;
    font-size: 0.88rem;
    gap: 3px;
  }

  #wrapper-nav-titles-tour-page .tour-tab-button i {
    font-size: 0.95rem;
    margin-bottom: 2px;
  }

  .tour-passengers-pricing__row {
    font-size: 0.9rem;
  }

  .tour-passengers-cta {
    border-radius: 10px;
    padding: 12px 16px;
  }

  .wrapper-comments-clients-home .wrapper1200 {
    padding-left: 14px;
    padding-right: 14px;
  }

  .comments-tripadvisor-header {
    padding: 16px 14px !important;
  }

  .comments-tripadvisor-header .text-5xl {
    font-size: 2rem;
  }

  .tour-similar-section {
    margin-top: 1.2rem;
  }
}

@media (max-width: 600px) {
  .wrapper-title-details-itinerary-tour h1 {
    font-size: 1.35rem;
    line-height: 1.15;
  }

  .wrapper-title-details-itinerary-tour span {
    font-size: 0.92rem;
    margin-bottom: 0;
  }

  .wrapper-title-details-itinerary-tour span i {
    font-size: 1rem;
  }

  .tour-description-left h2 {
    font-size: 1.2rem;
  }

  .tour-description-right h3,
  .tour-description-map h3 {
    font-size: 1rem;
  }

  #wrapper-nav-titles-tour-page .tour-tab-button {
    min-width: 132px;
    padding: 10px 8px;
  }

  .tour-availability-calendar,
  .tour-passengers-selector {
    border-radius: 12px;
  }

  .tour-passengers-counter {
    gap: 8px;
    padding: 8px 10px;
  }

  .tour-passengers-counter__input {
    width: 44px;
  }
}
