:root{--paper:#f6f5f1;--paper-2:#efede6;--surface:#fffefb;--ink:#16130f;--ink-soft:#423d35;--muted:#847d72;--faint:#a8a194;--line:#e7e3da;--line-strong:#d8d3c7;--brand:#047857;--brand-deep:#065f46;--brand-bright:#10b981;--brand-tint:#e7f3ee;--rose:#be123c;--rose-tint:#fbe9ec;--amber:#b45309;--amber-tint:#fcefdc;--violet:#6d28d9;--violet-tint:#efe9fb;--radius:14px;--radius-lg:20px;--radius-sm:9px;--shadow-sm:0 1px 2px #16130f0d, 0 1px 1px #16130f08;--shadow:0 10px 30px -12px #16130f2e, 0 2px 6px #16130f0d;--shadow-lg:0 30px 60px -20px #16130f4d;--ui:"Hanken Grotesk", ui-sans-serif, system-ui, sans-serif;--mono:"JetBrains Mono", ui-monospace, "SFMono-Regular", monospace}*{box-sizing:border-box}html,body,#root{height:100%}body{font-family:var(--ui);color:var(--ink);background:radial-gradient(1100px 600px at 12% -8%, #fffdf7 0%, transparent 55%), radial-gradient(900px 700px at 100% 0%, var(--brand-tint) 0%, transparent 45%), var(--paper);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;font-size:15px;line-height:1.55}h1,h2,h3{letter-spacing:-.02em;margin:0;font-weight:700}.mono,.num{font-family:var(--mono);font-variant-numeric:tabular-nums}button{font-family:inherit}:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:6px}.app{flex-direction:column;min-height:100%;display:flex}.topbar{z-index:30;-webkit-backdrop-filter:saturate(140%)blur(12px);backdrop-filter:saturate(140%)blur(12px);border-bottom:1px solid var(--line);background:#fffefbd1;align-items:center;gap:18px;padding:14px clamp(16px,4vw,40px);display:flex;position:sticky;top:0}.brand{align-items:center;gap:10px;display:flex}.brand-logo{width:auto;height:26px;display:block}.lang-toggle{border:1px solid var(--line);background:var(--paper-2);color:var(--muted);cursor:pointer;border-radius:999px;align-items:center;gap:5px;margin-left:4px;padding:3px 9px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600;transition:all .15s;display:inline-flex}.lang-toggle:hover{border-color:var(--line-strong);color:var(--ink-soft)}.lang-toggle .on{color:var(--brand-deep)}.lang-toggle .sep{color:var(--line-strong);font-weight:400}.nav-seg{background:var(--paper-2);border:1px solid var(--line);border-radius:11px;gap:2px;padding:4px;display:flex}.nav-seg a{color:var(--ink-soft);border-radius:8px;padding:7px 15px;font-size:13.5px;font-weight:600;text-decoration:none;transition:all .15s}.nav-seg a:hover{color:var(--ink)}.nav-seg a.active{background:var(--surface);color:var(--brand-deep);box-shadow:var(--shadow-sm)}.topbar .spacer{flex:1}.chip{border:1px solid var(--line-strong);background:var(--surface);color:var(--ink-soft);border-radius:999px;align-items:center;gap:7px;padding:5px 11px 5px 8px;font-size:12px;font-weight:600;display:inline-flex}.chip .av{color:#fff;background:linear-gradient(150deg,#3f3a33,#16130f);border-radius:50%;place-items:center;width:20px;height:20px;font-size:10px;font-weight:800;display:grid}.chip.manager .av{background:linear-gradient(150deg, var(--brand-bright), var(--brand-deep))}.btn-link{color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:8px;padding:7px 10px;font-size:13px;font-weight:600;transition:all .15s}.btn-link:hover{color:var(--rose);background:var(--rose-tint)}.page{flex:1;width:100%;margin:0 auto;padding:clamp(22px,4vw,44px) clamp(16px,4vw,40px) 96px;animation:.5s cubic-bezier(.2,.7,.2,1) both rise}.page.narrow{max-width:520px}.page.wide{max-width:1080px}@keyframes rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.page-head{margin-bottom:22px}.page-head h1{font-size:clamp(22px,4vw,28px)}.page-head p{color:var(--muted);margin:4px 0 0;font-size:14px}.eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--brand);margin-bottom:8px;font-size:11px;font-weight:700}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.card-pad{padding:clamp(18px,3vw,26px)}.card-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:12px;padding:16px 22px;font-weight:700;display:flex}.card-head .sub{color:var(--muted);font-size:12.5px;font-weight:500}.clock-card{text-align:center;padding:clamp(26px,5vw,40px) clamp(20px,4vw,32px);position:relative;overflow:hidden}.clock-card:before{content:"";pointer-events:none;background:radial-gradient(420px 200px at 50% -10%, var(--brand-tint), transparent 70%);position:absolute;inset:0}.clock-status{border-radius:999px;align-items:center;gap:8px;padding:6px 14px;font-size:13px;font-weight:600;display:inline-flex;position:relative}.clock-status.idle{background:var(--paper-2);color:var(--muted)}.clock-status.live{background:var(--brand-tint);color:var(--brand-deep)}.dot{background:currentColor;border-radius:50%;width:8px;height:8px}.clock-status.live .dot{background:var(--brand-bright);animation:1.6s infinite pulse;box-shadow:0 0 #10b98180}@keyframes pulse{0%{box-shadow:0 0 #10b98180}70%{box-shadow:0 0 0 9px #10b98100}to{box-shadow:0 0 #10b98100}}.clock-time{font-family:var(--mono);letter-spacing:-.02em;font-variant-numeric:tabular-nums;color:var(--ink);margin:18px 0 4px;font-size:clamp(46px,13vw,76px);font-weight:600;line-height:1.04}.clock-time .sec{color:var(--faint)}.clock-sub{color:var(--muted);font-size:13.5px}.clock-sub .mono{color:var(--ink-soft)}.btn-xl{cursor:pointer;color:#fff;letter-spacing:-.01em;border-radius:var(--radius);border:0;justify-content:center;align-items:center;gap:10px;width:100%;margin-top:26px;padding:17px;font-size:17px;font-weight:700;transition:transform .12s,box-shadow .2s,filter .15s;display:inline-flex}.btn-xl:disabled{opacity:.6;cursor:progress}.btn-xl:not(:disabled):hover{transform:translateY(-1px)}.btn-xl:not(:disabled):active{transform:translateY(1px)}.btn-start{background:linear-gradient(160deg, var(--brand-bright), var(--brand-deep));box-shadow:0 12px 24px -10px #04785799}.btn-finish{background:linear-gradient(160deg,#e11d48,#9f1239);box-shadow:0 12px 24px -10px #be123c8c}.btn-xl .ic{font-size:13px}.note-input{border:1px solid var(--line-strong);border-radius:var(--radius-sm);width:100%;font:inherit;background:var(--surface);color:var(--ink);margin-top:14px;padding:11px 13px}.note-input::placeholder{color:var(--faint)}.table-wrap{border-radius:var(--radius);overflow-x:auto}table.data{border-collapse:collapse;width:100%;font-size:13.5px}table.data th{text-align:left;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line);white-space:nowrap;padding:11px 14px;font-size:11px;font-weight:700}table.data td{border-bottom:1px solid var(--line);vertical-align:middle;padding:12px 14px}table.data tbody tr{transition:background .12s}table.data tbody tr:hover{background:#fbfaf6}table.data tbody tr:last-child td{border-bottom:0}table.data td.num,table.data th.num{text-align:right;font-family:var(--mono);font-variant-numeric:tabular-nums}table.data tfoot td{border-top:2px solid var(--line-strong);background:var(--paper-2);border-bottom:0;padding:12px 14px}table.data tfoot .num{font-size:14px}.data.history td{white-space:nowrap}.data.history th:last-child,.data.history td:last-child{white-space:normal;width:100%}@media (hover:hover) and (pointer:fine){.data.history tbody tr .col-actions .row-btn{opacity:0;transition:opacity .14s}.data.history tbody tr:hover .col-actions .row-btn,.data.history tbody tr:focus-within .col-actions .row-btn{opacity:1}}.data.detail td{white-space:nowrap}.data.detail th:nth-last-child(2),.data.detail td:nth-last-child(2){white-space:normal;width:100%}.data.detail td:last-child{text-align:right}.data.detail tr.group-head th{background:var(--line);border-left:3px solid var(--brand);border-bottom:1px solid var(--line-strong);text-transform:none;letter-spacing:0;color:var(--ink);padding:7px 14px 7px 11px}.group-head-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.group-toggle{cursor:pointer;color:inherit;font:inherit;text-align:left;background:0 0;border:0;flex-wrap:wrap;align-items:center;gap:10px;padding:3px 0;display:flex}.group-toggle .caret{color:var(--muted);width:11px;font-size:11px}.group-sub{color:var(--muted);font-weight:500;font-family:var(--mono);font-variant-numeric:tabular-nums}.col-actions{white-space:nowrap}.row-actions{opacity:0;gap:6px;transition:opacity .14s;display:inline-flex}.data.detail tbody tr:hover .row-actions,.data.detail tbody tr:focus-within .row-actions{opacity:1}.row-btn.danger{padding:6px 10px}.row-btn.danger:hover{border-color:var(--rose);color:var(--rose);background:var(--rose-tint)}.section-head{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.link-btn{cursor:pointer;font:inherit;color:var(--brand-deep);background:0 0;border:0;padding:0;font-size:12px;font-weight:600}.link-btn:hover{text-decoration:underline}.table-scroll{max-height:60vh;overflow:auto}.table-scroll thead th{z-index:2;background:var(--surface);position:sticky;top:0}.cell-id{font-family:var(--mono);color:var(--muted);font-size:11.5px}.cell-strong{font-weight:600}.t-mono{font-family:var(--mono);font-variant-numeric:tabular-nums;color:var(--ink-soft);font-size:12.5px}.tag{border-radius:999px;align-items:center;gap:5px;padding:2px 9px;font-size:11px;font-weight:600;display:inline-flex}.tag.open{background:var(--amber-tint);color:var(--amber)}.tag.nextday{background:var(--line);color:var(--ink-soft);border:1px solid var(--line-strong)}.tag.edited{background:var(--violet-tint);color:var(--violet)}.tag.warn{background:var(--amber-tint);color:var(--amber);border:1px solid #f1d9b0}.fix-req{color:var(--ink-soft);align-items:baseline;gap:7px;margin-top:5px;font-size:12.5px;display:flex}.row-btn{border:1px solid var(--line-strong);background:var(--surface);color:var(--ink-soft);cursor:pointer;border-radius:8px;padding:6px 13px;font-size:12.5px;font-weight:600;transition:all .14s}.row-btn:hover{border-color:var(--brand);color:var(--brand-deep);background:var(--brand-tint)}.toolbar{flex-wrap:wrap;align-items:flex-end;gap:14px;display:flex}.field{flex-direction:column;gap:6px;display:flex}.field label{color:var(--muted);font-size:12px;font-weight:600}.field input,.field select{border:1px solid var(--line-strong);border-radius:var(--radius-sm);font:inherit;background:var(--surface);color:var(--ink);min-height:40px;padding:9px 12px}.field input[type=date],.field input[type=datetime-local]{font-family:var(--mono);font-size:13px}.period-seg{background:var(--paper-2);border:1px solid var(--line);border-radius:11px;align-items:stretch;gap:2px;min-height:40px;padding:4px;display:inline-flex}.period-seg button{cursor:pointer;font-family:var(--mono);color:var(--ink-soft);background:0 0;border:0;border-radius:8px;padding:5px 14px;font-size:13px;font-weight:600;transition:all .15s}.period-seg button:not(:disabled):hover{color:var(--ink)}.period-seg button.active{background:var(--surface);color:var(--brand-deep);box-shadow:var(--shadow-sm)}.period-seg button:disabled{opacity:.45;cursor:not-allowed}.btn{cursor:pointer;border-radius:var(--radius-sm);border:0;min-height:40px;padding:10px 18px;font-size:14px;font-weight:700;transition:transform .12s,filter .15s,box-shadow .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--ink);color:#fff}.btn-primary:not(:disabled):hover{box-shadow:var(--shadow);transform:translateY(-1px)}.btn-outline{background:var(--surface);color:var(--ink);border:1px solid var(--line-strong)}.btn-outline:not(:disabled):hover{border-color:var(--ink)}.btn-ghost{cursor:pointer;color:var(--muted);border-radius:var(--radius-sm);background:0 0;border:0;margin-top:12px;padding:6px 12px;font-size:13px;font-weight:600;display:inline-block}.btn-ghost:not(:disabled):hover{color:var(--ink);background:var(--line)}.btn-ghost:disabled{opacity:.5;cursor:not-allowed}.stats{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin:20px 0;display:grid}.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px 18px}.stat .v{font-family:var(--mono);letter-spacing:-.02em;font-size:clamp(22px,3.5vw,28px);font-weight:600}.stat .v .u{color:var(--muted);margin-left:3px;font-size:14px}.stat .l{color:var(--muted);margin-top:2px;font-size:12px}.stat.accent{background:linear-gradient(160deg, var(--brand-deep), var(--brand));color:#fff;border:0}.stat.accent .l{color:#ffffffc7}.section-title{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:26px 0 12px;font-size:12px;font-weight:700}.overlay{z-index:60;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#16130f6b;place-items:center;padding:20px;animation:.2s both fade;display:grid;position:fixed;inset:0}@keyframes fade{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);animation:.24s cubic-bezier(.2,.8,.2,1) both pop;overflow:hidden}@keyframes pop{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:none}}.modal-wide{max-width:760px}.modal-head{border-bottom:1px solid var(--line);padding:18px 22px;font-size:16px;font-weight:700}.modal-head .sub{color:var(--muted);margin-top:2px;font-size:12.5px;font-weight:500}.modal-body{gap:14px;padding:20px 22px;display:grid}.modal-foot{border-top:1px solid var(--line);justify-content:flex-end;gap:10px;padding:16px 22px;display:flex}.dt-meta{color:var(--ink-soft);border-bottom:1px solid var(--line);gap:4px;padding-bottom:14px;font-size:13px;display:grid}.dt-meta-k{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-right:6px;font-size:11px;font-weight:700}.dt-row{gap:8px;display:flex}.dt-row input[type=date]{flex:auto;min-width:0}.dt-time{text-align:center;width:92px;font-family:var(--mono);font-variant-numeric:tabular-nums;flex:0 0 92px;font-size:13px}.adjust-row{gap:6px;margin-top:8px;display:flex}.adjust-btn{border:1px solid var(--line-strong);background:var(--surface);color:var(--ink-soft);font-family:var(--mono);cursor:pointer;border-radius:8px;flex:1;padding:5px 0;font-size:12px;font-weight:600;transition:all .14s}.adjust-btn:not(:disabled):hover{border-color:var(--brand);color:var(--brand-deep);background:var(--brand-tint)}.adjust-btn:disabled{opacity:.45;cursor:not-allowed}.dt-duration{color:var(--ink);font-size:13px;font-weight:600}.auth-wrap{place-items:center;min-height:100%;padding:24px;display:grid}.auth-card{width:100%;max-width:392px}.auth-logo{width:auto;height:40px;margin:0 auto 18px;display:block}.auth-card .card{padding:clamp(32px,6vw,44px)}.auth-card h1{font-size:24px}.auth-card .lede{color:var(--muted);margin:4px 0 22px;font-size:13.5px}.auth-field{margin-bottom:13px}.auth-field label{color:var(--ink-soft);margin-bottom:6px;font-size:12px;font-weight:600;display:block}.input{border:1px solid var(--line-strong);border-radius:var(--radius-sm);width:100%;font:inherit;background:var(--surface);color:var(--ink);padding:12px 13px;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-tint);outline:none}.input::placeholder{color:var(--faint)}.input-affix{position:relative}.input-affix .input{padding-right:44px}.affix-btn{cursor:pointer;width:42px;height:100%;color:var(--muted);border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:0 0;border:0;place-items:center;transition:color .15s;display:grid;position:absolute;top:0;right:0}.affix-btn:hover{color:var(--ink-soft)}.btn-block{width:100%;margin-top:6px;padding:13px}.btn-brand{background:var(--brand-deep);color:#fff}.btn-brand:not(:disabled):hover{background:var(--brand);box-shadow:var(--shadow);transform:translateY(-1px)}.auth-foot{text-align:center;color:var(--faint);margin-top:16px;font-size:12px}.state{color:var(--muted);justify-content:center;align-items:center;gap:10px;padding:26px;font-size:14px;display:flex}.state.error{color:var(--rose);background:var(--rose-tint);border-radius:var(--radius);border:1px solid #f3cdd5}.spin{border:2px solid var(--line-strong);border-top-color:var(--brand);border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.state-empty{text-align:center;color:var(--muted);padding:40px 20px}.state-empty .big{margin-bottom:8px;font-size:30px}.inline-alert{color:var(--rose);background:var(--rose-tint);border-radius:var(--radius-sm);border:1px solid #f3cdd5;align-items:center;gap:8px;margin-top:14px;padding:10px 13px;font-size:13px;font-weight:500;display:flex}.inline-warn{color:var(--amber);background:var(--amber-tint);border-radius:var(--radius-sm);text-align:left;border:1px solid #f1d9b0;align-items:center;gap:8px;margin:0 0 14px;padding:10px 13px;font-size:13px;font-weight:500;display:flex}.center-screen{min-height:100%;color:var(--muted);place-items:center;display:grid}.tabbar{display:none}@media (width<=640px){.nav-seg{display:none}.tabbar{z-index:40;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding:6px 8px calc(6px + env(safe-area-inset-bottom));background:#fffefbeb;display:flex;position:fixed;bottom:0;left:0;right:0}.tabbar a{text-align:center;color:var(--muted);border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:3px;padding:8px 4px;font-size:11px;font-weight:600;text-decoration:none;display:flex}.tabbar a.active{color:var(--brand-deep);background:var(--brand-tint)}.tabbar a .ti{font-size:17px;line-height:1}.page{padding-bottom:92px}}
