/* =========================================================================
   Admin-Panel (Prototyp/Mock) – mobile-first
   Nutzt die Design-Tokens aus styles.css
   ========================================================================= */
.admin-body { background: var(--surface); min-height: 100svh; }

/* Topbar */
.adm-top {
  position: sticky; top: 0; z-index: 40; height: 64px;
  background: rgba(255,255,255,.9); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
  display: flex; align-items: center; gap: 12px;
  padding-inline: clamp(14px, 4vw, 24px);
}
.adm-top .brand .logo { width: 36px; height: 36px; border-radius: 10px; }
.adm-top .brand .logo svg { width: 20px; height: 20px; }
.adm-top .brand-text strong { font-size: .96rem; }
.adm-top .brand-text span { font-size: .68rem; }
.adm-top .spacer { margin-left: auto; }
.adm-top .preview-link { font-weight: 700; font-size: .86rem; color: var(--teal-700);
  display: inline-flex; align-items: center; gap: 6px; padding: 8px 12px; border-radius: 999px; }
.adm-top .preview-link:hover { background: var(--teal-50); }
.adm-top .logout { border: 1px solid var(--line); background: #fff; border-radius: 999px;
  padding: 8px 14px; font-weight: 700; font-size: .86rem; color: var(--ink-soft); }

/* Mobile: Kopfzeilen-Aktionen umbrechen statt horizontal überlaufen */
@media (max-width: 560px) {
  .adm-top { height: auto; flex-wrap: wrap; padding-block: 9px; gap: 8px; }
  .adm-top .preview-link, .adm-top .logout { padding: 7px 11px; font-size: .8rem; }
}

.adm-wrap { max-width: 760px; margin-inline: auto; padding: clamp(16px, 4vw, 28px); }

/* --------------------------------------------------------------- Login */
.login-screen { min-height: 100svh; display: grid; place-items: center; padding: 24px;
  background: var(--grad-soft); position: relative; overflow: hidden; }
.login-screen::before { content:""; position:absolute; inset:0;
  background: radial-gradient(50% 40% at 80% 0%, rgba(56,189,248,.16), transparent 70%),
              radial-gradient(50% 50% at 0% 100%, rgba(20,184,166,.16), transparent 70%); }
.login-card { position: relative; z-index: 2; width: 100%; max-width: 400px; background: #fff;
  border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg);
  padding: clamp(26px, 6vw, 38px); }
.login-card .lock { width: 56px; height: 56px; border-radius: 16px; background: var(--grad-teal);
  display: grid; place-items: center; color: #fff; box-shadow: var(--shadow); margin-bottom: 20px; }
.login-card .lock svg { width: 28px; height: 28px; }
.login-card h1 { font-size: 1.5rem; letter-spacing: -.02em; }
.login-card p.sub { color: var(--muted); margin-top: 8px; font-size: .95rem; }
.field { margin-top: 18px; }
.field label { display: block; font-weight: 700; font-size: .84rem; margin-bottom: 7px; color: var(--ink-soft); }
.field input, .field textarea, .field select {
  width: 100%; padding: 14px 16px; border: 1.5px solid var(--line); border-radius: 13px;
  font: inherit; color: var(--ink); background: #fff; transition: border-color .15s, box-shadow .15s;
}
.field input:focus, .field textarea:focus, .field select:focus { border-color: var(--teal-400); box-shadow: var(--ring); outline: none; }
.field textarea { min-height: 96px; resize: vertical; }
.login-hint { margin-top: 14px; font-size: .82rem; color: var(--muted); background: var(--teal-50);
  border: 1px dashed var(--teal-200); border-radius: 12px; padding: 10px 12px; }
.login-error { color: var(--danger); font-size: .86rem; font-weight: 700; margin-top: 12px; display: none; }
.login-foot { margin-top: 16px; text-align: center; }
.login-foot a { color: var(--teal-700); font-weight: 700; font-size: .88rem; }

/* --------------------------------------------------------------- Tabs */
.adm-tabs { display: flex; gap: 6px; background: #fff; border: 1px solid var(--line); padding: 6px;
  border-radius: 999px; box-shadow: var(--shadow-sm); margin-bottom: 22px; position: sticky; top: 76px; z-index: 30; }
.adm-tabs button { flex: 1; border: none; background: transparent; padding: 12px; border-radius: 999px;
  font-weight: 700; color: var(--ink-soft); transition: .18s; font-size: .94rem; }
.adm-tabs button.active { background: var(--grad-teal); color: #fff; box-shadow: var(--shadow-sm); }

.panel { display: none; }
.panel.active { display: block; animation: fade .25s ease; }
@keyframes fade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

.card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow-sm);
  padding: clamp(18px, 4vw, 24px); margin-bottom: 18px; }
.card h2 { font-size: 1.12rem; display: flex; align-items: center; gap: 10px; margin-bottom: 4px; }
.card h2 svg { width: 20px; height: 20px; color: var(--teal-600); }
.card .hint { color: var(--muted); font-size: .9rem; margin-bottom: 16px; }

.row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.mini-form { display: flex; flex-wrap: wrap; gap: 12px; align-items: flex-end; margin-top: 16px; }
.mini-form .field { margin-top: 0; flex: 1 1 140px; }
.mini-form .btn { flex: 0 0 auto; }
@media (max-width: 560px) { .mini-form .field, .mini-form .btn { flex: 1 1 100%; } }

.sub-h { font-size: .95rem; font-weight: 800; margin-top: 24px; margin-bottom: 2px; color: var(--ink); }
.hours-row-edit { display: flex; align-items: center; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--line); flex-wrap: wrap; }
.hours-row-edit:first-child { padding-top: 4px; }
.hours-row-edit .hr-day { font-weight: 700; width: 96px; flex: none; }
.hours-row-edit .hr-toggle { display: inline-flex; align-items: center; gap: 6px; font-size: .85rem; color: var(--ink-soft); user-select: none; }
.hours-row-edit input[type="time"] { padding: 8px 10px; border: 1px solid var(--line); border-radius: 10px; font: inherit; }
.hours-row-edit input[type="time"]:disabled { opacity: .4; }
.hours-row-edit .hr-sep { color: var(--muted); }

/* Gruppiertes Zeitfeld (Von – Bis) im Formular */
.mini-form .time-field { flex: 1 1 230px; }
.time-pair { display: flex; align-items: center; gap: 8px; }
.time-pair input[type="time"] { flex: 1 1 0; min-width: 0; }
.time-pair .time-dash { color: var(--muted); flex: none; }

/* Feiertage: Kopf mit Jahr-Filter */
.hol-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-top: 24px; }
.hol-filter { display: inline-flex; align-items: center; gap: 8px; }
.hol-filter label { font-weight: 700; font-size: .84rem; color: var(--ink-soft); }
.hol-filter select { padding: 8px 10px; border: 1px solid var(--line); border-radius: 10px; font: inherit; background: #fff; }

/* Wahlarzt-Leistungs-Editor */
.wa-le-row { display: flex; gap: 8px; align-items: center; margin-bottom: 8px; flex-wrap: wrap; }
.wa-le-row input { padding: 9px 11px; border: 1px solid var(--line); border-radius: 10px; font: inherit; min-width: 0; }
.wa-le-row input:focus { border-color: var(--teal-400); box-shadow: var(--ring); outline: none; }
.wa-le-row .le-t { flex: 2 1 150px; }
.wa-le-row .le-d { flex: 3 1 200px; }
.wa-le-row .le-dauer { flex: 1 1 70px; }
.wa-le-row .le-p { flex: 1 1 80px; }
.wa-pk-row { border: 1px solid var(--line); border-radius: 12px; padding: 12px; margin-bottom: 10px; }
.wa-pk-top { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.wa-pk-top input { padding: 9px 11px; border: 1px solid var(--line); border-radius: 10px; font: inherit; min-width: 0; }
.wa-pk-top input:focus { border-color: var(--teal-400); box-shadow: var(--ring); outline: none; }
.wa-pk-top .pk-sub { flex: 1 1 110px; }
.wa-pk-top .pk-t { flex: 2 1 170px; }
.wa-pk-top .pk-p { flex: 1 1 80px; }
.wa-pk-row textarea { width: 100%; margin-top: 8px; padding: 9px 11px; border: 1px solid var(--line); border-radius: 10px; font: inherit; min-height: 84px; resize: vertical; }
.wa-pk-row textarea:focus { border-color: var(--teal-400); box-shadow: var(--ring); outline: none; }

/* Bereichs-Umschalter (Besucher-Statistik) */
.seg { display: inline-flex; gap: 4px; background: var(--surface); border: 1px solid var(--line);
  border-radius: 999px; padding: 4px; margin: 8px 0 18px; flex-wrap: wrap; }
.seg button { border: none; background: transparent; padding: 8px 16px; border-radius: 999px;
  font-weight: 700; font-size: .9rem; color: var(--ink-soft); cursor: pointer; transition: .18s; }
.seg button.active { background: var(--grad-teal); color: #fff; box-shadow: var(--shadow-sm); }
.switch-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 16px;
  padding: 12px 14px; border: 1px solid var(--line); border-radius: 13px; }
.switch-row b { font-size: .94rem; }
.switch-row small { color: var(--muted); display: block; font-size: .8rem; }
.switch { position: relative; width: 50px; height: 28px; flex: none; }
.switch input { opacity: 0; width: 0; height: 0; }
.switch .track { position: absolute; inset: 0; background: var(--line); border-radius: 999px; transition: .2s; }
.switch .track::before { content: ""; position: absolute; top: 3px; left: 3px; width: 22px; height: 22px;
  background: #fff; border-radius: 50%; transition: .2s; box-shadow: var(--shadow-sm); }
.switch input:checked + .track { background: var(--teal-500); }
.switch input:checked + .track::before { transform: translateX(22px); }

/* News list */
.item-list { display: flex; flex-direction: column; gap: 12px; }
.item {
  display: flex; gap: 12px; align-items: flex-start; background: #fff; border: 1px solid var(--line);
  border-radius: 14px; padding: 14px 16px;
}
.item.pinned { border-color: var(--teal-200); background: linear-gradient(180deg,#fff,#f6fdfd); }
.item .item-main { flex: 1; min-width: 0; }
.item .item-main b { display: block; font-size: .98rem; }
.item .item-main small { color: var(--muted); display: block; margin-top: 3px; }
.item .item-cat { font-size: .7rem; font-weight: 800; letter-spacing: .04em; text-transform: uppercase;
  padding: 4px 9px; border-radius: 999px; background: var(--teal-50); color: var(--teal-700); border: 1px solid var(--teal-200); }
.item .item-cat.impfung { background:#eef7ff; color:var(--blue-600); border-color:#cfe8fc; }
.item .item-cat.zeiten { background:#fff4ec; color:#c2570a; border-color:#fcdcc4; }
.item .actions { display: flex; gap: 6px; }
.icon-btn { width: 36px; height: 36px; border-radius: 10px; border: 1px solid var(--line); background: #fff;
  display: grid; place-items: center; color: var(--ink-soft); transition: .15s; }
.icon-btn svg { width: 18px; height: 18px; }
.icon-btn:hover { border-color: var(--teal-300); color: var(--teal-700); }
.icon-btn.danger:hover { border-color: #fbd5db; color: var(--danger); background: #fff5f6; }

/* Schedule editor */
.sched-day { border: 1px solid var(--line); border-radius: 14px; margin-bottom: 12px; overflow: hidden; }
.sched-day > summary { list-style: none; cursor: pointer; padding: 15px 18px; font-weight: 700;
  display: flex; align-items: center; justify-content: space-between; background: #fff; }
.sched-day > summary::-webkit-details-marker { display: none; }
.sched-day[open] > summary { border-bottom: 1px solid var(--line); background: var(--surface); }
.sched-day .count { font-size: .76rem; font-weight: 800; color: var(--teal-700); background: var(--teal-50);
  border: 1px solid var(--teal-200); padding: 3px 9px; border-radius: 999px; }
.sched-body { padding: 14px 18px; display: flex; flex-direction: column; gap: 10px; }
.slot-edit { display: grid; grid-template-columns: 1fr auto auto auto; gap: 8px; align-items: center; }
.slot-edit input, .slot-edit select { padding: 10px 12px; border: 1.5px solid var(--line); border-radius: 11px; font: inherit; width: 100%; background: #fff; }
.slot-edit input[type=time] { width: 110px; }
.add-slot { align-self: flex-start; }

.toast { position: fixed; left: 50%; bottom: 24px; transform: translateX(-50%) translateY(20px);
  background: var(--ink); color: #fff; padding: 13px 20px; border-radius: 999px; font-weight: 700; font-size: .92rem;
  box-shadow: var(--shadow-lg); opacity: 0; transition: .25s; z-index: 100; display: flex; gap: 8px; align-items: center; }
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast svg { width: 18px; height: 18px; color: var(--teal-300); }

/* Besucher-Statistik */
.stat-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.stat { background: var(--surface); border: 1px solid var(--line); border-radius: 14px; padding: 16px 18px; }
.stat-num { display: block; font-size: 1.8rem; font-weight: 800; letter-spacing: -.02em; color: var(--ink); line-height: 1.1; }
.stat-lbl { color: var(--muted); font-size: .84rem; font-weight: 600; }

.bars { display: flex; align-items: flex-end; gap: 10px; height: 190px; padding-top: 22px; }
.bar { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 8px; height: 100%; justify-content: flex-end; }
.bar-fill { width: 100%; max-width: 42px; background: var(--grad-teal); border-radius: 8px 8px 0 0;
  position: relative; min-height: 6px; box-shadow: var(--shadow-sm); }
.bar-fill b { position: absolute; top: -20px; left: 50%; transform: translateX(-50%);
  font-size: .74rem; color: var(--ink-soft); font-weight: 700; }
.bar-lbl { font-size: .8rem; color: var(--muted); font-weight: 700; }

.toppages { display: flex; flex-direction: column; gap: 14px; }
.toppage { display: grid; grid-template-columns: 1fr 92px 40px; align-items: center; gap: 12px; }
.tp-name { font-weight: 650; font-size: .92rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tp-bar { height: 8px; background: var(--surface-2); border-radius: 999px; overflow: hidden; }
.tp-bar span { display: block; height: 100%; background: var(--grad-teal); border-radius: 999px; }
.tp-val { text-align: right; font-weight: 800; color: var(--teal-700); font-size: .86rem; }

@media (max-width: 520px) {
  .row2 { grid-template-columns: 1fr; }
  .slot-edit { grid-template-columns: 1fr 1fr; }
  .slot-edit .arzt { grid-column: 1 / -1; }
  /* Reiter horizontal scrollbar machen, einzeilig – kein „Kreis"-Effekt mehr */
  .adm-tabs { overflow-x: auto; border-radius: 16px; gap: 4px; scrollbar-width: none; }
  .adm-tabs::-webkit-scrollbar { display: none; }
  .adm-tabs button { flex: 0 0 auto; white-space: nowrap; padding: 10px 13px; font-size: .84rem; border-radius: 12px; }
  .toppage { grid-template-columns: 1fr 60px 36px; }
}

/* ----------------------------- Besetzungs-Übersicht (Anwesenheit) */
.cover-banner { border-radius: 12px; padding: 12px 14px; font-size: .9rem; margin: 4px 0 16px; }
.cover-banner.ok { background: var(--teal-50); border: 1px solid var(--teal-100); color: var(--teal-700);
  display: flex; align-items: center; gap: 8px; font-weight: 700; }
.cover-banner.ok svg { width: 18px; height: 18px; flex: none; }
.cover-banner.alert { background: #fef2f2; border: 1px solid #fecaca; color: #b91c1c; }
.cover-banner.alert b { display: block; margin-bottom: 6px; }
.cover-banner.alert ul { margin: 0; padding-left: 18px; display: grid; gap: 3px; }

.cover-grid { display: grid; gap: 12px; }
.cover-week { display: grid; grid-template-columns: 120px 1fr; gap: 12px; align-items: stretch; }
.cover-wk-label { font-size: .8rem; font-weight: 700; color: var(--ink-soft); display: flex; align-items: center; }
.cover-days { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; }
.cover-day { border: 1px solid var(--line); border-radius: 10px; padding: 8px 9px; background: #fff;
  display: flex; flex-direction: column; gap: 2px; min-height: 62px; }
.cover-day .cd-day { font-size: .72rem; font-weight: 700; color: var(--muted); }
.cover-day .cd-count { font-size: .92rem; font-weight: 800; color: var(--teal-700); }
.cover-day .cd-note { font-size: .68rem; color: var(--ink-soft); line-height: 1.25; margin-top: 1px; }
.cover-day.empty { background: #fef2f2; border-color: #fca5a5; }
.cover-day.empty .cd-count { color: #b91c1c; }
.cover-day.closed { background: var(--surface); }
.cover-day.closed .cd-count { color: var(--muted); font-weight: 600; }
.cover-day.is-today { box-shadow: 0 0 0 2px rgba(20,184,166,.35); border-color: var(--teal-400); }
.cover-day.past { opacity: .45; }

@media (max-width: 720px) {
  .cover-week { grid-template-columns: 1fr; gap: 6px; }
  .cover-wk-label { margin-top: 6px; }
  .cover-days { grid-template-columns: repeat(5, 1fr); gap: 5px; }
  .cover-day { min-height: 56px; padding: 6px; }
  .cover-day .cd-note { display: none; }
}

/* ----------------------------- Team & Ärzte (Editor) */
.team-row { display: flex; gap: 14px; align-items: flex-start; border: 1px solid var(--line); border-radius: 12px; padding: 12px 12px 10px; margin-bottom: 10px; background: #fff; }
.tm-main { flex: 1; min-width: 0; }
.tm-grid { display: grid; grid-template-columns: 1.2fr 1fr 1.5fr 108px; gap: 8px; }
.team-row input, .team-row select { padding: 8px 10px; border: 1px solid var(--line); border-radius: 8px; font: inherit; background: var(--surface); width: 100%; }
.team-row .tm-chk input { width: auto; padding: 0; border: 0; }
.tm-flags { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin-top: 10px; }
.tm-chk { display: inline-flex; align-items: center; gap: 6px; font-size: .85rem; font-weight: 600; color: var(--ink-soft); white-space: nowrap; }
.tm-chk input { width: auto; }
.tm-flags .tm-kurz { flex: 1; min-width: 160px; width: auto; }
.tm-flags .tm-del { margin-left: auto; flex: none; }
.team-actions { display: flex; gap: 10px; margin-top: 6px; flex-wrap: wrap; }

/* Foto-Spalte je Team-Zeile */
.tm-photo { flex: none; width: 84px; display: flex; flex-direction: column; align-items: center; gap: 6px; }
.tm-avatar { width: 72px; height: 72px; border-radius: 50%; overflow: hidden; background: linear-gradient(160deg, var(--teal-200, #9fd5d0), var(--teal-100, #d6efec)); display: grid; place-items: center; box-shadow: 0 1px 4px rgba(0,0,0,.12); }
.tm-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.tm-avatar.ph span { color: #fff; font-size: 1.3rem; font-weight: 800; }
.tm-photo-btn { cursor: pointer; font-size: .72rem; font-weight: 700; color: var(--teal-700, #0f766e); border: 1px solid var(--line); border-radius: 7px; padding: 4px 8px; text-align: center; line-height: 1.2; background: var(--surface); width: 100%; }
.tm-photo-btn:hover { background: var(--teal-50, #eef9f7); }
.tm-photo-del { cursor: pointer; font-size: .7rem; color: var(--muted); background: none; border: none; padding: 0; text-decoration: underline; }
.tm-photo-del:hover { color: #c0392b; }

@media (max-width: 720px) {
  .tm-grid { grid-template-columns: 1fr 1fr; }
  .tm-flags .tm-del { margin-left: 0; }
}

/* ----------------------------- Tages-Zuweisung: anklickbare Tage + Dialog */
.cover-day.clickable { cursor: pointer; }
.cover-day.clickable:hover { border-color: var(--teal-400); box-shadow: 0 0 0 2px rgba(20,184,166,.18); }
.cover-day.assigned { box-shadow: inset 3px 0 0 var(--teal-400); }

.adm-dialog { border: none; border-radius: var(--radius-lg); padding: 22px 24px; max-width: 440px;
  width: calc(100% - 32px); box-shadow: var(--shadow-lg); color: var(--ink); }
.adm-dialog::backdrop { background: rgba(14,42,50,.45); backdrop-filter: blur(2px); }
.adm-dialog h3 { font-size: 1.12rem; margin-bottom: 6px; }
.adm-dialog .field { margin-top: 14px; display: flex; flex-direction: column; gap: 6px; }
.adm-dialog .field label { font-size: .85rem; font-weight: 700; color: var(--ink-soft); }
.adm-dialog select, .adm-dialog input[type="time"] { padding: 9px 11px; border: 1px solid var(--line); border-radius: 9px; font: inherit; background: var(--surface); }
.assign-btns { display: flex; gap: 10px; justify-content: flex-end; margin-top: 20px; }
.assign-current { margin-top: 14px; border-top: 1px solid var(--line); padding-top: 12px; font-size: .9rem; }
.assign-cur-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 6px 0; }
