:root{--primary:#185fa5;--primary-dark:#0c447c;--primary-soft:#e6f1fb;--bg:#f4f6f9;--surface:#fff;--surface-2:#f7f8fa;--border:#e4e6eb;--border-strong:#d6dae1;--text:#1b1d22;--muted:#6b7280;--faint:#9aa0aa;--green:#1d9e75;--green-soft:#e1f5ee;--green-dark:#085041;--red:#d85a30;--red-soft:#fbeae3;--amber:#ba7517;--radius:8px;--radius-lg:12px;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0}button{font:inherit;cursor:pointer}a{color:var(--primary)}h1,h2,h3{font-weight:500}.muted{color:var(--muted)}.faint{color:var(--faint)}.center{text-align:center;padding:3rem}.error{color:var(--red);margin:.5rem 0;font-size:.9rem}.small{font-size:.85rem}.btn-primary{background:var(--primary);color:#fff;border-radius:var(--radius);border:none;align-items:center;gap:6px;padding:.55rem .95rem;font-weight:500;display:inline-flex}.btn-primary:hover{background:var(--primary-dark)}.btn-primary:disabled{opacity:.6;cursor:default}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border-strong);border-radius:var(--radius);align-items:center;gap:6px;padding:.55rem .95rem;display:inline-flex}.btn-secondary:hover{background:var(--surface-2)}.link-btn{color:var(--primary);background:0 0;border:none;font-weight:500}input,textarea,select{font:inherit;color:var(--text);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius);padding:.55rem .7rem}input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft);outline:none}input:disabled{background:var(--surface-2);color:var(--muted)}.login-wrap{place-items:center;min-height:100vh;display:grid}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:360px;padding:2.25rem}.login-logo{color:#fff;letter-spacing:.5px;background:#0d0d0d;border-radius:10px;place-items:center;width:44px;height:44px;margin-bottom:1rem;font-size:1.05rem;font-weight:500;display:grid}.login-card h1{margin:0 0 .25rem;font-size:1.4rem}.app-shell{min-height:100vh;display:flex}.rail{background:var(--surface-2);border-right:1px solid var(--border);flex-direction:column;align-items:center;gap:6px;width:60px;padding:14px 0;display:flex}.rail-logo{color:#fff;letter-spacing:.5px;background:#0d0d0d;border-radius:9px;place-items:center;width:38px;height:38px;margin-bottom:10px;font-size:.92rem;font-weight:500;display:grid}.rail-btn{border-radius:var(--radius);width:42px;height:42px;color:var(--muted);background:0 0;border:none;place-items:center;display:grid}.rail-btn:hover{color:var(--text);background:#eef0f3}.rail-btn.on{background:var(--primary);color:#fff}.rail-spacer{margin-top:auto}.main{flex:1;min-width:0;max-width:1200px;padding:18px 24px}.toolbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.toolbar-title .ctx{color:var(--faint);font-size:.78rem}.toolbar-title h1{margin:0;font-size:1.35rem}.toolbar-actions{align-items:center;gap:10px;display:flex}.filter{color:var(--muted);align-items:center;gap:6px;font-size:.88rem;display:flex}.avatar{background:var(--primary-soft);width:34px;height:34px;color:var(--primary-dark);border-radius:50%;place-items:center;font-size:.8rem;font-weight:500;display:grid}.metrics{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;display:grid}.metric{background:var(--surface-2);border-radius:var(--radius);padding:.85rem 1rem}.metric .label{color:var(--muted);align-items:center;gap:6px;font-size:.78rem;display:flex}.metric .value{margin-top:2px;font-size:1.5rem;font-weight:500}.calendar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.1rem 1.2rem}.calendar-bar{justify-content:space-between;align-items:center;margin-bottom:.9rem;display:flex}.calendar-nav{align-items:center;gap:10px;display:flex}.calendar-nav h2{text-transform:capitalize;margin:0;font-size:1.05rem}.icon-btn{border:1px solid var(--border-strong);border-radius:var(--radius);width:30px;height:30px;color:var(--muted);background:0 0;place-items:center;display:grid}.icon-btn:hover{background:var(--surface-2)}.legend{color:var(--muted);align-items:center;gap:14px;font-size:.78rem;display:flex}.legend span{align-items:center;gap:5px;display:flex}.legend .dot{border-radius:50%;width:9px;height:9px}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.calendar-weekday{text-align:center;color:var(--faint);padding:.2rem 0;font-size:.72rem}.calendar-cell{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);flex-direction:column;gap:3px;min-height:88px;padding:5px;display:flex}.calendar-cell.is-muted{background:var(--surface-2)}.calendar-cell.is-muted .calendar-date{color:var(--faint)}.calendar-date{color:var(--muted);font-size:.74rem}.calendar-chip{text-align:left;background:var(--primary-soft);color:var(--primary-dark);white-space:nowrap;border:none;border-radius:6px;align-items:center;gap:5px;padding:2px 6px;font-size:.72rem;display:flex;overflow:hidden}.calendar-chip .cdot{border-radius:50%;flex:none;width:6px;height:6px}.calendar-chip .clabel{text-overflow:ellipsis;overflow:hidden}.calendar-chip.status-filled{background:var(--green-soft);color:var(--green-dark)}.calendar-chip.status-cancelled{color:var(--muted);background:#f1f1f1;text-decoration:line-through}.modal-backdrop{z-index:10;background:#0f141e73;place-items:start center;padding:2rem 1rem;display:grid;position:fixed;inset:0;overflow:auto}.modal{background:var(--surface);border-radius:var(--radius-lg);width:520px;max-width:100%;overflow:hidden}.bf-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.bf-head h2{margin:0;font-size:1.2rem}.bf-body{max-height:64vh;padding:1.1rem 1.25rem;overflow:auto}.bf-foot{border-top:1px solid var(--border);background:var(--surface-2);justify-content:flex-end;gap:10px;padding:.9rem 1.25rem;display:flex}.field{margin-bottom:.95rem}.field>label,.field-label{color:var(--muted);margin-bottom:5px;font-size:.78rem;font-weight:500;display:block}.field input,.field textarea,.field select{width:100%}.field-grid{grid-template-columns:1fr 130px;gap:12px;display:grid}.locked{background:var(--surface-2);color:var(--muted);border:1px solid var(--border-strong);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:.55rem .7rem;display:flex}.segmented{background:var(--surface-2);border-radius:var(--radius);gap:4px;padding:4px;display:flex}.segmented button{color:var(--muted);background:0 0;border:none;border-radius:6px;flex:1;padding:.5rem;font-size:.85rem}.segmented button.on{background:var(--surface);color:var(--text);border:1px solid var(--border-strong);font-weight:500}.stepper{border:1px solid var(--border-strong);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:.3rem .5rem;display:flex}.stepper span{font-size:1rem}.stepper button{background:var(--surface-2);width:26px;height:26px;color:var(--muted);border:none;border-radius:6px;place-items:center;display:grid}.emp-picker{position:relative}.emp-chips{border:1px solid var(--border-strong);border-radius:var(--radius);background:var(--surface);flex-wrap:wrap;align-items:center;gap:5px;padding:5px 7px;display:flex}.emp-chips input{box-shadow:none;border:none;outline:none;flex:1;min-width:120px;padding:4px}.chip{background:var(--primary-soft);color:var(--primary-dark);border-radius:20px;align-items:center;gap:5px;padding:3px 9px;font-size:.8rem;display:inline-flex}.chip button{color:var(--primary-dark);background:0 0;border:none;padding:0;display:inline-flex}.emp-dropdown{z-index:5;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);max-height:220px;margin:4px 0 0;padding:4px;list-style:none;position:absolute;top:100%;left:0;right:0;overflow:auto}.emp-dropdown button{text-align:left;background:0 0;border:none;border-radius:6px;width:100%;padding:.45rem .5rem;display:block}.emp-dropdown button:hover{background:var(--primary-soft)}.hint{color:var(--faint);margin-top:6px;font-size:.72rem}.daypicker{border:1px solid var(--border);border-radius:var(--radius);padding:.75rem}.daypicker-head{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.daypicker-title{text-transform:capitalize;font-size:.9rem;font-weight:500}.daypicker-grid{grid-template-columns:repeat(7,1fr);gap:3px;display:grid}.daypicker-weekday{text-align:center;color:var(--faint);font-size:.68rem}.daypicker-day{aspect-ratio:1;background:var(--surface-2);color:var(--text);border:1px solid #0000;border-radius:6px;font-size:.8rem}.daypicker-day:hover:not(:disabled){border-color:var(--primary)}.daypicker-day.is-muted{color:var(--faint);opacity:.5}.daypicker-day.is-today{border-color:var(--amber)}.daypicker-day.is-selected{background:var(--primary);color:#fff}.daypicker-day:disabled{opacity:.35;cursor:not-allowed}.daypicker-counter{color:var(--primary);font-size:.78rem;font-weight:500}.toggle-row{justify-content:space-between;align-items:center;display:flex}.toggle{background:var(--border-strong);border:none;border-radius:20px;width:44px;height:25px;transition:background .15s;position:relative}.toggle.on{background:var(--primary)}.toggle .knob{background:#fff;border-radius:50%;width:21px;height:21px;transition:left .15s;position:absolute;top:2px;left:2px}.toggle.on .knob{left:21px}.dropzone{border:1px dashed var(--border-strong);border-radius:var(--radius);color:var(--muted);cursor:pointer;align-items:center;gap:10px;padding:.9rem;font-size:.85rem;display:flex}.dropzone:hover{border-color:var(--primary)}.dropzone input{display:none}.dropzone .fname{color:var(--text)}.card-table{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.card-table table{border-collapse:collapse;width:100%;font-size:.9rem}.card-table th{text-align:left;color:var(--muted);border-bottom:1px solid var(--border);background:var(--surface-2);padding:.7rem 1rem;font-size:.74rem;font-weight:500}.card-table td{border-bottom:1px solid var(--border);padding:.7rem 1rem}.card-table tr:last-child td{border-bottom:none}.card-table tr.is-inactive td{opacity:.55}.role-badge{border-radius:20px;padding:2px 9px;font-size:.72rem}.role-badge.admin{background:var(--primary-soft);color:var(--primary-dark)}.role-badge.employee{background:var(--surface-2);color:var(--muted)}.role-badge.kund{color:var(--amber);background:#fbeedd}.status-on{color:var(--green);font-weight:500}.status-off{color:var(--muted)}.row-actions{justify-content:flex-end;gap:6px;display:flex}.card-table tr.clickable{cursor:pointer}.card-table tr.clickable:hover td{background:var(--surface-2)}.row-marking{font-weight:500}.list-search{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius);max-width:360px;color:var(--muted);align-items:center;gap:8px;margin-bottom:14px;padding:0 .7rem;display:flex}.list-search input{box-shadow:none;border:none;flex:1;padding:.55rem 0}.list-search input:focus{box-shadow:none}.settings-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;max-width:760px;display:grid}.settings-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem}.settings-card-head{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.settings-card-head h3{margin:0;font-size:1rem}.saved-flag{color:var(--green);align-items:center;gap:4px;font-size:.8rem;display:inline-flex}.detail-head{justify-content:space-between;align-items:center;display:flex}.detail-head h2{margin:0}.detail-sub{margin-top:2px;font-size:.85rem}.detail-statusrow{align-items:center;gap:8px;margin-bottom:1rem;display:flex}.detail-info{margin:0 0 1rem;font-size:.95rem}.fillbar{background:var(--surface-2);border-radius:var(--radius);margin-bottom:1rem;padding:.7rem .85rem}.fillbar-head{color:var(--muted);justify-content:space-between;margin-bottom:6px;font-size:.82rem;display:flex}.fillbar-track{background:var(--border);border-radius:20px;height:7px;overflow:hidden}.fillbar-fill{background:var(--green);border-radius:20px;height:100%;transition:width .2s}.day-chips{flex-wrap:wrap;gap:5px;margin-bottom:1rem;display:flex}.day-chip{background:var(--primary-soft);color:var(--primary-dark);border-radius:6px;padding:3px 9px;font-size:.78rem}.pdf-btn{border:1px solid var(--border-strong);border-radius:var(--radius);align-items:center;gap:6px;padding:.5rem .85rem;font-size:.88rem;text-decoration:none;display:inline-flex}.pdf-btn:hover{background:var(--surface-2)}.badge{border-radius:20px;padding:2px 10px;font-size:.74rem;font-weight:500;display:inline-block}.badge.status-open{background:var(--primary-soft);color:var(--primary-dark)}.badge.status-filled{background:var(--green-soft);color:var(--green-dark)}.badge.status-cancelled{color:var(--muted);background:#f1f1f1}.detail dl{grid-template-columns:130px 1fr;gap:.4rem 1rem;margin:1rem 0;display:grid}.detail dt{color:var(--muted);font-size:.85rem}.detail dd{margin:0}.response-list{flex-direction:column;gap:.35rem;margin:.5rem 0;padding:0;list-style:none;display:flex}.response-list li{align-items:center;gap:.5rem;font-size:.9rem;display:flex}.rdot{border-radius:50%;width:9px;height:9px}.rdot.accepted{background:var(--green)}.rdot.rejected{background:var(--red)}.rdot.info_requested{background:var(--amber)}.rdot.pending{background:var(--faint)}.emp-view{max-width:560px;margin:0 auto;padding:.75rem .9rem 2rem}.emp-topbar{justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.emp-topbar .brand{font-size:1.1rem;font-weight:500}.emp-greeting{margin:0 0 1rem}.emp-list{flex-direction:column;gap:.85rem;margin:0;padding:0;list-style:none;display:flex}.emp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:.95rem}.emp-card.is-highlighted{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.emp-card-head{align-items:center;gap:.5rem;display:flex}.emp-card-head strong{font-size:1.05rem}.tag{color:var(--amber);background:#fbeedd;border-radius:20px;align-items:center;gap:4px;padding:1px 8px;font-size:.72rem;display:inline-flex}.emp-info{margin:.5rem 0;font-size:.92rem}.emp-dates{color:var(--muted);align-items:center;gap:6px;margin-top:.35rem;font-size:.9rem;display:flex}.emp-pdf{align-items:center;gap:5px;margin-top:.5rem;font-size:.9rem;display:inline-flex}.emp-actions{gap:.5rem;margin-top:.85rem;display:flex}.emp-actions button{border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:5px;padding:.7rem 0;font-size:.95rem;font-weight:500;display:inline-flex}.btn-accept{background:var(--green);color:#fff}.btn-reject{background:var(--red-soft);color:var(--red)}.btn-info{background:var(--surface-2);color:var(--text)}.emp-actions button:disabled{opacity:.55}.emp-status{text-align:center;border-radius:10px;justify-content:center;align-items:center;gap:6px;margin-top:.85rem;padding:.6rem;font-size:.92rem;font-weight:500;display:flex}.emp-status.accepted{background:var(--green-soft);color:var(--green-dark)}.emp-status.rejected{background:var(--red-soft);color:var(--red)}.emp-status.info_requested{color:var(--amber);background:#fbeedd}.emp-status.closed{color:var(--muted);background:#f1f1f1}
