/* Globale Stile */
body { font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; background: #f4f7f6; color: #333; margin: 0; padding: 20px; }
.container { max-width: 1200px; margin: auto; }
h1 { color: #2c3e50; }

/* Karten und Container */
.card { background: white; padding: 20px; border-radius: 8px; margin-bottom: 20px; box-shadow: 0 2px 5px rgba(0,0,0,0.1); }

/* Tabellen allgemein */
table { width: 100%; border-collapse: collapse; background: white; }
th, td { border: 1px solid #e0e0e0; padding: 12px; text-align: left; }
th { background: #f8f9fa; font-weight: 600; }

/* Belegungsplan Spezifisch */
.grid-container { overflow-x: auto; border: 1px solid #ddd; border-radius: 8px; }
.day-cell { min-width: 35px; height: 40px; text-align: center; cursor: pointer; transition: all 0.1s; font-size: 0.8em; }
.day-cell:hover { filter: brightness(90%); transform: scale(1.05); z-index: 5; position: relative; }
.box-label { background: #eee; font-weight: bold; position: sticky; left: 0; min-width: 150px; z-index: 10; }
.weekend { background: #f1f1f1; }
.today-highlight { border: 2px solid #007bff !important; position: relative; }

/* Status Farben */
.occupied { background: #3498db; color: white; }
.reserved { background: #f1c40f; color: #333; }
.arrival-day { background: #2ecc71; color: white; }
.departure-day { background: #e74c3c; color: white; }

/* Formulare */
.form-row { display: flex; gap: 15px; align-items: flex-end; flex-wrap: wrap; margin-bottom: 15px; }
.form-group { display: flex; flex-direction: column; }
input, select { padding: 10px; border: 1px solid #ccc; border-radius: 4px; font-size: 14px; }
.btn { padding: 10px 20px; border-radius: 4px; border: none; cursor: pointer; font-weight: bold; text-decoration: none; display: inline-block; }
.btn-primary { background: #3498db; color: white; }
.btn-secondary { background: #95a5a6; color: white; }

/* Warnungen und Alerts */
.alert {
    padding: 15px;
    margin-bottom: 20px;
    border: 1px solid transparent;
    border-radius: 4px;
}
.alert-warning {
    color: #856404;
    background-color: #fff3cd;
    border-color: #ffeeba;
}
.alert-danger {
    color: #721c24;
    background-color: #f8d7da;
    border-color: #f5c6cb;
}
.alert-success {
    color: #155724;
    background-color: #d4edda;
    border-color: #c3e6cb;
}

/* Wetter & Boden Status */
.weather-bar { display: flex; gap: 10px; margin-bottom: 20px; padding: 10px; background: #eef2f3; border-radius: 8px; }
.status-wet { background: #3498db; color: white; border: 2px solid #2980b9; }
.status-moist { background: #1abc9c; color: white; border: 2px solid #16a085; }
.status-dry { background: #f1c40f; color: #333; border: 2px solid #f39c12; }
.weather-btn { cursor: pointer; padding: 8px 15px; border-radius: 20px; font-weight: bold; opacity: 0.6; }
.weather-btn.active { opacity: 1; box-shadow: 0 0 10px rgba(0,0,0,0.2); }


.place-badge {
    background: #34495e;
    color: white;
    padding: 3px 8px;
    border-radius: 4px;
    font-size: 0.85em;
}
table th { background: #f8f9fa; color: #333; }

.btn-primary { background-color: #007bff; color: white; border: none; border-radius: 5px; cursor: pointer; }
.btn-secondary { background-color: #6c757d; color: white; text-decoration: none; padding: 10px 20px; border-radius: 5px; }
.alert-success { background-color: #d4edda; color: #155724; border: 1px solid #c3e6cb; padding: 15px; border-radius: 5px; margin-bottom: 20px; }

/* Basis-Design für die Labels */
.koppel-label {
    background: rgba(255, 255, 255, 0.95); /* Weniger transparent für bessere Lesbarkeit */
    border: 2px solid #333;
    border-radius: 6px;
    padding: 5px 8px;
    font-size: 14px; /* Größere Standardschrift */
    text-align: center;
    pointer-events: none;
    box-shadow: 0 2px 4px rgba(0,0,0,0.3);
    color: #000;
    min-width: 80px;
}

/* Speziell für Mobilgeräte */
@media (max-width: 768px) {
    .koppel-label {
        font-size: 16px; /* Noch größere Schrift auf dem Handy */
        padding: 8px 12px;
    }
    .horse-details {
        font-size: 14px !important; /* Pferdenamen deutlich lesbar */
        font-weight: bold;
    }
}

.label-occupied { border-color: #e74c3c; background: #fff0f0; }
.label-free { border-color: #27ae60; background: #f0fff4; opacity: 0.9; }

.horse-details { 
    display: none; 
    margin-top: 5px; 
    border-top: 2px solid #ddd; 
    padding-top: 4px; 
    color: #d35400; /* Kontrastfarbe für Pferde */
}

