:root{--bg:#0d0e10;--bg-elev:#16181c;--bg-elev-2:#1d2025;--bg-elev-3:#22262d;--border:#2a2e36;--border-strong:#3a3f4a;--text:#eef0f3;--text-dim:#9aa0aa;--text-faint:#6b7280;--accent:#f5a623;--accent-soft:#f5a62329;--accent-strong:#f7b94c;--accent-ink:#1a1206;--danger:#e5484d;--danger-soft:#e5484d29;--success:#46a758;--success-soft:#46a7582e;--radius:12px;--radius-sm:8px;--shadow:0 8px 28px #00000080;--header-h:60px;--nav-h:64px;--touch:44px;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--safe-left:env(safe-area-inset-left,0px);--safe-right:env(safe-area-inset-right,0px)}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}html{overflow-x:hidden}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overscroll-behavior-y:none;max-width:100vw;font-family:Barlow,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;line-height:1.45;overflow-x:hidden}h1,h2,h3,h4{letter-spacing:.02em;margin:0;font-family:Barlow Condensed,Barlow,sans-serif;font-weight:600}h1{font-size:1.6rem}h2{margin-bottom:.85rem;font-size:1.35rem}h3{font-size:1.1rem}button{-webkit-tap-highlight-color:transparent;font-family:inherit}input,select,textarea{color:var(--text);background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;min-height:var(--touch);outline:none;padding:.7rem .85rem;font-family:inherit;font-size:16px;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}textarea{resize:vertical;min-height:80px}label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);margin-bottom:.4rem;font-size:12px;font-weight:600;display:block}.req{color:var(--accent);margin-left:2px;font-weight:700}.field-error :is(input,select,textarea,.combobox-input){border-color:var(--danger)}.app{min-height:100vh;padding-bottom:calc(var(--nav-h) + var(--safe-bottom));flex-direction:column;display:flex}.header{z-index:10;padding:.5rem 1rem;padding-top:calc(.5rem + var(--safe-top));padding-left:calc(1rem + var(--safe-left));padding-right:calc(1rem + var(--safe-right));height:calc(var(--header-h) + var(--safe-top));-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--border);background:#0d0e10eb;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.brand{align-items:center;gap:.7rem;display:flex}.brand-text{flex-direction:column;line-height:1;display:flex}.brand-name{letter-spacing:.04em;font-family:Barlow Condensed,sans-serif;font-size:1.35rem;font-weight:700}.brand-sub{letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);margin-top:2px;font-size:10.5px;font-weight:600}.header-right{align-items:center;gap:.5rem;display:flex}.role-chip{letter-spacing:.06em;text-transform:uppercase;background:var(--accent-soft);color:var(--accent-strong);border-radius:999px;padding:.25rem .6rem;font-size:11px;font-weight:700}.role-chip.worker{color:#7cb8ff;background:#5eaaff29}.icon-btn{border:1px solid var(--border);color:var(--text-dim);border-radius:var(--radius-sm);width:var(--touch);height:var(--touch);cursor:pointer;background:0 0;justify-content:center;align-items:center;transition:color .15s,border-color .15s,background .15s;display:inline-flex}.icon-btn:hover{color:var(--text);border-color:var(--border-strong)}.icon-btn.danger:hover{color:var(--danger);border-color:var(--danger);background:var(--danger-soft)}.main{padding:1rem;padding-left:calc(1rem + var(--safe-left));padding-right:calc(1rem + var(--safe-right));flex:1;width:100%;max-width:880px;margin:0 auto}.bottom-nav{z-index:20;-webkit-backdrop-filter:blur(10px);border-top:1px solid var(--border);padding-bottom:var(--safe-bottom);height:calc(var(--nav-h) + var(--safe-bottom));background:#16181cf5;grid-auto-columns:1fr;grid-auto-flow:column;display:grid;position:fixed;bottom:0;left:0;right:0}.nav-btn{color:var(--text-dim);cursor:pointer;min-height:var(--touch);background:0 0;border:0;flex-direction:column;justify-content:center;align-items:center;gap:3px;padding:0;font-size:11px;font-weight:600;transition:color .15s;display:flex;position:relative}.nav-btn .nav-label{letter-spacing:.02em}.nav-btn.active{color:var(--accent);background:linear-gradient(to top, var(--accent-soft) 0%, transparent 60%)}.nav-btn.active:after{content:"";background:var(--accent);border-radius:0 0 3px 3px;height:3px;position:absolute;top:0;left:20%;right:20%}.nav-btn:focus-visible{outline:2px solid var(--accent);outline-offset:-4px}.card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;padding:1.1rem;position:relative}.entry-card-head{flex-wrap:wrap;align-items:baseline;gap:.4rem .6rem;margin-bottom:.85rem;display:flex}.entry-card-head h2{margin-bottom:0}.entry-card-sub{color:var(--text-dim);font-size:14px;font-weight:600}@media (width<=480px){.entry-card-head{gap:.1rem .5rem}.entry-card-sub{width:100%;font-size:13px}}.entry-form{padding-bottom:0}@media (width<=640px){.entry-form{padding-bottom:110px}}.form-row{flex-direction:column;gap:1rem;display:flex}.form-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.9rem;display:grid}.btn{min-height:var(--touch);border-radius:var(--radius-sm);cursor:pointer;background:var(--bg-elev-2);color:var(--text);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:.45rem;padding:.7rem 1.1rem;font-size:15px;font-weight:700;transition:filter .15s,transform 50ms,background .15s,border-color .15s;display:inline-flex}.btn:hover{filter:brightness(1.1)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn.primary,.btn.primary:disabled{background:var(--accent);color:var(--accent-ink)}.btn.ghost{border-color:var(--border);color:var(--text-dim);background:0 0}.btn.ghost:hover{color:var(--text);border-color:var(--border-strong)}.btn.danger{background:var(--danger);color:#fff}.btn.full{width:100%}.btn.lg{min-height:52px;padding:.95rem 1.2rem;font-size:16px}.btn.sm{min-height:36px;padding:.4rem .75rem;font-size:13px}.hours-block{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.1rem .6rem;transition:border-color .2s,box-shadow .2s,background .2s}.hours-block.glow{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft), 0 0 16px var(--accent-soft);background:linear-gradient(140deg, var(--bg-elev-2), #f5a6231a)}.hours-stepper-h{grid-template-columns:auto 1fr auto;align-items:center;gap:.9rem;display:grid}.step-btn-circle{background:var(--bg-elev-3);border:1px solid var(--border-strong);width:52px;height:52px;color:var(--accent);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:background .15s,border-color .15s;display:inline-flex}.step-btn-circle:hover{background:var(--accent-soft);border-color:var(--accent)}.step-btn-circle:active{transform:scale(.95)}.hours-value{justify-content:center;align-items:baseline;gap:.3rem;display:flex}.hours-value input{text-align:center;width:100%;max-width:120px;color:var(--accent);-moz-appearance:textfield;background:0 0;border:0;min-height:0;padding:0;font-family:Barlow Condensed,sans-serif;font-size:2.8rem;font-weight:700}.hours-value input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.hours-value input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.hours-value input:focus{box-shadow:none}.hours-unit{color:var(--text-dim);font-family:Barlow Condensed,sans-serif;font-size:1.4rem;font-weight:700}.hours-slider{appearance:none;cursor:pointer;background:0 0;border:0;width:100%;height:36px;min-height:0;margin-top:.7rem;padding:0}.hours-slider:focus{box-shadow:none}.hours-slider::-webkit-slider-runnable-track{background:var(--bg-elev-3);border-radius:3px;height:6px}.hours-slider::-webkit-slider-thumb{appearance:none;background:var(--accent);border:3px solid var(--accent-ink);cursor:pointer;border-radius:50%;width:26px;height:26px;margin-top:-10px;box-shadow:0 1px 6px #00000080}.hours-slider::-moz-range-track{background:var(--bg-elev-3);border-radius:3px;height:6px}.hours-slider::-moz-range-thumb{background:var(--accent);border:3px solid var(--accent-ink);cursor:pointer;border-radius:50%;width:22px;height:22px}.hours-slider-scale{color:var(--text-faint);justify-content:space-between;margin-top:-2px;padding:0 4px;font-size:11px;display:flex}.day-compact{background:var(--bg-elev-2);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius-sm);flex-wrap:wrap;align-items:center;gap:.5rem .7rem;padding:.55rem .75rem;font-size:14px;display:flex}.day-compact-text{flex:1;min-width:0}.day-compact-text strong{color:var(--accent-strong);font-weight:700}.day-compact-sep{color:var(--text-faint)}.day-compact-tag{letter-spacing:.04em;text-transform:uppercase;border-radius:999px;margin-left:.5rem;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.day-compact-tag.success{background:var(--success-soft);color:var(--success)}.day-compact .quick-fill-btn{border-style:dashed!important;border-color:var(--accent)!important;color:var(--accent-strong)!important}.day-compact .quick-fill-btn:hover{background:var(--accent-soft)!important;border-style:solid!important}.date-compact-field{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex;position:relative}.date-compact-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);margin:0;font-size:12px;font-weight:600}.date-pill-wrap{border-radius:var(--radius-sm);background:var(--bg-elev-2);border:1px solid var(--border-strong);cursor:pointer;align-items:center;height:36px;padding:0 .9rem;transition:border-color .15s,background .15s;display:inline-flex;position:relative}.date-pill-wrap:hover{border-color:var(--accent)}.date-pill-wrap.past{border-color:var(--accent);background:var(--accent-soft)}.date-pill-display{color:var(--text);pointer-events:none;white-space:nowrap;align-items:center;gap:.4rem;font-size:14px;font-weight:600;display:inline-flex}.date-pill-wrap.past .date-pill-display{color:var(--accent-strong)}.date-pill-input{opacity:0;cursor:pointer;appearance:none;pointer-events:auto;color:#0000;background:0 0;border:0;width:100%;min-width:100%;height:100%;margin:0;padding:0;font-size:16px;position:absolute;inset:0}.date-pill-input::-webkit-date-and-time-value{text-align:left;margin:0}.date-pill-input::-webkit-calendar-picker-indicator{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.notes-add-link{border:1px dashed var(--border-strong);color:var(--text-dim);border-radius:var(--radius-sm);cursor:pointer;text-align:left;background:0 0;align-self:flex-start;padding:.5rem .8rem;font-size:13px;font-weight:600;transition:color .15s,border-color .15s}.notes-add-link:hover{color:var(--accent-strong);border-color:var(--accent)}.submit-sticky{width:100%}@media (width<=640px){.submit-sticky{left:0;right:0;bottom:calc(var(--nav-h) + var(--safe-bottom));z-index:18;padding:.6rem calc(.75rem + var(--safe-left)) .6rem calc(.75rem + var(--safe-right));-webkit-backdrop-filter:blur(8px);background:linear-gradient(#0d0e1000,#0d0e10f7 30%);position:fixed}.submit-sticky .btn{box-shadow:0 6px 20px #0006}}.date-picker{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:.7rem;padding:.7rem .8rem .8rem;display:flex}.date-pills{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex;position:relative}.date-pill{background:var(--bg-elev-3);color:var(--text);border:1px solid var(--border-strong);letter-spacing:.02em;cursor:pointer;border-radius:999px;justify-content:center;align-items:center;gap:.35rem;height:40px;min-height:40px;padding:0 1rem;font-size:14px;font-weight:700;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.date-pill:hover{border-color:var(--accent);color:var(--accent-strong)}.date-pill.active{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.date-pill.active:hover{color:var(--accent-ink)}.date-pill:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.date-pill-custom{color:var(--text-dim);margin-left:auto;padding:0 .9rem}.date-pill-custom:hover:not(.active){color:var(--accent-strong)}.date-pill.active.date-pill-custom,.date-pill.active.date-pill-custom:hover{color:var(--accent-ink)}.date-selected{color:var(--text);letter-spacing:.01em;font-family:Barlow Condensed,sans-serif;font-size:1.35rem;font-weight:700;line-height:1.2}@media (width<=380px){.date-pill{height:38px;min-height:38px;padding:0 .75rem;font-size:13px}.date-pill-custom{padding:0 .7rem}.date-pill-custom-label{display:none}.date-selected{font-size:1.15rem}}.day-overview{background:linear-gradient(140deg, var(--bg-elev-2), var(--bg-elev-3));border:1px solid var(--border-strong);border-radius:var(--radius);flex-direction:column;gap:.7rem;padding:.85rem 1rem .95rem;display:flex}.day-overview-head{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:.5rem;padding-bottom:.5rem;display:flex}.day-overview-title{letter-spacing:.06em;text-transform:uppercase;color:var(--text-dim);font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:700}.day-overview-date{color:var(--text);font-size:14px;font-weight:700}.day-overview-warn{background:var(--danger-soft);border:1px solid var(--danger);color:#ffd5d6;border-radius:var(--radius-sm);align-items:center;gap:.5rem;padding:.55rem .7rem;font-size:14px;font-weight:600;display:flex}.day-overview-warn.weekend{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-strong)}.day-overview-body{flex-direction:column;gap:.7rem;display:flex}.day-overview-empty{color:var(--text-dim);font-size:14px;font-style:italic}.day-overview-target{color:var(--text-dim);font-size:13px;font-weight:600}.day-overview-hint{padding-top:.25rem;font-size:13px;font-style:italic}.day-stats{flex-direction:column;gap:.35rem;display:flex}.day-stat{flex-wrap:wrap;align-items:center;gap:.45rem;font-size:14px;display:flex}.day-stat-ico{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex}.day-stat-ico.ok{background:var(--success-soft);color:var(--success)}.day-stat-ico.warn{background:var(--accent-soft);color:var(--accent)}.day-stat-label{color:var(--text-dim);font-weight:600}.day-stat-val{color:var(--text);font-family:Barlow Condensed,sans-serif;font-size:1.25rem;font-weight:700}.day-stat-val.warn{color:var(--accent-strong)}.day-stat-tag{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;margin-left:.25rem;padding:2px 8px;font-size:11px;font-weight:700}.day-stat-tag.success{background:var(--success-soft);color:var(--success)}.day-stat-tag.warn{background:var(--accent-soft);color:var(--accent-strong)}.day-stat-target{color:var(--text-faint);letter-spacing:.02em;border-top:1px dashed var(--border);text-align:center;padding-top:.45rem;font-size:12px;font-weight:600}.day-list-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);margin-bottom:.35rem;font-size:11px;font-weight:700}.day-list-ul{flex-direction:column;gap:.3rem;margin:0;padding:0;list-style:none;display:flex}.day-entry{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:.2rem;padding:.4rem .55rem;font-size:14px;display:flex}.day-entry-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.day-entry-notes{color:var(--text-dim);padding-left:56px;font-size:12.5px;font-style:italic;line-height:1.3}.day-entry-hours{color:var(--accent);flex-shrink:0;min-width:48px;font-family:Barlow Condensed,sans-serif;font-size:1rem;font-weight:700}.day-entry-act{font-weight:600}.day-entry-act.absence{color:var(--danger)}.day-entry-site{color:var(--text-dim);flex:1;min-width:0;font-size:13px}.day-entry-del{color:var(--text-faint);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;width:32px;height:32px;margin-left:auto;transition:color .15s,background .15s,border-color .15s;display:inline-flex}.day-entry-del:hover{color:var(--danger);background:var(--danger-soft);border-color:var(--danger)}.quick-fill-btn{font-weight:700;border-style:dashed!important;border-color:var(--accent)!important;color:var(--accent-strong)!important}.quick-fill-btn:hover{background:var(--accent-soft)!important;border-style:solid!important}@media (width<=480px){.day-entry{font-size:13px}.day-entry-site{flex-basis:100%;width:100%}.day-stat{font-size:13px}.day-stat-val{font-size:1.1rem}}.week-overview{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.week-toggle{width:100%;color:var(--text);min-height:var(--touch);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;background:0 0;border:0;justify-content:space-between;align-items:center;padding:.7rem .9rem;font-family:Barlow Condensed,sans-serif;font-size:14px;font-weight:700;display:flex}.week-toggle:hover{background:var(--bg-elev-2)}.week-toggle-label{color:var(--text-dim)}.week-toggle-week{color:var(--text)}.week-body{border-top:1px solid var(--border);flex-direction:column;gap:.7rem;padding:.4rem .9rem .9rem;display:flex}.week-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;padding-top:.4rem;display:flex}.week-head-title{flex-wrap:wrap;align-items:baseline;gap:.5rem;display:flex}.week-head-kw{color:var(--accent);letter-spacing:.04em;font-family:Barlow Condensed,sans-serif;font-size:1.4rem;font-weight:700}.week-head-range{color:var(--text-dim);font-size:13px;font-weight:600}.week-nav{gap:.3rem;display:flex}.week-nav-btn{border-radius:var(--radius-sm);background:var(--bg-elev-2);border:1px solid var(--border);width:36px;height:36px;color:var(--text-dim);cursor:pointer;justify-content:center;align-items:center;font-size:13px;display:inline-flex}.week-nav-btn:hover:not(:disabled){color:var(--accent);border-color:var(--accent)}.week-nav-btn:disabled{opacity:.35;cursor:not-allowed}.week-progress{flex-direction:column;gap:.25rem;display:flex}.week-progress-bar{background:var(--bg-elev-3);border-radius:4px;width:100%;height:8px;overflow:hidden}.week-progress-fill{background:var(--accent);height:100%;transition:width .35s ease-out}.week-progress-fill.full{background:var(--success)}.week-progress-label{color:var(--text-dim);text-align:right;font-size:12px;font-weight:600}.week-loading{color:var(--text-dim);padding:.5rem 0;font-size:13px}.week-days{flex-direction:column;gap:.3rem;margin:0;padding:0;list-style:none;display:flex}.week-day{flex-direction:column;gap:.15rem;display:flex}.week-day-btn{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);cursor:pointer;text-align:left;grid-template-columns:78px 1fr auto 22px;align-items:center;gap:.55rem;min-height:40px;padding:.45rem .6rem;font-family:inherit;font-size:14px;transition:border-color .15s,background .15s;display:grid}.week-day-btn:hover{border-color:var(--accent);background:var(--bg-elev-3)}.week-day.today .week-day-btn{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-soft) inset}.week-day.future .week-day-btn{opacity:.55}.week-day-label{color:var(--text-dim);letter-spacing:.03em;font-family:Barlow Condensed,sans-serif;font-size:13.5px;font-weight:700}.week-day.today .week-day-label{color:var(--accent-strong)}.week-day-bar{background:var(--bg-elev-3);border-radius:5px;min-width:40px;height:10px;position:relative;overflow:hidden}.week-day-bar-fill{background:var(--accent);transition:width .3s ease-out;position:absolute;inset:0 auto 0 0}.week-day-bar-fill.complete{background:var(--success)}.week-day-bar-fill.missing{background:var(--accent)}.week-day-bar-fill.weekend,.week-day-bar-fill.weekend-overtime,.week-day-bar-fill.future{background:var(--text-faint)}.week-day-hours{color:var(--text);font-variant-numeric:tabular-nums;text-align:right;min-width:50px;font-family:Barlow Condensed,sans-serif;font-size:14px;font-weight:700}.week-day-sym{width:22px;height:22px;color:var(--text-faint);border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:inline-flex}.week-day-sym.complete,.week-day-sym.absence{background:var(--success-soft);color:var(--success)}.week-day-sym.missing,.week-day-sym.weekend-overtime{background:var(--accent-soft);color:var(--accent-strong)}.week-day-badge{white-space:nowrap;text-overflow:ellipsis;border-radius:999px;align-items:center;gap:.3rem;padding:.15rem .55rem;font-size:13px;font-weight:700;display:inline-flex;overflow:hidden}.week-day-badge.ferien{color:#7cb8ff;background:#5eaaff29}.week-day-badge.krank,.week-day-badge.unfall{background:var(--danger-soft);color:#ffd5d6}.week-day-hint{color:var(--accent-strong);padding-left:88px;font-size:11.5px;font-style:italic;font-weight:600}.week-foot{border-top:1px dashed var(--border);flex-direction:column;gap:.25rem;padding-top:.55rem;font-size:13px;display:flex}.week-foot-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:700}.week-foot-val{color:var(--accent);font-family:Barlow Condensed,sans-serif;font-size:1.2rem;font-weight:700}.week-foot-of{color:var(--text-dim);font-size:12px}.week-foot-abs{color:var(--text-dim);font-size:12px;font-weight:600}@media (width<=480px){.week-day-btn{grid-template-columns:56px 1fr auto 22px;gap:.4rem;padding:.4rem .5rem;font-size:13px}.week-day-hours{min-width:44px;font-size:13px}.week-day-hint{padding-left:66px}.week-head-kw{font-size:1.15rem}}@media (width<=360px){.week-day-btn{grid-template-columns:52px auto 20px}.week-day-bar{display:none}}.success-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius);z-index:50;pointer-events:none;background:#0d0e10f2;flex-direction:column;justify-content:center;align-items:center;gap:.8rem;animation:.18s ease-out fade-in;display:flex;position:absolute;inset:0}.success-ring{background:var(--success-soft);width:100px;height:100px;color:var(--success);border-radius:50%;place-items:center;animation:.4s cubic-bezier(.2,1.4,.4,1) pop;display:grid}.success-msg{color:var(--success);text-align:center;padding:0 1rem;font-family:Barlow Condensed,sans-serif;font-size:1.5rem;font-weight:700}.success-sub{color:var(--text);margin-top:-.2rem;font-family:Barlow Condensed,sans-serif;font-size:1.15rem;font-weight:600}.success-overlay.full-day .success-ring{animation:.4s cubic-bezier(.2,1.4,.4,1) pop,1.4s ease-out .4s 2 success-pulse}.success-overlay.full-week .success-ring{animation:.4s cubic-bezier(.2,1.4,.4,1) pop,1.2s ease-out .4s 3 success-pulse}.success-overlay.rich{gap:.6rem;padding:1rem}.success-entry{text-align:center;color:var(--text)}.success-entry-hours{font-family:Barlow Condensed,sans-serif;font-size:1.15rem;font-weight:700}.success-entry-site{color:var(--text-dim);margin-top:.1rem;font-size:13px}.success-week{flex-direction:column;gap:.25rem;width:min(320px,100%);margin-top:.4rem;display:flex}.success-week-label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-dim);text-align:center;font-size:11px;font-weight:700}.success-week-bar{background:var(--bg-elev-3);border-radius:5px;height:10px;overflow:hidden}.success-week-fill{background:var(--accent);height:100%;transition:width .35s ease-out}.success-week-fill.full{background:var(--success)}.success-week-text{text-align:center;color:var(--text);font-variant-numeric:tabular-nums;font-size:13px;font-weight:600}.week-page-picker{border-bottom:1px solid var(--border);margin-bottom:1rem;padding-bottom:.8rem}.week-overview.force-open{background:0 0;border:0;border-radius:0;overflow:visible}.week-overview.force-open .week-body{border-top:0;padding:0}@keyframes success-pulse{0%{box-shadow:0 0 0 0 var(--success-soft)}60%{box-shadow:0 0 0 22px #46a75800}to{box-shadow:0 0 #46a75800}}@keyframes pop{0%{opacity:0;transform:scale(.4)}60%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.table-wrap{margin:0 -.5rem;padding:0 .5rem;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:14px}th,td{text-align:left;border-bottom:1px solid var(--border);padding:.6rem}th{text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);font-family:Barlow Condensed,sans-serif;font-size:12px;font-weight:600}table.zebra tbody tr:nth-child(2n) td{background:#ffffff06}table.zebra tbody tr:hover td{background:#f5a6230d}td.num,th.num{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}.total-tile{background:linear-gradient(140deg, var(--bg-elev-2), var(--bg-elev-3));border:1px solid var(--border-strong);border-radius:var(--radius);flex-direction:column;align-items:flex-start;gap:.1rem;margin-bottom:1rem;padding:1rem 1.1rem;display:flex}.total-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);font-size:11px;font-weight:700}.total-value{color:var(--accent);align-items:baseline;gap:.25rem;font-family:Barlow Condensed,sans-serif;font-size:3rem;font-weight:700;line-height:1;display:inline-flex}.total-unit{color:var(--text-dim);font-size:1.4rem}.total-sub{color:var(--text-dim);font-size:13px}.kpi-2x2{grid-template-columns:repeat(2,1fr);gap:.6rem;margin-bottom:1rem;display:grid}.kpi{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:.55rem;min-width:0;padding:.7rem .75rem;display:flex}.kpi-icon{border-radius:var(--radius-sm);background:var(--accent-soft);width:36px;height:36px;color:var(--accent);flex-shrink:0;place-items:center;display:grid}.kpi-text{flex:1;min-width:0}.kpi-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);overflow-wrap:break-word;white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:700;line-height:1.2;overflow:hidden}.kpi-value{color:var(--text);overflow-wrap:anywhere;font-family:Barlow Condensed,sans-serif;font-size:1.65rem;font-weight:700;line-height:1.05}.kpi-unit{color:var(--text-dim);margin-left:.2rem;font-size:.8rem;font-weight:600}.tabs{border-bottom:1px solid var(--border);gap:.3rem;margin-bottom:1rem;display:flex;overflow-x:auto}.tab{color:var(--text-dim);min-height:var(--touch);cursor:pointer;white-space:nowrap;background:0 0;border:0;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.7rem .9rem;font-size:14px;font-weight:600}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.login-screen{min-height:100vh;padding:1rem;padding-top:calc(1rem + var(--safe-top));padding-bottom:calc(1rem + var(--safe-bottom));place-items:center;display:grid}.login-card{background:var(--bg-elev);border:1px solid var(--border);width:100%;max-width:380px;box-shadow:var(--shadow);text-align:center;border-radius:18px;padding:2.2rem 1.6rem 1.6rem}.login-logo{justify-content:center;margin-bottom:1rem;display:flex}.login-title{letter-spacing:.04em;margin-bottom:.1rem;font-family:Barlow Condensed,sans-serif;font-size:2.2rem;font-weight:700}.login-sub{letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);margin:0 0 1.6rem;font-size:12px;font-weight:600}.login-label{text-align:left}.login-input-wrap{position:relative}.login-eye{color:var(--text-dim);cursor:pointer;background:0 0;border:0;justify-content:center;align-items:center;padding:6px;display:inline-flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.login-eye:hover{color:var(--text)}.login-input-wrap input{padding-right:40px}.login-foot{color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase;margin-top:1.8rem;font-size:11px}.toast-host{left:50%;bottom:calc(var(--nav-h) + 1.2rem + var(--safe-bottom));z-index:100;pointer-events:none;flex-direction:column;gap:.5rem;max-width:calc(100vw - 2rem);display:flex;position:fixed;transform:translate(-50%)}.toast{background:var(--bg-elev-2);color:var(--text);border:1px solid var(--border-strong);box-shadow:var(--shadow);pointer-events:auto;text-align:center;border-radius:999px;max-width:100%;padding:.65rem 1.1rem;font-size:14px;font-weight:600}.toast.success{border-color:var(--success);color:#c0eccb}.toast.error{border-color:var(--danger);color:#ffd5d6}.muted{color:var(--text-dim)}.error-text{color:var(--danger);margin-top:.5rem;font-size:13px;font-weight:600}.error-banner{background:var(--danger-soft);border:1px solid var(--danger);border-radius:var(--radius-sm);color:#ffd5d6;flex-wrap:wrap;align-items:center;gap:.5rem;margin:.8rem 0;padding:.8rem;font-size:14px;display:flex}.section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);margin:1.2rem 0 .5rem;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:600}.row-actions{justify-content:flex-end;gap:.4rem;display:flex}.list-empty{text-align:center;color:var(--text-faint);padding:2rem 0}.add-row{gap:.5rem;margin-bottom:1rem;display:flex}.add-row input{flex:1;min-width:0}.center{text-align:center}.filters-bar{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.8rem;display:flex}.filter-toggle{background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:.4rem;min-height:36px;padding:.5rem .8rem;font-size:14px;font-weight:600;display:inline-flex}.filter-toggle:hover{border-color:var(--border-strong)}.filter-count{background:var(--accent);color:var(--accent-ink);border-radius:999px;padding:1px 7px;font-size:11px;font-weight:700;line-height:1.5}.export-btn{margin-left:auto}.filter-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.7rem;margin-bottom:.8rem;display:grid}.entry-cards{flex-direction:column;gap:.7rem;display:flex}.entry-card-item{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.35rem;padding:.85rem .95rem;display:flex}.entry-card-row{flex-wrap:wrap;align-items:baseline;gap:.6rem;display:flex}.entry-card-row.top{justify-content:space-between}.entry-card-row.meta{color:var(--text-dim);border-top:1px solid var(--border);flex-direction:column;align-items:flex-start;gap:.15rem;margin-top:.25rem;padding-top:.25rem;font-size:13px}.entry-card-row.actions{border-top:1px solid var(--border);justify-content:flex-end;margin-top:.2rem;padding-top:.4rem}.entry-date{color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;font-family:Barlow Condensed,sans-serif;font-size:14px;font-weight:600}.entry-hours{color:var(--accent);font-family:Barlow Condensed,sans-serif;font-size:1.5rem;font-weight:700}.entry-employee{font-size:16px;font-weight:700}.entry-activity{font-size:14px}.entry-activity.absence{color:var(--danger);font-weight:600}.entry-site,.entry-notes{display:block}.admin-list{flex-direction:column;gap:.4rem;margin:0;padding:0;list-style:none;display:flex}.admin-list li{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;gap:.6rem;padding:.6rem .8rem;display:flex}.admin-item-name{font-weight:600}.combobox{width:100%;position:relative}.combobox-input-wrap{align-items:center;display:flex;position:relative}.combobox-input{padding-right:60px}.combobox-caret{color:var(--text-faint);pointer-events:none;font-size:12px;position:absolute;right:14px}.combobox-clear{color:var(--text-dim);cursor:pointer;background:0 0;border:0;justify-content:center;align-items:center;width:32px;height:32px;padding:0 6px;font-size:22px;line-height:1;display:inline-flex;position:absolute;right:32px}.combobox-clear:hover{color:var(--text)}.combobox-list{z-index:30;background:var(--bg-elev-2);border:1px solid var(--border-strong);border-radius:var(--radius-sm);max-height:300px;box-shadow:var(--shadow);margin:0;padding:4px;list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.combobox-sep{text-transform:uppercase;letter-spacing:.06em;color:var(--danger);border-top:2px solid var(--danger-soft);margin-top:4px;padding:.55rem .6rem .25rem;font-size:11px;font-weight:700}.combobox-list li:first-child .combobox-sep{border-top:0;margin-top:0;padding-top:.25rem}.combobox-opt{text-align:left;cursor:pointer;width:100%;min-height:40px;color:var(--text);background:0 0;border:0;border-radius:6px;align-items:baseline;gap:.5rem;padding:.6rem .7rem;font-size:14px;display:flex}.combobox-opt:hover,.combobox-opt.active{background:var(--accent-soft)}.combobox-opt.absence{color:var(--danger)}.combobox-opt.absence.active{background:var(--danger-soft)}.combobox-opt.custom{color:var(--accent);font-style:italic}.combobox-opt.custom.active{background:var(--accent-soft)}.combobox-label{font-size:15px;font-weight:600}.combobox-sublabel{color:var(--text-faint);font-size:12px;font-style:italic}.combobox-empty{color:var(--text-faint);text-align:center;padding:.9rem;font-size:13px}.site-custom-hint{color:var(--accent);margin-top:.35rem;font-size:12px;display:block}.chart-tooltip{box-shadow:var(--shadow);background:#1d2025;border:1px solid #3a3f4a;border-radius:8px;padding:.5rem .7rem;font-size:13px}.chart-tooltip-label{color:var(--text);margin-bottom:2px;font-weight:700}.chart-tooltip-value{color:var(--accent);font-family:Barlow Condensed,sans-serif;font-size:16px;font-weight:700}.chart-tooltip-pct{color:var(--text-dim);margin-left:6px;font-family:Barlow,sans-serif;font-size:13px;font-weight:600}.chart-wrap{width:100%;height:260px;margin-bottom:.5rem}.dialog-backdrop{z-index:200;background:#000000a6;place-items:center;padding:1rem;animation:.15s ease-out fade-in;display:grid;position:fixed;inset:0}.dialog{background:var(--bg-elev);border:1px solid var(--border-strong);border-radius:var(--radius);width:100%;max-width:380px;box-shadow:var(--shadow);padding:1.25rem 1.25rem 1rem}.dialog h3{margin-bottom:.4rem;font-size:1.2rem}.dialog-msg{color:var(--text-dim);margin:0 0 1.1rem;font-size:14px}.dialog-actions{justify-content:flex-end;gap:.5rem;display:flex}.skeleton{background:linear-gradient(90deg, var(--bg-elev-2) 0%, var(--bg-elev-3) 50%, var(--bg-elev-2) 100%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.4s linear infinite shimmer}.skeleton.h-form{height:320px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.login-tabs{background:var(--bg-elev-2);border-radius:var(--radius-sm);border:1px solid var(--border);grid-template-columns:1fr 1fr;margin:1rem 0 1.4rem;padding:4px;display:grid}.login-tab{color:var(--text-dim);cursor:pointer;letter-spacing:.02em;background:0 0;border:0;border-radius:6px;padding:.6rem;font-size:14px;font-weight:700;transition:background .15s,color .15s}.login-tab.active{background:var(--accent);color:var(--accent-ink)}.login-form{text-align:left}.recent-name-wrap{position:relative}.recent-name-list{z-index:5;background:var(--bg-elev-2);border:1px solid var(--border-strong);border-radius:var(--radius-sm);box-shadow:var(--shadow);max-height:220px;margin:0;padding:4px;list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.recent-name-head{letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);padding:6px 10px 4px;font-size:11px;font-weight:600}.recent-name-opt{text-align:left;width:100%;color:var(--text);cursor:pointer;min-height:var(--touch);background:0 0;border:0;border-radius:6px;padding:10px 12px;font-size:15px;display:block}.recent-name-opt:hover,.recent-name-opt:focus-visible{background:var(--bg-elev-3);outline:none}.pin-input{grid-template-columns:repeat(4,1fr);gap:.55rem;display:grid}.pin-cell{text-align:center;letter-spacing:0;background:var(--bg-elev-2);border:1px solid var(--border-strong);height:56px;min-height:56px;color:var(--accent);caret-color:var(--accent);-webkit-text-security:disc;padding:.5rem 0;font-family:Barlow Condensed,sans-serif;font-size:1.6rem;font-weight:700}.pin-cell:focus{background:var(--bg-elev-3);border-color:var(--accent)}.user-menu{position:relative}.user-menu-btn{border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);min-height:var(--touch);cursor:pointer;background:0 0;align-items:center;gap:.4rem;max-width:240px;padding:.4rem .7rem;font-size:13px;font-weight:600;display:inline-flex}.user-menu-btn:hover{border-color:var(--border-strong)}.user-menu-name{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.user-menu-role{color:var(--text-dim);font-weight:500}.user-menu-dropdown{background:var(--bg-elev-2);border:1px solid var(--border-strong);border-radius:var(--radius-sm);min-width:200px;box-shadow:var(--shadow);z-index:30;flex-direction:column;gap:2px;padding:4px;display:flex;position:absolute;top:calc(100% + 6px);right:0}.user-menu-item{color:var(--text);text-align:left;cursor:pointer;min-height:var(--touch);background:0 0;border:0;border-radius:6px;align-items:center;gap:.5rem;padding:.6rem .7rem;font-size:14px;font-weight:600;display:flex}.user-menu-item:hover{background:var(--accent-soft)}.user-menu-item.danger{color:var(--danger)}.user-menu-item.danger:hover{background:var(--danger-soft)}.readonly-field{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius-sm);min-height:var(--touch);justify-content:space-between;align-items:center;gap:.5rem;padding:.7rem .85rem;display:flex}.readonly-value{font-size:16px;font-weight:700}.readonly-hint{text-transform:uppercase;letter-spacing:.05em;color:var(--accent);font-size:11px;font-weight:700}.badge{letter-spacing:.05em;text-transform:uppercase;border-radius:999px;padding:.2rem .5rem;font-size:11px;font-weight:700;display:inline-block}.badge.admin{background:var(--accent-soft);color:var(--accent-strong)}.badge.worker{color:#7cb8ff;background:#5eaaff29}.status{align-items:center;gap:4px;font-size:13px;font-weight:600;display:inline-flex}.status.ok{color:var(--success)}.status.missing{color:var(--text-dim)}.status.locked{color:var(--danger)}.row-actions-stack{flex-direction:column;align-items:flex-start;gap:4px;display:flex}.row-inactive td{opacity:.55}.pin-display{background:var(--bg-elev-3);border:1px solid var(--border-strong);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;gap:1rem;margin:.8rem 0 1rem;padding:1rem;display:flex}.pin-display-value{letter-spacing:.15em;color:var(--accent);font-family:Barlow Condensed,sans-serif;font-size:2.6rem;font-weight:700}.login-cards{flex-direction:column;gap:.7rem;display:flex}.login-card-item{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.55rem;padding:.85rem .95rem;display:flex}.login-card-item.inactive{opacity:.6}.login-card-head{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.login-card-name{overflow-wrap:anywhere;min-width:0;font-size:16px}.login-card-meta{grid-template-columns:max-content 1fr;gap:.25rem .7rem;margin:0;font-size:13px;display:grid}.login-card-meta dt{color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;align-self:center;font-size:11px;font-weight:700}.login-card-meta dd{overflow-wrap:anywhere;align-self:center;min-width:0;margin:0}.login-card-actions{border-top:1px solid var(--border);flex-wrap:wrap;gap:.4rem;padding-top:.45rem;display:flex}@media (width<=480px){.main{padding:.75rem}h1{font-size:1.4rem}.total-value{font-size:2.5rem}.kpi-value{font-size:1.45rem}.kpi{gap:.5rem;padding:.6rem .65rem}.kpi-icon{width:32px;height:32px}.pin-cell{height:52px;min-height:52px;font-size:1.4rem}.user-menu-btn{max-width:180px}}@media (width<=360px){.kpi-2x2{grid-template-columns:1fr}}
