/* === Entwurf A: Editorial Calm === */
:root{
  --paper:#f6f2eb; --surface:#fffdf9; --ink:#211c18; --muted:#8a8174;
  --line:#e8e1d4; --line-soft:#f0eadd; --accent:#5e6b54; --accent-ink:#3c4736;
  --accent-soft:#eef0ea; --danger:#8c3b34;
  --radius:13px; --radius-sm:9px; --shadow:0 18px 44px rgba(33,28,24,.10);
  --display:'Fraunces',Georgia,serif; --body:'Hanken Grotesk',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--body);background:var(--paper);color:var(--ink);
  line-height:1.5;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--display);font-weight:500;letter-spacing:-.015em;line-height:1.15}
a{color:var(--accent-ink)}

/* Navigation */
.nav{display:flex;align-items:center;gap:26px;padding:16px 26px;
  background:var(--surface);border-bottom:1px solid var(--line);flex-wrap:wrap}
.nav .brand{font-family:var(--display);font-weight:600;font-size:19px;
  letter-spacing:-.01em;margin-right:auto;text-decoration:none;color:var(--ink)}
.nav .brand small{display:block;font-family:var(--body);font-weight:500;font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:2px}
.nav a{color:#5b5246;text-decoration:none;font-size:14.5px;font-weight:500;
  padding-bottom:4px;border-bottom:2px solid transparent}
.nav a:hover{color:var(--ink)}
.nav a.act{color:var(--ink);border-bottom-color:var(--accent)}

/* Layout */
main{padding:34px 26px;max-width:1000px;margin:0 auto}
/* Breit-Ansicht fuer Kalender-/Matrix-Seiten: volle Bildschirmbreite (90%) statt schmaler Spalte */
main.main-wide{max-width:90%}
@media (max-width:700px){main.main-wide{max-width:100%}}
.hi{font-size:27px;margin-bottom:4px}
.sub{color:var(--muted);font-size:14px;margin-bottom:26px}
.page-title{font-size:24px;margin-bottom:18px}

/* Cards / Panels */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:18px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.card .lab{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.card .num{font-family:var(--display);font-size:30px;font-weight:500;margin-top:8px;color:var(--accent-ink)}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden}
.panel-pad{padding:22px 24px}

/* Tabelle */
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th{text-align:left;font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);font-weight:600;padding:14px 16px;border-bottom:1px solid var(--line)}
.table td{padding:13px 16px;border-bottom:1px solid var(--line-soft)}
.table tr:last-child td{border-bottom:none}
.pill{display:inline-block;font-size:11px;padding:4px 10px;border-radius:20px;
  background:var(--accent-soft);color:var(--accent);font-weight:600}

/* Buttons */
.btn{display:inline-block;font-family:var(--body);font-size:14px;font-weight:600;
  padding:10px 18px;border-radius:var(--radius-sm);border:1px solid var(--accent);
  background:var(--accent);color:var(--surface);cursor:pointer;text-decoration:none}
.btn:hover{background:var(--accent-ink);border-color:var(--accent-ink)}
.btn-ghost{background:transparent;color:var(--accent-ink);border-color:var(--line)}
.btn-ghost:hover{background:var(--accent-soft);color:var(--accent-ink)}
.linklike{background:none;border:none;padding:0;font:inherit;
  color:var(--accent);cursor:pointer;text-decoration:underline}
.linklike:hover{color:var(--accent-ink)}

/* Formulare */
form p{margin-bottom:14px}
form label{display:block;font-size:13px;font-weight:600;color:#5b5246;margin-bottom:5px}
input,select,textarea{font-family:var(--body);font-size:15px;width:100%;max-width:420px;
  padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);
  background:var(--surface);color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft)}

/* Auth-Karte */
.auth{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.auth .box{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:38px 34px;width:100%;max-width:380px}
.auth h1{font-size:26px;margin-bottom:4px}
.auth .sub{margin-bottom:22px}
.auth .btn{width:100%;text-align:center;margin-top:8px}
.brandmark{font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--muted);margin-bottom:18px}

/* Avatar / Profilfoto */
.avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;
  border:1px solid var(--line);background:var(--surface);display:block;flex-shrink:0}
.avatar-lg{width:84px;height:84px}
.avatar-ph{display:flex;align-items:center;justify-content:center;
  background:var(--accent-soft);color:var(--accent);font-family:var(--display);
  font-weight:600;font-size:28px;text-transform:uppercase}

/* Abmelden-Button in der Navigation (identisch zu den Nav-Links) */
.nav form{display:flex;margin:0}
.nav-logout{background:none;border:none;margin:0;cursor:pointer;
  font-family:var(--body);font-size:14.5px;font-weight:500;color:#5b5246;
  padding:0 0 4px 0;border-bottom:2px solid transparent;line-height:inherit}
.nav-logout:hover{color:var(--ink)}

/* Hinweis-Box (Arbeitszeit/Pausen) */
.hinweis{background:#f7eede;border:1px solid #e3cfa5;border-radius:var(--radius-sm);
  color:#7c5512;padding:10px 14px;margin-bottom:10px;font-size:14px}

/* Schichtplan */
.kal-scroll{overflow-x:auto}
.kal-matrix{border-collapse:collapse;font-size:12px}
.kal-matrix th,.kal-matrix td{border:1px solid var(--line-soft);padding:4px 6px;text-align:center;vertical-align:top;min-width:34px}
.kal-matrix th.name,.kal-matrix td.name{position:sticky;left:0;background:var(--surface);text-align:left;white-space:nowrap;z-index:1}
.kal-matrix .we{background:var(--line-soft)}
.kal-matrix .feier{background:#f7eede}
.schicht-pill{display:inline-block;font-size:11px;padding:1px 7px;border-radius:20px;color:var(--ink);margin:1px;text-decoration:none}
.abw-pill{display:inline-block;font-size:11px;padding:1px 7px;border-radius:20px;background:var(--line);color:var(--muted);margin:1px}
.kal-plus{display:inline-block;font-size:12px;color:var(--muted);text-decoration:none;padding:0 3px}
.kal-plus:hover{color:var(--accent)}
.kal-raster{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.kal-raster .kopf{text-align:center;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.kal-raster .tag{min-height:64px;border:1px solid var(--line);border-radius:var(--radius-sm);padding:4px;background:var(--surface)}
.kal-raster .tag.aus{opacity:.4}
.kal-raster .tag.we{background:var(--line-soft)}
.kal-raster .tag.feier{background:#f7eede}
.kal-raster .tag .dnum{font-size:11px;color:var(--muted)}
.kal-eintrag{font-size:10.5px;border-radius:4px;padding:0 4px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--ink)}
.farbswatch{display:inline-flex;align-items:center;gap:6px;margin-right:12px}
.farbswatch .sw{width:16px;height:16px;border-radius:4px;border:1px solid var(--line)}

/* Urlaubsplanung – Zellen-Markierungen (nutzt .kal-matrix aus dem Schichtplan) */
.url-pill{display:block;font-size:10px;border-radius:4px;padding:0 3px;line-height:1.5}
.url-genehmigt{background:var(--accent);color:#fff}
.url-beantragt{background:repeating-linear-gradient(45deg,#e9ddc4,#e9ddc4 3px,#f3ebd8 3px,#f3ebd8 6px);color:var(--ink)}
.url-sonstige{background:var(--line-soft);color:var(--muted)}
.url-legende{display:flex;gap:18px;flex-wrap:wrap;align-items:center;font-size:13px;margin-bottom:14px}
.url-legende span.sw{display:inline-block;width:16px;height:12px;border-radius:3px;vertical-align:middle;margin-right:5px}

/* Kalender-Abo – Zeile mit Link-Feld und Kopier-Button */
.copy-row{display:flex;gap:8px;margin-bottom:16px}
.copy-input{flex:1;font-family:monospace;font-size:14px;padding:6px 10px}
