*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: oklch(.985 .004 240);--surface: #ffffff;--surface-2: oklch(.965 .005 240);--surface-3: oklch(.94 .006 240);--divider: oklch(.93 .006 240);--border: oklch(.9 .008 240);--border-strong: oklch(.82 .01 240);--ink: oklch(.22 .02 240);--ink-2: oklch(.42 .015 240);--ink-3: oklch(.58 .012 240);--ink-muted: oklch(.68 .01 240);--brand: oklch(.34 .06 235);--brand-hover: oklch(.29 .07 235);--brand-soft: oklch(.95 .022 235);--brand-strong: oklch(.24 .07 235);--accent: oklch(.62 .09 175);--accent-soft: oklch(.94 .04 175);--ok: oklch(.58 .13 152);--ok-soft: oklch(.95 .04 152);--warn: oklch(.72 .14 75);--warn-soft: oklch(.96 .05 75);--danger: oklch(.55 .18 25);--danger-soft: oklch(.96 .04 25);--info: oklch(.55 .13 235);--info-soft: oklch(.95 .04 235);--vacation-color: oklch(.48 .1 235);--sick-color: oklch(.48 .1 290);--float-color: oklch(.55 .12 75);--non-balance-color: oklch(.55 .04 240);--gap-1: 4px;--gap-2: 8px;--gap-3: 12px;--gap-4: 16px;--gap-5: 20px;--gap-6: 24px;--gap-8: 32px;--pad-card: 20px;--row-h: 44px;--r-sm: 4px;--r-md: 6px;--r-lg: 10px;--r-xl: 14px;--shadow-1: 0 1px 0 oklch(.9 .01 240 / .6), 0 1px 2px oklch(.2 .02 240 / .04);--shadow-2: 0 1px 0 oklch(.9 .01 240 / .6), 0 4px 16px oklch(.2 .02 240 / .06);--shadow-3: 0 12px 40px oklch(.2 .02 240 / .12);--ui: "Public Sans", "Segoe UI", system-ui, -apple-system, Arial, sans-serif;--mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace}[data-density=compact]{--pad-card: 14px;--row-h: 36px;--gap-4: 12px;--gap-5: 14px;--gap-6: 18px}html,body,#root{height:100%}body{font-family:var(--ui);font-size:14px;line-height:1.5;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:var(--brand-strong);height:100vh;position:sticky;top:0;overflow-y:auto;display:flex;flex-direction:column}.sidebar-brand{padding:20px 18px 16px;border-bottom:1px solid oklch(.35 .06 235)}.sidebar-brand-mark{display:flex;align-items:center;gap:10px;text-decoration:none}.brand-icon{width:32px;height:32px;background:var(--accent);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:-.5px;flex-shrink:0}.brand-name{color:#e8f0f4;font-size:13px;font-weight:600;line-height:1.2}.brand-sub{color:#6f8b9b;font-size:10.5px;font-weight:400;text-transform:uppercase;letter-spacing:.06em;margin-top:2px}.sidebar-nav{padding:10px 0;flex:1}.sidebar-section-label{padding:14px 18px 4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:#4d6777}.sidebar-item{display:flex;align-items:center;gap:10px;padding:9px 18px;font-size:13.5px;color:#9cb1bf;cursor:pointer;border-radius:0;border-left:3px solid transparent;transition:background .1s,color .1s;background:none;border-top:none;border-right:none;border-bottom:none;text-align:left;width:100%;font-family:var(--ui)}.sidebar-item:hover{background:#00324980;background:oklch(.3 .065 235 / .5);color:#d8e7f0}.sidebar-item.active{background:#00324999;background:oklch(.3 .065 235 / .6);color:#fff;border-left-color:var(--accent);font-weight:500}.sidebar-item svg{opacity:.7;flex-shrink:0}.sidebar-item.active svg{opacity:1}.sidebar-footer{padding:16px 18px;border-top:1px solid oklch(.3 .05 235);display:flex;align-items:center;gap:10px}.sidebar-footer-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-footer-info{min-width:0}.sidebar-footer-name{color:#ced9e0;font-size:12.5px;font-weight:500}.sidebar-footer-role{color:#5b7686;font-size:11px}.main{min-width:0;display:flex;flex-direction:column}.topbar{height:52px;border-bottom:1px solid var(--divider);background:var(--surface);display:flex;align-items:center;padding:0 24px;gap:8px;position:sticky;top:0;z-index:10;box-shadow:var(--shadow-1)}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink-muted)}.breadcrumb-sep{color:var(--ink-muted);opacity:.4}.breadcrumb-current{color:var(--ink);font-weight:500}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}.content{padding:28px 32px;flex:1}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-1)}.card-head{display:flex;align-items:center;justify-content:space-between;padding:14px var(--pad-card);border-bottom:1px solid var(--divider)}.card-head h3{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-2)}.card-body{padding:var(--pad-card)}.page-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}.page-head h1{font-size:22px;font-weight:700;color:var(--ink);line-height:1.2}.page-head .sub{color:var(--ink-muted);font-size:13px;margin-top:3px}.actions{display:flex;gap:8px;align-items:center}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap-5)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap-5)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap-5)}.balance-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--pad-card);box-shadow:var(--shadow-1)}.balance-card .type{display:flex;align-items:center;gap:8px;font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-2);margin-bottom:10px}.balance-card .swatch{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.balance-card .figure{display:flex;align-items:baseline;gap:6px;margin-bottom:6px}.balance-card .figure .num{font-family:var(--mono);font-size:30px;font-weight:600;color:var(--ink);letter-spacing:-.5px}.balance-card .figure.negative .num{color:var(--danger)}.balance-card .figure .unit{font-size:12.5px;color:var(--ink-muted)}.balance-card .meta-row{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--ink-muted);margin-top:8px}.balance-card .cap-bar{height:4px;background:var(--surface-3);border-radius:999px;margin-top:12px;overflow:hidden}.balance-card .cap-bar-fill{height:100%;border-radius:999px;transition:width .3s ease}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl th{padding:10px 14px;text-align:left;font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-muted);border-bottom:1px solid var(--divider);white-space:nowrap}.tbl td{padding:11px 14px;border-bottom:1px solid var(--divider);color:var(--ink);vertical-align:middle}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:var(--surface-2)}.tbl tr{cursor:default}.tbl tr.clickable{cursor:pointer}.tbl td.num{font-family:var(--mono);text-align:right;font-size:13px}.tbl th.num{text-align:right}.tbl td.muted{color:var(--ink-muted)}.tbl td.mono{font-family:var(--mono);font-size:12.5px}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;font-size:13px;font-family:var(--ui);font-weight:500;border-radius:var(--r-md);border:1px solid var(--border-strong);background:var(--surface);color:var(--ink);cursor:pointer;transition:background .1s,border-color .1s;white-space:nowrap}.btn:hover{background:var(--surface-2)}.btn.primary{background:var(--brand);border-color:var(--brand);color:#fff}.btn.primary:hover{background:var(--brand-hover);border-color:var(--brand-hover)}.btn.sm{padding:5px 10px;font-size:12px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--ink-2);transition:background .1s}.icon-btn:hover{background:var(--surface-2)}.search{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--ink-muted)}.search:focus-within{border-color:var(--brand);outline:none}.search input{border:none;outline:none;background:none;font-family:var(--ui);font-size:13.5px;color:var(--ink);width:100%;min-width:0}.search input::placeholder{color:var(--ink-muted)}.select{padding:7px 28px 7px 10px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);font-family:var(--ui);font-size:13px;color:var(--ink);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%23888' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;cursor:pointer}.select:focus{outline:1px solid var(--brand)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:11.5px;font-weight:500}.badge.ok{background:var(--ok-soft);color:var(--ok)}.badge.warn{background:var(--warn-soft);color:#986600;color:oklch(.55 .14 75)}.badge.danger{background:var(--danger-soft);color:var(--danger)}.badge.info{background:var(--info-soft);color:var(--info)}.badge.muted{background:var(--surface-3);color:var(--ink-muted)}.avatar{border-radius:50%;background:var(--surface-3);color:var(--ink-2);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;flex-shrink:0}.banner{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:var(--r-md);font-size:13px;line-height:1.5}.banner.info{background:var(--info-soft);color:#004e6f;color:oklch(.4 .12 235)}.banner.warn{background:var(--warn-soft);color:#734c00;color:oklch(.45 .14 75)}.banner.danger{background:var(--danger-soft);color:var(--danger)}.banner.ok{background:var(--ok-soft);color:var(--ok)}.banner .b-icon{flex-shrink:0;margin-top:1px}.meta{font-size:12px;color:var(--ink-muted)}.tiny{font-size:11.5px}.muted{color:var(--ink-muted)}.mono{font-family:var(--mono)}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 50%,var(--surface-2) 75%);background-size:800px 100%;animation:shimmer 1.4s infinite;border-radius:var(--r-md)}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--ink-muted);gap:10px;text-align:center}.risk-meter{display:flex;align-items:center;gap:8px}.risk-track{position:relative;height:6px;background:var(--surface-3);border-radius:999px;overflow:hidden;flex:1}.risk-fill{position:absolute;left:0;top:0;height:100%;border-radius:999px;transition:width .3s ease}.trajectory-chart{position:relative;overflow:hidden}.trajectory-chart svg{width:100%;display:block}.login-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--brand-strong);display:flex;align-items:center;justify-content:center;z-index:1000}.login-box{width:420px;background:#011925;border-radius:var(--r-xl);padding:36px 32px 32px;box-shadow:0 24px 64px #00040880;box-shadow:0 24px 64px oklch(.1 .04 235 / .5);display:flex;flex-direction:column;gap:24px}.login-logo{display:flex;align-items:center;gap:12px}.login-logo-mark{width:44px;height:44px;border-radius:10px;background:var(--accent);color:#fff;font-size:15px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.login-logo-title{font-size:18px;font-weight:700;color:#fff;letter-spacing:-.2px}.login-logo-sub{font-size:12px;color:#6b96af;margin-top:1px}.login-role-cards{display:flex;gap:8px}.login-role-card{flex:1;background:#00121d;background:oklch(.17 .04 235);border:1.5px solid oklch(.32 .06 235);border-radius:var(--r-lg);padding:12px 8px;cursor:pointer;text-align:center;transition:border-color .15s,background .15s;color:#81a4b9}.login-role-card:hover{border-color:#136b94;background:#001e2d;background:oklch(.22 .05 235)}.login-role-card.active{border-color:var(--accent);background:#00211933;background:oklch(.22 .06 175 / .2);color:#fff}.login-role-label{font-size:13px;font-weight:600}.login-role-sub{font-size:10.5px;margin-top:3px;opacity:.75}.login-form{display:flex;flex-direction:column;gap:14px}.login-field{display:flex;flex-direction:column;gap:6px}.login-label{font-size:12px;font-weight:600;color:#7295aa;text-transform:uppercase;letter-spacing:.5px}.login-input{background:#00121d;background:oklch(.17 .04 235);border:1.5px solid oklch(.32 .06 235);border-radius:var(--r-md);padding:9px 12px;font-size:14px;color:#fff;outline:none;font-family:var(--ui);transition:border-color .15s;width:100%}.login-input::placeholder{color:#3f5969}.login-input:focus{border-color:var(--accent)}.login-input:disabled{opacity:.5;cursor:not-allowed}.login-error{background:#361715;border:1px solid oklch(.4 .1 25);color:#edc2bd;border-radius:var(--r-md);padding:9px 12px;font-size:13px}.login-submit{width:100%;justify-content:center;padding:11px;font-size:14px;margin-top:4px}.auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--brand-strong);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:1000;color:#c2d0d9}.auth-spinner{width:36px;height:36px;border:3px solid oklch(.4 .06 235);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--ink);color:#fff;padding:10px 18px;border-radius:var(--r-lg);font-size:13.5px;box-shadow:var(--shadow-3);z-index:999;animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.mt-4{margin-top:var(--gap-4)}.mt-5{margin-top:var(--gap-5)}.mt-6{margin-top:var(--gap-6)}.mb-5{margin-bottom:var(--gap-5)}.section-gap{margin-top:28px}
