/* Simple Workshop Booking v2.3 */

:root {
    --swb-accent: #c17b8a;
    --swb-accent-dark: #9b5d6e;
    --swb-accent-light: #c17b8a18;
    --swb-accent-border: #c17b8a55;
}

.bwb-dates-wrap { margin: 16px 0 24px; font-family: var(--swb-font, inherit); }
.bwb-dates-label { font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: #888; margin: 0 0 12px; }
.bwb-no-dates { color: #999; font-style: italic; font-size: 0.9rem; }

/* Grid */
.bwb-dates-grid { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 18px; }

/* Date button */
.bwb-date-btn {
    display: flex; flex-direction: column; align-items: center; gap: 1px;
    min-width: 84px; padding: 10px 12px 8px;
    border: 1.5px solid #ddd; border-radius: 8px;
    background: #fff; cursor: pointer;
    transition: border-color 0.15s, background 0.15s;
    text-align: center; color: #333; line-height: 1.2; font-family: var(--swb-font, inherit);
}
.bwb-date-btn:hover:not([disabled]):not(.bwb-date-btn--selected) {
    border-color: var(--swb-accent);
    background: var(--swb-accent-light);
    color: #333;
}
.bwb-date-btn--selected {
    border-color: var(--swb-accent) !important;
    border-width: 2px !important;
    background: var(--swb-accent) !important;
    color: #fff !important;
    box-shadow: 0 2px 10px var(--swb-accent-border);
}
.bwb-date-btn--selected .bwb-btn-day,
.bwb-date-btn--selected .bwb-btn-num,
.bwb-date-btn--selected .bwb-btn-month,
.bwb-date-btn--selected .bwb-btn-time,
.bwb-date-btn--selected .bwb-btn-spots { color: rgba(255,255,255,0.9) !important; }

.bwb-date-btn--low { border-color: #e6a817; }
.bwb-date-btn--low .bwb-btn-spots { color: var(--swb-seats-low) !important; font-weight: 700; }

.bwb-date-btn--full, .bwb-date-btn[disabled] {
    background: #f5f5f5 !important; border-color: #e0e0e0 !important;
    color: #bbb !important; cursor: not-allowed; opacity: 0.75;
}

/* Button text */
.bwb-btn-day   { font-size: 0.64rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: #999; }
.bwb-btn-num   { font-size: 1.7rem; font-weight: 800; line-height: 1; margin: 2px 0; color: #222; }
.bwb-btn-month { font-size: 0.7rem; font-weight: 600; color: #555; }
.bwb-btn-time  { font-size: 0.62rem; color: #888; margin-top: 4px; }
.bwb-btn-spots { font-size: 0.6rem; color: var(--swb-seats-ok); font-weight: 700; margin-top: 4px; text-transform: uppercase; letter-spacing: 0.04em; }

/* Add to Cart button */
.bwb-add-to-cart-btn {
    display: block; width: 100%;
    padding: 13px 24px; border: none; border-radius: 6px;
    font-size: 0.95rem; font-weight: 700; font-family: var(--swb-font, inherit);
    letter-spacing: 0.03em; text-align: center;
    background: #e5e5e5; color: #aaa; cursor: not-allowed;
    transition: background 0.2s ease, color 0.2s ease;
}
.bwb-add-to-cart-btn.bwb-btn-active {
    background: var(--swb-accent);
    color: #fff;
    cursor: pointer;
}
.bwb-add-to-cart-btn.bwb-btn-active:hover { background: var(--swb-accent-dark); }

/* Messages */
.bwb-message { margin-top: 12px; font-size: 0.88rem; }
.bwb-msg-confirm { color: var(--swb-accent-dark); font-weight: 600; }
.bwb-msg-confirm a { color: var(--swb-accent); text-decoration: underline; margin-left: 4px; }
.bwb-msg-error { color: #c62828; font-weight: 600; }

@media (max-width: 480px) {
    .bwb-date-btn { min-width: 72px; padding: 8px 8px 6px; }
    .bwb-btn-num  { font-size: 1.4rem; }
}

/* No upcoming dates state */
.bwb-no-dates-wrap { margin: 16px 0 24px; }

.bwb-no-dates-msg {
    font-size: 0.95rem;
    font-weight: 700;
    color: #1d1d1d;
    margin: 0 0 14px;
    font-style: normal;
}

/* Override old italic grey style */
.bwb-no-dates {
    color: #1d1d1d !important;
    font-style: normal !important;
    font-weight: 700 !important;
    font-size: 0.95rem !important;
}
