:root{
  --bg:#050505;
  --panel:#0b0d10;
  --panel2:#11151a;
  --panel3:#171c22;
  --line:#252b33;
  --text:#f1f4f8;
  --muted:#8d99a6;
  --blue:#5884ad;
  --blue2:#406b90;
  --danger:#c44;
  --ok:#35b66c;
  --warn:#d3a230;
}
*{box-sizing:border-box}
html,body{min-height:100%}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text);font-size:13px;line-height:1.35}
h1,h2,h3,p{margin-top:0}h1{font-size:20px;margin-bottom:3px}h2{font-size:15px;margin-bottom:8px}h3{font-size:13px;margin-bottom:6px}.muted{color:var(--muted);font-size:12px}.small{font-size:11px}.mono{font-family:Consolas,Menlo,monospace}
.login-body{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:22px;background:radial-gradient(circle at top,rgba(88,132,173,.18),transparent 34%),#030303}.login-card{width:min(390px,100%);background:rgba(11,13,16,.96);border:1px solid var(--line);border-radius:12px;padding:24px;box-shadow:0 20px 60px rgba(0,0,0,.55)}.login-logo{width:100%;max-height:118px;object-fit:contain;margin-bottom:14px}
label{display:block;margin:12px 0 5px;color:#dce5ef;font-size:12px}input,select,textarea{width:100%;padding:9px 10px;border-radius:7px;border:1px solid var(--line);background:#07090c;color:var(--text);font-size:13px}button,.btn,.logout{display:inline-flex;align-items:center;gap:6px;border:0;border-radius:7px;background:var(--blue);color:#fff;font-weight:700;padding:8px 11px;text-decoration:none;cursor:pointer;font-size:12px;line-height:1}.btn.secondary{background:var(--panel3);border:1px solid var(--line);color:var(--text)}.btn.light,.logout{background:#fff;color:#050607}.alert{padding:10px 12px;border-radius:8px;background:#17202c;margin:12px 0}.alert.error{background:#321316;color:#ffdede}.alert.success{background:#12301f;color:#d8ffe8}
.app-shell{display:flex;min-height:100vh}.sidebar{width:230px;flex:0 0 230px;background:#070809;border-right:1px solid var(--line);padding:14px 12px;position:sticky;top:0;height:100vh;overflow:auto}.sidebar-logo{display:block;width:92%;max-height:72px;object-fit:contain;margin:8px auto 16px auto}.sidebar-section{border-top:1px solid var(--line);padding-top:10px;margin-top:10px}.sidebar-title{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:800;margin:0 0 7px}.online-list{display:flex;flex-direction:column;gap:5px}.online-row{display:flex;align-items:flex-start;gap:7px;padding:5px 6px;border-radius:7px;background:#0d1014;border:1px solid transparent}.online-row:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--ok);margin-top:4px;flex:0 0 7px}.online-row span{display:block;font-weight:700;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.online-row small{display:block;color:var(--muted);font-size:10px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar nav{display:flex;flex-direction:column;gap:4px}.sidebar nav a{display:flex;align-items:center;gap:8px;color:#dce5ef;text-decoration:none;padding:8px 9px;border-radius:7px;border:1px solid transparent;font-weight:700;font-size:12px}.sidebar nav a:hover,.sidebar nav a.active{background:var(--panel2);border-color:var(--line);color:#fff}.sidebar-footer{margin-top:14px;color:var(--muted);font-size:10px}
.main{flex:1;min-width:0;padding:16px 18px}.topbar{height:50px;display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px;border-bottom:1px solid var(--line);padding-bottom:10px}.topbar-actions{display:flex;align-items:center;gap:8px}.user-pill{background:var(--panel2);border:1px solid var(--line);border-radius:999px;padding:6px 10px;font-size:11px;color:#dce5ef}.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:10px}.card{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:12px;box-shadow:0 10px 25px rgba(0,0,0,.18)}.big{font-size:30px;font-weight:800;margin:3px 0 2px}.status-dot:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--blue);margin-right:6px}.status-dot.ok:before{background:var(--ok)}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:9px;background:#080a0d}table.compact{width:100%;border-collapse:collapse;font-size:12px;min-width:900px}table.compact th,table.compact td{padding:5px 7px;border-bottom:1px solid #242a31;border-right:1px solid #1d2228;white-space:nowrap}table.compact th{background:#111923;color:#eef4fb;font-size:11px;text-align:left}table.compact tr:nth-child(even) td{background:#0d1014}table.compact tr:hover td{background:#15202a}.badge{display:inline-block;padding:2px 6px;border-radius:999px;background:var(--panel3);border:1px solid var(--line);font-size:10px;font-weight:700}.badge.ok{background:#0f2a1a;border-color:#1f6b3c;color:#d8ffe8}.badge.warn{background:#2d230c;border-color:#6b541f;color:#fff3cf}
.module-placeholder{max-width:1100px}.module-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
@media(max-width:1100px){.grid{grid-template-columns:repeat(2,minmax(0,1fr))}.sidebar{width:210px;flex-basis:210px}}
@media(max-width:760px){.app-shell{display:block}.sidebar{position:relative;width:auto;height:auto}.main{padding:14px}.grid{grid-template-columns:1fr}.topbar{height:auto;align-items:flex-start}.topbar-actions{flex-direction:column;align-items:flex-end}}

/* Paket 3: Projekte */
.module-head{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:12px;
    margin-bottom:12px;
}
.filterbar{
    display:grid;
    grid-template-columns: minmax(220px,1fr) 160px auto auto;
    gap:8px;
    align-items:end;
    margin:10px 0 12px;
}
.form-card{max-width:1000px}
.form-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px 12px;
}
.form-grid .span-2{grid-column:span 2}
textarea{resize:vertical}
@media(max-width:760px){
    .module-head{display:block}
    .filterbar{grid-template-columns:1fr}
    .form-grid{grid-template-columns:1fr}
    .form-grid .span-2{grid-column:auto}
}


/* Paket 4: Projektfunktionen */
.row-actions{
    display:flex;
    flex-wrap:wrap;
    gap:5px;
}
.btn.danger{
    background:#3a1216;
    border:1px solid #6b1f2b;
    color:#ffdede;
}
.project-tabs{
    display:flex;
    flex-wrap:wrap;
    gap:6px;
    border-bottom:1px solid var(--line);
    margin:4px 0 12px;
    padding-bottom:8px;
}
.project-tabs a,
.project-tabs span{
    display:inline-flex;
    align-items:center;
    border:1px solid var(--line);
    background:#0d1014;
    color:#dce5ef;
    border-radius:7px;
    padding:6px 9px;
    font-size:12px;
    text-decoration:none;
    font-weight:700;
}
.project-tabs .active{
    background:var(--blue);
    border-color:var(--blue);
    color:#fff;
}
.detail-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
}
.detail-box{
    border:1px solid var(--line);
    background:#080a0d;
    border-radius:9px;
    padding:11px;
}
.detail-box p{
    margin:0 0 6px;
}
.detail-box.span-2{
    grid-column:span 2;
}
@media(max-width:760px){
    .detail-grid{grid-template-columns:1fr}
    .detail-box.span-2{grid-column:auto}
}

/* Paket 8: Projektliste Korrektur */
.project-filterbar{
    display:grid;
    grid-template-columns:minmax(280px,1fr) 210px 72px 105px;
    gap:8px;
    align-items:center;
}
.project-filterbar input,
.project-filterbar select,
.project-filterbar button,
.project-filterbar .btn{
    height:36px;
    min-height:36px;
}
.project-filterbar button,
.project-filterbar .btn{
    justify-content:center;
    padding-top:0;
    padding-bottom:0;
}
.project-filterbar select{
    min-width:210px;
    padding-right:28px;
}
.project-list{
    min-width:1080px;
}
.project-list .actions-col{
    width:112px;
}
.project-actions{
    display:flex;
    align-items:center;
    gap:5px;
    position:relative;
    white-space:nowrap;
}
.project-actions .btn{
    padding:6px 8px;
    font-size:11px;
}
.dropdown-actions{
    position:relative;
    display:inline-flex;
}
.icon-btn{
    width:28px;
    height:28px;
    border-radius:7px;
    border:1px solid var(--line);
    background:var(--panel3);
    color:#fff;
    font-weight:800;
    font-size:14px;
    line-height:1;
    padding:0;
    justify-content:center;
}
.dropdown-panel{
    display:none;
    position:absolute;
    right:0;
    top:31px;
    min-width:145px;
    background:#0b0d10;
    border:1px solid var(--line);
    border-radius:8px;
    box-shadow:0 14px 36px rgba(0,0,0,.55);
    z-index:9999;
    overflow:hidden;
}
.dropdown-actions:hover .dropdown-panel,
.dropdown-actions:focus-within .dropdown-panel{
    display:block;
}
.dropdown-panel a{
    display:block;
    padding:8px 10px;
    color:#dce5ef;
    text-decoration:none;
    font-size:12px;
    border-bottom:1px solid #1d2228;
}
.dropdown-panel a:last-child{
    border-bottom:0;
}
.dropdown-panel a:hover{
    background:#15202a;
    color:#fff;
}
.dropdown-panel .danger-link{
    color:#ffdede;
}
.table-wrap{
    overflow:visible;
}
.card{
    overflow:visible;
}
@media(max-width:900px){
    .project-filterbar{
        grid-template-columns:1fr;
    }
    .project-filterbar select{
        min-width:0;
    }
}

/* Paket 9: Mitarbeiter */
.employee-filterbar{
    display:grid;
    grid-template-columns:minmax(280px,1fr) 190px 72px 105px;
    gap:8px;
    align-items:center;
}
.employee-filterbar input,
.employee-filterbar select,
.employee-filterbar button,
.employee-filterbar .btn{
    height:36px;
    min-height:36px;
}
.employee-filterbar button,
.employee-filterbar .btn{
    justify-content:center;
    padding-top:0;
    padding-bottom:0;
}
.employee-list{
    min-width:1050px;
}
.split-row{
    display:grid;
    grid-template-columns:95px 1fr;
    gap:8px;
}
@media(max-width:900px){
    .employee-filterbar{
        grid-template-columns:1fr;
    }
    .split-row{
        grid-template-columns:1fr;
    }
}

/* Paket 13: Korrektur Mitarbeiter und Projektfarben */

/* Projektliste Farben wiederherstellen */
.project-list tr.planning-missing td{
    background:rgba(160,40,40,.20)!important;
}
.project-list tr.planning-partial td{
    background:rgba(180,140,20,.16)!important;
}
.project-list tr.planning-complete td{
    background:rgba(40,135,70,.16)!important;
}
.project-list tr.planning-empty td{
    background:#0d1014;
}
.project-list tr:hover td{
    filter:brightness(1.15);
}
.planning-pill{
    display:inline-flex;
    align-items:center;
    gap:6px;
    padding:3px 8px;
    border-radius:999px;
    border:1px solid var(--line);
    background:#11151a;
    color:#dce5ef;
    font-size:11px;
    font-weight:800;
    white-space:nowrap;
}
.planning-pill:before{
    content:"";
    width:7px;
    height:7px;
    border-radius:50%;
    background:var(--muted);
    flex:0 0 7px;
}
.planning-pill.danger{
    background:#321316;
    border-color:#6b1f2b;
    color:#ffb6b6;
}
.planning-pill.danger:before{
    background:#e05a5a;
}
.planning-pill.warn{
    background:#2d230c;
    border-color:#6b541f;
    color:#ffe08a;
}
.planning-pill.warn:before{
    background:var(--warn);
}
.planning-pill.ok{
    background:#0f2a1a;
    border-color:#1f6b3c;
    color:#8ef0b0;
}
.planning-pill.ok:before{
    background:var(--ok);
}

/* Projektaktionen ohne Dropdown */
.project-list{
    min-width:1280px;
}
.project-list .actions-col{
    width:360px;
}
.project-actions-inline{
    display:flex;
    flex-wrap:wrap;
    gap:5px;
    align-items:center;
    white-space:nowrap;
}
.project-actions-inline .btn{
    padding:5px 7px;
    font-size:11px;
}

/* Schichtfarben behalten */
.shift-list tr.shift-open td{
    background:rgba(160,40,40,.18)!important;
}
.shift-list tr.shift-filled td{
    background:rgba(180,140,20,.14)!important;
}
.shift-list tr.shift-confirmed td{
    background:rgba(40,135,70,.15)!important;
}
.shift-list tr.shift-cancelled td{
    background:#0b0d10!important;
    opacity:.55;
}
.shift-list tr:hover td{
    filter:brightness(1.16);
}

/* Mitarbeiterformular */
.multi-select{
    min-height:145px;
    padding:8px;
}
.multi-select option{
    padding:5px 7px;
}
.qual-badges{
    display:flex;
    flex-wrap:wrap;
    gap:4px;
}
.qual-badge{
    display:inline-flex;
    align-items:center;
    padding:2px 7px;
    border-radius:999px;
    border:1px solid #31404f;
    background:#111923;
    color:#dce5ef;
    font-size:10px;
    font-weight:700;
}
.employee-list{
    min-width:1120px;
}
.form-grid select{
    height:36px;
}

/* Paket 14: Aktionsspalten und Mitarbeiter löschen */

/* Projekte: Aktionen breiter und sauber in einer Zeile */
.project-list{
    min-width:1360px;
}
.project-list .actions-col{
    width:430px;
    min-width:430px;
}
.project-actions-inline{
    display:flex;
    flex-wrap:nowrap;
    gap:5px;
    align-items:center;
    white-space:nowrap;
}
.project-actions-inline .btn{
    padding:5px 7px;
    font-size:11px;
}

/* Mitarbeiter: Aktionen breiter + Löschen */
.employee-list{
    min-width:1180px;
}
.employee-list th:last-child,
.employee-list td:last-child{
    width:230px;
    min-width:230px;
}
.employee-actions-inline{
    display:flex;
    flex-wrap:nowrap;
    gap:5px;
    align-items:center;
    white-space:nowrap;
}
.employee-actions-inline .btn{
    padding:5px 7px;
    font-size:11px;
}
.btn.danger{
    background:#3a1216;
    border:1px solid #6b1f2b;
    color:#ffdede;
}

/* Paket 15: Auditlog */
.audit-table{
    min-width:950px;
}

/* Paket 24A: Meldeliste Checkboxen und echter XLSX Export */
.meldeliste-field-grid{
    display:grid;
    grid-template-columns:repeat(4,minmax(160px,1fr));
    gap:8px;
    margin-top:10px;
}
.meldeliste-check{
    display:flex;
    align-items:center;
    justify-content:flex-start;
    gap:8px;
    min-height:34px;
    padding:8px 10px;
    border:1px solid var(--line);
    border-radius:8px;
    background:#080a0d;
    cursor:pointer;
}
.meldeliste-check input{
    width:auto;
    margin:0;
    flex:0 0 auto;
}
.meldeliste-check span{
    font-size:12px;
    color:#dce5ef;
}
.inline-export-form{
    display:inline-flex;
    margin:0;
}
.inline-export-form button{
    height:30px;
}
@media(max-width:1000px){
    .meldeliste-field-grid{
        grid-template-columns:repeat(2,minmax(160px,1fr));
    }
}
@media(max-width:600px){
    .meldeliste-field-grid{
        grid-template-columns:1fr;
    }
}
