/*
 * Offenstall-Dienstplan-App
 * Copyright (c) 2026 Bernhard Rauleder. Alle Rechte vorbehalten.
 *
 * Diese CSS-Datei definiert das gemeinsame Erscheinungsbild der App:
 * Layout, Karten, Navigation, Formulare, Kalenderdarstellung und Druckansichten.
 */

:root{--bg:#f4f6fb;--card:#ffffff;--text:#111827;--muted:#6b7280;--line:#e5e7eb;--brand:#2563eb;--danger:#dc2626;--ok:#16a34a;--warn:#f59e0b}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font:15px/1.45 system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}.brand a{font-weight:800;color:var(--text);text-decoration:none}.topbar nav{display:flex;gap:14px;flex-wrap:wrap}.topbar nav a{color:#374151;text-decoration:none;font-weight:600}.topbar nav a:hover{color:var(--brand)}.container{max-width:1380px;margin:0 auto;padding:22px}.footer{text-align:center;color:var(--muted);padding:24px}.card{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:0 8px 24px rgba(15,23,42,.06);padding:22px;margin-bottom:18px}.card.narrow{max-width:460px;margin:50px auto}.card.wide{min-width:0}.card.side{height:max-content}.grid{display:grid;gap:18px}.grid.two{grid-template-columns:minmax(0,2fr) minmax(320px,1fr)}h1,h2,h3{margin:0 0 12px}p{margin:0 0 12px}.muted{color:var(--muted)}.small{font-size:13px}.form{display:grid;gap:12px}.form.compact{gap:10px}.form label{display:grid;gap:5px;font-weight:650}.form input,.form select,.form textarea,.copy,.inline input,.userrow input{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;background:#fff;font:inherit}.form .check{display:flex;grid-template-columns:none;align-items:center;gap:10px;font-weight:500}.form .check input{width:auto}.btn{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:11px;padding:10px 14px;background:var(--brand);color:#fff;text-decoration:none;font-weight:700;cursor:pointer}.btn:hover{filter:brightness(.95)}.btn.ghost{background:#eef2ff;color:#1f2937}.btn.danger{background:var(--danger)}.btn.small{padding:6px 10px;border-radius:9px;font-size:13px}.flash{padding:12px 14px;border-radius:12px;margin-bottom:16px;background:#eff6ff;border:1px solid #bfdbfe}.flash.success{background:#ecfdf5;border-color:#bbf7d0}.flash.error{background:#fef2f2;border-color:#fecaca}.flash.warning{background:#fffbeb;border-color:#fde68a}.split{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.legend{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.legend span{display:inline-flex;align-items:center;gap:6px;background:#f9fafb;border:1px solid var(--line);border-radius:999px;padding:5px 9px}.legend i,.dot{width:11px;height:11px;border-radius:50%;display:inline-block}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;border-bottom:1px solid var(--line);padding:9px 8px}.table th{font-size:13px;color:var(--muted);font-weight:800}.inline{display:flex;gap:8px;align-items:end;flex-wrap:wrap}.mt{margin-top:12px}.userrow{display:grid;grid-template-columns:1.1fr 1.4fr 50px 140px 140px auto;gap:8px;align-items:center;margin-bottom:8px}.fc .fc-button{border-radius:10px!important}.fc .fc-toolbar-title{font-size:1.4rem!important}.fc-event{border-radius:8px!important;padding:2px 4px}.fc-bg-event{opacity:.45!important}@media(max-width:900px){.grid.two{grid-template-columns:1fr}.topbar{align-items:flex-start;gap:10px;flex-direction:column}.split{flex-direction:column}.legend{justify-content:flex-start}.userrow{grid-template-columns:1fr}.container{padding:14px}}
.draft-filter{margin-bottom:10px}.mt{margin-top:12px}.fc-event[style*="rgb"]{font-weight:650}.fc-event-title{font-weight:700}.legend .muted{opacity:.75}.color-preview{display:inline-flex;align-items:center;gap:8px}.color-preview input[type=color]{width:52px;padding:3px;height:38px}
.inline select,.inline textarea{border:1px solid var(--line);border-radius:10px;padding:10px 12px;background:#fff;font:inherit}.tablewrap{overflow:auto}.table input[type=checkbox]{transform:scale(1.1)}code{background:#f3f4f6;border:1px solid var(--line);border-radius:6px;padding:1px 5px}.btn + .btn{margin-left:6px}
.user-admin-card{border:1px solid var(--line);border-radius:14px;padding:10px;margin-bottom:10px;background:#fbfdff}.delete-user-form{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:8px}.delete-user-form .check{display:flex;align-items:center;gap:7px;margin:0}.delete-user-form input[type=checkbox]{width:auto}.danger-zone{border-color:#fecaca;background:#fff7f7}

.alertcard { border: 2px solid #f59e0b; background: #fffbeb; }
.swap-list { display: grid; gap: 12px; margin-top: 12px; }
.swap-card { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 14px; border: 1px solid #f3d18a; border-radius: 16px; background: #fff; }
.swap-card .inline { flex-wrap: nowrap; }
@media (max-width: 760px) { .swap-card { align-items: stretch; flex-direction: column; } .swap-card .inline { justify-content: flex-start; } }

/* v1.7: übersichtlichere Benutzer-/Parteiverwaltung */
.users-layout{display:grid;grid-template-columns:minmax(280px,.85fr) minmax(520px,1.55fr);gap:22px;align-items:start}.user-list-panel{min-width:0}.party-card-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.party-color-dot{width:18px;height:18px;border-radius:50%;display:inline-block;box-shadow:0 0 0 3px #fff,0 0 0 4px var(--line);flex:0 0 auto}.party-title{display:grid;gap:1px;min-width:0}.party-title strong{font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.party-title span{font-size:13px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.party-service-count{margin-left:auto;background:#f3f4f6;border:1px solid var(--line);border-radius:999px;padding:4px 9px;color:var(--muted);font-size:13px;white-space:nowrap}.party-edit-form{display:grid;grid-template-columns:minmax(160px,1.1fr) minmax(210px,1.45fr) 78px 135px 135px auto;gap:10px;align-items:end}.party-edit-form label{display:grid;gap:4px;font-weight:650;font-size:13px;color:#374151}.party-edit-form input{width:100%;border:1px solid var(--line);border-radius:10px;padding:9px 10px;background:#fff;font:inherit}.party-edit-form input[type=color]{height:41px;padding:3px}.party-actions{display:flex;align-items:end}.user-admin-card{background:#fff;border-color:#dbe2ea;box-shadow:0 3px 14px rgba(15,23,42,.04)}@media(max-width:1100px){.users-layout{grid-template-columns:1fr}.party-edit-form{grid-template-columns:1fr 1fr}.party-actions{align-items:stretch}.party-actions .btn{width:100%}}@media(max-width:650px){.party-edit-form{grid-template-columns:1fr}.party-card-header{align-items:flex-start}.party-service-count{margin-left:0}.party-card-header{flex-wrap:wrap}}

/* v4.2: aufgeräumte Navigation und direktes Formularfeedback */
.topnav{display:flex;gap:14px;flex-wrap:wrap;align-items:center}.nav-dropdown{position:relative}.nav-dropdown summary{list-style:none;cursor:pointer;color:#374151;font-weight:700}.nav-dropdown summary::-webkit-details-marker{display:none}.nav-dropdown summary::after{content:" ▾";font-weight:700;color:var(--muted)}.nav-dropdown[open] summary{color:var(--brand)}.nav-menu{position:absolute;right:0;top:calc(100% + 10px);min-width:260px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 14px 34px rgba(15,23,42,.16);padding:8px;z-index:50;display:grid;gap:2px}.nav-menu a{display:block;padding:10px 12px;border-radius:10px;white-space:nowrap}.nav-menu a:hover{background:#f3f4f6}.inline-feedback{margin-bottom:12px;padding:10px 12px;border-radius:12px;font-weight:700;background:#ecfdf5;border:1px solid #bbf7d0;color:#166534}.inline-feedback.error{background:#fef2f2;border-color:#fecaca;color:#991b1b}@media(max-width:760px){.topnav{gap:10px}.nav-dropdown{width:100%}.nav-menu{position:static;min-width:0;margin-top:8px;box-shadow:none}.nav-menu a{white-space:normal}}

/* v4.7: Kalenderexport und Drag-&-Drop-Tauschanfragen */
.export-wrap{display:grid;gap:18px}.print-month{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 8px 24px rgba(15,23,42,.06);padding:18px;break-after:page}.print-month h2{margin-bottom:10px}.print-cal{width:100%;border-collapse:collapse;table-layout:fixed}.print-cal th{background:#f3f4f6;color:#374151;font-weight:800;border:1px solid #d1d5db;padding:7px;text-align:center}.print-cal td{height:96px;vertical-align:top;border:1px solid #d1d5db;padding:6px;background:#fff}.print-cal td.empty{background:#f9fafb}.print-cal td.weekend{background:#fff7ed}.print-cal td.school{background:#eff6ff}.dayno{font-weight:800;margin-bottom:4px}.svc{background:#fff;border:1px solid #e5e7eb;border-left:6px solid var(--brand);border-radius:8px;padding:3px 5px;margin:3px 0;font-size:12px}.holiday{margin-top:3px;background:#ffedd5;border-radius:6px;padding:2px 5px;color:#9a3412;font-size:11px;font-weight:700}.schooltxt{margin-top:3px;color:#1d4ed8;font-size:11px;font-weight:700}.year-grid{grid-template-columns:repeat(3,1fr)}.year-grid .print-month{break-after:auto;padding:10px;border-radius:12px}.year-grid .print-month h2{font-size:16px;margin-bottom:6px}.year-grid .print-cal th{font-size:10px;padding:3px}.year-grid .print-cal td{height:52px;padding:3px}.year-grid .svc{font-size:9px;padding:1px 3px;border-left-width:4px}.year-grid .holiday,.year-grid .schooltxt{display:none}.year-grid .dayno{font-size:11px}.fc-event[style*="245, 158, 11"], .fc-event[style*="#f59e0b"]{font-weight:800}
@media print{body{background:#fff;font-size:11px}.topbar,.footer,.print-controls{display:none!important}.container{max-width:none;padding:0}.print-month{box-shadow:none;border:0;border-radius:0;margin:0;page-break-after:always}.print-month.compact{page-break-after:auto}.print-cal th{padding:4px}.print-cal td{height:82px;padding:4px}.svc{font-size:10px}.year-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.year-grid .print-month{padding:0;page-break-after:auto}.year-grid .print-cal td{height:38px}.year-grid .svc{font-size:8px}.card{box-shadow:none}@page{size:A4 landscape;margin:10mm}}

/* v4.9: sauberere Jahresansicht, lesbarere Feiertage/Ferien und kompakter A4-Export */
.fc .fc-toolbar.fc-header-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px}.fc .fc-toolbar-chunk{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.fc .fc-toolbar-title{font-size:1.35rem!important;line-height:1.15;text-align:center;min-width:180px}.fc .fc-button{margin:0!important}.fc-multimonth{border-radius:12px;overflow:hidden}.fc-multimonth-title{font-weight:800}.fc-multimonth .fc-bg-event .fc-event-title,.fc-daygrid .fc-bg-event .fc-event-title{display:none!important}.fc-multimonth .fc-bg-event{opacity:.58!important}.fc-multimonth .fc-event{font-size:11px!important;line-height:1.05!important;min-height:auto!important}.fc-multimonth .fc-event-main{padding:1px 3px!important}.fc-multimonth .cal-holiday-label{display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:10px;letter-spacing:.02em}.fc-daygridMonth-view .cal-holiday-label{font-weight:800}.fc-multimonth .fc-daygrid-event{white-space:nowrap}.fc .fc-daygrid-day-number{font-weight:650}.fc .fc-daygrid-day.fc-day-today{background:#fff7ed}.fc .fc-daygrid-bg-harness{pointer-events:none}.fc .fc-bg-event{border-radius:0!important}
@media(max-width:1050px){.fc .fc-toolbar.fc-header-toolbar{align-items:flex-start}.fc .fc-toolbar-chunk{justify-content:flex-start}.fc .fc-toolbar-title{text-align:left;min-width:0;width:100%}}

/* Export: Jahresübersicht passt im Druck auf eine A4-Querformatseite. */
.year-grid{grid-template-columns:repeat(4,1fr);gap:10px}.year-grid .print-month{break-after:auto;break-inside:avoid;padding:8px;border-radius:10px}.year-grid .print-month h2{font-size:14px;margin-bottom:5px}.year-grid .print-cal th{font-size:9px;padding:2px}.year-grid .print-cal td{height:40px;padding:2px}.year-grid .svc{font-size:8px;line-height:1.05;padding:1px 2px;border-left-width:3px;border-radius:5px}.year-grid .holiday{display:inline-flex;margin-top:1px;padding:1px 3px;border-radius:4px;font-size:8px;line-height:1;background:#f97316;color:#fff}.year-grid .schooltxt{display:none}.year-grid .dayno{font-size:10px;line-height:1;margin-bottom:1px}.print-cal td.school{background:#eef6ff}.print-cal td.weekend.school{background:#eef6ff}.print-cal .holiday{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
@media print{.year-grid{grid-template-columns:repeat(4,1fr)!important;gap:3mm!important}.year-grid .print-month{padding:0!important;border:0!important;box-shadow:none!important;break-after:auto!important;page-break-after:auto!important;break-inside:avoid!important}.year-grid .print-month h2{font-size:10px!important;line-height:1.05!important;margin:0 0 1.5mm!important;text-align:center}.year-grid .print-cal th{font-size:6.8px!important;padding:0.6mm!important}.year-grid .print-cal td{height:13mm!important;padding:0.6mm!important}.year-grid .dayno{font-size:7px!important;line-height:1!important;margin:0 0 0.5mm!important}.year-grid .svc{font-size:6.3px!important;line-height:1.05!important;padding:0.4mm 0.6mm!important;border-left-width:1.2mm!important;border-radius:1.5mm!important;margin:0.4mm 0!important}.year-grid .holiday{display:inline-flex!important;font-size:6px!important;line-height:1!important;padding:0.4mm 0.8mm!important;border-radius:1.2mm!important;background:#f97316!important;color:#fff!important}.year-grid .schooltxt{display:none!important}@page{size:A4 landscape;margin:6mm}}
.calendar-note-legend{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px;color:var(--muted);font-size:13px}.calendar-note-legend span{display:inline-flex;align-items:center;gap:6px}.calendar-note-legend i{width:14px;height:14px;border-radius:4px;display:inline-block;border:1px solid var(--line)}.legend-holiday{background:#f97316}.legend-school{background:#dbeafe}.legend-absence{background:#fecaca}

/* v5.0: PWA-Installation und Push-Einstellungen */
.pwa-card{border-color:#dbeafe;background:linear-gradient(180deg,#ffffff,#f8fbff)}
.pwa-actions{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0}
.notify-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
.notify-grid h3{margin:0 0 8px;font-size:15px;color:#374151}
.push-ok{color:#166534!important}.push-error{color:#991b1b!important}
@media(max-width:760px){.notify-grid{grid-template-columns:1fr}.pwa-actions .btn{width:100%}}
