:where(body,.topbar,.card,.cell,.week-cell,.monthly-total,.exp-table,.exp-empty,.pill,.badge,.btn,.nav-btn,.theme-toggle,.logout,.progress,.progress-fill,.hours-input,.field input,.add-expense,.state-card,.login-card,.avatar){transition:background-color .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease}.app-root{min-height:100%}.topbar{background:var(--surface);border-bottom:1px solid var(--border)}.topbar-inner{max-width:1180px;margin:0 auto;height:66px;padding:0 24px;display:flex;align-items:center;justify-content:space-between}.brand{display:flex;align-items:center;gap:12px}.logo{width:38px;height:38px;border-radius:11px;background:var(--accent);color:#fff;font-weight:700;font-size:17px;display:grid;place-items:center;flex-shrink:0}.brand-name{font-size:15px;font-weight:700}.brand-sub{font-size:12.5px;color:var(--muted);margin-top:1px}.user{display:flex;align-items:center;gap:14px}.user-text{text-align:right}.user-name{font-size:14px;font-weight:600}.user-company{font-size:12.5px;color:var(--muted);margin-top:1px}.avatar{width:40px;height:40px;border-radius:50%;background:var(--accent-weak);color:var(--accent-ink);font-weight:600;font-size:13px;display:grid;place-items:center}.logout{background:transparent;border:1px solid var(--border-strong);border-radius:9px;padding:7px 12px;font-size:13px;font-weight:600;color:var(--text-soft)}.logout:hover{background:var(--surface-hover)}.theme-toggle{width:38px;height:38px;border-radius:10px;border:1px solid var(--border-strong);background:var(--surface);color:var(--text-soft);display:grid;place-items:center}.theme-toggle:hover{background:var(--surface-hover);color:var(--text)}.page{max-width:1180px;margin:0 auto;padding:28px 24px 72px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.eyebrow{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:12px}.month-row{display:flex;align-items:center;gap:14px;margin-bottom:22px}.month-title{font-size:38px;font-weight:800;letter-spacing:-.02em;margin:0}.nav-btn{width:44px;height:44px;border-radius:12px;border:1px solid var(--border-strong);background:var(--surface);color:var(--text-soft);display:grid;place-items:center}.nav-btn:hover{background:var(--surface-hover)}.badge{margin-left:auto;display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;font-size:13px;font-weight:600}.badge .dot{width:8px;height:8px;border-radius:50%;background:currentColor}.badge-draft{background:var(--good-weak);color:var(--good-ink)}.badge-submitted{background:var(--warn-weak);color:var(--warn-ink)}.badge-locked{background:var(--surface-2);color:var(--text-soft)}.summary{padding:24px 28px 22px}.summary-row{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.label{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600}.label.accent{color:var(--accent-ink)}.big{font-size:38px;font-weight:800;letter-spacing:-.02em;margin-top:6px}.big-sub{font-size:18px;font-weight:500;color:var(--muted);letter-spacing:0}.summary-right{text-align:right}.big.accent{color:var(--accent)}.big-unit{font-size:20px;font-weight:700}.big.is-over,.mt-big.is-over{color:var(--danger)}.progress{height:10px;background:var(--track);border-radius:999px;margin:22px 0 12px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:999px;transition:width .25s ease,background-color .18s ease}.progress-fill.is-over{background:var(--danger)}.summary-foot{display:flex;justify-content:space-between;font-size:13px;color:var(--muted)}.calendar{margin-top:20px;overflow:hidden}.cal-head,.cal-row{display:grid;grid-template-columns:repeat(7,1fr) 92px}.cal-h{padding:14px 16px;font-size:11.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:600}.cal-h:not(:last-child){border-right:1px solid var(--border)}.cal-h-week{text-align:right}.cell{min-height:106px;padding:12px 14px;display:flex;flex-direction:column;justify-content:space-between;border-top:1px solid var(--border);background:var(--surface)}.cell:not(:last-child){border-right:1px solid var(--border)}.cell-out{background:var(--surface-2)}.cell-out .cell-day,.cell-out .hours-static{color:var(--faint)}.cell-today{position:relative;z-index:1;border-radius:10px;box-shadow:inset 0 0 0 2px var(--accent)}.cell-head{display:flex;align-items:center;justify-content:space-between}.cell-day{font-size:14px;color:var(--muted);font-weight:500}.cell-today-tag{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent)}.cell-hours{align-self:flex-end;display:flex;align-items:baseline;gap:3px}.hours-input{width:58px;border:none;background:transparent;text-align:right;font-size:22px;font-weight:700;color:var(--text);padding:2px;outline:none;border-radius:8px}.hours-input::placeholder{color:var(--faint)}.hours-input:focus{background:var(--accent-weak)}.hours-static{font-size:22px;font-weight:700;color:var(--text)}.hours-static.is-zero{color:var(--faint)}.hours-unit{font-size:13px;color:var(--muted);font-weight:500}.week-cell{background:var(--surface-2);align-items:flex-end;justify-content:center;text-align:right}.week-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600}.week-total{font-size:22px;font-weight:800;margin-top:6px}.monthly-total{margin-top:20px;background:var(--accent-weak);border:1px solid var(--accent-border);border-radius:var(--radius);padding:22px 28px;display:flex;align-items:center;justify-content:space-between}.mt-sub{color:var(--text-soft);font-size:14px;margin-top:4px}.mt-big{font-size:38px;font-weight:800;letter-spacing:-.02em}.mt-unit{font-size:20px;font-weight:600;color:var(--muted)}.expenses{margin-top:20px;padding:24px 28px}.exp-head{display:flex;align-items:flex-start;justify-content:space-between}.exp-head h2{font-size:19px;font-weight:700;margin:0}.sub{color:var(--muted);font-size:13.5px;margin:3px 0 0}.pill{background:var(--surface-2);color:var(--text-soft);padding:6px 12px;border-radius:999px;font-size:13px;font-weight:600}.exp-table{margin-top:18px;border:1px solid var(--border);border-radius:12px;overflow:hidden}.exp-row{display:grid;grid-template-columns:2.2fr 1.2fr 1fr .9fr .5fr .45fr;align-items:center}.exp-row:not(:first-child){border-top:1px solid var(--border)}.exp-row>*{padding:13px 16px;min-width:0}.exp-row-head{background:var(--surface-2);font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600}.exp-empty{border-top:1px solid var(--border);padding:22px 16px;text-align:center;color:var(--faint);font-size:14px}.exp-desc{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.exp-amt{font-weight:600;font-variant-numeric:tabular-nums}.exp-cur{color:var(--text-soft)}.ta-r{text-align:right}.ta-c{text-align:center}.muted{color:var(--faint);font-style:normal}.exp-draft input[type=text],.exp-draft input:not([type]),.exp-draft input[type=date],.exp-draft select{width:100%;border:none;background:transparent;outline:none;font-size:14.5px;color:var(--text);padding:4px 6px;border-radius:6px}.exp-draft input::placeholder{color:var(--faint)}.exp-draft input:focus,.exp-draft select:focus{background:var(--accent-weak)}.icon-btn{border:none;background:transparent;color:var(--muted);font-size:14px;padding:4px 8px;border-radius:6px;line-height:1}.icon-btn:hover{color:var(--danger);background:var(--danger-weak)}.add-expense{margin-top:16px;display:inline-flex;align-items:center;gap:8px;padding:11px 16px;border:1.5px dashed var(--accent-border);color:var(--accent-ink);background:transparent;border-radius:12px;font-weight:600;font-size:14px}.add-expense:hover{background:var(--accent-weak)}.action-error{margin-top:18px;background:var(--danger-weak);color:var(--danger);padding:12px 14px;border-radius:10px;font-size:14px}.footer-actions{margin-top:26px;display:flex;align-items:center;justify-content:space-between;gap:16px}.footer-note{color:var(--muted);font-size:13.5px;max-width:64ch}.footer-buttons{display:flex;gap:12px;flex-shrink:0}.btn{padding:11px 18px;border-radius:11px;font-size:14px;font-weight:600;border:1px solid transparent}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-ink)}.btn-secondary{background:var(--surface);border-color:var(--border-strong);color:var(--text)}.btn-secondary:hover:not(:disabled){background:var(--surface-hover)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-block{width:100%;margin-top:6px}.state-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:44px 28px;text-align:center;color:var(--text-soft);display:flex;flex-direction:column;align-items:center;gap:16px}.login-wrap{position:relative;min-height:100vh;display:grid;place-items:center;padding:24px}.login-toggle{position:absolute;top:20px;right:20px}.login-card{width:380px;max-width:92vw;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:30px 30px 28px}.login-title{font-size:22px;font-weight:700;margin:22px 0 18px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field span{font-size:13px;font-weight:600;color:var(--text-soft)}.field input{padding:11px 12px;border:1px solid var(--border-strong);border-radius:10px;font-size:15px;outline:none;background:var(--surface);color:var(--text)}.field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-weak)}.login-error{background:var(--danger-weak);color:var(--danger);padding:10px 12px;border-radius:9px;font-size:13.5px;margin-bottom:6px}:root,:root[data-theme=light]{color-scheme:light;--bg: #f3f4f6;--surface: #ffffff;--surface-2: #f5f6f8;--surface-hover: #eef0f3;--track: #e7e9ef;--text: #1b1f29;--text-soft: #4b515e;--muted: #99a0ad;--faint: #c4c9d2;--border: #ebedf1;--border-strong: #dde0e6;--accent: #5a4ff2;--accent-ink: #4a3fe0;--accent-weak: #eeedfe;--accent-border: #e0ddfb;--good-ink: #1f8a55;--good-weak: #e6f6ec;--warn-ink: #b27a17;--warn-weak: #fbf1de;--danger: #d8492f;--danger-weak: #fdecea;--radius: 16px;--shadow: 0 1px 2px rgba(16, 20, 30, .04), 0 6px 20px rgba(16, 20, 30, .05)}:root[data-theme=dark]{color-scheme:dark;--bg: #1a1d21;--surface: #23272e;--surface-2: #1e2227;--surface-hover: #2b3039;--track: #2c313a;--text: #e7e9ee;--text-soft: #b0b6c0;--muted: #828893;--faint: #565c67;--border: #2f343c;--border-strong: #3b414b;--accent: #7b73f7;--accent-ink: #a39cfb;--accent-weak: #262a3a;--accent-border: #3b3f63;--good-ink: #5fcd93;--good-weak: #16301f;--warn-ink: #d9ad5e;--warn-weak: #2e2715;--danger: #ef8a72;--danger-weak: #34211d;--shadow: 0 1px 2px rgba(0, 0, 0, .35), 0 8px 24px rgba(0, 0, 0, .45)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,select{font-family:inherit;font-size:100%}button{cursor:pointer}
