/* intranet.css — Leibfritz Intranet · Corporate Grün/Orange */

:root{
  --gruen:#5aa12f;      --gruen-d:#48831f;   --gruen-l:#eef5e7;
  --orange:#ed960c;     --orange-d:#cf8200;  --orange-l:#fdf1dc;
  --ink:#2b2f2a;        --muted:#717a6b;     --line:#e2e7da;
  --bg:#f2f5ee;         --card:#ffffff;      --rot:#c0392b;
  --radius:10px;        --shadow:0 1px 3px rgba(40,50,30,.08), 0 4px 14px rgba(40,50,30,.05);
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink); background:var(--bg); font-size:15px; line-height:1.5;
}
a{ color:var(--gruen-d); text-decoration:none; }
a:hover{ text-decoration:underline; }
h1,h2,h3{ margin:0 0 .5em; line-height:1.25; }
h1{ font-size:1.55rem; } h2{ font-size:1.2rem; } h3{ font-size:1.02rem; }
small{ color:var(--muted); }

/* ---------- Topbar ---------- */
.topbar{
  display:flex; align-items:center; gap:14px;
  background:var(--card); border-bottom:3px solid var(--gruen);
  padding:10px 18px; position:sticky; top:0; z-index:30; box-shadow:var(--shadow);
}
.logo{ display:flex; align-items:baseline; gap:6px; text-decoration:none; }
.logo:hover{ text-decoration:none; }
.logo-name{ font-weight:800; font-size:1.4rem; color:var(--gruen); letter-spacing:-.5px; }
.logo-dot{ width:8px; height:8px; border-radius:50%; background:var(--orange); display:inline-block; transform:translateY(-2px); }
.logo-sub{ font-weight:600; color:var(--muted); font-size:.85rem; text-transform:uppercase; letter-spacing:1px; }
.topbar-right{ margin-left:auto; display:flex; align-items:center; gap:14px; }
.user-info{ display:flex; flex-direction:column; align-items:flex-end; line-height:1.15; }
.user-name{ font-weight:600; }
.user-rolle{ font-size:.78rem; color:var(--orange-d); }
.nav-toggle{ display:none; background:none; border:0; font-size:1.5rem; cursor:pointer; color:var(--gruen-d); padding:0 4px; }

/* ---------- Layout ---------- */
.layout{ display:flex; align-items:flex-start; min-height:calc(100vh - 120px); }
.sidenav{ width:220px; flex:0 0 220px; padding:18px 12px; position:sticky; top:64px; }
.sidenav ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:3px; }
.sidenav a{
  display:flex; align-items:center; gap:11px; padding:10px 13px; border-radius:8px;
  color:var(--ink); font-weight:500; transition:background .12s,color .12s;
}
.sidenav a:hover{ background:var(--gruen-l); text-decoration:none; }
.sidenav a.active{ background:var(--gruen); color:#fff; box-shadow:0 2px 6px rgba(90,161,47,.35); }
.nav-icon{ font-size:1.05rem; width:22px; text-align:center; }
.content{ flex:1 1 auto; padding:22px 26px; min-width:0; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:7px; cursor:pointer;
  font:inherit; font-weight:600; padding:9px 16px; border-radius:8px; border:1px solid transparent;
  background:#eef0ea; color:var(--ink); transition:background .12s,box-shadow .12s,border-color .12s;
}
.btn:hover{ text-decoration:none; }
.btn-green{ background:var(--gruen); color:#fff; }
.btn-green:hover{ background:var(--gruen-d); color:#fff; }
.btn-orange{ background:var(--orange); color:#fff; }
.btn-orange:hover{ background:var(--orange-d); color:#fff; }
.btn-ghost{ background:transparent; border-color:var(--line); color:var(--ink); }
.btn-ghost:hover{ border-color:var(--gruen); color:var(--gruen-d); }
.btn-danger{ background:#fff; border-color:#e6b8b2; color:var(--rot); }
.btn-danger:hover{ background:var(--rot); color:#fff; }
.btn-sm{ padding:5px 11px; font-size:.85rem; }

/* ---------- Cards ---------- */
.card{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:20px 22px; box-shadow:var(--shadow); margin-bottom:20px; }
.card-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:16px; }
.tile{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow); display:flex; flex-direction:column; gap:6px; transition:transform .1s,box-shadow .1s; }
.tile:hover{ transform:translateY(-2px); box-shadow:0 6px 18px rgba(40,50,30,.1); text-decoration:none; }
.tile .tile-icon{ font-size:1.7rem; }
.tile .tile-title{ font-weight:700; color:var(--ink); }
.tile .tile-sub{ color:var(--muted); font-size:.88rem; }
.tile .tile-zahl{ font-size:1.9rem; font-weight:800; color:var(--gruen); }

.page-head{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-bottom:18px; }
.page-head h1{ margin:0; }
.page-head .spacer{ flex:1 1 auto; }

/* ---------- Tabellen ---------- */
.tabelle{ width:100%; border-collapse:collapse; background:var(--card); }
.tabelle th,.tabelle td{ text-align:left; padding:10px 12px; border-bottom:1px solid var(--line); vertical-align:middle; }
.tabelle thead th{ background:var(--gruen-l); color:var(--gruen-d); font-size:.82rem; text-transform:uppercase; letter-spacing:.4px; border-bottom:2px solid var(--gruen); }
.tabelle tbody tr:hover{ background:#f8faf5; }
.tabelle .rechts{ text-align:right; }
.table-card{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden; }

/* ---------- Badges ---------- */
.badge{ display:inline-block; padding:2px 9px; border-radius:20px; font-size:.74rem; font-weight:700; letter-spacing:.3px; }
.badge-linie{ background:var(--gruen-l); color:var(--gruen-d); }
.badge-mietbus{ background:var(--orange-l); color:var(--orange-d); }
.badge-sonstiges{ background:#eceee9; color:var(--muted); }
.badge-grau{ background:#eceee9; color:var(--muted); }

/* ---------- Formulare ---------- */
.form-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:14px 18px; }
.feld{ display:flex; flex-direction:column; gap:5px; }
.feld.voll{ grid-column:1/-1; }
.feld label{ font-weight:600; font-size:.86rem; color:var(--muted); }
.feld input,.feld select,.feld textarea{
  font:inherit; padding:9px 11px; border:1px solid var(--line); border-radius:8px; background:#fff; color:var(--ink); width:100%;
}
.feld input:focus,.feld select:focus,.feld textarea:focus{ outline:none; border-color:var(--gruen); box-shadow:0 0 0 3px rgba(90,161,47,.15); }
.feld textarea{ min-height:70px; resize:vertical; }
.form-actions{ display:flex; gap:10px; margin-top:18px; flex-wrap:wrap; }
.hint{ font-size:.8rem; color:var(--muted); }

/* ---------- Hinweise ---------- */
.hinweis{ padding:11px 15px; border-radius:8px; margin-bottom:16px; font-weight:500; border:1px solid; }
.hinweis-ok{ background:var(--gruen-l); border-color:#bcdca6; color:var(--gruen-d); }
.hinweis-fehler{ background:#fdecea; border-color:#e6b8b2; color:var(--rot); }
.leer{ color:var(--muted); padding:30px; text-align:center; }

/* ---------- Dienstplan ---------- */
.dp-kopf{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-bottom:16px; }
.dp-kw{ font-weight:700; font-size:1.15rem; }
.dp-kw small{ display:block; font-weight:500; }
.dp-nav{ display:flex; gap:6px; }

.table-scroll{ overflow-x:auto; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); background:var(--card); }
.woche{ width:100%; border-collapse:collapse; min-width:880px; }
.woche th,.woche td{ border:1px solid var(--line); vertical-align:top; padding:0; }
.woche thead th{ background:var(--gruen-l); color:var(--gruen-d); padding:8px 10px; font-size:.82rem; text-align:center; }
.woche thead th.heute{ background:var(--gruen); color:#fff; }
.woche .fahrer-sp{ position:sticky; left:0; z-index:2; background:var(--card); min-width:150px; max-width:170px; padding:10px 12px; font-weight:600; }
.woche thead .fahrer-sp{ background:var(--gruen-l); }
.woche .zelle{ min-width:120px; padding:6px; }
.woche td.heute{ background:#fbfdf8; }

.dienst{
  display:block; background:#fff; border:1px solid var(--line); border-left:4px solid var(--gruen);
  border-radius:7px; padding:6px 8px; margin-bottom:6px; color:var(--ink); font-size:.82rem; line-height:1.3;
}
.dienst:hover{ text-decoration:none; box-shadow:0 2px 8px rgba(40,50,30,.12); }
.dienst.typ-mietbus{ border-left-color:var(--orange); }
.dienst.typ-sonstiges{ border-left-color:var(--muted); }
.dienst .d-zeit{ font-weight:700; }
.dienst .d-kunde{ font-weight:600; }
.dienst .d-meta{ color:var(--muted); }
.dienst-add{ display:block; text-align:center; color:var(--muted); border:1px dashed var(--line); border-radius:7px; padding:4px; font-size:1rem; }
.dienst-add:hover{ border-color:var(--gruen); color:var(--gruen); text-decoration:none; background:var(--gruen-l); }

/* Eigene Wochenansicht (Fahrer) als Tageskarten */
.tag-karten{ display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:14px; }
.tag-karte{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden; }
.tag-karte > h3{ margin:0; padding:9px 14px; background:var(--gruen-l); color:var(--gruen-d); font-size:.95rem; }
.tag-karte.heute > h3{ background:var(--gruen); color:#fff; }
.tag-karte .tk-body{ padding:10px 12px; }
.tag-karte .dienst{ font-size:.86rem; }
.tag-karte .tk-leer{ color:var(--muted); padding:6px 2px; font-size:.86rem; }

/* ---------- Login (eigenständige Seite) ---------- */
.login-body{ min-height:100vh; display:flex; align-items:center; justify-content:center; padding:20px;
  background:linear-gradient(135deg,#eef5e7 0%,#f2f5ee 55%,#fdf1dc 100%); }
.login-card{ background:#fff; width:100%; max-width:400px; border-radius:14px; box-shadow:0 10px 40px rgba(40,50,30,.15); padding:30px 28px; }
.login-logo{ text-align:center; margin-bottom:6px; }
.login-logo .logo-name{ font-size:2rem; }
.login-claim{ text-align:center; color:var(--muted); margin-bottom:22px; font-size:.9rem; }
.login-tabs{ display:flex; gap:6px; background:var(--bg); padding:5px; border-radius:10px; margin-bottom:20px; }
.login-tab{ flex:1; text-align:center; padding:9px; border-radius:7px; cursor:pointer; font-weight:600; color:var(--muted); }
.login-tab.active{ background:#fff; color:var(--gruen-d); box-shadow:var(--shadow); }
.login-pane{ display:none; }
.login-pane.active{ display:block; }
.login-pane .feld{ margin-bottom:14px; }
.pin-input{ letter-spacing:.5em; text-align:center; font-size:1.4rem !important; font-weight:700; }
.login-card .btn{ width:100%; justify-content:center; }

/* ---------- Footer ---------- */
.footer{ display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap; color:var(--muted); font-size:.82rem; padding:16px 26px; border-top:1px solid var(--line); margin-top:10px; }

/* ---------- Responsive ---------- */
@media (max-width:820px){
  .nav-toggle{ display:block; }
  .sidenav{
    position:fixed; top:57px; left:0; bottom:0; width:230px; background:var(--card);
    box-shadow:4px 0 18px rgba(0,0,0,.12); transform:translateX(-105%); transition:transform .2s; z-index:40; overflow-y:auto;
  }
  .sidenav.open{ transform:translateX(0); }
  .content{ padding:16px 14px; }
  .user-info{ display:none; }
  .page-head h1{ font-size:1.3rem; }
}
@media (max-width:480px){
  .topbar{ padding:9px 12px; }
  .logo-sub{ display:none; }
}

/* ===========================================================================
   FAHRER-APP (mobil)
   =========================================================================== */
.app-body{ background:var(--bg); margin:0; }
.app-top{
  position:sticky; top:0; z-index:20; display:flex; align-items:center; gap:10px;
  background:#fff; border-bottom:3px solid var(--gruen); padding:10px 16px; box-shadow:var(--shadow);
}
.app-top .logo-name{ font-size:1.25rem; }
.app-top .app-user{ margin-left:auto; font-weight:600; color:var(--muted); font-size:.9rem; }
.app-top .app-logout{ font-size:1.3rem; color:var(--gruen-d); text-decoration:none; padding:0 4px; }
.app-main{ max-width:640px; margin:0 auto; padding:14px 14px 80px; }

.app-bottomnav{
  position:fixed; left:0; right:0; bottom:0; z-index:30; display:flex; background:#fff;
  border-top:1px solid var(--line); box-shadow:0 -2px 10px rgba(40,50,30,.06);
}
.app-bottomnav a{
  flex:1; text-align:center; padding:9px 4px 7px; color:var(--muted); text-decoration:none;
  font-size:.72rem; font-weight:600; display:flex; flex-direction:column; align-items:center; gap:2px;
}
.app-bottomnav a.active{ color:var(--gruen-d); }
.app-bottomnav .bn-ico{ font-size:1.25rem; }

.app-kw{ display:flex; align-items:center; gap:8px; margin-bottom:14px; }
.app-kw-btn{ width:42px; height:42px; flex:0 0 42px; display:flex; align-items:center; justify-content:center;
  background:#fff; border:1px solid var(--line); border-radius:10px; font-size:1.3rem; color:var(--gruen-d); text-decoration:none; }
.app-kw-mid{ flex:1; text-align:center; font-weight:700; }
.app-kw-mid small{ display:block; font-weight:500; color:var(--muted); }

.app-tag{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); margin-bottom:12px; overflow:hidden; }
.app-tag-kopf{ background:var(--gruen-l); color:var(--gruen-d); font-weight:700; padding:8px 14px; }
.app-tag.heute .app-tag-kopf{ background:var(--gruen); color:#fff; }
.app-frei{ color:var(--muted); padding:12px 14px; }
.app-dienst{ padding:11px 14px; border-top:1px solid var(--line); border-left:4px solid var(--gruen); }
.app-dienst:first-of-type{ border-top:0; }
.app-dienst.typ-mietbus{ border-left-color:var(--orange); }
.app-dienst.typ-sonstiges{ border-left-color:var(--muted); }
.ad-top{ display:flex; align-items:center; gap:8px; margin-bottom:3px; }
.ad-zeit{ font-weight:700; font-size:1.05rem; }
.ad-kunde{ font-weight:600; }
.ad-auf{ color:var(--ink); }
.ad-meta{ color:var(--muted); font-size:.9rem; margin-top:2px; }
.ad-maps{ color:var(--orange-d); font-weight:600; margin-left:4px; }

.app-h{ font-size:1.1rem; margin:6px 2px 12px; }
.app-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); padding:16px; margin-bottom:18px; }
.app-card .feld{ margin-bottom:12px; }
.app-row2{ display:grid; grid-template-columns:2fr 1fr; gap:12px; }
.app-leer{ color:var(--muted); background:#fff; border:1px dashed var(--line); border-radius:var(--radius); padding:20px; text-align:center; margin-bottom:16px; }

.app-doc{ display:flex; align-items:center; gap:12px; background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:12px 14px; margin-bottom:10px; color:var(--ink); text-decoration:none; }
.app-doc-ico{ font-size:1.5rem; }
.app-doc-txt{ flex:1; min-width:0; display:flex; flex-direction:column; }
.app-doc-name{ font-weight:700; }
.app-doc-meta{ color:var(--muted); font-size:.85rem; }
.app-doc-go{ font-size:1.4rem; color:var(--gruen); }

.app-beleg{ display:flex; align-items:center; gap:10px; background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:12px 14px; margin-bottom:10px; }
.app-beleg .ab-l{ flex:1; min-width:0; }
.app-beleg .ab-kat{ color:var(--muted); font-size:.85rem; }
.app-beleg .ab-betrag{ font-weight:800; font-size:1.1rem; }
.app-beleg .ab-besch{ color:var(--muted); font-size:.88rem; }
.app-beleg .ab-r{ display:flex; flex-direction:column; gap:6px; align-items:flex-end; }
