/* ============================================================================
   DEPARTURES CALENDAR — Sitio inglés/cliente (choquequiraotrek.pe)
   ✓ Tamaños grandes (números 24px, etiquetas 14px)
   ✓ Alto contraste WCAG AAA
   ✓ Color + ícono + texto (nunca solo color)
   ✓ Touch targets de 44px+
   ============================================================================ */

.cqt-cal {
    --cqt-cal-navy: #0e2547;
    --cqt-cal-orange: #ff7a1a;
    --cqt-cal-orange-dark: #d65f00;
    --cqt-cal-cream: #f5f3ee;
    --cqt-cal-cream-dark: #e8e3d6;
    --cqt-cal-text: #1d2433;
    --cqt-cal-muted: #4a5568;       /* AAA contrast en fondos claros */
    --cqt-cal-border: #d1d5db;
    --cqt-cal-border-strong: #9ca3af;
    --cqt-cal-wa: #25d366;
    --cqt-cal-wa-dark: #128c7e;
    --cqt-cal-green: #1e7e34;       /* darker, mejor contraste */
    --cqt-cal-orange-status: #c2410c;
    --cqt-cal-gray: #6b7280;
    --cqt-cal-red: #991b1b;
    --cqt-cal-color: var(--cqt-cal-navy);

    font-family: inherit;
    color: var(--cqt-cal-text);
    line-height: 1.5;
    margin: 32px 0;
}

.cqt-cal *, .cqt-cal *::before, .cqt-cal *::after { box-sizing: border-box; }

/* =========================================================================== */
/* HEADER CON LANGUAGE TOGGLE                                                  */
/* =========================================================================== */
.cqt-cal-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 24px;
    flex-wrap: wrap;
    gap: 14px;
}
.cqt-cal-title {
    font-size: 24px;
    font-weight: 700;
    color: var(--cqt-cal-navy);
    margin: 0;
}
.cqt-cal-subtitle {
    font-size: 15px;
    color: var(--cqt-cal-muted);
    margin: 6px 0 0 0;
}
.cqt-cal-lang {
    display: inline-flex;
    background: var(--cqt-cal-cream);
    border-radius: 10px;
    padding: 5px;
    gap: 3px;
}
.cqt-cal-lang-btn {
    background: transparent;
    border: 0;
    padding: 8px 16px;
    border-radius: 7px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    color: var(--cqt-cal-muted);
    font-family: inherit;
    min-height: 44px;
    min-width: 44px;
}
.cqt-cal-lang-btn.is-active {
    background: var(--cqt-cal-navy);
    color: white;
}

/* =========================================================================== */
/* TABS POR TREK                                                               */
/* =========================================================================== */
.cqt-cal-tabs {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 12px;
    margin-bottom: 24px;
}
.cqt-cal-tab {
    background: white;
    border: 2px solid var(--cqt-cal-border);
    border-radius: 12px;
    padding: 16px 18px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 14px;
    text-align: left;
    transition: all 0.15s;
    color: var(--cqt-cal-text);
    font-family: inherit;
    width: 100%;
    min-height: 72px;
}
.cqt-cal-tab:hover {
    border-color: var(--cqt-cal-color);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}
.cqt-cal-tab.is-active {
    background: var(--cqt-cal-color);
    border-color: var(--cqt-cal-color);
    color: white;
}
.cqt-cal-tab-num {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(0,0,0,0.06);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-weight: 800;
    flex-shrink: 0;
}
.cqt-cal-tab.is-active .cqt-cal-tab-num {
    background: rgba(255,255,255,0.25);
}
.cqt-cal-tab-title { font-weight: 700; font-size: 16px; display: block; }
.cqt-cal-tab-sub { font-size: 13px; opacity: 0.9; margin-top: 3px; display: block; }

/* =========================================================================== */
/* AVISO DE MODALIDAD                                                          */
/* =========================================================================== */
.cqt-cal-notice {
    background: #fff8e1;
    border-left: 5px solid #f59e0b;
    color: #5a3a06;
    padding: 14px 18px;
    border-radius: 0 8px 8px 0;
    font-size: 15px;
    margin-bottom: 20px;
    line-height: 1.5;
}
.cqt-cal-notice strong { color: #3d2604; }

/* =========================================================================== */
/* NAV DEL MES                                                                 */
/* =========================================================================== */
.cqt-cal-monthbar {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 18px;
    flex-wrap: wrap;
}
.cqt-cal-monthnav {
    background: white;
    border: 2px solid var(--cqt-cal-border-strong);
    border-radius: 10px;
    padding: 0;
    width: 48px;
    height: 48px;
    cursor: pointer;
    font-size: 18px;
    color: var(--cqt-cal-text);
    transition: all 0.15s;
    font-weight: 700;
}
.cqt-cal-monthnav:hover {
    background: var(--cqt-cal-cream);
    border-color: var(--cqt-cal-color);
    color: var(--cqt-cal-color);
}
.cqt-cal-monthtitle {
    font-size: 26px;
    font-weight: 700;
    color: var(--cqt-cal-navy);
    margin: 0;
    flex: 1;
    min-width: 220px;
}
.cqt-cal-today-btn {
    background: var(--cqt-cal-orange);
    color: white;
    border: 0;
    padding: 10px 22px;
    border-radius: 10px;
    font-weight: 700;
    cursor: pointer;
    font-size: 15px;
    height: 48px;
    min-width: 80px;
}
.cqt-cal-today-btn:hover {
    background: var(--cqt-cal-orange-dark);
    transform: translateY(-1px);
}

/* =========================================================================== */
/* GRID                                                                        */
/* =========================================================================== */
.cqt-cal-grid-wrap {
    background: white;
    border: 1px solid var(--cqt-cal-border);
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.04);
}
.cqt-cal-weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 6px;
    margin-bottom: 8px;
}
.cqt-cal-weekdays div {
    text-align: center;
    padding: 10px 0;
    font-size: 13px;
    font-weight: 700;
    color: var(--cqt-cal-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
}
.cqt-cal-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 6px;
    min-height: 380px;
}

/* Día del calendario */
.cqt-cal-day {
    background: white;
    border: 2px solid var(--cqt-cal-border);
    border-radius: 10px;
    min-height: 96px;
    padding: 10px 8px 8px;
    text-align: left;
    font-family: inherit;
    color: var(--cqt-cal-text);
    transition: all 0.15s;
    display: flex;
    flex-direction: column;
    width: 100%;
    cursor: default;
}
.cqt-cal-day.is-bookable {
    cursor: pointer;
    border-width: 2px;
}
.cqt-cal-day.is-bookable:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(0,0,0,0.10);
}
.cqt-cal-day.is-outside { opacity: 0; pointer-events: none; }
.cqt-cal-day.is-past { background: #f9fafb; opacity: 0.55; }
.cqt-cal-day.is-today {
    border-color: var(--cqt-cal-orange);
    border-style: dashed;
}
.cqt-cal-day-num {
    font-size: 22px;
    font-weight: 700;
    line-height: 1;
    color: var(--cqt-cal-text);
    margin-bottom: 6px;
}
.cqt-cal-day.is-today .cqt-cal-day-num { color: var(--cqt-cal-orange-dark); }
.cqt-cal-day-pill {
    margin-top: auto;
    padding: 5px 7px;
    border-radius: 5px;
    font-size: 12px;
    font-weight: 700;
    color: white;
    line-height: 1.2;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.cqt-cal-day-icon {
    font-size: 12px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.cqt-cal-day-meta { font-size: 11px; font-weight: 600; opacity: 0.95; }

/* =========================================================================== */
/* LEYENDA                                                                     */
/* =========================================================================== */
.cqt-cal-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    padding: 16px 10px 4px;
    border-top: 1px solid var(--cqt-cal-border);
    margin-top: 14px;
    font-size: 13px;
    color: var(--cqt-cal-muted);
}
.cqt-cal-legend-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.cqt-cal-legend-dot {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 9px;
    font-weight: 700;
}

/* =========================================================================== */
/* MODAL DE DETALLE DE SALIDA                                                  */
/* =========================================================================== */
.cqt-cal-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(14, 37, 71, 0.55);
    z-index: 9998;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 16px;
}
.cqt-cal-modal-backdrop.is-open {
    display: flex;
    animation: cqt-cal-fade 0.2s;
}
@keyframes cqt-cal-fade { from { opacity: 0; } to { opacity: 1; } }

.cqt-cal-modal {
    background: white;
    border-radius: 16px;
    max-width: 480px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    padding: 24px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.3);
}
.cqt-cal-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 16px;
}
.cqt-cal-modal-date {
    font-size: 20px;
    font-weight: 700;
    color: var(--cqt-cal-navy);
    margin: 0;
}
.cqt-cal-modal-trek {
    font-size: 14px;
    color: var(--cqt-cal-muted);
    margin: 4px 0 0 0;
}
.cqt-cal-modal-close {
    background: transparent;
    border: 0;
    cursor: pointer;
    width: 44px;
    height: 44px;
    border-radius: 8px;
    font-size: 22px;
    color: var(--cqt-cal-muted);
    display: flex;
    align-items: center;
    justify-content: center;
}
.cqt-cal-modal-close:hover {
    background: var(--cqt-cal-cream);
    color: var(--cqt-cal-text);
}

.cqt-cal-modal-status {
    padding: 14px 16px;
    border-radius: 10px;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 12px;
}
.cqt-cal-modal-status-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-weight: 700;
    flex-shrink: 0;
}
.cqt-cal-modal-status-text strong { display: block; font-size: 15px; font-weight: 700; }
.cqt-cal-modal-status-text small { display: block; font-size: 13px; margin-top: 2px; opacity: 0.9; }

.cqt-cal-modal-info {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 18px;
    padding: 14px;
    background: var(--cqt-cal-cream);
    border-radius: 10px;
}
.cqt-cal-modal-info-cell {
    font-size: 14px;
}
.cqt-cal-modal-info-label {
    color: var(--cqt-cal-muted);
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    display: block;
}
.cqt-cal-modal-info-value {
    color: var(--cqt-cal-navy);
    font-size: 16px;
    font-weight: 700;
    margin-top: 2px;
    display: block;
}

.cqt-cal-modal-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: var(--cqt-cal-wa);
    color: white !important;
    padding: 14px 22px;
    border-radius: 12px;
    font-weight: 700;
    font-size: 16px;
    text-decoration: none;
    transition: all 0.15s;
    border: 0;
    cursor: pointer;
    width: 100%;
    min-height: 52px;
}
.cqt-cal-modal-cta:hover {
    background: var(--cqt-cal-wa-dark);
    transform: translateY(-1px);
    box-shadow: 0 6px 14px rgba(37,211,102,0.4);
}
.cqt-cal-modal-cta.is-disabled {
    background: var(--cqt-cal-gray);
    cursor: not-allowed;
    pointer-events: none;
    opacity: 0.7;
}

.cqt-cal-modal-empty {
    text-align: center;
    padding: 30px 10px;
}
.cqt-cal-modal-empty p {
    color: var(--cqt-cal-muted);
    font-size: 15px;
    margin: 0 0 16px 0;
}

/* =========================================================================== */
/* LOADING / EMPTY / ERROR                                                     */
/* =========================================================================== */
.cqt-cal-state {
    text-align: center;
    padding: 50px 20px;
    background: var(--cqt-cal-cream);
    border-radius: 12px;
    color: var(--cqt-cal-muted);
    font-size: 15px;
}
.cqt-cal-state.is-error {
    background: #fef2f2;
    color: #8b3a00;
}
.cqt-cal-loading::after {
    content: '';
    display: inline-block;
    width: 16px;
    height: 16px;
    margin-left: 10px;
    border: 2px solid var(--cqt-cal-orange);
    border-top-color: transparent;
    border-radius: 50%;
    animation: cqt-cal-spin 0.8s linear infinite;
    vertical-align: middle;
}
@keyframes cqt-cal-spin { to { transform: rotate(360deg); } }

/* =========================================================================== */
/* MOBILE                                                                      */
/* =========================================================================== */
@media (max-width: 700px) {
    .cqt-cal-header { flex-direction: column; align-items: stretch; }
    .cqt-cal-title { font-size: 22px; }
    .cqt-cal-tab { padding: 12px 14px; min-height: 60px; gap: 10px; }
    .cqt-cal-tab-num { width: 40px; height: 40px; font-size: 17px; }
    .cqt-cal-tab-title { font-size: 14px; }
    .cqt-cal-monthtitle { font-size: 20px; }
    .cqt-cal-grid-wrap { padding: 12px; }
    .cqt-cal-day { min-height: 76px; padding: 6px 4px 4px; border-radius: 8px; }
    .cqt-cal-day-num { font-size: 17px; }
    .cqt-cal-day-pill { font-size: 10px; padding: 3px 4px; }
    .cqt-cal-day-meta { font-size: 9px; }
    .cqt-cal-modal { padding: 18px; }
    .cqt-cal-modal-info { grid-template-columns: 1fr; gap: 10px; }
}
@media (max-width: 460px) {
    .cqt-cal-weekdays div { font-size: 11px; padding: 8px 0; letter-spacing: 0.3px; }
    .cqt-cal-day { min-height: 64px; padding: 5px 3px; }
    .cqt-cal-day-num { font-size: 15px; }
}
