:root{
  --bg:#f7f8fb; --card:#fff; --text:#1c1e21; --muted:#6b7280; --line:#e5e7eb;
  --primary:#2563eb; --success:#16a34a; --danger:#dc2626; --info:#0ea5e9; --secondary:#334155;
}
*{box-sizing:border-box} body{margin:0;background:var(--bg);color:var(--text);font:16px/1.5 system-ui,Segoe UI,Roboto,Arial}
.wrap{max-width:1100px;margin:0 auto;padding:16px}
.topbar{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center}
.brand{display:flex;gap:10px;align-items:center}
nav .nav{margin-left:12px;color:var(--secondary);text-decoration:none;padding:8px 10px;border-radius:8px}
nav .nav:hover{background:#eef2ff}
h1,h2,h3{margin:16px 0 8px}
.muted{color:var(--muted)}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:10px}
.btn{display:inline-block;padding:10px 14px;border-radius:12px;text-decoration:none;border:1px solid transparent;cursor:pointer}
.btn.primary{background:var(--primary);color:#fff}
.btn.secondary{background:#fff;color:var(--primary);border-color:var(--primary)}
.btn.danger{background:var(--danger);color:#fff}
.btn.danger.ghost{background:#fff;color:var(--danger);border-color:var(--danger)}
.btn.info{background:var(--info);color:#fff}
.btn.success{background:var(--success);color:#fff}
.alert{padding:10px 14px;border-radius:12px;margin:10px 0}
.alert.success{background:#ecfdf5;border:1px solid #bbf7d0}
.alert.danger{background:#fef2f2;border:1px solid #fecaca}
.alert.info{background:#eff6ff;border:1px solid #bfdbfe}
.form{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px;margin:10px 0}
.form label{display:flex;flex-direction:column;gap:6px;margin:8px 0}
.form input,.form textarea,.form select{padding:10px;border:1px solid var(--line);border-radius:10px;background:#fff}
.table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.table th,.table td{padding:10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.table th{background:#f9fafb}
.badge{padding:4px 8px;border-radius:999px;font-size:12px;border:1px solid var(--line)}
.badge.offen{background:#fff7ed;border-color:#fed7aa}
.badge.genehmigt{background:#ecfdf5;border-color:#bbf7d0}
.badge.abgelehnt{background:#fef2f2;border-color:#fecaca}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid2 .span2{grid-column:1/-1}
.mt{margin-top:18px}
.inline{display:inline-flex;gap:8px;align-items:center}
.w-80{width:80px}
.rowline{display:grid;grid-template-columns:1.2fr .4fr .4fr 1fr auto;gap:10px;align-items:start;background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px;margin:8px 0}
.radio,.check{display:flex;gap:8px;align-items:center;margin:6px 0}
.box{padding:10px;border:1px dashed var(--line);border-radius:12px;margin:6px 0;background:#fafafa}
.footer{margin-top:40px;padding:20px 0;border-top:1px solid var(--line);text-align:center;background:#fff}
.footer .wimpel{max-height:60px;display:block;margin:0 auto 8px}
.footer .credit{color:var(--muted);font-size:13px}
/* === Auth Redesign ======================================================= */
:root{
  --bg-grad: linear-gradient(135deg, #0ea5e9 0%, #2563eb 45%, #111827 100%);
  --card:#fff; --text:#0f172a; --muted:#64748b; --line:#e5e7eb;
  --primary:#2563eb; --success:#16a34a; --danger:#dc2626; --info:#0ea5e9; --secondary:#334155;
  --ring: 0 0 0 4px rgba(37,99,235,.15);
}

/* Vollflächiger, ruhiger Hintergrund für Auth */
body.auth {
  min-height: 100vh;
  background: var(--bg-grad) fixed;
  display: grid;
  grid-template-rows: auto 1fr auto;
}

/* Topbar transparenter + dezenter */
body.auth .topbar{
  background: transparent;
  border: none;
}
body.auth .topbar .wrap .brand strong{ color:#f8fafc }
body.auth .topbar .wrap .nav{ color:#e2e8f0 }
body.auth .topbar .wrap .nav:hover{ background:rgba(255,255,255,.12); color:#fff }

/* Auth Shell */
.auth-shell{
  display:grid;
  place-items:center;
  padding: 32px 16px;
}
.auth-card{
  width: min(420px, 92vw);
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.6);
  border-radius: 20px;
  box-shadow:
    0 12px 30px rgba(0,0,0,.15),
    0 2px 8px rgba(0,0,0,.08);
  padding: 26px;
}

/* Kopfbereich */
.auth-head{
  display:flex; align-items:center; gap:12px; margin-bottom:6px;
}
.auth-head .logo-badge{
  width:40px; height:40px; border-radius:12px;
  background: #fff; display:grid; place-items:center;
  box-shadow: 0 6px 16px rgba(0,0,0,.08);
  color: var(--primary); font-size:22px;
}
.auth-subtitle{ color: var(--muted); margin: 0 0 18px; }

/* Formular */
.form.auth label{ margin: 10px 0; }
.form.auth input{
  height: 46px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  transition: box-shadow .15s ease, border-color .15s ease, transform .02s;
  background:#fff;
}
.form.auth input:focus{
  outline: none;
  border-color: var(--primary);
  box-shadow: var(--ring);
}
.form.auth .btn{
  width:100%;
  height:46px;
  border-radius: 12px;
  font-weight: 600;
}
.form.auth .btn.success{ background: linear-gradient(180deg, #22c55e, #16a34a); }
.form.auth .btn.success:hover{ filter: brightness(1.05); }
.form.auth .btn.primary{ background: linear-gradient(180deg, #3b82f6, #2563eb); }
.form.auth .btn.primary:hover{ filter: brightness(1.05); }

/* Linkzeile unter dem Formular */
.auth-links{
  display:flex; gap:10px; flex-wrap:wrap; justify-content:space-between;
  margin-top: 12px;
}
.auth-links .btn{ padding:10px 12px; border-radius:10px; }
.auth-links .btn.secondary{
  background:#fff; color:var(--primary); border-color:var(--primary);
}
.auth-links .btn.secondary:hover{ background:#eef2ff; }

/* Footer auf Auth hell und luftig */
body.auth .footer{
  background: transparent; border: none;
  color: #e5e7eb;
}
body.auth .footer .credit{ color:#e5e7eb }
body.auth .footer .wimpel{ filter: drop-shadow(0 3px 10px rgba(0,0,0,.3)); }

/* Alerts dezenter */
.alert{ border-radius: 12px; }
/* === Auth Redesign ======================================================= */
:root{
  --bg-grad: linear-gradient(135deg, #0ea5e9 0%, #2563eb 45%, #111827 100%);
  --card:#fff; --text:#0f172a; --muted:#64748b; --line:#e5e7eb;
  --primary:#2563eb; --success:#16a34a; --danger:#dc2626; --info:#0ea5e9; --secondary:#334155;
  --ring: 0 0 0 4px rgba(37,99,235,.15);
}
body.auth { min-height: 100vh; background: var(--bg-grad) fixed; display: grid; grid-template-rows: auto 1fr auto; }
body.auth .topbar{ background: transparent; border: none; }
body.auth .topbar .wrap .brand strong{ color:#f8fafc }
body.auth .topbar .wrap .nav{ color:#e2e8f0 }
body.auth .topbar .wrap .nav:hover{ background:rgba(255,255,255,.12); color:#fff }

.auth-shell{ display:grid; place-items:center; padding: 32px 16px; }
.auth-card{
  width: min(420px, 92vw);
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.6);
  border-radius: 20px;
  box-shadow: 0 12px 30px rgba(0,0,0,.15), 0 2px 8px rgba(0,0,0,.08);
  padding: 26px;
}
.auth-head{ display:flex; align-items:center; gap:12px; margin-bottom:6px; }
.auth-head .logo-badge{
  width:40px; height:40px; border-radius:12px; background:#fff; display:grid; place-items:center;
  box-shadow: 0 6px 16px rgba(0,0,0,.08); color: var(--primary); font-size:22px;
}
.auth-subtitle{ color: var(--muted); margin: 0 0 18px; }

.form.auth label{ margin: 10px 0; }
.form.auth input{
  height: 46px; padding: 10px 12px; border: 1px solid var(--line); border-radius: 12px;
  transition: box-shadow .15s ease, border-color .15s ease;
  background:#fff; width:100%;
}
.form.auth input:focus{ outline: none; border-color: var(--primary); box-shadow: var(--ring); }
.form.auth .btn{ width:100%; height:46px; border-radius: 12px; font-weight: 600; }
.form.auth .btn.success{ background: linear-gradient(180deg, #22c55e, #16a34a); color:#fff; }
.form.auth .btn.primary{ background: linear-gradient(180deg, #3b82f6, #2563eb); color:#fff; }
.form.auth .btn.success:hover,.form.auth .btn.primary:hover{ filter: brightness(1.05); }

.auth-links{ display:flex; gap:10px; flex-wrap:wrap; justify-content:space-between; margin-top:12px; }
.auth-links .btn{ padding:10px 12px; border-radius:10px; }
.auth-links .btn.secondary{ background:#fff; color:var(--primary); border:1px solid var(--primary); }
.auth-links .btn.secondary:hover{ background:#eef2ff; }

.pw-wrap{ position: relative; display:flex; align-items:center; }
.pw-wrap input{ padding-right:44px !important; }
.pw-toggle{
  position:absolute; right:6px; top:50%; transform:translateY(-50%);
  border:1px solid var(--line); background:#fff; border-radius:10px; height:36px; min-width:36px;
  display:grid; place-items:center; cursor:pointer;
}
.pw-toggle:hover{ background:#f3f4f6; }

body.auth .footer{ background: transparent; border: none; color: #e5e7eb; }
body.auth .footer .credit{ color:#e5e7eb }
body.auth .footer .wimpel{ filter: drop-shadow(0 3px 10px rgba(0,0,0,.3)); }
.alert{ border-radius:12px; }
/* ===== App Mode (gleich wie Auth-Look) ================================ */
:root{
  --bg-grad: linear-gradient(135deg, #0ea5e9 0%, #2563eb 45%, #111827 100%);
  --card:#fff; --text:#0f172a; --muted:#64748b; --line:#e5e7eb;
  --primary:#2563eb; --success:#16a34a; --danger:#dc2626; --info:#0ea5e9; --secondary:#334155;
  --ring: 0 0 0 4px rgba(37,99,235,.15);
}

body.app.app--gradient{
  min-height:100vh; background: var(--bg-grad) fixed;
  display:grid; grid-template-rows:auto 1fr auto;
}

.topbar--app{
  background: transparent; border:none;
}
.topbar--app .brand strong{ color:#f8fafc }
.topbar--app .nav{ color:#e2e8f0; text-decoration:none; padding:8px 10px; border-radius:10px; }
.topbar--app .nav:hover{ background:rgba(255,255,255,.12); color:#fff }

.app-shell{ padding:28px 16px; }
.page-head{ display:flex; justify-content:space-between; align-items:end; flex-wrap:wrap; gap:12px; margin-bottom:18px; }
.page-title h1{ color:#fff; margin:0 0 4px; }
.page-title .subtitle{ color:#e5e7eb; margin:0; }
.page-actions .btn{ margin-left:8px; }

.cards{ display:grid; grid-template-columns:repeat(auto-fill, minmax(280px,1fr)); gap:16px; }
.card{
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(8px);
  border:1px solid rgba(255,255,255,.6);
  border-radius:20px;
  box-shadow: 0 12px 30px rgba(0,0,0,.15), 0 2px 8px rgba(0,0,0,.08);
  padding:16px;
}
.card-head{ display:flex; justify-content:space-between; gap:10px; align-items:center; }
.card h3{ margin:0 0 6px; }
.badge.date{
  background:#eef2ff; color:#1e3a8a; border:1px solid #c7d2fe;
  padding:4px 8px; border-radius:999px; font-size:12px;
}
.meta{ display:flex; gap:8px; flex-wrap:wrap; margin:8px 0; }
.chip{ background:#f3f4f6; border:1px solid #e5e7eb; border-radius:999px; padding:4px 8px; font-size:12px; color:#334155; }
.muted{ color:var(--muted); }

.btn{ display:inline-block; padding:10px 14px; border-radius:12px; text-decoration:none; border:1px solid transparent; cursor:pointer; }
.btn.primary{ background: linear-gradient(180deg, #3b82f6, #2563eb); color:#fff; }
.btn.secondary{ background:#fff; color:var(--primary); border-color:var(--primary); }
.btn.info{ background: linear-gradient(180deg, #38bdf8, #0ea5e9); color:#fff; }
.btn.primary:hover,.btn.info:hover{ filter:brightness(1.05); }

.footer--app{ background: transparent; border:none; color:#e5e7eb; }
.footer--app .credit{ color:#e5e7eb }
.footer--app .wimpel{ filter: drop-shadow(0 3px 10px rgba(0,0,0,.3)); }

.empty{
  background: rgba(255,255,255,.9);
  border:1px solid rgba(255,255,255,.6);
  border-radius:20px; padding:22px; text-align:center;
  box-shadow: 0 12px 30px rgba(0,0,0,.15), 0 2px 8px rgba(0,0,0,.08);
}
.empty-emoji{ font-size:38px; margin-bottom:6px; }

/* ===== Viewport-Rahmen (dezent) ======================================= */
:root{
  /* Farbe/Deckkraft und Stärke des Rahmens hier anpassen */
  --frame-color: rgba(255,255,255,.65);  /* z.B. #ffffffa6 oder #60a5fa99 */
  --frame-glow:  rgba(255,255,255,.12);  /* weiche Innen-Lichtkante */
  --frame-thick: 2px;                    /* Linienstärke */
  --frame-gap:   clamp(8px, 2vw, 18px);  /* Abstand vom Rand */
  --frame-radius: 22px;                  /* Eckenradius */
}

/* Rahmen für Auth + App (gleiche Bereiche wie dein Hintergrund) */
body.auth,
body.app.app--gradient{
  position: relative;
}

/* Der Rahmen selbst – fixiert am Viewport */
body.auth::after,
body.app.app--gradient::after{
  content: "";
  position: fixed;
  pointer-events: none;
  inset: var(--frame-gap);
  border-radius: var(--frame-radius);
  border: var(--frame-thick) solid var(--frame-color);
  /* sanfter „Passepartout“-Effekt nach innen */
  box-shadow:
    0 0 0 6px var(--frame-glow) inset,
    0 0 40px var(--frame-glow) inset;
  z-index: 3; /* über dem Hintergrund, unter dem Inhalt */
}

/* Inhalt eine Ebene höher, damit der Rahmen nicht verdeckt */
.topbar, .app-shell, .auth-shell, .footer{
  position: relative;
  z-index: 4;
}

/* Optional: Farbverlauf-Rahmen statt einfarbig (einfach einkommentieren) */
/*
body.auth::after,
body.app.app--gradient::after{
  border: none;
  background:
    linear-gradient(#0000, #0000) padding-box,
    linear-gradient(135deg, #93c5fd, #60a5fa, #1f4fbf) border-box;
  border: var(--frame-thick) solid transparent;
}
*/
:root{
  --frame-gap: max(4px, env(safe-area-inset-top), env(safe-area-inset-left), env(safe-area-inset-right), env(safe-area-inset-bottom));
}
/* --- Tabellen-Overflow & Kommentare fixen ------------------------------ */
.table-wrap{
  max-width: 100%;
  overflow-x: auto;          /* nur die Tabelle scrollt, nie die Seite */
  -webkit-overflow-scrolling: touch;
}

.table{
  table-layout: fixed;       /* Spalten behalten Breite, verhindert “Aufblähen” */
  width: 100%;
}

.table th,
.table td{
  vertical-align: top;
  word-wrap: break-word;     /* ältere Browser */
  overflow-wrap: anywhere;   /* moderne Browser – bricht lange Wörter/URLs */
  hyphens: auto;             /* automatisches Trennen, wo möglich */
}

/* Kommentarspalte: begrenzen & schön umbrechen */
.table .col-comment{ width: 32ch; max-width: 44ch; }
.comment-cell{
  white-space: pre-wrap;     /* Zeilenumbrüche respektieren */
  overflow-wrap: anywhere;
  word-break: break-word;
  hyphens: auto;
  color:#334155;
}

/* Die kleine Stunden-Inputbox nicht zu breit werden lassen */
.w-80{ width: 8ch; max-width: 100%; }

/* Buttons/Forms in der Aktionsspalte sauber umbrechbar machen */
.table td form.inline{
  display: inline-flex;
  gap: 6px;
  flex-wrap: wrap;           /* darf umbrechen, statt die Tabelle zu stretchen */
}
.table td form.inline .btn{ white-space: nowrap; }

/* Mobile: Kommentarspalte nicht festklammern */
@media (max-width: 820px){
  .table .col-comment{ width:auto; max-width:none; }
}

