/**
 * frontend-calendar.css — Reservas Calendar
 *
 * Paleta: #333333 (negro) y #ffffff (blanco).
 * Layout: 2 columnas en grupos de campos.
 * Bordes: 2px solid #333333 en todos los campos y botones.
 *
 * NOTA SOBRE !important:
 * Se usa de forma quirúrgica únicamente en propiedades de layout y display
 * que el tema OceanWP (u otros temas) sobreescriben con sus propias reglas
 * de normalización de formularios (display:block, width:100%, etc.).
 * Sin estos !important el grid y el flex del contador se rompen.
 *
 * @package ReservasCalendar
 */

/* ──────────────────────────────────────────────
   WRAPPER
────────────────────────────────────────────── */

.rcal-form-wrapper {
    width: 100%;
    box-sizing: border-box;
    font-family: inherit;
    color: #333333;
}

/* ──────────────────────────────────────────────
   GRUPOS DE CAMPOS — 2 columnas
   !important necesario: OceanWP sobreescribe
   display en elementos de formulario.
────────────────────────────────────────────── */

.rcal-form-wrapper .rcal-field-group {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
    margin-bottom: 16px !important;
    width: 100% !important;
    float: none !important;
}

.rcal-form-wrapper .rcal-field {
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
    position: relative !important;
    width: auto !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Etiquetas */
.rcal-form-wrapper .rcal-field label {
    display: block !important;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: #333333;
    margin: 0 0 4px !important;
    padding: 0;
    float: none;
    width: auto;
}

.rcal-required {
    color: #333333;
    margin-left: 2px;
}

.rcal-opcional {
    font-weight: 400;
    font-size: 11px;
    text-transform: none;
    color: #333333;
    margin-left: 4px;
    opacity: .6;
}

/* ──────────────────────────────────────────────
   INPUTS DE TEXTO
────────────────────────────────────────────── */

.rcal-form-wrapper .rcal-input {
    display: block !important;
    width: 100% !important;
    padding: 10px 12px !important;
    border: 2px solid #333333 !important;
    border-radius: 0 !important;
    background: #ffffff !important;
    color: #333333 !important;
    font-size: 14px !important;
    font-family: inherit !important;
    box-sizing: border-box !important;
    outline: none !important;
    box-shadow: none !important;
    margin: 0 !important;
    height: auto !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    transition: background .15s, color .15s;
}

.rcal-form-wrapper .rcal-input:focus {
    background: #ffffff !important;
    color: #333333 !important;
    box-shadow: none !important;
    outline: none !important;
    border-color: #333333 !important;
}

.rcal-form-wrapper .rcal-input::placeholder {
    color: #333333 !important;
    opacity: .4 !important;
}

.rcal-form-wrapper .rcal-input.has-error {
    border-color: #333333 !important;
}

/* Contenedor del input de fecha */
.rcal-form-wrapper .rcal-date-input-wrap {
    position: relative;
    width: 100%;
}

/* ──────────────────────────────────────────────
   CONTADORES DE HUÉSPEDES
   El tema rompe el flex aplicando display:block
   a los inputs hijos — se necesita !important
   en todo el componente.
────────────────────────────────────────────── */

.rcal-form-wrapper .rcal-counter {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    border: 2px solid #333333 !important;
    background: #ffffff !important;
    overflow: hidden !important;
    padding: 0 !important;
    margin: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
    height: 44px !important;
}

/* Botones − y + */
.rcal-form-wrapper .rcal-counter .rcal-counter-btn {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-shrink: 0 !important;
    flex-grow: 0 !important;
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    border: none !important;
    border-radius: 0 !important;
    background: #ffffff !important;
    color: #333333 !important;
    font-size: 20px !important;
    line-height: 1 !important;
    cursor: pointer !important;
    padding: 0 !important;
    margin: 0 !important;
    box-shadow: none !important;
    font-family: inherit !important;
    transition: background .15s, color .15s;
}

.rcal-form-wrapper .rcal-counter .rcal-counter-btn:hover:not(:disabled) {
    background: #333333 !important;
    color: #ffffff !important;
}

.rcal-form-wrapper .rcal-counter .rcal-counter-btn:disabled {
    opacity: .3 !important;
    cursor: default !important;
}

/* Separadores internos */
.rcal-form-wrapper .rcal-counter .rcal-decrement {
    border-right: 2px solid #333333 !important;
}

.rcal-form-wrapper .rcal-counter .rcal-increment {
    border-left: 2px solid #333333 !important;
}

/* Input numérico dentro del contador */
.rcal-form-wrapper .rcal-counter input[type="number"] {
    display: block !important;
    border: none !important;
    border-radius: 0 !important;
    text-align: center !important;
    flex: 1 1 auto !important;
    width: auto !important;
    min-width: 0 !important;
    height: 44px !important;
    max-height: 44px !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    color: #333333 !important;
    background: #ffffff !important;
    font-family: inherit !important;
    padding: 0 !important;
    margin: 0 !important;
    box-shadow: none !important;
    outline: none !important;
    -moz-appearance: textfield !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    float: none !important;
}

.rcal-form-wrapper .rcal-counter input[type="number"]::-webkit-inner-spin-button,
.rcal-form-wrapper .rcal-counter input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: none !important;
    margin: 0 !important;
}

/* Hint de capacidad */
.rcal-form-wrapper .rcal-capacity-hint {
    display: block;
    font-size: 11px;
    color: #333333;
    opacity: .55;
    margin: 2px 0 0;
    padding: 0;
}

/* ──────────────────────────────────────────────
   MENSAJES DE ERROR DE CAMPO
────────────────────────────────────────────── */

.rcal-form-wrapper .rcal-field-error {
    display: block;
    font-size: 11px;
    color: #333333;
    font-weight: 600;
    min-height: 14px;
    margin: 0;
    padding: 0;
}

/* ──────────────────────────────────────────────
   BOTÓN SUBMIT — ancho completo
────────────────────────────────────────────── */

/* Contenedor de los dos botones: WhatsApp y Mail */
.rcal-form-wrapper .rcal-submit-btns {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 8px;
}

.rcal-form-wrapper .rcal-submit-group {
    margin-top: 8px;
    width: 100%;
}

.rcal-form-wrapper .rcal-btn-submit {
    display: block !important;
    width: 100% !important;
    padding: 14px 24px !important;
    border: 2px solid #333333 !important;
    border-radius: 0 !important;
    background: #ffffff !important;
    color: #333333 !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
    font-family: inherit !important;
    cursor: pointer !important;
    text-align: center !important;
    box-shadow: none !important;
    margin: 0 !important;
    line-height: normal !important;
    transition: background .15s, color .15s;
}

.rcal-form-wrapper .rcal-btn-submit:hover {
    background: #333333 !important;
    color: #ffffff !important;
}

.rcal-form-wrapper .rcal-btn-submit:disabled {
    opacity: .45 !important;
    cursor: not-allowed !important;
}

/* ──────────────────────────────────────────────
   FEEDBACK DE ENVÍO
────────────────────────────────────────────── */

.rcal-form-wrapper .rcal-submit-feedback {
    margin-top: 10px;
    padding: 10px 14px;
    border: 2px solid #333333;
    font-size: 13px;
    font-weight: 500;
    color: #333333;
    background: #ffffff;
}

.rcal-form-wrapper .rcal-submit-feedback.error {
    border-style: dashed;
}

/* ──────────────────────────────────────────────
   POPUP DEL CALENDARIO
────────────────────────────────────────────── */

.rcal-form-wrapper .rcal-calendar-popup {
    position: absolute !important;
    top: calc(100% + 4px) !important;
    left: 0 !important;
    z-index: 9999 !important;
    background: #ffffff !important;
    border: 2px solid #333333 !important;
    padding: 12px !important;
    min-width: 280px;
    max-width: 320px;
    box-shadow: 4px 4px 0 #333333;
    user-select: none;
    font-size: 13px;
    color: #333333;
    box-sizing: border-box;
    margin: 0 !important;
    float: none !important;
}

/* Navegación mes */
.rcal-form-wrapper .rcal-popup-nav {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin-bottom: 10px;
    width: 100%;
}

.rcal-form-wrapper .rcal-popup-nav button {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #ffffff !important;
    border: 2px solid #333333 !important;
    border-radius: 0 !important;
    width: 28px !important;
    height: 28px !important;
    cursor: pointer !important;
    font-size: 13px !important;
    line-height: 1 !important;
    padding: 0 !important;
    color: #333333 !important;
    box-shadow: none !important;
    transition: background .15s, color .15s;
    flex-shrink: 0;
}

.rcal-form-wrapper .rcal-popup-nav button:hover {
    background: #333333 !important;
    color: #ffffff !important;
}

.rcal-popup-month {
    font-weight: 700;
    font-size: 14px;
    color: #333333;
}

/* Días de la semana */
.rcal-form-wrapper .rcal-popup-weekdays {
    display: grid !important;
    grid-template-columns: repeat(7, 1fr) !important;
    gap: 2px;
    margin-bottom: 2px;
}

.rcal-popup-wd {
    text-align: center;
    font-size: 10px;
    font-weight: 700;
    color: #333333;
    padding: 3px 0;
    text-transform: uppercase;
    opacity: .5;
}

/* Grilla de días */
.rcal-form-wrapper .rcal-popup-days {
    display: grid !important;
    grid-template-columns: repeat(7, 1fr) !important;
    gap: 2px;
}

.rcal-form-wrapper .rcal-popup-day {
    position: relative;
    aspect-ratio: 1;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 12px;
    font-weight: 500;
    min-height: 34px;
    cursor: pointer;
    transition: background .1s, color .1s;
    margin: 0 !important;
    padding: 0 !important;
    float: none !important;
    box-sizing: border-box;
}

/* Estados de disponibilidad */
.rcal-form-wrapper .rcal-popup-day.disponible {
    background: #e8f5e9;
    color: #2e7d32;
    border: 1px solid #c8e6c9;
}
.rcal-form-wrapper .rcal-popup-day.disponible:hover {
    background: #c8e6c9;
    color: #1b5e20;
    border-color: #a5d6a7;
}

.rcal-form-wrapper .rcal-popup-day.con-minimo {
    background: #e8f5e9;
    color: #2e7d32;
    border: 1px solid #c8e6c9;
}
.rcal-form-wrapper .rcal-popup-day.con-minimo .rcal-noches-badge {
    font-size: 9px;
    font-weight: 700;
    color: #1565c0;
    line-height: 1;
}
.rcal-form-wrapper .rcal-popup-day.con-minimo:hover {
    background: #c8e6c9;
    color: #1b5e20;
    border-color: #a5d6a7;
}

.rcal-form-wrapper .rcal-popup-day.no-disponible {
    background: #e53935;
    color: #ffffff;
    border: 1px solid #e53935;
    cursor: default;
    pointer-events: none;
}

.rcal-form-wrapper .rcal-popup-day.sin-checkin {
    background: #f5f5f5;
    color: #999;
    border: 1px solid #e0e0e0;
    cursor: default;
    pointer-events: none;
}

.rcal-form-wrapper .rcal-popup-day.pasado {
    background: #ffffff;
    color: #ccc;
    border: 1px solid #eee;
    cursor: default;
    pointer-events: none;
}

.rcal-form-wrapper .rcal-popup-day.vacio {
    background: transparent !important;
    border: none !important;
    pointer-events: none;
}

.rcal-form-wrapper .rcal-popup-day.seleccionado {
    background: #333333 !important;
    color: #ffffff !important;
    border-color: #333333 !important;
}

.rcal-form-wrapper .rcal-popup-day.checkout-disabled {
    opacity: .25;
    cursor: not-allowed;
    pointer-events: none;
}

/* Tooltip */
.rcal-form-wrapper .rcal-popup-day[data-tooltip]:hover::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: calc(100% + 5px);
    left: 50%;
    transform: translateX(-50%);
    background: #333333;
    color: #ffffff;
    font-size: 11px;
    padding: 5px 8px;
    white-space: normal;
    max-width: 180px;
    text-align: center;
    z-index: 10000;
    pointer-events: none;
}

/* ── Días en rango: entre check-in y checkout seleccionado ─────────────
   Se aplica en el popup de checkout para mostrar visualmente las noches
   seleccionadas. Color negro suave para distinguir del día seleccionado. */
.rcal-form-wrapper .rcal-popup-day.en-rango {
    background: #333333 !important;
    color: #ffffff !important;
    border-color: #333333 !important;
    border-radius: 0;      /* rango continuo sin bordes redondeados */
}

/* ──────────────────────────────────────────────
   RESPONSIVE — 1 columna en móvil
────────────────────────────────────────────── */

@media ( max-width: 600px ) {
    .rcal-form-wrapper .rcal-field-group {
        grid-template-columns: 1fr !important;
    }

    .rcal-form-wrapper .rcal-calendar-popup {
        position: fixed !important;
        top: 50% !important;
        left: 50% !important;
        transform: translate(-50%, -50%) !important;
        max-width: 92vw;
        max-height: 88vh;
        overflow-y: auto;
        box-shadow: 6px 6px 0 #333333;
    }
}

/* Botón CONSULTAR POR MAIL: mismo tamaño que WhatsApp, color diferenciado */
.rcal-form-wrapper .rcal-btn-mail {
    background: #ffffff;
    color: #333333;
    border: 2px solid #333333;
}

.rcal-form-wrapper .rcal-btn-mail:hover:not(:disabled) {
    background: #333333;
    color: #ffffff;
}

.rcal-form-wrapper .rcal-btn-mail:disabled {
    background: #f5f5f5;
    color: #aaa;
    border-color: #ddd;
}