/* Stadthofsaal Calendar - Frontend Styles */

/* CSS Custom Properties for easy theming with Breakdance */
:root {
    --shc-primary-color: #2c5282;
    --shc-primary-hover: #2b4c7e;
    --shc-blocked-bg: #e57373;
    --shc-blocked-text: #ffffff;
    --shc-free-bg: #16a34a;
    --shc-free-text: #ffffff;
    --shc-free-hover: #dcfce7;
    --shc-selected-bg: #16a34a;
    --shc-selected-text: #ffffff;
    --shc-today-border: #000000;
    --shc-border-color: #e2e8f0;
    --shc-text-color: #2d3748;
    --shc-text-muted: #718096;
    --shc-bg-light: #f7fafc;
    --shc-shadow: none;
    --shc-radius: 0;
    --shc-transition: all 0.2s ease;
}

/* Main Wrapper */
.shc-wrapper {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    color: var(--shc-text-color);
    margin: 0 auto;
}

/* Error Messages */
.shc-error {
    background: #fed7d7;
    border: 1px solid #fc8181;
    color: #c53030;
    padding: 12px 16px;
    border-radius: var(--shc-radius);
    margin-bottom: 20px;
}

/* Steps Container */
.shc-step {
    display: none;
    animation: shcFadeIn 0.3s ease;
}

.shc-step.active {
    display: block;
}

@keyframes shcFadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Step Titles */
.shc-step-title {
    font-size: 1.5rem;
    font-weight: 600;
    margin: 0 0 20px 0;
    color: var(--shc-text-color);
}

/* Step 1 Two-Column Layout */
.shc-step1-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
    align-items: stretch;
}

.shc-step1-left {
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.shc-step1-right {
    display: flex;
    flex-direction: column;
}

/* Calendar Container */
.shc-calendar-container {
    background: #ffffff;
    border: 1px solid var(--shc-border-color);
    border-radius: var(--shc-radius);
    box-shadow: var(--shc-shadow);
    padding: 20px;
    flex: 1;
}

.shc-calendar {
    width: 100%;
}

/* Sidebar Card */
.shc-sidebar-card {
    background: #ffffff;
    border: 1px solid var(--shc-border-color);
    border-radius: var(--shc-radius);
    box-shadow: var(--shc-shadow);
    padding: 24px;
    flex: 1;
}

/* Legend */
.shc-legend {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--shc-border-color);
    margin-bottom: 20px;
}

.shc-legend-item {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 0.9375rem;
    color: var(--shc-text-color);
}

.shc-legend-color {
    width: 24px;
    height: 24px;
    border-radius: 4px;
    flex-shrink: 0;
}

.shc-legend-blocked .shc-legend-color {
    background: #ffcdd2;
    border: 2px solid var(--shc-blocked-bg);
}

.shc-legend-free .shc-legend-color {
    background: #dcfce7;
    border: 2px solid var(--shc-free-bg);
}

/* Contact Section */
.shc-contact {
    font-size: 0.9375rem;
    line-height: 1.6;
}

.shc-contact-title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--shc-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin: 0 0 12px 0;
}

.shc-contact-name {
    font-size: 1.0625rem;
    margin: 0 0 4px 0;
}

.shc-contact p {
    margin: 0 0 2px 0;
}

.shc-contact-details {
    margin-top: 16px;
}

.shc-contact-details p {
    margin: 0 0 6px 0;
}

.shc-contact a {
    color: var(--shc-primary-color);
    text-decoration: none;
    transition: var(--shc-transition);
}

.shc-contact a:hover {
    text-decoration: underline;
}

/* Vanilla Calendar Overrides */
.shc-calendar .vanilla-calendar {
    width: 100%;
    max-width: 100%;
    font-family: inherit;
    box-shadow: none;
    border: none;
    background: transparent;
}

.shc-calendar .vanilla-calendar-header {
    padding: 0 0 16px 0;
    border-bottom: 1px solid var(--shc-border-color);
    margin-bottom: 16px;
}

.shc-calendar .vanilla-calendar-header__content {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--shc-text-color);
}

.shc-calendar .vanilla-calendar-arrow {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #f1f1f1;
    border: 1px solid #e0e0e0;
    transition: var(--shc-transition);
    cursor: pointer;
}

.shc-calendar .vanilla-calendar-arrow:hover {
    background: #D08A00;
    border-color: #D08A00;
}

.shc-calendar .vanilla-calendar-arrow:hover svg {
    fill: #ffffff;
}

.shc-calendar .vanilla-calendar-arrow svg {
    fill: #333333;
    transition: var(--shc-transition);
}

.shc-calendar .vanilla-calendar-week {
    margin-bottom: 8px;
}

.shc-calendar .vanilla-calendar-week__day {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--shc-text-muted);
    text-transform: uppercase;
}

.shc-calendar .vanilla-calendar-day {
    font-size: 0.9375rem;
    width: 100%;
    aspect-ratio: 1;
    border-radius: 50%;
    transition: var(--shc-transition);
}

.shc-calendar .vanilla-calendar-day__btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    font-weight: 500;
    transition: var(--shc-transition);
}

/* Free/Available dates - Green background */
.shc-calendar .vanilla-calendar-day__btn:not([disabled]) {
    background: #dcfce7;
    color: #166534;
}

/* Free dates (clickable) - Darker green on hover */
.shc-calendar .vanilla-calendar-day__btn:not([disabled]):hover {
    background: var(--shc-free-bg);
    color: var(--shc-free-text);
    cursor: pointer;
}

/* Today's date */
.shc-calendar .vanilla-calendar-day__btn_today {
    border: 2px solid var(--shc-today-border) !important;
    background: transparent !important;
}

.shc-calendar .vanilla-calendar-day__btn_today:hover {
    background: var(--shc-free-hover) !important;
}

/* Selected date - Green */
.shc-calendar .vanilla-calendar-day__btn_selected {
    background: var(--shc-selected-bg) !important;
    color: var(--shc-selected-text) !important;
}

/* Disabled/Past dates - Light red/blocked appearance */
.shc-calendar .vanilla-calendar-day__btn[disabled],
.shc-calendar .vanilla-calendar-day__btn_disabled {
    background: #fecaca !important;
    color: #991b1b !important;
    cursor: not-allowed;
    opacity: 0.7;
}

/* Blocked dates (from CSV) - Red */
.shc-calendar .vanilla-calendar-day.shc-blocked .vanilla-calendar-day__btn,
.shc-calendar .vanilla-calendar-day.shc-blocked .vanilla-calendar-day__btn[disabled],
.shc-calendar .vanilla-calendar-day__btn.shc-blocked-btn,
.shc-calendar .shc-blocked-btn {
    background: var(--shc-blocked-bg) !important;
    color: var(--shc-blocked-text) !important;
    cursor: not-allowed !important;
    opacity: 1 !important;
    pointer-events: none;
}

/* Ensure blocked dates don't show green hover */
.shc-calendar .vanilla-calendar-day.shc-blocked .vanilla-calendar-day__btn:hover,
.shc-calendar .shc-blocked-btn:hover {
    background: var(--shc-blocked-bg) !important;
    color: var(--shc-blocked-text) !important;
}

/* Past dates - more muted appearance */
.shc-calendar .vanilla-calendar-day__btn_disabled:not(.shc-blocked .vanilla-calendar-day__btn) {
    background: #fee2e2 !important;
    color: #b91c1c !important;
    opacity: 0.6;
}

/* Step 2: Form View */
.shc-selected-date-display {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    background: #D08A00;
    border: 1px solid #D08A00;
    border-radius: var(--shc-radius);
    padding: 16px 20px;
    margin-bottom: 24px;
}

.shc-selected-date-label {
    font-weight: 500;
    color: #ffffff;
}

.shc-selected-date-value {
    font-size: 1.125rem;
    font-weight: 600;
    color: #ffffff;
}

.shc-back-button {
    margin-left: auto;
    background: rgba(255, 255, 255, 0.2);
    border: 1px solid rgba(255, 255, 255, 0.5);
    color: #ffffff;
    padding: 8px 16px;
    border-radius: var(--shc-radius);
    font-size: 0.875rem;
    cursor: pointer;
    transition: var(--shc-transition);
}

.shc-back-button:hover {
    background: rgba(255, 255, 255, 0.3);
    color: #ffffff;
    border-color: rgba(255, 255, 255, 0.7);
}

/* Form Container - Card style wrapper, Gravity Forms styles preserved */
.shc-form-container {
    background: #ffffff;
    border: 1px solid var(--shc-border-color);
    border-radius: var(--shc-radius);
    padding: 24px;
    box-shadow: var(--shc-shadow);
}

/* Responsive */
@media (max-width: 768px) {
    .shc-step1-layout {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .shc-step1-right {
        position: static;
    }

    .shc-sidebar-card {
        padding: 20px;
    }

    .shc-legend {
        flex-direction: row;
        flex-wrap: wrap;
        gap: 16px;
    }

    .shc-calendar-container {
        padding: 16px;
    }

    .shc-calendar .vanilla-calendar-day__btn {
        width: 32px;
        height: 32px;
        font-size: 0.8125rem;
    }

    .shc-selected-date-display {
        flex-direction: column;
        align-items: flex-start;
    }

    .shc-back-button {
        margin-left: 0;
        margin-top: 8px;
    }
}

/* Thank You Message */
.shc-thank-you {
    background: #ffffff;
    border: 1px solid var(--shc-border-color);
    padding: 40px 30px;
    margin-bottom: 30px;
    text-align: center;
}

.shc-thank-you-icon {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: #16a34a;
    color: #ffffff;
    font-size: 36px;
    line-height: 60px;
    margin: 0 auto 20px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.shc-thank-you-title {
    font-size: 1.75rem;
    font-weight: 600;
    color: var(--shc-text-color);
    margin: 0 0 12px 0;
}

.shc-thank-you-message {
    font-size: 1rem;
    color: var(--shc-text-muted);
    margin: 0;
    line-height: 1.6;
}
