:root{--bg:#f5f7fb;--card:#ffffff;--line:#e8edf3;--text:#1f2a37;--muted:#6b7280;--accent:#2563eb;--danger:#c62828;--shadow:0 10px 30px rgba(2,6,23,.06)}html,body,#root{height:auto!important;margin:0;padding:0;font-family:system-ui,sans-serif;background:var(--bg);color:var(--text)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.card{background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:14px}input,select,textarea{padding:10px 12px;border-radius:10px;border:1px solid var(--line);font-size:1rem;background:#fff;color:var(--text)}input:focus,select:focus,textarea:focus{outline:none;border-color:#cfd6e2;box-shadow:0 0 0 3px #2563eb24}.btn{border:1px solid var(--line);background:#fff;padding:10px 14px;border-radius:10px;font-weight:600;cursor:pointer}.btn.primary:hover{filter:brightness(.97)}.btn.ghost{background:#fff;color:var(--text)}.btn.ghost.danger{color:var(--danger);border-color:#f0d6d6}.btn.ghost.danger:hover{background:#fff7f7}.alert{padding:12px 14px;border-radius:10px;border:1px solid var(--line);margin:8px 0 12px}.alert.error{border-color:#ffd4d4;background:#fff6f6;color:#9b2222}.home-wrap{max-width:1100px;margin:24px auto 48px;padding:0 16px}.home-topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:var(--card);box-shadow:var(--shadow)}.brand{display:flex;align-items:center;gap:8px;font-size:.95rem;color:var(--muted)}.brand .dot{width:10px;height:10px;border-radius:50%;background:var(--accent);display:inline-block}.home-header{display:flex;align-items:center;justify-content:space-between;margin:18px 0 12px;gap:12px}.month-nav{display:flex;align-items:center;gap:10px}.month-nav h1{margin:0;font-size:1.25rem;font-weight:700;text-transform:capitalize}.icon-btn{width:34px;height:34px;border:1px solid var(--line);background:#fff;border-radius:10px;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer}.actions .btn{min-width:160px}.home-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.kpi{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px;box-shadow:var(--shadow)}.kpi-label{font-size:.85rem;color:var(--muted);margin-bottom:6px}.kpi-value{font-size:1.6rem;font-weight:800}.home-table{border-radius:14px;overflow:hidden}.loading{padding:18px;text-align:center;color:var(--muted)}@media (max-width: 900px){.home-cards{grid-template-columns:1fr 1fr}.actions .btn{min-width:unset;width:100%}.home-header{flex-direction:column;align-items:stretch}}@media (max-width: 600px){.home-cards{grid-template-columns:1fr}}.auth-bg{background:radial-gradient(1200px 600px at 10% -10%,#fff 20%,#eef3ff 55%,#eaf0ff 85%),var(--bg);min-height:100vh}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:100%;max-width:380px;background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:20px 18px}.auth-brand{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:.95rem;margin-bottom:8px}.auth-brand .dot{width:10px;height:10px;border-radius:50%;background:var(--accent);display:inline-block}h1{margin:6px 0 2px;font-size:1.4rem;color:var(--text)}.auth-sub{margin:0 0 12px;color:var(--muted);font-size:.95rem}.auth-alert{margin:8px 0 12px;padding:10px 12px;border:1px solid #ffd5d5;background:#fff7f7;color:#9b2222;border-radius:10px}.auth-form{display:flex;flex-direction:column;gap:12px}.field label{display:block;margin-bottom:6px;color:var(--muted);font-size:.9rem}.field input{width:100%;padding:12px;border:1px solid var(--line);border-radius:10px;font-size:1rem;background:#fff;color:var(--text)}.field input:focus{outline:none;border-color:#cfd6e2;box-shadow:0 0 0 3px #2563eb24}.pass-wrap{position:relative}.pass-wrap input{padding-right:88px}.pass-toggle{position:absolute;right:6px;top:6px;bottom:6px;padding:0 10px;border:1px solid var(--line);background:#fff;border-radius:8px;font-size:.9rem;color:var(--muted);cursor:pointer}.pass-toggle:hover{border-color:#cfd6e2}.btn{border:1px solid var(--line);background:#fff;padding:11px 14px;border-radius:10px;font-weight:700;cursor:pointer}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn[disabled]{opacity:.7;cursor:not-allowed}.auth-meta{margin-top:6px;display:flex;align-items:center;justify-content:space-between}.remember{color:var(--muted);font-size:.9rem;display:flex;align-items:center;gap:6px}.link{background:transparent;border:none;color:var(--accent);font-weight:600;cursor:pointer;padding:6px 4px}.auth-footer{margin-top:14px;text-align:center;color:var(--muted)}*{box-sizing:border-box}.ts-wrap{position:relative;padding:12px}.ts-fab{position:fixed;right:16px;bottom:16px;width:52px;height:52px;border-radius:14px;border:1px solid var(--line);background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);z-index:10}@media (min-width: 900px){.ts-fab{display:none}.badge.today,.badge.holiday{font-size:.9rem}}.ts-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.ts-head h2{margin:0;font-size:1.1rem}.ts-actions{display:flex;gap:8px}.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);background:#fff;color:var(--text);border-radius:10px;cursor:pointer}.icon-btn:hover{border-color:#cfd6e2}.icon-btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.icon-btn.danger{color:var(--danger);border-color:#f0d6d6;background:#fff}.icon-btn[disabled]{cursor:not-allowed;color:#b8c2cf;border-color:#e5eaf1;background:#f7f9fc;opacity:1}.badge{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;padding:2px 6px;color:var(--muted);background:#fff;margin-left:8px}.badge.today,.badge.holiday{display:inline-flex;align-items:center;gap:4px;font-size:.8rem;padding:2px 6px;border-radius:999px}.badge.today{color:#28a745}.badge.holiday{color:#bf120f}.ts-list{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}.ts-row--head{display:none;background:#f9fbff;border-bottom:1px solid var(--line);padding:10px 12px;font-size:.86rem;color:var(--muted)}@media (min-width: 900px){.ts-row--head{display:grid;grid-template-columns:48px 140px 110px 1fr 140px}}.ts-row{border-top:1px solid var(--line)}.ts-row:first-child{border-top:none}.ts-row-main{display:flex;align-items:center;gap:10px;padding:10px 12px}@media (min-width: 900px){.ts-row-main{display:grid;grid-template-columns:48px 140px 110px 1fr 140px}}.ts-cell.ts-date{display:flex;flex-direction:column;gap:2px}.ts-date-top{font-weight:600;display:flex;align-items:center}.ts-date-sub{font-size:.85rem;color:var(--muted)}@media (min-width: 900px){.ts-date-sub{display:none}}.ts-day{font-size:.95rem;color:var(--text)}.ts-total{margin-left:auto;display:flex;align-items:center;gap:10px;justify-content:flex-end;min-width:140px}.ts-total-value{display:inline-block;justify-content:flex-end;align-items:center;gap:4px;width:200px;text-align:right;font-weight:700}.ts-total-extra{color:var(--danger);font-size:.85rem}.expander{flex:0 0 auto}.ts-dot-saving{width:8px;height:8px;border-radius:50%;background:#ffd54f;display:inline-block;margin-left:6px}.ts-drill{background:#fafbff;border-top:1px dashed var(--line);padding:10px 12px 12px}.ts-drill-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:center}.ts-drill-head{font-size:.82rem;color:var(--muted)}.ts-drill-cell input{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--text)}.row-with-action{display:grid;grid-template-columns:1fr 36px;gap:8px;align-items:center}.is-today .ts-row-main{background:#fff}.is-weekend .ts-row-main{background:#fcfcfd}.icon-btn:focus,.ts-fab:focus,.ts-drill-cell input:focus{outline:none;box-shadow:0 0 0 3px #2563eb2e}.ts-extra-icon-positive{color:#1a7f37}.ts-extra-icon-negative{color:var(--danger)}.ts-total-extra.positive{color:#1a7f37}.ts-total-extra.negative{color:var(--danger)}@media (max-width: 500px){.ts-drill{display:block}.icon-btn.ghost.expander,.icon-btn.primary,.ts-day{display:none}.ts-total-value{font-size:1rem;display:flex;align-items:center;gap:4px}.ts-wrap{padding:10px;padding-bottom:calc(76px + env(safe-area-inset-bottom))}.ts-head h2{font-size:1rem}.ts-actions{gap:6px}.icon-btn{width:32px;height:32px;border-radius:8px}.icon-btn.primary svg,.icon-btn.ghost svg,.icon-btn.danger svg{width:16px;height:16px}.ts-fab{width:48px;height:48px;border-radius:12px;right:14px;bottom:calc(14px + env(safe-area-inset-bottom))}.ts-list{border-radius:10px}.ts-row-main{display:grid;grid-template-columns:32px 1fr auto;align-items:center;gap:8px;padding:8px 10px}.ts-day{display:none}.ts-cell.ts-date{gap:0}.ts-date-top{font-weight:600;font-size:.95rem}.badge{margin-left:6px;font-size:.66rem;padding:1px 6px}.ts-total{min-width:auto;gap:8px}.ts-total-value{width:auto;min-width:48px;text-align:right;font-weight:700;font-size:.95rem}.expander{width:32px;height:32px}.ts-drill{padding:8px 10px 10px}.ts-drill-grid{grid-template-columns:1fr 1fr;gap:6px}.ts-drill-head{font-size:.78rem}.ts-drill-cell input{padding:8px 10px;height:38px;font-size:.95rem}.row-with-action{grid-template-columns:1fr 32px;gap:6px}.ts-dot-saving{width:6px;height:6px;margin-left:4px}.badge.today,.badge.holiday{font-size:.7rem;padding:1px}}@media (max-width: 340px){.icon-btn.primary,.icon-btn.ghost.expander{display:none}.ts-row-main{gap:6px;padding:8px}.ts-total-value{min-width:42px;font-size:.8rem}.ts-drill{padding:8px}}
