:root{
  --bg:#f2f3f5; --card:#fff; --ink:#222222; --muted:#6b7280;
  --line:#e3e3e6; --brand:#b61216; --brand-d:#8e0e12;
  --slate:#272f38; --ok:#1c8a4d; --danger:#c23b3b; --shift:#fdecec;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink)}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--muted)}
.pad{padding:16px}
.error{color:var(--danger)}

/* Topbar */
.topbar{display:flex;align-items:center;gap:14px;background:var(--card);
  border-bottom:3px solid var(--brand);padding:10px 16px}
.topbar .logo{height:38px;width:auto;display:block}
.topbar .subtitle{font-weight:700;color:var(--slate);letter-spacing:.3px;
  border-left:1px solid var(--line);padding-left:14px}
.topbar nav{display:flex;gap:16px;margin-left:auto}
.topbar nav a{color:var(--slate);font-weight:600}
.topbar nav a:hover{color:var(--brand);text-decoration:none}
.topbar nav a.active{color:var(--brand)}
.topbar .who{margin-left:auto;color:var(--muted)}

/* Buttons */
.btn,.primary{font:inherit;cursor:pointer;border:1px solid var(--line);
  background:var(--card);color:var(--ink);padding:7px 12px;border-radius:8px}
.btn:hover{background:#eef1f6}
.primary{background:var(--brand);color:#fff;border-color:var(--brand-d)}
.primary:hover{background:var(--brand-d)}
.btn.danger{color:var(--danger);border-color:#f0c9c9}
.btn.danger:hover{background:#fbeaea}

/* Week nav */
.weeknav{display:flex;align-items:center;gap:8px;padding:14px 16px;flex-wrap:wrap}
.weeklabel{margin-left:8px;font-weight:600}
.add-day{display:inline-flex;gap:6px;align-items:center;margin-left:auto}
.add-day select{padding:7px;border:1px solid var(--line);border-radius:8px;font:inherit}
.copy-week{display:inline-flex;margin:0}
.print-title{display:none}

/* Zusatztag-Spalten */
th.extra-col{background:#eef6ee}
th.extra-col small{color:var(--ok)}
.rm-day{margin:2px 0 0}
.rm-day .x{border:none;background:transparent;color:var(--muted);cursor:pointer;
  font-size:11px;line-height:1;padding:1px 4px}
.rm-day .x:hover{color:var(--danger)}

/* Plan table */
.tablewrap{overflow-x:auto;padding:0 16px}
table.plan{border-collapse:collapse;width:100%;background:var(--card)}
table.plan th,table.plan td{border:1px solid var(--line);padding:6px;text-align:center;vertical-align:top}
table.plan thead th{background:#f0f3f8;position:sticky;top:0}
table.plan th.namecol{text-align:left;min-width:160px;background:#eef1f6;position:sticky;left:0;z-index:1;
  font-weight:700;border-right:2px solid #c2c9d4}
table.plan td.namecol{position:sticky;left:0}
/* Zeilen besser abgrenzen: Zebra + kräftige Trennlinie + Hover */
table.plan tbody tr:nth-child(even) td{background:#f5f6f8}
table.plan tbody tr:nth-child(even) th.namecol{background:#e6eaf0}
table.plan tbody td,table.plan tbody th.namecol{border-bottom:2px solid #c2c9d4}
table.plan tbody tr:hover td{background:#fdeeee}
table.plan tbody tr:hover th.namecol{background:#f6dede;color:var(--brand)}
table.plan thead th.is-today{background:#fff7e6}
.cell{min-width:96px;height:54px;cursor:pointer}
.cell.empty .add{color:#c3ccd8;font-size:18px}
.cell.empty:hover{background:#fdf3f3}
.plan.ro td.cell{cursor:default}
.plan.ro td.cell.empty:hover{background:var(--card)}
.cell.has-shift{background:var(--shift);box-shadow:inset 4px 0 0 var(--brand)}
.chip{display:block;background:var(--brand);color:#fff;border:1px solid var(--brand-d);
  border-radius:6px;padding:3px 7px;margin:2px 0;font-size:13px;font-weight:600;line-height:1.25}
.chip small{display:block;color:#f7dada;font-size:11px;font-weight:400}
.ort{display:block;width:fit-content;max-width:100%;background:#fff;color:var(--brand-d);
  font-weight:700;font-size:11px;border-radius:999px;padding:1px 8px;margin:3px 0 1px}
.ort::before{content:"📍";margin-right:3px}

/* Modal */
.overlay{position:fixed;inset:0;background:rgba(15,23,35,.45);display:flex;
  align-items:center;justify-content:center;padding:16px}
.overlay.hidden{display:none}
.modal{background:var(--card);border-radius:12px;padding:18px;width:min(520px,100%);
  box-shadow:0 18px 48px rgba(0,0,0,.25)}
.modal h3{margin:0 0 12px}
.m-row{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:10px;
  padding-bottom:10px;border-bottom:1px dashed var(--line)}
#m-rows .m-row:last-child{border-bottom:none;padding-bottom:0}
.m-row .sep{color:var(--muted)}
.m-row input[type=time]{width:96px}
.m-row .r-ort{flex:1 1 130px;min-width:110px}
.m-row .r-notiz{flex:1 1 150px;min-width:110px}
.m-row .r-abruf-l{display:inline-flex;align-items:center;gap:5px;white-space:nowrap;
  font-size:13px;color:var(--slate);cursor:pointer}
.m-row .r-abruf-l input{width:auto}
.m-row .r-del{margin-left:auto}
.m-row input{padding:6px;border:1px solid var(--line);border-radius:7px;font:inherit}
.m-actions{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0}
.hint{color:var(--muted);font-size:12px;margin:8px 0}
.m-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}

/* Lists / forms */
.inline-form{display:inline-flex;gap:6px;align-items:center;flex-wrap:wrap;margin:0}
.inline-form input[type=text]{padding:7px;border:1px solid var(--line);border-radius:8px;font:inherit}
table.list{border-collapse:collapse;width:100%;margin-top:16px;background:var(--card)}
table.list th,table.list td{border:1px solid var(--line);padding:8px;text-align:left;vertical-align:top}
table.list tr.inactive{opacity:.55}
.actions{display:flex;gap:6px;flex-wrap:wrap}
.codelink{font-size:13px;word-break:break-all}
.badge{display:inline-block;padding:2px 8px;border-radius:999px;background:#eceff3;font-size:12px}
.badge.ok{background:#e3f5ea;color:var(--ok)}

/* Cards */
.centered{display:flex;align-items:center;justify-content:center;min-height:100vh}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:20px;
  display:flex;flex-direction:column;gap:10px;max-width:420px}
.card.login h1{margin:0}
.logo-lg{width:100%;max-width:260px;height:auto;display:block;margin:2px auto 8px}
.card input{padding:9px;border:1px solid var(--line);border-radius:8px;font:inherit}
.check{display:flex;align-items:center;gap:8px}

/* Employee day list */
.daylist{display:flex;flex-direction:column;gap:10px;padding:16px;max-width:560px}
.daycard{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px}
.daycard.is-today{border-color:var(--brand);box-shadow:0 0 0 2px #dde8ff}
.dhead{display:flex;justify-content:space-between;margin-bottom:6px}
.dname{font-weight:700}
.tag{font-weight:600;color:var(--ok);background:#e3f5ea;border-radius:999px;padding:1px 8px;font-size:11px;margin-left:6px}
.ddate{color:var(--muted)}
.dbody .chip{display:inline-block;margin:2px 4px 2px 0}
.free{color:var(--muted)}

/* Druck / PDF */
@media print{
  .topbar,.weeknav,.pad,.hint,.overlay,.rm-day{display:none !important}
  .print-title{display:flex !important;align-items:center;gap:12px;margin:0 0 10px;font-size:16px}
  .print-title .print-logo{height:30px;width:auto}
  body{background:#fff}
  .tablewrap{overflow:visible;padding:0}
  table.plan{font-size:11px;width:100%}
  table.plan thead th,table.plan th.namecol,table.plan td.namecol{position:static}
  .cell{height:auto}
  .cell.has-shift{box-shadow:inset 4px 0 0 #b61216;background:#fdecec !important;
    -webkit-print-color-adjust:exact;print-color-adjust:exact}
  .chip{background:#b61216 !important;color:#fff !important;
    -webkit-print-color-adjust:exact;print-color-adjust:exact}
  .chip small{color:#f7dada !important}
  .ort{background:#fff !important;color:#8e0e12 !important;
    -webkit-print-color-adjust:exact;print-color-adjust:exact}
  th.extra-col{background:#eef6ee !important;
    -webkit-print-color-adjust:exact;print-color-adjust:exact}
  @page{size:landscape;margin:10mm}
}

/* ---------- Responsive (Smartphone/Tablet) ---------- */
@media (max-width:760px){
  .pad{padding:12px}

  /* Kopfzeile umbrechen */
  .topbar{flex-wrap:wrap;gap:8px 12px;padding:10px 12px}
  .topbar .logo{height:30px}
  .topbar .subtitle{border-left:none;padding-left:0;font-size:14px}
  .topbar nav{flex-basis:100%;margin-left:0;gap:14px;flex-wrap:wrap}
  .topbar .who{flex-basis:100%;margin-left:0}

  /* Wochenleiste */
  .weeknav{padding:12px;gap:6px}
  .weeklabel{flex-basis:100%;margin-left:0;order:-1}
  .add-day{margin-left:0;flex-basis:100%}
  .add-day select{flex:1}

  /* Plan: je Mitarbeiter eine Karte, Tage untereinander – kein seitliches Schieben */
  .tablewrap{overflow:visible;padding:0 12px}
  table.plan,table.plan tbody{display:block;width:100%}
  table.plan thead{display:none}
  table.plan tr{display:block;background:var(--card);border:1px solid var(--line);
    border-radius:10px;margin:0 0 12px;overflow:hidden}
  table.plan th.namecol{display:block;position:static;min-width:0;background:var(--slate);
    color:#fff;text-align:left;padding:10px 12px;font-size:15px}
  table.plan td.cell{display:flex;align-items:center;gap:10px;width:100%;min-width:0;
    height:auto;text-align:left;border:0;border-top:1px solid var(--line);box-shadow:none;padding:8px 12px}
  table.plan td.cell::before{content:attr(data-label);flex:0 0 86px;
    color:var(--muted);font-weight:700;font-size:13px}
  table.plan td.cell.is-today{background:#fff7e6}
  table.plan td.cell.is-today::before{color:var(--brand)}
  table.plan td.cell.has-shift{box-shadow:inset 4px 0 0 var(--brand)}
  table.plan td.cell.empty .add{color:#b9c2cd;font-size:18px}
  .cell .chip{display:inline-block;margin:2px 4px 2px 0}

  /* Editor-Dialog */
  .modal{padding:14px}
  .m-row{flex-wrap:wrap}
  .m-row .r-von,.m-row .r-bis{flex:1 1 40%;width:auto}
  .m-row .r-ort{flex:1 1 100%;order:4;min-width:0}
  .m-row .r-notiz{flex:1 1 100%;order:5;min-width:0}

  /* Mitarbeiterliste als Karten */
  table.list thead{display:none}
  table.list,table.list tbody,table.list tr,table.list td{display:block;width:100%}
  table.list tr{border:1px solid var(--line);border-radius:10px;
    margin-bottom:12px;padding:6px;background:var(--card)}
  table.list td{border:none;border-bottom:1px solid var(--line);padding:8px 6px}
  table.list td:last-child{border-bottom:none}
  table.list td[data-label]::before{content:attr(data-label);display:block;
    font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;margin-bottom:4px}
  .inline-form{width:100%}
  .inline-form input[type=text]{flex:1;min-width:0}
  .codelink{font-size:12px}

  /* Mitarbeiter-Tagesliste */
  .daylist{padding:12px}
}
