*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;color:#111827;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}.container{margin:0 auto;max-width:1200px;padding:0 20px}.btn{font-weight:500;gap:8px}.btn-primary{background-color:#2563eb}.btn-primary:hover:not(:disabled){background-color:#1d4ed8}.btn-secondary{background-color:#6b7280}.btn-secondary:hover:not(:disabled){background-color:#4b5563}.btn-success{background-color:#10b981}.btn-success:hover:not(:disabled){background-color:#059669}.btn-danger{background-color:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-outline{background-color:initial}.btn-outline:hover:not(:disabled){background-color:#f3f4f6}.input{transition:border-color .2s}.card{box-shadow:0 1px 3px #0000001a;padding:20px}.badge-primary{background-color:#dbeafe;color:#1e40af}.badge-success{background-color:#d1fae5}.badge-warning{background-color:#fef3c7}.badge-danger{background-color:#fee2e2;color:#991b1b}.badge-gray{background-color:#f3f4f6}.spinner{border:3px solid #f3f4f6;height:24px;width:24px}.toast{animation:slideIn .3s ease-out;background:#fff;border-radius:8px;box-shadow:0 10px 25px #0000001a;padding:16px 20px;position:fixed;right:20px;top:20px;z-index:1000}@keyframes slideIn{0%{opacity:0;transform:translateX(400px)}to{opacity:1;transform:translateX(0)}}.toast-success{border-left:4px solid #10b981}.toast-error{border-left:4px solid #ef4444}.toast-info{border-left:4px solid #3b82f6}.toast-warning{border-left:4px solid #f59e0b}.modal-overlay{animation:fadeIn .2s ease-out;background-color:#00000080;z-index:999}.modal{animation:scaleIn .2s ease-out;padding:24px;width:90%}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.form-group .error{color:#ef4444;font-size:12px;margin-top:4px}.table thead{background-color:#f9fafb}.table td,.table th{border-bottom:1px solid #e5e7eb;padding:12px;text-align:left}.table tbody tr:hover{background-color:#f9fafb}@media (max-width:768px){.container{padding:0 16px}.modal{padding:20px;width:95%}}.app-layout{display:flex;height:100vh;overflow:hidden;position:relative}.mobile-menu-toggle{background:#1f2937;border:none;border-radius:8px;box-shadow:0 4px 6px #0000004d;color:#fff;cursor:pointer;display:none;font-size:20px;left:16px;line-height:1;padding:12px 16px;pointer-events:auto;position:fixed;top:16px;transition:all .2s;z-index:1100}.mobile-menu-toggle:hover{background:#374151;box-shadow:0 6px 8px #0006}.mobile-menu-toggle:active{transform:scale(.95)}.sidebar{background-color:#1f2937;color:#fff;display:flex;flex-direction:column;transition:transform .3s ease;width:250px;z-index:1000}.sidebar.closed{width:70px}@media (max-width:768px){.mobile-menu-toggle{display:block}.sidebar{bottom:0;box-shadow:2px 0 8px #0000001a;left:0;position:fixed;top:0;transform:translateX(-100%);width:280px;z-index:1000}.sidebar.open{transform:translateX(0)}.sidebar.closed{transform:translateX(-100%);width:280px}.sidebar-overlay{background:#00000080;bottom:0;display:none;left:280px;position:fixed;right:0;top:0;transition:left .3s ease;z-index:999}.sidebar-overlay.active{display:block;left:280px}}.sidebar-header{border-bottom:1px solid #374151;padding:20px;text-align:center}.sidebar-header .logo{height:auto;max-height:50px;max-width:100%}.sidebar-header h2{font-size:20px;margin:0}.sidebar-nav{flex:1 1;overflow-y:auto;padding:20px 0}.nav-item{align-items:center;border-left:3px solid #0000;color:#d1d5db;display:flex;gap:12px;padding:12px 20px;text-decoration:none;transition:all .2s}.nav-item.active,.nav-item:hover{background-color:#374151;border-left-color:#2563eb;border-left-color:var(--hover-color,#2563eb);color:#fff}.nav-icon{font-size:20px;min-width:20px;text-align:center}.sidebar.closed .nav-label{display:none}.sidebar-footer{border-top:1px solid #374151;gap:8px;padding:16px}.sidebar-footer,.user-button{align-items:center;display:flex}.user-button{background:#0000;border:none;border-radius:6px;color:#fff;cursor:pointer;flex:1 1;gap:10px;padding:8px;transition:background-color .2s}.user-button:hover{background-color:#374151}.user-avatar{align-items:center;background-color:#2563eb;display:flex;flex-shrink:0;font-size:14px;font-weight:700;justify-content:center}.user-avatar,.user-avatar-img{border-radius:50%;height:36px;width:36px}.user-avatar-img{background:none;object-fit:cover}.user-avatar-initials{background-color:#2563eb}.sidebar.closed .user-info{display:none}.user-info{flex:1 1;text-align:left}.user-name{font-size:14px;font-weight:500}.user-role{color:#9ca3af;font-size:12px;text-transform:capitalize}.logout-button{background:#0000;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:18px;height:36px;transition:background-color .2s;width:36px}.logout-button:hover{background-color:#ef4444}.main-content{display:flex;flex:1 1;flex-direction:column;overflow:hidden}@media (max-width:768px){.main-content{margin-left:0}.top-bar{padding-left:60px}}.top-bar{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;display:flex;height:60px;justify-content:space-between;padding:0 20px}@media (max-width:480px){.top-bar{flex-wrap:wrap;height:auto;min-height:60px;padding:12px 16px}}.sidebar-toggle{background:#0000;border:none;border-radius:6px;cursor:pointer;font-size:20px;padding:8px;transition:background-color .2s}@media (max-width:768px){.sidebar-toggle{display:none}}.sidebar-toggle:hover{background-color:#f3f4f6}.top-bar-right{align-items:center;display:flex;gap:16px}@media (max-width:480px){.top-bar-right{gap:8px}}.content-area{background-color:#f9fafb;flex:1 1;overflow-y:auto;padding:24px}.loading-screen{align-items:center;display:flex;flex-direction:column;gap:20px;height:100vh;justify-content:center}.loading-screen p{color:#6b7280;font-size:14px}@media (max-width:768px){.sidebar{height:100vh;left:0;position:fixed;top:0;transform:translateX(0);z-index:100}.sidebar.closed{transform:translateX(-100%);width:250px}.content-area{padding:16px}}.page-header h1{color:#111827;font-weight:600;margin-bottom:8px}.page-header p{font-size:14px}.cards-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:24px}.stat-card{box-shadow:0 1px 3px #0000001a;padding:20px}.stat-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.stat-card-title{color:#6b7280;font-size:14px;font-weight:500}.stat-card-icon{font-size:20px}.stat-card-value{color:#111827;font-size:32px;font-weight:700;margin-bottom:4px}.stat-card-change{color:#6b7280;font-size:12px}.stat-card-change.positive{color:#10b981}.stat-card-change.negative{color:#ef4444}.empty-state h3{color:#374151;font-size:18px}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.alert{border-radius:6px;padding:12px 16px}.alert-info{background-color:#dbeafe;border-left:4px solid #3b82f6;color:#1e40af}.alert-success{background-color:#d1fae5;border-left:4px solid #10b981;color:#065f46}.alert-warning{background-color:#fef3c7;border-left:4px solid #f59e0b;color:#92400e}.alert-error{background-color:#fee2e2;border-left:4px solid #ef4444}.tabs{border-bottom:1px solid #e5e7eb;margin-bottom:24px}.tab-list{display:flex;gap:8px}.tab{background:#0000;font-size:14px;padding:12px 20px}.skeleton{animation:loading 1.5s ease-in-out infinite;background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb 50%,#f3f4f6 75%);background-size:200% 100%;border-radius:4px}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:16px;margin-bottom:8px}.skeleton-title{height:24px;margin-bottom:16px;width:60%}.skeleton-card{height:120px}.nav-badge{background:#ef4444;border-radius:10px;color:#fff;font-size:11px;font-weight:700;min-width:18px;padding:2px 6px;position:absolute;right:8px;text-align:center;top:8px}.sidebar.collapsed .nav-badge{right:4px;top:4px}.notif-bell-btn,.notif-bell-container{position:relative}.notif-bell-btn{background:none;border:none;border-radius:8px;cursor:pointer;font-size:22px;padding:6px 10px;transition:background .15s}.notif-bell-btn:hover{background:#f3f4f6}.notif-badge{background:#ef4444;border:2px solid #fff;border-radius:10px;color:#fff;font-size:10px;font-weight:700;line-height:16px;min-width:16px;padding:1px 5px;position:absolute;right:2px;text-align:center;top:0}.notif-overlay{bottom:0;left:0;position:fixed;right:0;top:0;z-index:998}.notif-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 40px #00000026;margin-top:6px;max-height:440px;overflow:hidden;position:absolute;right:0;top:100%;width:340px;z-index:999}.notif-dropdown-header{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;font-size:14px;font-weight:600;justify-content:space-between;padding:14px 16px}.notif-mark-all{background:none;border:none;color:#2563eb;cursor:pointer;font-size:12px;font-weight:500}.notif-mark-all:hover{text-decoration:underline}.notif-empty{color:#9ca3af;font-size:14px;padding:30px 16px;text-align:center}.notif-list{max-height:300px;overflow-y:auto}.notif-item{border-bottom:1px solid #f9fafb;cursor:pointer;padding:12px 16px;transition:background .1s}.notif-item:hover{background:#f9fafb}.notif-item-title{color:#111827;font-size:13px;font-weight:600;margin-bottom:2px}.notif-item-msg{color:#6b7280;font-size:12px;line-height:1.4}.notif-item-time{color:#9ca3af;font-size:11px;margin-top:4px}.notif-dropdown-footer{border-top:1px solid #f3f4f6;padding:10px 16px;text-align:center}.notif-dropdown-footer button{background:none;border:none;color:#2563eb;cursor:pointer;font-size:13px;font-weight:500}.notif-dropdown-footer button:hover{text-decoration:underline}@media (max-width:640px){.notif-dropdown{right:-60px;width:300px}}.auth-container{align-items:center;background:linear-gradient(135deg,#1e3a8a,#2563eb 50%,#3b82f6);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-card{background:#fff;border-radius:16px;box-shadow:0 25px 80px #0000004d;max-width:420px;padding:40px;position:relative;width:100%}.auth-card.role-selection{max-width:480px}.auth-header{margin-bottom:24px;text-align:center}.auth-header h1{font-size:28px;margin:0}.auth-subtitle{color:#6b7280;font-size:16px;margin:8px 0 0}.auth-logo{margin-bottom:8px;max-height:60px;max-width:200px}.auth-logo-small{max-height:40px;max-width:150px}.role-options{margin-top:24px}.role-options h2{color:#374151;font-size:18px;font-weight:500;margin:0 0 20px;text-align:center}.role-card{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;display:flex;gap:16px;margin-bottom:12px;padding:20px;text-align:left;transition:all .2s ease;width:100%}.role-card:hover{background:#f8fafc;transform:translateX(4px)}.role-card:active{transform:translateX(2px)}.role-card.admin-card:hover{background:#eff6ff;border-color:#2563eb}.role-card.worker-card:hover{background:#ecfdf5;border-color:#10b981}.role-icon{flex-shrink:0;font-size:36px}.role-info{flex:1 1}.role-info h3{color:#111827;font-size:17px;font-weight:600;margin:0 0 4px}.role-info p{color:#6b7280;font-size:13px;margin:0}.role-arrow{color:#9ca3af;font-size:20px;transition:transform .2s}.role-card:hover .role-arrow{color:#2563eb;transform:translateX(4px)}.auth-footer-info{border-top:1px solid #e5e7eb;margin-top:24px;padding-top:24px;text-align:center}.auth-footer-info p{color:#6b7280;font-size:14px;margin:0}.auth-footer-info a{color:#2563eb;font-weight:500}.back-button{background:none;border:none;border-radius:6px;color:#6b7280;cursor:pointer;font-size:14px;left:16px;padding:8px 12px;position:absolute;top:16px;transition:all .2s}.back-button:hover{background:#f3f4f6;color:#111827}.auth-form{display:flex;flex-direction:column;gap:20px}.login-role-badge{border-radius:8px;font-size:14px;font-weight:500;padding:10px 16px;text-align:center}.auth-form .form-group{display:flex;flex-direction:column;gap:6px}.auth-form label{color:#374151;font-size:14px;font-weight:500}.auth-form .input{border:1px solid #d1d5db;border-radius:8px;font-size:15px;padding:12px 14px;transition:border-color .2s,box-shadow .2s}.auth-form .input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.auth-form .input::placeholder{color:#9ca3af}.password-input-wrapper .input{width:100%}.password-toggle{background:none;border:none;cursor:pointer;font-size:18px;opacity:.6;padding:4px;position:absolute;right:12px;transition:opacity .2s}.password-toggle:hover{opacity:1}.btn-login{align-items:center;border-radius:8px;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:14px 24px}.spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-top-color:#fff;height:18px;width:18px}.admin-help{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;text-align:center}.admin-help p{color:#6b7280;font-size:13px;margin:0 0 8px}.admin-help code{background:#e5e7eb;border-radius:6px;color:#374151;display:block;font-size:13px;padding:8px 12px}.admin-help .help-note{color:#9ca3af;font-size:12px;margin:12px 0 0}.auth-footer{color:#6b7280;font-size:14px;margin-top:8px;text-align:center}.auth-footer a{color:#2563eb;font-weight:500}.password-requirements{color:#6b7280;font-size:12px;margin-bottom:8px;margin-top:-12px}.auth-form .alert{align-items:center;border-radius:8px;display:flex;font-size:14px;gap:8px;padding:12px 16px}.auth-form .alert-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}@media (max-width:480px){.auth-card{margin:16px;padding:24px}.auth-header h1{font-size:24px}.role-card{padding:16px}.role-icon{font-size:28px}}.dashboard-v2{max-width:1200px}.dash-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:80px 20px}.dash-actions{display:flex;gap:8px}.dash-alert{align-items:center;border-radius:10px;display:flex;gap:10px;margin-top:16px}.active-timer-banner{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #93c5fd;border-radius:12px;gap:16px;margin-bottom:20px;padding:14px 20px}.active-timer-banner,.atb-left{align-items:center;display:flex}.atb-left{flex:1 1;gap:12px}.atb-pulse{animation:pulse-glow 2s ease-in-out infinite;background:#22c55e;border-radius:50%;flex-shrink:0;height:12px;width:12px}@keyframes pulse-glow{0%,to{box-shadow:0 0 0 0 #22c55e66}50%{box-shadow:0 0 0 8px #22c55e00}}.atb-label{color:#6b7280;font-size:12px;font-weight:500}.atb-job{color:#1e40af;font-size:15px;font-weight:600}.atb-time{color:#1e40af;font-family:Menlo,Monaco,Courier New,monospace;font-size:24px;font-weight:700}.stats-grid{grid-gap:16px;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}.stat-card-v2{align-items:flex-start;background:#fff;border:1px solid #f3f4f6;border-radius:12px;box-shadow:0 1px 3px #0000000f;display:flex;gap:14px;padding:20px;transition:transform .15s,box-shadow .15s}.stat-card-v2:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.sc-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;font-size:20px;height:44px;justify-content:center;width:44px}.sc-icon-blue{background:#eff6ff}.sc-icon-purple{background:#f5f3ff}.sc-icon-green{background:#f0fdf4}.sc-icon-orange{background:#fff7ed}.sc-content{min-width:0}.sc-label{color:#6b7280;font-size:12px;font-weight:500;margin-bottom:2px}.sc-value{color:#111827;font-size:26px;font-weight:700;line-height:1.2}.sc-change{color:#6b7280;font-size:11px;margin-top:2px}.sc-change.up{color:#16a34a}.sc-change.down{color:#dc2626}.dash-grid-2col{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:20px}.card-header-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.card-header-row h3{font-size:16px;font-weight:600;margin:0}.card-subtitle{color:#6b7280;font-size:13px;font-weight:500}.dash-chart-card{padding:20px}.bar-chart{align-items:flex-end;gap:8px;height:180px;margin-bottom:12px}.bar-col{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:4px;height:100%}.bar-col.today .bar-label{color:#2563eb;font-weight:700}.bar-value{color:#374151;font-size:11px;font-weight:600;height:16px}.bar-track{background:#f9fafb;display:flex;flex:1 1;flex-direction:column;justify-content:flex-end}.bar-fill,.bar-track{border-radius:6px;width:100%}.bar-fill{background:linear-gradient(180deg,#60a5fa,#3b82f6);min-height:2px;transition:height .5s ease}.bar-fill.bar-today{background:linear-gradient(180deg,#818cf8,#6366f1)}.bar-fill.bar-empty{background:#e5e7eb}.bar-label{color:#6b7280;font-size:12px;font-weight:500}.last-week-row{align-items:center;border-top:1px solid #f3f4f6;display:flex;gap:10px;margin-top:8px;padding-top:12px}.lw-label{color:#9ca3af;font-size:12px;white-space:nowrap}.lw-bar-track{background:#f3f4f6;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.lw-bar-fill{background:#d1d5db;border-radius:4px;height:100%;transition:width .5s}.lw-value{color:#6b7280;font-size:12px;font-weight:600}.dash-topjobs-card{padding:20px}.top-jobs-list{display:flex;flex-direction:column;gap:2px}.top-job-row{align-items:center;border-radius:8px;display:flex;gap:12px;padding:10px 8px;transition:background .15s}.top-job-row:hover{background:#f9fafb}.tj-rank{align-items:center;background:#f3f4f6;border-radius:50%;color:#6b7280;display:flex;flex-shrink:0;font-size:13px;font-weight:700;height:28px;justify-content:center;width:28px}.top-job-row:first-child .tj-rank{background:#fef3c7;color:#d97706}.tj-info{flex:1 1;min-width:0}.tj-title{color:#111827;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tj-worker{color:#6b7280;font-size:12px}.tj-stats{flex-shrink:0;text-align:right}.tj-hours{color:#111827;font-size:15px;font-weight:700}.tj-sessions{color:#9ca3af;font-size:11px}.dash-workers-card{padding:20px}.worker-status-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-bottom:16px}.ws-badge{border-radius:10px;padding:14px;text-align:center}.ws-clocked-in{background:#d1fae5}.ws-clocked-out{background:#f3f4f6}.ws-count{font-size:26px;font-weight:700}.ws-clocked-in .ws-count{color:#065f46}.ws-clocked-out .ws-count{color:#6b7280}.ws-label{font-size:12px;margin-top:2px}.ws-clocked-in .ws-label{color:#065f46}.ws-clocked-out .ws-label{color:#6b7280}.worker-list{display:flex;flex-direction:column;gap:4px}.worker-row{align-items:center;border-radius:8px;display:flex;gap:10px;padding:8px}.worker-row:hover{background:#f9fafb}.worker-avatar{font-size:13px;height:32px;width:32px}.worker-details{flex:1 1;min-width:0}.worker-name{font-size:13px;font-weight:500}.worker-job{color:#6b7280;font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.worker-elapsed{color:#6b7280;flex-shrink:0;font-size:13px;font-weight:600}.worker-more{color:#2563eb;cursor:pointer;font-size:13px;padding:8px;text-align:center}.dash-quick-card{padding:20px}.quick-actions-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.qa-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;color:#374151;cursor:pointer;display:flex;flex-direction:column;font-size:13px;font-weight:500;gap:8px;padding:20px 12px;transition:all .15s}.qa-btn:hover{background:#f9fafb;border-color:#d1d5db;transform:translateY(-1px)}.qa-icon{font-size:24px}.dash-activity-card{padding:20px}.activity-feed{display:flex;flex-direction:column;gap:2px;max-height:340px;overflow-y:auto}.af-row{border-radius:6px;display:flex;gap:10px;padding:8px 4px;transition:background .15s}.af-row:hover{background:#f9fafb}.af-icon{flex-shrink:0;font-size:16px;margin-top:1px;text-align:center;width:24px}.af-content{flex:1 1;min-width:0}.af-text{color:#374151;font-size:13px;line-height:1.4}.af-user{font-weight:600}.af-time{color:#9ca3af;font-size:11px;margin-top:2px}.empty-state-sm{color:#9ca3af;padding:30px 20px;text-align:center}.empty-state-sm p{font-size:14px;margin:0}@media (max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.dash-grid-2col{grid-template-columns:1fr}}@media (max-width:640px){.stats-grid{gap:10px;grid-template-columns:1fr 1fr}.stat-card-v2{padding:14px}.sc-value{font-size:22px}.sc-icon{font-size:16px;height:36px;width:36px}.active-timer-banner{flex-wrap:wrap;gap:10px;padding:12px 14px}.atb-time{font-size:20px}.bar-chart{height:140px}.bar-value{font-size:10px}}.gps-location{align-items:center;display:inline-flex;font-size:13px;gap:6px}.gps-label{color:#6b7280;font-weight:500}.gps-icon{font-size:14px}.gps-link{color:#2563eb;font-family:Courier New,monospace;text-decoration:none;transition:color .2s}.gps-link:hover{color:#1d4ed8;text-decoration:underline}@media (max-width:768px){.gps-location{font-size:12px}.gps-link{word-break:break-all}}.active-timer-badge{align-items:center;animation:pulse 2s ease-in-out infinite;background:linear-gradient(135deg,#10b981,#059669);border-radius:12px;box-shadow:0 2px 4px #10b9814d;color:#fff;display:inline-flex;font-size:13px;font-weight:600;gap:6px;padding:4px 12px}.timer-icon{font-size:14px}.timer-time{font-family:Courier New,monospace;letter-spacing:.5px}.timer-worker{font-size:12px;font-weight:500;opacity:.9}@keyframes pulse{0%,to{box-shadow:0 2px 4px #10b9814d}50%{box-shadow:0 2px 8px #10b98180}}@media (max-width:768px){.active-timer-badge{font-size:11px;padding:3px 8px}.timer-worker{display:none}}.subtasks-list{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-top:20px;padding:20px}.subtasks-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.subtasks-header h3{color:#111827;font-size:16px;font-weight:600;margin:0 0 8px}.subtasks-actions{display:flex;flex-wrap:wrap;gap:8px}.subtasks-progress{margin-top:8px}.progress-bar{background:#e5e7eb;border-radius:4px;height:8px;margin-bottom:4px;overflow:hidden;width:200px}.progress-fill{background:linear-gradient(90deg,#10b981,#059669);height:100%;transition:width .3s ease}.progress-text{color:#6b7280;font-size:12px;font-weight:500}.subtask-form{background:#fff;border:1px solid #e5e7eb;border-radius:6px;margin-bottom:16px;padding:16px}.subtask-form .form-group{margin-bottom:12px}.subtask-form .form-group:last-of-type{margin-bottom:0}.subtask-form .form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}.subtasks-empty{color:#6b7280;padding:32px 16px;text-align:center}.subtasks-empty p{margin:0 0 12px}.subtasks-items{display:flex;flex-direction:column;gap:8px}.subtask-item{align-items:flex-start;background:#fff;border:1px solid #e5e7eb;border-radius:6px;display:flex;gap:12px;padding:12px;transition:all .2s}.subtask-item:hover{border-color:#d1d5db;box-shadow:0 1px 3px #0000000d}.subtask-item.completed{background:#f0fdf4;border-color:#86efac}.subtask-checkbox{align-items:flex-start;cursor:pointer;display:flex;flex:1 1;gap:12px;margin:0}.subtask-checkbox input[type=checkbox]{cursor:pointer;flex-shrink:0;height:18px;margin-top:2px;width:18px}.subtask-content{flex:1 1}.subtask-title{color:#111827;font-size:14px;font-weight:500;margin-bottom:4px}.subtask-item.completed .subtask-title{color:#6b7280;text-decoration:line-through}.subtask-description{color:#6b7280;font-size:13px;margin-top:4px}.subtask-meta{color:#059669;font-size:12px;font-weight:500;margin-top:6px}.btn-icon-delete{background:none;border:none;cursor:pointer;flex-shrink:0;font-size:16px;opacity:.5;padding:4px;transition:opacity .2s}.btn-icon-delete:hover{opacity:1}.loading-small{color:#6b7280;font-size:14px;padding:20px;text-align:center}@media (max-width:768px){.subtasks-list{padding:16px}.subtasks-header{flex-direction:column;gap:12px}.subtasks-actions{width:100%}.subtasks-actions .btn{flex:1 1}.progress-bar{width:100%}.subtask-item{padding:10px}.subtask-title{font-size:13px}.subtask-description{font-size:12px}}.move-subtasks-list{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;max-height:200px;overflow-y:auto;padding:8px}.move-subtask-item{align-items:center;border-radius:4px;cursor:pointer;display:flex;gap:10px;padding:8px 10px;transition:background .2s}.move-subtask-item:hover{background:#e5e7eb}.move-subtask-item input[type=checkbox]{cursor:pointer;height:16px;width:16px}.move-subtask-item span{color:#374151;font-size:14px}.job-media{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;margin-top:20px;padding:20px}.media-header{flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px}.media-header,.media-title{align-items:center;display:flex}.media-title{gap:8px}.media-title h4{color:#111827;font-size:16px;font-weight:600;margin:0}.media-count{background:#e5e7eb;border-radius:12px;color:#374151;font-size:13px;font-weight:600;padding:2px 10px}.media-controls{align-items:center;display:flex;gap:8px}.view-toggle{background:#e5e7eb;display:flex;padding:2px}.toggle-btn{background:#0000;border:none;border-radius:4px;cursor:pointer;font-size:14px;padding:6px 10px;transition:all .2s}.toggle-btn.active{background:#fff;box-shadow:0 1px 3px #0000001a}.media-filter,.media-sort{background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;font-size:13px;padding:6px 10px}.media-upload-section{margin-bottom:20px}.upload-area{position:relative}.upload-trigger{align-items:center;border-radius:10px;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:16px 24px;width:100%}.upload-menu{animation:slideDown .2s ease;background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;left:0;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:100}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.upload-option{align-items:center;background:none;border:none;cursor:pointer;display:flex;gap:16px;padding:16px 20px;text-align:left;transition:background .2s;width:100%}.upload-option:hover{background:#f3f4f6}.upload-option:active{background:#e5e7eb}.upload-option:not(:last-child){border-bottom:1px solid #f3f4f6}.option-icon{align-items:center;background:#f3f4f6;border-radius:12px;display:flex;font-size:28px;height:48px;justify-content:center;width:48px}.option-text{display:flex;flex-direction:column}.option-text strong{color:#111827;font-size:15px}.option-text small{color:#6b7280;font-size:13px;margin-top:2px}.upload-progress{margin-top:16px}.upload-progress .progress-bar{background:#e5e7eb;border-radius:4px;height:8px;overflow:hidden}.upload-progress .progress-fill{background:linear-gradient(90deg,#2563eb,#10b981);height:100%;transition:width .3s ease}.upload-progress .progress-text{color:#6b7280;display:block;font-size:13px;margin-top:8px;text-align:center}.selected-files{background:#fff;border:1px solid #e5e7eb;border-radius:10px;margin-top:16px;overflow:hidden}.selected-files-header{align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:12px 16px}.selected-files-header span{color:#374151;font-size:14px;font-weight:500}.selected-files-actions{display:flex;gap:8px}.selected-files-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));padding:16px}.selected-files-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto;padding:12px}.selected-file-row{align-items:flex-start;background:#f9fafb;border-radius:8px;display:flex;gap:12px;padding:12px;position:relative}.selected-file-preview{border-radius:8px;flex-shrink:0;height:80px;overflow:hidden;width:80px}.selected-file-preview img{height:100%;object-fit:cover;width:100%}.file-icon-preview{align-items:center;background:#e5e7eb;display:flex;font-size:32px;height:100%;justify-content:center;width:100%}.selected-file-details{flex:1 1;min-width:0}.caption-input{border:1px solid #e5e7eb;border-radius:6px;font-size:14px;margin-top:8px;padding:8px 12px;transition:border-color .2s;width:100%}.caption-input:focus{border-color:#2563eb;outline:none}.caption-input::placeholder{color:#9ca3af}.selected-file-item{background:#f9fafb;border-radius:8px;overflow:hidden;position:relative}.selected-file-item img{height:80px;object-fit:cover;width:100%}.selected-file-item .file-icon-large{align-items:center;display:flex;font-size:32px;height:80px;justify-content:center}.selected-file-info{padding:8px}.selected-file-name{color:#374151;font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.selected-file-size{color:#9ca3af;font-size:10px}.remove-file-btn{align-items:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:12px;height:24px;justify-content:center;position:absolute;right:4px;top:4px;width:24px}.media-loading{align-items:center;color:#6b7280;display:flex;flex-direction:column;gap:12px;padding:40px}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#2563eb;height:32px;width:32px}.media-empty{padding:48px 20px;text-align:center}.media-empty .empty-icon{font-size:48px;opacity:.5}.media-empty p{color:#374151;font-size:16px;margin:12px 0 4px}.media-empty small{color:#9ca3af}.media-display.grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.media-display.grid .media-item{background:#fff;border-radius:10px;box-shadow:0 1px 3px #0000001a;overflow:hidden;transition:transform .2s,box-shadow .2s}.media-display.grid .media-item:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.media-display.grid .media-thumbnail{cursor:pointer;height:140px;position:relative}.media-display.grid .media-thumbnail img{height:100%;object-fit:cover;width:100%}.media-display.grid .media-file-link{display:block;height:140px}.media-display.grid .file-icon-large{background:#f9fafb;font-size:48px;height:100%}.media-display.grid .file-icon-large,.media-overlay{align-items:center;display:flex;justify-content:center}.media-overlay{background:#0006;inset:0;opacity:0;position:absolute;transition:opacity .2s}.media-thumbnail:hover .media-overlay{opacity:1}.media-overlay span{font-size:28px}.media-info{padding:12px}.media-name{color:#111827;font-size:13px;font-weight:500;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.media-caption{color:#6b7280;cursor:pointer;font-size:12px;padding:4px 0}.media-caption .no-caption{color:#9ca3af;font-style:italic}.media-caption:hover{color:#2563eb}.caption-edit{display:flex;gap:4px}.caption-edit input{border:1px solid #e5e7eb;border-radius:4px;flex:1 1;font-size:12px;padding:4px 8px}.caption-edit button{background:#e5e7eb;border:none;border-radius:4px;cursor:pointer;padding:4px 8px}.media-meta{align-items:center;color:#9ca3af;display:flex;flex-wrap:wrap;font-size:11px;gap:4px;margin-top:8px}.meta-separator{color:#d1d5db}.media-actions{border-top:1px solid #f3f4f6;display:flex;gap:4px;justify-content:flex-end;padding:8px 12px}.media-action-btn{background:none;border:none;border-radius:6px;cursor:pointer;font-size:16px;padding:6px 10px;text-decoration:none;transition:background .2s}.media-action-btn:hover{background:#f3f4f6}.media-action-btn.delete:hover{background:#fee2e2}.media-display.list{display:flex;flex-direction:column;gap:8px}.media-display.list .media-item{align-items:center;background:#fff;border-radius:10px;box-shadow:0 1px 3px #0000000d;display:flex;gap:16px;padding:12px}.media-display.list .media-thumbnail{border-radius:8px;cursor:pointer;flex-shrink:0;height:60px;overflow:hidden;width:60px}.media-display.list .media-thumbnail img{height:100%;object-fit:cover;width:100%}.media-display.list .media-file-link{flex-shrink:0;height:60px;width:60px}.media-display.list .file-icon-large{align-items:center;background:#f9fafb;border-radius:8px;display:flex;font-size:28px;height:60px;justify-content:center;width:60px}.media-display.list .media-info{flex:1 1;min-width:0;padding:0}.media-display.list .media-actions{border:none;padding:0}.lightbox{animation:fadeIn .2s ease;z-index:9999}.lightbox-content{align-items:center;display:flex;flex-direction:column;max-height:95vh;max-width:95vw}.lightbox-content img{border-radius:8px;max-height:80vh}.lightbox-close{background:#fff3;border-radius:50%;font-size:20px;height:36px;top:-40px;transition:background .2s;width:36px}.lightbox-close:hover{background:#ffffff4d}.lightbox-nav{background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:20px;height:48px;position:absolute;top:50%;transform:translateY(-50%);transition:background .2s;width:48px}.lightbox-nav:hover{background:#ffffff4d}.lightbox-nav.prev{left:20px}.lightbox-nav.next{right:20px}.lightbox-filename{font-size:14px;opacity:.9}.lightbox-caption{font-size:16px;margin-top:8px}.lightbox-counter{font-size:13px;margin-top:8px;opacity:.7}@media (max-width:768px){.job-media{border-radius:0;margin:16px -16px;padding:16px}.media-header{align-items:flex-start;flex-direction:column}.media-controls{justify-content:space-between;width:100%}.media-filter,.media-sort{flex:1 1;min-width:0}.media-display.grid{gap:12px;grid-template-columns:repeat(2,1fr)}.media-display.grid .media-file-link,.media-display.grid .media-thumbnail{height:120px}.lightbox-nav{height:40px;width:40px}.lightbox-nav.prev{left:10px}.lightbox-nav.next{right:10px}}@media (max-width:480px){.selected-files-header{align-items:stretch;flex-direction:column;gap:12px}.selected-files-actions{justify-content:stretch}.selected-files-actions .btn{flex:1 1}}.job-notes{border-top:1px solid #e5e7eb;margin-top:24px;padding-top:24px}.notes-header{margin-bottom:16px}.notes-header h4{color:#374151;font-size:16px;font-weight:600;margin:0}.add-note-form{margin-bottom:20px}.add-note-form .input{min-height:60px;resize:vertical}.add-note-form .form-actions{align-items:center;display:flex;justify-content:space-between;margin-top:8px}.error-text{color:#dc2626;font-size:13px}.notes-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto}.note-item{background:#f9fafb;border-left:3px solid #d1d5db;border-radius:8px;padding:12px 16px;transition:all .2s}.note-item:hover{border-left-color:#2563eb}.note-header{justify-content:space-between;margin-bottom:8px}.note-author,.note-header{align-items:center;display:flex}.note-author{gap:8px}.author-name{color:#111827;font-size:14px;font-weight:600}.author-badge{border-radius:12px;font-size:10px;font-weight:600;padding:2px 8px;text-transform:uppercase}.badge-admin{background:#fef3c7;color:#92400e}.badge-manager{background:#dbeafe;color:#1e40af}.badge-worker{background:#e5e7eb;color:#374151}.note-date{color:#9ca3af;font-size:12px}.note-content{color:#4b5563;font-size:14px;line-height:1.6;white-space:pre-wrap;word-break:break-word}.note-actions{display:flex;gap:8px;margin-top:8px;opacity:0;transition:opacity .2s}.note-item:hover .note-actions{opacity:1}.note-actions .action-btn{background:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;padding:4px 8px;transition:all .2s}.note-actions .action-btn:hover{background:#e5e7eb}.note-actions .action-btn.delete:hover{background:#fee2e2}.note-edit{margin-top:8px}.note-edit .input{font-size:14px}.edit-actions{display:flex;gap:8px;margin-top:8px}.notes-empty,.notes-loading{color:#9ca3af;padding:30px 20px;text-align:center}.notes-empty span{display:block;font-size:32px;margin-bottom:8px;opacity:.5}.notes-empty p{font-size:14px;margin:0}@media (max-width:768px){.note-header{align-items:flex-start;flex-direction:column;gap:4px}.note-actions{opacity:1}}.job-activity-history{border-top:1px solid #e5e7eb;margin-top:24px;padding-top:24px}.activity-header{justify-content:space-between;margin-bottom:16px}.activity-header h4{color:#374151;font-size:16px;font-weight:600;margin:0}.activity-count{background:#f3f4f6;border-radius:12px;color:#6b7280;font-size:12px;padding:4px 10px}.activity-timeline{padding-left:24px;position:relative}.activity-item{padding-bottom:16px;position:relative}.activity-item:last-child{padding-bottom:0}.activity-icon{align-items:center;border-radius:50%;display:flex;font-size:14px;height:32px;justify-content:center;left:-24px;width:32px;z-index:1}.activity-icon,.activity-line{background:#e5e7eb;position:absolute}.activity-line{bottom:0;left:-8px;top:32px;width:2px}.activity-content{padding-left:16px;padding-top:4px}.activity-description{color:#374151}.activity-user{margin-right:4px}.activity-action{color:#6b7280}.activity-changes{align-items:center;background:#f9fafb;border-radius:6px;display:flex;font-size:12px;gap:8px;margin-top:8px;padding:8px 12px}.activity-changes .old-value{color:#dc2626;max-width:150px;overflow:hidden;text-decoration:line-through;text-overflow:ellipsis;white-space:nowrap}.activity-changes .arrow{color:#9ca3af}.activity-changes .new-value{color:#10b981;font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.show-more-btn{margin-top:12px;width:100%}.activity-empty,.activity-loading{color:#9ca3af;padding:30px 20px;text-align:center}.activity-empty span{display:block;font-size:32px;margin-bottom:8px;opacity:.5}.activity-empty p{font-size:14px;margin:0}@media (max-width:768px){.activity-timeline{padding-left:20px}.activity-icon{font-size:12px;height:28px;left:-20px;width:28px}.activity-line{left:-6px;top:28px}}.jobs-page{margin:0 auto;max-width:1400px}.jobs-filters{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;display:flex;gap:16px;margin-bottom:24px;padding:20px}.search-box{flex:1 1}.search-box .input{margin:0}.filter-group{align-items:center;gap:8px}.filter-group label{color:#6b7280;font-size:14px;font-weight:500;white-space:nowrap}.filter-group .input{min-width:150px}.jobs-count{color:#6b7280;font-size:14px;white-space:nowrap}.jobs-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.job-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;padding:20px;transition:all .2s}.job-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.job-card-header{margin-bottom:12px}.job-card-header h3{color:#111827;flex:1 1;font-size:18px;line-height:1.4;margin:0}.job-description{background:#f9fafb;border-left:3px solid #d1d5db;border-radius:6px;color:#4b5563;font-size:14px;line-height:1.6;margin-bottom:16px;padding:12px 14px}.job-description p{margin:0;white-space:pre-wrap;word-break:break-word}.job-detail-description{background:#f9fafb;border-radius:8px;margin-bottom:20px;padding:16px}.job-detail-description h4{color:#374151;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.job-detail-description .description-content{color:#4b5563;font-size:14px;line-height:1.7}.job-detail-description .description-content p{margin:0 0 8px}.job-detail-description .description-content p:last-child{margin-bottom:0}.btn-warning{background:#f59e0b;border:none;color:#fff}.btn-warning:hover{background:#d97706}.job-stats{grid-gap:12px;border-bottom:1px solid #e5e7eb;border-top:1px solid #e5e7eb;gap:12px;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));margin-bottom:12px;padding:16px 0}.stat{text-align:center}.stat-label{display:block;font-size:11px;font-weight:500}.stat-value{display:block;font-size:18px}.job-meta{color:#9ca3af;font-size:12px;margin-bottom:16px}.job-meta .completion-info{color:#10b981;font-weight:500}.job-detail-tabs{background:#f3f4f6;border-radius:8px;display:flex;gap:4px;margin:20px 0;padding:4px;width:-webkit-fit-content;width:fit-content}.tab-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:10px 20px;transition:all .2s}.tab-btn:hover{color:#374151}.tab-btn.active{background:#fff;box-shadow:0 1px 3px #0000001a;color:#2563eb}.job-actions{display:flex;gap:8px;margin-top:auto}.job-actions .btn-sm{flex:1 1;font-size:13px;padding:8px 12px}.modal-header{align-items:flex-start;gap:16px;margin-bottom:20px}.modal-header>div{gap:12px}.btn-close,.modal-header>div{align-items:center;display:flex}.btn-close{background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;font-size:24px;height:32px;justify-content:center;padding:0;width:32px}.btn-close:hover{background:#f3f4f6;color:#111827}.job-detail-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin:20px 0}.stat-card{background:#f9fafb;padding:16px;text-align:center}.stat-card .stat-label{color:#6b7280;display:block;font-size:12px;margin-bottom:8px;text-transform:uppercase}.stat-card .stat-value{color:#111827;display:block;font-size:24px;font-weight:700}.time-entries-list{border:1px solid #e5e7eb;border-radius:8px;max-height:400px;overflow-y:auto}.time-entry{border-bottom:1px solid #e5e7eb;padding:16px}.time-entry:last-child{border-bottom:none}.entry-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px}.entry-user{color:#111827;font-size:14px;font-weight:600}.entry-date{color:#6b7280;font-size:13px;margin-top:2px}.entry-duration{color:#2563eb;font-family:Courier New,monospace;font-size:18px;font-weight:700}.entry-notes{display:flex;flex-direction:column;gap:6px;margin-top:8px}.entry-note{border-radius:4px;font-size:13px;padding:8px 12px}.entry-start-note{background:#dbeafe;border-left:3px solid #3b82f6;color:#1e40af}.entry-pause-note{background:#fef3c7;border-left:3px solid #f59e0b;color:#92400e}.entry-location{color:#6b7280;font-size:12px;margin-top:8px}.modal-sm{max-width:400px}.modal-large{max-width:800px}.job-worker-name{color:#6b7280;font-size:13px;font-weight:500;margin-top:4px}.job-card-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between}.job-card-badges{align-items:flex-end;display:flex;flex-direction:column;gap:8px}.filter-select{background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 12px;transition:all .2s}.filter-select:hover{border-color:#9ca3af}.filter-select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.loading{color:#6b7280;font-size:16px;padding:60px 20px;text-align:center}@media (max-width:768px){.filter-group,.jobs-filters{align-items:stretch;flex-direction:column}.filter-group label{font-size:13px}.job-detail-stats,.jobs-grid{grid-template-columns:1fr}.job-actions{flex-direction:column}.job-actions .btn-sm{width:100%}.job-card-header{flex-direction:column}.job-card-badges{align-items:flex-start;width:100%}}.time-tracker{margin:0 auto;max-width:1000px}.tracker-container{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;margin-top:24px}.timer-display{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;flex-direction:column;justify-content:center;padding:40px;text-align:center}.timer-display,.timer-status{align-items:center;display:flex}.timer-status{color:#6b7280;font-weight:500;gap:8px;margin-bottom:24px}.status-indicator{border-radius:50%;height:12px;width:12px}.status-indicator.active{animation:pulse-dot 2s infinite;background-color:#10b981}.status-indicator.inactive{background-color:#9ca3af}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.timer-clock{color:#2563eb;font-family:Courier New,monospace;font-size:56px;font-weight:700;letter-spacing:4px;margin:20px 0}.timer-job-info{margin-top:24px;width:100%}.job-badge{align-items:center;background:#f3f4f6;border-radius:8px;display:flex;gap:12px;padding:16px;text-align:left}.job-icon{font-size:24px}.job-title{color:#111827;font-size:16px;font-weight:600;margin-bottom:4px}.job-started{color:#6b7280;font-size:13px}.tracker-controls{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;padding:32px}.tracker-controls .form-group{margin-bottom:20px}.checkbox-label{font-weight:400}.checkbox-label input[type=checkbox]{width:auto}.btn-large{font-size:16px;font-weight:600;margin-top:auto;padding:16px 32px;width:100%}.job-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin-top:20px}.stat-item{background:#f9fafb;border-radius:8px;padding:16px;text-align:center}.stat-label{margin-bottom:8px}.stat-value{font-size:20px}@media (max-width:768px){.tracker-container{grid-template-columns:1fr}.timer-clock{font-size:42px}.job-stats{grid-template-columns:1fr}.tracker-controls{padding:24px}.timer-display{padding:32px 24px}}.paystub-info{background:#f9fafb;border-left:4px solid #2563eb;border-radius:8px;margin-bottom:20px;padding:16px}.paystub-info p{color:#374151;font-size:14px;margin:0}.paystub-modal{max-width:600px}.worker-selection-controls{display:flex;gap:16px;margin-bottom:12px}.btn-link{background:none;border:none;color:#2563eb;cursor:pointer;font-size:13px;font-weight:500;padding:0;text-decoration:underline}.btn-link:hover{color:#1d4ed8}.worker-checkbox-list{background:#fafafa;border:1px solid #e5e7eb;border-radius:6px;max-height:200px;overflow-y:auto;padding:12px}.worker-checkbox-list .checkbox-label{align-items:center;border-radius:4px;display:flex;gap:8px;margin:0;padding:8px;transition:background .2s}.worker-checkbox-list .checkbox-label:hover{background:#f3f4f6}.split-week-info{background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;margin-top:12px;padding:12px}.split-week-info p{color:#1e40af;font-size:13px;margin:4px 0}.info-note{font-style:italic;opacity:.8}.checkbox-label{color:#374151;font-weight:500}.checkbox-label input[type=checkbox]{height:18px;width:18px}.checkbox-label span{-webkit-user-select:none;user-select:none}.reports-page{margin:0 auto;max-width:1400px}.reports-filters{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-bottom:24px;padding:24px}.filter-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filter-group{flex-direction:column;gap:6px}.filter-group label{color:#374151;font-size:13px;font-weight:600}.filter-group .input{margin:0}.report-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:32px}.report-section h2{color:#111827;font-size:20px;margin-bottom:24px}.chart-container{background:#f9fafb;border-radius:8px;margin:32px 0;padding:24px}.bar-chart{gap:20px}.bar-chart,.bar-item{display:flex;flex-direction:column}.bar-item{gap:8px}.bar-label{align-items:center;display:flex;justify-content:space-between}.bar-job-name{color:#111827;font-size:14px;font-weight:600}.bar-value{color:#2563eb;font-family:Courier New,monospace;font-size:16px;font-weight:700}.bar-track{background:#e5e7eb;border-radius:4px;height:32px;overflow:hidden;position:relative}.bar-fill{align-items:center;background:linear-gradient(90deg,#3b82f6,#2563eb);color:#fff;display:flex;font-size:12px;font-weight:600;height:100%;justify-content:flex-end;padding-right:12px;transition:width .5s ease}.bar-meta{color:#6b7280;font-size:12px}.table{margin-top:20px}.notes-cell{display:flex;flex-direction:column;gap:4px}.entry-note-mini{border-radius:4px;display:inline-block;font-size:12px;padding:4px 8px}.entry-note-mini.start{background:#dbeafe;color:#1e40af}.entry-note-mini.pause{background:#fef3c7;color:#92400e}.loading-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:80px 20px}.spinner{animation:spin 1s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#2563eb;height:48px;margin-bottom:16px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.loading-state p{font-size:16px;margin-top:12px}.empty-state-icon{font-size:64px;margin-bottom:16px;opacity:.5}@media (max-width:768px){.filter-row,.stats-grid{grid-template-columns:1fr}.report-section{padding:20px}.table{font-size:12px}.table td,.table th{padding:8px}.bar-label{align-items:flex-start;flex-direction:column;gap:4px}.stat-card{padding:16px}.stat-icon{font-size:28px}.stat-value{font-size:22px}}.timesheets-page{margin:0 auto;max-width:1200px;padding:0 20px}.timesheets-filters{-webkit-overflow-scrolling:touch;display:flex;gap:8px;margin-bottom:24px;overflow-x:auto}.timesheets-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.timesheet-card{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;padding:20px;transition:all .2s}.timesheet-card:hover{box-shadow:0 4px 8px #0000001a}.timesheet-header{align-items:flex-start;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:16px}.timesheet-header h3{color:#111827;font-size:16px;margin:0 0 8px}.timesheet-hours{color:#2563eb;font-size:24px;font-weight:700}.timesheet-meta{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.meta-item{display:flex;font-size:14px;gap:8px}.meta-label{color:#6b7280;font-weight:500}.timesheet-actions{display:flex;gap:8px}.timesheet-actions .btn{flex:1 1}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;display:flex;flex-direction:column;max-height:90vh;max-width:600px;width:100%}.modal-content.large{max-width:900px}.modal-header{padding:24px}.modal-header h2{color:#111827;font-size:20px}.modal-close{align-items:center;border-radius:6px;display:flex;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.modal-close:hover{background:#f3f4f6}.modal-body{flex:1 1;overflow-y:auto}.modal-footer{padding:24px}textarea.input{font-family:inherit;min-height:80px;resize:vertical}.timesheet-entries-section{margin:24px 0}.section-header h3{color:#111827;font-size:16px}.entries-list{display:flex;flex-direction:column;gap:12px}.entry-row{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:12px;padding:16px}.entry-fields{grid-gap:12px;display:grid;flex:1 1;gap:12px;grid-template-columns:2fr 1fr 1fr 2fr}.entry-row .form-group{margin-bottom:0}.btn-icon{align-self:flex-end;background:none;border:none;border-radius:6px;cursor:pointer;font-size:20px;height:-webkit-fit-content;height:fit-content;padding:8px;transition:all .2s}.btn-icon:hover{background:#fee2e2}.btn-error{color:#dc2626}.total-hours{align-items:center;background:#eff6ff;border-radius:8px;display:flex;font-size:18px;justify-content:space-between;margin:20px 0;padding:16px}.hours-value{color:#2563eb;font-size:24px;font-weight:700}.empty-message{color:#6b7280;font-size:14px;padding:40px 20px;text-align:center}.timesheet-info-grid{grid-gap:20px;background:#f9fafb;border-radius:8px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr);margin-bottom:24px;padding:20px}.info-item{display:flex;flex-direction:column;gap:6px}.info-label{color:#6b7280;font-size:12px;font-weight:600;text-transform:uppercase}.info-value{color:#111827;font-size:16px;font-weight:500}.entries-table-section{margin:24px 0}.entries-table-section h3{color:#111827;font-size:16px;margin-bottom:12px}.entries-table{border-collapse:collapse;width:100%}.entries-table th{background:#f9fafb;border-bottom:2px solid #e5e7eb;color:#6b7280;font-size:13px;font-weight:600;padding:12px;text-align:left;text-transform:uppercase}.entries-table td{border-bottom:1px solid #e5e7eb;font-size:14px;padding:12px}.timesheet-notes{background:#fffbeb;border-left:4px solid #f59e0b;border-radius:4px;margin:24px 0;padding:16px}.timesheet-notes h4{color:#92400e;font-size:14px;margin:0 0 8px}.timesheet-notes p{color:#78350f;font-size:14px;margin:0}.approval-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;margin-top:24px;padding-top:24px}.approval-info{border-left:4px solid;border-radius:8px;margin-top:24px;padding:16px}.approval-info.approved{background:#f0fdf4;border-color:#22c55e}.approval-info.rejected{background:#fef2f2;border-color:#ef4444}.approval-info h4{font-size:16px;margin:0 0 8px}.approval-info.approved h4{color:#166534}.approval-info.rejected h4{color:#991b1b}.approval-info p{font-size:14px;margin:4px 0}.approval-form{background:#f9fafb;border-radius:8px;margin-top:24px;padding:20px}.approval-form h4{color:#111827;font-size:16px;margin:0 0 16px}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover{background:#4b5563}.btn-success{background:#22c55e;color:#fff}.btn-success:hover{background:#16a34a}.btn-error{background:#ef4444;color:#fff}.btn-error:hover{background:#dc2626}.btn-error-outline{background:#fff;border:1px solid #fecaca;color:#dc2626}.btn-error-outline:hover{background:#fee2e2}.btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.entry-fields,.form-row,.timesheet-info-grid,.timesheets-grid{grid-template-columns:1fr}.modal-content{border-radius:0;max-height:100vh;max-width:100%}.approval-actions,.entry-row{flex-direction:column}.modal-footer{flex-wrap:wrap}.modal-footer .btn{flex:1 1;min-width:120px}}@media (max-width:480px){.timesheets-page{padding:0 12px}.timesheet-card{padding:16px}.modal-content{padding:0}.modal-body,.modal-footer,.modal-header{padding:16px}}@media print{.modal-overlay{background:#fff;position:static}.modal-content.timesheet-print{border-radius:0;box-shadow:none;max-height:none;max-width:100%}.approval-actions,.approval-form,.btn,.modal-close,.no-print{display:none!important}.print-only{display:block!important}.timesheet-print-header{border-bottom:2px solid #000;margin-bottom:30px;padding-bottom:20px;text-align:center}.print-logo{margin-bottom:10px;max-height:80px;max-width:200px}.timesheet-print-header h1{font-size:24px;margin:10px 0}.timesheet-print-header h2{color:#666;font-size:18px;margin:5px 0}.modal-body{padding:20px 40px}.entries-table{page-break-inside:avoid}.badge{border:1px solid #000;padding:2px 8px}}.print-only{display:none}.header-actions{align-items:center}.entry-mode-toggle{background:#f3f4f6;border-radius:8px;display:flex;gap:8px;padding:4px;width:-webkit-fit-content;width:fit-content}.mode-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s}.mode-btn:hover{color:#374151}.mode-btn.active{background:#fff;box-shadow:0 1px 3px #0000001a;color:#2563eb}.day-quick-add{display:flex;flex-wrap:wrap;gap:6px}.day-quick-add .btn-sm{font-size:12px;padding:4px 8px}.entry-day-badge{min-width:90px}.day-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;display:inline-block;font-size:13px;font-weight:600;padding:6px 12px}@media (max-width:768px){.entry-mode-toggle{width:100%}.mode-btn{flex:1 1;justify-content:center}.day-quick-add{margin-top:8px;width:100%}.day-quick-add .btn-sm{flex:1 1}}.week-jobs-summary{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;margin-top:20px;padding:16px}.week-jobs-summary h3{font-size:15px;margin:0 0 8px}.week-jobs-summary .entries-table{font-size:13px;margin:0}.week-jobs-summary tr.dimmed td{opacity:.5}.week-select{font-size:14px}.week-select option{padding:4px}.admin-panel{margin:0 auto;max-width:1400px}.admin-tabs{border-bottom:2px solid #e5e7eb;display:flex;gap:8px;margin-bottom:24px}.tab{background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;font-size:15px;font-weight:500;margin-bottom:-2px;padding:12px 24px;transition:all .2s}.tab:hover{background:#f9fafb;color:#111827}.tab.active{border-bottom-color:#2563eb;color:#2563eb}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.stat-card{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;display:flex;gap:16px;padding:24px}.stat-icon{font-size:36px;opacity:.8}.stat-content{flex:1 1}.stat-label{font-size:13px;margin-bottom:4px}.stat-value{font-size:28px}.table-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.table-header h2{color:#111827;font-size:20px;margin:0}.action-buttons{flex-wrap:wrap}.action-buttons .btn-sm{font-size:13px;padding:4px 12px}.roles-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:24px}.role-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:24px;transition:all .2s}.role-card:hover{border-color:#2563eb;box-shadow:0 4px 12px #2563eb1a}.role-card h3{color:#111827;font-size:18px;margin-bottom:8px}.role-card p{color:#6b7280;font-size:14px;margin-bottom:16px}.role-card ul{list-style:none;margin:0;padding:0}.role-card li{border-bottom:1px solid #e5e7eb;color:#374151;font-size:14px;padding:8px 0}.role-card li:last-child{border-bottom:none}.card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:32px}.card h2{color:#111827;font-size:20px;margin-bottom:8px}.table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 2px 4px #0000000d;overflow:hidden;width:100%}.table thead{background:#f9fafb}.table th{border-bottom:2px solid #e5e7eb;color:#6b7280;font-size:12px;font-weight:600;padding:12px 16px;text-align:left;text-transform:uppercase}.table td{border-bottom:1px solid #e5e7eb;color:#374151;font-size:14px;padding:16px}.table tbody tr:hover{background:#f9fafb}.table tbody tr:last-child td{border-bottom:none}.badge{border-radius:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.badge-success{background:#dcfce7;color:#166534}.badge-warning{background:#fef3c7;color:#92400e}.badge-gray{color:#374151}.modal-overlay{bottom:0;left:0;right:0;top:0}.modal{border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;padding:32px}.modal h2{color:#111827;font-size:24px;margin-bottom:24px}.form-actions{margin-top:24px}.btn{padding:10px 20px}.btn-sm{font-size:13px;padding:6px 12px}.info-banner{align-items:flex-start;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;display:flex;gap:12px;padding:16px}.info-icon{font-size:20px}.info-banner div{color:#1e40af;font-size:14px}.user-filter-tabs{display:flex;gap:8px;margin-bottom:16px}.filter-tab{background:#f3f4f6;border:none;border-radius:20px;color:#6b7280;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .2s}.filter-tab:hover{background:#e5e7eb}.filter-tab.active{background:#2563eb;color:#fff}.inactive-row{background:#f9fafb;opacity:.6}.btn-danger{border-color:#fecaca!important;color:#dc2626!important}.btn-danger:hover{background:#fef2f2!important}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper .input{padding-right:45px}.password-toggle-btn{background:none;border:none;cursor:pointer;font-size:18px;opacity:.6;padding:4px;position:absolute;right:10px}.password-toggle-btn:hover{opacity:1}.encryption-section{margin:0 auto;max-width:800px}.encryption-card{text-align:center}.encryption-header{align-items:center;display:flex;gap:12px;justify-content:center;margin-bottom:16px}.encryption-icon{font-size:32px}.encryption-desc{color:#6b7280;font-size:15px;margin:0 auto 32px;max-width:600px}.key-types{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:32px}.key-type-card{align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;display:flex;gap:16px;padding:20px;text-align:left;transition:all .2s}.key-type-card:hover{background:#eff6ff;border-color:#2563eb;transform:translateX(4px)}.key-type-icon{font-size:32px}.key-type-info{flex:1 1}.key-type-info h3{color:#111827;font-size:16px;margin:0 0 4px}.key-type-info p{color:#6b7280;font-size:13px;margin:0}.key-arrow{color:#9ca3af;font-size:20px;transition:transform .2s}.key-type-card:hover .key-arrow{color:#2563eb;transform:translateX(4px)}.encryption-warning{align-items:flex-start;background:#fef3c7;border:1px solid #fcd34d;border-radius:8px;display:flex;gap:12px;padding:16px;text-align:left}.warning-icon{font-size:20px}.encryption-warning div{color:#92400e;font-size:14px}.encryption-modal{max-width:550px}.modal-header{margin-bottom:24px}.modal-header h2{margin:0}.modal-close{background:none;border:none;color:#6b7280;cursor:pointer;font-size:24px;padding:4px}.modal-close:hover{color:#111827}.key-generate-section{text-align:center}.key-generate-section p{color:#6b7280;margin-bottom:24px}.key-warning-box{align-items:flex-start;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;display:flex;gap:12px;margin-bottom:24px;padding:16px;text-align:left}.key-warning-box div{color:#991b1b;font-size:14px}.key-warning-box ul{margin:8px 0 0;padding-left:20px}.key-warning-box li{margin-bottom:4px}.btn-lg{font-size:16px;padding:14px 28px}.key-display-section{text-align:center}.key-success{align-items:center;color:#166534;display:flex;font-weight:600;gap:8px;justify-content:center;margin-bottom:24px}.success-icon{font-size:24px}.generated-key-box{background:#f3f4f6;border-radius:8px;margin-bottom:24px;padding:16px;text-align:left}.generated-key-box label{color:#6b7280;display:block;font-size:12px;font-weight:600;margin-bottom:8px;text-transform:uppercase}.key-value{align-items:center;display:flex;gap:12px}.key-value code{background:#fff;border:1px solid #e5e7eb;border-radius:6px;flex:1 1;font-family:monospace;font-size:14px;padding:12px;word-break:break-all}.copy-btn{background:#2563eb;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:all .2s;white-space:nowrap}.copy-btn:hover{background:#1d4ed8}.copy-btn.copied{background:#16a34a}.key-instructions{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;margin-bottom:24px;padding:16px;text-align:left}.key-instructions h4{color:#166534;margin:0 0 12px}.key-instructions ol{color:#166534;margin:0;padding-left:20px}.key-instructions li{margin-bottom:8px}.key-final-warning{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#991b1b;display:flex;font-size:14px;gap:8px;justify-content:center;margin-bottom:24px;padding:12px}@media (max-width:768px){.admin-tabs{overflow-x:auto}.tab{white-space:nowrap}.roles-grid,.stats-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column}.action-buttons .btn-sm{width:100%}.table{font-size:12px}.table td,.table th{padding:8px}.form-actions{flex-direction:column}.form-actions .btn{width:100%}.form-row,.key-types{grid-template-columns:1fr}.user-filter-tabs{flex-wrap:nowrap;overflow-x:auto}}.settings-page{margin:0 auto;max-width:1000px;padding:0 20px}.access-denied-icon{font-size:64px;margin-bottom:20px;opacity:.5}.access-denied h2{font-size:24px;margin-bottom:8px}.settings-tabs{-webkit-overflow-scrolling:touch;border-bottom:2px solid #e5e7eb;display:flex;gap:8px;margin-bottom:24px;overflow-x:auto}.settings-tabs .tab{background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;font-size:15px;font-weight:500;margin-bottom:-2px;padding:12px 24px;transition:all .2s;white-space:nowrap}.settings-tabs .tab:hover{background:#f9fafb;color:#111827}.settings-tabs .tab.active{border-bottom-color:#2563eb;color:#2563eb}.tab-content{animation:fadeIn .3s}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.settings-card{box-shadow:0 2px 4px #0000000d;padding:32px}.settings-card h2{color:#111827;font-size:24px;margin-bottom:8px}.settings-description{margin-bottom:32px}.form-group{margin-bottom:24px}.form-group label{margin-bottom:8px}.form-group small{color:#6b7280;display:block;font-size:12px;margin-top:6px}.input{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:10px 12px;transition:all .2s;width:100%}.input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.color-picker-container{align-items:center;display:flex;gap:12px}.color-picker{border:1px solid #d1d5db;border-radius:6px;cursor:pointer;height:44px;width:60px}.color-text{flex:1 1;max-width:150px}.color-preview{border:2px solid #e5e7eb;border-radius:6px;height:44px;width:44px}.logo-preview{background:#f9fafb;border-radius:6px;margin-top:12px;padding:16px;text-align:center}.logo-preview img{max-height:100px;max-width:200px;object-fit:contain}.checkbox-label{font-weight:400!important;gap:12px}.checkbox-label input[type=checkbox]{cursor:pointer;height:20px;margin:0;width:20px}.form-actions{margin-top:32px}.btn{padding:10px 24px}.btn-primary{background:#2563eb}.btn-primary:hover{background:#1d4ed8}.btn-primary:disabled{background:#9ca3af}.alert{align-items:center;border-radius:8px;display:flex;gap:12px;margin-bottom:20px;padding:16px}.alert button{background:none;border:none;color:inherit;cursor:pointer;font-size:18px;height:24px;margin-left:auto;padding:0;width:24px}.alert-error{background:#fee2e2;border:1px solid #fecaca;color:#991b1b}.alert-success{background:#dcfce7;border:1px solid #bbf7d0;color:#166534}@media (max-width:768px){.settings-page{padding:0 16px}.settings-card{border-radius:8px;padding:20px}.settings-card h2{font-size:20px}.settings-tabs{gap:4px}.settings-tabs .tab{font-size:14px;padding:10px 16px}.form-row{grid-template-columns:1fr}.color-picker-container{flex-wrap:wrap}.color-text{max-width:100%}.form-actions{flex-direction:column}.form-actions .btn{width:100%}.logo-preview img{max-width:100%}}@media (max-width:480px){.settings-card{padding:16px}.form-group{margin-bottom:20px}.input{font-size:16px}.color-picker-container{align-items:stretch;flex-direction:column}.color-picker{width:100%}}.profile-page{background:#f5f7fa;margin:0 auto;max-width:800px;min-height:100vh;padding:16px}.profile-page .page-header{margin-bottom:20px}.profile-page .page-header h1{color:#1f2937;font-size:24px;margin:0 0 4px}.profile-page .page-header p{color:#6b7280;font-size:14px;margin:0}.profile-page .alert{align-items:center;border-radius:8px;display:flex;font-size:14px;justify-content:space-between;margin-bottom:16px;padding:12px 16px}.profile-page .alert-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.profile-page .alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.profile-page .alert button{background:none;border:none;cursor:pointer;font-size:18px;line-height:1;opacity:.7;padding:0}.profile-container{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;overflow:hidden}.profile-picture-section{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;gap:16px;padding:24px 16px;text-align:center}.profile-picture-container{flex-shrink:0;position:relative}.profile-picture{background:#e5e7eb;object-fit:cover}.profile-picture,.profile-picture-placeholder{border:4px solid #ffffffe6;border-radius:50%;box-shadow:0 4px 12px #00000026;height:100px;width:100px}.profile-picture-placeholder{align-items:center;background:#fff3;display:flex;justify-content:center}.profile-initials{color:#fff;font-size:36px;font-weight:700;text-shadow:0 1px 2px #0000001a}.profile-picture-upload-btn{align-items:center;background:#fff;border-radius:20px;bottom:-4px;box-shadow:0 2px 8px #00000026;color:#667eea;cursor:pointer;display:flex;font-size:12px;font-weight:600;gap:4px;padding:6px 12px;position:absolute;right:-4px;transition:transform .2s,box-shadow .2s}.profile-picture-upload-btn:hover{box-shadow:0 4px 12px #0003;transform:scale(1.05)}.profile-picture-upload-btn:active{transform:scale(.98)}.upload-btn-text{display:inline}.profile-info{align-items:center;display:flex;flex-direction:column;gap:8px}.profile-info h2{font-size:22px;font-weight:700;margin:0}.profile-role{background:#fff3;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.5px;padding:4px 14px;text-transform:uppercase}.profile-email{font-size:14px;margin:0;opacity:.9}.profile-tabs{-webkit-overflow-scrolling:touch;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;overflow-x:auto;scrollbar-width:none}.profile-tabs::-webkit-scrollbar{display:none}.profile-tabs .tab{align-items:center;background:none;border:none;border-bottom:3px solid #0000;color:#6b7280;cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:13px;gap:4px;min-width:0;padding:14px 8px;transition:all .2s;white-space:nowrap}.profile-tabs .tab:hover{background:#667eea0d;color:#667eea}.profile-tabs .tab.active{background:#fff;border-bottom-color:#667eea;color:#667eea;font-weight:600}.tab-icon{font-size:18px}.tab-text{font-size:12px}.profile-form{padding:20px 16px}.form-group{margin-bottom:20px}.form-group label{font-size:14px;font-weight:600}.form-group .input{-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #d1d5db;color:#1f2937;font-size:16px;padding:12px 14px;transition:border-color .2s,box-shadow .2s}.form-group .input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group .input::placeholder{color:#9ca3af}.form-group select.input{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236b7280'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m19 9-7 7-7-7'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:18px;padding-right:40px}.form-hint{color:#6b7280;display:block;font-size:12px;margin-top:6px}.form-row{grid-template-columns:1fr}.form-group-city,.form-group-state,.form-group-zip{margin-bottom:20px}.btn{align-items:center;border-radius:8px;display:inline-flex;font-size:15px;justify-content:center;padding:12px 20px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-block{width:100%}@media (min-width:480px){.profile-page{padding:24px}.profile-picture-section{flex-direction:row;gap:24px;padding:32px;text-align:left}.profile-info{align-items:flex-start}.profile-picture,.profile-picture-placeholder{height:110px;width:110px}.profile-initials{font-size:40px}.profile-info h2{font-size:26px}.form-row{grid-template-columns:2fr 1fr 1.2fr}.form-group-city,.form-group-state,.form-group-zip{margin-bottom:20px}.profile-tabs .tab{flex-direction:row;gap:8px;padding:16px 20px}.tab-icon{font-size:16px}.tab-text{font-size:14px}.profile-form{padding:28px 32px}}@media (min-width:768px){.profile-page{padding:32px}.profile-page .page-header h1{font-size:28px}.profile-picture,.profile-picture-placeholder{height:120px;width:120px}.profile-initials{font-size:44px}.profile-info h2{font-size:28px}.profile-tabs .tab{padding:16px 32px}}@media (hover:none) and (pointer:coarse){.profile-picture-upload-btn:hover{box-shadow:0 2px 8px #00000026;transform:none}.btn-primary:hover:not(:disabled){box-shadow:none;transform:none}.profile-tabs .tab{min-height:54px}.btn,.form-group .input{min-height:48px}}.profile-form .password-input-wrapper{align-items:center;display:flex;position:relative}.profile-form .password-input-wrapper .input{flex:1 1;padding-right:44px}.profile-form .password-toggle{background:none;border:none;cursor:pointer;font-size:18px;opacity:.6;padding:4px 8px;position:absolute;right:8px}.profile-form .password-toggle:hover{opacity:1}.notifications-page{margin:0 auto;max-width:900px;padding:0 20px}.notifications-stats{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;display:flex;gap:20px;margin-bottom:24px;padding:20px}.stat-item{display:flex;flex-direction:column;gap:4px}.stat-label{color:#6b7280;font-size:12px;font-weight:600;text-transform:uppercase}.stat-value{color:#111827;font-size:24px;font-weight:700}.stat-value.unread{color:#2563eb}.notifications-filters{-webkit-overflow-scrolling:touch;display:flex;gap:8px;margin-bottom:20px;overflow-x:auto}.filter-btn{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s;white-space:nowrap}.filter-btn:hover{background:#f9fafb;border-color:#9ca3af}.filter-btn.active{background:#2563eb;border-color:#2563eb;color:#fff}.notifications-list{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;overflow:hidden}.notification-item{align-items:flex-start;border-bottom:1px solid #e5e7eb;cursor:pointer;display:flex;gap:16px;padding:20px;position:relative;transition:background-color .2s}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:#f9fafb}.notification-item.unread{background:#eff6ff}.notification-item.unread:before{background:#2563eb;bottom:0;content:"";left:0;position:absolute;top:0;width:4px}.notification-icon{align-items:center;background:#f3f4f6;border-radius:50%;display:flex;flex-shrink:0;font-size:20px;height:40px;justify-content:center;width:40px}.notification-item.unread .notification-icon{background:#dbeafe}.notification-content{flex:1 1;min-width:0}.notification-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:4px}.notification-header h4{color:#111827;font-size:15px;font-weight:600;margin:0}.notification-time{color:#6b7280;flex-shrink:0;font-size:12px;white-space:nowrap}.notification-content p{color:#6b7280;font-size:14px;line-height:1.5;margin:0}.notification-delete{background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;flex-shrink:0;font-size:18px;height:28px;padding:4px;transition:all .2s;width:28px}.notification-delete:hover{background:#fee2e2;color:#dc2626}.empty-icon{margin-bottom:16px}.empty-state h3{font-size:20px;margin-bottom:8px}.btn,.empty-state p{font-size:14px}.btn{border:none;border-radius:6px;cursor:pointer;font-weight:600;padding:8px 16px;transition:all .2s}.btn-outline{background:#fff;border:1px solid #d1d5db;color:#374151}.btn-outline:hover{background:#f9fafb;border-color:#9ca3af}@media (max-width:768px){.notifications-page{padding:0 16px}.header-actions{flex-direction:column}.header-actions .btn{width:100%}.notifications-stats{flex-wrap:wrap}.stat-item{flex:1 1;min-width:100px}.notification-item{padding:16px}.notification-icon{font-size:18px;height:36px;width:36px}.notification-header{align-items:flex-start;flex-direction:column;gap:4px}.notification-time{font-size:11px}.filter-btn{font-size:13px;padding:6px 12px}}@media (max-width:480px){.notifications-stats{flex-direction:column;gap:12px}.stat-item{align-items:center;border-bottom:1px solid #e5e7eb;flex-direction:row;justify-content:space-between;padding-bottom:12px}.stat-item:last-child{border-bottom:none;padding-bottom:0}.stat-value{font-size:20px}.notification-item{padding:12px}.notification-content p{font-size:13px}.notification-header h4{font-size:14px}}.my-paystubs{margin:0 auto;max-width:1400px;padding:24px}.paystubs-grid{grid-gap:24px;gap:24px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-top:24px}.paystub-card{border-radius:12px;padding:24px;transition:all .2s}.paystub-card:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.paystub-header{align-items:flex-start;border-bottom:2px solid #f3f4f6;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.paystub-header h3{color:#6b7280;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.date-range{color:#111827;font-size:18px;font-weight:600;margin:0}.status-badge{border-radius:20px;font-size:13px;font-weight:600;padding:6px 12px}.status-badge.approved{background:#d1fae5;color:#065f46}.paystub-details{margin-bottom:20px}.detail-row{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:12px 0}.detail-row:last-child{border-bottom:none}.detail-row .label{color:#6b7280;font-size:14px;font-weight:500}.detail-row .value{color:#111827;font-size:14px;font-weight:600}.paystub-actions{gap:12px}.paystub-actions .btn{flex:1 1}@media (max-width:768px){.my-paystubs{padding:16px}.paystubs-grid{gap:16px;grid-template-columns:1fr}.paystub-card{padding:16px}.paystub-header{flex-direction:column;gap:12px}}.media-browser-page{margin:0 auto;max-width:1400px}.media-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.media-stats .stat-card{background:#fff;box-shadow:0 2px 4px #0000000d;gap:16px;padding:20px}.media-stats .stat-card,.stat-icon{align-items:center;border-radius:12px;display:flex}.stat-icon{background:#f3f4f6;font-size:32px;height:56px;justify-content:center;width:56px}.stat-info .stat-value{color:#111827;font-size:24px;font-weight:700}.stat-info .stat-label{color:#6b7280;font-size:13px}.media-filters{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:16px 20px}.media-filters .search-box{flex:1 1;min-width:200px}.media-filters .search-box .input{margin:0}.media-filters .filter-group{min-width:150px}.media-filters .filter-group .input{margin:0}.view-toggles{background:#f3f4f6;border-radius:8px;display:flex;gap:4px;padding:4px}.view-toggle{background:#0000;border:none;border-radius:6px;cursor:pointer;font-size:16px;padding:8px 12px;transition:all .2s}.view-toggle.active{background:#fff;box-shadow:0 1px 3px #0000001a}.media-groups{display:flex;flex-direction:column;gap:32px}.media-group{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;padding:20px}.group-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.group-header,.group-header h3{align-items:center;display:flex}.group-header h3{color:#111827;font-size:18px;gap:8px;margin:0}.group-header h3:hover{color:#2563eb}.file-count{background:#f3f4f6;border-radius:20px;color:#6b7280;font-size:13px;padding:4px 12px}.media-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.media-grid-large{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.media-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 2px 4px #00000014;overflow:hidden;transition:all .2s}.media-card:hover{box-shadow:0 4px 12px #0000001f;transform:translateY(-2px)}.media-card-thumbnail{cursor:pointer;height:140px;overflow:hidden;position:relative}.media-card-thumbnail img{height:100%;object-fit:cover;transition:transform .3s;width:100%}.media-card-thumbnail:hover img{transform:scale(1.05)}.media-card-overlay{align-items:center;background:#0006;display:flex;inset:0;justify-content:center;opacity:0;position:absolute;transition:opacity .2s}.media-card-thumbnail:hover .media-card-overlay{opacity:1}.media-card-overlay span{color:#fff;font-size:14px;font-weight:600}.media-card-file{align-items:center;background:#f9fafb;display:flex;height:140px;justify-content:center;text-decoration:none}.media-card-file .file-icon{font-size:48px}.media-card-info{padding:12px}.media-card-name{color:#111827;font-size:13px;font-weight:600;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.media-card-job{color:#2563eb;font-size:12px;margin-bottom:4px}.media-card-caption{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#6b7280;display:-webkit-box;font-size:12px;margin-bottom:8px;overflow:hidden}.media-card-meta{color:#9ca3af;display:flex;font-size:11px;gap:6px}.media-card-actions{border-top:1px solid #f3f4f6;display:flex}.media-card-actions .action-btn{background:none;border:none;cursor:pointer;flex:1 1;font-size:16px;padding:8px;text-align:center;text-decoration:none;transition:background .2s}.media-card-actions .action-btn:hover{background:#f3f4f6}.media-card-actions .action-btn.delete:hover{background:#fee2e2}.loading-state{color:#6b7280;padding:60px 20px;text-align:center}.empty-state{box-shadow:0 2px 4px #0000000d;padding:80px 20px}.empty-state p{margin:0 0 20px}.lightbox{align-items:center;background:#000000f2;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:2000}.lightbox-content{max-height:90vh;max-width:90vw;position:relative}.lightbox-content img{border-radius:4px;max-height:75vh;max-width:100%;object-fit:contain}.lightbox-close{background:none;border:none;color:#fff;cursor:pointer;font-size:32px;position:absolute;right:0;top:-45px}.lightbox-info{color:#fff;margin-top:16px;text-align:center}.lightbox-filename{font-size:16px;font-weight:600}.lightbox-caption{color:#d1d5db;font-size:14px;margin-top:4px}.lightbox-meta{color:#9ca3af;font-size:12px;margin-top:8px}@media (max-width:1024px){.media-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.media-stats{gap:12px;grid-template-columns:1fr 1fr}.media-stats .stat-card{padding:16px}.stat-icon{font-size:24px;height:44px;width:44px}.media-filters{align-items:stretch;flex-direction:column}.media-filters .filter-group,.media-filters .search-box{min-width:100%}.view-toggles{justify-content:center}.media-grid{gap:12px;grid-template-columns:repeat(2,1fr)}.media-card-file,.media-card-thumbnail{height:120px}}@media (max-width:480px){.media-stats{grid-template-columns:1fr 1fr}.stat-info .stat-value{font-size:20px}.media-grid{grid-template-columns:1fr 1fr}}.activity-log-page{margin:0 auto;max-width:1200px}.activity-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.activity-stats .stat-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;display:flex;gap:16px;padding:20px}.activity-stats .stat-icon{align-items:center;background:#f3f4f6;border-radius:12px;display:flex;font-size:32px;height:56px;justify-content:center;width:56px}.activity-stats .stat-value{color:#111827;font-size:24px;font-weight:700}.activity-stats .stat-label{color:#6b7280;font-size:13px;text-transform:capitalize}.activity-filters{align-items:flex-end;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:20px}.activity-filters .filter-group{display:flex;flex-direction:column;gap:4px;min-width:150px}.activity-filters .filter-group label{color:#6b7280;font-size:12px;font-weight:600}.activity-filters .input{margin:0}.activity-container{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;overflow:hidden}.activity-list{max-height:600px;overflow-y:auto}.activity-item{border-bottom:1px solid #f3f4f6;display:flex;gap:16px;padding:16px 20px;transition:background .2s}.activity-item:hover{background:#f9fafb}.activity-item:last-child{border-bottom:none}.activity-icons{align-items:center;display:flex;flex-direction:column;gap:4px}.entity-icon{font-size:24px}.action-icon{align-items:center;border-radius:50%;display:flex;font-size:12px;height:24px;justify-content:center;width:24px}.activity-content{flex:1 1}.activity-header{align-items:center;display:flex;gap:8px;margin-bottom:4px}.activity-user{color:#111827;font-weight:600}.badge-small{background:#e5e7eb;border-radius:10px;color:#374151;font-size:10px;font-weight:600;padding:2px 8px;text-transform:uppercase}.activity-description{color:#4b5563;font-size:14px;line-height:1.5}.activity-entity{color:#6b7280;font-size:13px;margin-top:4px}.activity-time{color:#9ca3af;font-size:12px;margin-top:4px}.activity-pagination{align-items:center;background:#f9fafb;border-top:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:16px 20px}.pagination-info{color:#6b7280;font-size:13px}.pagination-buttons{display:flex;gap:8px}.access-denied{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;padding:80px 20px}.access-denied h2{color:#111827;margin:0 0 8px}.access-denied p{color:#6b7280;margin:0}.empty-state,.loading-state{color:#6b7280;padding:60px 20px;text-align:center}.empty-state .empty-icon{display:block;font-size:64px;margin-bottom:16px;opacity:.5}.empty-state h3{color:#111827;margin:0 0 8px}.empty-state p{margin:0}@media (max-width:1024px){.activity-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.activity-stats{gap:12px;grid-template-columns:1fr 1fr}.activity-stats .stat-card{padding:16px}.activity-stats .stat-icon{font-size:24px;height:44px;width:44px}.activity-filters{align-items:stretch;flex-direction:column}.activity-filters .filter-group{width:100%}.activity-item{padding:12px 16px}.activity-pagination{flex-direction:column;gap:12px}}@media (max-width:480px){.activity-stats{grid-template-columns:1fr 1fr}.activity-stats .stat-value{font-size:20px}}.workers-management{margin:0 auto;max-width:1400px;padding:24px}.clock-status-summary{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.status-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;cursor:pointer;display:flex;gap:16px;padding:20px;transition:transform .2s,box-shadow .2s}.status-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.status-card.clocked-in{border-left:4px solid #10b981}.status-card.clocked-out{border-left:4px solid #9ca3af}.status-card.total{border-left:4px solid #2563eb}.status-count,.status-icon{font-size:32px}.status-count{color:#111827;font-weight:700}.status-label{color:#6b7280;font-size:14px}.workers-tabs{border-bottom:1px solid #e5e7eb;display:flex;gap:8px;margin-bottom:20px;overflow-x:auto;padding-bottom:12px}.workers-tabs .tab{background:none;border:none;border-radius:8px;color:#6b7280;cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:all .2s;white-space:nowrap}.workers-tabs .tab:hover{background:#f3f4f6}.workers-tabs .tab.active{background:#2563eb;color:#fff}.workers-section h3{font-size:18px;margin:0 0 16px}.empty-text{color:#9ca3af;font-style:italic}.clocked-in-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.clocked-in-card{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;gap:16px;padding:16px}.worker-avatar{align-items:center;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:20px;font-weight:600;height:56px;justify-content:center;position:relative;width:56px}.worker-avatar img{border-radius:50%;height:100%;object-fit:cover;width:100%}.worker-avatar.small{font-size:16px;height:40px;width:40px}.online-dot{background:#10b981;border:2px solid #fff;border-radius:50%;bottom:2px;height:14px;position:absolute;right:2px;width:14px}.worker-info{display:flex;flex-direction:column;gap:4px}.worker-info strong{color:#111827;font-size:16px}.current-job{color:#2563eb;font-size:13px}.time-elapsed{color:#6b7280;font-size:13px}.workers-table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.workers-table{border-collapse:collapse;width:100%}.workers-table th{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#374151;font-size:13px;font-weight:600;padding:14px 16px;text-align:left}.workers-table td{border-bottom:1px solid #f3f4f6;font-size:14px;padding:14px 16px}.workers-table tr:hover{background:#f9fafb}.workers-table tr.inactive{opacity:.6}.worker-cell{align-items:center;display:flex;gap:12px}.worker-cell small{color:#6b7280;display:block;font-size:12px}.badge-error{margin-left:8px}.ssn-masked{color:#6b7280;font-family:monospace}.no-ssn{color:#9ca3af;font-style:italic}.modal{max-height:90vh;max-width:600px;overflow-y:auto}.form-group textarea.input{min-height:80px}.ssn-modal{max-width:500px}.ssn-current{border-bottom:1px solid #e5e7eb;margin-bottom:24px;padding-bottom:24px}.reveal-section{display:flex;gap:8px;margin-top:12px}.reveal-section .input{flex:1 1}.revealed-ssn{background:#fef3c7;border:1px solid #fcd34d;border-radius:8px;margin-top:16px;padding:16px}.revealed-ssn strong{display:block;font-family:monospace;font-size:18px}.revealed-ssn small{color:#92400e;font-size:12px}.ssn-set h4{margin:0 0 16px}.ssn-warning{background:#fef3c7;border-radius:8px;color:#92400e;font-size:13px;margin-top:20px;padding:12px 16px}@media (max-width:768px){.workers-management{padding:16px}.page-header{flex-direction:column;gap:16px}.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:span 1}.workers-table{display:block;overflow-x:auto}.action-buttons{flex-direction:column}}.billing{margin:0 auto;max-width:1200px;padding:24px}.stripe-warning{background:#fef3c7;border-radius:8px;color:#92400e;font-size:13px;padding:8px 16px}.access-denied{padding:60px 20px;text-align:center}.access-denied .icon{display:block;font-size:64px;margin-bottom:16px}.billing-tabs{border-bottom:1px solid #e5e7eb;display:flex;gap:8px;margin-bottom:24px;padding-bottom:12px}.billing-tabs .tab{background:none;border:none;border-radius:8px;color:#6b7280;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.billing-tabs .tab:hover{background:#f3f4f6}.billing-tabs .tab.active{background:#2563eb;color:#fff}.empty-state p{margin-bottom:24px}.invoices-table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.invoices-table{border-collapse:collapse;width:100%}.invoices-table th{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#374151;font-size:13px;font-weight:600;padding:14px 16px;text-align:left}.invoices-table td{border-bottom:1px solid #f3f4f6;font-size:14px;padding:14px 16px}.invoices-table tr:hover{background:#f9fafb}.invoices-table small{color:#6b7280;display:block}.invoices-table .amount{font-family:monospace;font-size:15px;font-weight:600}.badge-gray{background:#f3f4f6;color:#6b7280}.badge-error{background:#fee2e2;color:#991b1b}.create-invoice-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.form-section{margin-bottom:32px}.form-section h3{font-size:16px;font-weight:600;margin:0 0 16px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.section-header h3{margin:0}.form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.full-width{grid-column:span 2}.line-items{display:flex;flex-direction:column;gap:12px}.line-item{grid-gap:12px;align-items:center;display:grid;gap:12px;grid-template-columns:1fr 80px 100px 80px 40px}.item-total{font-family:monospace;font-weight:600;text-align:right}.remove-item-btn{background:#fee2e2;border:none;border-radius:6px;color:#991b1b;cursor:pointer;font-size:14px;height:32px;width:32px}.remove-item-btn:hover{background:#fecaca}.totals-section{background:#f9fafb;border-radius:8px;margin-left:auto;max-width:300px;padding:16px}.totals-row{display:flex;font-size:14px;justify-content:space-between;padding:8px 0}.totals-row.tax{border-bottom:1px solid #e5e7eb}.totals-row.total{font-size:18px;font-weight:700;padding-top:12px}.tax-input{margin:0 4px;padding:4px 8px;text-align:center;width:60px}.form-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding-top:24px}.settings-section{max-width:600px}.settings-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.settings-header{justify-content:space-between;margin-bottom:16px}.settings-header,.stripe-logo{align-items:center;display:flex}.stripe-logo{font-size:18px;font-weight:600;gap:8px}.stripe-logo span{font-size:24px}.settings-description{color:#6b7280;font-size:14px;margin-bottom:24px}.settings-description a{color:#2563eb}.checkbox-label{align-items:center;cursor:pointer;display:flex;gap:8px}.checkbox-label input{height:18px;width:18px}@media (max-width:768px){.billing{padding:16px}.page-header{flex-direction:column;gap:12px}.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:span 1}.line-item{background:#f9fafb;border-radius:8px;gap:8px;grid-template-columns:1fr;padding:12px}.item-total{text-align:left}.invoices-table{display:block;overflow-x:auto}}.invoices-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.invoice-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 1px 3px #0000001a;padding:16px}.invoice-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px}.invoice-card-header h3{font-size:15px;margin:0}.invoice-total{color:#059669;font-size:20px;font-weight:700}.invoice-card-body{font-size:13px;margin-bottom:12px}.invoice-card-actions{display:flex;flex-wrap:wrap;gap:6px}.job-select-list{border:1px solid #e5e7eb;border-radius:8px;max-height:200px;overflow-y:auto;padding:4px}.job-select-item{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:8px;padding:8px}.job-select-item:hover{background:#f3f4f6}.job-select-item.selected{background:#eff6ff}.job-select-item input[type=checkbox]{accent-color:#2563eb;height:18px;width:18px}.invoice-items-list{display:flex;flex-direction:column;gap:8px}.invoice-item-row{align-items:flex-start;display:flex;gap:8px}.invoice-print-header{align-items:flex-start;border-bottom:2px solid #2563eb;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.invoice-print-header .print-logo{max-height:60px;max-width:200px}.invoice-bill-to{background:#f9fafb;border-radius:8px;margin-bottom:20px;padding:12px}.invoice-bill-to h4{color:#6b7280;font-size:13px;margin:0 0 4px;text-transform:uppercase}.invoice-bill-to p{font-size:14px;margin:2px 0}.invoice-linked-jobs{margin-bottom:20px}.invoice-linked-jobs h4{margin:0 0 8px}.linked-job-item{border-bottom:1px solid #f3f4f6;padding:8px 0}.subtask-list{list-style:none;margin:4px 0 0 16px;padding:0}.subtask-list li{color:#374151;font-size:13px;padding:2px 0}.subtask-list li.completed{color:#059669}.invoice-table{border-collapse:collapse;margin:20px 0;width:100%}.invoice-table th{background:#f3f4f6;border-bottom:2px solid #e5e7eb;font-size:13px;padding:10px 12px;text-align:left}.invoice-table td{border-bottom:1px solid #f3f4f6;font-size:14px;padding:10px 12px}.invoice-table tfoot td{font-size:14px;padding:8px 12px}.invoice-total-row td{border-top:2px solid #2563eb;font-size:16px!important}.invoice-notes{background:#fffbeb;border-left:3px solid #f59e0b;border-radius:8px;margin:16px 0;padding:12px}.invoice-notes h4{font-size:13px;margin:0 0 4px}.invoice-photos-section{margin-top:24px;page-break-before:auto}.invoice-photos-section h4{margin:0 0 12px}.invoice-photos-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.invoice-photo-item{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.invoice-photo-img{display:block;height:200px;object-fit:cover;width:100%}.invoice-photo-caption{background:#f9fafb;color:#374151;font-size:13px;margin:0;padding:8px 12px}@media print{.no-print{display:none!important}.invoice-print{border:none;box-shadow:none}.invoice-photos-grid{grid-template-columns:repeat(2,1fr)}.invoice-photo-img{height:160px}}.info-icon{cursor:help;font-size:14px;opacity:.7}.info-icon:hover{opacity:1}.info-box{line-height:1.6}.info-box code{background:#dbeafe;border-radius:3px;font-size:12px;padding:1px 4px}.stripe-settings-panel .form-group{margin-bottom:16px}.stripe-settings-panel label{align-items:center;display:flex;font-size:14px;font-weight:500;gap:6px;margin-bottom:4px}.stripe-settings-panel small{display:block;font-size:12px;margin-top:2px}.stripe-settings-panel ol li,.stripe-settings-panel ul li{color:#374151}.stripe-settings-panel code{background:#f3f4f6;border-radius:3px;font-size:12px;padding:1px 4px}.stripe-settings-panel a{color:#2563eb;text-decoration:none}.stripe-settings-panel a:hover{text-decoration:underline}.paystubs{margin:0 auto;max-width:1200px;padding:24px}.page-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.page-header h1{font-size:28px;margin:0 0 4px}.page-header p{color:#6b7280;margin:0}.header-actions{gap:12px}.filters-bar{display:flex;gap:12px;margin-bottom:20px}.filters-bar .input{border:1px solid #e5e7eb;border-radius:8px;font-size:14px;min-width:150px;padding:10px 14px}.summary-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:24px}.summary-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:20px;text-align:center}.summary-value{color:#111827;font-size:28px;font-weight:700}.summary-label{color:#6b7280;font-size:14px;margin-top:4px}.empty-state{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:60px 20px;text-align:center}.empty-icon{font-size:64px;opacity:.5}.empty-state h3{margin:16px 0 8px}.empty-state p{color:#6b7280}.paystubs-table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.paystubs-table{border-collapse:collapse;width:100%}.paystubs-table th{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#374151;font-size:13px;font-weight:600;padding:14px 16px;text-align:left}.paystubs-table td{border-bottom:1px solid #f3f4f6;font-size:14px;padding:14px 16px}.paystubs-table tr:hover{background:#f9fafb}.paystubs-table .amount{font-family:monospace;font-weight:600}.paystubs-table .deductions{color:#dc2626;font-family:monospace}.paystubs-table .net{color:#059669;font-size:16px}.badge{border-radius:20px;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px}.badge-yellow{background:#fef3c7;color:#92400e}.badge-blue{background:#dbeafe;color:#1e40af}.badge-success{background:#d1fae5;color:#065f46}.action-buttons{display:flex;gap:8px}.modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.modal{background:#fff;border-radius:16px;max-width:500px;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h3{font-size:18px;margin:0}.close-btn{background:#f3f4f6;border:none;border-radius:50%;cursor:pointer;font-size:16px;height:32px;width:32px}.modal-body{padding:24px}.modal-footer{background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.form-group{margin-bottom:16px}.form-group label{color:#374151;display:block;font-size:13px;font-weight:500;margin-bottom:6px}.form-group .input{border:1px solid #e5e7eb;border-radius:8px;font-size:14px;padding:10px 12px;width:100%}.form-group .input:focus{border-color:#2563eb;outline:none}.form-group textarea.input{min-height:60px;resize:vertical}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}@media (max-width:768px){.paystubs{padding:16px}.page-header{flex-direction:column;gap:16px}.header-actions{width:100%}.header-actions button{flex:1 1}.filters-bar{flex-direction:column}.form-row{grid-template-columns:1fr}.paystubs-table{display:block;overflow-x:auto}}.export-modal{max-width:520px}.timesheet-checklist{border:1px solid #e5e7eb;border-radius:8px;display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto;padding:8px}.timesheet-check-item{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:10px;padding:8px 10px;transition:background .1s}.timesheet-check-item:hover{background:#f9fafb}.timesheet-check-item input[type=checkbox]{accent-color:#2563eb;flex-shrink:0;height:18px;width:18px}.ts-check-info{align-items:center;display:flex;flex:1 1;justify-content:space-between}.ts-check-dates{font-size:13px;font-weight:500}.ts-check-hours{color:#2563eb;font-size:13px;font-weight:600}.header-actions{display:flex;flex-wrap:wrap;gap:8px}@media (max-width:640px){.header-actions{flex-direction:column}.export-modal{margin:10px;max-width:100%}}.paystubs-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.paystub-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 1px 3px #0000001a;padding:16px;transition:border-color .2s}.paystub-card.paid{border-left:3px solid #059669}.paystub-card.pending{border-left:3px solid #f59e0b}.paystub-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px}.paystub-card-header h3{font-size:15px;margin:0}.paystub-amount{color:#059669;font-size:22px;font-weight:700}.paystub-details{color:#4b5563;display:flex;flex-direction:column;font-size:13px;gap:2px;margin-bottom:12px}.paystub-details .label{color:#6b7280;font-weight:500}.paystub-actions{display:flex;flex-wrap:wrap;gap:6px}.paystubs-filters{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;margin-bottom:16px}.filter-group{display:flex;gap:4px}.badge-info{background:#dbeafe;color:#1e40af}.badge-sm{font-size:11px;padding:1px 6px}@media (max-width:768px){.paystubs-grid{grid-template-columns:1fr}.paystubs-filters{flex-direction:column}}.clients-page{padding:0}.clients-layout{grid-gap:0;background:#fff;border:1px solid #e5e7eb;border-radius:12px;display:grid;gap:0;grid-template-columns:300px 1fr;min-height:500px;overflow:hidden}.clients-sidebar{background:#f9fafb;border-right:1px solid #e5e7eb;max-height:70vh;overflow-y:auto;padding:16px}.client-list-item{border-radius:8px;cursor:pointer;margin-bottom:4px;padding:12px;transition:all .15s}.client-list-item:hover{background:#eff6ff}.client-list-item.active{background:#dbeafe;border-left:3px solid #2563eb}.client-list-name{font-size:14px;font-weight:600}.client-list-meta{color:#6b7280;font-size:12px;margin-top:2px}.client-detail{max-height:70vh;overflow-y:auto;padding:24px}.client-detail-header{align-items:flex-start;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.client-detail-header h2{margin:0 0 4px}.client-detail-header p{color:#4b5563;font-size:14px;margin:2px 0}.client-detail-actions{display:flex;gap:6px}.properties-section{margin-top:8px}.properties-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.property-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:14px}.property-card-header{align-items:center;display:flex;justify-content:space-between}.property-card-header h4{font-size:15px;margin:0}.property-address{color:#4b5563;font-size:13px;margin:4px 0}.property-notes{color:#6b7280;font-size:12px;font-style:italic;margin:4px 0}.property-meta{color:#9ca3af;font-size:12px;margin:4px 0}.property-actions{display:flex;gap:6px;margin-top:8px}@media (max-width:768px){.clients-layout{grid-template-columns:1fr}.clients-sidebar{border-bottom:1px solid #e5e7eb;border-right:none;max-height:300px}}.ai-assistant-page{margin:0 auto;max-width:800px}.ai-search-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:20px;padding:20px}.ai-search-bar{display:flex;gap:8px;margin-bottom:12px}.ai-search-input{flex:1 1;font-size:16px;padding:12px 16px}.ai-photo-actions{align-items:flex-start;display:flex;flex-wrap:wrap;gap:8px}.ai-photo-preview{display:inline-block;margin-top:8px;position:relative}.ai-photo-preview img{border:2px solid #e5e7eb;border-radius:8px;max-height:150px;max-width:200px;object-fit:cover}.remove-photo{align-items:center;background:#ef4444;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:12px;height:24px;justify-content:center;position:absolute;right:-8px;top:-8px;width:24px}.ai-quick-searches{margin-top:20px}.ai-quick-searches h3{font-size:16px;margin:0 0 12px}.quick-search-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.quick-search-card{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;display:flex;gap:10px;padding:14px;text-align:left;transition:all .15s}.quick-search-card:hover{background:#eff6ff;border-color:#2563eb;transform:translateY(-1px)}.qs-emoji{font-size:24px}.qs-label{color:#374151;font-size:14px;font-weight:500}.ai-results{display:flex;flex-direction:column;gap:12px}.ai-result-card{background:#fff;border-radius:10px;box-shadow:0 1px 3px #0000001a;padding:16px}.ai-result-card.tip{border-left:4px solid #2563eb}.ai-result-card.warning{background:#fffbeb;border-left:4px solid #f59e0b}.ai-result-card.search{border-left:4px solid #059669}.ai-result-card.suggestion{border-left:4px solid #8b5cf6}.ai-result-card h4{font-size:15px;margin:0 0 6px}.ai-result-card p{color:#374151;font-size:14px;line-height:1.6;margin:0 0 8px}.ai-google-links,.result-links{display:flex;flex-wrap:wrap;gap:8px}.ai-google-links{border-top:1px solid #e5e7eb;margin-top:12px;padding-top:12px}@media (max-width:640px){.ai-search-bar{flex-direction:column}.quick-search-grid{grid-template-columns:1fr}}.payroll-tabs{border-bottom:2px solid #e5e7eb;display:flex;gap:0;margin-bottom:20px}.payroll-tab{background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;font-size:15px;font-weight:500;margin-bottom:-2px;padding:12px 24px;transition:all .15s}.payroll-tab:hover{background:#f9fafb;color:#374151}.payroll-tab.active{border-bottom-color:#2563eb;color:#2563eb}.payroll-content{min-height:400px}
/*# sourceMappingURL=main.5aa6d0c5.css.map*/