:root {
    --gold: #c5a059;
    --black: #1a1a1a;
    --gray-soft: #f8f8f8;
    --border: #ececec;
}

body { margin: 0; font-family: 'Montserrat', sans-serif; background: #fff; color: var(--black); }

/* HEADER */
.header-luxury { padding: 30px 50px; border-bottom: 1px solid var(--border); }
.header-inner { display: flex; justify-content: space-between; align-items: center; max-width: 1400px; margin: 0 auto; }
.brand h1 { font-family: 'Playfair Display'; letter-spacing: 5px; margin: 0; font-size: 24px; }
.brand p { color: var(--gold); font-size: 10px; letter-spacing: 3px; margin: 0; }
.nav-back { text-decoration: none; color: var(--black); font-size: 11px; letter-spacing: 1px; font-weight: 600; }

/* LAYOUT */
.booking-layout { display: flex; min-height: 100vh; }
.booking-visual { width: 35%; background: url("../assets/fondo/FONDO2.png") center/cover; position: relative; }
.visual-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.3); }
.visual-info { position: relative; z-index: 2; height: 100%; display: flex; flex-direction: column; justify-content: center; padding: 60px; color: #fff; }
.visual-info h2 { font-family: 'Playfair Display'; font-size: 40px; }

/* FORM CONTENT */
.booking-form-container { width: 65%; padding: 80px 100px; }
.step-box { position: relative; padding-bottom: 50px; margin-bottom: 50px; border-bottom: 1px solid var(--border); }
.step-indicator { position: absolute; left: -60px; top: 0; font-family: 'Playfair Display'; color: var(--gold); font-size: 24px; font-weight: bold; }
.step-label { font-size: 11px; letter-spacing: 3px; color: #999; display: block; margin-bottom: 30px; }

/* GRID DE SERVICIOS */
.premium-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 20px; }
.service-card { border: 1px solid var(--border); padding: 25px; text-align: center; transition: 0.3s; cursor: pointer; }
.service-card h4 { font-size: 14px; margin: 0; text-transform: uppercase; }
.service-card span { color: var(--gold); display: block; margin: 10px 0; font-weight: 600; }
.service-card p { font-size: 10px; color: #bbb; margin: 0; }
.service-card.selected { border-color: var(--black); background: var(--black); color: #fff; }

/* CALENDARIO Y HORAS */
.calendar-strip { display: flex; gap: 15px; overflow-x: auto; padding-bottom: 10px; }
.day-item { min-width: 90px; padding: 20px; border: 1px solid var(--border); text-align: center; cursor: pointer; }
.day-item.selected { background: var(--gold); color: white; border-color: var(--gold); }

.hours-flex { display: flex; flex-wrap: wrap; gap: 10px; }
.hour-item { padding: 12px 25px; border: 1px solid var(--border); font-size: 13px; cursor: pointer; }
.hour-item.selected { border-color: var(--black); background: var(--black); color: white; }

/* INPUTS */
.lux-input { width: 100%; padding: 15px 0; border: none; border-bottom: 1px solid var(--border); margin-bottom: 30px; outline: none; transition: 0.3s; }
.lux-input:focus { border-color: var(--gold); }
.dual-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }

/* BOTÓN FINAL */
.btn-submit-lux { background: var(--black); color: white; border: none; padding: 25px; width: 100%; letter-spacing: 4px; font-weight: 600; cursor: pointer; transition: 0.4s; }
.btn-submit-lux:hover { background: var(--gold); }

/* RESUMEN (CARRITO) */
.resumen-badge { background: var(--gray-soft); padding: 25px; border-radius: 4px; margin-top: 20px; }

/* --- MEDIA QUERY PARA MÓVILES --- */
@media (max-width: 768px) {
    /* 1. Ajuste del Header */
    .header-luxury {
        padding: 20px;
    }
    
    .header-inner {
        flex-direction: column;
        gap: 15px;
        text-align: center;
    }

    /* 2. Layout: De dos columnas a una sola */
    .booking-layout {
        flex-direction: column;
    }

    /* Ocultamos o reducimos la imagen lateral para ahorrar espacio */
    .booking-visual {
        width: 100%;
        height: 200px; /* Altura pequeña para que se vea el formulario rápido */
    }

    .visual-info h2 {
        font-size: 28px;
        text-align: center;
    }

    /* 3. Ajuste del Contenedor del Formulario */
    .booking-form-container {
        width: 100%;
        padding: 40px 20px;
        box-sizing: border-box;
    }

    /* 4. Reposicionamiento de los Indicadores Numéricos (01, 02...) */
    .step-box {
        padding-left: 0;
        margin-left: 0;
    }

    .step-indicator {
        position: static; /* Ya no flotan a la izquierda */
        display: inline-block;
        margin-bottom: 10px;
        font-size: 20px;
    }

    /* 5. Grillas Adaptables */
    .premium-grid {
        grid-template-columns: 1fr; /* Una sola columna para que las cards sean grandes */
        gap: 15px;
    }

    .dual-fields {
        grid-template-columns: 1fr; /* Inputs uno debajo del otro */
        gap: 0;
    }

    /* 6. Optimización del Calendario y Horas */
    .calendar-strip {
        gap: 10px;
        -webkit-overflow-scrolling: touch; /* Scroll suave en iOS */
    }

    .day-item {
        min-width: 75px;
        padding: 15px 10px;
    }

    .hours-flex {
        justify-content: center;
    }

    .hour-item {
        flex: 1 1 30%; /* Tres columnas de horas por fila aprox. */
        text-align: center;
        padding: 12px 5px;
    }

    /* 7. Botón de Confirmación */
    .btn-submit-lux {
        padding: 20px;
        font-size: 14px;
        position: sticky;
        bottom: 0; /* Lo mantiene visible al final de la pantalla */
        z-index: 10;
    }
}

@media (max-width: 768px) {
    /* ... tus otros estilos ... */

    .visual-info {
        padding: 30px 20px; /* Reducimos el padding para ganar espacio */
        text-align: center;
        justify-content: center; /* Asegura que el texto esté centrado verticalmente */
    }

    .visual-info h2 {
        font-size: 26px; /* Reducimos el tamaño de la letra para que no se corte */
        line-height: 1.2;
        margin-bottom: 10px;
        word-wrap: break-word; /* Fuerza a que la palabra rompa si es muy larga */
    }

    .visual-info p {
        font-size: 14px;
        line-height: 1.5;
    }

    .visual-overlay {
        background: rgba(0, 0, 0, 0.5); /* Un poco más oscuro para que el texto blanco brille */
    }
}
}

/* Filtros de Categoría */
.categories-tabs {
    display: flex;
    gap: 10px;
    margin-bottom: 25px;
    overflow-x: auto;
    padding-bottom: 10px;
    scrollbar-width: none; /* Oculta scroll en Firefox */
}

.categories-tabs::-webkit-scrollbar { display: none; } /* Oculta scroll en Chrome/Safari */

.cat-btn {
    background: none;
    border: 1px solid var(--border);
    padding: 10px 20px;
    font-family: 'Montserrat', sans-serif;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 2px;
    cursor: pointer;
    transition: 0.3s;
    white-space: nowrap;
}

.cat-btn.active {
    background: var(--gold);
    color: white;
    border-color: var(--gold);
}

.cat-btn:hover:not(.active) {
    border-color: var(--gold);
}

/* Animación del Spinner */
@keyframes spin {
    to { transform: rotate(360deg); }
}

.spinner {
    display: inline-block;
    width: 18px;
    height: 18px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-radius: 50%;
    border-top-color: #fff;
    animation: spin 0.8s linear infinite;
    margin-right: 10px;
    vertical-align: middle;
}

/* Estado deshabilitado del botón */
.btn-submit-lux:disabled {
    opacity: 0.8;
    cursor: not-allowed;
    filter: grayscale(0.2);
}
