*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--navy:#0f1b2d;--navy-light:#1a2d47;--navy-lighter:#243b5c;--gold:#c8a45e;--gold-light:#e8ce8a;--gold-dark:#a6873d;--white:#fff;--gray-50:#f8f9fa;--gray-100:#f1f3f5;--gray-200:#e9ecef;--gray-300:#dee2e6;--gray-400:#ced4da;--gray-500:#adb5bd;--gray-600:#868e96;--gray-700:#495057;--gray-800:#343a40;--gray-900:#212529;--green:#2ecc71;--red:#e74c3c;--blue:#3498db;--sidebar-width:260px;--header-height:64px;--radius:8px;--shadow:0 1px 3px #0000001a;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #0000001f;--transition:.2s ease}html{font-size:15px}body{color:var(--gray-800);background:var(--gray-50);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}table{border-collapse:collapse;width:100%}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--navy);color:var(--white);z-index:100;transition:transform var(--transition);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{border-bottom:1px solid var(--navy-lighter);padding:24px 20px}.sidebar-brand h1{color:var(--gold);letter-spacing:-.02em;font-size:1.25rem;font-weight:700}.sidebar-brand p{color:var(--gray-500);margin-top:2px;font-size:.75rem}.sidebar-nav{flex:1;padding:16px 0;overflow-y:auto}.sidebar-nav a{color:var(--gray-400);transition:all var(--transition);border-left:3px solid #0000;align-items:center;gap:12px;padding:11px 20px;font-size:.9rem;font-weight:500;display:flex}.sidebar-nav a:hover{color:var(--white);background:var(--navy-light)}.sidebar-nav a.active{color:var(--gold);background:var(--navy-light);border-left-color:var(--gold)}.sidebar-nav a .nav-icon{text-align:center;width:20px;font-size:1.1rem}.main-area{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.header{height:var(--header-height);background:var(--white);border-bottom:1px solid var(--gray-200);z-index:50;justify-content:space-between;align-items:center;padding:0 32px;display:flex;position:sticky;top:0}.header-title{color:var(--navy);font-size:1.35rem;font-weight:700}.header-timer{background:var(--gray-50);border-radius:var(--radius);border:1px solid var(--gray-200);align-items:center;gap:12px;padding:8px 16px;display:flex}.header-timer.running{border-color:var(--gold);background:#fef3e2}.timer-display{color:var(--navy);min-width:80px;font-family:JetBrains Mono,monospace;font-size:1.1rem;font-weight:600}.content{flex:1;padding:32px}.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--gray-200)}.card-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.card-header h2{color:var(--navy);font-size:1.05rem;font-weight:600}.card-body{padding:24px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:28px;display:grid}.stat-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--gray-200);border-left:4px solid var(--gold);padding:24px}.stat-card .stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--gray-600);margin-bottom:8px;font-size:.8rem;font-weight:600}.stat-card .stat-value{color:var(--navy);font-size:1.8rem;font-weight:700}.stat-card .stat-sub{color:var(--gray-500);margin-top:4px;font-size:.8rem}.btn{border-radius:var(--radius);transition:all var(--transition);white-space:nowrap;border:none;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--gold);color:var(--navy)}.btn-primary:hover{background:var(--gold-dark)}.btn-secondary{background:var(--navy);color:var(--white)}.btn-secondary:hover{background:var(--navy-light)}.btn-outline{color:var(--navy);border:1px solid var(--gray-300);background:0 0}.btn-outline:hover{background:var(--gray-50);border-color:var(--gray-400)}.btn-danger{background:var(--red);color:var(--white)}.btn-danger:hover{opacity:.9}.btn-success{background:var(--green);color:var(--white)}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn-icon{border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;padding:0;display:inline-flex}.data-table{width:100%}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-600);background:var(--gray-50);border-bottom:2px solid var(--gray-200);padding:12px 16px;font-size:.75rem;font-weight:600}.data-table td{border-bottom:1px solid var(--gray-100);vertical-align:middle;padding:14px 16px;font-size:.9rem}.data-table tr:hover td{background:var(--gray-50)}.data-table .mono{font-family:JetBrains Mono,monospace;font-size:.85rem}.form-group{margin-bottom:20px}.form-group label{color:var(--gray-700);text-transform:uppercase;letter-spacing:.03em;margin-bottom:6px;font-size:.8rem;font-weight:600;display:block}.form-control{border:1px solid var(--gray-300);border-radius:var(--radius);width:100%;color:var(--gray-800);background:var(--white);transition:border-color var(--transition);padding:10px 14px;font-size:.9rem}.form-control:focus{border-color:var(--gold);outline:none;box-shadow:0 0 0 3px #c8a45e26}select.form-control{appearance:auto}textarea.form-control{resize:vertical;min-height:80px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-actions{border-top:1px solid var(--gray-200);gap:12px;margin-top:24px;padding-top:20px;display:flex}.checkbox-label{cursor:pointer;align-items:center;gap:8px;font-size:.9rem;display:flex}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--gold)}.badge{text-transform:uppercase;letter-spacing:.03em;border-radius:20px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-block}.badge-active{color:#1a8a4a;background:#e6f9ed}.badge-closed{background:var(--gray-100);color:var(--gray-600)}.badge-draft{color:#b8860b;background:#fef3e2}.badge-sent{color:#1967d2;background:#e8f0fe}.badge-paid,.badge-billable{color:#1a8a4a;background:#e6f9ed}.badge-void{color:#991b1b;background:#fde8e8}.badge-pending{color:#92400e;background:#fef3e2}.badge-overdue{color:#991b1b;background:#fde8e8}.modal-overlay{z-index:1000;background:#0f1b2d80;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--white);box-shadow:var(--shadow-lg);border-radius:12px;width:90%;max-width:560px;max-height:90vh;animation:.2s slideUp;overflow-y:auto}.modal-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{color:var(--navy);font-size:1.1rem;font-weight:700}.modal-close{color:var(--gray-500);background:0 0;border:none;font-size:1.5rem;line-height:1}.modal-close:hover{color:var(--gray-800)}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--gray-100);justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.empty-state{text-align:center;color:var(--gray-500);padding:60px 20px}.empty-state .empty-icon{margin-bottom:16px;font-size:3rem}.empty-state h3{color:var(--gray-700);margin-bottom:8px}.filter-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.filter-bar select,.filter-bar input{border:1px solid var(--gray-300);border-radius:var(--radius);background:var(--white);padding:8px 12px;font-size:.85rem}.tabs{border-bottom:2px solid var(--gray-200);gap:0;margin-bottom:24px;display:flex}.tab{color:var(--gray-500);transition:all var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-size:.875rem;font-weight:600}.tab:hover{color:var(--gray-700)}.tab.active{color:var(--gold-dark);border-bottom-color:var(--gold)}.invoice-container{background:var(--white);max-width:800px;box-shadow:var(--shadow-lg);border-radius:var(--radius);margin:0 auto;padding:48px}.invoice-header{border-bottom:3px solid var(--navy);justify-content:space-between;margin-bottom:40px;padding-bottom:24px;display:flex}.invoice-firm h1{color:var(--navy);font-size:1.5rem;font-weight:800}.invoice-firm p{color:var(--gray-600);font-size:.85rem;line-height:1.5}.invoice-meta{text-align:right}.invoice-meta h2{color:var(--gold-dark);letter-spacing:-.02em;font-size:2rem;font-weight:800}.invoice-meta p{color:var(--gray-600);font-size:.85rem}.invoice-parties{grid-template-columns:1fr 1fr;gap:40px;margin-bottom:32px;display:grid}.invoice-parties h3{text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);margin-bottom:8px;font-size:.75rem}.invoice-parties p{color:var(--gray-800);font-size:.9rem;line-height:1.6}.invoice-table{margin-bottom:32px}.invoice-table th{background:var(--navy);color:var(--white);text-transform:uppercase;letter-spacing:.05em;padding:12px 16px;font-size:.75rem;font-weight:600}.invoice-table td{border-bottom:1px solid var(--gray-100);padding:12px 16px;font-size:.85rem}.invoice-table .text-right{text-align:right}.invoice-totals{justify-content:flex-end;margin-bottom:40px;display:flex}.invoice-totals table{width:280px}.invoice-totals td{padding:8px 16px;font-size:.9rem}.invoice-totals .total-row td{border-top:2px solid var(--navy);color:var(--navy);font-size:1.1rem;font-weight:700}.invoice-footer{text-align:center;border-top:1px solid var(--gray-200);color:var(--gray-500);padding-top:24px;font-size:.8rem}.report-chart{align-items:flex-end;gap:8px;height:300px;padding:20px 0;display:flex}.chart-bar{background:var(--gold);min-height:4px;transition:background var(--transition);border-radius:4px 4px 0 0;flex:1;position:relative}.chart-bar:hover{background:var(--gold-dark)}.chart-bar .bar-label{color:var(--gray-600);white-space:nowrap;font-size:.7rem;position:absolute;bottom:-24px;left:50%;transform:translate(-50%)}.chart-bar .bar-value{color:var(--navy);font-size:.7rem;font-weight:600;position:absolute;top:-20px;left:50%;transform:translate(-50%)}.mobile-toggle{color:var(--navy);background:0 0;border:none;font-size:1.5rem;display:none}@media (max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-area{margin-left:0}.mobile-toggle{display:block}.content{padding:20px 16px}.form-row{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.invoice-container{padding:24px}.invoice-header{flex-direction:column;gap:16px}.invoice-meta{text-align:left}.invoice-parties{grid-template-columns:1fr;gap:20px}.header{padding:0 16px}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}}@media print{.sidebar,.header,.no-print{display:none!important}.main-area{margin-left:0}.content{padding:0}.invoice-container{box-shadow:none;padding:0}body{background:#fff}}.text-right{text-align:right}.text-center{text-align:center}.text-gold{color:var(--gold-dark)}.text-muted{color:var(--gray-500)}.text-danger{color:#dc2626;font-weight:600}.text-sm{font-size:.8rem}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.flex{display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.gap-2{gap:8px}.gap-3{gap:12px}.link{color:var(--gold-dark);font-weight:500}.link:hover{text-decoration:underline}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header h1{color:var(--navy);font-size:1.5rem;font-weight:700}.detail-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:28px;display:grid}.detail-item label{text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);margin-bottom:4px;font-size:.72rem;font-weight:600;display:block}.detail-item p{color:var(--gray-800);font-size:.95rem}.section-title{color:var(--navy);margin-top:32px;margin-bottom:16px;font-size:1.1rem;font-weight:700}@keyframes growUp{0%{height:0!important}}@media (max-width:768px){.dash-charts-grid{grid-template-columns:1fr}.h-bar-row{grid-template-columns:100px 1fr 50px}.donut-wrap{flex-direction:column;align-items:center}.heatmap-cell{min-height:22px;font-size:.55rem}}.dash-charts-grid{grid-template-columns:1fr 1fr;gap:20px;margin-top:8px;display:grid}.chart-card{animation:.5s both slideUp}.trend-chart{align-items:flex-end;gap:6px;height:200px;padding-bottom:28px;display:flex;position:relative}.trend-col{flex-direction:column;flex:1;align-items:center;height:100%;display:flex}.trend-bar-wrap{flex:1;justify-content:center;align-items:flex-end;width:100%;display:flex}.trend-bar{background:var(--gold-gradient);border-radius:6px 6px 0 0;width:70%;max-width:48px;min-height:4px;animation:.6s both growUp;position:relative}.trend-val{color:var(--navy);white-space:nowrap;font-size:.68rem;font-weight:700;position:absolute;top:-20px;left:50%;transform:translate(-50%)}.trend-label{color:var(--gray-500);white-space:nowrap;margin-top:8px;font-size:.68rem}.h-bar-chart{flex-direction:column;gap:14px;display:flex}.h-bar-row{grid-template-columns:140px 1fr 60px;align-items:center;gap:12px;animation:.4s both slideIn;display:grid}.h-bar-label{color:var(--gray-700);text-overflow:ellipsis;white-space:nowrap;font-size:.8rem;font-weight:600;overflow:hidden}.h-bar-track{background:var(--gray-100);border-radius:6px;height:24px;overflow:hidden}.h-bar-fill{background:var(--gold-gradient);border-radius:6px;min-width:4px;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.h-bar-value{color:var(--navy);text-align:right;font-variant-numeric:tabular-nums;font-size:.78rem;font-weight:700}.donut-wrap{flex-wrap:wrap;align-items:center;gap:24px;display:flex}.donut-chart{border-radius:50%;flex-shrink:0;width:160px;height:160px;position:relative}.donut-chart.donut-sm{width:140px;height:140px}.donut-chart.donut-xs{width:80px;height:80px}.donut-hole{background:var(--white);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:60%;height:60%;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.donut-big{color:var(--navy);font-size:1.4rem;font-weight:800;line-height:1.1}.donut-small{color:var(--gray-500);text-transform:uppercase;letter-spacing:.04em;font-size:.65rem}.donut-legend{flex-direction:column;gap:8px;display:flex}.legend-item{align-items:center;gap:8px;font-size:.78rem;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.legend-label{color:var(--gray-700);flex:1}.legend-val{color:var(--navy);font-variant-numeric:tabular-nums;font-weight:700}.grouped-bar-chart{justify-content:center;align-items:flex-end;gap:24px;height:200px;padding-bottom:28px;display:flex}.grouped-col{flex-direction:column;flex:1;align-items:center;max-width:120px;height:100%;display:flex}.grouped-bars{flex:1;align-items:flex-end;gap:6px;width:100%;display:flex}.grouped-bar{border-radius:5px 5px 0 0;flex:1;min-height:4px;animation:.6s both growUp;position:relative}.grouped-bar.hours-bar{background:var(--gold-gradient)}.grouped-bar.rev-bar{background:var(--navy-lighter)}.gb-val{color:var(--navy);white-space:nowrap;font-size:.62rem;font-weight:700;position:absolute;top:-18px;left:50%;transform:translate(-50%)}.grouped-label{color:var(--gray-500);margin-top:8px;font-size:.78rem;font-weight:600}.grouped-legend{color:var(--gray-600);justify-content:center;gap:20px;margin-top:12px;font-size:.75rem;display:flex}.activity-timeline{flex-direction:column;gap:0;display:flex}.timeline-item{border-bottom:1px solid var(--gray-100);align-items:flex-start;gap:14px;padding:12px 0;animation:.3s both slideIn;display:flex}.timeline-item:last-child{border-bottom:none}.timeline-avatar{background:linear-gradient(135deg,var(--gold),var(--gold-dark));width:34px;height:34px;color:var(--navy);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.78rem;font-weight:800;display:flex}.timeline-content{flex:1;min-width:0}.timeline-desc{color:var(--gray-800);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:500;overflow:hidden}.timeline-meta{color:var(--gray-500);flex-wrap:wrap;gap:4px;margin-top:3px;font-size:.7rem;display:flex}.timeline-sep{color:var(--gray-300)}.timeline-amount{color:var(--gold-dark);white-space:nowrap;flex-shrink:0;font-size:.78rem;font-weight:700}.util-grid{text-align:center;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:20px;display:grid}.util-item{flex-direction:column;align-items:center;gap:8px;display:flex}.util-name{color:var(--navy);font-size:.82rem;font-weight:700}.util-role{color:var(--gray-500);font-size:.68rem}.mini-bar-track{background:var(--gray-100);border-radius:4px;min-width:60px;height:8px;overflow:hidden}.mini-bar-fill{background:var(--gold-gradient);border-radius:4px;min-width:2px;height:100%}.heatmap{flex-direction:column;gap:4px;display:flex}.heatmap-header,.heatmap-row{grid-template-columns:50px repeat(5,1fr);gap:4px;display:grid}.heatmap-day-label{text-align:center;color:var(--gray-500);padding:4px 0;font-size:.68rem;font-weight:600}.heatmap-week-label{color:var(--gray-500);justify-content:flex-end;align-items:center;padding-right:6px;font-size:.65rem;display:flex}.heatmap-cell{aspect-ratio:1.6;color:var(--navy);cursor:default;border-radius:4px;justify-content:center;align-items:center;min-height:28px;font-size:.62rem;font-weight:700;transition:transform .15s;display:flex}.heatmap-cell:hover{transform:scale(1.1)}.heatmap-legend{justify-content:flex-end;align-items:center;gap:4px;margin-top:8px;display:flex}.heatmap-legend-cell{border-radius:3px;width:16px;height:16px}@media (max-width:768px){.dash-charts-grid{grid-template-columns:1fr}.h-bar-row{grid-template-columns:100px 1fr 50px}.donut-wrap{flex-direction:column;align-items:center}.heatmap-cell{min-height:22px;font-size:.55rem}}.stat-card .stat-trend{border-radius:20px;align-items:center;gap:3px;margin-left:6px;padding:2px 7px;font-size:.72rem;font-weight:600;display:inline-flex}.stat-trend.up{background:var(--green-bg);color:var(--green)}.stat-trend.down{background:var(--red-bg);color:var(--red)}.login-page{background:var(--navy);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-container{width:100%;max-width:560px}.login-brand{text-align:center;margin-bottom:32px}.login-brand h1{color:var(--gold);margin-bottom:4px;font-size:2rem}.login-brand p{color:var(--gray-400);font-size:.9rem}.login-title{text-align:center;color:var(--gray-300);margin-bottom:24px;font-size:1rem;font-weight:500}.login-grid{flex-direction:column;gap:10px;display:flex}.login-card{background:var(--navy-light);border:1px solid var(--navy-lighter);border-radius:var(--radius);cursor:pointer;transition:var(--transition);text-align:left;width:100%;font:inherit;color:inherit;align-items:center;gap:16px;padding:16px 20px;display:flex}.login-card:hover{background:var(--navy-lighter);border-color:var(--gold);transform:translateY(-1px)}.login-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:.85rem;font-weight:700;display:flex}.login-info{flex:1}.login-name{color:var(--gray-100);font-size:.95rem;font-weight:600}.login-role{color:var(--gray-400);margin-top:2px;font-size:.8rem}.login-footer{text-align:center;color:var(--gray-500);margin-top:24px;font-size:.75rem}.sidebar-user{border-top:1px solid var(--navy-lighter);justify-content:space-between;align-items:center;margin-top:auto;padding:16px 20px;display:flex}.sidebar-user-info{align-items:center;gap:10px;display:flex}.sidebar-user-avatar{background:var(--gold-dark);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:.7rem;font-weight:700;display:flex}.sidebar-user-name{color:var(--gray-200);font-size:.8rem;font-weight:600}.sidebar-user-role{color:var(--gray-400);font-size:.7rem}.sidebar-logout{color:var(--gray-400);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:1.1rem}.sidebar-logout:hover{background:var(--navy-lighter);color:var(--gray-200)}
