*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-w:260px;--sidebar-collapsed:68px;--primary:#b45309;--primary-dark:#3f190b;--primary-light:#fef3c7;--accent:#f59e0b;--danger:#dc2626;--success:#16a34a;--warning:#d97706;--info:#2563eb;--bg:#f1f5f9;--card:#fff;--border:#e2e8f0;--text:#0f172a;--text-2:#475569;--text-3:#94a3b8;--sidebar-bg:#1c0a04;--sidebar-hover:#ffffff14;--sidebar-active:#f59e0b2e;--shadow:0 1px 3px #00000014,0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012,0 2px 4px #0000000f;--shadow-lg:0 10px 15px #0000001a,0 4px 6px #0000000d;--radius:10px;--radius-sm:6px;--radius-lg:14px}body{-webkit-font-smoothing:antialiased;background:#f1f5f9;background:var(--bg);color:#0f172a;color:var(--text);font-family:Inter,-apple-system,sans-serif;font-size:14px;line-height:1.5}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}@media print{body{background:#fff}.no-print{display:none!important}}.login-page{background:var(--bg);display:flex;min-height:100vh}.login-left{align-items:center;background:var(--sidebar-bg);display:flex;justify-content:center;overflow:hidden;padding:40px;position:relative;width:45%}.login-left:before{background:radial-gradient(ellipse at 30% 70%,#f59e0b1f,#0000 60%),radial-gradient(ellipse at 70% 20%,#b453091a,#0000 50%);content:"";inset:0;position:absolute}.login-left-content{max-width:380px;position:relative;z-index:1}.login-brand-icon{align-items:center;background:var(--accent);border-radius:14px;box-shadow:0 8px 24px #f59e0b4d;color:var(--primary-dark);display:flex;font-size:1.8rem;height:60px;justify-content:center;margin-bottom:28px;width:60px}.login-left-content h1{color:#fff;font-size:2.2rem;font-weight:800;line-height:1.2;margin-bottom:14px}.login-left-content p{color:#ffffff80;font-size:.9rem;line-height:1.6;margin-bottom:28px}.login-features{display:flex;flex-direction:column;gap:10px}.login-feature-item{align-items:center;color:#ffffffa6;display:flex;font-size:.85rem;gap:10px}.feature-dot{background:var(--accent);border-radius:50%;flex-shrink:0;height:6px;width:6px}.login-right{align-items:center;display:flex;flex:1 1;justify-content:center;padding:40px 20px}.login-card{max-width:420px;width:100%}.login-card-header{margin-bottom:28px}.login-card-header h2{color:var(--text);font-size:1.6rem;font-weight:800;margin-bottom:6px}.login-card-header p{color:var(--text-2);font-size:.88rem}.login-error{align-items:flex-start;background:#fee2e2;border:1px solid #fca5a5;border-radius:var(--radius-sm);color:var(--danger);display:flex;font-size:.82rem;gap:8px;line-height:1.4;margin-bottom:18px;padding:10px 14px}.login-error svg{flex-shrink:0;font-size:1rem;margin-top:1px}.login-form{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.lf-group label{color:var(--text-2);display:block;font-size:.78rem;font-weight:600;letter-spacing:.5px;margin-bottom:7px;text-transform:uppercase}.lf-input-wrap{position:relative}.lf-icon{color:var(--text-3);font-size:1.1rem;left:13px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.lf-input-wrap input{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:.9rem;outline:none;padding:11px 14px 11px 40px;transition:border-color .2s,box-shadow .2s;width:100%}.lf-input-wrap input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #b453091a}.login-btn{align-items:center;background:var(--primary-dark);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:700;gap:8px;justify-content:center;margin-top:4px;padding:12px;transition:background .2s;width:100%}.login-btn:hover{background:#5a2510}.login-btn:disabled{cursor:not-allowed;opacity:.65}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;height:14px;width:14px}.demo-box{background:#fffbf2;border:1px solid #fde68a;border-radius:var(--radius);padding:14px}.demo-box-title{align-items:center;color:#92400e;display:flex;font-size:.75rem;font-weight:700;gap:6px;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.demo-rows{display:flex;flex-direction:column;gap:6px}.demo-row{align-items:center;background:#fff;border:1px solid #fde68a;border-radius:var(--radius-sm);cursor:pointer;display:flex;font-family:inherit;gap:10px;padding:7px 10px;transition:background .15s}.demo-row:hover{background:#fffbf2}.demo-badge{border-radius:20px;font-size:.68rem;font-weight:700;padding:2px 8px;text-transform:uppercase}.demo-badge.admin{background:#fef3c7;color:#92400e}.demo-badge.user{background:#f1f5f9;color:#475569}.demo-u{color:var(--text);flex:1 1;font-size:.82rem;font-weight:600}.demo-p{color:var(--text-3);font-family:monospace;font-size:.78rem}@media (max-width:768px){.login-left{display:none}.login-right{padding:24px 16px}}.sidebar{background:var(--sidebar-bg);display:flex;flex-direction:column;flex-shrink:0;height:100vh;overflow:hidden;position:sticky;top:0;transition:width .25s ease;width:var(--sidebar-w)}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-brand{border-bottom:1px solid #ffffff12;gap:10px;min-height:70px;padding:18px 14px 16px;position:relative}.brand-icon,.sidebar-brand{align-items:center;display:flex}.brand-icon{background:var(--accent);border-radius:10px;color:var(--primary-dark);flex-shrink:0;font-size:1.3rem;font-weight:900;height:40px;justify-content:center;width:40px}.brand-text{flex:1 1;overflow:hidden}.brand-text span{color:#fff;display:block;font-size:.92rem;font-weight:700;white-space:nowrap}.brand-text small{color:#ffffff73;font-size:.72rem}.collapse-btn{align-items:center;background:#ffffff14;border:none;border-radius:6px;color:#fff9;cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;height:26px;justify-content:center;transition:all .15s;width:26px}.collapse-btn:hover{background:#ffffff26;color:#fff}.sidebar-user{background:#ffffff0d;border-radius:var(--radius);gap:10px;margin:10px 10px 0;overflow:hidden;padding:14px}.sidebar-user,.user-avatar{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,var(--accent),var(--primary));border-radius:50%;color:#fff;flex-shrink:0;font-size:.9rem;font-weight:700;height:38px;justify-content:center;width:38px}.user-info{flex:1 1;overflow:hidden}.user-name{color:#fff;font-size:.85rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.7rem;font-weight:600;gap:4px;margin-top:3px;padding:2px 8px}.user-role-badge.admin{background:#f59e0b33;color:var(--accent)}.user-role-badge.user{background:#ffffff1a;color:#fff9}.sidebar-nav{flex:1 1;overflow-x:hidden;overflow-y:auto;padding:12px 10px}.nav-section-label{color:#ffffff4d;font-size:.65rem;font-weight:700;letter-spacing:1px;padding:6px 10px 8px;white-space:nowrap}.nav-item{align-items:center;background:#0000;border:none;border-radius:var(--radius-sm);color:#ffffff8c;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:11px;margin-bottom:2px;padding:10px 12px;position:relative;text-align:left;transition:all .15s;white-space:nowrap;width:100%}.nav-item:hover{background:var(--sidebar-hover);color:#ffffffe6}.nav-item.active{background:var(--sidebar-active);color:var(--accent);font-weight:600}.nav-icon{align-items:center;display:flex;flex-shrink:0;font-size:1.15rem}.nav-label{flex:1 1}.nav-dot{background:var(--accent);border-radius:50%;flex-shrink:0;height:6px;width:6px}.sidebar-footer{border-top:1px solid #ffffff12;padding:10px}.logout-btn{color:#ffffff73!important}.logout-btn:hover{background:#dc262626!important;color:#fca5a5!important}.sidebar-desktop{display:flex}.mobile-toggle{align-items:center;background:var(--sidebar-bg);border:none;border-radius:8px;box-shadow:var(--shadow-md);color:#fff;cursor:pointer;display:none;font-size:1.2rem;height:40px;justify-content:center;left:14px;position:fixed;top:14px;width:40px;z-index:1100}.sidebar-overlay{background:#00000080;display:none;inset:0;position:fixed;z-index:900}.sidebar-mobile{display:none;left:0;position:fixed;top:0;transform:translateX(-100%);transition:transform .25s ease;z-index:1000}.sidebar-mobile.open{transform:translateX(0)}@media (max-width:768px){.mobile-toggle{display:flex}.sidebar-mobile,.sidebar-overlay{display:block}.sidebar-desktop{display:none}.sidebar{width:var(--sidebar-w)!important}.collapse-btn{display:none}}.admin-wrap{display:flex;flex-direction:column;gap:20px}.stats-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.stat-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);gap:12px;overflow:hidden;padding:16px;position:relative}.stat-card,.stat-icon{align-items:center;display:flex}.stat-icon{border-radius:10px;flex-shrink:0;font-size:1.25rem;height:42px;justify-content:center;width:42px}.stat-body{flex:1 1}.stat-val{color:var(--text);font-size:1.7rem;font-weight:800;line-height:1}.stat-label{color:var(--text-2);font-size:.72rem;letter-spacing:.4px;margin-top:3px;text-transform:uppercase}.stat-bar{border-radius:0 0 var(--radius) var(--radius);bottom:0;height:3px;left:0;position:absolute;right:0}.stat-bar-fill{border-radius:inherit;height:100%;transition:width .5s ease}.admin-tabs{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);display:flex;gap:6px;padding:6px;width:fit-content}.atab{align-items:center;background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text-2);cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:7px;padding:8px 18px;transition:all .15s}.atab:hover{background:var(--bg);color:var(--text)}.atab.active{background:var(--primary-dark);color:#fff}.atab-count{background:#fff3;border-radius:20px;font-size:.72rem;padding:1px 7px}.atab:not(.active) .atab-count{background:var(--bg);color:var(--text-2)}.panel{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.panel-hd{border-bottom:1px solid var(--border);color:var(--text);font-size:.9rem;font-weight:700;gap:10px;justify-content:space-between;padding:14px 18px}.panel-hd,.panel-hd>span{align-items:center;display:flex}.panel-hd>span{gap:8px}.panel-bd{padding:18px}.panel-bd.p0{padding:0}.task-form-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr 1fr}.col-full{grid-column:1/-1}.tf label{color:var(--text-2);display:block;font-size:.75rem;font-weight:700;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.req{color:var(--danger)}.tf input,.tf select,.tf textarea{background:#fafafa;border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:.87rem;outline:none;padding:9px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.tf input:focus,.tf select:focus,.tf textarea:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #b453091a}.tf textarea{min-height:68px;resize:vertical}.btn-tf{align-items:flex-end;display:flex}.btn-primary{align-items:center;background:var(--primary-dark);border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;font-size:.87rem;font-weight:700;gap:7px;padding:10px 18px;transition:background .2s;white-space:nowrap}.btn-primary:hover{background:#5a2510}.filter-wrap{align-items:center;color:var(--text-2);display:flex;gap:7px}.filter-sel{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:.82rem;outline:none;padding:6px 10px}.filter-sel:focus{border-color:var(--primary)}.data-table{border-collapse:collapse;font-size:.84rem;width:100%}.data-table th{background:#f8fafc;border-bottom:1px solid var(--border);color:var(--text-2);font-size:.72rem;font-weight:700;letter-spacing:.5px;padding:10px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.data-table td{border-bottom:1px solid #f1f5f9;padding:12px 14px;vertical-align:middle}.data-table tr:last-child td{border:none}.data-table tr:hover td{background:#fafafa}.task-title-cell{color:var(--text);font-weight:600}.task-desc-cell{color:var(--text-3);font-size:.75rem;margin-top:2px}.assignee-chip{align-items:center;display:flex;gap:7px}.assignee-chip:first-letter,.assignee-chip>:first-child{align-items:center;background:var(--primary-dark);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.72rem;font-weight:700;height:26px;justify-content:center;width:26px}.date-cell{color:var(--text-2);font-size:.8rem;white-space:nowrap}.badge-high{color:var(--danger)}.badge-done,.badge-low{color:var(--success)}.badge-done{background:#dcfce7}.badge-prog{background:#dbeafe;color:var(--info)}.badge-pend{background:#fef3c7;color:var(--warning)}.badge-admin{background:#fef3c7;color:#92400e}.badge-user{background:#f1f5f9;color:var(--text-2)}.status-sel{border:1.5px solid var(--border);border-radius:20px;cursor:pointer;font-family:inherit;font-size:.75rem;font-weight:600;outline:none;padding:5px 10px}.status-sel.status-pending{background:#fef3c7;border-color:#fde68a;color:#92400e}.status-sel.status-in-progress{background:#dbeafe;border-color:#bfdbfe;color:var(--info)}.status-sel.status-done{background:#dcfce7;border-color:#bbf7d0;color:var(--success)}.icon-btn-del{background:none;border:none;border-radius:6px;color:var(--text-3);cursor:pointer;font-size:1rem;padding:6px;transition:all .15s}.icon-btn-del:hover{background:#fee2e2;color:var(--danger)}.user-cell{gap:9px}.u-avatar,.user-cell{align-items:center;display:flex}.u-avatar{background:var(--primary-dark);border-radius:50%;color:#fff;flex-shrink:0;font-size:.8rem;font-weight:700;height:32px;justify-content:center;width:32px}.code-text{border-radius:4px;font-family:monospace;font-size:.8rem;padding:2px 6px}.code-text,.count-pill{background:#f1f5f9;color:var(--text-2)}.count-pill{border-radius:20px;font-size:.78rem;font-weight:600;padding:2px 10px}.add-user-bar{grid-gap:12px;align-items:flex-end;background:#f8fafc;border:1px solid var(--border);border-radius:var(--radius);display:grid;gap:12px;grid-template-columns:1fr 1fr 1fr 1fr auto;margin-bottom:18px;padding:14px}.empty-state{align-items:center;color:var(--text-3);display:flex;flex-direction:column;font-size:.88rem;gap:10px;padding:40px}.empty-state svg{font-size:2.5rem}.toast-msg{align-items:center;animation:toastIn .3s ease;border-radius:var(--radius);bottom:24px;box-shadow:var(--shadow-lg);display:flex;font-size:.85rem;font-weight:600;gap:8px;padding:12px 18px;position:fixed;right:24px;z-index:9999}.toast-msg.success{background:#1a0a04;border-left:4px solid var(--success);color:#fff}.toast-msg.error{background:#1a0a04;border-left:4px solid var(--danger);color:#fff}@media(max-width:768px){.task-form-grid{grid-template-columns:1fr}.add-user-bar,.stats-grid{grid-template-columns:1fr 1fr}}.ut-wrap{display:flex;flex-direction:column;gap:20px}.ut-header{background:linear-gradient(135deg,var(--primary-dark),#6b2d0e);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);gap:16px;justify-content:space-between;padding:24px}.ut-header,.ut-header-left{align-items:center;display:flex}.ut-header-left{gap:14px}.ut-avatar{align-items:center;background:#fff3;border:2px solid #ffffff4d;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.3rem;font-weight:800;height:52px;justify-content:center;width:52px}.ut-header-left h2{color:#fff;font-size:1.15rem;font-weight:700;margin-bottom:3px}.ut-header-left p{color:#fff9;font-size:.82rem}.ut-stats{display:flex;gap:14px}.ut-stat{align-items:center;background:#ffffff1f;border-radius:10px;display:flex;flex-direction:column;gap:2px;padding:10px 16px;text-align:center}.ut-stat svg{color:#ffffffb3;font-size:1.15rem}.ut-stat span{color:#fff;font-size:1.2rem;font-weight:800;line-height:1}.ut-stat small{color:#ffffff8c;font-size:.68rem;letter-spacing:.4px;text-transform:uppercase}.ut-stat.in-prog svg{color:#93c5fd}.ut-stat.done svg{color:#86efac}.ut-filter-row{display:flex;flex-wrap:wrap;gap:6px}.ut-filter-btn{align-items:center;background:#fff;border:1.5px solid var(--border);border-radius:20px;color:var(--text-2);cursor:pointer;display:flex;font-size:.82rem;font-weight:600;gap:7px;padding:8px 16px;transition:all .15s}.ut-filter-btn:hover{border-color:var(--primary);color:var(--primary)}.ut-filter-btn.active{background:var(--primary-dark);border-color:var(--primary-dark);color:#fff}.utf-count{background:#fff3;border-radius:20px;font-size:.7rem;padding:1px 7px}.ut-filter-btn:not(.active) .utf-count{background:var(--bg);color:var(--text-3)}.task-card-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(290px,1fr))}.task-card{background:#fff;border-radius:var(--radius);border-top:3px solid var(--border);box-shadow:var(--shadow);overflow:hidden;transition:transform .15s,box-shadow .15s}.task-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.task-card.tc-pending{border-top-color:#f59e0b}.task-card.tc-in-progress{border-top-color:#3b82f6}.task-card.tc-done{border-top-color:#22c55e}.tc-top{align-items:flex-start;display:flex;gap:10px;justify-content:space-between;padding:14px 14px 8px}.tc-title{color:var(--text);flex:1 1;font-size:.9rem;font-weight:700;line-height:1.35}.tc-desc{color:var(--text-2);font-size:.78rem;line-height:1.5;padding:0 14px 10px}.tc-meta{display:flex;flex-wrap:wrap;gap:6px;padding:0 14px 12px}.tc-chip{align-items:center;background:var(--bg);border:1px solid var(--border);border-radius:20px;color:var(--text-2);display:flex;font-size:.72rem;gap:4px;padding:3px 9px}.tc-chip svg{font-size:.8rem}.tc-footer{padding:10px 14px 14px}.tc-status-sel{border:1.5px solid var(--border);border-radius:20px;cursor:pointer;font-family:inherit;font-size:.8rem;font-weight:600;outline:none;padding:7px 12px;width:100%}.s-pending{background:#fef3c7;border-color:#fde68a;color:#92400e}.s-in-progress{background:#dbeafe;border-color:#bfdbfe;color:#1d4ed8}.s-done{background:#dcfce7;border-color:#bbf7d0;color:#15803d}.badge{border-radius:20px;display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.3px;padding:3px 9px;text-transform:uppercase;white-space:nowrap}.badge-high{background:#fee2e2;color:#dc2626}.badge-med{background:#fef3c7;color:#92400e}.badge-low{background:#f0fdf4;color:#16a34a}.ut-empty{align-items:center;color:var(--text-3);display:flex;flex-direction:column;gap:10px;padding:60px 20px}.ut-empty svg{font-size:3rem}.ut-empty p{color:var(--text-2);font-size:.95rem;font-weight:600}.ut-empty small{font-size:.8rem}.toast-small{align-items:center;animation:toastIn .3s ease;background:#1a0a04;border-left:3px solid var(--success);border-radius:8px;bottom:24px;box-shadow:var(--shadow-lg);color:#fff;display:flex;font-size:.83rem;font-weight:500;gap:8px;padding:10px 16px;position:fixed;right:24px;z-index:9999}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.ut-header{align-items:flex-start;flex-direction:column}.ut-stats{width:100%}.task-card-grid{grid-template-columns:1fr}}.report-container{margin:0 auto;max-width:1100px}.action-bar{flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:18px}.action-bar,.page-title{align-items:center;display:flex}.page-title{color:#3f190b;color:var(--primary-dark,#3f190b);font-size:1.2rem;font-weight:700;gap:8px}.action-btns{display:flex;gap:10px}.alert{border-radius:8px;font-size:.9rem;font-weight:500;margin-bottom:16px;padding:12px 18px}.alert-success{background:#dcfce7;border:1px solid #86efac;color:#15803d}.alert-error{background:#fee2e2;border:1px solid #fca5a5;color:#b91c1c}.report-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 12px #00000014;padding:32px 28px}.report-header-title{border-bottom:2px solid #333;color:#1a1a1a;font-size:1.3rem;font-weight:800;letter-spacing:2px;margin-bottom:20px;padding-bottom:12px;text-align:center;text-transform:uppercase}.header-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(4,1fr);margin-bottom:4px}.signature-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(3,1fr);margin-top:4px}.field-group{display:flex;flex-direction:column;gap:4px}.field-label{color:#555;font-size:.72rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.field-input{background:#fafafa;border:1px solid #ccc;border-radius:4px;color:#1a1a1a;font-family:inherit;font-size:.88rem;outline:none;padding:8px 10px;transition:border-color .2s}.field-input:focus{background:#fff;border-color:#666}.section-title{background:#f3f4f6;border-left:3px solid #555;color:#333;font-size:.78rem;font-weight:700;letter-spacing:1px;margin-bottom:8px;padding:7px 12px;text-transform:uppercase}.section-divider{border:none;border-top:1px solid #e5e7eb;margin:16px 0}.tbl-wrapper{margin-bottom:6px}.table-scroll,.tbl-wrapper{overflow-x:auto}.report-table{border-collapse:collapse;font-size:.83rem;width:100%}.tbl-th{background:#374151;color:#fff;font-size:.72rem;font-weight:600;letter-spacing:.4px;padding:8px 9px;text-align:left;white-space:nowrap}.tbl-td{border:1px solid #d1d5db;padding:3px 5px;vertical-align:middle}.report-table tbody tr:nth-child(2n){background:#f9fafb}.report-table tbody tr:hover{background:#f1f5f9}.tbl-input{background:#0000;border:1px solid #0000;border-radius:3px;color:#1a1a1a;font-family:inherit;font-size:.83rem;min-width:60px;outline:none;padding:5px 7px;transition:border-color .15s;width:100%}.tbl-input:focus{background:#fff;border-color:#9ca3af}.dsc-table .tbl-td,.dsc-table .tbl-th,.payment-table .tbl-td,.payment-table .tbl-th{text-align:center;vertical-align:middle}.payment-table .tbl-input{text-align:center}.btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.87rem;font-weight:600;gap:6px;padding:8px 18px;transition:all .15s}.btn-primary{background:#1e3a5f;color:#fff;font-size:.95rem;padding:11px 32px}.btn-primary:hover{background:#2d4e7a}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-outline{background:#0000;border:1.5px solid #374151;color:#374151}.btn-outline:hover{background:#f3f4f6}.btn-ghost{background:#f1f5f9;border:1px solid #cbd5e1;color:#475569}.btn-ghost:hover{background:#e2e8f0}.add-row-btn{align-items:center;background:#f8fafc;border:1.5px dashed #9ca3af;border-radius:5px;color:#4b5563;cursor:pointer;display:inline-flex;font-size:.8rem;font-weight:600;gap:5px;margin-top:6px;padding:6px 16px;transition:all .15s}.add-row-btn:hover{background:#e5e7eb;border-color:#6b7280}.icon-btn{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:1rem;justify-content:center;padding:4px;transition:background .15s}.icon-btn.danger{color:#dc2626}.icon-btn.danger:hover{background:#fee2e2}.submit-bar{display:flex;justify-content:center;margin-top:24px;padding-bottom:16px}@media (max-width:768px){.header-grid,.signature-grid{grid-template-columns:1fr 1fr}.report-card{padding:16px 12px}}@media (max-width:480px){.header-grid,.signature-grid{grid-template-columns:1fr}}@media print{*{color-adjust:exact!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}@page{size:A4 portrait;margin:8mm 10mm 8mm 10mm}.action-bar,.add-row-btn,.icon-btn,.no-print,.submit-bar{display:none!important}body,html{background:#fff!important}.report-container,body,html{margin:0!important;padding:0!important}.report-container{max-width:100%!important}.report-card{background:#fff!important;border:none!important;border-radius:0!important;box-shadow:none!important;margin:0!important;padding:0!important}.report-header-title{background:none!important;border-bottom:2px solid #000!important;color:#000!important;font-size:11pt!important;font-weight:900!important;letter-spacing:2px!important;margin-bottom:8pt!important;padding-bottom:4pt!important;text-transform:uppercase!important}.header-grid{grid-gap:8pt!important;display:grid!important;gap:8pt!important;grid-template-columns:repeat(4,1fr)!important;margin-bottom:4pt!important}.field-group{gap:2pt!important}.field-label{color:#000!important;font-size:6pt!important;font-weight:800!important;letter-spacing:.5px!important;text-transform:uppercase!important}.field-input{background:#0000!important;border:none!important;border-bottom:1px solid #000!important;border-radius:0!important;color:#000!important;font-size:8pt!important;padding:1pt 0 3pt!important}.section-title{background:none!important;border:none!important;border-bottom:1.5px solid #000!important;color:#000!important;font-size:7pt!important;font-weight:900!important;letter-spacing:1px!important;margin-bottom:4pt!important;padding:3pt 0 2pt!important;text-transform:uppercase!important}.section-divider{border:none!important;border-top:.5px solid #bbb!important;margin:5pt 0!important}.table-scroll,.tbl-wrapper{overflow:visible!important}.report-table{border-collapse:collapse!important;font-size:7.5pt!important;width:100%!important}.tbl-th{background:none!important;border:1px solid #000!important;font-size:6.5pt!important;font-weight:900!important;padding:3pt 4pt!important;text-align:center!important;white-space:nowrap!important}.tbl-td,.tbl-th{color:#000!important}.tbl-td{border:.75px solid #888!important;padding:2pt 3pt!important;vertical-align:middle!important}.report-table tbody tr:hover .tbl-td,.report-table tbody tr:nth-child(2n),.report-table tbody tr:nth-child(2n) .tbl-td,.tbl-td{background:#fff!important}.tbl-input{background:#0000!important;border:none!important;color:#000!important;font-size:7.5pt!important;min-width:0!important;min-width:auto!important;padding:0 2pt!important;width:100%!important}select.tbl-input{appearance:none}.signature-grid{grid-gap:12pt!important;display:grid!important;gap:12pt!important;grid-template-columns:repeat(3,1fr)!important;margin-top:6pt!important}.signature-grid .field-input{border-bottom:1px solid #000!important;padding-bottom:10pt!important}.report-table{page-break-inside:auto}.report-table tr{page-break-after:auto;page-break-inside:avoid}.section-divider,.section-title{page-break-after:avoid}}.list-container{margin:0 auto;max-width:1100px}.list-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.list-title{color:var(--primary);font-size:1.3rem;font-weight:700}.list-sub{color:var(--grey);font-size:.83rem;margin-top:3px}.list-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.search-input{border:1.5px solid var(--border);border-radius:8px;font-size:.88rem;outline:none;padding:9px 14px;transition:border-color .2s;width:240px}.search-input:focus{border-color:var(--primary-light)}.btn-new{background:var(--primary);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.88rem;font-weight:600;padding:9px 20px;transition:background .2s;white-space:nowrap}.btn-new:hover{background:var(--primary-light)}.list-loader{align-items:center;color:var(--grey);display:flex;flex-direction:column;gap:16px;justify-content:center;padding:80px 20px}.spinner{animation:spin .7s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top:4px solid var(--primary);height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.empty-state{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 12px #0000000f;padding:80px 20px;text-align:center}.empty-icon{font-size:3rem;margin-bottom:14px}.empty-state h3{color:#374151;font-size:1.15rem;margin-bottom:8px}.empty-state p{color:var(--grey);font-size:.9rem;margin-bottom:20px}.cards-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.report-card-item{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 10px #0000000f;display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .2s,transform .2s}.report-card-item:hover{box-shadow:0 6px 20px #0000001f;transform:translateY(-2px)}.rci-header{align-items:flex-start;background:var(--primary);color:#fff;display:flex;gap:10px;justify-content:space-between;padding:14px 16px}.rci-date{font-size:.78rem;margin-bottom:3px;opacity:.75}.rci-employee{font-size:1rem;font-weight:700}.rci-dept-badge{background:#fff3;border:1px solid #ffffff59;border-radius:20px;color:#fff;font-size:.75rem;font-weight:600;padding:3px 10px;white-space:nowrap}.rci-stats{border-bottom:1px solid #f1f5f9;display:grid;grid-template-columns:repeat(4,1fr)}.stat-box{border-right:1px solid #f1f5f9;padding:12px 8px;text-align:center}.stat-box:last-child{border-right:none}.stat-val{color:var(--primary);font-size:1rem;font-weight:700}.stat-lbl{color:var(--grey);font-size:.68rem;letter-spacing:.4px;margin-top:2px;text-transform:uppercase}.rci-dsc-row{display:flex;flex-wrap:wrap;gap:6px;min-height:40px;padding:10px 14px}.dsc-chip{background:var(--accent);border:1px solid #bfdbfe;border-radius:12px;color:var(--primary);font-size:.75rem;font-weight:600;padding:2px 10px}.rci-footer{align-items:center;background:#f8faff;border-top:1px solid #e2e8f0;display:flex;justify-content:space-between;margin-top:auto;padding:10px 14px}.rci-company{color:var(--grey);font-size:.8rem;font-weight:500}.rci-btns{display:flex;gap:8px}.rci-btn{border:none;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:600;padding:6px 12px;transition:all .2s}.rci-btn.edit{background:#eff6ff;border:1px solid #bfdbfe;color:var(--primary-light)}.rci-btn.edit:hover{background:#dbeafe}.rci-btn.delete{background:#fff1f2;border:1px solid #fecaca;color:var(--danger)}.rci-btn.delete:hover{background:#fee2e2}.rci-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:600px){.cards-grid{grid-template-columns:1fr}.list-header{flex-direction:column}.search-input{width:100%}}.app-shell{background:var(--bg);display:flex;min-height:100vh}.app-main{display:flex;flex:1 1;flex-direction:column;min-width:0;overflow:hidden}.topbar{background:var(--card);border-bottom:1px solid var(--border);box-shadow:var(--shadow);gap:16px;justify-content:space-between;padding:14px 24px;position:sticky;top:0;z-index:100}.topbar,.topbar-left{align-items:center;display:flex}.topbar-left{gap:12px}.topbar-icon{align-items:center;background:var(--primary-light);border-radius:9px;color:var(--primary);display:flex;font-size:1.15rem;height:38px;justify-content:center;width:38px}.topbar-title{color:var(--text);font-size:1rem;font-weight:700;line-height:1.2}.topbar-sub{color:var(--text-3);font-size:.75rem;margin-top:1px}.topbar-right{gap:12px}.topbar-right,.topbar-user{align-items:center;display:flex}.topbar-user{gap:9px}.tu-avatar{align-items:center;background:var(--primary-dark);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.85rem;font-weight:700;height:34px;justify-content:center;width:34px}.tu-name{color:var(--text);font-size:.85rem;font-weight:600}.tu-role{color:var(--text-3);font-size:.72rem}.page-content{flex:1 1;max-width:1280px;overflow-y:auto;padding:24px;width:100%}@media (max-width:768px){.topbar{padding:14px 16px 14px 64px}.topbar-sub{display:none}.page-content{padding:16px}}
/*# sourceMappingURL=main.6e2c6138.css.map*/