@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--primary:#2563eb;--primary-dark:#1d4ed8;--primary-light:#eff6ff;--success:#16a34a;--success-light:#f0fdf4;--danger:#dc2626;--danger-light:#fef2f2;--warning:#d97706;--warning-light:#fffbeb;--bg:#f8fafc;--surface:#fff;--border:#e2e8f0;--border-focus:#2563eb;--text:#0f172a;--text-muted:#64748b;--text-light:#94a3b8;--radius:10px;--radius-sm:6px;--radius-lg:16px;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000a;--shadow-lg:0 10px 25px #0000001a, 0 4px 6px #0000000a;--navbar-height:64px;--font:"Inter", system-ui, -apple-system, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6}a{color:inherit;text-decoration:none}.main-content{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.navbar{z-index:100;height:var(--navbar-height);background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow);align-items:center;gap:1rem;padding:0 1.5rem;display:flex;position:sticky;top:0}.navbar-brand{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.navbar-logo{font-size:1.4rem}.navbar-title{color:var(--primary);font-size:1.1rem;font-weight:700}.navbar-links{flex:1;align-items:center;gap:.25rem;display:flex}.nav-link{border-radius:var(--radius-sm);color:var(--text-muted);padding:.4rem .85rem;font-size:.875rem;font-weight:500;transition:background .15s,color .15s}.nav-link:hover,.nav-link.active{background:var(--primary-light);color:var(--primary)}.navbar-user{flex-shrink:0;align-items:center;gap:.75rem;margin-left:auto;display:flex}.user-badge{text-transform:uppercase;letter-spacing:.05em;background:var(--primary-light);color:var(--primary);border-radius:999px;padding:.2rem .6rem;font-size:.7rem;font-weight:600}.user-name{font-size:.875rem;font-weight:500}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem}.card-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.card-title{font-size:1.1rem;font-weight:600}.page-header{margin-bottom:1.75rem}.page-title{font-size:1.6rem;font-weight:700}.page-subtitle{color:var(--text-muted);margin-top:.25rem;font-size:.95rem}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:.4rem;padding:.55rem 1.1rem;font-size:.875rem;font-weight:600;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-ghost{color:var(--text-muted);border:1px solid var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg);color:var(--text)}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.btn-block{justify-content:center;width:100%;padding:.75rem}.form-group{flex-direction:column;gap:.4rem;margin-bottom:1rem;display:flex}.form-label{color:var(--text-muted);font-size:.85rem;font-weight:600}.form-control{border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;font-family:var(--font);background:var(--surface);color:var(--text);width:100%;padding:.6rem .85rem;transition:border-color .15s,box-shadow .15s}.form-control:focus{border-color:var(--border-focus);outline:none;box-shadow:0 0 0 3px #2563eb1f}.form-control::placeholder{color:var(--text-light)}textarea.form-control{resize:vertical;min-height:90px}select.form-control{cursor:pointer}.alert{border-radius:var(--radius-sm);margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.alert-error{background:var(--danger-light);color:var(--danger);border:1px solid #fca5a5}.alert-success{background:var(--success-light);color:var(--success);border:1px solid #86efac}.table-wrapper{border-radius:var(--radius);border:1px solid var(--border);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.875rem}thead th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap;background:#f1f5f9;padding:.75rem 1rem;font-size:.75rem;font-weight:700}tbody tr{border-bottom:1px solid var(--border)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:#f8fafc}tbody td{vertical-align:middle;padding:.6rem .85rem}.td-date{white-space:nowrap;color:var(--text);min-width:110px;font-weight:600}.td-notes{color:#374151;max-width:340px;font-size:.82rem;line-height:1.55}.td-time input{width:100px}.td-hours{text-align:center;min-width:60px;font-weight:600}.time-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.82rem;font-family:var(--font);width:105px;padding:.35rem .5rem}.time-input:focus{border-color:var(--border-focus);outline:none}.task-list{flex-direction:column;gap:.3rem;max-height:160px;padding:.2rem;display:flex;overflow-y:auto}.task-item{cursor:pointer;align-items:flex-start;gap:.45rem;font-size:.8rem;line-height:1.4;display:flex}.task-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--primary);margin-top:2px}.task-item-label{color:var(--text)}.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem;margin-top:1.5rem;display:grid}.dash-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;color:var(--text);box-shadow:var(--shadow);flex-direction:column;justify-content:center;align-items:center;gap:.6rem;padding:2rem 1rem;text-decoration:none;transition:all .2s;display:flex}.dash-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.dash-card-icon{font-size:2.2rem}.dash-card-label{font-size:.95rem;font-weight:600}.login-page{background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 50%,#1d4ed8 100%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-lg);padding:2.5rem 2rem}.login-logo{text-align:center;margin-bottom:1.5rem}.login-logo-icon{font-size:3rem}.login-logo-title{margin-top:.5rem;font-size:1.4rem;font-weight:700}.login-logo-sub{color:var(--text-muted);margin-top:.2rem;font-size:.875rem}.filters-row{flex-wrap:wrap;align-items:flex-end;gap:1rem;margin-bottom:1.25rem;display:flex}.filters-row .form-group{min-width:170px;margin-bottom:0}.badge{text-transform:uppercase;letter-spacing:.05em;border-radius:999px;padding:.2rem .65rem;font-size:.7rem;font-weight:700;display:inline-block}.badge-admin{color:#6d28d9;background:#ede9fe}.badge-employee{background:var(--primary-light);color:var(--primary)}.badge-client{color:#92400e;background:#fef3c7}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1rem}.empty-icon{margin-bottom:.75rem;font-size:2.5rem}.ts-meta{flex-wrap:wrap;gap:2rem;margin-bottom:1.25rem;font-size:.875rem;display:flex}.ts-meta span{color:var(--text-muted)}.ts-meta strong{color:var(--text)}.ts-row-header{cursor:pointer;border-bottom:1px solid var(--border);-webkit-user-select:none;user-select:none;background:#f8fafc;align-items:center;gap:1rem;padding:.7rem 1rem;display:flex}.ts-row-header:hover{background:var(--primary-light)}.ts-body{border-bottom:1px solid var(--border);padding:.75rem 1rem;font-size:.85rem}.divider{background:var(--border);height:1px;margin:1.25rem 0}@media (width<=768px){.navbar-links{display:none}.main-content{padding:1rem}.dashboard-grid{grid-template-columns:repeat(2,1fr)}.filters-row{flex-direction:column}}@media print{@page{size:portrait;margin:6mm 8mm}*{box-sizing:border-box!important}body{-webkit-print-color-adjust:exact;print-color-adjust:exact;color:#000!important;background:#fff!important;font-family:Arial,Helvetica,sans-serif!important;font-size:6pt!important;line-height:1.15!important}.navbar,.page-header,.print-hide,.alert,.ts-selection-card,.task-list,.btn,.btn-ghost,.btn-success,.btn-primary,.btn-danger{display:none!important}.main-content{max-width:100%!important;margin:0!important;padding:0!important}.card{box-shadow:none!important;border:none!important;border-radius:0!important;margin:0!important;padding:0!important}.print-timesheet>div:first-child{padding:2pt 4pt!important;font-size:8pt!important}.print-timesheet>div:nth-child(2){gap:1rem!important;padding:2pt 4pt!important;font-size:7pt!important}.print-timesheet table{border-collapse:collapse!important;table-layout:fixed!important;width:100%!important;font-size:6.5pt!important}.print-timesheet thead tr{background:#d8d8d8!important}.print-timesheet th{color:#000!important;border:.5pt solid #555!important;padding:1.5pt 3pt!important;font-size:6pt!important}.print-timesheet td{color:#000!important;vertical-align:top!important;word-wrap:break-word!important;border:.5pt solid #888!important;padding:1pt 3pt!important;line-height:1.25!important}.print-timesheet table th:first-child,.print-timesheet table td:first-child{width:7%!important}.print-timesheet table th:nth-child(2),.print-timesheet table td:nth-child(2),.print-timesheet table th:nth-child(3),.print-timesheet table td:nth-child(3){width:6%!important}.print-timesheet table th:nth-child(4),.print-timesheet table td:nth-child(4){width:5%!important}.print-timesheet table th:nth-child(5),.print-timesheet table td:nth-child(5){width:76%!important}.print-timesheet>div:last-of-type{padding:2pt 4pt!important;font-size:7pt!important}.ts-rules-box{page-break-inside:avoid!important;border:1pt solid #000!important;margin:2pt 0!important;padding:2pt 4pt!important;font-size:6pt!important;line-height:1.25!important}.ts-rules-box p,.ts-rules-box div{margin-bottom:1pt!important}.ts-sig-section{page-break-inside:avoid!important;margin:2pt 0 0!important}.ts-sig-section>div:first-child{gap:1rem!important;margin-bottom:2pt!important;font-size:7pt!important}.ts-sig-section canvas{width:200px!important;height:40px!important}.ts-sig-section>div:last-child>div{font-size:6.5pt!important}.print-only{display:inline!important}.print-date{display:inline-block!important}.time-input,input[type=date],input[type=time]{display:none!important}canvas.sig-canvas{border:.5pt solid #000!important;display:block!important}}
