/**
 * Frontend Widget-Styles für Landlust-Termine
 * Basierend auf Öffungszeiten.html und Feiertage.html
 */

/* ==================== ÖFFNUNGSZEITEN COMPONENT ==================== */
.oeffnungszeiten-component {
    font-family: 'Roboto', sans-serif;
    color: #fff;
    margin: 0;
    padding: 0;
}

.oeffnungszeiten-component .main-container {
    max-width: 960px;
    margin: 0 auto;
    padding: 20px;
}

.oeffnungszeiten-component .content-box {
    padding: 32px 28px 28px 28px;
    border-radius: 16px;
    margin-bottom: 40px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.30);
}

/* ==================== ÜBERSCHRIFTEN ==================== */
.oeffnungszeiten-component .component-h1,
.oeffnungszeiten-component .component-h2 {
    color: #fff;
    font-weight: 700;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.30);
    margin-bottom: 18px;
    text-align: center;
    font-family: 'Roboto', sans-serif;
}

.oeffnungszeiten-component .component-h1 {
    font-size: 3em;
    margin-top: 12px;
}

.oeffnungszeiten-component .component-h2 {
    font-size: 3em;
    margin-top: 26px;
}

/* ==================== ÖFFNUNGSZEITEN GRID ==================== */
.oeffnungszeiten-component .oeffnungszeiten {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 14px;
    margin-top: 24px;
}

.oeffnungszeiten-component .day-box {
    background: rgba(255, 255, 255, 0.12);
    padding: 15px 18px;
    border-radius: 9px;
    text-align: center;
    font-size: 1.2em;
    letter-spacing: 0.5px;
    transition: background 0.2s;
}

.oeffnungszeiten-component .day-box strong {
    display: block;
    font-weight: 700;
    margin-bottom: 5px;
}

/* ==================== EVENTS & TERMINE ==================== */
.oeffnungszeiten-component .component-p {
    margin-bottom: 22px;
    text-align: center;
}

.oeffnungszeiten-component .dates {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(128px, 1fr));
    gap: 14px;
    margin-bottom: 8px;
}

.oeffnungszeiten-component .date-box {
    border: 2px solid #fff;
    padding: 13px 16px;
    border-radius: 8px;
    font-size: 1.2em;
    font-weight: 500;
    text-align: center;
    background: rgba(255, 255, 255, 0.09);
    color: #fff;
    user-select: none;
    pointer-events: none;
    cursor: default;
    margin-bottom: 0;
    transition: none;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.10);
}

/* Status-basierte Styles für Termine */
.oeffnungszeiten-component .date-box.ausgebucht {
    opacity: 0.5;
    background: rgba(255, 255, 255, 0.05);
    border-style: dashed;
}

/* ==================== RESPONSIVE DESIGN ==================== */

/* Mobile (max-width: 600px) */
@media (max-width: 600px) {
    .oeffnungszeiten-component .component-h1 {
        font-size: 1.7em;
    }
    
    .oeffnungszeiten-component .component-h2 {
        font-size: 1.25em;
    }
    
    .oeffnungszeiten-component .content-box {
        padding: 19px 8px 14px 8px;
    }
    
    .oeffnungszeiten-component .day-box {
        font-size: 0.94em;
        padding: 10px;
    }
    
    .oeffnungszeiten-component .date-box {
        font-size: 0.83em;
        padding: 9px 8px;
    }
    
    .oeffnungszeiten-component .main-container {
        padding: 10px;
    }
}

/* Tablet (601px - 1024px) */
@media (min-width: 601px) and (max-width: 1024px) {
    .oeffnungszeiten-component .component-h1,
    .oeffnungszeiten-component .component-h2 {
        font-size: 2.2em;
    }
    
    .oeffnungszeiten-component .oeffnungszeiten {
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    }
    
    .oeffnungszeiten-component .dates {
        grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    }
}

/* Desktop (1025px+) */
@media (min-width: 1025px) {
    .oeffnungszeiten-component .day-box:hover {
        background: rgba(255, 255, 255, 0.18);
    }
}

/* ==================== ACCESSIBILITY ==================== */

/* Screen Reader Text */
.oeffnungszeiten-component .screen-reader-text {
    clip: rect(1px, 1px, 1px, 1px);
    position: absolute !important;
    height: 1px;
    width: 1px;
    overflow: hidden;
    word-wrap: normal !important;
}

/* Focus Styles */
.oeffnungszeiten-component .day-box:focus,
.oeffnungszeiten-component .date-box:focus {
    outline: 2px solid #fff;
    outline-offset: 2px;
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
    .oeffnungszeiten-component .day-box,
    .oeffnungszeiten-component .date-box {
        border: 2px solid currentColor;
    }
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
    .oeffnungszeiten-component .day-box,
    .oeffnungszeiten-component .date-box {
        transition: none;
    }
}

/* ==================== PRINT STYLES ==================== */
@media print {
    .oeffnungszeiten-component .content-box {
        box-shadow: none;
        border: 1px solid #000;
    }
    
    .oeffnungszeiten-component .component-h1,
    .oeffnungszeiten-component .component-h2 {
        color: #000;
        text-shadow: none;
    }
    
    .oeffnungszeiten-component .day-box,
    .oeffnungszeiten-component .date-box {
        border-color: #000;
        color: #000;
        background: transparent;
    }
}

/* ==================== DARK MODE SUPPORT ==================== */
@media (prefers-color-scheme: dark) {
    /* Dark Mode ist bereits Standard-Design */
    /* Diese Regel ist für zukünftige Erweiterungen */
}

/* ==================== ELEMENTOR EDITOR FIXES ==================== */

/* Im Elementor Editor bessere Sichtbarkeit */
.elementor-editor-active .oeffnungszeiten-component .content-box {
    min-height: 200px;
}

.elementor-editor-active .oeffnungszeiten-component {
    background: rgba(0, 0, 0, 0.1);
}

/* Widget-Platzhalter im Editor */
.elementor-widget-landlust-oeffnungszeiten.elementor-element-edit-mode .oeffnungszeiten-component,
.elementor-widget-landlust-events.elementor-element-edit-mode .oeffnungszeiten-component {
    border: 2px dashed rgba(255, 255, 255, 0.3);
}

