/* ============================================================
   Schulkalender – Stylesheet
   ============================================================ */

:root {
    --sk-primary:    #1A3A5C;
    --sk-accent:     #2E6DA4;
    --sk-green:      #43a047;
    --sk-grey:       #9E9E9E;
    --sk-red:        #E53935;
    --sk-bg:         #ffffff;
    --sk-bg-subtle:  #f5f7fa;
    --sk-border:     #e0e4ea;
    --sk-text:       #1a1a2e;
    --sk-text-muted: #6b7280;
    --sk-radius:     8px;
    --sk-shadow:     0 2px 12px rgba(0,0,0,.08);
    --sk-font:       system-ui, -apple-system, "Segoe UI", sans-serif;
}

.sk-kalender-wrap * { box-sizing: border-box; }
.sk-kalender-wrap {
    font-family: var(--sk-font);
    color: var(--sk-text);
    background: var(--sk-bg);
    border-radius: var(--sk-radius);
    box-shadow: var(--sk-shadow);
    padding: 20px;
    max-width: 1100px;
    margin: 0 auto;
}

/* ---- Toolbar ---- */
.sk-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 16px;
}
.sk-toolbar-left, .sk-toolbar-right { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.sk-current-label { font-weight: 700; font-size: 1.1rem; min-width: 180px; text-align: center; }

/* ---- Buttons ---- */
.sk-btn {
    display: inline-flex; align-items: center; justify-content: center;
    padding: 7px 14px; border-radius: 6px; border: 1px solid var(--sk-border);
    background: var(--sk-bg); color: var(--sk-text); font-size: .875rem;
    cursor: pointer; transition: background .15s, border-color .15s;
    font-family: inherit; font-weight: 500;
}
.sk-btn:hover { background: var(--sk-bg-subtle); border-color: var(--sk-accent); }
.sk-btn.active { background: var(--sk-primary); color: #fff; border-color: var(--sk-primary); }
.sk-btn-primary { background: var(--sk-accent); color: #fff; border-color: var(--sk-accent); }
.sk-btn-primary:hover { background: var(--sk-primary); border-color: var(--sk-primary); }

/* ---- Filter Bar ---- */
.sk-filter-bar {
    display: flex; align-items: center; flex-wrap: wrap; gap: 10px;
    margin-bottom: 16px; padding: 12px; background: var(--sk-bg-subtle);
    border-radius: var(--sk-radius); border: 1px solid var(--sk-border);
}
.sk-filter {
    padding: 6px 10px; border-radius: 6px; border: 1px solid var(--sk-border);
    background: #fff; font-size: .875rem; font-family: inherit;
    min-width: 150px;
}
.sk-filter:focus { outline: 2px solid var(--sk-accent); outline-offset: 1px; }
.sk-legend { display: flex; align-items: center; gap: 8px; font-size: .8rem; color: var(--sk-text-muted); margin-left: auto; }
.sk-legend-dot { width: 12px; height: 12px; border-radius: 50%; display: inline-block; }

/* ---- Loading ---- */
.sk-loading {
    text-align: center; padding: 60px 20px; color: var(--sk-text-muted);
    font-size: .95rem;
}

/* ============================================================
   MONATSANSICHT
   ============================================================ */
.sk-month-grid { width: 100%; border-collapse: collapse; }
.sk-month-grid th {
    text-align: center; font-size: .8rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: .05em; color: var(--sk-text-muted);
    padding: 8px 4px; border-bottom: 2px solid var(--sk-border);
}
.sk-month-grid td {
    vertical-align: top; border: 1px solid var(--sk-border); min-height: 90px;
    padding: 6px; font-size: .8rem; width: 14.285%;
}
.sk-month-grid td.sk-other-month { background: var(--sk-bg-subtle); opacity: .6; }
.sk-day-number {
    font-size: .75rem; font-weight: 600; color: var(--sk-text-muted); margin-bottom: 4px;
}
.sk-day-number.sk-today {
    background: var(--sk-accent); color: #fff; border-radius: 50%;
    width: 22px; height: 22px; display: flex; align-items: center; justify-content: center;
}

/* ---- Events im Monat ---- */
.sk-event {
    display: block; padding: 2px 6px; border-radius: 4px; margin-bottom: 2px;
    font-size: .73rem; font-weight: 500; color: #fff; cursor: pointer;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    transition: opacity .15s, transform .1s;
}
.sk-event:hover { opacity: .85; transform: translateY(-1px); }
.sk-event.sk-status-pending  { background: var(--sk-grey); }
.sk-event.sk-status-rejected { background: var(--sk-red); }

/* ============================================================
   WOCHENANSICHT
   ============================================================ */
.sk-week-grid { display: grid; grid-template-columns: 50px repeat(7, 1fr); border-collapse: collapse; }
.sk-week-header { display: contents; }
.sk-week-header > div {
    text-align: center; font-size: .8rem; font-weight: 600; color: var(--sk-text-muted);
    padding: 8px 4px; border-bottom: 2px solid var(--sk-border); border-left: 1px solid var(--sk-border);
}
.sk-week-header > div:first-child { border-left: none; }
.sk-week-col {
    border-left: 1px solid var(--sk-border); min-height: 80px; padding: 4px;
    border-bottom: 1px solid var(--sk-border);
}
.sk-week-col:first-child { border-left: none; }
.sk-week-time { font-size: .7rem; color: var(--sk-text-muted); padding: 8px 4px; border-bottom: 1px solid var(--sk-border); }
.sk-week-day-num.sk-today {
    background: var(--sk-accent); color: #fff; border-radius: 50%;
    width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; margin: 0 auto 2px;
}

/* ============================================================
   LISTENANSICHT
   ============================================================ */
.sk-list { list-style: none; margin: 0; padding: 0; }
.sk-list-item {
    display: flex; align-items: flex-start; gap: 14px;
    padding: 14px 16px; border-bottom: 1px solid var(--sk-border);
    cursor: pointer; transition: background .1s;
}
.sk-list-item:hover { background: var(--sk-bg-subtle); }
.sk-list-color-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; margin-top: 5px; }
.sk-list-date { font-size: .8rem; color: var(--sk-text-muted); min-width: 120px; flex-shrink: 0; }
.sk-list-title { font-weight: 600; font-size: .9rem; }
.sk-list-meta { font-size: .78rem; color: var(--sk-text-muted); margin-top: 2px; }
.sk-list-status {
    font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
    padding: 2px 8px; border-radius: 20px; margin-left: auto; flex-shrink: 0; align-self: center;
}
.sk-list-status.pending  { background: #f3f4f6; color: #6b7280; }
.sk-list-status.publish  { background: #dcfce7; color: #166534; }
.sk-list-status.rejected { background: #fee2e2; color: #991b1b; }
.sk-list-empty { text-align: center; padding: 40px; color: var(--sk-text-muted); }

/* ============================================================
   MODAL
   ============================================================ */
.sk-modal {
    position: fixed; inset: 0; z-index: 999999;
    display: flex; align-items: center; justify-content: center;
}
.sk-modal-overlay {
    position: absolute; inset: 0; background: rgba(0,0,0,.5);
    backdrop-filter: blur(2px);
}
.sk-modal-box {
    position: relative; background: #fff; border-radius: 12px;
    box-shadow: 0 20px 60px rgba(0,0,0,.2); padding: 28px; max-width: 520px;
    width: 90%; max-height: 85vh; overflow-y: auto; z-index: 1;
    animation: sk-modal-in .2s ease;
}
@keyframes sk-modal-in { from { opacity:0; transform: scale(.95) translateY(10px); } to { opacity:1; transform: none; } }
.sk-modal-close {
    position: absolute; top: 14px; right: 14px; background: none;
    border: none; font-size: 1.4rem; cursor: pointer; color: var(--sk-text-muted);
    line-height: 1; padding: 4px 8px; border-radius: 4px;
}
.sk-modal-close:hover { background: var(--sk-bg-subtle); }
.sk-modal-title { margin: 0 0 16px; font-size: 1.15rem; color: var(--sk-primary); padding-right: 30px; }
.sk-modal-body { font-size: .875rem; }
.sk-modal-body p { margin: 6px 0; }
.sk-modal-body strong { color: var(--sk-text); }
.sk-modal-body .sk-detail-row { display: flex; gap: 8px; margin-bottom: 6px; }
.sk-modal-body .sk-detail-label { color: var(--sk-text-muted); min-width: 90px; }
.sk-modal-actions { margin-top: 20px; display: flex; gap: 10px; flex-wrap: wrap; }
.sk-modal-actions .sk-btn { flex: 1; justify-content: center; }
.sk-reject-form { margin-top: 10px; display: none; }
.sk-reject-form textarea { width: 100%; padding: 8px; border-radius: 6px; border: 1px solid var(--sk-border); font-family: inherit; font-size: .875rem; resize: vertical; }
.sk-reject-form .sk-btn { margin-top: 6px; }

/* ============================================================
   ANTRAGSFORMULAR
   ============================================================ */
.sk-antrag-form { display: flex; flex-direction: column; gap: 14px; }
.sk-form-row { display: flex; flex-direction: column; gap: 5px; }
.sk-form-row label { font-size: .85rem; font-weight: 600; color: var(--sk-primary); }
.sk-form-row input,
.sk-form-row select,
.sk-form-row textarea {
    padding: 9px 12px; border-radius: 6px; border: 1px solid var(--sk-border);
    font-family: inherit; font-size: .9rem; transition: border-color .15s;
    background: #fff;
}
.sk-form-row input:focus,
.sk-form-row select:focus,
.sk-form-row textarea:focus {
    outline: none; border-color: var(--sk-accent); box-shadow: 0 0 0 3px rgba(46,109,164,.12);
}
.sk-form-row-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.sk-form-direkt { background: #fffbeb; border: 1px solid #fde68a; border-radius: 6px; padding: 10px 14px; }
.sk-form-direkt label { font-size: .875rem; display: flex; align-items: center; gap: 8px; cursor: pointer; font-weight: 400; color: var(--sk-text); }
.sk-form-actions { display: flex; align-items: center; gap: 14px; }
.sk-form-msg { font-size: .85rem; color: var(--sk-green); }
.sk-form-msg.error { color: var(--sk-red); }
.sk-req { color: var(--sk-red); }
.sk-form-hint { font-size: .78rem; color: var(--sk-text-muted); font-weight: 400; margin-left: 4px; }
.sk-role-checkboxes {
    display: flex; flex-wrap: wrap; gap: 8px;
    background: var(--sk-bg-subtle); border: 1px solid var(--sk-border);
    border-radius: 6px; padding: 10px 14px;
}
.sk-role-label {
    display: flex; align-items: center; gap: 6px;
    font-size: .85rem; font-weight: 400; color: var(--sk-text);
    cursor: pointer; padding: 4px 10px; border-radius: 20px;
    border: 1px solid var(--sk-border); background: #fff;
    transition: background .15s, border-color .15s;
}
.sk-role-label:has(input:checked) {
    background: #dbeafe; border-color: var(--sk-accent); color: var(--sk-primary);
}
.sk-role-label input[type="checkbox"] { margin: 0; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 700px) {
    .sk-kalender-wrap { padding: 12px; }
    .sk-toolbar { flex-direction: column; align-items: stretch; }
    .sk-toolbar-left, .sk-toolbar-right { justify-content: center; }
    .sk-form-row-2col { grid-template-columns: 1fr; }
    .sk-month-grid td { min-height: 60px; padding: 3px; }
    .sk-event { font-size: .65rem; }
}

/* ---- Admin-Anpassungen ---- */
.sk-meta-table th { padding: 10px 14px 10px 0; font-weight: 600; width: 140px; }
.sk-meta-table td { padding: 6px 0; }

/* ---- Notices ---- */
.sk-notice { padding: 12px 16px; background: var(--sk-bg-subtle); border-left: 4px solid var(--sk-accent); border-radius: 0 6px 6px 0; font-size: .9rem; }
