.padel-page {
    --stay-bg: #eef5f2;
    --stay-paper: #fffdf9;
    --stay-ink: #17211f;
    --stay-muted: #65716e;
    --stay-line: rgba(23, 33, 31, 0.13);
    --stay-clay: #1f6f78;
    --stay-clay-dark: #0e4f58;
    --stay-teal: #bf6430;
    --stay-green: #176f4a;
}

.padel-page .booking-hero {
    background: #dfeeea;
}

.padel-page .booking-hero img {
    filter: saturate(0.92) brightness(0.78);
}

.padel-page .booking-hero::after {
    display: block;
    background:
        linear-gradient(90deg, rgba(23, 33, 31, 0.42), rgba(23, 33, 31, 0.08) 48%, rgba(23, 33, 31, 0.28)),
        linear-gradient(0deg, rgba(238, 245, 242, 0.08), rgba(238, 245, 242, 0));
}

.padel-hero-copy {
    position: relative;
    z-index: 2;
    align-self: center;
    width: min(520px, 100%);
    margin-bottom: 110px;
    color: #fff;
    pointer-events: none;
}

.padel-hero-copy p {
    margin: 0 0 8px;
    color: #bce7df;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.padel-hero-copy strong {
    display: block;
    max-width: 14ch;
    font-size: clamp(2.2rem, 6vw, 5.2rem);
    font-weight: 900;
    line-height: 0.92;
}

.padel-hero-copy span {
    display: block;
    max-width: 520px;
    margin-top: 14px;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.5;
}

.padel-page .booking-search-shell {
    border-color: rgba(255, 255, 255, 0.74);
}

.padel-search {
    grid-template-columns: minmax(190px, 1.4fr) repeat(3, minmax(130px, 0.8fr)) auto;
}

.padel-page .search-btn,
.padel-page .book-btn {
    background: var(--stay-clay-dark);
}

.padel-page .search-btn:hover,
.padel-page .book-btn:hover {
    background: var(--stay-teal);
}

.padel-page .stay-score {
    background: var(--stay-clay-dark);
}

.padel-page .stay-badges span {
    color: var(--stay-clay-dark);
}

.padel-page .stay-booking strong {
    color: var(--stay-clay-dark);
}

.padel-page .contact-link {
    color: var(--stay-clay-dark);
}

.padel-page .stay-booking-form select {
    width: 100%;
    border: 1px solid var(--stay-line);
    border-radius: 8px;
    background: #fff;
    color: var(--stay-ink);
    padding: 10px 12px;
    font: inherit;
}

#padelBookingApp {
    padding: 24px clamp(16px, 4vw, 48px) 110px;
    background: var(--stay-bg);
}

.padel-workflow {
    max-width: 1440px;
    margin: 0 auto;
}

.padel-workflow-heading {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 16px;
    margin-bottom: 18px;
}

.padel-workflow-heading h1 {
    margin: 0;
    color: var(--stay-clay-dark);
    font-size: clamp(2rem, 5vw, 4.5rem);
    line-height: 0.95;
}

.padel-stepper {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.padel-step {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    min-height: 36px;
    border: 1px solid var(--stay-line);
    border-radius: 999px;
    background: #fff;
    color: var(--stay-muted);
    padding: 5px 11px;
    font-size: 12px;
    font-weight: 900;
    white-space: nowrap;
}

.padel-step b {
    display: inline-grid;
    place-items: center;
    width: 22px;
    height: 22px;
    border-radius: 999px;
    background: rgba(31, 111, 120, 0.12);
    color: var(--stay-clay-dark);
}

.padel-step.is-active,
.padel-step.is-done {
    border-color: rgba(31, 111, 120, 0.35);
    color: var(--stay-clay-dark);
}

.padel-workflow-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
    gap: 18px;
}

.padel-main-panel,
.padel-side-panel,
.padel-side-card,
.padel-summary-card,
.padel-form-block,
.padel-confirmation {
    border: 1px solid var(--stay-line);
    border-radius: 8px;
    background: var(--stay-paper);
    box-shadow: 0 18px 50px rgba(23, 33, 31, 0.07);
}

.padel-main-panel {
    padding: 20px;
    overflow: hidden;
}

.padel-side-panel {
    display: grid;
    align-content: start;
    gap: 12px;
    padding: 14px;
}

.padel-side-card {
    padding: 16px;
    box-shadow: none;
}

.padel-side-card h3,
.padel-picker-block h3,
.padel-summary-card h2,
.padel-form-block h2,
.padel-confirmation h2 {
    margin: 0 0 10px;
    color: var(--stay-clay-dark);
}

.padel-side-card p,
.padel-side-card li,
.padel-section-title p,
.padel-club-detail p,
.padel-confirmation p {
    color: var(--stay-muted);
    line-height: 1.6;
}

.padel-side-card ul,
.padel-side-card ol {
    display: grid;
    gap: 8px;
    margin: 0;
    padding-left: 20px;
}

.padel-side-card strong {
    display: block;
    color: var(--stay-clay-dark);
    font-size: 30px;
    line-height: 1;
}

.padel-mini-booking {
    display: grid;
    gap: 3px;
    border-top: 1px solid rgba(23, 33, 31, 0.08);
    padding: 10px 0;
}

.padel-mini-booking:first-of-type {
    border-top: 0;
    padding-top: 0;
}

.padel-mini-booking strong {
    font-size: 18px;
}

.padel-mini-booking span,
.padel-mini-booking small {
    color: var(--stay-muted);
    font-size: 12px;
    font-weight: 800;
}

.padel-section-title {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-end;
    margin-bottom: 16px;
}

.padel-section-title h2 {
    margin: 0;
    color: var(--stay-clay-dark);
    font-size: clamp(1.6rem, 4vw, 3rem);
    line-height: 1;
}

.padel-club-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 14px;
}

.padel-club-card {
    display: grid;
    overflow: hidden;
    border: 1px solid var(--stay-line);
    border-radius: 8px;
    background: #fff;
}

.padel-club-card img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    background: #dfeeea;
}

.padel-club-card-body {
    display: grid;
    gap: 10px;
    padding: 16px;
}

.padel-card-topline,
.padel-card-meta,
.padel-detail-list,
.padel-next-row,
.padel-slot-heading,
.padel-summary-row {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.padel-card-topline {
    justify-content: space-between;
    color: var(--stay-clay-dark);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.padel-club-card h2 {
    margin: 0;
    color: var(--stay-clay-dark);
    font-size: 28px;
    line-height: 1;
}

.padel-club-card p {
    margin: 0;
    color: var(--stay-muted);
}

.padel-card-meta span,
.padel-detail-list span {
    display: inline-flex;
    min-height: 28px;
    align-items: center;
    border-radius: 999px;
    background: rgba(31, 111, 120, 0.09);
    color: var(--stay-clay-dark);
    padding: 4px 9px;
    font-size: 12px;
    font-weight: 900;
}

.padel-back-button {
    margin-bottom: 14px;
}

.padel-club-detail {
    display: grid;
    grid-template-columns: minmax(180px, 320px) minmax(0, 1fr);
    gap: 18px;
    margin-bottom: 18px;
    align-items: center;
}

.padel-club-detail img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: 8px;
    background: #dfeeea;
}

.padel-club-detail h2 {
    margin: 0 0 8px;
    color: var(--stay-clay-dark);
    font-size: clamp(2rem, 5vw, 4rem);
    line-height: 0.95;
}

.padel-picker-block {
    margin-top: 18px;
}

.padel-day-list,
.padel-court-list,
.padel-duration-list,
.padel-slot-grid {
    display: grid;
    gap: 10px;
}

.padel-day-list {
    grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
}

.padel-court-list {
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

.padel-duration-list {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.padel-slot-grid {
    grid-template-columns: repeat(auto-fit, minmax(86px, 1fr));
}

.padel-day,
.padel-court,
.padel-duration,
.padel-slot {
    min-height: 74px;
    border: 1px solid var(--stay-line);
    border-radius: 8px;
    background: #fff;
    color: var(--stay-ink);
    padding: 11px;
    text-align: left;
    font-weight: 900;
}

.padel-day span,
.padel-court span,
.padel-court small,
.padel-duration span,
.padel-duration small,
.padel-slot span {
    display: block;
    margin-top: 5px;
    color: var(--stay-muted);
    font-size: 11px;
    font-weight: 800;
}

.padel-day.is-active,
.padel-court.is-active,
.padel-duration.is-active,
.padel-slot.is-active {
    border-color: var(--stay-clay-dark);
    background: rgba(31, 111, 120, 0.1);
    color: var(--stay-clay-dark);
}

.padel-day:disabled,
.padel-court:disabled,
.padel-duration:disabled,
.padel-slot:disabled {
    cursor: not-allowed;
    opacity: 0.48;
}

.padel-slot {
    display: grid;
    place-items: center;
    text-align: center;
}

.padel-slot-heading,
.padel-next-row,
.padel-summary-row {
    justify-content: space-between;
}

.padel-slot-heading span,
.padel-next-row div {
    color: var(--stay-muted);
    font-weight: 800;
}

.padel-next-row {
    margin-top: 20px;
    border-top: 1px solid var(--stay-line);
    padding-top: 16px;
}

.padel-login-required {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 18px;
    border: 1px solid rgba(166, 60, 47, 0.18);
    border-radius: 8px;
    background: rgba(166, 60, 47, 0.06);
    color: var(--stay-muted);
    padding: 12px 14px;
    font-size: 13px;
    font-weight: 800;
}

.padel-login-required strong {
    color: var(--stay-clay-dark);
}

.padel-login-required span {
    flex: 1 1 240px;
}

.padel-login-required a {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    border-radius: 8px;
    background: var(--stay-clay-dark);
    color: #fff;
    padding: 8px 12px;
    text-decoration: none;
    font-weight: 900;
}

.padel-summary-card,
.padel-form-block,
.padel-confirmation {
    padding: 18px;
    margin-bottom: 14px;
    box-shadow: none;
}

.padel-summary-row {
    border-bottom: 1px solid rgba(23, 33, 31, 0.08);
    padding: 10px 0;
}

.padel-summary-row:last-child {
    border-bottom: 0;
}

.padel-summary-row span {
    color: var(--stay-muted);
    font-weight: 800;
}

.padel-summary-row strong {
    color: var(--stay-ink);
    text-align: right;
}

.padel-summary-row.is-total strong {
    color: var(--stay-clay-dark);
    font-size: 24px;
}

.padel-payment-form {
    display: block;
}

.padel-cliq-box {
    background: #f6fbf9;
}

.padel-cliq-grid {
    display: grid;
    gap: 2px;
}

.padel-form-block input,
.padel-form-block textarea {
    width: 100%;
    border: 1px solid var(--stay-line);
    border-radius: 8px;
    background: #fff;
    color: var(--stay-ink);
    padding: 11px 12px;
    font: inherit;
}

.padel-form-block label {
    color: var(--stay-muted);
    font-size: 13px;
    font-weight: 900;
}

.padel-confirmation {
    max-width: 760px;
}

.padel-confirmation .book-btn {
    margin-top: 14px;
}

@media (max-width: 1040px) {
    .padel-search {
        grid-template-columns: 1fr;
    }

    .padel-hero-copy {
        margin-bottom: 130px;
    }

    .padel-workflow-heading,
    .padel-workflow-grid {
        grid-template-columns: 1fr;
        display: grid;
    }

    .padel-stepper {
        justify-content: flex-start;
    }
}

@media (max-width: 680px) {
    .padel-hero {
        min-height: 420px;
    }

    .padel-hero-copy {
        width: 100%;
        margin-bottom: 94px;
    }

    .padel-hero-copy strong {
        font-size: 42px;
    }

    .padel-club-detail {
        grid-template-columns: 1fr;
    }

    .padel-main-panel {
        padding: 14px;
    }

    .padel-summary-row {
        display: grid;
        justify-content: stretch;
    }

    .padel-summary-row strong {
        text-align: left;
    }
}
