  :root{
    --ink:#16181d;          /* near-black structural ink */
    --ink-2:#3a3f4a;
    --paper:#f3f1ea;        /* blueprint paper warm */
    --paper-2:#eae7dd;
    --line:#cdc8b8;         /* hairline */
    --line-2:#ddd9cc;
    --signal:#ffd400;       /* safety-vest signal yellow */
    --signal-deep:#e0b800;
    --blue:#1b4f9c;         /* blueprint blue */
    --blue-soft:#e4ebf6;
    --ok:#1c7a4d;
    --ok-soft:#dcefe4;
    --warn:#b3540f;
    --warn-soft:#f6e6d6;
    --stop:#9e2b2b;
    --stop-soft:#f2dede;
    --white:#fff;
    --shadow:0 1px 0 var(--line), 0 2px 8px rgba(22,24,29,.04);
    --r:10px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{-webkit-text-size-adjust:100%}
  body{
    font-family:"Inter","Helvetica Neue",Arial,sans-serif;
    background:var(--paper);
    color:var(--ink);
    font-size:14px;line-height:1.5;
    -webkit-font-smoothing:antialiased;
  }
  /* mono utility face for data/codes */
  .mono{font-family:"SFMono-Regular",ui-monospace,"Roboto Mono",Menlo,monospace;font-variant-numeric:tabular-nums;}
  h1,h2,h3,h4{font-weight:760;letter-spacing:-.01em;line-height:1.15}
  button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
  input,select,textarea{font-family:inherit;font-size:14px}
  a{color:var(--blue);text-decoration:none}
  img{max-width:100%;display:block}

  /* ---------- App shell ---------- */
  .app{display:flex;min-height:100vh;}
  /* Sidebar */
  .side{
    width:236px;flex-shrink:0;background:var(--ink);color:#e9e7df;
    display:flex;flex-direction:column;position:sticky;top:0;height:100vh;
  }
  .brand{padding:18px 18px 14px;border-bottom:1px solid #2a2d35;display:flex;align-items:center;gap:10px}
  .brand .glyph{
    width:30px;height:30px;border-radius:7px;background:var(--signal);
    display:grid;place-items:center;color:var(--ink);font-weight:800;flex-shrink:0;
    box-shadow:0 0 0 4px rgba(255,212,0,.12);
  }
  .brand b{font-size:15px;letter-spacing:-.02em;color:#fff}
  .brand small{display:block;font-size:10.5px;color:#8b8f99;letter-spacing:.08em;text-transform:uppercase;font-weight:600}
  .nav{padding:10px 10px;flex:1;overflow:auto}
  .nav .lbl{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:#6f7480;padding:14px 10px 6px;font-weight:700}
  .nav button{
    width:100%;display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:8px;
    color:#c3c6cf;font-size:13.5px;font-weight:500;text-align:left;transition:.12s;
  }
  .nav button .ic{width:18px;text-align:center;font-size:15px;opacity:.85}
  .nav button:hover{background:#22252d;color:#fff}
  .nav button.on{background:#2c3038;color:#fff}
  .nav button.on .ic{color:var(--signal);opacity:1}
  .nav button .badge{margin-left:auto;background:var(--signal);color:var(--ink);font-size:10px;font-weight:800;border-radius:20px;padding:1px 7px}
  .side .who{padding:12px;border-top:1px solid #2a2d35}
  .roleswitch{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#6f7480;font-weight:700;margin-bottom:7px}
  .roleswitch span{display:block;margin-bottom:6px}
  .roles{display:flex;gap:5px}
  .roles button{flex:1;padding:7px 4px;border-radius:7px;background:#22252d;color:#aeb2bb;font-size:11px;font-weight:600;border:1px solid transparent}
  .roles button.on{background:var(--signal);color:var(--ink);border-color:var(--signal-deep)}

  /* Main */
  .main{flex:1;min-width:0;display:flex;flex-direction:column}
  .topbar{
    height:56px;background:var(--paper);border-bottom:1px solid var(--line);
    display:flex;align-items:center;gap:14px;padding:0 22px;position:sticky;top:0;z-index:20;
  }
  .topbar .crumb{font-size:12px;color:var(--ink-2)}
  .topbar .crumb b{color:var(--ink)}
  .search{
    margin-left:auto;display:flex;align-items:center;gap:8px;background:var(--white);
    border:1px solid var(--line);border-radius:8px;padding:7px 11px;width:280px;color:#888;font-size:13px;
  }
  .search input{border:none;outline:none;background:none;flex:1;color:var(--ink)}
  .iconbtn{width:36px;height:36px;border-radius:8px;border:1px solid var(--line);background:var(--white);display:grid;place-items:center;position:relative;font-size:15px}
  .iconbtn .dot{position:absolute;top:7px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--stop);border:1.5px solid var(--white)}
  .content{padding:24px;max-width:1280px;width:100%;margin:0 auto;flex:1}

  /* ---------- Generic UI ---------- */
  .page-h{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}
  .page-h .eyebrow{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);font-weight:700;margin-bottom:4px}
  .page-h h1{font-size:26px}
  .page-h p{color:var(--ink-2);font-size:13.5px;margin-top:3px;max-width:560px}
  .btn{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:8px;font-weight:650;font-size:13px;border:1px solid var(--line);background:var(--white);transition:.12s}
  .btn:hover{border-color:var(--ink-2)}
  .btn.primary{background:var(--signal);border-color:var(--signal-deep);color:var(--ink)}
  .btn.primary:hover{background:var(--signal-deep)}
  .btn.dark{background:var(--ink);color:#fff;border-color:var(--ink)}
  .btn.sm{padding:6px 11px;font-size:12px}

  .grid{display:grid;gap:16px}
  .card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow)}
  .card .ch{padding:14px 16px;border-bottom:1px solid var(--line-2);display:flex;align-items:center;justify-content:space-between;gap:10px}
  .card .ch h3{font-size:14px}
  .card .ch .sub{font-size:11.5px;color:var(--ink-2);font-weight:500}
  .card .cb{padding:16px}

  /* KPI tiles */
  .kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
  .kpi{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:15px 16px;position:relative;overflow:hidden}
  .kpi .k-lbl{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);font-weight:700}
  .kpi .k-val{font-size:30px;font-weight:800;letter-spacing:-.02em;margin-top:6px;line-height:1}
  .kpi .k-val small{font-size:14px;font-weight:600;color:var(--ink-2)}
  .kpi .k-meta{font-size:11.5px;margin-top:8px;font-weight:600}
  .kpi .k-meta.up{color:var(--ok)} .kpi .k-meta.down{color:var(--stop)}
  .kpi .spark{position:absolute;right:12px;top:14px;opacity:.9}

  /* badges / status */
  .tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;letter-spacing:.02em;white-space:nowrap}
  .tag .d{width:6px;height:6px;border-radius:50%}
  .t-open{background:var(--blue-soft);color:var(--blue)} .t-open .d{background:var(--blue)}
  .t-prog{background:var(--signal);color:#6b5800} .t-prog .d{background:#6b5800}
  .t-wait{background:var(--warn-soft);color:var(--warn)} .t-wait .d{background:var(--warn)}
  .t-done{background:var(--ok-soft);color:var(--ok)} .t-done .d{background:var(--ok)}
  .t-stop{background:var(--stop-soft);color:var(--stop)} .t-stop .d{background:var(--stop)}
  .t-neutral{background:var(--paper-2);color:var(--ink-2)} .t-neutral .d{background:var(--ink-2)}

  /* table */
  table{width:100%;border-collapse:collapse}
  thead th{font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-2);text-align:left;padding:10px 14px;border-bottom:1px solid var(--line);font-weight:700;background:var(--paper)}
  tbody td{padding:12px 14px;border-bottom:1px solid var(--line-2);font-size:13px;vertical-align:middle}
  tbody tr{cursor:pointer;transition:.1s}
  tbody tr:hover{background:var(--paper)}
  tbody tr:last-child td{border-bottom:none}
  .avatar{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:800;color:#fff;flex-shrink:0}
  .with-av{display:flex;align-items:center;gap:9px}

  .bar{height:6px;border-radius:6px;background:var(--paper-2);overflow:hidden}
  .bar > i{display:block;height:100%;border-radius:6px;background:var(--blue)}

  .seg{display:inline-flex;background:var(--paper-2);border:1px solid var(--line);border-radius:9px;padding:3px}
  .seg button{padding:6px 13px;border-radius:7px;font-size:12.5px;font-weight:650;color:var(--ink-2)}
  .seg button.on{background:var(--white);color:var(--ink);box-shadow:var(--shadow)}

  /* checklist */
  .check{display:flex;align-items:flex-start;gap:12px;padding:12px 4px;border-bottom:1px solid var(--line-2)}
  .check:last-child{border-bottom:none}
  .check .box{width:22px;height:22px;border-radius:6px;border:2px solid var(--line);flex-shrink:0;display:grid;place-items:center;margin-top:1px;transition:.12s;font-size:13px;color:transparent}
  .check.done .box{background:var(--ok);border-color:var(--ok);color:#fff}
  .check .body{flex:1;min-width:0}
  .check .ti{font-weight:600;font-size:13.5px}
  .check.done .ti{text-decoration:line-through;color:var(--ink-2)}
  .check .me{font-size:11.5px;color:var(--ink-2);margin-top:2px;display:flex;gap:10px;flex-wrap:wrap}
  .check .ph{display:flex;gap:5px;margin-top:7px}
  .check .ph .thumb{width:46px;height:46px;border-radius:7px;border:1px solid var(--line);background-size:cover;background-position:center}
  .check .addph{width:46px;height:46px;border-radius:7px;border:1.5px dashed var(--line);display:grid;place-items:center;color:var(--ink-2);font-size:18px}

  /* timeline / activity */
  .tl{position:relative;padding-left:26px}
  .tl::before{content:"";position:absolute;left:8px;top:4px;bottom:4px;width:2px;background:var(--line-2)}
  .tl .ev{position:relative;padding:0 0 18px}
  .tl .ev::before{content:"";position:absolute;left:-22px;top:3px;width:12px;height:12px;border-radius:50%;background:var(--white);border:2.5px solid var(--blue)}
  .tl .ev.mail::before{border-color:var(--blue)}
  .tl .ev.call::before{border-color:var(--ok)}
  .tl .ev.note::before{border-color:var(--ink-2)}
  .tl .ev.status::before{border-color:var(--signal-deep);background:var(--signal)}
  .tl .ev .et{font-size:11px;color:var(--ink-2);font-weight:600;margin-bottom:2px}
  .tl .ev .eb{background:var(--paper);border:1px solid var(--line-2);border-radius:8px;padding:9px 12px;font-size:13px}
  .tl .ev .eb .who{font-weight:700;font-size:12px}

  .pill-row{display:flex;gap:8px;flex-wrap:wrap}
  .pill{font-size:12px;font-weight:600;padding:5px 11px;border-radius:20px;border:1px solid var(--line);background:var(--white);color:var(--ink-2)}
  .pill.on{background:var(--ink);color:#fff;border-color:var(--ink)}

  .toggle{width:42px;height:24px;border-radius:20px;background:var(--line);position:relative;transition:.15s;flex-shrink:0}
  .toggle::after{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;left:3px;transition:.15s;box-shadow:0 1px 2px rgba(0,0,0,.2)}
  .toggle.on{background:var(--ok)} .toggle.on::after{left:21px}

  .stat-line{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-2)}
  .stat-line:last-child{border-bottom:none}
  .stat-line .nm{flex:1;font-weight:600;font-size:13px}
  .stat-line .val{font-weight:800;font-size:14px;width:54px;text-align:right}

  .obj-card{display:flex;flex-direction:column;overflow:hidden}
  .obj-card .hero{height:120px;background-size:cover;background-position:center;position:relative}
  .obj-card .hero .ov{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(22,24,29,.7))}
  .obj-card .hero .nm{position:absolute;left:14px;bottom:11px;color:#fff;font-weight:750;font-size:15px;text-shadow:0 1px 3px rgba(0,0,0,.4)}
  .obj-card .hero .tg{position:absolute;top:11px;left:11px}
  .obj-card .meta{padding:13px 15px;display:flex;flex-direction:column;gap:9px}
  .obj-card .meta .row{display:flex;justify-content:space-between;font-size:12.5px}
  .obj-card .meta .row span{color:var(--ink-2)}

  .empty{text-align:center;padding:46px 20px;color:var(--ink-2)}
  .empty .ic{font-size:34px;opacity:.4;margin-bottom:10px}

  .hr{height:1px;background:var(--line-2);margin:16px 0;border:none}
  .muted{color:var(--ink-2)}
  .right{text-align:right}.center{text-align:center}

  /* drawer */
  .scrim{position:fixed;inset:0;background:rgba(22,24,29,.42);z-index:40;opacity:0;pointer-events:none;transition:.2s}
  .scrim.on{opacity:1;pointer-events:auto}
  .drawer{position:fixed;top:0;right:0;height:100vh;width:560px;max-width:94vw;background:var(--paper);z-index:50;transform:translateX(100%);transition:.24s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-8px 0 30px rgba(0,0,0,.15)}
  .drawer.on{transform:translateX(0)}
  .drawer .dh{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;justify-content:space-between;gap:12px;background:var(--white)}
  .drawer .dh h2{font-size:18px}
  .drawer .dh .code{font-size:11px;color:var(--ink-2);font-weight:600;letter-spacing:.05em}
  .drawer .db{flex:1;overflow:auto;padding:20px}
  .drawer .x{font-size:20px;color:var(--ink-2);line-height:1}

  .kv{display:grid;grid-template-columns:120px 1fr;gap:8px 14px;font-size:13px}
  .kv dt{color:var(--ink-2);font-weight:600}
  .kv dd{font-weight:600}

  .field{margin-bottom:14px}
  .field label{display:block;font-size:12px;font-weight:700;margin-bottom:5px;color:var(--ink-2)}
  .field input,.field select,.field textarea{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:8px;background:var(--white);outline:none}
  .field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue)}

  .notice{background:var(--blue-soft);border:1px solid #c5d4ec;border-radius:9px;padding:11px 13px;font-size:12.5px;color:var(--blue);display:flex;gap:9px;align-items:flex-start}

  /* offline banner (employee) */
  .offbar{background:var(--ink);color:#e9e7df;font-size:12px;padding:8px 22px;display:flex;align-items:center;gap:10px}
  .offbar .d{width:8px;height:8px;border-radius:50%;background:var(--ok)}
  .offbar.sync .d{background:var(--signal)}
  .offbar b{color:#fff}

  /* mobile employee frame */
  .phonewrap{display:flex;justify-content:center;padding:8px}
  .phone{width:390px;max-width:100%;background:var(--white);border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:0 10px 40px rgba(22,24,29,.12)}
  .phone .pbar{background:var(--ink);color:#fff;padding:10px 16px;display:flex;align-items:center;justify-content:space-between;font-size:12px}
  .phone .pbody{padding:14px;background:var(--paper)}

  @media(max-width:1080px){.kpis{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:860px){
    .side{position:fixed;left:0;top:0;z-index:60;transform:translateX(-100%);transition:.2s}
    .side.open{transform:translateX(0)}
    .menubtn{display:grid!important}
    .search{display:none}
  }
  .menubtn{display:none}
  @media(max-width:560px){.content{padding:16px}.page-h h1{font-size:22px}.kpis{grid-template-columns:1fr 1fr}}
  .cols-2{grid-template-columns:1fr 1fr}
  .cols-3{grid-template-columns:repeat(3,1fr)}
  .cols-12-8{grid-template-columns:1.6fr 1fr}
  @media(max-width:920px){.cols-2,.cols-3,.cols-12-8{grid-template-columns:1fr}}

/* ---------- Server-Portal Ergänzungen ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;background:var(--ink);padding:20px}
.login-card{width:100%;max-width:380px;background:var(--paper);border-radius:14px;padding:30px;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.login-card .glyph{width:46px;height:46px;border-radius:11px;background:var(--signal);display:grid;place-items:center;color:var(--ink);font-weight:800;font-size:22px;margin-bottom:18px}
.login-card h1{font-size:22px;margin-bottom:4px}
.login-card p{color:var(--ink-2);font-size:13px;margin-bottom:20px}
.login-card .err{background:var(--stop-soft);color:var(--stop);padding:10px 12px;border-radius:8px;font-size:13px;margin-bottom:14px;font-weight:600}
.flash{padding:11px 14px;border-radius:9px;font-size:13px;font-weight:600;margin-bottom:16px}
.flash.ok{background:var(--ok-soft);color:var(--ok)} .flash.err{background:var(--stop-soft);color:var(--stop)}
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}
.photo-grid .pi{position:relative;border-radius:9px;overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3;background:var(--paper-2)}
.photo-grid .pi img{width:100%;height:100%;object-fit:cover}
.photo-grid .pi .ts{position:absolute;left:0;right:0;bottom:0;background:rgba(22,24,29,.78);color:#fff;font-size:10px;padding:3px 6px;font-weight:600}
.uploader{border:2px dashed var(--line);border-radius:11px;padding:22px;text-align:center;color:var(--ink-2);cursor:pointer;transition:.15s;background:var(--white)}
.uploader:hover{border-color:var(--blue);color:var(--blue)}
.uploader input{display:none}
.duration-chip{display:inline-flex;align-items:center;gap:6px;background:var(--blue-soft);color:var(--blue);font-weight:700;font-size:12px;padding:4px 11px;border-radius:20px}
.warn-banner{background:var(--warn-soft);border:1px solid #e8c9a3;color:var(--warn);border-radius:9px;padding:11px 14px;font-size:13px;font-weight:600;margin-bottom:14px;display:flex;gap:9px;align-items:flex-start}
a.btn{text-decoration:none}
.tablink{cursor:pointer}
.searchbox{display:flex;gap:8px;margin-bottom:16px}
.searchbox input{flex:1;padding:10px 13px;border:1px solid var(--line);border-radius:9px;background:var(--white)}
.perm-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.perm-grid label{display:flex;align-items:center;gap:9px;padding:9px 11px;border:1px solid var(--line);border-radius:9px;background:var(--white);font-size:13px;cursor:pointer}
.perm-grid input{width:17px;height:17px}
@media(max-width:560px){.perm-grid{grid-template-columns:1fr}}
