*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#1a1a1a;background:#f5f5f7;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}a{color:inherit;text-decoration:none}.main-nav{z-index:50;background:#fff;border-bottom:1px solid #e5e5ea;position:sticky;top:0}.nav-inner{align-items:center;gap:32px;max-width:1400px;height:52px;margin:0 auto;padding:0 20px;display:flex}.nav-brand{letter-spacing:-.3px;color:#1a1a1a;font-size:15px;font-weight:700}.nav-links{gap:4px;display:flex}.nav-link{color:#666;border-radius:8px;padding:6px 12px;font-size:13px;font-weight:500;transition:all .1s}.nav-link:hover{color:#1a1a1a;background:#f0f0f5}.nav-link.active{color:#fff;background:#1c3d6e}.app{max-width:1400px;margin:0 auto;padding:24px 20px}.header{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.header-left h1{letter-spacing:-.5px;font-size:26px;font-weight:700}.header-left .week-range{color:#666;margin-top:2px;font-size:13px}.week-nav{align-items:center;gap:6px;margin-top:8px;display:flex}.btn{color:#1a1a1a;background:#fff;border:1px solid #d1d1d6;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;transition:background .1s;display:inline-flex}.btn:hover{background:#f0f0f5}.btn-icon{padding:6px 10px;font-size:16px;font-weight:400}.btn-back{gap:4px}.btn-primary{color:#fff;background:#1c3d6e;border:none;border-radius:8px;padding:8px 18px;font-size:14px;font-weight:600}.btn-primary:hover{background:#163060}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-danger{color:#dc2626;background:#fff5f5;border:1px solid #fca5a5;border-radius:8px;padding:8px 14px;font-size:14px;font-weight:500}.btn-danger:hover{background:#fee2e2}.btn-danger-outline{color:#dc2626;border-color:#fca5a5}.btn-danger-outline:hover{background:#fff5f5}.btn-cancel{color:#555;background:#fff;border:1px solid #d1d1d6;border-radius:8px;margin-right:auto;padding:8px 14px;font-size:14px;font-weight:500}.btn-cancel:hover{background:#f5f5f7}.grid-card{background:#fff;border:1px solid #e5e5ea;border-radius:16px;overflow-x:auto;box-shadow:0 1px 4px #0000000f}.day-headers{grid-template-columns:150px repeat(7,1fr);gap:6px;min-width:700px;padding:12px 16px 8px;display:grid}.day-header{text-align:center;border-radius:10px;padding:8px 4px}.day-header.today{color:#fff;background:#1c3d6e}.day-header .day-name{letter-spacing:.5px;opacity:.65;font-size:11px;font-weight:600}.day-header.today .day-name{opacity:.85}.day-header .day-date{margin-top:2px;font-size:16px;font-weight:700}.group-header{letter-spacing:1px;text-transform:uppercase;color:#555;align-items:center;gap:8px;padding:12px 16px 6px;font-size:11px;font-weight:700;display:flex}.group-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.group-count{color:#999;font-weight:400}.employee-row{grid-template-columns:150px repeat(7,1fr);align-items:center;gap:6px;min-width:700px;padding:3px 16px;display:grid}.employee-row:last-child{padding-bottom:14px}.employee-name{color:#333;white-space:nowrap;text-overflow:ellipsis;padding-right:8px;font-size:13px;font-weight:500;overflow:hidden}.emp-link{color:#333}.emp-link:hover{color:#1c3d6e;text-decoration:underline}.shift-cell{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:1px;height:44px;transition:filter .1s;display:flex;position:relative}.shift-cell:hover{filter:brightness(.95)}.shift-cell.today-col{outline-offset:-2px;outline:2px solid #c7d8f0}.shift-cell.empty{color:#ccc;filter:none;background:0 0;border:2px dashed #d1d1d6;font-size:20px}.shift-cell.empty:hover{color:#999;background:#fafafa;border-color:#aaa}.cell-label{text-overflow:ellipsis;white-space:nowrap;max-width:100%;padding:0 4px;font-size:13px;font-weight:600;overflow:hidden}.cell-time{opacity:.75;font-size:10px;font-weight:400}.cell-dienst{text-overflow:ellipsis;white-space:nowrap;background:#0000001f;border-radius:4px;max-width:calc(100% - 8px);padding:1px 6px;font-size:10px;font-weight:700;overflow:hidden}.dienst-tag-preview{color:#374151;white-space:nowrap;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;padding:3px 10px;font-size:11px;font-weight:700}.cell-plus-btn{color:#444;opacity:0;background:#ffffffe6;border:1px solid #0000002e;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:14px;line-height:1;transition:opacity .12s;display:flex;position:absolute;top:4px;right:4px}.shift-cell:hover .cell-plus-btn{opacity:1}.empty-state{text-align:center;color:#999;padding:60px 20px}.empty-state p{color:#555;margin-bottom:8px;font-size:15px;font-weight:500}.modal-backdrop{z-index:100;background:#00000059;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:16px;width:100%;max-width:420px;padding:24px;box-shadow:0 20px 60px #0003}.modal-wide{max-width:500px}.modal h2{margin-bottom:3px;font-size:17px;font-weight:700}.modal .modal-subtitle{color:#888;margin-bottom:20px;font-size:12px}.form-row{margin-bottom:14px}.form-row label{color:#555;text-transform:uppercase;letter-spacing:.4px;margin-bottom:5px;font-size:11px;font-weight:700;display:block}.form-row input,.form-row select,.form-row textarea{background:#fafafa;border:1px solid #d1d1d6;border-radius:8px;outline:none;width:100%;padding:9px 12px;font-size:14px}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{background:#fff;border-color:#1c3d6e}.form-row textarea{resize:vertical;min-height:70px}.time-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.label-chips{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.label-chip{color:#333;cursor:pointer;background:#fff;border:1.5px solid #d1d1d6;border-radius:20px;padding:5px 12px;font-size:12px;font-weight:500;transition:all .1s}.label-chip:hover{border-color:#888}.label-chip.selected{color:#fff;background:#1c3d6e;border-color:#1c3d6e}.modal-actions{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.ma-list{border:1px solid #e5e5ea;border-radius:10px;max-height:300px;margin-bottom:16px;overflow-y:auto}.ma-item{border-bottom:1px solid #f0f0f5;align-items:center;gap:10px;padding:10px 14px;display:flex}.ma-item:last-child{border-bottom:none}.ma-item-name{flex:1;font-size:14px;font-weight:500}.ma-item-group{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:500}.ma-item-del{color:#dc2626;background:#fff;border:1px solid #fca5a5;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;display:flex}.ma-item-del:hover{background:#fee2e2}.ma-divider{background:#e5e5ea;height:1px;margin:16px 0}.ma-add-row{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px;display:grid}.ma-add-row input,.ma-add-row select{background:#fafafa;border:1px solid #d1d1d6;border-radius:8px;outline:none;padding:9px 12px;font-size:14px}.ma-add-row input:focus,.ma-add-row select:focus{background:#fff;border-color:#1c3d6e}.detail-header{align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.detail-title{align-items:center;gap:10px;display:flex}.detail-title h1{letter-spacing:-.5px;font-size:26px;font-weight:700}.detail-dept{border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600}.dept-select{cursor:pointer;background:#fff;border-style:solid;border-width:1.5px;border-radius:20px;outline:none;padding:5px 10px;font-size:12px;font-weight:600}.dept-select:focus{box-shadow:0 0 0 2px #c7d8f0}.stats-row{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.stat-chip{border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:600;display:flex}.stat-count{font-weight:700}.month-nav{align-items:center;gap:12px;margin-bottom:12px;display:flex}.month-title{text-align:center;min-width:160px;font-size:16px;font-weight:600}.month-grid-card{background:#fff;border:1px solid #e5e5ea;border-radius:16px;margin-bottom:20px;padding:16px;box-shadow:0 1px 4px #0000000f}.month-day-headers{grid-template-columns:repeat(7,1fr);margin-bottom:8px;display:grid}.month-day-name{text-align:center;letter-spacing:.5px;color:#888;padding:4px 0;font-size:11px;font-weight:700}.month-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.month-cell{cursor:pointer;background:#fafafa;border:1px solid #e5e5ea;border-radius:10px;flex-direction:column;align-items:flex-start;min-height:64px;padding:6px;transition:filter .1s;display:flex}.month-cell:hover{filter:brightness(.97)}.month-cell.out-of-month{opacity:.3;cursor:default}.month-cell.today{outline-offset:-2px;outline:2px solid #1c3d6e}.month-cell.has-entry{border-color:#0000}.month-cell-day{color:#333;margin-bottom:4px;font-size:12px;font-weight:600}.month-cell.has-entry .month-cell-day{color:inherit}.month-cell-label{font-size:11px;font-weight:700}.month-cell-time{opacity:.75;margin-top:1px;font-size:10px}.quick-card{background:#fff;border:1px solid #e5e5ea;border-radius:16px;padding:20px 24px;box-shadow:0 1px 4px #0000000f}.quick-title{margin-bottom:14px;font-size:14px;font-weight:700}.quick-row{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.quick-field{flex-direction:column;gap:5px;display:flex}.quick-field label{color:#555;text-transform:uppercase;letter-spacing:.4px;font-size:11px;font-weight:700}.quick-field input,.quick-field select{background:#fafafa;border:1px solid #d1d1d6;border-radius:8px;outline:none;padding:9px 12px;font-size:14px}.quick-field input:focus,.quick-field select:focus{background:#fff;border-color:#1c3d6e}.settings-card{background:#fff;border:1px solid #e5e5ea;border-radius:16px;padding:24px;box-shadow:0 1px 4px #0000000f}.settings-section-title{margin-bottom:4px;font-size:17px;font-weight:700}.settings-desc{color:#888;margin-bottom:20px;font-size:13px}.settings-list{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.settings-row{background:#fafafa;border:1px solid #e5e5ea;border-radius:10px;align-items:center;gap:10px;padding:10px 14px;display:flex}.settings-name-input{background:#fff;border:1px solid #d1d1d6;border-radius:8px;outline:none;flex:1;padding:7px 10px;font-size:14px;font-weight:500}.settings-name-input:focus{border-color:#1c3d6e}.settings-emp-count{color:#999;white-space:nowrap;font-size:11px}.settings-add-row{border:2px dashed #d1d1d6;border-radius:10px;flex-wrap:wrap;align-items:center;gap:10px;padding:10px 14px;display:flex}.color-swatch{cursor:pointer;background:#fff;border:1px solid #d1d1d6;border-radius:8px;flex-shrink:0;width:36px;height:36px;padding:2px}.color-group{flex-direction:column;align-items:center;gap:3px;display:flex}.color-hint{color:#999;white-space:nowrap;font-size:10px}.st-order{text-align:center;color:#aaa;flex-shrink:0;width:20px;font-size:11px;font-weight:700}.st-preview{white-space:nowrap;border-radius:16px;flex-shrink:0;padding:4px 10px;font-size:12px;font-weight:600}.mv-filter-bar{flex-direction:column;gap:10px;margin-bottom:20px;display:flex}.mv-search{background:#fff;border:1px solid #d1d1d6;border-radius:10px;outline:none;width:100%;padding:10px 14px;font-size:14px}.mv-search:focus{border-color:#1c3d6e}.mv-dept-tabs{flex-wrap:wrap;gap:6px;display:flex}.mv-dept-tab{color:#555;cursor:pointer;background:#fff;border:1.5px solid #d1d1d6;border-radius:20px;padding:5px 14px;font-size:13px;font-weight:500;transition:all .1s}.mv-dept-tab:hover{color:#1a1a1a;border-color:#888}.mv-dept-tab.active{color:#fff;background:#1c3d6e;border-color:#1c3d6e}.mv-list{flex-direction:column;gap:0;display:flex}.mv-group{margin-bottom:8px}.mv-group-header{letter-spacing:1px;text-transform:uppercase;color:#555;align-items:center;gap:8px;padding:12px 0 6px;font-size:11px;font-weight:700;display:flex}.emp-card{background:#fff;border:1px solid #e5e5ea;border-radius:12px;grid-template-columns:48px 1fr auto auto auto;align-items:center;gap:14px;margin-bottom:6px;padding:14px 16px;transition:box-shadow .1s;display:grid}.emp-card:hover{box-shadow:0 2px 8px #00000014}.emp-card.emp-inactive{opacity:.5}.emp-avatar{color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:15px;font-weight:700;display:flex}.emp-avatar:hover{opacity:.85}.emp-info{flex-direction:column;gap:2px;min-width:0;display:flex}.emp-name{color:#1a1a1a;white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;text-decoration:none;overflow:hidden}.emp-name:hover{color:#1c3d6e;text-decoration:underline}.emp-position{color:#888;font-size:12px}.emp-notes{color:#aaa;white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-style:italic;overflow:hidden}.emp-meta{flex-wrap:wrap;justify-content:flex-end;gap:5px;display:flex}.emp-badge{white-space:nowrap;border-radius:10px;padding:3px 9px;font-size:11px;font-weight:600}.emp-badge-neutral{color:#374151;background:#f3f4f6}.emp-badge-red{color:#991b1b;background:#fee2e2}.emp-contact{flex-direction:column;gap:3px;min-width:140px;display:flex}.emp-contact-row{color:#666;white-space:nowrap;font-size:12px}.emp-actions{align-items:center;gap:6px;display:flex}.modal-employee{max-width:560px}.emp-form-grid{grid-template-columns:1fr 1fr;gap:0 16px;display:grid}.checkbox-row{color:#555;cursor:pointer;align-items:center;gap:8px;margin-bottom:4px;font-size:14px;display:flex}.checkbox-row input{cursor:pointer;width:auto}.shift-cell,.day-header.today,.stat-chip,.emp-badge{-webkit-print-color-adjust:exact;print-color-adjust:exact}@media print{@page{size:A4 landscape;margin:1.2cm 1.5cm}.main-nav,.no-print,.cell-plus-btn,.modal-backdrop{display:none!important}body{background:#fff}.app{max-width:100%;padding:0}.header{margin-bottom:10px}.header-left h1{margin-bottom:2px;font-size:18px}.header-left .week-range{font-size:11px}.week-nav{display:none!important}.grid-card{box-shadow:none;border:1px solid #ccc;border-radius:6px;overflow:visible}.day-headers{gap:3px;padding:6px 10px 4px;grid-template-columns:110px repeat(7,1fr)!important;min-width:0!important}.day-header{border-radius:5px;padding:5px 2px}.day-header .day-name{font-size:9px}.day-header .day-date{font-size:12px}.group-header{padding:7px 10px 3px;font-size:9px}.employee-row{gap:3px;padding:2px 10px;grid-template-columns:110px repeat(7,1fr)!important;min-width:0!important}.employee-row:last-child{padding-bottom:8px}.employee-name{font-size:11px}.emp-link{color:#1a1a1a!important;text-decoration:none!important}.shift-cell{border-radius:5px;height:32px}.cell-label{font-size:10px}.cell-dienst{font-size:9px}.cell-time{font-size:8px}.shift-cell.empty{border:1px solid #e0e0e0;background:#fafafa!important}.shift-cell.empty span,.shift-cell.default-frei,.shift-cell.default-nicht{display:none}}.day-default-selector{flex-wrap:wrap;gap:10px;display:flex}.dds-col{flex-direction:column;align-items:center;gap:4px;display:flex}.dds-label{color:#8e8e93;font-size:11px;font-weight:500}.dds-btn{color:#8e8e93;cursor:pointer;background:#f5f5f7;border:1.5px solid #d1d1d6;border-radius:8px;width:42px;height:36px;font-size:13px;font-weight:500;transition:all .15s}.dds-btn:hover{background:#ebebef;border-color:#b0b0b8}.dds-frei{color:#0369a1!important;background:#e0f2fe!important;border-color:#7dd3fc!important}.dds-nicht{color:#991b1b!important;background:#fee2e2!important;border-color:#fca5a5!important}.dds-arbeit{color:#065f46!important;background:#d1fae5!important;border-color:#6ee7b7!important}.form-section-divider{background:#e5e5ea;height:1px;margin:18px 0 14px}.form-section-title{letter-spacing:.6px;text-transform:uppercase;color:#888;margin-bottom:12px;font-size:11px;font-weight:700}.work-counter{color:#6b7280;white-space:nowrap;background:#f3f4f6;border-radius:8px;flex-shrink:0;align-items:center;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:700;display:inline-flex}.work-counter-max{color:#dc2626;background:#fee2e2}.shift-cell.default-frei{color:#0284c7;background:#f0f9ff;border:1.5px dashed #7dd3fc}.shift-cell.default-nicht{color:#dc2626;opacity:.65;background:#fff5f5;border:1.5px dashed #fca5a5}.default-hint{font-size:11px;font-weight:500}.shift-cell.default-arbeit{color:#065f46;background:#f0fdf4;border:1.5px dashed #6ee7b7}.shift-cell.default-arbeit:hover{background:#dcfce7;border-color:#34d399}.shift-cell.cell-at-max{opacity:.4;cursor:not-allowed}.shift-cell.cell-at-max:hover{filter:none}.avail-hint{color:#8e8e93;margin:0 0 10px;font-size:12px}.day-header-holiday{background:#fef9ec}.day-header-holiday .day-name,.day-header-holiday .day-date{color:#92400e}.day-header.today.day-header-holiday{background:#1c3d6e}.day-header.today.day-header-holiday .day-name,.day-header.today.day-header-holiday .day-date{color:#fff}.day-holiday{color:#b45309;text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:100%;margin-top:2px;font-size:9px;font-weight:600;line-height:1.2;overflow:hidden}.day-header.today .day-holiday{color:#fde68a}.day-note-preview{cursor:pointer;border-radius:4px;min-height:18px;margin-top:4px;padding:1px 3px;transition:background .1s}.day-note-preview:hover{background:#0000000f}.day-note-placeholder{opacity:0;color:#888;font-size:11px;line-height:1}.day-note-preview:hover .day-note-placeholder{opacity:.5}.day-note-text{color:#555;word-break:break-word;white-space:pre-wrap;font-size:10px;line-height:1.3;display:block}.day-header.today .day-note-text{color:#c7d9f5}.day-header.today .day-note-preview:hover{background:#ffffff1f}.day-note-edit{flex-direction:column;gap:3px;margin-top:4px;display:flex}.day-note-textarea{resize:none;box-sizing:border-box;color:#111;background:#fff;border:1px solid #93c5fd;border-radius:5px;outline:none;width:100%;padding:3px 5px;font-family:inherit;font-size:11px;line-height:1.4}.day-note-actions{justify-content:flex-end;gap:4px;display:flex}.day-note-save,.day-note-cancel{cursor:pointer;border:none;border-radius:4px;padding:1px 7px;font-size:12px;font-weight:600}.day-note-save{color:#fff;background:#1c3d6e}.day-note-cancel{color:#555;background:#e5e7eb}.month-cell.is-holiday{background:#fef9ec;border-color:#fde68a}.month-cell-holiday{color:#b45309;white-space:normal;word-break:break-word;margin-top:1px;font-size:9px;font-weight:600;line-height:1.2}.month-cell.has-entry .month-cell-holiday{display:none}.dt-dept-section{background:#fafafa;border:1px solid #e5e5ea;border-radius:12px;margin-bottom:12px;padding:14px}.dt-dept-section .settings-list{margin-bottom:10px}.dt-dept-section .settings-add-row{background:#fff;border-radius:8px}.dt-dept-header{align-items:center;gap:8px;margin-bottom:12px;display:flex}.dt-dept-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.dt-dept-name{color:#333;font-size:13px;font-weight:700}.dt-empty{color:#bbb;padding:8px 14px;font-size:12px;font-style:italic}.preset-warning{color:#c2410c;background:#fff7ed;border:1px solid #fed7aa;border-radius:8px;margin-top:10px;padding:8px 12px;font-size:12px;font-weight:500}.nav-brand-link{color:inherit;align-items:center;gap:8px;text-decoration:none;display:flex}.nav-logo-img{object-fit:contain;border-radius:4px;width:auto;height:28px}.nav-subtitle{color:#999;font-size:11px;font-weight:400}.db-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-left:4px}.db-dot-loading{background:#f59e0b;animation:1.2s ease-in-out infinite db-pulse}.db-dot-synced{background:#22c55e}.db-dot-error{background:#ef4444}@keyframes db-pulse{0%,to{opacity:1}50%{opacity:.3}}.company-form{padding-top:4px}.company-logo-area{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.company-logo-preview{object-fit:contain;background:#f5f5f7;border:1.5px solid #e5e5ea;border-radius:10px;flex-shrink:0;width:72px;height:72px}.company-logo-placeholder{color:#c0c0cc;background:#f5f5f7;border:2px dashed #d1d1d6;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;font-size:28px;font-weight:700;display:flex}.company-logo-btns{flex-direction:column;align-items:flex-start;gap:8px;display:flex}.btn-sort-active{color:#fff;background:#1c3d6e;border-color:#1c3d6e}.emp-card-sort{cursor:grab;-webkit-user-select:none;user-select:none}.emp-card-dragging{opacity:.4;transform:scale(.98)}.emp-card-dragover{background:#f0f4fa;border-color:#1c3d6e;box-shadow:0 0 0 2px #c7d8f0}.emp-sort-handle{flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:0 4px 0 0;display:flex}.drag-handle{color:#bbb;cursor:grab;font-size:18px;line-height:1}.sort-arrows{flex-direction:column;gap:1px;display:flex}.sort-arrow{color:#555;cursor:pointer;background:#fff;border:1px solid #d1d1d6;border-radius:4px;justify-content:center;align-items:center;width:24px;height:20px;padding:0;font-size:10px;line-height:1;display:flex}.sort-arrow:hover:not(:disabled){background:#f0f0f5;border-color:#aaa}.sort-arrow:disabled{opacity:.25;cursor:not-allowed}.dept-multi-chips{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.dept-multi-chip{color:#555;cursor:pointer;background:0 0;border:1.5px solid #d1d1d6;border-radius:20px;align-items:center;gap:5px;padding:4px 10px;font-size:13px;transition:background .1s,border-color .1s;display:flex}.dept-multi-chip:hover{background:#f5f5f7;border-color:#aaa}.dept-multi-chip.dmc-on{font-weight:600}.dmc-primary{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.dept-multi-hint{color:#888;margin:4px 0 0;font-size:11px}.su-toggle{color:#555;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:7px;margin-top:6px;font-size:13px;font-weight:500;display:flex}.su-toggle input{cursor:pointer}.su-grid{grid-template-columns:repeat(7,1fr);gap:10px;min-width:700px;display:grid;overflow-x:auto}.su-day-card{background:#fff;border:1px solid #e5e5ea;border-radius:14px;flex-direction:column;gap:8px;min-height:120px;padding:12px 10px;display:flex}.su-day-card.su-today{border-color:#1c3d6e;box-shadow:0 0 0 2px #c7d8f0}.su-day-header{border-bottom:1px solid #f0f0f5;align-items:center;gap:5px;padding-bottom:8px;display:flex}.su-day-name{color:#1a1a1a;text-transform:uppercase;letter-spacing:.3px;font-size:13px;font-weight:800}.su-today .su-day-name{color:#1c3d6e}.su-day-date{color:#aaa;font-size:11px;font-weight:500}.su-day-count{color:#1c3d6e;background:#f0f4ff;border-radius:8px;margin-left:auto;padding:1px 7px;font-size:10px;font-weight:700}.su-groups{flex-direction:column;gap:10px;display:flex}.su-group{flex-direction:column;gap:4px;display:flex}.su-group-label{letter-spacing:.7px;text-transform:uppercase;color:#888;align-items:center;gap:5px;margin-bottom:1px;font-size:9px;font-weight:800;display:flex}.su-group-label-frei{color:#bbb}.su-group-label-warn{color:#c2410c}.su-group-understaff{background:#fff7ed;border-radius:8px;margin:-4px -6px;padding:4px 6px}.su-group-count{color:#6b7280;white-space:nowrap;background:#f3f4f6;border-radius:6px;margin-left:auto;padding:1px 5px;font-size:9px;font-weight:700}.su-staffing-ok{color:#166534;background:#dcfce7}.su-staffing-warn{color:#dc2626;background:#fee2e2;animation:1.8s ease-in-out infinite su-pulse}.su-warn-icon{color:#fff;background:#dc2626;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:12px;height:12px;margin-left:2px;font-size:8px;font-weight:900;display:inline-flex}@keyframes su-pulse{0%,to{opacity:1}50%{opacity:.55}}.min-staff-field{flex-shrink:0;align-items:center;gap:5px;display:flex}.min-staff-label{color:#888;white-space:nowrap;font-size:11px;font-weight:600}.min-staff-input{text-align:center;background:#fafafa;border:1px solid #d1d1d6;border-radius:7px;outline:none;width:52px;padding:5px 8px;font-size:13px;font-weight:600}.min-staff-input:focus{background:#fff;border-color:#1c3d6e}.min-staff-input::placeholder{color:#ccc}.su-emp-chip{background:#fafafa;border-left:3px solid #d1d1d6;border-radius:8px;align-items:center;gap:6px;min-width:0;padding:5px 8px;text-decoration:none;transition:background .1s;display:flex}.su-emp-chip:hover{background:#f0f0f5}.su-chip-absent{opacity:.65}.su-chip-absent:hover{opacity:.85}.su-chip-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.su-chip-name{color:#1a1a1a;white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:12px;font-weight:600;overflow:hidden}.su-chip-time{color:#888;white-space:nowrap;flex-shrink:0;font-size:10px}.su-chip-status{white-space:nowrap;opacity:.75;flex-shrink:0;font-size:10px}.su-empty{color:#ccc;text-align:center;padding:16px 0;font-size:13px}@media (width<=900px){.su-grid{grid-template-columns:repeat(4,1fr)}}@media (width<=600px){.su-grid{grid-template-columns:repeat(2,1fr)}}.nav-hamburger{cursor:pointer;background:0 0;border:none;border-radius:8px;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:6px;display:none}.nav-hamburger:hover{background:#f0f0f5}.ham-line{background:#333;border-radius:2px;height:2px;transition:transform .2s,opacity .2s;display:block}.ham-line.ham-open:first-child{transform:translateY(7px)rotate(45deg)}.ham-line.ham-open:nth-child(2){opacity:0}.ham-line.ham-open:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.nav-mobile-menu{background:#fff;border-top:1px solid #e5e5ea;flex-direction:column;padding:8px 0;display:flex;box-shadow:0 8px 24px #0000001a}.nav-mobile-link{color:#333;border-left:3px solid #0000;padding:13px 20px;font-size:15px;font-weight:500;display:block}.nav-mobile-link.active{color:#1c3d6e;background:#f0f4fa;border-left-color:#1c3d6e}@media (width<=700px){.nav-hamburger{display:flex}.nav-links-desktop,.nav-subtitle{display:none}.nav-inner{padding:0 12px}.nav-brand{font-size:16px}.nav-user-role{display:none}.nav-user-avatar{width:30px;height:30px;font-size:13px}.app{padding:12px 10px 32px}.header{flex-direction:column;align-items:stretch;gap:8px;margin-bottom:12px}.header-left{gap:4px}.header-left h1{font-size:20px}.week-range{color:#555;font-size:13px}.week-nav{margin-top:4px}.header>div:last-child{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;gap:6px;padding-bottom:2px;display:flex;overflow-x:auto}.header>div:last-child::-webkit-scrollbar{display:none}.header>div:last-child .btn,.header>div:last-child button{white-space:nowrap;flex-shrink:0}.grid-card{-webkit-overflow-scrolling:touch;border-radius:10px}.day-headers,.employee-row{grid-template-columns:96px repeat(7,minmax(46px,1fr));gap:3px;padding-left:8px;padding-right:8px}.day-header{border-radius:6px;padding:6px 2px 4px}.day-header .day-name{font-size:9px}.day-header .day-date{font-size:13px}.day-note-preview,.day-note-edit{display:none!important}.employee-name{padding:0 4px;font-size:11px}.emp-link{color:#1a1a1a!important;text-decoration:none!important}.work-counter{font-size:9px}.shift-cell{border-radius:6px;height:46px;font-size:11px}.cell-label{font-size:11px}.cell-dienst{font-size:9px}.group-header{padding:8px 8px 3px;font-size:10px}.modal-backdrop{align-items:flex-end;padding:0}.modal{max-width:100%;padding:20px 16px calc(24px + env(safe-area-inset-bottom));border-radius:20px 20px 0 0;max-height:92dvh;overflow-y:auto}.modal-employee,.af-modal{border-radius:20px 20px 0 0;max-width:100%}.modal-backdrop:has(.modal[style*="380px"]){align-items:center;padding:16px}.print-modal,.copy-week-modal,.tpl-modal{border-radius:0;width:100%;max-width:100%;height:100dvh;max-height:100dvh}:is(.modal-backdrop:has(.print-modal),.modal-backdrop:has(.copy-week-modal),.modal-backdrop:has(.tpl-modal)){align-items:stretch;padding:0}.emp-card{grid-template-rows:auto auto auto;grid-template-columns:44px 1fr;gap:6px 10px}.emp-avatar{grid-row:span 2;width:44px;height:44px;font-size:15px}.emp-meta{grid-column:2}.emp-contact{grid-column:1/-1}.emp-actions{grid-column:1/-1;justify-content:flex-end}.mv-filter-bar{flex-direction:column;gap:8px}.mv-search{width:100%}.detail-header{flex-wrap:wrap;gap:8px}.detail-title{flex-direction:column;align-items:flex-start;gap:6px}.quick-row{flex-direction:column;gap:10px}.quick-field{width:100%}.quick-card .btn-primary{justify-content:center;width:100%;padding:11px}.stats-table{font-size:11px}.stats-table th,.stats-table td{padding:6px 8px}.month-cell{min-height:52px;font-size:12px}.settings-row{flex-wrap:wrap}.cw-week-row{flex-direction:column;gap:12px}.cw-arrow{align-self:center;padding:0;transform:rotate(90deg)}}@media (width<=390px){.app{padding:10px 6px 32px}.day-headers,.employee-row{grid-template-columns:80px repeat(7,minmax(40px,1fr));gap:2px}.shift-cell{height:42px}.header-left h1{font-size:18px}.nav-brand{font-size:15px}}.print-modal{background:#fff;border-radius:16px;flex-direction:column;width:95vw;max-width:1100px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #0003}.print-controls{border-bottom:1px solid #e5e5ea;flex-shrink:0;padding:20px 24px 16px}.print-controls h2{margin-bottom:14px;font-size:17px;font-weight:700}.print-control-row{flex-wrap:wrap;align-items:flex-start;gap:24px;display:flex}.print-range-tabs{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.print-custom-range{align-items:center;gap:8px;margin-top:8px;display:flex}.print-custom-range input[type=date]{border:1.5px solid #d1d1d6;border-radius:8px;padding:5px 8px;font-size:13px}.print-actions-top{justify-content:space-between;align-items:center;margin-top:14px;display:flex}.print-preview-area{background:#f5f5f7;flex:1;padding:20px 24px;overflow:auto}.print-preview-table{border-collapse:collapse;background:#fff;border-radius:10px;width:100%;margin-bottom:16px;font-size:12px;overflow:hidden;box-shadow:0 1px 4px #00000012}.print-preview-table th,.print-preview-table td{vertical-align:middle;border:1px solid #e0e0e5;padding:4px 5px}.pp-th-name{text-align:left;background:#f0f0f5;min-width:110px;padding-left:10px;font-size:11px;font-weight:700}.pp-th-day{text-align:center;background:#f0f0f5;min-width:46px}.pp-th-day.pp-holiday{background:#fef3c7}.pp-th-day.pp-weekend{background:#ebebf2}.pp-dow{font-size:10px;font-weight:700}.pp-date{color:#555;font-size:10px}.pp-hol{color:#b45309;white-space:nowrap;text-overflow:ellipsis;max-width:44px;font-size:8px;overflow:hidden}.pp-dept-row{letter-spacing:.3px;background:#e4e4ec;padding:5px 10px;font-size:11px;font-weight:700}.pp-dept-dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.pp-emp-row:hover td{filter:brightness(.97)}.pp-emp-name{white-space:nowrap;padding-left:10px;font-size:12px;font-weight:500}.pp-cell{text-align:center;font-size:10px}.pp-cell.pp-weekend{background:#f7f7fb}.pp-cell-status{font-size:10px;font-weight:700}.pp-cell-dienst{opacity:.8;font-size:9px}.copy-week-modal{background:#fff;border-radius:16px;flex-direction:column;width:95vw;max-width:1000px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #0003}.cw-controls{border-bottom:1px solid #e5e5ea;flex-shrink:0;padding:20px 24px 16px}.cw-controls h2{margin-bottom:16px;font-size:17px;font-weight:700}.cw-week-row{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.cw-week-block{flex-direction:column;gap:6px;display:flex}.cw-week-label{text-transform:uppercase;letter-spacing:.4px;color:#888;font-size:11px;font-weight:700}.cw-week-nav{align-items:center;gap:8px;display:flex}.cw-week-name{color:#1a1a1a;font-size:14px;font-weight:600}.cw-target{color:#1c3d6e}.cw-arrow{color:#aaa;padding-top:18px;font-size:20px}.cw-summary{color:#555;margin-top:12px;font-size:13px}.cw-conflict{color:#b45309;font-weight:500}.cw-preview{background:#f5f5f7;flex:1;padding:16px 24px;overflow:auto}.cw-src-date{color:#555}.cw-tgt-date{color:#1c3d6e;font-size:9px;font-weight:600}.cw-conflict-cell{outline-offset:-2px;outline:2px solid #fbbf24;position:relative}.cw-conflict-dot{background:#f59e0b;border-radius:50%;width:6px;height:6px;position:absolute;top:2px;right:3px}.cw-actions{border-top:1px solid #e5e5ea;flex-shrink:0;justify-content:flex-end;align-items:center;gap:10px;padding:14px 24px;display:flex}.af-modal{max-width:560px}.af-summary{color:#333;margin-bottom:12px;font-size:14px}.af-count{font-size:16px;font-weight:700}.af-no-presets{color:#999;font-size:12px}.af-list{background:#fafafa;border:1px solid #e5e5ea;border-radius:10px;flex-direction:column;gap:6px;max-height:340px;padding:8px;display:flex;overflow-y:auto}.af-empty{color:#999;text-align:center;padding:12px;font-size:13px}.af-row{background:#fff;border:1px solid #ebebef;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:6px 8px;display:flex}.af-row-dim{opacity:.45}.af-emp{flex:1;align-items:center;gap:7px;min-width:0;display:flex}.af-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.af-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.af-dienst-tag{color:#555;white-space:nowrap;background:#f0f0f5;border-radius:4px;padding:1px 6px;font-size:10px;font-weight:600}.af-days{flex-wrap:wrap;justify-content:flex-end;gap:3px;display:flex}.af-day{cursor:default;border-radius:5px;justify-content:center;align-items:center;width:28px;height:22px;font-size:10px;font-weight:700;display:inline-flex}.af-day-fill{color:#065f46;background:#d1fae5}.af-day-overwrite{color:#92400e;background:#fef3c7}.af-day-conflict{color:#9ca3af;background:#f3f4f6;text-decoration:line-through}.af-day-limit{color:#991b1b;background:#fee2e2;text-decoration:line-through}.af-dept-tabs{flex-wrap:wrap;gap:6px;margin-bottom:14px;display:flex}.af-dept-header{text-transform:uppercase;letter-spacing:.5px;color:#666;align-items:center;gap:7px;padding:8px 4px 4px;font-size:11px;font-weight:700;display:flex}.af-legend{color:#888;flex-wrap:wrap;align-items:center;gap:4px;margin-top:10px;font-size:11px;display:flex}.stats-table-wrap{background:#fff;border:1px solid #e5e5ea;border-radius:16px;overflow-x:auto;box-shadow:0 1px 4px #0000000f}.stats-table{border-collapse:collapse;width:100%;font-size:13px}.stats-table th{text-align:center;text-transform:uppercase;letter-spacing:.4px;color:#666;white-space:nowrap;background:#f5f5f7;border-bottom:1px solid #e5e5ea;padding:10px 12px;font-size:11px;font-weight:700}.st-th-name,.st-th-dept{text-align:left}.st-th-workdays{min-width:140px}.st-status-dot{vertical-align:middle;border-radius:4px;justify-content:center;align-items:center;width:18px;height:18px;margin-right:5px;font-size:10px;font-weight:700;display:inline-flex}.st-dept-row td{padding:0}.st-dept-cell{text-transform:uppercase;letter-spacing:.5px;color:#666;background:#fafafa;padding:10px 14px 4px;font-size:11px;font-weight:700}.st-dept-dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.st-emp-row td{vertical-align:middle;border-bottom:1px solid #f0f0f5;padding:8px 12px}.st-emp-row:hover td{background:#fafafa}.st-emp-row:last-child td{border-bottom:none}.st-td-name{white-space:nowrap;font-weight:500}.st-td-dept{white-space:nowrap}.st-td-count{text-align:center}.st-td-total{text-align:center;font-weight:600}.st-td-workdays{padding-right:16px}.st-badge{border-radius:6px;padding:2px 8px;font-size:12px;font-weight:700;display:inline-block}.st-zero{color:#ccc}.st-total-row td{text-align:center;background:#f5f5f7;border-top:2px solid #e5e5ea;padding:10px 12px}.st-total-row .st-td-name{text-align:left}.st-empty{text-align:center;color:#999;padding:40px}.st-wd-bar{background:#f0f0f5;border-radius:10px;align-items:center;min-width:100px;height:20px;display:flex;position:relative;overflow:hidden}.st-wd-fill{background:#d1fae5;border-radius:10px;transition:width .3s;position:absolute;top:0;bottom:0;left:0}.st-wd-over .st-wd-fill{background:#fee2e2}.st-wd-label{color:#444;z-index:1;padding:0 8px;font-size:11px;font-weight:600;position:relative}.tpl-modal{background:#fff;border-radius:16px;flex-direction:column;width:95vw;max-width:860px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #0003}.tpl-header{border-bottom:1px solid #e5e5ea;flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:16px;padding:20px 24px 16px;display:flex}.tpl-header h2{margin-bottom:2px;font-size:17px;font-weight:700}.tpl-tabs{background:#f0f0f5;border-radius:10px;gap:4px;padding:4px;display:flex}.tpl-tab{color:#666;cursor:pointer;background:0 0;border:none;border-radius:7px;padding:6px 14px;font-size:13px;font-weight:500;transition:background .1s,color .1s}.tpl-tab-active{color:#1a1a1a;background:#fff;box-shadow:0 1px 4px #0000001a}.tpl-save-body{flex:1;padding:20px 24px}.tpl-save-row{gap:10px;margin-top:10px;display:flex}.tpl-name-input{border:1.5px solid #d1d1d6;border-radius:8px;flex:1;padding:8px 12px;font-size:14px}.tpl-name-input:focus{border-color:#1c3d6e;outline:none}.tpl-load-body{flex-direction:column;flex:1;gap:0;padding:16px 24px;display:flex;overflow-y:auto}.tpl-list{flex-direction:column;gap:8px;margin-bottom:4px;display:flex}.tpl-item{cursor:pointer;background:#fafafa;border:1.5px solid #e5e5ea;border-radius:10px;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;transition:border-color .15s,background .15s;display:flex}.tpl-item:hover{background:#f5f5f7;border-color:#c0c0cc}.tpl-item-active{background:#f0f4fa;border-color:#1c3d6e}.tpl-item-info{flex-direction:column;gap:3px;min-width:0;display:flex}.tpl-item-name{color:#1a1a1a;font-size:14px;font-weight:600}.tpl-item-meta{color:#999;font-size:11px}.tpl-item-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.tpl-preview{border-top:1px solid #e5e5ea;margin-top:16px;padding-top:12px}.tpl-preview-title{color:#666;text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px;font-size:12px;font-weight:700}.tpl-footer{border-top:1px solid #e5e5ea;flex-shrink:0;justify-content:flex-end;padding:14px 24px;display:flex}@media print{.no-print{display:none!important}}.login-page{background:#f5f5f7;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:#fff;border-radius:16px;width:100%;max-width:380px;padding:40px 36px 32px;box-shadow:0 4px 32px #0000001a}.login-logo{text-align:center;margin-bottom:8px;font-size:40px}.login-title{text-align:center;margin:0 0 4px;font-size:24px;font-weight:700}.login-subtitle{color:#888;text-align:center;margin:0 0 28px;font-size:14px}.login-form{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.login-label{color:#555;margin-top:8px;font-size:13px;font-weight:500}.login-input{border:1.5px solid #ddd;border-radius:8px;outline:none;padding:10px 12px;font-size:15px;transition:border-color .15s}.login-input:focus{border-color:#007aff}.login-error{color:#ef4444;margin:4px 0 0;font-size:13px}.login-success{color:#166534;text-align:center;background:#f0fdf4;border:1px solid #86efac;border-radius:8px;margin-bottom:16px;padding:12px 14px;font-size:14px}.login-btn{color:#fff;cursor:pointer;background:#007aff;border:none;border-radius:8px;margin-top:14px;padding:11px;font-size:15px;font-weight:600;transition:background .15s}.login-btn:hover:not(:disabled){background:#0062cc}.login-btn:disabled{opacity:.6;cursor:default}.login-toggle{color:#007aff;cursor:pointer;text-align:center;background:0 0;border:none;width:100%;margin-top:8px;padding:4px;font-size:13px;display:block}.login-toggle:hover{text-decoration:underline}.login-invite-banner{color:#166534;text-align:center;background:#f0fdf4;border:1px solid #86efac;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:13px}.login-google-btn{color:#333;cursor:pointer;background:#fff;border:1.5px solid #ddd;border-radius:8px;justify-content:center;align-items:center;gap:10px;width:100%;margin-bottom:4px;padding:10px;font-size:14px;font-weight:500;transition:background .15s;display:flex}.login-google-btn:hover:not(:disabled){background:#f9f9fb}.login-google-btn:disabled{opacity:.6;cursor:default}.login-divider{color:#bbb;align-items:center;gap:10px;margin:12px 0;font-size:12px;display:flex}.login-divider:before,.login-divider:after{content:"";background:#eee;flex:1;height:1px}.nav-right{align-items:center;gap:8px;display:flex}.nav-user-wrap{position:relative}.nav-user-btn{cursor:pointer;color:#333;background:0 0;border:1.5px solid #ddd;border-radius:20px;align-items:center;gap:6px;padding:4px 10px 4px 4px;font-size:13px;display:flex}.nav-user-btn:hover{background:#f5f5f7}.nav-user-avatar{color:#fff;background:#007aff;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:13px;font-weight:700;display:flex}.nav-user-role{color:#666;font-size:12px}.nav-user-dropdown{z-index:200;background:#fff;border:1px solid #e5e5ea;border-radius:10px;min-width:200px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 4px 20px #0000001f}.nav-user-email{color:#888;word-break:break-all;border-bottom:1px solid #f0f0f0;padding:10px 14px;font-size:13px}.nav-user-signout{text-align:left;color:#ef4444;cursor:pointer;background:0 0;border:none;width:100%;padding:10px 14px;font-size:14px;display:block}.nav-user-signout:hover{background:#fff5f5}.inv-card{background:#f9f9fb;border:1px solid #e5e5ea;border-radius:12px;margin-bottom:28px;padding:18px 20px}.inv-title{margin:0 0 4px;font-size:15px;font-weight:600}.inv-create-row{flex-wrap:wrap;gap:10px;margin-top:12px;display:flex}.inv-role-select{background:#fff;border:1.5px solid #ddd;border-radius:8px;flex:1;min-width:180px;padding:8px 10px;font-size:13px}.inv-list{flex-direction:column;gap:8px;margin-top:14px;display:flex}.inv-row{background:#fff;border:1px solid #e5e5ea;border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 12px;display:flex}.inv-expiry{color:#888;flex-shrink:0;font-size:12px}.inv-token{color:#555;background:#f3f4f6;border-radius:4px;padding:2px 6px;font-size:12px}.inv-email-row{flex-wrap:wrap;gap:10px;margin-top:10px;display:flex}.inv-email-input{border:1.5px solid #ddd;border-radius:8px;flex:1;min-width:180px;padding:8px 10px;font-size:13px}.inv-email-input:focus{border-color:#007aff;outline:none}.inv-actions{flex-shrink:0;align-items:center;gap:6px;margin-left:auto;display:flex}.inv-copy-btn{color:#fff;cursor:pointer;background:#007aff;border:none;border-radius:6px;padding:5px 10px;font-size:12px;font-weight:600;transition:background .15s}.inv-copy-btn.copied{background:#22c55e}.inv-copy-btn:hover:not(.copied){background:#0062cc}.inv-mail-btn{cursor:pointer;background:#f3f4f6;border:1px solid #ddd;border-radius:6px;padding:5px 8px;font-size:13px}.inv-mail-btn:hover{background:#e5e7eb}.inv-del-btn{color:#bbb;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:16px}.inv-del-btn:hover{color:#ef4444}.users-section{margin-bottom:28px}.users-section-title{color:#888;text-transform:uppercase;letter-spacing:.05em;margin:0 0 10px;font-size:13px;font-weight:600}.users-row{background:#f9f9fb;border-radius:10px;justify-content:space-between;align-items:center;gap:12px;margin-bottom:6px;padding:12px 14px;display:flex}.users-row-self{background:#f0f7ff}.users-email{word-break:break-all;flex:1;align-items:center;gap:6px;min-width:0;font-size:14px;display:flex}.users-you{color:#fff;background:#007aff;border-radius:10px;padding:1px 7px;font-size:11px;font-weight:600}.users-role-wrap{flex-shrink:0;align-items:center;gap:8px;display:flex}.role-badge{border-radius:10px;padding:2px 9px;font-size:11px;font-weight:600}.role-admin{color:#92400e;background:#fef3c7}.role-editor{color:#1e40af;background:#dbeafe}.role-viewer{color:#374151;background:#f3f4f6}.role-pending{color:#991b1b;background:#fee2e2}.role-blocked{color:#f9fafb;background:#1f2937}.users-role-select{cursor:pointer;background:#fff;border:1.5px solid #ddd;border-radius:6px;padding:4px 8px;font-size:13px}.users-role-select:disabled{opacity:.5;cursor:default}@media (width<=700px){.nav-user-role{display:none}.nav-mobile-signout{text-align:left;cursor:pointer;background:0 0;border-top:1px solid #f0f0f0;width:100%;color:#ef4444!important}}.mo-page{padding-bottom:32px}.mo-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.mo-nav{align-items:center;gap:8px;display:flex}.mo-nav-btn{cursor:pointer;background:0 0;border:1.5px solid #ddd;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;display:flex}.mo-nav-btn:hover{background:#f5f5f7}.mo-title{text-align:center;min-width:180px;margin:0;font-size:20px;font-weight:700}.mo-today-btn{cursor:pointer;background:#f3f4f6;border:1.5px solid #ddd;border-radius:8px;padding:5px 12px;font-size:13px}.mo-today-btn:hover{background:#e5e7eb}.mo-scroll{border:1px solid #e5e5ea;border-radius:10px;overflow-x:auto}.mo-table{border-collapse:collapse;min-width:100%;font-size:12px}.mo-th-name{z-index:3;text-align:left;white-space:nowrap;background:#f9f9fb;border-bottom:2px solid #e5e5ea;border-right:1px solid #e5e5ea;min-width:130px;padding:8px 12px;font-weight:600;position:sticky;left:0}.mo-th-day{text-align:center;background:#f9f9fb;border-bottom:2px solid #e5e5ea;border-right:1px solid #f0f0f0;min-width:28px;padding:4px 2px;position:relative}.mo-th-stats{white-space:nowrap;text-align:center;background:#f9f9fb;border-bottom:2px solid #e5e5ea;border-left:1px solid #e5e5ea;padding:8px 10px;font-size:11px}.mo-day-num{font-size:13px;font-weight:700;line-height:1.2}.mo-day-name{color:#888;font-size:10px;line-height:1}.mo-holiday-dot{background:#f59e0b;border-radius:50%;width:5px;height:5px;margin:1px auto 0}.mo-th-day.mo-weekend,.mo-td-cell.mo-weekend{background:#fafafa}.mo-th-day.mo-today{background:#eff6ff}.mo-td-cell.mo-today{background:#eff6ff!important}.mo-th-day.mo-holiday,.mo-td-cell.mo-holiday-col{background:#fffbeb}.mo-dept-row td{background:#f5f5f7;padding:6px 10px}.mo-dept-label{font-size:12px}.mo-emp-row:hover td{background:#f5f8ff}.mo-td-name{z-index:2;white-space:nowrap;background:#fff;border-bottom:1px solid #f0f0f0;border-right:1px solid #e5e5ea;padding:4px 12px;font-size:13px;position:sticky;left:0}.mo-emp-row:hover .mo-td-name{background:#f5f8ff}.mo-td-cell{text-align:center;border-bottom:1px solid #f0f0f0;border-right:1px solid #f5f5f7;height:32px;padding:3px 2px}.mo-cell-badge{border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;font-size:10px;font-weight:700;display:inline-flex}.mo-td-stats{white-space:nowrap;text-align:center;border-bottom:1px solid #f0f0f0;border-left:1px solid #e5e5ea;padding:4px 10px;font-size:11px}.mo-stat-a{color:#16a34a;font-weight:600}.mo-stat-u{color:#2563eb;font-weight:600}.mo-stat-t{color:#666}.mo-legend{color:#666;flex-wrap:wrap;gap:16px;margin-top:12px;font-size:12px;display:flex}.mo-legend-item{align-items:center;gap:5px;display:flex}.mo-legend-dot{border-radius:3px;width:12px;height:12px;display:inline-block}.mo-weekend-dot{background:#fafafa;border:1px solid #ddd}.mo-holiday-dot{background:#fffbeb;border:1px solid #f59e0b}.mo-today-dot{background:#eff6ff;border:1px solid #93c5fd}@media (width<=700px){.mo-header{flex-direction:column;align-items:flex-start}.mo-th-name,.mo-td-name{min-width:90px;padding:4px 6px;font-size:11px}}.role-employee{color:#065f46;background:#d1fae5}.users-row-employee{border-left:3px solid #10b981}.users-emp-select{min-width:160px}.emp-portal-page{max-width:800px;margin:0 auto;padding:24px 16px 40px}.emp-portal-header{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:20px;display:flex}.emp-portal-avatar{color:#fff;background:#007aff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:22px;font-weight:700;display:flex}.emp-portal-name{margin:0 0 2px;font-size:22px;font-weight:700}.emp-portal-pos{color:#888;margin:0;font-size:13px}.emp-portal-tabs{gap:6px;margin-left:auto;display:flex}.emp-tab{cursor:pointer;background:0 0;border:1.5px solid #ddd;border-radius:20px;padding:7px 16px;font-size:13px;transition:all .15s}.emp-tab.active{color:#fff;background:#007aff;border-color:#007aff}.emp-stats-row{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:20px;display:grid}.emp-stat-card{text-align:center;border-radius:12px;padding:14px 16px}.emp-stat-num{font-size:28px;font-weight:700;line-height:1}.emp-stat-label{opacity:.8;margin-top:4px;font-size:12px}.emp-stat-arbeit{color:#166534;background:#dcfce7}.emp-stat-urlaub{color:#1e40af;background:#dbeafe}.emp-stat-krank{color:#991b1b;background:#fee2e2}.emp-stat-total{color:#374151;background:#f3f4f6}.emp-weeks{flex-direction:column;gap:12px;display:flex}.emp-week-card{background:#f9f9fb;border:1px solid #e5e5ea;border-radius:12px;padding:14px 16px}.emp-week-current{background:#eff6ff;border-color:#93c5fd}.emp-week-label{color:#555;margin-bottom:10px;font-size:13px;font-weight:600}.emp-week-days{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.emp-day{text-align:center;background:#fff;border:1px solid #e5e5ea;border-radius:8px;flex-direction:column;align-items:center;gap:3px;min-height:72px;padding:6px 4px;display:flex}.emp-day-today{background:#eff6ff;border-color:#3b82f6}.emp-day-weekend{background:#fafafa}.emp-day-holiday{background:#fffbeb;border-color:#f59e0b}.emp-day-name{color:#888;font-size:11px;font-weight:500}.emp-day-num{font-size:16px;font-weight:700;line-height:1}.emp-day-entry{border-radius:6px;flex-direction:column;align-items:center;gap:1px;width:100%;margin-top:2px;padding:3px 5px;display:flex}.emp-entry-abbr{font-size:13px;font-weight:700}.emp-entry-dienst{opacity:.8;font-size:9px}.emp-entry-time{opacity:.75;font-size:9px}.emp-day-empty{color:#ddd;margin-top:4px;font-size:18px}.emp-day-holiday-name{color:#d97706;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:8px;overflow:hidden}.emp-month-card{background:#f9f9fb;border:1px solid #e5e5ea;border-radius:12px;padding:20px}.emp-month-title{margin:0 0 16px;font-size:17px;font-weight:700}.emp-month-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.emp-month-dow{text-align:center;color:#888;padding:4px 0;font-size:11px;font-weight:600}.emp-month-cell{aspect-ratio:1;background:#fff;border:1px solid #f0f0f0;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:2px;padding:2px;display:flex;position:relative}.emp-mc-today{background:#eff6ff;border-color:#3b82f6}.emp-mc-weekend{background:#fafafa}.emp-mc-holiday{background:#fffbeb}.emp-mc-num{font-size:13px;font-weight:600;line-height:1}.emp-mc-badge{border-radius:4px;padding:1px 4px;font-size:10px;font-weight:700;line-height:1.4}.emp-mc-hol-dot{background:#f59e0b;border-radius:50%;width:5px;height:5px;position:absolute;top:2px;right:2px}.emp-month-legend{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.emp-legend-item{border-radius:8px;padding:3px 10px;font-size:11px;font-weight:600}.emp-portal-unlinked{text-align:center;color:#666;padding:60px 20px}.emp-portal-unlinked h2{margin-bottom:8px}@media (width<=700px){.emp-week-days{grid-template-columns:repeat(7,1fr);gap:3px}.emp-day{min-height:60px;padding:4px 2px}.emp-day-num{font-size:13px}.emp-entry-abbr{font-size:11px}.emp-portal-tabs{width:100%}}.invite-linked-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.invite-linked-badge{color:#166534;background:#dcfce7;border-radius:20px;padding:4px 12px;font-size:13px;font-weight:600}.invite-linked-email{color:#555;font-size:13px}.invite-unlink-btn{color:#ef4444;cursor:pointer;background:0 0;border:none;margin-left:auto;padding:4px 8px;font-size:12px}.invite-unlink-btn:hover{text-decoration:underline}.invite-sent-msg{color:#16a34a;padding:4px 0;font-size:14px}.invite-send-row{align-items:center;gap:8px;margin-top:4px;display:flex}.invite-email-field{border:1.5px solid #ddd;border-radius:8px;flex:1;padding:9px 12px;font-size:14px}.invite-email-field:focus{border-color:#007aff;outline:none}.invite-send-btn{white-space:nowrap;padding:9px 16px}
