/**

 * Dates and Prices Block - Booking Interface Styles

 *

 * Complete redesign with year/month navigation and booking cards

 *

 * @package Travel\Blocks

 * @since 2.0.0

 */



/* ===== MAIN CONTAINER ===== */



.booking {

    /* ===== CSS VARIABLES ===== */



    /* Base colors */

    --booking-bg: #FFFFFF;

    --booking-border: #E5E7EB;        /* gray-300 */

    --booking-text: #1F2937;

    --booking-muted: #6B7280;

    --gray-100: #F5F6F7;

    --gray-300: #E5E7EB;



    /* NEW: Exact palette from spec */

    --rose: var(--wp--preset--color--secondary);  /* Mapped to theme.json secondary color */

    --green-strong: #A8F04C;           /* acentos, barras o iconos de deal */

    --green-soft: #EBFED3;             /* fondo de tarjetas deal / chip deal */

    --green-dark: #0A797E;             /* textos de precio / acentos de deal */



    /* CTA colors (using rose) */

    --booking-cta: var(--wp--preset--color--secondary);  /* Mapped to theme.json secondary color */

    --booking-cta-text: #FFFFFF;

    --booking-cta-hover: #D97C76;      /* rose darker */



    /* Deal colors (using green palette) */

    --booking-deal-bg: #EBFED3;        /* green-soft */

    --booking-deal-border: #D6F6B0;    /* green-soft darker */

    --booking-deal-badge: #0A797E;     /* green-dark */

    --booking-deal-badge-bg: #DFF4C6;  /* green-soft lighter */

    --booking-deal-price: #0A797E;     /* green-dark for price */



    /* Sold out colors */

    --booking-soldout-bg: #F3F4F6;

    --booking-soldout-text: #9CA3AF;



    /* Alert colors (orange) */

    --booking-alert-bg: #FFF5ED;       /* orange light */

    --booking-alert-border: #FFD9BF;   /* orange border */

    --booking-alert-accent: #FF7A1A;   /* orange emphasis */



    /* Chips colors */

    --booking-chip-soldout: #F1F2F4;

    --booking-chip-available: #F8FAFF;

    --booking-chip-deal: #EBFED3;      /* green-soft */

    --booking-chip-deal-text: #0A797E; /* green-dark */



    /* Layout */

    position: relative;

    background: var(--booking-bg);

    border: 2px solid var(--booking-border);

    border-radius: 16px;

    padding: 24px 20px 56px;

    max-width: 880px;

    margin: 24px auto;

    font-family: 'Satoshi', sans-serif;

}



/* Screen reader only */

.sr-only {

    position: absolute;

    width: 1px;

    height: 1px;

    padding: 0;

    margin: -1px;

    overflow: hidden;

    clip: rect(0, 0, 0, 0);

    white-space: nowrap;

    border-width: 0;

}



/* ===== YEAR TABS (floating on top border) ===== */



.year-tabs {

    position: absolute;

    top: 0;

    left: 50%;

    transform: translate(-50%, -50%);

    display: flex;

    gap: 8px;

    z-index: 10;

}



.year-tab {

    height: 36px;

    padding: 0 14px;

    border-radius: 9999px;

    border: 1px solid var(--booking-border);

    background: #fff;

    font-weight: 600;

    font-size: 14px;

    color: var(--booking-text);

    cursor: pointer;

    transition: all 0.2s ease;

}



.year-tab:hover {

    background: #F9FAFB;

    border-color: #D1D5DB;

}



.year-tab.is-active {

    background: #F9FAFB;

    color: var(--booking-text);

    border-color: var(--booking-border);

}



.year-tab:focus-visible {

    outline: 2px solid #6AA9FF;

    outline-offset: 2px;

}



/* ===== MONTH NAVIGATION ===== */



.month-nav {

    display: flex;

    align-items: center;

    justify-content: center;

    gap: 10px;

    padding-top: 8px;

    padding-bottom: 12px;

    margin-bottom: 16px;

    position: relative;

}



/* Wrapper for prev + label + next with rounded border */

.month-nav__group {

    display: flex;

    align-items: center;

    gap: 0;

    border: 1px solid var(--gray-300);

    border-radius: 50px;

    padding: 4px;

    background: #fff;

}



.icon-btn {

    width: 36px;

    height: 36px;

    border: 1px solid var(--gray-300);

    border-radius: 50%;

    background: #fff;

    display: flex;

    align-items: center;

    justify-content: center;

    cursor: pointer;

    transition: all 0.2s ease;

    color: var(--booking-text);

    font-size: 18px;

}



/* Remove border from prev/next buttons inside group */

.month-nav__group .icon-btn {

    border: none;

}



/* Select button with rose background */

.icon-btn--select {

    background: var(--rose);

    border-color: var(--rose);

    color: #fff;

}



.icon-btn--select:hover {

    background: var(--booking-cta-hover);

    border-color: var(--booking-cta-hover);

}



.icon-btn:hover {

    background: #F9FAFB;

}



.icon-btn:disabled {

    opacity: 0.4;

    cursor: not-allowed;

}



.icon-btn:focus-visible {

    outline: 2px solid #6AA9FF;

    outline-offset: 2px;

}



.month-label {

    text-align: center;

    display: flex;

    justify-content: center;

    align-items: center;

    padding: 0 16px;

}



.month-label__text {

    font-weight: 600;

    font-size: 16px;

    color: var(--green-dark);

    white-space: nowrap;

}



/* Month select popover */

.month-popover {

    position: absolute;

    top: 100%;

    left: 50%;

    transform: translateX(-50%);

    margin-top: 8px;

    background: #fff;

    border: 1px solid var(--gray-300);

    border-radius: 12px;

    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);

    max-height: 320px;

    overflow-y: auto;

    z-index: 9999;

    list-style: none;

    padding: 8px;

    min-width: 220px;

}



.month-popover[hidden] {

    display: none;

}



.month-popover__item {

    padding: 10px 14px;

    cursor: pointer;

    border-radius: 8px;

    transition: background 0.15s ease;

    font-size: 14px;

    color: var(--booking-text);

}



.month-popover__item:hover {

    background: #F9FAFB;

}



.month-popover__item.is-active {

    background: var(--green-soft);

    color: var(--green-dark);

    font-weight: 600;

}



.month-popover__item[aria-disabled="true"] {

    opacity: 0.4;

    cursor: not-allowed;

    pointer-events: none;

}



/* ===== TRIP LIST (scrollable) ===== */



.trip-list {

    display: flex;

    flex-direction: column;

    gap: 12px;

    max-height: 480px;

    overflow-y: auto;

    padding-right: 6px;

    list-style: none;

    margin: 0;

}



/* Custom scrollbar */

.trip-list::-webkit-scrollbar {

    width: 6px;

}



.trip-list::-webkit-scrollbar-track {

    background: #F3F4F6;

    border-radius: 3px;

}



.trip-list::-webkit-scrollbar-thumb {

    background: #D1D5DB;

    border-radius: 3px;

}



.trip-list::-webkit-scrollbar-thumb:hover {

    background: #9CA3AF;

}



/* ===== TRIP CARD ===== */



.trip-card {

    display: grid;

    grid-template-columns: 1fr auto auto auto; /* dates, price, deal, CTA */

    gap: 16px;

    align-items: center;

    border: 1px solid var(--booking-border);

    border-radius: 12px;

    padding: 16px;

    background: #fff;

    transition: all 0.2s ease;

}



.trip-card[data-month]:not([data-month=""]) {

    display: none; /* Hidden by default, shown by JS */

}



.trip-card[data-month].trip-card--visible {

    display: grid !important; /* Override hidden state - must have higher specificity */

}



.trip-card:hover:not(.trip-card--soldout) {

    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);

}



/* Deal variant */

.trip-card--deal {

    background: var(--booking-deal-bg);

    border-color: var(--booking-deal-border);

}



/* Sold out variant */

.trip-card--soldout {

    background: var(--booking-soldout-bg);

    color: var(--booking-soldout-text);

}



/* ===== DATES COLUMN ===== */



.trip-dates {

    display: flex;

    gap: 12px;

    align-items: center;

    flex-wrap: wrap;

}



.trip-dates__item {

    display: flex;

    flex-direction: column;

    gap: 4px;

}



.trip-dates__line {

    display: flex;

    gap: 6px;

    align-items: baseline;

}



.trip-dates__label {

    color: var(--booking-text);

    font-size: 12px;

    letter-spacing: 0.02em;

    text-transform: capitalize;

    font-weight: 700;

}



.trip-dates__day {

    font-size: 12px;

    color: var(--booking-text);

    font-weight: 400;

}



.trip-dates__date {

    font-size: 13px;

    font-weight: 400;

    color: var(--booking-text);

}



.trip-dates__arrow {

    flex-shrink: 0;

    opacity: 0.6;

}



.trip-card--soldout .trip-dates__date,

.trip-card--soldout .trip-dates__day,

.trip-card--soldout .trip-dates__label {

    color: var(--booking-soldout-text);

}



/* ===== PRICE COLUMN ===== */



.trip-price {

    display: flex;

    flex-direction: column;

    align-items: flex-end;

    gap: 4px;

}



.trip-price__amount {

    display: flex;

    align-items: baseline;

    gap: 4px;

    flex-wrap: wrap;

}



.trip-price__currency {

    font-size: 14px;

    color: var(--booking-muted);

}



.trip-price__value {

    font-size: 18px;

    font-weight: 700;

    color: var(--green-dark);

}



.trip-price__meta {

    font-size: 12px;

    color: var(--booking-muted);

    margin-top: 4px;

}



/* ===== DEAL COLUMN (always present, empty if no deal) ===== */



.trip-deal {

    display: flex;

    flex-direction: column;

    gap: 4px;

    align-items: center;

    min-width: 60px;

}



.trip-deal__old-price {

    font-size: 12px;

    color: var(--booking-muted);

    text-decoration: line-through;

}



/* Deal badge - 2 lines: "40%" + "Off" */

.badge--deal {

    display: flex;

    flex-direction: column;

    align-items: center;

    justify-content: center;

    padding: 4px 8px;

    background: var(--green-strong);

    color: var(--booking-deal-badge);

    border-radius: 6px;

    min-width: 50px;

    margin-top: 4px;

    line-height: 1;

}



.badge__percentage {

    font-size: 16px;

    font-weight: 700;

}



.badge__text {

    font-size: 11px;

    font-weight: 700;

    text-transform: capitalize;

    margin-top: 2px;

}



/* ===== STATUS (for sold out) ===== */



.trip-status {

    text-align: center;

    font-size: 14px;

    font-weight: 700;

    color: var(--booking-soldout-text);

    text-transform: capitalize;

    padding: 8px;

    min-width: 124px; /* Minimum width for sold out status */

}



/* ===== CTA COLUMN ===== */



.trip-cta {

    display: flex;

}



.btn {

    font-family: 'Satoshi', sans-serif;

    cursor: pointer;

    transition: all 0.2s ease;

    border: none;

}



.btn-primary {

    background: var(--booking-cta);

    color: var(--booking-cta-text);

    height: 40px;

    border-radius: 9999px;

    padding: 0 20px;

    font-weight: 600;

    font-size: 14px;

    white-space: nowrap;

}



.btn-primary:hover:not(:disabled) {

    background: var(--booking-cta-hover);

    box-shadow: 0 2px 6px rgba(240, 138, 123, 0.3);

}



.btn-primary:disabled {

    opacity: 0.5;

    cursor: not-allowed;

}



.btn-primary:focus-visible {

    outline: 2px solid #6AA9FF;

    outline-offset: 2px;

}



/* ===== LEGEND CHIPS (floating on bottom border) ===== */



.legend-chips {

    position: absolute;

    left: 50%;

    bottom: 0;

    transform: translate(-50%, 50%);

    display: flex;

    gap: 8px;

    z-index: 10;

}



.chip {

    padding: 6px 10px;

    border-radius: 0px;

    font-size: 12px;

    border: 1px solid var(--booking-border);

    background: #fff;

    font-weight: 500;

}



.chip--soldout {

    background: var(--booking-chip-soldout);

}



.chip--available {

    background: var(--booking-chip-available);

}



.chip--deal {

    background: var(--green-strong);

    color: #212529;

}



/* ===== BOOKING ALERT (outside container) ===== */



.booking-alert {

    display: flex;

    gap: 8px;

    align-items: flex-start;

    background: var(--booking-alert-bg);

    border: 1px solid var(--booking-alert-border);

    border-radius: 12px;

    padding: 12px;

    margin: 24px auto 0;

    max-width: 880px;

    font-size: 14px;

    line-height: 1.5;

}



.icon-bell {

    flex-shrink: 0;

    color: var(--booking-alert-accent);

}



.booking-alert strong {

    color: var(--booking-alert-accent);

    font-weight: 600;

}



/* ===== EMPTY STATE ===== */



.booking-empty {

    padding: 4rem 2rem;

    text-align: center;

    background: #F9FAFB;

    border-radius: 12px;

    max-width: 600px;

    margin: 0 auto;

}



.booking-empty__icon {

    color: var(--booking-muted);

    opacity: 0.5;

    margin-bottom: 1.5rem;

}



.booking-empty__title {

    font-size: 1.5rem;

    font-weight: 600;

    color: var(--booking-text);

    margin: 0 0 1rem 0;

}



.booking-empty__message {

    font-size: 1rem;

    line-height: 1.6;

    color: var(--booking-muted);

    margin: 0 0 1.5rem 0;

}



.booking-empty__hint {

    padding: 1rem;

    background: #FFF3CD;

    border: 1px solid #FFE69C;

    border-radius: 8px;

    font-size: 0.875rem;

    color: #856404;

    text-align: left;

}



.booking-empty__hint strong {

    display: block;

    margin-bottom: 0.5rem;

}



/* Hide empty state hint on frontend */

.booking--empty:not(.is-editor) .booking-empty__hint {

    display: none;

}



/* ===== RESPONSIVE ===== */



@media (max-width: 420px) {

    .booking {

        padding: 20px 16px 52px;

        margin: 16px;

    }



    .booking-empty {

        padding: 3rem 1.5rem;

    }



    .booking-empty__icon {

        width: 48px;

        height: 48px;

    }



    .booking-empty__title {

        font-size: 1.25rem;

    }



    .booking-empty__message {

        font-size: 0.9375rem;

    }



    .year-tabs {

        gap: 6px;

        flex-wrap: wrap;

        justify-content: center;

    }



    .year-tab {

        height: 32px;

        padding: 0 12px;

        font-size: 13px;

    }



    .month-nav {

        padding-bottom: 10px;

        margin-bottom: 12px;

    }



    .month-label__text {

        font-size: 15px;

    }



    .trip-list {

        max-height: 400px;

    }



    /* Two rows: (dates | price | deal) + (CTA full-width) */

    .trip-card {

        grid-template-columns: 1fr auto auto; /* dates, price, deal */

        grid-auto-rows: auto;

        gap: 12px;

        padding: 14px;

    }



    .trip-dates {

        gap: 12px;

        grid-column: 1 / -1; /* Full width on mobile */

    }



    .trip-price {

        align-items: flex-start;

    }



    .trip-deal {

        align-items: flex-start;

    }



    .trip-cta {

        grid-column: 1 / -1;

        justify-self: stretch;

    }



    .btn-primary {

        width: 100%;

    }



    .legend-chips {

        gap: 6px;

        flex-wrap: wrap;

        justify-content: center;

    }



    .chip {

        font-size: 11px;

        padding: 5px 8px;

    }



    .booking-alert {

        font-size: 13px;

        padding: 10px;

        margin: 16px;

    }

}



@media (max-width: 480px) {

    .year-tabs {

        flex-wrap: wrap;

        justify-content: center;

    }

}



/* ===== PRINT STYLES ===== */



@media print {

    .year-tabs,

    .month-nav,

    .trip-cta,

    .legend-chips {

        display: none;

    }



    .booking-alert {

        display: none;

    }



    .booking {

        box-shadow: none;

        border: 1px solid #E5E7EB;

    }



    .trip-card {

        box-shadow: none;

        page-break-inside: avoid;

    }

}



/* ===== API INTEGRATION: PROMO BACKGROUND COLORS ===== */



/* Fixed week promo background (green-lime) */

.trip-card.booking-row--promo-fixed-week {

    background-color: #EBFED3 !important;

}



/* Fixed dates promo background (green-yellow) */

.trip-card.booking-row--promo-fixed-dates {

    background-color: #F7FED3 !important;

}



/* SOLD OUT: Override promo backgrounds - sold out always uses default background */

.trip-card.trip-card--soldout.booking-row--promo-fixed-week,

.trip-card.trip-card--soldout.booking-row--promo-fixed-dates,

.trip-card.trip-card--soldout {

    background-color: var(--booking-card-bg) !important;

}



/* ========================================================================

   CALENDAR GRID VIEW - NEW DESIGN

   ======================================================================== */



/* Hide old trip list (deprecated) */

.trip-list--deprecated {

  display: none !important;

}



/* ===== TOUR SELECTOR ===== */

.trail-selector-wrapper {

  max-width: 880px;

  margin: 0 auto 16px auto;

  padding: 0 20px;

}



.trail-selector-title {

  font-size: 12px;

  margin-bottom: 8px;

  color: #444;

  font-weight: 600;

}



.trail-selector {

  border: 1px solid #e2e2e2;

  border-radius: 8px;

  padding: 10px 14px;

  font-size: 13px;

  background: #fcfcfc;

}



.trail-option {

  display: flex;

  align-items: center;

  gap: 6px;

  margin-bottom: 4px;

}



.trail-option:last-child {

  margin-bottom: 0;

}



.trail-option label {

  cursor: pointer;

  user-select: none;

}



/* Calendar Month Container */

.calendar-month {

  display: none;

  margin-top: 18px;

}



.calendar-month--visible {

  display: block;

}



/* Calendar Container */

.calendar {

  overflow: hidden;

}



/* Calendar Grid - 7 columns */

.calendar-grid {

  display: grid;

  grid-template-columns: repeat(7, 1fr);

  gap: 4px;

  font-size: 11px;

}



/* Weekday Headers */

.weekday {

  font-weight: 600;

  font-style: normal;

  font-size: 16px;

  line-height: 100%;

  letter-spacing: 0;

  text-align: center;

  vertical-align: middle;

  text-transform: capitalize;

  color: #666666;

  padding: 4px 0 8px;

}



/* Day Cell */

.day {

  min-height: 60px;

  border-radius: 4px;

  border: 1px solid var(--wp--preset--color--gray-light, #B0B0B0);

  text-align: center;

  padding: 0;

  position: relative;

  background: var(--wp--preset--color--base, #FFFFFF);

  display: flex;

  flex-direction: column;

  align-items: stretch;

  justify-content: flex-start;

}



.day.empty {

  background: #fafafa;

  border-color: #f0f0f0;

  opacity: 0.5;

}



/* Day Number */

.day-number {

  font-weight: 400;

  font-style: normal;

  font-size: 20px;

  line-height: 100%;

  letter-spacing: 0;

  text-align: center;

  vertical-align: middle;

  padding: 8px 3px;

  color: #454545;

  flex-shrink: 0;

}



/* Status Badge */

.status {

  font-weight: 600;

  font-style: normal;

  font-size: 14px;

  line-height: 100%;

  letter-spacing: 0;

  text-align: center;

  vertical-align: middle;

  text-transform: capitalize;

  display: flex;

  align-items: center;

  justify-content: center;

  width: 100%;

  flex-grow: 1;

  padding: 8px 3px;

  margin: 0;

  border-radius: 0 0 3px 3px;

}



.status--closed {

  color: var(--wp--preset--color--gray-light, #B0B0B0);

  background: transparent;

}



.status--book {

  background: var(--wp--preset--color--base, #FFFFFF);

  color: var(--wp--preset--color--success-green, #00AA6C);

  transition: background-color 0.2s ease, color 0.2s ease;

}



.status--book:hover,

.day:hover .status--book {

  background: var(--wp--preset--color--success-green, #00AA6C);

  color: var(--wp--preset--color--base, #FFFFFF);

  cursor: pointer;

}



.status--deal {

  background: #b4ea73;

  color: var(--wp--preset--color--dark-text, #212529);

}



.status--callus {

  background: var(--wp--preset--color--base, #FFFFFF);

  color: var(--wp--preset--color--cyan-link, #14B7F3BF);

  transition: background-color 0.2s ease, color 0.2s ease;

}



.status--callus:hover,

.day:hover .status--callus {

  background: var(--wp--preset--color--cyan-link, #14B7F3BF);

  color: var(--wp--preset--color--base, #FFFFFF);

  cursor: pointer;

}



/* Tooltip */

.tooltip {

  position: absolute;

  top: -50px;

  left: 50%;

  transform: translateX(-50%);

  background: var(--wp--preset--color--tertiary, #202C2E);

  color: var(--wp--preset--color--base, #FFFFFF);

  padding: 6px 10px;

  border-radius: 4px;

  white-space: nowrap;

  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.25);

  opacity: 0;

  visibility: hidden;

  transition: opacity 0.2s ease, visibility 0.2s ease;

  pointer-events: none;

  z-index: 10;

  display: flex;

  flex-direction: column;

  gap: 2px;

  align-items: center;

}



.tooltip__label {

  font-weight: 600;

  font-style: normal;

  font-size: 14px;

  line-height: 100%;

  letter-spacing: 0;

  text-align: center;

}



.tooltip__label--deal {

  font-size: 12px;

  color: #A8F04C;

}



.tooltip__price {

  font-weight: 400;

  font-style: normal;

  font-size: 16px;

  line-height: 100%;

  letter-spacing: -0.05em;

  text-align: center;

  vertical-align: middle;

}



.tooltip__price--deal {

  color: #A8F04C;

}



.tooltip::after {

  content: "";

  position: absolute;

  bottom: -6px;

  left: 50%;

  transform: translateX(-50%);

  border-width: 6px 6px 0 6px;

  border-style: solid;

  border-color: var(--wp--preset--color--tertiary, #202C2E) transparent transparent transparent;

}



/* Hover States */

.day:hover {

  border-color: var(--wp--preset--color--primary, #17565C);

  cursor: pointer;

}



.day:hover .tooltip {

  opacity: 1;

  visibility: visible;

}



.day.empty:hover {

  border-color: #f0f0f0;

  cursor: default;

}



.day.empty:hover .tooltip {

  opacity: 0;

  visibility: hidden;

}



/* Ensure hover works on day number (let events bubble to .day) */

.day-number {

  pointer-events: none;

}

