:root{--bg: #f1f5f9;--panel: #ffffff;--panel-soft: #f8fafc;--border: #e2e8f0;--border-soft: rgba(226, 232, 240, .6);--accent: #4f46e5;--accent-soft: rgba(79, 70, 229, .1);--text: #1e293b;--muted: #64748b;--danger: #ef4444;--success: #22c55e;--warning: #eab308;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}html,body{min-height:100%}body{background:var(--bg);color:var(--text)}.hidden{display:none!important}#app{min-height:100vh;display:flex;flex-direction:column;padding:12px 12px 20px;max-width:480px;margin:0 auto;gap:12px}.app-header-bar{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--panel);border-bottom:1px solid var(--border)}.app-user-info{font-size:.9rem;color:var(--muted)}.user-pill{padding:2px 8px;border-radius:999px;background:var(--accent-soft);color:var(--accent)}.logout-button{border-radius:999px;border:1px solid var(--border);background:transparent;font-size:.8rem;padding:4px 10px;color:var(--text);cursor:pointer}.logout-button:hover{background:var(--panel-soft)}.top-nav{display:flex;align-items:center;gap:4px;padding:6px;border-radius:18px;background:#94a3b833;border:1px solid rgba(255,255,255,.4);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 1px 3px #0000000f}.top-nav-tab{flex:1;text-align:center;border:none;border-radius:12px;padding:10px 8px;background:transparent;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.top-nav-tab:hover{color:#334155;background:#94a3b840}.top-nav-tab.active{background:#fff;color:#4f46e5;box-shadow:0 2px 10px #0651ed1a}.app-view{display:none}.app-view.active{display:block;flex:1}.sidebar{width:100%}.sidebar-group{width:100%;border-radius:18px;background:var(--panel);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-sm)}.sidebar-header{list-style:none;padding:12px 14px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--panel);border-bottom:1px solid var(--border-soft)}.sidebar-header::-webkit-details-marker{display:none}.sidebar-header::marker{content:""}.sidebar-header-text{display:flex;flex-direction:column;gap:2px}.sidebar-title{font-size:1.1rem;font-weight:700;color:var(--text)}.sidebar-pill{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-top:2px}.chevron{font-size:.85rem;color:var(--muted);transition:transform .18s ease}.sidebar-group:not([open]) .chevron{transform:rotate(-90deg)}.sidebar-body{padding:8px}.week-control{display:inline-flex;align-items:center;gap:0;padding:3px;border-radius:12px;background:var(--panel-soft);border:1px solid var(--border)}.week-arrow{background:none;border:none;color:var(--muted);cursor:pointer;padding:6px 8px;border-radius:9px;display:flex;align-items:center;justify-content:center;transition:all .15s}.week-arrow:hover{background:var(--border);color:var(--text)}.week-label{font-size:13px;font-weight:800;color:var(--text);min-width:46px;text-align:center}.week-card{background:var(--panel);border:1px solid var(--border);border-radius:24px;padding:16px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-sm)}.week-card-header{display:flex;align-items:center;justify-content:space-between}.week-card-title-group{display:flex;align-items:center;gap:10px}.week-card-icon{background:#6366f11f;color:#818cf8;padding:9px;border-radius:14px;display:flex;align-items:center;justify-content:center}.week-card-title{display:block;font-size:15px;font-weight:700;color:var(--text);line-height:1.2}.week-card-sub{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-top:2px}.day-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}.day-button{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:14px 4px;border-radius:18px;border:none;background:var(--panel-soft);cursor:pointer;transition:all .18s ease;gap:5px}.day-button:hover{background:var(--border)}.day-button.active{background:var(--accent);box-shadow:0 8px 20px #4f46e54d;transform:scale(1.03)}.day-abbr{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);line-height:1}.day-button.active .day-abbr{color:#c7d2fee6}.day-num{font-size:15px;font-weight:800;color:var(--text);line-height:1}.day-button.active .day-num{color:#fff}.day-button.week-locked{opacity:.4;cursor:default}.day-button.week-locked:hover{background:var(--panel-soft);transform:none}.day-name-row{display:flex;justify-content:space-between;align-items:baseline}.day-date{font-size:.9rem;color:var(--muted)}.main{width:100%;background:var(--panel);border-radius:28px;border:1px solid var(--border);padding:20px;box-shadow:var(--shadow)}.main-header{margin-bottom:0}.main-header-top{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding-bottom:10px;border-bottom:1px solid var(--border);-webkit-user-select:none;user-select:none}.day-header-left{display:flex;align-items:baseline;gap:8px}#dayTitle{font-size:28px;font-weight:900;color:var(--text);letter-spacing:-.3px;margin-bottom:0}.day-title-date{font-size:14px;color:var(--muted);font-weight:700;display:flex;align-items:center;gap:8px}.day-header-total{font-weight:900;color:var(--muted)}.day-header-right{display:flex;align-items:center}.day-card-chevron{font-size:13px;color:var(--muted);transition:transform .2s ease;padding:10px;border-radius:14px;background:var(--panel-soft);box-shadow:var(--shadow-sm);border:1px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center}.day-card-body{display:flex;flex-direction:column;gap:28px;padding-top:24px}.day-content{display:none;font-size:.95rem;color:var(--muted);line-height:1.55}.day-content.active{display:block}.day-content p{margin-bottom:8px}.day-content strong{color:var(--text)}.day-content ul{margin-top:4px;margin-left:18px}.day-content li+li{margin-top:4px}.day-total{display:flex;flex-direction:column;align-items:flex-end}.day-total-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.day-section-header{display:flex;align-items:center;gap:8px;margin-bottom:14px}.day-section-icon{padding:8px;border-radius:12px;display:flex;align-items:center;justify-content:center}.day-section-icon.green{background:#ecfdf5;color:#10b981}.day-section-icon.indigo{background:#eef2ff;color:#6366f1}.day-section-title{font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.day-hours-section{display:flex;flex-direction:column}.day-hours-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.day-hours-item{display:flex;flex-direction:column;gap:6px}.day-hours-item span{font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-left:4px}.day-hours-input{width:100%;background:var(--panel-soft);border:1px solid transparent;border-radius:16px;padding:12px 16px;font-size:14px;font-weight:900;color:var(--text);outline:none;transition:all .15s}.day-hours-input::placeholder{color:#cbd5e1;font-weight:700}.day-hours-input:hover{background:var(--border)}.day-hours-input:focus{background:var(--panel);border-color:#a5b4fc;box-shadow:0 0 0 4px var(--accent-soft)}.kom-section{display:flex;flex-direction:column}.kom-card{background:var(--panel-soft);border-radius:20px;padding:18px;border:1px solid var(--border);display:flex;flex-direction:column;gap:16px;transition:background .15s;margin-bottom:10px}.kom-card-header{display:flex;flex-direction:column;gap:6px;position:relative}.kom-label{display:flex;flex-direction:column;gap:6px}.kom-label span,.kom-option-label{font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-left:4px}.kom-input{width:100%;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:12px 44px 12px 16px;font-size:14px;font-weight:900;color:var(--text);outline:none;transition:all .15s;box-shadow:var(--shadow-sm)}.kom-input::placeholder{color:#cbd5e1;font-weight:700}.kom-input:focus{border-color:#a5b4fc;box-shadow:0 0 0 4px var(--accent-soft)}.kom-remove-btn{position:absolute;right:12px;bottom:12px;background:none;border:none;color:var(--muted);cursor:pointer;padding:6px;border-radius:10px;display:flex;align-items:center;justify-content:center;transition:all .15s}.kom-remove-btn:hover{background:var(--border);color:var(--text)}.kom-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.kom-option{display:flex;flex-direction:column;gap:6px}.hours-input{width:100%;background:var(--panel-soft);border:1px solid transparent;border-radius:16px;padding:12px 16px;font-size:14px;font-weight:900;color:var(--text);outline:none;transition:all .15s}.hours-input::placeholder{color:#cbd5e1;font-weight:700}.hours-input:hover{background:var(--border)}.hours-input:focus{background:var(--panel);border-color:#a5b4fc;box-shadow:0 0 0 4px var(--accent-soft)}.kom-add-wrapper{margin-top:0}.kom-add-btn{width:100%;padding:14px;border-radius:18px;border:2px dashed var(--border);background:transparent;color:var(--muted);font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.kom-add-btn:hover{border-color:#a5b4fc;background:var(--accent-soft);color:var(--accent)}.kom-confirm-row,.pikett-confirm-row,.special-confirm-row,.absence-confirm-row{display:flex;align-items:center;gap:8px;justify-content:space-between;font-size:.75rem;color:var(--text);margin-top:8px;padding-top:6px;border-top:1px solid var(--border)}.kom-confirm-text,.pikett-confirm-text,.special-confirm-text,.absence-confirm-text{flex:1;color:var(--muted)}.kom-confirm-cancel,.kom-confirm-delete,.pikett-confirm-cancel,.pikett-confirm-delete,.special-confirm-cancel,.special-confirm-delete,.absence-confirm-cancel,.absence-confirm-delete{border-radius:999px;border:1px solid var(--border);background:var(--panel);color:var(--text);font-size:.75rem;padding:3px 8px;cursor:pointer}.kom-confirm-delete,.pikett-confirm-delete,.special-confirm-delete,.absence-confirm-delete{border-color:#ef444480;color:var(--danger)}.special-section{border-top:1px solid #f1f5f9;padding-top:24px;display:flex;flex-direction:column;gap:12px}.special-list{display:flex;flex-direction:column;gap:8px}.special-empty-text{font-size:12px;font-weight:600;color:#94a3b8;padding:4px}.special-row{background:#f8fafccc;border-radius:24px;border:1px solid #f1f5f9;padding:20px;display:flex;flex-direction:column;gap:16px;position:relative;transition:background .2s}.special-row:hover{background:#f8fafc}.special-row-top{display:flex;align-items:flex-start;gap:12px;flex-wrap:nowrap}.special-row-middle,.special-row-bottom{display:flex;flex-direction:column;gap:6px}.special-field{display:flex;flex-direction:column;gap:6px;flex:1 1 0;min-width:0}.special-field span{font-size:10px;font-weight:900;color:#94a3b8;text-transform:uppercase;letter-spacing:.1em;margin-left:4px}.special-field input,.special-field select{width:100%;box-sizing:border-box;background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:11px 16px;font-size:14px;font-weight:900;color:#334155;box-shadow:0 1px 3px #0000000d;outline:none;transition:border-color .2s,box-shadow .2s;-moz-appearance:none;appearance:none;-webkit-appearance:none}.special-field input::placeholder{color:#cbd5e1;font-weight:600}.special-field input:focus,.special-field select:focus{border-color:#a5b4fc;box-shadow:0 0 0 4px #6366f114}.special-select-wrap{position:relative;display:flex;align-items:center}.special-select-wrap select{padding-right:36px}.special-select-chevron{position:absolute;right:13px;pointer-events:none;color:#94a3b8;display:flex;align-items:center}.special-field.small{flex:0 0 92px;max-width:92px}.special-field.small input{text-align:center}.special-remove-btn{flex-shrink:0;margin-top:22px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:10px;color:#94a3b8;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000000d;font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center}.special-remove-btn:hover{color:#475569;background:#f8fafc;border-color:#cbd5e1}.special-add-btn{width:100%;padding:16px;border-radius:16px;border:2px dashed #e2e8f0;background:transparent;color:#64748b;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.special-add-btn:hover{border-color:#a5b4fc;background:#eef2ff80;color:#6366f1}.meal-section{padding:10px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.meal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.meal-title{font-size:.85rem;font-weight:600;color:var(--text)}.meal-info-btn{border:1px solid var(--border);background:var(--panel);color:var(--muted);border-radius:999px;padding:2px 7px;font-size:.7rem;cursor:pointer}.meal-info-box{display:none;font-size:.75rem;color:var(--muted);background:var(--panel-soft);border-radius:10px;padding:6px 8px;margin-bottom:6px;border:1px solid var(--border)}.meal-section.open-info .meal-info-box{display:block}.meal-pill-row{display:flex;gap:6px;flex-wrap:wrap}.meal-pill{flex:0 0 auto;min-width:32px;padding:4px 8px;border-radius:999px;border:1px solid var(--border);background:var(--panel-soft);color:var(--muted);font-size:.8rem;cursor:pointer;transition:all .15s}.meal-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}.day-flags{margin-bottom:12px;display:flex;flex-wrap:wrap;gap:6px}.flags-grid{display:flex;gap:4px;flex-wrap:wrap}.flag-item{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:10px;background:var(--panel-soft);border:1px solid var(--border);font-size:.75rem;color:var(--text)}.flag-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent)}.pikett-wrapper{display:flex;flex-direction:column;gap:16px;padding-bottom:80px;margin-top:24px}.pikett-header-card{background:#fff;border-radius:40px;border:1px solid rgba(241,245,249,.6);padding:24px;box-shadow:0 8px 30px #0000000a;display:flex;flex-direction:column;gap:20px}.pikett-header-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.pikett-title{font-size:1.5rem;font-weight:900;color:#1e293b;letter-spacing:-.02em}.pikett-subtitle{font-size:14px;font-weight:700;color:#64748b;line-height:1.6}.pikett-month-control{display:inline-flex;align-items:center;gap:4px;padding:6px;border-radius:16px;background:#f8fafc;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000f}.pikett-month-label{font-size:14px;font-weight:900;color:#334155;min-width:90px;text-align:center}.pikett-month-arrow{border:none;padding:6px 8px;font-size:16px;cursor:pointer;background:transparent;color:#94a3b8;border-radius:10px;transition:all .15s;line-height:1}.pikett-month-arrow:hover{color:#334155;background:#94a3b833}.pikett-summary-row{display:flex;align-items:center;justify-content:space-between;background:#eef2ff80;border:1px solid rgba(199,210,254,.5);border-radius:24px;padding:16px}.pikett-summary-label{font-size:11px;font-weight:900;color:#1e1b4b80;text-transform:uppercase;letter-spacing:.1em}.pikett-summary-value{font-size:18px;font-weight:900;color:#4f46e5}.pikett-actions{display:flex;justify-content:flex-end}.pikett-add-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;border-radius:16px;border:2px solid #e2e8f0;background:#fff;color:#475569;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000000f}.pikett-add-btn:hover{border-color:#a5b4fc;background:#eef2ff80;color:#4f46e5}.pikett-list{display:flex;flex-direction:column;gap:12px}.pikett-card{background:#fff;border-radius:40px;border:1px solid rgba(241,245,249,.6);padding:24px;box-shadow:0 8px 30px #0000000a;display:flex;flex-direction:column;gap:16px;transition:border-color .2s}.pikett-card:hover{border-color:#e2e8f0cc}.pikett-card-header{display:grid;grid-template-columns:1fr 1fr;gap:16px}.pikett-field-group{display:contents}.pikett-card-body{display:grid;grid-template-columns:1fr 1fr;gap:16px}.pikett-label{display:flex;flex-direction:column;gap:6px}.pikett-label>span{font-size:10px;font-weight:900;color:#94a3b8;text-transform:uppercase;letter-spacing:.1em;margin-left:4px}.pikett-label input,.pikett-label input.pikett-date,.pikett-label input.pikett-kom,.pikett-label input.pikett-hours,.pikett-label input.pikett-note{width:100%;box-sizing:border-box;background:#f8fafc;border:1px solid transparent;border-radius:16px;padding:12px 16px;font-size:14px;font-weight:900;color:#334155;outline:none;transition:all .2s;box-shadow:0 1px 3px #0000000a;max-width:none}.pikett-label input::placeholder{color:#cbd5e1;font-weight:600}.pikett-label input:focus{background:#fff;border-color:#a5b4fc;box-shadow:0 0 0 4px #6366f114}.pikett-kom-wrap{position:relative;display:flex;align-items:center}.pikett-kom-wrap input{padding-right:40px}.pikett-remove-btn{position:absolute;right:8px;background:none;border:none;padding:6px;border-radius:10px;color:#94a3b8;cursor:pointer;font-size:14px;transition:all .15s;display:flex;align-items:center;justify-content:center;line-height:1}.pikett-remove-btn:hover{color:#475569;background:#94a3b826}.pikett-note-row{grid-column:1 / -1}.pikett-overtime3-section{padding-top:1px;margin-top:10px;border-top:1px solid #f1f5f9;display:flex;flex-direction:column;gap:1px;grid-column:1 / -1}.pikett-overtime3-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.pikett-overtime3-title{font-size:14px;font-weight:900;color:#334155;letter-spacing:-.01em}.pikett-overtime3-info-btn{width:28px;height:28px;border-radius:999px;border:none;background:transparent;font-size:16px;display:flex;align-items:center;justify-content:center;color:#94a3b8;cursor:pointer;transition:color .15s}.pikett-overtime3-info-btn:hover{color:#4f46e5}.pikett-overtime3-info-box{font-size:13px;color:#64748b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:12px 14px;max-height:0;overflow:hidden;opacity:0;transition:max-height .2s ease,opacity .2s ease}.pikett-card.open-overtime3-info .pikett-overtime3-info-box{max-height:200px;opacity:1}.pikett-overtime3-toggle{display:flex;align-items:flex-start;gap:12px;cursor:pointer;background:#f8fafc80;border:1px solid transparent;border-radius:16px;padding:12px;transition:all .2s}.pikett-overtime3-toggle:hover{border-color:#e2e8f0;background:#f8fafc}.pikett-overtime3-checkbox{width:20px;height:20px;border-radius:6px;accent-color:#4f46e5;flex-shrink:0;margin-top:1px;cursor:pointer}.pikett-overtime3-toggle>span{font-size:14px;font-weight:700;color:#64748b;line-height:1.4}.pikett-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:20px;margin-top:4px;border-top:1px solid #f1f5f9}.pikett-save-status{font-size:11px;font-weight:900;padding:6px 12px;border-radius:10px;text-transform:uppercase;letter-spacing:.06em}.pikett-save-status.saved{background:#f0fdf4;color:#16a34a;border:1px solid rgba(34,197,94,.25)}.pikett-save-status.unsaved{background:#fffbeb;color:#d97706;border:1px solid rgba(234,179,8,.3)}.pikett-save-btn{background:#4f46e5;color:#fff;border:none;border-radius:16px;padding:10px 24px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #4f46e533}.pikett-save-btn:hover{background:#4338ca;box-shadow:0 6px 16px #4f46e54d}.pikett-save-btn:disabled{opacity:.35;cursor:default;box-shadow:none}.pikett-card-locked{position:relative;pointer-events:none;background:#fafafa;border-color:#f1f5f9}.pikett-lock-badge{font-size:11px;font-weight:900;color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:10px;padding:8px 14px;align-self:flex-start;text-transform:uppercase;letter-spacing:.06em}.pikett-lock-error{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:inherit;background:#ffffffbf;pointer-events:none}.pikett-lock-error-text{font-size:12px;font-weight:900;color:#d97706;background:#fffbeb;border:1px solid rgba(234,179,8,.3);border-radius:12px;padding:10px 16px;text-align:center;text-transform:uppercase;letter-spacing:.06em}.pikett-lock-msg{font-size:11px;font-weight:900;color:#d97706;background:#fffbeb;border:1px solid rgba(234,179,8,.3);border-radius:12px;padding:10px 14px;text-align:center;text-transform:uppercase;letter-spacing:.06em;grid-column:1 / -1}.dashboard-wrapper{display:flex;flex-direction:column;gap:16px;padding-bottom:80px;margin:12px auto 24px}.dashboard-header-card{background:#fff;border-radius:40px;border:1px solid rgba(241,245,249,.6);padding:24px;box-shadow:0 8px 30px #0000000a;display:flex;flex-direction:column;gap:16px}.dashboard-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.dashboard-title{font-size:1.875rem;font-weight:900;color:#1e293b;letter-spacing:-.02em;line-height:1.1}.dashboard-subtitle{font-size:14px;font-weight:700;color:#94a3b8;margin-top:4px}.dashboard-month-control{display:inline-flex;align-items:center;gap:4px;padding:6px;border-radius:16px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000f;flex-shrink:0}.dashboard-month-label{font-size:14px;font-weight:900;color:#334155;min-width:90px;text-align:center}.dashboard-month-arrow{border:none;padding:6px 8px;font-size:16px;cursor:pointer;background:transparent;color:#94a3b8;border-radius:10px;transition:all .15s;line-height:1}.dashboard-month-arrow:hover{color:#334155;background:#94a3b826}.dashboard-transmit-row{display:flex;align-items:center;gap:10px}.dashboard-transmit-btn{background:#4f46e5;color:#fff;border:none;border-radius:16px;padding:10px 20px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #4f46e533;white-space:nowrap}.dashboard-transmit-btn:hover{background:#4338ca;box-shadow:0 6px 16px #4f46e54d}.sync-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:16px;font-size:12px;font-weight:900;border:1px solid transparent;letter-spacing:.02em}.sync-dot{width:8px;height:8px;border-radius:999px;flex-shrink:0}.sync-age-unknown{background:#f8fafc;border-color:#e2e8f0;color:#94a3b8}.sync-age-ok{background:#f0fdf4;border-color:#22c55e4d;color:#15803d}.sync-age-warn{background:#fffbeb;border-color:#eab3084d;color:#b45309}.sync-age-warn .sync-dot{background:#f59e0b;animation:pulse 1.5s infinite}.sync-age-bad{background:#fff1f2;border-color:#ef44444d;color:#b91c1c}.sync-age-bad .sync-dot{background:#ef4444}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.dashboard-card{background:#fff;border-radius:40px;border:1px solid rgba(241,245,249,.6);padding:24px;box-shadow:0 8px 30px #0000000a;display:flex;flex-direction:column;gap:20px}.dashboard-card-title{font-size:18px;font-weight:900;color:#1e293b;letter-spacing:-.01em}.dashboard-card-note{font-size:12px;font-weight:700;color:#94a3b8;margin-top:-12px}.dashboard-card-note.is-error{color:#ef4444}.dashboard-metric-row{display:flex;align-items:center;justify-content:space-between;padding:0;border-top:none}.dashboard-metric-row:first-of-type{border-top:none}.metric-label{font-size:14px;font-weight:700;color:#64748b}.metric-value{font-size:14px;font-weight:900;color:#334155}.dashboard-metric-separator{border:none;border-top:1px solid #f1f5f9;margin:0}.dashboard-metric-row.total-row{padding-top:4px}.metric-label-total{font-size:14px;font-weight:900;color:#1e293b}.metric-value-total{font-size:18px;font-weight:900;color:#4f46e5}.dashboard-week-list{display:flex;flex-direction:column;gap:8px;margin-top:-4px}.overtime-year-row{display:flex;justify-content:space-between;align-items:center;background:#f8fafc;border:1px solid #f1f5f9;border-radius:16px;padding:16px;font-size:14px;font-weight:700;color:#475569}.overtime-year-row span:last-child{font-weight:900;color:#1e293b}.absence-section-title{font-size:14px;font-weight:900;color:#1e293b}.absence-form{display:flex;flex-direction:column;gap:14px}.absence-form-row{display:flex;flex-direction:column;gap:6px}.absence-form-row--two{display:grid;grid-template-columns:1fr 1fr;gap:14px}.absence-label{display:flex;flex-direction:column;gap:6px;flex:1 1 0}.absence-label span{font-size:10px;font-weight:900;color:#94a3b8;text-transform:uppercase;letter-spacing:.1em;margin-left:4px}.absence-input{width:100%;box-sizing:border-box;background:#f8fafc;border:1px solid transparent;border-radius:16px;padding:12px 16px;font-size:14px;font-weight:900;color:#334155;outline:none;transition:all .2s;-moz-appearance:none;appearance:none;-webkit-appearance:none}.absence-input::placeholder{color:#cbd5e1;font-weight:600}.absence-input:focus{background:#fff;border-color:#a5b4fc;box-shadow:0 0 0 4px #6366f114}.absence-form-actions{display:flex;justify-content:flex-end;padding-top:4px}.absence-save-btn{background:#4f46e5;color:#fff;border:none;border-radius:16px;padding:10px 24px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #4f46e533}.absence-save-btn:hover{background:#4338ca;box-shadow:0 6px 16px #4f46e54d}.absence-item{background:#f8fafccc;border:1px solid #f1f5f9;border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:10px;transition:border-color .2s}.absence-item:hover{border-color:#e2e8f0}.absence-item-header{display:flex;flex-direction:column;gap:4px}.absence-title{font-size:14px;font-weight:900;color:#334155}.absence-meta{font-size:12px;font-weight:700;color:#94a3b8;display:flex;flex-direction:column;gap:8px}.absence-status-row{display:flex;align-items:center;gap:10px}.absence-status-badge{font-size:10px;font-weight:900;padding:5px 10px;border-radius:10px;border:1px solid transparent;text-transform:uppercase;letter-spacing:.06em}.absence-status-badge.pending{background:#fffbeb;color:#d97706;border-color:#eab3084d}.absence-status-badge.accepted{background:#f0fdf4;color:#16a34a;border-color:#22c55e40}.absence-status-badge.rejected{background:#fff1f2;color:#ef4444;border-color:#ef444433}.absence-status-badge.cancel_requested{background:#fffbeb;color:#d97706;border-color:#f59e0b4d}.absence-status-badge.cancelled{background:#fff1f2;color:#ef4444;border-color:#ef444433}.absence-cancel-btn{background:#fff;border:2px solid #fecdd3;color:#ef4444;border-radius:10px;padding:5px 12px;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;transition:all .2s}.absence-cancel-btn:hover{background:#fff1f2;border-color:#fca5a5}.absence-cancel-btn:disabled{opacity:.5;cursor:not-allowed}.week-row{background:#f8fafc80;border:1px solid #f1f5f9;border-radius:16px;overflow:hidden;transition:border-color .2s,background .2s;cursor:pointer}.week-row:hover{border-color:#e2e8f0;background:#f8fafc}.week-row-header{display:flex;align-items:center;justify-content:space-between;padding:16px;gap:8px}.week-row-left{display:flex;flex-direction:column;gap:4px}.week-label{font-size:14px;font-weight:900;color:#334155}.week-dates{font-size:11px;font-weight:700;color:#94a3b8}.week-right{display:flex;align-items:center;gap:16px}.week-status-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:10px;font-size:9px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}.week-status-badge.status-ok{background:#f0fdf4;color:#16a34a;border:1px solid rgba(34,197,94,.2)}.week-status-badge.status-missing{background:#fff1f2;color:#ef4444;border:1px solid rgba(239,68,68,.15)}.week-status-badge.status-weekend{background:#f8fafc;color:#94a3b8;border:1px solid #e2e8f0}.week-status-icon{width:12px;height:12px;flex-shrink:0}.week-total{font-size:14px;font-weight:900;color:#334155;min-width:44px;text-align:right}.week-chevron{color:#cbd5e1;transition:transform .2s,color .2s;display:flex;align-items:center}.week-row:hover .week-chevron{color:#64748b}.week-chevron.open{transform:rotate(180deg)}.week-days{display:none;border-top:1px solid #f1f5f9;padding:8px 16px 14px;flex-direction:column;gap:4px}.week-days.open{display:flex}.week-days .day-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid #f8fafc}.week-days .day-row:last-child{border-bottom:none}.week-days .day-name{font-size:12px;font-weight:700;color:#94a3b8;width:30px}.week-days .day-date{font-size:12px;color:#94a3b8;flex:1}.week-days .day-hours{font-size:12px;font-weight:700;color:#334155}.week-days .day-hours.missing{color:#ef4444;font-weight:700}.absence-status-select{border-radius:999px;border:1px solid var(--border);background:var(--panel);color:var(--text);padding:2px 8px;font-size:.75rem}.absence-status-badge{font-size:.7rem;padding:2px 6px;border-radius:999px;border:1px solid transparent}.absence-status-badge.pending{border-color:#facc1599;color:#b45309;background:#facc151a}.absence-status-badge.accepted{border-color:#22c55e80;color:#15803d;background:#22c55e1a}.absence-status-badge.rejected{border-color:#ef444480;color:var(--danger);background:#ef44441a}.absence-status-badge.cancel_requested{background:#f59e0b26;border-color:#f59e0b66;color:#b45309}.absence-status-badge.cancelled{background:#ef44441a;border-color:#ef444466;color:var(--danger)}.absence-delete-btn{margin-left:auto;border-radius:999px;border:1px solid var(--border);background:var(--panel);color:var(--muted);font-size:.7rem;padding:3px 8px;cursor:pointer}.absence-cancel-btn{background:#ef444414;color:var(--danger);border:1px solid rgba(239,68,68,.3);border-radius:10px;padding:2px 8px;font-size:12px;cursor:pointer}.absence-cancel-btn:hover{background:#ef444426}.absence-cancel-btn:disabled{opacity:.6;cursor:not-allowed}.absence-form{display:flex;flex-direction:column;gap:8px;font-size:.8rem}.absence-form-row{display:flex;flex-direction:column;gap:4px}.absence-form-row--two{flex-direction:row;gap:8px}.absence-label{display:flex;flex-direction:column;gap:2px;flex:1 1 0}.absence-label span{color:var(--muted);font-size:.78rem}.absence-input{border-radius:10px;border:1px solid var(--border);background:var(--panel);color:var(--text);padding:6px 10px;font-size:.8rem;outline:none}.absence-input:focus{border-color:#a5b4fc;box-shadow:0 0 0 3px var(--accent-soft)}.absence-form-actions{display:flex;justify-content:flex-end;margin-top:4px}.absence-save-btn{border-radius:999px;border:none;background:var(--accent);color:#fff;font-size:.85rem;font-weight:600;padding:6px 14px;cursor:pointer}.login-view{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:16px}.login-card{width:100%;max-width:360px;background:var(--panel);border-radius:18px;border:1px solid var(--border);padding:28px 22px;box-shadow:var(--shadow-lg)}.login-title{font-size:1.4rem;font-weight:800;color:var(--text);margin-bottom:4px}.login-subtitle{font-size:.85rem;color:var(--muted);margin-bottom:20px}.login-form{display:flex;flex-direction:column;gap:12px}.login-label{display:flex;flex-direction:column;gap:4px;font-size:.8rem;color:var(--text)}.login-label input{border-radius:10px;border:1px solid var(--border);background:var(--panel-soft);padding:10px 12px;font-size:.9rem;color:var(--text);outline:none}.login-label input:focus{border-color:#a5b4fc;box-shadow:0 0 0 3px var(--accent-soft)}.login-error{font-size:.8rem;color:var(--danger);background:#ef444414;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:6px 10px}.login-button{margin-top:4px;width:100%;border-radius:999px;border:none;padding:10px 12px;font-size:.95rem;font-weight:700;color:#fff;background:var(--accent);cursor:pointer;transition:filter .15s}.login-button:hover{filter:brightness(1.08)}.login-button:disabled{opacity:.7;cursor:wait;filter:none}.login-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:2rem 0}.login-loader-text{font-size:.8rem;color:var(--muted);text-align:center}.sync-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.2rem .6rem;border-radius:999px;font-size:.8rem;border:1px solid transparent}.sync-dot{width:8px;height:8px;border-radius:999px}.sync-age-unknown{background:#f8fafc;border-color:var(--border);color:var(--muted)}.sync-age-unknown .sync-dot{background:#94a3b8}.sync-age-ok{background:#f0fdf4;border-color:#bbf7d0;color:#15803d}.sync-age-ok .sync-dot{background:#22c55e}.sync-age-warn{background:#fffbeb;border-color:#fde68a;color:#b45309}.sync-age-warn .sync-dot{background:#f59e0b}.sync-age-bad{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.sync-age-bad .sync-dot{background:var(--danger)}.week-locked-overlay{position:relative;opacity:.4}.week-lock-indicator{display:none;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:2px 8px;border-radius:999px;background:#ef44441a;border:1px solid rgba(239,68,68,.35);color:var(--danger)}.week-lock-indicator.visible{display:flex}.week-lock-overlay-msg{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:inherit;background:#ffffffb3;pointer-events:none}.week-lock-overlay-text{font-size:13px;color:var(--danger);font-weight:700;padding:8px 14px;border-radius:10px;background:#ef444414;border:1px solid rgba(239,68,68,.35);text-align:center;max-width:80%}.stamp-card{background:#fff;border-radius:32px;padding:24px;box-shadow:0 8px 30px #0000000a;border:1px solid rgba(241,245,249,.6);display:flex;flex-direction:column;gap:20px;margin-bottom:12px;margin-top:24px}.stamp-card-header{display:flex;justify-content:space-between;align-items:center}.stamp-card-date{font-size:13px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em}.stamp-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(to bottom,#34d399,#10b981);color:#fff;border:none;border-radius:18px;padding:20px;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 8px 20px #10b98140}.stamp-btn:hover{box-shadow:0 8px 25px #10b98159;filter:brightness(.97)}.stamp-btn:active{transform:scale(.98)}.stamp-btn.stamped-in{background:linear-gradient(to bottom,#f87171,#ef4444);box-shadow:0 8px 20px #ef444440;color:#fff}.stamp-log{display:flex;flex-direction:column;gap:5px}.stamp-log-entry{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-radius:10px;background:#f8fafc;font-size:13px;flex-wrap:wrap;gap:6px}.stamp-log-entry-left{display:flex;align-items:center;gap:8px}.stamp-log-type{font-size:11px;font-weight:700;padding:2px 7px;border-radius:999px}.stamp-log-type.in{background:#10b9811a;color:#10b981}.stamp-log-type.out{background:#ef44441a;color:#ef4444}.stamp-log-time{color:#334155;font-weight:600}.stamp-log-edit-btn{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:12px;padding:2px 6px;border-radius:6px}.stamp-log-edit-btn:hover{color:#475569;background:#f1f5f9}.stamp-log-action-btn{padding:4px 10px;border-radius:8px;border:1px solid #e2e8f0;background:transparent;color:#64748b;font-size:11px;cursor:pointer}.stamp-divider{height:1px;background:#f1f5f9}.stamp-zulagen{display:grid;grid-template-columns:1fr 1fr;gap:8px}.stamp-meals{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.stamp-pill{padding:12px 10px;border-radius:18px;font-size:14px;font-weight:600;border:1px solid #e2e8f0;background:#f8fafc;color:#64748b;cursor:pointer;transition:all .2s;text-align:center}.stamp-pill:hover{background:#f1f5f9;color:#475569}.stamp-pill.zulage-active,.stamp-pill.meal-active{background:#eef2ff;border-color:#c7d2fe;color:#4f46e5;box-shadow:0 1px 3px #6366f11a}.stamp-edit-section{border-top:none;padding-top:0}.stamp-edit-toggle{list-style:none;cursor:pointer;display:flex;justify-content:center;font-size:14px;font-weight:700;color:#94a3b8;background:none;border:none;padding:8px 0 0;transition:color .2s}.stamp-edit-toggle:hover{color:#6366f1}.stamp-edit-toggle::-webkit-details-marker{display:none}.stamp-edit-body{display:flex;flex-direction:column;gap:10px;margin-top:16px;padding-top:16px;border-top:1px solid #f1f5f9}.stamp-edit-datepicker{padding:10px 14px;border-radius:14px;border:1px solid #e2e8f0;background:#f8fafc;color:#334155;font-size:14px;width:100%;box-sizing:border-box;outline:none}.stamp-edit-datepicker:focus{border-color:#a5b4fc;background:#fff;box-shadow:0 0 0 4px #6366f114}.stamp-edit-date-row{display:flex;align-items:center;gap:10px}.stamp-edit-date-row .stamp-edit-datepicker{flex:1}.stamp-edit-total-badge{display:flex;align-items:baseline;gap:5px;background:#eef2ff;border:1px solid #c7d2fe;border-radius:12px;padding:6px 12px;white-space:nowrap;flex-shrink:0}.stamp-edit-total-label{font-size:10px;font-weight:900;color:#6366f1;text-transform:uppercase;letter-spacing:.08em}.stamp-edit-total-value{font-size:14px;font-weight:900;color:#4f46e5}.stamp-edit-log{display:flex;flex-direction:column;gap:5px}.stamp-edit-add-btn{padding:12px;border-radius:14px;border:2px dashed #e2e8f0;background:transparent;color:#94a3b8;font-size:13px;font-weight:600;cursor:pointer;text-align:center;transition:all .2s}.stamp-edit-add-btn:hover{border-color:#a5b4fc;background:#6366f108;color:#6366f1}.stamp-edit-extras{display:grid;grid-template-columns:1fr 1fr;gap:8px}.stamp-extra-item{display:none}.stamp-log:empty{display:none}.stamp-card-net-wrap{display:flex;align-items:baseline;gap:5px;background:#eef2ff80;padding:6px 12px;border-radius:12px;border:1px solid rgba(199,210,254,.5)}.stamp-card-net-label{font-size:10px;font-weight:900;color:#a5b4fc;text-transform:uppercase;letter-spacing:.1em}.stamp-card-net{font-size:14px;font-weight:900;color:#4f46e5;background:none;padding:0;border:none}.stamp-edit-lock-msg{font-size:11px;font-weight:900;color:#d97706;background:#fffbeb;border:1px solid rgba(234,179,8,.3);border-radius:12px;padding:10px 14px;text-align:center;text-transform:uppercase;letter-spacing:.06em}.stamp-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.stamp-modal.hidden{display:none}.stamp-modal-box{background:#fff;border-radius:24px;width:100%;max-width:320px;display:flex;flex-direction:column;box-shadow:0 20px 50px #0000001f}.stamp-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;border-bottom:1px solid #f1f5f9;font-weight:700;color:#1e293b;font-size:15px}.stamp-modal-close{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:16px;padding:4px;border-radius:8px;transition:all .15s}.stamp-modal-close:hover{background:#f1f5f9;color:#475569}.stamp-modal-body{display:flex;flex-direction:column;gap:14px;padding:16px 18px}.stamp-modal-type-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.stamp-modal-type-btn{padding:10px;border-radius:12px;border:1px solid #e2e8f0;background:#f8fafc;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.stamp-modal-type-btn.active{background:#eef2ff;border-color:#c7d2fe;color:#4f46e5}.stamp-modal-time{padding:12px 14px;border-radius:14px;border:1px solid #e2e8f0;background:#f8fafc;color:#334155;font-size:16px;font-weight:700;width:100%;box-sizing:border-box;outline:none;transition:all .15s}.stamp-modal-time:focus{border-color:#a5b4fc;background:#fff;box-shadow:0 0 0 4px #6366f114}.stamp-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 18px 16px;border-top:1px solid #f1f5f9}.stamp-modal-btn-cancel{padding:9px 16px;border-radius:12px;border:1px solid #e2e8f0;background:transparent;color:#64748b;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.stamp-modal-btn-cancel:hover{background:#f8fafc}.stamp-modal-btn-save{padding:9px 16px;border-radius:12px;border:none;background:#4f46e5;color:#fff;font-size:13px;font-weight:700;cursor:pointer;transition:all .15s}.stamp-modal-btn-save:hover{background:#4338ca}.stamp-log-actions{display:flex;gap:6px;margin-left:auto}.stamp-log-action-btn{padding:5px 12px;border-radius:8px;border:1px solid #e2e8f0;background:transparent;color:#64748b;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.stamp-log-action-btn:hover{background:#f1f5f9;color:#334155}.stamp-log-action-btn.danger{border-color:#ef44444d;color:#ef4444}.stamp-log-action-btn.danger:hover{background:#ef44440f}.floor-display{width:64px;height:64px;border:1.5px solid var(--border);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.floor-arrow-up{width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:9px solid #f59e0b;animation:blink-arrow 1.2s infinite}.floor-num{font-size:22px;font-weight:500;color:var(--text);min-width:20px;text-align:center}@keyframes blink-arrow{0%,to{opacity:1}50%{opacity:.15}}#view-admin{padding:24px;max-width:1200px;margin:0 auto;box-sizing:border-box}#view-admin *,#view-admin *:before,#view-admin *:after{box-sizing:border-box}@media (min-width: 960px){#view-admin{padding:32px 40px}#adminSummaryContainer{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}}body.admin-only #app{max-width:none;margin:0;padding:12px 12px 20px}body.in-admin-only .top-nav,body.admin-only .top-nav{display:none!important}body.in-admin-view #app{max-width:none;margin:0}body.in-admin-view #view-admin{max-width:1600px;width:100%}.admin-tabs{display:flex;align-items:center;justify-content:center;gap:4px;padding:4px;border-radius:16px;margin:6px auto 16px;background:var(--panel);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.admin-tab-btn{border:none;background:transparent;padding:8px 16px;font-size:14px;cursor:pointer;border-radius:12px;color:var(--muted);font-weight:600;transition:background .15s,color .15s}.admin-tab-btn:hover{background:var(--panel-soft);color:var(--text)}.admin-tab-btn.active{background:var(--accent);color:#fff}.admin-tab-content{display:none;margin-top:5px}.admin-tab-content.active{display:block}#adminSummaryContainer{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:18px;align-items:start}.admin-toolbar{display:flex;justify-content:flex-end;margin:12px 0 14px}.admin-month-control{display:inline-flex;align-items:center;gap:10px;padding:6px 10px;border-radius:12px;background:var(--panel);border:1px solid var(--border)}.admin-month-arrow{border:none;background:transparent;cursor:pointer;font-size:18px;padding:4px 8px;border-radius:10px;color:var(--muted)}.admin-month-arrow:hover{background:var(--panel-soft)}.admin-month-label{font-weight:600;min-width:140px;text-align:center;color:var(--text)}.admin-section-header{margin-bottom:10px}.admin-subheading{margin:6px 0 10px;color:var(--muted);font-size:.85rem}.admin-loading-text{font-size:.8rem;color:var(--muted)}.admin-error,.admin-empty{opacity:.8;padding:10px 0;color:var(--muted)}.admin-muted{font-size:12px;color:var(--muted)}.admin-user-list{display:flex;flex-direction:column;gap:8px}.admin-user-card{border-radius:16px;background:var(--panel);border:1px solid var(--border);padding:14px 16px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:8px}.admin-user-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}.admin-user-title-block{display:flex;flex-direction:column;gap:2px}.admin-user-title{font-size:1rem;font-weight:700;color:var(--text)}.admin-user-team{font-size:.78rem;color:var(--muted)}.admin-user-header .sync-chip{font-size:.75rem;padding:.15rem .55rem}.admin-month-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.admin-month-header-title{font-size:.95rem;font-weight:600;color:var(--text)}.admin-user-meta-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:4px}.admin-user-month-label{font-size:.8rem;color:var(--muted)}.admin-user-month-hours{font-size:.85rem;font-weight:600;color:var(--text)}.admin-user-vacation-chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;border:1px solid rgba(99,102,241,.4);background:var(--accent-soft);font-size:.75rem;color:var(--accent)}.admin-user-month-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border);font-size:17px;font-weight:500;color:var(--text)}.admin-month-badge{display:inline-flex;align-items:center;gap:8px;padding:4px 10px;border-radius:999px;font-size:12px;border:1px solid var(--border);background:var(--panel-soft);white-space:nowrap;color:var(--muted)}.admin-month-badge.transmitted{border-color:#22c55e66;color:#15803d;background:#22c55e14}.admin-week-list{margin-top:12px;display:flex;flex-direction:column;gap:10px}.admin-user-week-list{display:flex;flex-direction:column;gap:4px;margin-top:4px}.admin-user-week-row{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:10px;background:var(--panel-soft);border:1px solid var(--border)}.admin-user-week-row.locked{border-color:#6366f180;box-shadow:0 0 0 1px #6366f140}.admin-user-week-main{flex:1 1 auto;display:flex;align-items:center;gap:4px;min-width:0}.admin-user-week-label{font-size:.8rem;color:var(--text);white-space:nowrap}.admin-user-week-vacation-icon{font-size:.8rem;opacity:.9}.admin-user-week-status{flex:0 0 auto;font-size:.75rem;color:var(--muted)}.admin-user-week-status.status-ok{color:var(--success)}.admin-user-week-status.status-missing{color:var(--danger)}.admin-user-week-right{margin-left:auto;display:inline-flex;align-items:center;gap:6px}.admin-user-week-total{font-size:.9rem;font-weight:600;color:var(--text)}.admin-user-week-empty{font-size:.78rem;color:var(--muted)}.admin-user-week-lock-btn{border-radius:999px;border:1px solid var(--border);background:var(--panel);color:var(--muted);padding:2px 8px;font-size:.85rem;cursor:pointer}.admin-user-week-lock-btn:hover{background:var(--accent-soft);border-color:#6366f166;color:var(--accent)}.admin-week-block{border-radius:14px;border:1px solid var(--border);background:var(--panel);padding:12px;box-shadow:var(--shadow-sm)}.admin-week-block.locked{border-color:#6366f180;box-shadow:0 0 0 1px #6366f140}.admin-week-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-bottom:8px;border-bottom:1px solid var(--border);font-weight:600;color:var(--text)}.admin-week-header-left{flex:1 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:15px}.admin-week-header-right{display:inline-flex;align-items:center;gap:10px;flex:0 0 auto;white-space:nowrap}.admin-week-lock-btn{border:1px solid var(--border);background:var(--panel);color:var(--muted);border-radius:999px;padding:2px 10px;font-size:.8rem;cursor:pointer}.admin-week-lock-btn:hover{background:var(--accent-soft);border-color:#6366f166;color:var(--accent)}.admin-week-lock-btn.is-locked{border-color:#6366f199;color:var(--accent)}.admin-day-list{display:flex;flex-direction:column;gap:6px;margin-top:8px}.admin-day-row{display:grid;grid-template-columns:minmax(90px,10px) minmax(0,1fr) auto;gap:10px;align-items:center;padding:6px 8px;border-radius:10px;background:var(--panel-soft);column-gap:5px;cursor:pointer}.admin-day-row>*{min-width:0}.admin-day-row.expanded{outline:1px solid var(--border)}.admin-day-row.is-ferien,.admin-day-row.is-absence{opacity:.85}.admin-day-hours{display:grid;grid-template-columns:55px minmax(0,1fr);align-items:center;gap:10px;min-width:0}.admin-day-hours-text{text-align:right;white-space:nowrap}.admin-hours-bar{height:7px;width:80px;max-width:85px;border-radius:999px;background:var(--border);overflow:hidden}.admin-hours-bar-fill{height:100%;width:0%;background:var(--accent)}.admin-status{display:inline-flex;align-items:center;justify-content:flex-end;gap:8px;font-size:13px;white-space:nowrap;justify-self:end}.admin-status-dot{width:8px;height:8px;border-radius:999px;background:var(--muted)}.admin-status.missing .admin-status-dot{background:var(--danger)}.admin-status.ok .admin-status-dot{background:var(--success)}.admin-status.ferien .admin-status-dot,.admin-status.absence .admin-status-dot{background:var(--accent)}.admin-day-drawer{overflow:hidden;max-height:0;opacity:0;transform:translateY(-4px);transition:max-height .18s ease,opacity .18s ease,transform .18s ease;will-change:max-height;margin:6px 0;padding:10px 12px;border-radius:12px;background:var(--panel-soft);border:1px solid var(--border)}.admin-day-drawer.is-open{opacity:1;transform:translateY(0)}.admin-day-drawer-loading,.admin-day-drawer-error{font-size:13px;color:var(--muted)}.admin-day-drawer-content{display:grid;gap:8px;font-size:13px;color:var(--text)}.admin-day-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px}.admin-day-title{font-weight:700;color:var(--text)}.admin-day-subtitle{opacity:.7;font-size:12px;margin-top:2px;color:var(--muted)}.admin-day-status-badge{padding:4px 10px;border-radius:999px;font-weight:700;font-size:12px;white-space:nowrap;background:var(--panel-soft);border:1px solid var(--border);color:var(--muted)}.admin-day-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.admin-day-chip{padding:3px 8px;border-radius:999px;font-size:13px;background:var(--panel-soft);border:1px solid var(--border);color:var(--text)}.admin-day-chip.chip-muted{opacity:.7}.admin-day-totals{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;padding:10px;border-radius:10px;background:var(--accent-soft);margin-bottom:10px}.admin-day-kv{display:flex;justify-content:space-between;gap:10px;font-size:13px;color:var(--text)}.admin-day-kv.is-total{font-weight:800}.admin-day-mini-breakdown{grid-column:1 / -1;margin-top:6px;padding-top:6px;border-top:1px solid var(--border);font-size:12px}.admin-day-mini-title{font-weight:700;margin-bottom:4px;color:var(--text);font-size:13px}.admin-day-section{display:grid;gap:6px 12px;padding:10px;border-radius:10px;background:var(--panel-soft);margin-bottom:10px}.admin-day-section-title{font-weight:800;margin-bottom:6px;color:var(--text)}.admin-day-muted{opacity:.7;font-size:13px;color:var(--muted)}.admin-day-list-row{display:flex;gap:10px}.admin-day-list-left{min-width:90px;font-weight:700}.admin-day-list-right{opacity:.9}.admin-users-toolbar{display:flex;gap:10px;align-items:center;margin-bottom:14px;flex-wrap:wrap}.admin-users-add-btn{padding:10px 16px;border-radius:10px;border:none;background:var(--accent);color:#fff;font-weight:600;cursor:pointer;white-space:nowrap}.admin-users-add-btn:hover{filter:brightness(1.08)}.admin-users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.admin-user-item{border-radius:16px;background:var(--panel);border:1px solid var(--border);padding:14px;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-sm)}.admin-user-item-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.admin-user-item-name{font-size:15px;font-weight:600;color:var(--text)}.admin-user-item-meta{font-size:12px;color:var(--muted);display:flex;flex-direction:column;gap:2px}.admin-user-item-badge{font-size:11px;padding:2px 8px;border-radius:999px;font-weight:600}.admin-user-item-badge.admin{background:var(--accent-soft);color:var(--accent)}.admin-user-item-badge.user{background:var(--panel-soft);border:1px solid var(--border);color:var(--muted)}.admin-user-item-badge.inactive{background:#ef44441a;color:var(--danger)}.admin-user-item-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}.admin-user-btn{padding:6px 12px;border-radius:8px;border:1px solid var(--border);background:var(--panel-soft);color:var(--text);font-size:12px;cursor:pointer}.admin-user-btn:hover{background:var(--accent-soft);border-color:#6366f159;color:var(--accent)}.admin-user-btn.danger{border-color:#ef444459;color:var(--danger)}.admin-user-btn.danger:hover{background:#ef444414}.admin-user-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.admin-user-modal.hidden{display:none}.admin-user-modal-box{background:var(--panel);border:1px solid var(--border);border-radius:18px;width:100%;max-width:420px;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.admin-user-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;border-bottom:1px solid var(--border);font-weight:600;color:var(--text);font-size:15px}.admin-user-modal-close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px}.admin-user-modal-body{display:flex;flex-direction:column;gap:12px;padding:16px 18px}.admin-user-modal-label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}.admin-user-modal-input{padding:9px 12px;border-radius:10px;border:1px solid var(--border);background:var(--panel-soft);color:var(--text);font-size:14px;outline:none}.admin-user-modal-input:focus{border-color:#a5b4fc;box-shadow:0 0 0 3px var(--accent-soft)}.admin-user-modal-error{font-size:12px;color:var(--danger);padding:8px 10px;border-radius:8px;background:#ef444414;border:1px solid rgba(239,68,68,.25)}.admin-user-modal-error.hidden{display:none}.admin-user-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 18px 16px;border-top:1px solid var(--border)}.admin-user-modal-btn-cancel{padding:8px 16px;border-radius:10px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;font-size:13px}.admin-user-modal-btn-save{padding:8px 16px;border-radius:10px;border:none;background:var(--accent);color:#fff;font-weight:600;cursor:pointer;font-size:13px}.admin-payroll-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;margin-bottom:14px}.admin-payroll-filter{display:flex;flex-direction:column;gap:4px;min-width:170px;font-size:.8rem;color:var(--muted)}.admin-payroll-date{border-radius:12px;border:1px solid var(--border);background:var(--panel);color:var(--text);padding:8px 10px}.admin-payroll-refresh{border:none;border-radius:12px;background:var(--accent);color:#fff;font-weight:600;padding:9px 14px;cursor:pointer}.admin-payroll-summary{margin-bottom:14px;padding:10px 12px;border-radius:14px;background:var(--panel-soft);border:1px solid var(--border);color:var(--muted);font-size:.85rem}.admin-payroll-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}@media (max-width: 980px){.admin-payroll-grid{grid-template-columns:1fr}}.admin-payroll-card{border-radius:18px;padding:14px;background:var(--panel);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.admin-payroll-card-head{display:flex;justify-content:space-between;align-items:start;gap:10px;margin-bottom:12px}.admin-payroll-card-title{margin:0;font-size:1rem;font-weight:600;color:var(--text)}.admin-payroll-card-period{margin-top:2px;font-size:.78rem;color:var(--muted)}.admin-payroll-card-badge{padding:4px 8px;border-radius:999px;font-size:.72rem;font-weight:600;background:var(--accent-soft);color:var(--accent);white-space:nowrap}.admin-payroll-card-badge.is-complete{background:#22c55e1a;color:#15803d}.admin-payroll-card-badge.is-incomplete{background:#f59e0b1a;color:#b45309}.admin-payroll-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.admin-payroll-metrics--secondary{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-payroll-metric{border-radius:14px;padding:10px;background:var(--panel-soft);border:1px solid var(--border)}.admin-payroll-metric-label{display:block;margin-bottom:4px;font-size:.72rem;color:var(--muted)}.admin-payroll-metric-value{font-size:1rem;font-weight:600;color:var(--text)}.admin-payroll-empty{padding:18px;border-radius:16px;background:var(--panel-soft);border:1px dashed var(--border);color:var(--muted)}.admin-payroll-divider{height:1px;margin:14px 0 12px;background:var(--border)}.admin-payroll-subtitle{margin-bottom:10px;font-size:.78rem;font-weight:700;color:var(--muted);letter-spacing:.05em;text-transform:uppercase}.admin-personnel-toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}.admin-personnel-search{flex:1;min-width:220px;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:var(--panel);color:var(--text);outline:none}.admin-personnel-status,.admin-personnel-refresh{padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:var(--panel-soft);color:var(--text)}.admin-personnel-layout{display:grid;grid-template-columns:1.2fr 1fr;gap:16px}@media (max-width: 900px){.admin-personnel-layout{grid-template-columns:1fr}}.admin-absence-list .admin-absence-item{border:1px solid var(--border);border-radius:14px;padding:12px;margin-bottom:10px;background:var(--panel);box-shadow:var(--shadow-sm)}.admin-absence-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.admin-absence-title{font-weight:600;color:var(--text)}.admin-absence-meta{margin-top:6px;font-size:.95em;color:var(--muted)}.admin-absence-comment{margin-top:8px;color:var(--text);font-size:.9em}.admin-absence-actions{display:flex;gap:8px;margin-top:10px}.admin-absence-accept,.admin-absence-reject,.admin-konto-save{padding:8px 12px;border-radius:10px;border:1px solid var(--border);cursor:pointer;font-weight:600;font-size:13px;background:var(--panel-soft);color:var(--text)}.admin-absence-cancel-approve{background:#22c55e1a;color:#15803d;border:1px solid rgba(34,197,94,.4);border-radius:10px;padding:2px 8px;font-size:13px;cursor:pointer}.admin-absence-cancel-deny{background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.4);border-radius:10px;padding:2px 8px;font-size:13px;cursor:pointer}.admin-konten-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px}.admin-konto-card{border:1px solid var(--border);border-radius:14px;padding:14px;background:var(--panel);box-shadow:var(--shadow-sm)}.admin-konto-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}.admin-konto-user{font-weight:700;color:var(--text)}.admin-konto-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:10px}.admin-konto-grid label{display:flex;flex-direction:column;gap:6px;font-size:.9rem;color:var(--muted)}.admin-konto-input{padding:10px;border-radius:10px;border:1px solid var(--border);background:var(--panel-soft);color:var(--text);outline:none}.admin-konto-input:focus{border-color:#a5b4fc;box-shadow:0 0 0 3px var(--accent-soft)}.admin-konto-actions{margin-top:10px;display:flex;justify-content:flex-end}.admin-konto-metrics{margin:8px 0 10px;padding:10px;border-radius:12px;border:1px solid var(--border);background:var(--panel-soft)}.admin-konto-metric-row{display:flex;justify-content:space-between;align-items:baseline;gap:10px}.admin-konto-metric-label{font-size:.9rem;font-weight:500;color:var(--muted)}.admin-konto-metric-value{font-weight:600;color:var(--text)}.admin-day-presenz{display:flex;flex-direction:column;gap:10px}.admin-day-stamp-pills{display:flex;flex-wrap:wrap;gap:6px}.admin-stamp-pill{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:10px;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.admin-stamp-pill.stamp-in{background:#f0fdf4;color:#16a34a;border:1px solid rgba(34,197,94,.25)}.admin-stamp-pill.stamp-out{background:#fff1f2;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.admin-day-stamp-net{font-size:13px;font-weight:900;color:#4f46e5;background:#eef2ff;border:1px solid #c7d2fe;border-radius:10px;padding:7px 12px;align-self:flex-start}.anlagen-layout{display:grid;grid-template-columns:360px 1fr;gap:16px;align-items:start}@media (max-width: 900px){.anlagen-layout{grid-template-columns:1fr}}.anlagen-sidebar{display:flex;flex-direction:column;gap:10px}.anlagen-controls{display:flex;gap:8px;align-items:center}.anlagen-search{flex:1;min-width:0;padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:var(--panel);color:var(--text);outline:none}.anlagen-status,.anlagen-refresh{padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:var(--panel-soft);color:var(--text);cursor:pointer}.anlagen-list{border:1px solid var(--border);border-radius:12px;overflow:auto;max-height:70vh;background:var(--panel);box-shadow:var(--shadow-sm)}.anlagen-row{padding:10px 12px;border-bottom:1px solid var(--border);cursor:pointer;display:grid;grid-template-columns:1fr auto;gap:6px 10px}.anlagen-row:last-child{border-bottom:none}.anlagen-row:hover{background:var(--panel-soft)}.anlagen-row.is-selected{background:var(--accent-soft)}.anlagen-komnr{font-weight:700;color:var(--text)}.anlagen-meta{font-size:12px;color:var(--muted)}.anlagen-hours{font-weight:700;color:var(--text);justify-self:end}.anlagen-detail{border:1px solid var(--border);border-radius:12px;padding:14px;background:var(--panel);min-height:200px;box-shadow:var(--shadow-sm)}.anlagen-detail-empty{color:var(--muted)}.anlagen-detail-head{display:flex;justify-content:space-between;align-items:start;gap:12px;margin-bottom:10px}.anlagen-detail-title{font-size:18px;font-weight:800;color:var(--text)}.anlagen-detail-sub{font-size:14px;color:var(--muted);margin-top:4px;font-weight:600}.anlagen-detail-actions{display:inline-flex;gap:10px;align-items:center}.anlagen-archive-btn,.anlagen-export-btn{padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:var(--panel-soft);cursor:pointer;white-space:nowrap;color:var(--text)}.anlagen-archive-btn.is-archived{opacity:.8}.anlagen-charts{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:12px}@media (max-width: 900px){.anlagen-charts{grid-template-columns:1fr}}.anlagen-card{border:1px solid var(--border);border-radius:12px;padding:12px;background:var(--panel)}.anlagen-card h4{margin:0 0 10px;font-size:14px;color:var(--text)}.anlagen-donut{width:170px;height:170px;border-radius:50%;position:relative;margin-bottom:10px}.anlagen-donut:after{content:"";position:absolute;top:26px;right:26px;bottom:26px;left:26px;border-radius:50%;background:var(--panel);border:1px solid var(--border)}.anlagen-legend{display:grid;gap:6px}.anlagen-legend-item{display:grid;grid-template-columns:12px 1fr auto;gap:8px;align-items:center;font-size:13px;font-weight:500;color:var(--text)}.anlagen-legend-dot{width:10px;height:10px;border-radius:50%}.anlagen-bars{display:grid;gap:8px}.anlagen-bar-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;font-size:14px;color:var(--text)}.anlagen-bar-track{grid-column:1 / -1;height:8px;border-radius:999px;background:var(--border);overflow:hidden}.anlagen-bar-fill{height:100%;width:0%;background:var(--accent)}
