/**
 * WestCarSpark Services - Frontend v1.4.0
 * With calendar and time slot styling
 */

:root {
    --wcss-primary: #e74c3c;
    --wcss-primary-dark: #c0392b;
    --wcss-dark: #1a1a2e;
    --wcss-text: #333;
    --wcss-text-light: #666;
    --wcss-border: #e0e0e0;
    --wcss-bg-light: #f8f9fa;
    --wcss-white: #fff;
    --wcss-success: #27ae60;
}

/* GRID */
.wcss-packages-grid, .wcss-extras-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 25px !important;
    margin: 40px 0 !important;
}
@media (max-width: 992px) { .wcss-packages-grid, .wcss-extras-grid { grid-template-columns: repeat(2, 1fr) !important; } }
@media (max-width: 600px) { .wcss-packages-grid, .wcss-extras-grid { grid-template-columns: 1fr !important; } }

/* CARDS */
.wcss-card {
    background: var(--wcss-white) !important;
    border-radius: 12px !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.08) !important;
    padding: 25px 20px !important;
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
    border: 1px solid var(--wcss-border) !important;
    box-sizing: border-box !important;
    transition: transform 0.3s, box-shadow 0.3s !important;
}
.wcss-card:hover { transform: translateY(-5px); box-shadow: 0 8px 30px rgba(0,0,0,0.12) !important; }
.wcss-card.wcss-card-highlight { border: 2px solid var(--wcss-primary) !important; }
.wcss-card-subtitle { font-size: 11px !important; font-weight: 600 !important; text-transform: uppercase !important; letter-spacing: 1.5px !important; color: var(--wcss-text-light) !important; margin-bottom: 5px !important; }
.wcss-card-title { font-size: 20px !important; font-weight: 700 !important; color: var(--wcss-dark) !important; margin: 0 0 12px 0 !important; }
.wcss-card-price { margin-bottom: 15px !important; }
.wcss-price-label { display: block !important; font-size: 12px !important; color: var(--wcss-text-light) !important; }
.wcss-price-amount { font-size: 32px !important; font-weight: 800 !important; color: var(--wcss-dark) !important; }
.wcss-card-highlight .wcss-price-amount { color: var(--wcss-primary) !important; }
.wcss-card-description { font-size: 13px !important; color: var(--wcss-text-light) !important; margin-bottom: 15px !important; }
.wcss-features-wrapper { flex-grow: 1 !important; margin-bottom: 15px !important; }
.wcss-card-features { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.wcss-card-features li { position: relative !important; padding: 6px 0 6px 20px !important; font-size: 13px !important; border-bottom: 1px solid var(--wcss-bg-light) !important; }
.wcss-card-features li:last-child { border-bottom: none !important; }
.wcss-card-features li::before { content: '•' !important; position: absolute !important; left: 0 !important; color: var(--wcss-primary) !important; font-weight: bold !important; }
.wcss-features-hidden { display: none !important; }
.wcss-features-hidden.expanded { display: block !important; }
.wcss-toggle-features { background: none !important; border: none !important; padding: 8px 0 !important; font-size: 13px !important; font-weight: 600 !important; color: var(--wcss-primary) !important; cursor: pointer !important; }
.wcss-toggle-features .show-less { display: none !important; }
.wcss-toggle-features.active .show-more { display: none !important; }
.wcss-toggle-features.active .show-less { display: inline !important; }
.wcss-card-footer { margin-top: auto !important; padding-top: 15px !important; }

/* BUTTONS */
.wcss-button { display: inline-block !important; width: 100% !important; padding: 12px 20px !important; font-size: 14px !important; font-weight: 600 !important; text-align: center !important; text-decoration: none !important; border-radius: 6px !important; cursor: pointer !important; border: none !important; text-transform: uppercase !important; box-sizing: border-box !important; transition: all 0.3s !important; }
.wcss-button:not(.wcss-button-secondary) { background: linear-gradient(135deg, var(--wcss-primary), var(--wcss-primary-dark)) !important; color: var(--wcss-white) !important; }
.wcss-button:not(.wcss-button-secondary):hover { background: linear-gradient(135deg, var(--wcss-primary-dark), #a93226) !important; transform: translateY(-2px) !important; }
.wcss-button-secondary { background: var(--wcss-white) !important; color: var(--wcss-dark) !important; border: 2px solid var(--wcss-border) !important; }
.wcss-button-secondary:hover { background: var(--wcss-dark) !important; color: var(--wcss-white) !important; }
.wcss-button:disabled { opacity: 0.5 !important; cursor: not-allowed !important; }

/* BOOKING FORM */
.wcss-booking-form-wrapper { max-width: 800px !important; margin: 40px auto !important; background: var(--wcss-white) !important; border-radius: 16px !important; box-shadow: 0 4px 30px rgba(0,0,0,0.1) !important; overflow: hidden !important; }
.wcss-form-header { background: linear-gradient(135deg, var(--wcss-dark), #2d2d44) !important; padding: 30px !important; text-align: center !important; }
.wcss-form-header h2 { color: var(--wcss-white) !important; margin: 0 0 10px 0 !important; font-size: 24px !important; }
.wcss-form-header p { color: rgba(255,255,255,0.7) !important; margin: 0 !important; font-size: 14px !important; }
.wcss-form-step { display: none !important; padding: 35px !important; }
.wcss-form-step.active { display: block !important; }
.wcss-step-title { display: flex !important; align-items: center !important; font-size: 18px !important; font-weight: 700 !important; color: var(--wcss-dark) !important; margin: 0 0 25px 0 !important; }
.wcss-step-number { display: flex !important; align-items: center !important; justify-content: center !important; width: 32px !important; height: 32px !important; background: var(--wcss-primary) !important; color: var(--wcss-white) !important; border-radius: 50% !important; font-size: 14px !important; margin-right: 12px !important; }
.wcss-optional { font-size: 13px !important; font-weight: 400 !important; color: var(--wcss-text-light) !important; margin-left: 8px !important; }

/* Package Selection */
.wcss-package-selection { display: flex !important; flex-direction: column !important; gap: 10px !important; margin-bottom: 25px !important; }
.wcss-package-option { display: block !important; cursor: pointer !important; }
.wcss-package-option input[type="radio"] { display: none !important; }
.wcss-package-option-content { display: flex !important; justify-content: space-between !important; align-items: center !important; padding: 15px 20px !important; background: var(--wcss-bg-light) !important; border: 2px solid var(--wcss-border) !important; border-radius: 8px !important; transition: all 0.2s !important; }
.wcss-package-option:hover .wcss-package-option-content { border-color: var(--wcss-primary) !important; }
.wcss-package-option input:checked + .wcss-package-option-content { border-color: var(--wcss-primary) !important; background: var(--wcss-white) !important; box-shadow: 0 0 0 1px var(--wcss-primary) !important; }
.wcss-package-option-title { font-size: 15px !important; font-weight: 600 !important; color: var(--wcss-dark) !important; }
.wcss-package-option-price { font-size: 14px !important; font-weight: 700 !important; color: var(--wcss-primary) !important; }

/* Extras Selection */
.wcss-extras-selection { display: flex !important; flex-direction: column !important; gap: 12px !important; margin-bottom: 25px !important; }
.wcss-extra-option { background: var(--wcss-white) !important; border: 2px solid var(--wcss-border) !important; border-radius: 8px !important; transition: border-color 0.2s !important; }
.wcss-extra-option:hover { border-color: var(--wcss-primary) !important; }
.wcss-extra-option.selected { border-color: var(--wcss-success) !important; background: #f0fff4 !important; }
.wcss-extra-checkbox { display: block !important; cursor: pointer !important; position: relative !important; }
.wcss-extra-checkbox input[type="checkbox"] { position: absolute !important; opacity: 0 !important; }
.wcss-extra-content { padding: 15px 18px 15px 50px !important; position: relative !important; }
.wcss-extra-content::before { content: '' !important; position: absolute !important; left: 15px !important; top: 50% !important; transform: translateY(-50%) !important; width: 22px !important; height: 22px !important; border: 2px solid var(--wcss-border) !important; border-radius: 4px !important; background: var(--wcss-white) !important; }
.wcss-extra-checkbox input:checked + .wcss-extra-content::before { background: var(--wcss-success) !important; border-color: var(--wcss-success) !important; }
.wcss-extra-checkbox input:checked + .wcss-extra-content::after { content: '✓' !important; position: absolute !important; left: 20px !important; top: 50% !important; transform: translateY(-50%) !important; color: var(--wcss-white) !important; font-size: 14px !important; font-weight: bold !important; }
.wcss-extra-header { display: flex !important; justify-content: space-between !important; align-items: center !important; }
.wcss-extra-title { font-size: 15px !important; font-weight: 600 !important; color: var(--wcss-dark) !important; }
.wcss-extra-price { font-size: 14px !important; font-weight: 700 !important; color: var(--wcss-primary) !important; }
.wcss-extra-description { margin-top: 8px !important; font-size: 13px !important; color: var(--wcss-text-light) !important; }
.wcss-extra-description p { margin: 0 !important; }
.wcss-no-extras-message { text-align: center !important; padding: 20px !important; background: var(--wcss-bg-light) !important; border-radius: 8px !important; }

/* Form Fields */
.wcss-form-row { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 15px !important; }
@media (max-width: 500px) { .wcss-form-row { grid-template-columns: 1fr !important; } }
.wcss-form-group { margin-bottom: 18px !important; }
.wcss-form-group label { display: block !important; font-size: 13px !important; font-weight: 600 !important; color: var(--wcss-dark) !important; margin-bottom: 6px !important; }
.wcss-form-group input, .wcss-form-group select, .wcss-form-group textarea { width: 100% !important; padding: 12px 14px !important; font-size: 14px !important; border: 2px solid var(--wcss-border) !important; border-radius: 6px !important; background: var(--wcss-white) !important; box-sizing: border-box !important; font-family: inherit !important; }
.wcss-form-group input:focus, .wcss-form-group select:focus, .wcss-form-group textarea:focus { outline: none !important; border-color: var(--wcss-primary) !important; }

/* ========================================
   CALENDAR STYLES
   ======================================== */

.wcss-datetime-section { margin: 25px 0 !important; }
.wcss-datetime-grid { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 25px !important; }
@media (max-width: 700px) { .wcss-datetime-grid { grid-template-columns: 1fr !important; } }

.wcss-date-section, .wcss-time-section { background: var(--wcss-bg-light) !important; border-radius: 12px !important; padding: 20px !important; }
.wcss-section-title { font-size: 14px !important; font-weight: 700 !important; color: var(--wcss-dark) !important; margin: 0 0 15px 0 !important; text-transform: uppercase !important; letter-spacing: 0.5px !important; }

/* Calendar */
#wcss-calendar { background: var(--wcss-white) !important; border-radius: 10px !important; overflow: hidden !important; box-shadow: 0 2px 10px rgba(0,0,0,0.05) !important; }
.wcss-cal-header { display: flex !important; justify-content: space-between !important; align-items: center !important; padding: 15px !important; background: var(--wcss-dark) !important; }
.wcss-cal-title { color: var(--wcss-white) !important; font-weight: 700 !important; font-size: 16px !important; }
.wcss-cal-prev, .wcss-cal-next { background: none !important; border: none !important; color: var(--wcss-white) !important; font-size: 24px !important; cursor: pointer !important; padding: 5px 12px !important; border-radius: 4px !important; transition: background 0.2s !important; }
.wcss-cal-prev:hover, .wcss-cal-next:hover { background: rgba(255,255,255,0.1) !important; }

.wcss-cal-days-header { display: grid !important; grid-template-columns: repeat(7, 1fr) !important; background: var(--wcss-bg-light) !important; }
.wcss-cal-day-name { padding: 10px 5px !important; text-align: center !important; font-size: 11px !important; font-weight: 600 !important; color: var(--wcss-text-light) !important; text-transform: uppercase !important; }

.wcss-cal-days { display: grid !important; grid-template-columns: repeat(7, 1fr) !important; gap: 2px !important; padding: 10px !important; }
.wcss-cal-day { aspect-ratio: 1 !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 14px !important; font-weight: 500 !important; border-radius: 8px !important; cursor: default !important; transition: all 0.2s !important; }
.wcss-cal-day.empty { background: transparent !important; }
.wcss-cal-day.past, .wcss-cal-day.too-far { color: #ccc !important; }
.wcss-cal-day.closed { color: #999 !important; background: #f5f5f5 !important; }
.wcss-cal-day.blocked { color: #999 !important; background: #fff0f0 !important; }
.wcss-cal-day.full { color: var(--wcss-white) !important; background: var(--wcss-primary) !important; opacity: 0.5 !important; }
.wcss-cal-day.available { color: var(--wcss-dark) !important; background: #e8f5e9 !important; cursor: pointer !important; }
.wcss-cal-day.available:hover { background: #c8e6c9 !important; transform: scale(1.1) !important; }
.wcss-cal-day.selected { background: var(--wcss-success) !important; color: var(--wcss-white) !important; transform: scale(1.1) !important; box-shadow: 0 2px 8px rgba(39,174,96,0.3) !important; }

.wcss-cal-legend { display: flex !important; justify-content: center !important; gap: 20px !important; padding: 12px !important; border-top: 1px solid var(--wcss-border) !important; flex-wrap: wrap !important; }
.wcss-legend-item { display: flex !important; align-items: center !important; gap: 6px !important; font-size: 11px !important; color: var(--wcss-text-light) !important; }
.wcss-legend-dot { width: 12px !important; height: 12px !important; border-radius: 3px !important; }
.wcss-legend-dot.available { background: #e8f5e9 !important; border: 1px solid #c8e6c9 !important; }
.wcss-legend-dot.full { background: var(--wcss-primary) !important; opacity: 0.5 !important; }
.wcss-legend-dot.closed { background: #f5f5f5 !important; border: 1px solid #ddd !important; }

/* ========================================
   TIME SLOTS
   ======================================== */

#wcss-time-slots { min-height: 200px !important; }
.wcss-select-date-first { text-align: center !important; color: var(--wcss-text-light) !important; padding: 40px 20px !important; font-size: 14px !important; }
.wcss-time-slots-grid { display: grid !important; grid-template-columns: repeat(3, 1fr) !important; gap: 10px !important; }
@media (max-width: 500px) { .wcss-time-slots-grid { grid-template-columns: repeat(2, 1fr) !important; } }

.wcss-time-slot { padding: 15px 10px !important; text-align: center !important; border-radius: 8px !important; cursor: default !important; transition: all 0.2s !important; border: 2px solid transparent !important; }
.wcss-time-slot.available { background: #e8f5e9 !important; cursor: pointer !important; border-color: #c8e6c9 !important; }
.wcss-time-slot.available:hover { background: #c8e6c9 !important; transform: translateY(-2px) !important; }
.wcss-time-slot.full { background: #f5f5f5 !important; opacity: 0.6 !important; }
.wcss-time-slot.selected { background: var(--wcss-success) !important; border-color: var(--wcss-success) !important; transform: translateY(-2px) !important; box-shadow: 0 4px 12px rgba(39,174,96,0.3) !important; }
.wcss-time-slot.selected .wcss-slot-time, .wcss-time-slot.selected .wcss-slot-spots { color: var(--wcss-white) !important; }

.wcss-slot-time { display: block !important; font-size: 16px !important; font-weight: 700 !important; color: var(--wcss-dark) !important; }
.wcss-slot-spots { display: block !important; font-size: 11px !important; color: var(--wcss-success) !important; margin-top: 3px !important; }
.wcss-slot-full { display: block !important; font-size: 11px !important; color: #999 !important; margin-top: 3px !important; }

/* Hidden inputs for date/time */
#preferred_date, #preferred_time { display: none !important; }

/* ========================================
   PRICE SUMMARY
   ======================================== */

.wcss-price-summary { background: var(--wcss-dark) !important; border-radius: 10px !important; padding: 20px !important; margin: 25px 0 !important; color: var(--wcss-white) !important; }
.wcss-price-summary h4 { font-size: 14px !important; font-weight: 600 !important; margin: 0 0 12px 0 !important; color: rgba(255,255,255,0.7) !important; text-transform: uppercase !important; }
.wcss-summary-items { margin-bottom: 12px !important; }
.wcss-summary-item { display: flex !important; justify-content: space-between !important; padding: 8px 0 !important; font-size: 14px !important; border-bottom: 1px solid rgba(255,255,255,0.1) !important; }
.wcss-summary-item:last-child { border-bottom: none !important; }
.wcss-summary-item-name { color: rgba(255,255,255,0.9) !important; }
.wcss-summary-item-price { font-weight: 600 !important; }
.wcss-summary-total { display: flex !important; justify-content: space-between !important; align-items: center !important; padding-top: 12px !important; border-top: 2px solid rgba(255,255,255,0.2) !important; margin-top: 8px !important; }
.wcss-summary-total span:first-child { font-size: 14px !important; font-weight: 600 !important; }
.wcss-total-price { font-size: 24px !important; font-weight: 800 !important; color: var(--wcss-primary) !important; }
.wcss-price-disclaimer { background: rgba(255,255,255,0.1) !important; border-radius: 6px !important; padding: 12px !important; margin-top: 15px !important; }
.wcss-price-disclaimer p { margin: 0 !important; font-size: 12px !important; color: rgba(255,255,255,0.8) !important; line-height: 1.5 !important; }

/* Navigation */
.wcss-form-navigation { display: flex !important; gap: 12px !important; justify-content: flex-end !important; padding-top: 20px !important; border-top: 1px solid var(--wcss-border) !important; margin-top: 25px !important; }
.wcss-form-navigation .wcss-button { width: auto !important; min-width: 120px !important; }
.wcss-prev-step { margin-right: auto !important; }

/* Success */
.wcss-form-success { text-align: center !important; padding: 60px 40px !important; }

/* Loading */
.wcss-submit-button.loading { position: relative !important; color: transparent !important; }
.wcss-submit-button.loading::after { content: '' !important; position: absolute !important; width: 18px !important; height: 18px !important; border: 2px solid rgba(255,255,255,0.3) !important; border-top-color: var(--wcss-white) !important; border-radius: 50% !important; animation: spin 0.8s linear infinite !important; top: 50% !important; left: 50% !important; margin: -9px 0 0 -9px !important; }
@keyframes spin { to { transform: rotate(360deg); } }

/* Errors */
.wcss-form-group.error input, .wcss-form-group.error select { border-color: var(--wcss-primary) !important; }
.wcss-error-message { font-size: 11px !important; color: var(--wcss-primary) !important; margin-top: 4px !important; }
