:root{--bg: #f3f4f6;--surface: #ffffff;--surface-alt: #f9fafb;--text: #1f2937;--text-secondary: #6b7280;--text-tertiary: #9ca3af;--heading: #111827;--border: #d1d5db;--border-light: #e5e7eb;--hover: #f3f4f6;--primary: #0d9488;--primary-hover: #0f766e;--primary-light: #f0fdfa;--primary-lighter: #ccfbf1;--focus: #2563eb;--danger: #dc2626;--danger-bg: #fef2f2;--danger-border: #fecaca;--danger-text: #991b1b;--success-bg: #ecfdf5;--success-border: #a7f3d0;--success-text: #065f46;--warning-bg: #fef3c7;--warning-text: #92400e;--shadow: 0 1px 3px rgba(15, 23, 42, .08);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .15);--overlay: rgba(0, 0, 0, .4);--mono: ui-monospace, SFMono-Regular, Menlo, monospace;color-scheme:light}[data-theme=dark]{--bg: #111827;--surface: #1f2937;--surface-alt: #374151;--text: #f3f4f6;--text-secondary: #9ca3af;--text-tertiary: #6b7280;--heading: #f9fafb;--border: #374151;--border-light: #4b5563;--hover: #374151;--primary: #14b8a6;--primary-hover: #0d9488;--primary-light: #1a3a38;--primary-lighter: #1a3a38;--focus: #3b82f6;--danger: #ef4444;--danger-bg: #451a1a;--danger-border: #7f1d1d;--danger-text: #fca5a5;--success-bg: #1a3a2a;--success-border: #166534;--success-text: #86efac;--warning-bg: #3a2a1a;--warning-text: #fcd34d;--shadow: 0 1px 3px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .5);--overlay: rgba(0, 0, 0, .6);color-scheme:dark}[data-theme=dark] input,[data-theme=dark] textarea,[data-theme=dark] select{background-color:var(--surface)!important;color:var(--text)!important;border-color:var(--border)!important}[data-theme=dark] input::placeholder,[data-theme=dark] textarea::placeholder{color:var(--text-tertiary)!important}:host{font-family:system-ui,-apple-system,sans-serif;color:var(--text);background:var(--bg);min-height:100vh;display:block}.page{max-width:1100px;margin:0 auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}@media (max-width: 640px){.page{padding:.75rem;gap:.75rem}}.header{display:flex;flex-direction:column;gap:.25rem}.header h1{font-size:1.75rem;margin:0}.header p{margin:0;color:var(--text-secondary)}.header-top{display:flex;justify-content:space-between;align-items:center}.header-actions{display:flex;gap:.75rem;align-items:center}.link{font-size:.85rem;color:var(--primary);text-decoration:none}.link:hover{text-decoration:underline}.panel{background:var(--surface);border-radius:.75rem;padding:1rem;box-shadow:var(--shadow)}.panel h2{font-size:1.05rem;margin:0 0 .75rem}.loading,.empty{text-align:center;color:var(--text-secondary);padding:2rem}.loading p,.empty p{margin:.25rem 0}.error-msg{padding:.5rem .6rem;font-size:.85rem;color:var(--danger-text);background:var(--danger-bg);border-radius:.5rem;border:1px solid var(--danger-border);margin-bottom:.75rem}.success-msg{padding:.5rem .6rem;font-size:.85rem;color:var(--success-text);background:var(--success-bg);border-radius:.5rem;border:1px solid var(--success-border);margin-bottom:.75rem}table{width:100%;border-collapse:collapse}table th,table td{text-align:left;padding:.6rem .75rem;font-size:.9rem}table th{font-weight:600;color:var(--text-secondary);border-bottom:2px solid var(--border-light)}table td{border-bottom:1px solid var(--hover)}table tr:last-child td{border-bottom:none}.num{text-align:right}.mono{font-family:var(--mono)}.clickable{cursor:pointer}.clickable:hover{background:var(--surface-alt)}.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.action-cell{display:flex;gap:.5rem;justify-content:flex-end}@media (max-width: 900px){.hide-tablet{display:none!important}}@media (max-width: 640px){.hide-mobile{display:none!important}}.mobile-view{display:none}@media (max-width: 640px){.desktop-view{display:none!important}.mobile-view{display:block!important}}.m-card{background:var(--surface);border:1px solid var(--border-light);border-radius:.5rem;padding:.75rem;margin-bottom:.5rem}.card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.5rem}.card-title{font-weight:600;font-size:.95rem;line-height:1.3;min-width:0;overflow:hidden;text-overflow:ellipsis}.card-header-right{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.card-fields{display:flex;flex-direction:column;gap:.3rem}.card-field{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem;font-size:.85rem}.card-label{color:var(--text-secondary);font-size:.8rem;flex-shrink:0}.card-value{text-align:right;font-weight:500;word-break:break-all}.card-actions{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin-top:.5rem}.card-checkbox{flex-shrink:0;cursor:pointer}.card-duration{font-family:var(--mono);font-size:.85rem;font-weight:600;flex-shrink:0}.card-expansion{background:var(--surface-alt);border:1px solid var(--border-light);border-top:none;border-radius:0 0 .5rem .5rem;margin-top:-.5rem;margin-bottom:.5rem;padding:.75rem}.badge{display:inline-block;padding:.15rem .5rem;border-radius:999px;font-size:.75rem;font-weight:500}.badge-draft{background:var(--hover);color:var(--text-secondary)}.badge-submitted{background:#ccfbf1;color:#115e59}.badge-approved{background:#d1fae5;color:#065f46}.badge-rejected{background:#fee2e2;color:#991b1b}.badge-finalized{background:#ccfbf1;color:#115e59}.badge-sent{background:#fef3c7;color:#92400e}.badge-paid{background:#d1fae5;color:#065f46}.badge-external{background:#ede9fe;color:#5b21b6}.badge-overdue{background:#fee2e2;color:#991b1b;font-weight:700;font-size:.65rem;margin-left:.35rem}.badge-active{background:#d1fae5;color:#065f46}.badge-inactive{background:var(--hover);color:var(--text-secondary)}.badge-user,.badge-freelancer{background:#ccfbf1;color:#115e59}.badge-approver,.badge-client{background:#fef3c7;color:#92400e}.badge-admin{background:#fce7f3;color:#9d174d}.badge-superadmin{background:#ede9fe;color:#5b21b6}.badge-connected{background:#d1fae5;color:#065f46}.badge-warning{background:#fef3c7;color:#92400e;font-weight:700;font-size:.7rem}.badge-danger{background:#fef2f2;color:#b91c1c}.modal-overlay,.modal-backdrop{position:fixed;inset:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-backdrop{z-index:100}.modal{background:var(--surface);border-radius:.75rem;padding:1.5rem;width:100%;max-width:480px;box-shadow:var(--shadow-lg);max-height:90vh;display:flex;flex-direction:column}.modal h3{margin:0 0 .25rem;font-size:1.1rem}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-light)}.modal-header h2{font-size:1.1rem;margin:0}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:0;line-height:1}.modal-close:hover{color:var(--text)}.modal-body{padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem 1.25rem;border-top:1px solid var(--border-light)}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.modal-hint{color:var(--text-secondary);font-size:.85rem;margin:0 0 1rem}.modal-label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.35rem}.modal-textarea{width:100%;padding:.5rem .6rem;border:1px solid var(--border);border-radius:.5rem;font:inherit;font-size:.9rem;resize:vertical;box-sizing:border-box}.modal-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #0d948826}.modal-char-count{text-align:right;font-size:.75rem;color:var(--text-tertiary);margin-top:.25rem}.btn-cancel{background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:.35rem .85rem;font:inherit;font-size:.85rem;cursor:pointer}.btn-cancel:hover{background:var(--hover)}.filter-bar{display:flex;gap:.5rem;flex-wrap:wrap;align-items:flex-end;margin-bottom:.75rem}.bulk-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding:.5rem 0}.bulk-buttons{display:flex;gap:.5rem}.selection-info{font-size:.8rem;color:var(--text-secondary)}.checkbox-label{display:flex;align-items:center;gap:.4rem;font-size:.85rem;cursor:pointer}@media (max-width: 640px){.filter-bar{flex-direction:column}.filter-bar .field{width:100%}.bulk-actions{flex-direction:column;gap:.5rem;align-items:stretch}}.filter-head{background:var(--surface);border-radius:.75rem;box-shadow:var(--shadow);padding:1.125rem 1.375rem;display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;margin-bottom:.75rem}.stat-anchor{display:flex;flex-direction:column;gap:.125rem;min-width:0}.stat-anchor .label{font-size:.66rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary)}.stat-anchor .value{font-family:var(--mono);font-size:2.25rem;font-weight:700;color:var(--heading);line-height:1;letter-spacing:-.02em;margin-top:.125rem}.stat-anchor .sub{font-size:.82rem;color:var(--text-secondary);margin-top:.375rem}.stat-anchor .sub .billable{color:var(--success-text);font-weight:500;font-family:var(--mono)}.filter-chips{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;padding:0 .25rem;margin-bottom:.75rem}.filter-chips .lead{font-size:.7rem;color:var(--text-tertiary);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-right:.25rem}.filter-chip{display:inline-flex;align-items:center;padding:0 .25rem 0 .7rem;height:1.75rem;background:var(--surface);border:1px solid var(--border);border-radius:999px;font-size:.78rem;color:var(--text);white-space:nowrap;transition:background .15s}.filter-chip:hover{background:var(--surface-alt)}.filter-chip .key{color:var(--text-secondary);margin-right:.3rem}.filter-chip .val{font-weight:600;color:var(--heading)}.filter-chip .x{margin-left:.375rem;width:1.25rem;height:1.25rem;border-radius:50%;border:none;background:transparent;display:inline-flex;align-items:center;justify-content:center;color:var(--text-tertiary);cursor:pointer}.filter-chip .x:hover{background:var(--hover);color:var(--text)}.filter-chip .x:focus-visible{outline:2px solid var(--focus);outline-offset:1px}.filter-chip-add-wrap{position:relative;display:inline-flex}.filter-chip-add{display:inline-flex;align-items:center;gap:.3rem;padding:0 .75rem;height:1.75rem;background:transparent;border:1px dashed var(--border);border-radius:999px;font:inherit;font-size:.78rem;color:var(--text-secondary);cursor:pointer;transition:border-color .15s,color .15s,background .15s}.filter-chip-add:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.filter-chip-add:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.filter-clear-all{margin-left:auto;font:inherit;font-size:.75rem;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;padding:.25rem .5rem;border-radius:.375rem}.filter-clear-all:hover{color:var(--danger);background:var(--danger-bg)}.filter-clear-all:focus-visible{outline:2px solid var(--focus);outline-offset:1px}.chip-menu{position:absolute;top:calc(100% + .4rem);left:0;z-index:50;min-width:14rem;max-width:22rem;background:var(--surface);border:1px solid var(--border-light);border-radius:.6rem;box-shadow:var(--shadow-lg);padding:.35rem;display:flex;flex-direction:column;gap:.1rem;animation:chip-menu-in .14s ease-out}.chip-menu button,.chip-menu .chip-menu-item{display:flex;align-items:center;justify-content:space-between;gap:.5rem;background:transparent;border:none;text-align:left;padding:.45rem .6rem;font:inherit;font-size:.82rem;color:var(--text);border-radius:.4rem;cursor:pointer}.chip-menu button:hover,.chip-menu .chip-menu-item:hover{background:var(--hover)}.chip-menu button.active,.chip-menu .chip-menu-item.active{background:var(--primary-light);color:var(--primary);font-weight:600}.chip-menu button:focus-visible,.chip-menu .chip-menu-item:focus-visible{outline:2px solid var(--focus);outline-offset:-2px}.chip-menu button .hint,.chip-menu .chip-menu-item .hint{color:var(--text-tertiary);font-size:.7rem}.chip-menu .chip-menu-section{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);padding:.4rem .6rem .2rem}@keyframes chip-menu-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 760px){.filter-head{flex-direction:column;align-items:stretch}.filter-clear-all{margin-left:0}}.tabs{display:flex;gap:.25rem;background:var(--surface);border-radius:.75rem;padding:.25rem;box-shadow:var(--shadow)}.tabs button{flex:1;border:none;background:transparent;padding:.5rem 1rem;border-radius:.5rem;font:inherit;font-size:.9rem;cursor:pointer;color:var(--text-secondary)}.tabs button.active{background:var(--primary);color:#fff}.tabs button:hover:not(.active){background:var(--hover)}.scroll-sentinel{display:flex;justify-content:center;padding:1rem;min-height:1px}.loading-more{color:var(--text-secondary);font-size:.85rem}.hint{font-size:.8rem;color:var(--text-secondary)}.total{font-weight:600}.group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.group-total{font-family:var(--mono);font-size:.85rem;font-weight:600;color:var(--text)}.add-row{display:flex;gap:.5rem;margin-bottom:1rem}.create-form{display:flex;flex-direction:column;gap:.75rem;max-width:400px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem}@media (max-width: 640px){.form-grid{grid-template-columns:1fr}}.form-actions{display:flex;gap:.5rem}.page-actions{display:flex;justify-content:flex-end}.btn-icon{background:none;border:none;font-size:1rem;cursor:pointer;color:var(--text-secondary)}.btn-icon:hover{color:var(--text)}.btn-danger{color:var(--danger)}.btn-danger:hover{color:var(--danger-text)}.primary{background:var(--primary);color:#fff;border-radius:999px;border:none;padding:.4rem .9rem;font:inherit;font-size:.9rem;cursor:pointer}.primary:hover:not(:disabled){background:var(--primary-hover)}.primary:disabled{opacity:.6;cursor:default}.secondary{background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:.35rem .75rem;font:inherit;font-size:.85rem;cursor:pointer}.secondary:hover{background:var(--hover)}html,body{margin:0;padding:0;background:var(--bg);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:focus-visible{outline:2px solid var(--focus);outline-offset:2px}:focus:not(:focus-visible){outline:none}.page{min-height:100vh}.page-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.page-header h1{font-size:1.5rem;font-weight:700;color:var(--heading);margin:0;line-height:1.3}.page-header p{font-size:.85rem;color:var(--text-secondary);margin:.25rem 0 0}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start;gap:.75rem}.page-header h1{font-size:1.25rem}}.table-scroll,.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}@media (max-width: 640px){.hide-mobile{display:none}}.btn,.btn-danger-outline,.btn-ghost,.btn-secondary,.btn-primary{font:inherit;font-size:.85rem;border:none;border-radius:999px;padding:.4rem 1rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.35rem;transition:background .15s,opacity .15s;min-height:2.5rem}.btn:disabled,.btn-danger-outline:disabled,.btn-ghost:disabled,.btn-secondary:disabled,.btn-primary:disabled{opacity:.5;cursor:default}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--surface);border:1px solid var(--border);color:var(--text)}.btn-secondary:hover:not(:disabled){background:var(--surface-alt)}.btn-ghost{background:none;color:var(--primary);padding:.4rem .75rem}.btn-ghost:hover:not(:disabled){background:var(--primary-light)}.btn-danger-outline{background:var(--surface);border:1px solid var(--danger-border);color:var(--danger)}.btn-danger-outline:hover:not(:disabled){background:var(--danger-bg)}.btn-loading{position:relative;color:transparent!important;pointer-events:none}.btn-loading:after{content:"";position:absolute;width:.85rem;height:.85rem;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:btn-spin .6s linear infinite;border-color:#fff6;border-top-color:#fff}@keyframes btn-spin{to{transform:rotate(360deg)}}.loading-center{display:flex;justify-content:center;align-items:center;padding:2rem}@media (max-width: 640px){button,select,input[type=date],input[type=time]{min-height:2.75rem}.btn-icon{min-width:2.75rem;min-height:2.75rem;display:inline-flex;align-items:center;justify-content:center}}input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=time],input[type=url],input[type=tel],input[type=search],textarea,select{font:inherit;font-size:.875rem;padding:.5rem .75rem;border:1px solid var(--border);border-radius:.5rem;background:var(--surface);color:var(--text);transition:border-color .15s,box-shadow .15s;width:100%;box-sizing:border-box}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,input[type=number]:focus,input[type=date]:focus,input[type=time]:focus,input[type=url]:focus,input[type=tel]:focus,input[type=search]:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0d94881a}input[type=text]:disabled,input[type=email]:disabled,input[type=password]:disabled,input[type=number]:disabled,input[type=date]:disabled,input[type=time]:disabled,input[type=url]:disabled,input[type=tel]:disabled,input[type=search]:disabled,textarea:disabled,select:disabled{background:var(--surface-alt);color:var(--text-tertiary);cursor:not-allowed}input[type=text]::placeholder,input[type=email]::placeholder,input[type=password]::placeholder,input[type=number]::placeholder,input[type=date]::placeholder,input[type=time]::placeholder,input[type=url]::placeholder,input[type=tel]::placeholder,input[type=search]::placeholder,textarea::placeholder,select::placeholder{color:var(--text-tertiary)}select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.25rem;cursor:pointer}textarea{resize:vertical;min-height:4rem}label{display:block;font-size:.8rem;font-weight:500;color:var(--text);margin-bottom:.25rem}.field{display:flex;flex-direction:column;gap:.25rem}.msg-success{padding:.5rem .75rem;font-size:.85rem;color:var(--success-text);background:var(--success-bg);border-radius:.5rem;border:1px solid var(--success-border)}.msg-error{padding:.5rem .75rem;font-size:.85rem;color:var(--danger-text);background:var(--danger-bg);border-radius:.5rem;border:1px solid var(--danger-border)}
