/* EHS Kostenverwaltung v5 — components.css */
.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.card-header{background:linear-gradient(90deg,var(--ehs-light),#fff);border-bottom:2px solid var(--ehs-border);padding:16px 24px;display:flex;align-items:center;gap:10px}
.card-header h2{font-size:16px;font-weight:700;color:var(--ehs-dark)}
.ch-icon{width:32px;height:32px;background:var(--ehs-blue);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;flex-shrink:0}
.card-body{padding:24px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.form-group{margin-bottom:18px}
label{display:block;font-size:12px;font-weight:700;color:var(--ehs-gray);margin-bottom:6px;text-transform:uppercase;letter-spacing:.8px}
input,select{width:100%;padding:10px 14px;border:1.5px solid var(--ehs-border);border-radius:8px;font-size:14px;font-family:inherit;background:#fff;color:var(--ehs-text);transition:border-color .2s,box-shadow .2s;outline:none}
input:focus,select:focus{border-color:var(--ehs-blue);box-shadow:0 0 0 3px rgba(0,159,227,.12)}
input.invalid{border-color:var(--ehs-danger)!important}
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s;letter-spacing:.3px}
.btn-primary{background:linear-gradient(135deg,var(--ehs-blue),#00b8f0);color:#fff;box-shadow:0 4px 14px rgba(0,159,227,.35);width:100%;justify-content:center;padding:13px}
.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,159,227,.45)}
.btn-primary:disabled{opacity:.6;cursor:not-allowed}
.btn-success{background:linear-gradient(135deg,#27ae60,#219a52);color:#fff;box-shadow:0 4px 14px rgba(39,174,96,.3);width:100%;justify-content:center;padding:13px}
.btn-danger{background:var(--ehs-danger);color:#fff;flex:1;justify-content:center}
.btn-ghost{background:#f0f4f8;color:var(--ehs-text);flex:1;justify-content:center}
.btn-icon{background:none;border:none;cursor:pointer;padding:4px 8px;color:#ccc;font-size:15px;border-radius:4px;transition:all .15s}
.btn-icon:hover{color:var(--ehs-danger);background:#fff0ee}
.btn-sm{padding:7px 14px;font-size:13px}
.stat-card{background:#fff;border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow);border-top:3px solid var(--ehs-blue)}
.sc-icon{font-size:22px;margin-bottom:6px}
.sc-val{font-size:28px;font-weight:700;color:#3a3a3a}
.sc-lbl{font-size:12px;color:var(--ehs-gray);margin-top:4px;text-transform:uppercase;letter-spacing:.8px}
.filter-bar{background:#fff;border-radius:var(--radius);padding:16px 24px;box-shadow:var(--shadow);margin-bottom:24px;display:flex;gap:16px;flex-wrap:wrap;align-items:flex-end}
.filter-bar .fg{flex:1;min-width:160px}
.filter-bar label{font-size:11px}
.filter-bar select{padding:8px 12px;font-size:13px}
.filter-total{background:var(--ehs-blue);color:#fff;border-radius:8px;padding:8px 20px;text-align:center;flex-shrink:0}
.ft-val{font-size:20px;font-weight:700}
.ft-lbl{font-size:10px;opacity:.7;letter-spacing:1px;text-transform:uppercase}
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
thead tr{background:var(--ehs-blue);color:#fff}
thead th{padding:11px 14px;text-align:left;font-weight:600;font-size:12px;letter-spacing:.6px;white-space:nowrap}
thead th.r{text-align:right}
tbody tr{border-bottom:1px solid var(--ehs-border);transition:background .1s}
tbody tr:nth-child(even){background:var(--ehs-bg)}
tbody tr:hover{background:var(--ehs-light)}
tbody td{padding:9px 14px;color:var(--ehs-text)}
tbody td.r{text-align:right;font-weight:700;color:var(--ehs-blue)}
tfoot tr{background:var(--ehs-blue);color:#fff}
tfoot td{padding:10px 14px;font-weight:700}
tfoot td.r{text-align:right;font-size:16px}
.entry-item{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;border-radius:8px;margin-bottom:8px;background:var(--ehs-bg);border-left:4px solid var(--ehs-blue);transition:background .15s}
.entry-item:hover{background:var(--ehs-light)}
.ei-name{font-weight:700;font-size:14px;color:#3a3a3a}
.ei-meta{font-size:12px;color:var(--ehs-gray);margin-top:2px}
.ei-amount{font-weight:700;color:var(--ehs-blue);font-size:16px;white-space:nowrap;margin:0 10px}
.badge{display:inline-block;padding:2px 10px;border-radius:20px;font-size:11px;font-weight:700;background:var(--ehs-light);color:var(--ehs-blue)}
.chart-box{padding:24px}
.chart-box h3{font-size:14px;font-weight:700;color:var(--ehs-dark);margin-bottom:16px;text-transform:uppercase;letter-spacing:.8px}
.toast{position:fixed;bottom:28px;right:28px;z-index:9999;background:#27ae60;color:#fff;padding:14px 22px;border-radius:10px;font-weight:700;font-size:14px;box-shadow:0 4px 20px rgba(0,0,0,.2);transform:translateY(80px);opacity:0;transition:all .3s cubic-bezier(.34,1.56,.64,1);pointer-events:none}
.toast.show{transform:translateY(0);opacity:1}
.toast.err-toast{background:var(--ehs-danger)}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:none;align-items:center;justify-content:center;z-index:2000;backdrop-filter:blur(3px)}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:14px;padding:32px;max-width:420px;width:92%;box-shadow:0 8px 40px rgba(0,0,0,.25);animation:pop .2s ease}
.modal h3{font-size:18px;margin-bottom:10px}
.modal p{color:#666;margin-bottom:24px;font-size:14px}
.modal-actions{display:flex;gap:10px}
.export-summary{background:var(--ehs-bg);border-radius:10px;padding:20px}
.sum-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--ehs-border);font-size:14px}
.sum-row:last-child{border-bottom:none}
.sum-total{display:flex;justify-content:space-between;padding:12px 0 0;font-size:16px;font-weight:700;color:var(--ehs-dark)}
.dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:8px}
.skel{background:linear-gradient(90deg,#eee 25%,#f5f5f5 50%,#eee 75%);background-size:200% 100%;animation:shimmer 1.2s infinite;border-radius:6px;height:16px;margin:6px 0}
.laedle-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);display:none;align-items:center;justify-content:center;z-index:3000;backdrop-filter:blur(4px)}
.laedle-overlay.open{display:flex}
.laedle-modal{background:#fff;border-radius:16px;width:100%;max-width:820px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 12px 60px rgba(0,0,0,.3);animation:pop .2s ease;overflow:hidden}
.laedle-header{background:linear-gradient(135deg,var(--ehs-blue),#00b8f0);padding:20px 24px;color:#fff;flex-shrink:0}
.laedle-header h3{font-size:18px;font-weight:700;margin-bottom:2px}
.laedle-header p{font-size:12px;opacity:.85;margin:0}
.laedle-header-nav{display:flex;align-items:center;gap:10px;margin-top:10px}
.laedle-breadcrumb{font-size:13px;opacity:.85;flex:1}
.laedle-back-btn{background:rgba(255,255,255,.2);border:none;color:#fff;border-radius:7px;padding:5px 12px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}
.laedle-back-btn:hover{background:rgba(255,255,255,.35)}
.laedle-body{flex:1;overflow-y:auto;padding:16px;display:grid;gap:12px;align-content:start}
.laedle-body.view-cat{grid-template-columns:repeat(3,1fr)}
.laedle-body.view-items{grid-template-columns:repeat(3,1fr)}
.laedle-items-banner{grid-column:1/-1}
.kat-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:28px 16px;border-radius:12px;border:2px solid var(--ehs-border);cursor:pointer;transition:all .18s;background:#fff;text-align:center;gap:8px}
.kat-card:hover{border-color:var(--ehs-blue);background:var(--ehs-light);transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,159,227,.12)}
.kat-card .kc-emoji{font-size:36px}
.kat-card .kc-name{font-weight:700;font-size:15px;color:var(--ehs-dark)}
.kat-card .kc-count{font-size:12px;color:var(--ehs-gray)}
.kat-card .kc-badge{background:var(--ehs-blue);color:#fff;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:700;margin-top:2px}
.laedle-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:14px 10px;border-radius:10px;border:2px solid var(--ehs-border);cursor:pointer;transition:all .15s;background:#fff;text-align:center;gap:6px;position:relative}
.laedle-item:hover{border-color:var(--ehs-blue);background:var(--ehs-light)}
.laedle-item.gesperrt{background:#fff5f5;border-color:#ffcccc;cursor:not-allowed;opacity:.7}
.laedle-item.gesperrt:hover{background:#fff5f5;border-color:#ffcccc}
.laedle-item.gesperrt .li-name{text-decoration:line-through;color:#aaa}
.laedle-item.gesperrt .li-price{color:#ccc}
.laedle-no-access{background:#fff0f0;border:2px solid #ffaaaa;border-radius:10px;padding:14px;text-align:center;color:#c0392b;font-weight:700;font-size:14px}
.laedle-item .li-name{font-weight:600;font-size:14px;color:var(--ehs-dark);line-height:1.2}
.laedle-item .li-price{font-weight:700;color:var(--ehs-blue);font-size:16px}
.laedle-item .li-count{position:absolute;top:6px;right:8px;background:var(--ehs-blue);color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;opacity:0;transition:opacity .15s}
.laedle-item.selected .li-count{opacity:1}
.laedle-item.selected{border-color:var(--ehs-blue);background:var(--ehs-light)}
#laedleSearch::placeholder{color:rgba(255,255,255,.65)}
#laedleSearch:focus{background:rgba(255,255,255,.3)}
.laedle-footer{border-top:2px solid var(--ehs-border);padding:14px 20px;background:#fafbfd;flex-shrink:0}
.laedle-warenkorb{margin-bottom:10px;max-height:110px;overflow-y:auto}
.wk-kat-header{font-size:11px;font-weight:700;color:var(--ehs-blue);text-transform:uppercase;letter-spacing:.6px;padding:4px 0 2px;opacity:.8}
.wk-item{display:flex;justify-content:space-between;align-items:center;padding:3px 0;font-size:13px;border-bottom:1px solid var(--ehs-border)}
.wk-item:last-child{border-bottom:none}
.wk-remove{background:none;border:none;cursor:pointer;color:#ccc;font-size:14px;padding:0 4px;border-radius:3px}
.wk-remove:hover{color:var(--ehs-danger)}
.laedle-total-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.laedle-total-row .lt-label{font-size:13px;color:var(--ehs-gray);text-transform:uppercase;letter-spacing:.8px;font-weight:700}
.laedle-total-row .lt-val{font-size:24px;font-weight:700;color:var(--ehs-blue)}
.laedle-btns{display:flex;gap:10px}
.btn-laedle-ok{flex:2;background:linear-gradient(135deg,var(--ehs-blue),#00b8f0);color:#fff;border:none;border-radius:8px;padding:12px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit}
.btn-laedle-ok:disabled{opacity:.4;cursor:not-allowed}
.btn-laedle-cancel{flex:1;background:#f0f4f8;color:var(--ehs-text);border:none;border-radius:8px;padding:12px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit}
.btn-laedle-reset{flex:1;background:linear-gradient(135deg,var(--ehs-blue),#00b8f0);color:#fff;border:none;border-radius:8px;padding:12px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit}
.admin-section{margin-bottom:28px}
.user-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-radius:8px;background:var(--ehs-bg);border-left:4px solid var(--ehs-blue);margin-bottom:8px}
.user-row .ur-name{font-weight:700;font-size:14px}
.user-row .ur-meta{font-size:12px;color:var(--ehs-gray);margin-top:2px}
.user-row .ur-actions{display:flex;gap:6px}
.rolle-admin{background:#fff3cd;color:#856404;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:700}
.rolle-ma{background:var(--ehs-light);color:var(--ehs-blue);border-radius:10px;padding:2px 8px;font-size:11px;font-weight:700}
.inactive-row{opacity:.5}
.preisliste-upload{border:2px dashed var(--ehs-border);border-radius:10px;padding:24px;text-align:center;cursor:pointer;transition:all .2s;margin-top:12px}
.preisliste-upload:hover{border-color:var(--ehs-blue);background:var(--ehs-light)}
.pl-row{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;border-radius:8px;background:var(--ehs-bg);margin-bottom:6px;font-size:14px}
.pl-row .pl-name{font-weight:600}
.pl-row .pl-price{font-weight:700;color:var(--ehs-blue)}
.tg-bewohner-card{background:#fff;border-radius:var(--radius);border:2px solid var(--ehs-border);padding:18px 20px;cursor:pointer;transition:all .18s;position:relative}
.tg-bewohner-card:hover{border-color:var(--ehs-blue);transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,159,227,.15)}
.tg-bewohner-card.selected{border-color:var(--ehs-blue);background:var(--ehs-light)}
.tg-bw-name{font-weight:700;font-size:15px;color:var(--ehs-dark);margin-bottom:4px}
.tg-bw-modus{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;margin-bottom:8px}
.tg-modus-monat{background:#e8f8ee;color:#27ae60}
.tg-modus-woche{background:#e6f6fd;color:#009fe3}
.tg-modus-einzel{background:#fff3cd;color:#856404}
.tg-modus-wohnbereich{background:#ffe5d0;color:#c0392b}
.tg-modus-kein{background:#f0f4f8;color:#6b7a8d}
.tg-bw-betrag{font-size:22px;font-weight:700;color:var(--ehs-blue)}
.tg-bw-sub{font-size:11px;color:var(--ehs-gray);margin-top:2px}
.tg-ausgabe-btn{width:100%;margin-top:12px;background:linear-gradient(135deg,var(--ehs-blue),#00b8f0);color:#fff;border:none;border-radius:8px;padding:11px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit}
.tg-ausgabe-btn:disabled{opacity:.4;cursor:not-allowed}
.tg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.wb-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:4500;backdrop-filter:blur(4px)}
.wb-overlay.open{display:flex}
.wb-modal{background:#fff;border-radius:16px;width:100%;max-width:480px;box-shadow:0 12px 60px rgba(0,0,0,.35);animation:pop .2s ease;overflow:hidden}
.wb-header{background:linear-gradient(135deg,#e74c3c,#c0392b);padding:20px 24px;color:#fff}
.wb-header h3{font-size:18px;font-weight:700;margin-bottom:2px}
.wb-header p{font-size:12px;opacity:.85;margin:0}
.wb-body{padding:24px}
.tg-konto-row{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;border-radius:8px;background:var(--ehs-bg);border-left:4px solid var(--ehs-blue);margin-bottom:8px}
.tg-konto-row .tkr-name{font-weight:700;font-size:14px}
.tg-konto-row .tkr-meta{font-size:12px;color:var(--ehs-gray);margin-top:2px}
.tg-stat-card{background:#fff;border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow);border-top:3px solid #27ae60}
.sig-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:4000;backdrop-filter:blur(4px)}
.sig-overlay.open{display:flex}
.sig-modal{background:#fff;border-radius:16px;width:100%;max-width:560px;box-shadow:0 12px 60px rgba(0,0,0,.35);animation:pop .2s ease;overflow:hidden}
.sig-header{background:linear-gradient(135deg,var(--ehs-blue),#00b8f0);padding:20px 24px;color:#fff}
.sig-header h3{font-size:18px;font-weight:700;margin-bottom:2px}
.sig-header p{font-size:12px;opacity:.85;margin:0}
.sig-info{padding:16px 24px;background:var(--ehs-bg);border-bottom:1px solid var(--ehs-border);display:grid;grid-template-columns:1fr 1fr;gap:8px}
.sig-info-item{font-size:13px;color:var(--ehs-gray)}
.sig-info-item strong{display:block;color:var(--ehs-text);font-size:14px;margin-top:2px}
.sig-canvas-wrap{padding:20px 24px}
.sig-canvas-wrap label{display:block;font-size:11px;font-weight:700;color:var(--ehs-gray);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px}
#sigCanvas{display:block;width:100%;height:180px;border:2px solid var(--ehs-border);border-radius:10px;cursor:crosshair;touch-action:none;background:#fafbff}
#sigCanvas.has-sig{border-color:var(--ehs-blue)}
.sig-hint{font-size:11px;color:var(--ehs-gray);text-align:center;margin-top:6px}
.sig-actions{padding:16px 24px;display:flex;gap:10px;border-top:1px solid var(--ehs-border)}
.btn-sig-clear{background:#f0f4f8;color:var(--ehs-text);border:none;border-radius:8px;padding:10px 18px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}
.btn-sig-clear:hover{background:#e0e8f0}
.btn-sig-save{flex:1;background:linear-gradient(135deg,var(--ehs-blue),#00b8f0);color:#fff;border:none;border-radius:8px;padding:12px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;box-shadow:0 4px 14px rgba(0,159,227,.35)}
.btn-sig-save:disabled{opacity:.4;cursor:not-allowed}
.btn-sig-cancel{background:#f0f4f8;color:var(--ehs-text);border:none;border-radius:8px;padding:12px 18px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit}
.sig-archive-item{background:#fff;border-radius:10px;border:1px solid var(--ehs-border);padding:16px;margin-bottom:12px;display:flex;align-items:center;gap:16px}
.sig-archive-img{width:180px;height:100px;object-fit:contain;border:1px solid var(--ehs-border);border-radius:6px;background:#fafbff;flex-shrink:0}
.sig-archive-info{flex:1}
.sig-archive-info .sai-name{font-weight:700;font-size:14px;color:var(--ehs-dark)}
.sig-archive-info .sai-meta{font-size:12px;color:var(--ehs-gray);margin-top:3px}
.sig-archive-actions{display:flex;gap:6px;flex-shrink:0}
.btn-sig-dl{background:var(--ehs-light);color:var(--ehs-blue);border:none;border-radius:6px;padding:7px 12px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit}
.btn-sig-dl:hover{background:var(--ehs-blue);color:#fff}
.btn-sig-del{background:#fff0ee;color:var(--ehs-danger);border:none;border-radius:6px;padding:7px 10px;font-size:12px;cursor:pointer;font-family:inherit}
.btn-sig-del:hover{background:var(--ehs-danger);color:#fff}
.sig-filter-bar{background:#fff;border-radius:var(--radius);padding:14px 20px;box-shadow:var(--shadow);margin-bottom:20px;display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}
.sig-filter-bar .fg{flex:1;min-width:150px}
