.signup-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;overflow-x:hidden;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.signup-bg-gradient{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#0f0f1a,#1a1a2e,#16213e);z-index:-2}.signup-bg-shapes{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;z-index:-1;pointer-events:none}.signup-shape{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;animation:signupFloat 20s ease-in-out infinite}.signup-shape-1{width:600px;height:600px;background:linear-gradient(135deg,#06b6d4,#3b82f6);top:-200px;right:-100px;animation-delay:0s}.signup-shape-2{width:500px;height:500px;background:linear-gradient(135deg,#8b5cf6,#ec4899);bottom:-150px;left:-100px;animation-delay:-7s}.signup-shape-3{width:400px;height:400px;background:linear-gradient(135deg,#10b981,#06b6d4);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-14s}@keyframes signupFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.95)}}.signup-card{width:90vw;max-width:600px;min-width:0;background:#fffffff7;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:40px;box-shadow:0 25px 50px -12px #0006,0 0 0 1px #ffffff1a;position:relative;z-index:1;transition:max-width .4s ease,width .4s ease}.signup-card.signup-card-wide{max-width:850px}.signup-logo{display:flex;align-items:center;gap:10px;margin-bottom:24px;cursor:pointer;transition:opacity .2s}.signup-logo:hover{opacity:.8}.signup-logo span{font-size:22px;font-weight:700;background:linear-gradient(135deg,#06b6d4,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.signup-progress{display:flex;justify-content:center;gap:10px;margin-bottom:32px}.signup-progress-dot{width:10px;height:10px;border-radius:50%;background:#e2e8f0;transition:all .3s ease}.signup-progress-dot.active{width:28px;border-radius:5px;background:linear-gradient(135deg,#8b5cf6,#6366f1)}.signup-progress-dot.completed{background:#8b5cf6}.signup-steps-container{position:relative;overflow:hidden;width:100%}.signup-steps-track{display:flex;width:100%;transition:transform .4s ease}.signup-step{width:100%;min-width:100%;flex-shrink:0;position:relative;box-sizing:border-box;max-height:65vh;overflow-y:auto;overflow-x:hidden;padding-right:4px}.signup-step::-webkit-scrollbar{width:4px}.signup-step::-webkit-scrollbar-track{background:transparent}.signup-step::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.signup-step::-webkit-scrollbar-thumb:hover{background:#9ca3af}.signup-title{font-size:26px;font-weight:700;color:#1e293b;margin:0 0 8px}.signup-subtitle{font-size:15px;color:#64748b;margin:0 0 28px}.signup-error{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;color:#dc2626;font-size:14px;margin-bottom:20px}.signup-form{display:flex;flex-direction:column;gap:18px;width:100%}.signup-field-row{display:flex;gap:12px;width:100%}.signup-field-row .signup-field{flex:1;min-width:0}.signup-field{display:flex;flex-direction:column;gap:6px;width:100%}.signup-label{font-size:13px;font-weight:500;color:#475569}.signup-input-wrapper{position:relative;display:flex;align-items:center;width:100%}.signup-input-icon{position:absolute;left:14px;color:#94a3b8;pointer-events:none;z-index:1}.signup-input{width:100%;height:48px;padding:0 14px 0 44px;font-size:15px;color:#1e293b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;outline:none;transition:all .2s;box-sizing:border-box}.signup-input:focus{background:#fff;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.signup-select{width:100%;height:48px;padding:0 14px;font-size:15px;color:#1e293b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;outline:none;cursor:pointer;transition:all .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;box-sizing:border-box}.signup-select:focus{background-color:#fff;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.signup-password-toggle{position:absolute;right:12px;background:none;border:none;padding:4px;cursor:pointer;color:#94a3b8;display:flex;align-items:center;justify-content:center;transition:color .2s}.signup-password-toggle:hover{color:#64748b}.signup-submit-btn{width:100%;height:52px;margin-top:8px;font-size:16px;font-weight:600;color:#fff;background:linear-gradient(135deg,#8b5cf6,#6366f1);border:none;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;box-shadow:0 4px 14px #8b5cf666;white-space:nowrap;box-sizing:border-box}.signup-submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #8b5cf680}.signup-skip-btn{background:none;border:none;color:#64748b;font-size:14px;cursor:pointer;padding:12px;transition:color .2s;white-space:nowrap}.signup-skip-btn:hover{color:#8b5cf6}.signup-back-btn{background:none;border:1px solid #e2e8f0;color:#64748b;font-size:14px;font-weight:500;cursor:pointer;padding:10px 20px;border-radius:8px;transition:all .2s;white-space:nowrap}.signup-back-btn:hover{border-color:#8b5cf6;color:#8b5cf6}.signup-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px;width:100%}.signup-actions-row{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}.signup-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:signupSpin .8s linear infinite;flex-shrink:0}@keyframes signupSpin{to{transform:rotate(360deg)}}.signup-login-link{text-align:center;font-size:14px;color:#64748b;margin:24px 0 0}.signup-login-link a{color:#8b5cf6;text-decoration:none;font-weight:600;transition:color .2s}.signup-login-link a:hover{color:#7c3aed}.signup-legal-text{text-align:center;font-size:12px;color:#94a3b8;margin:16px 0 0;line-height:1.5}.signup-legal-text a{color:#8b5cf6;text-decoration:none;transition:color .2s}.signup-legal-text a:hover{color:#7c3aed;text-decoration:underline}.signup-plans{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:8px;width:100%}.signup-plan-card{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;padding:16px 12px;cursor:pointer;transition:all .2s;position:relative;text-align:center}.signup-plan-card:hover{border-color:#c4b5fd;background:#faf5ff}.signup-plan-card.selected{border-color:#8b5cf6;background:#faf5ff;box-shadow:0 0 0 3px #8b5cf626}.signup-plan-card.recommended{border-color:#8b5cf6}.signup-plan-badge{position:absolute;top:-10px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;font-size:11px;font-weight:600;padding:4px 12px;border-radius:20px;white-space:nowrap}.signup-plan-name{font-size:14px;font-weight:600;color:#1e293b;margin:6px 0 8px}.signup-plan-price{margin-bottom:12px}.signup-plan-price .price{font-size:24px;font-weight:700;color:#1e293b}.signup-plan-price .period{font-size:12px;color:#64748b}.signup-plan-features{list-style:none;padding:0;margin:0;text-align:left}.signup-plan-features li{display:flex;align-items:center;gap:6px;font-size:11px;color:#475569;padding:4px 0}.signup-plan-features li svg{color:#10b981;flex-shrink:0}.signup-size-options{display:flex;flex-wrap:wrap;gap:8px;width:100%}.signup-size-btn{padding:10px 16px;font-size:13px;font-weight:500;color:#475569;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s;white-space:nowrap}.signup-size-btn:hover{border-color:#c4b5fd;background:#faf5ff}.signup-size-btn.selected{background:#8b5cf6;border-color:#8b5cf6;color:#fff}.signup-goals{display:flex;flex-direction:column;gap:10px;width:100%}.signup-goal-item{display:flex;align-items:center;gap:12px;cursor:pointer;padding:12px 16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;transition:all .2s;width:100%;box-sizing:border-box}.signup-goal-item:hover{border-color:#c4b5fd;background:#faf5ff}.signup-goal-item input{display:none}.signup-goal-check{width:22px;height:22px;border:2px solid #d1d5db;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.signup-goal-check svg{opacity:0;color:#fff;transition:opacity .2s}.signup-goal-item input:checked+.signup-goal-check{background:#8b5cf6;border-color:#8b5cf6}.signup-goal-item input:checked+.signup-goal-check svg{opacity:1}.signup-goal-label{font-size:14px;color:#1e293b}.signup-invites{display:flex;flex-direction:column;gap:12px;width:100%}.signup-invite-row{display:flex;gap:12px;width:100%}.signup-invite-email{flex:1;min-width:0;padding-left:14px}.signup-invite-role{width:130px;flex-shrink:0}.signup-add-invite{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:none;border:2px dashed #e2e8f0;border-radius:10px;color:#64748b;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;width:100%;box-sizing:border-box}.signup-add-invite:hover{border-color:#8b5cf6;color:#8b5cf6;background:#faf5ff}.signup-features{display:flex;flex-direction:column;gap:16px;margin-bottom:8px;width:100%}.signup-feature-item{display:flex;gap:16px;padding:16px;background:#f8fafc;border-radius:12px;transition:background .2s;width:100%;box-sizing:border-box}.signup-feature-item:hover{background:#f1f5f9}.signup-feature-icon{width:44px;height:44px;background:linear-gradient(135deg,#8b5cf61a,#6366f11a);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.signup-feature-icon svg{width:22px;height:22px;stroke:#8b5cf6}.signup-feature-content{flex:1;min-width:0}.signup-feature-content h3{font-size:15px;font-weight:600;color:#1e293b;margin:0 0 4px}.signup-feature-content p{font-size:13px;color:#64748b;margin:0;line-height:1.5}@media(max-width:1100px){.signup-plans{grid-template-columns:repeat(3,1fr)}}@media(max-width:900px){.signup-card,.signup-card.signup-card-wide{max-width:600px}.signup-plans{grid-template-columns:repeat(2,1fr);gap:12px}.signup-plan-card{display:flex;flex-direction:row;align-items:center;text-align:left;padding:16px 20px;gap:16px}.signup-plan-badge{position:static;transform:none;order:-1;align-self:flex-start}.signup-plan-name{margin:0;font-size:16px;flex:1}.signup-plan-price{margin:0;text-align:right}.signup-plan-price .price{font-size:24px}.signup-plan-features{display:none}}@media(max-width:600px){.signup-plans{grid-template-columns:1fr}.signup-plan-card{display:flex;flex-direction:row;align-items:center;text-align:left;padding:14px 16px;gap:12px}.signup-plan-badge{position:static;transform:none;font-size:10px;padding:3px 8px}.signup-plan-name{margin:0;font-size:14px;flex:1}.signup-plan-price{margin:0;text-align:right}.signup-plan-price .price{font-size:20px}.signup-plan-features{display:none}}@media(max-width:480px){.signup-page{padding:32px 16px 16px;align-items:flex-start}.signup-card{width:100%;max-width:100%;padding:24px;border-radius:20px}.signup-card.signup-card-wide{max-width:100%}.signup-step{max-height:60vh}.signup-title{font-size:22px}.signup-subtitle{font-size:14px;margin-bottom:24px}.signup-progress{margin-bottom:24px}.signup-field-row{flex-direction:column;gap:18px}.signup-input,.signup-select{height:48px;font-size:16px}.signup-submit-btn{height:50px;font-size:15px}.signup-invite-row{flex-direction:column}.signup-invite-role{width:100%}.signup-size-options{flex-direction:column}.signup-size-btn{width:100%;text-align:center}.signup-feature-item{flex-direction:column;text-align:center;gap:12px}.signup-feature-icon{margin:0 auto}.signup-feature-content{text-align:center}.signup-shape-1{width:400px;height:400px}.signup-shape-2{width:350px;height:350px}.signup-shape-3{width:300px;height:300px}}.audit-logs-page{padding:24px;max-width:1400px;margin:0 auto}.audit-logs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.audit-logs-header h1{font-size:1.5rem;font-weight:600;color:#1a1a2e;margin:0}.audit-logs-filters{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px;padding:16px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.audit-logs-filters select,.audit-logs-filters input[type=date]{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:.875rem;background:#fff;min-width:150px}.audit-logs-filters select:focus,.audit-logs-filters input[type=date]:focus{outline:none;border-color:var(--color-primary, #4361ee);box-shadow:0 0 0 2px var(--color-primary-light)}.audit-logs-loading,.audit-logs-empty{padding:48px;text-align:center;color:#666;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.audit-logs-table-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow-x:auto}.audit-logs-table{width:100%;border-collapse:collapse;font-size:.875rem}.audit-logs-table th{text-align:left;padding:12px 16px;background:#f8f9fa;border-bottom:2px solid #e9ecef;font-weight:600;color:#495057;white-space:nowrap}.audit-logs-table td{padding:12px 16px;border-bottom:1px solid #e9ecef;vertical-align:top}.audit-logs-table tbody tr:hover{background:#f8f9fa}.audit-timestamp{white-space:nowrap;color:#666;font-size:.8125rem}.audit-user-name{font-weight:500;color:#1a1a2e}.audit-user-email{font-size:.75rem;color:#888}.audit-action{display:inline-block;padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:500;text-transform:capitalize}.audit-action-auth{background:#e7f1ff;color:#06c}.audit-action-timesheet{background:#e6f7ed;color:#00875a}.audit-action-invoice{background:#fff4e5;color:#b86e00}.audit-action-user{background:#f3e8ff;color:#7c3aed}.audit-resource-type{display:block;font-weight:500;color:#495057}.audit-resource-id{display:block;font-size:.75rem;color:#888;font-family:monospace}.audit-details{max-width:300px;font-size:.8125rem;color:#666;word-break:break-word}.audit-ip{font-family:monospace;font-size:.8125rem;color:#666}.audit-logs-pagination{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#fff;border-radius:0 0 8px 8px;border-top:1px solid #e9ecef}.audit-pagination-info{font-size:.875rem;color:#666}.audit-pagination-controls{display:flex;align-items:center;gap:12px}.audit-page-number{font-size:.875rem;color:#495057}.btn-sm{padding:6px 12px;font-size:.8125rem}@media(max-width:768px){.audit-logs-page{padding:16px}.audit-logs-header{flex-direction:column;gap:12px;align-items:flex-start}.audit-logs-filters{flex-direction:column}.audit-logs-filters select,.audit-logs-filters input[type=date]{width:100%}.audit-logs-pagination{flex-direction:column;gap:12px}.audit-logs-table{font-size:.8125rem}.audit-logs-table th,.audit-logs-table td{padding:8px 12px}.audit-details{max-width:200px}}.bulk-operations-page{padding:24px;max-width:1200px;margin:0 auto}.bulk-header{margin-bottom:24px}.bulk-header h1{font-size:1.5rem;font-weight:600;color:#1a1a2e;margin:0}.bulk-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:2px solid #e9ecef}.bulk-tab{padding:12px 24px;background:none;border:none;font-size:1rem;font-weight:500;color:#666;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}.bulk-tab:hover{color:#4361ee}.bulk-tab.active{color:#4361ee;border-bottom-color:#4361ee}.export-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.export-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;align-items:center;text-align:center;min-height:280px}.export-card-top{flex:1;display:flex;flex-direction:column;align-items:center}.export-card-icon{width:48px;height:48px;background:#e7f1ff;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.export-card-icon svg{width:24px;height:24px;color:#4361ee}.export-card h3{font-size:1.125rem;font-weight:600;color:#1a1a2e;margin:0 0 8px}.export-card p{font-size:.875rem;color:#666;margin:0 0 16px;flex-grow:1}.export-card .btn-primary{margin-top:auto;width:100%}.export-date-range{display:flex;align-items:center;gap:6px;margin-bottom:16px;flex-wrap:wrap;justify-content:center}.export-date-range input{padding:6px 8px;border:1px solid #ddd;border-radius:6px;font-size:.8125rem;width:130px}.export-date-range span{color:#666;font-size:.875rem}.import-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:32px}.import-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a}.import-card-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}.import-card-icon{width:48px;height:48px;background:#e7f1ff;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.import-card-icon svg{width:24px;height:24px;color:#4361ee}.import-card-header h3{font-size:1.125rem;font-weight:600;color:#1a1a2e;margin:0 0 4px}.template-link{font-size:.875rem;color:#4361ee;padding:0;background:none;border:none;cursor:pointer}.template-link:hover{text-decoration:underline}.import-dropzone{border:2px dashed #ddd;border-radius:8px;padding:32px;cursor:pointer;transition:all .2s;margin-bottom:16px}.import-dropzone:hover,.import-dropzone.drag-over{border-color:#4361ee;background:#f8faff}.import-dropzone.has-file{border-color:#00875a;background:#e6f7ed}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:12px;color:#666}.dropzone-content svg{width:32px;height:32px;color:#999}.selected-file{display:flex;align-items:center;justify-content:center;gap:8px;color:#00875a;font-weight:500}.selected-file svg{width:20px;height:20px}.import-card .btn-primary{width:100%}.import-note{font-size:.75rem;color:#888;margin:12px 0 0;text-align:center}.import-result{background:#e6f7ed;border:1px solid #00875a;border-radius:8px;padding:16px;margin-bottom:24px}.import-result.has-errors{background:#fff4e5;border-color:#b86e00}.import-result-summary{display:flex;align-items:center;gap:12px;font-weight:500}.import-result-icon svg{width:20px;height:20px}.import-result.success .import-result-icon svg{color:#00875a}.import-result.has-errors .import-result-icon svg{color:#b86e00}.import-errors{margin-top:12px;padding-top:12px;border-top:1px solid rgba(0,0,0,.1)}.import-error-row{display:flex;gap:8px;font-size:.875rem;padding:4px 0}.error-row-num{font-weight:600;color:#b86e00}.error-message{color:#666}.import-history{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a}.import-history h2{font-size:1.125rem;font-weight:600;color:#1a1a2e;margin:0 0 16px}.history-loading,.history-empty{padding:32px;text-align:center;color:#666}.history-table-container{overflow-x:auto}.history-table{width:100%;border-collapse:collapse;font-size:.875rem}.history-table th{text-align:left;padding:12px;background:#f8f9fa;border-bottom:2px solid #e9ecef;font-weight:600;color:#495057}.history-table td{padding:12px;border-bottom:1px solid #e9ecef}.history-type{text-transform:capitalize}.history-file{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.success-count{color:#00875a}.failed-count{color:#de350b}.bulk-status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:500}.status-completed{background:#e6f7ed;color:#00875a}.status-warning{background:#fff4e5;color:#b86e00}.status-failed{background:#ffebe6;color:#de350b}.status-processing{background:#e7f1ff;color:#06c}@media(max-width:1024px){.export-cards{grid-template-columns:repeat(2,1fr)}.export-card{min-height:260px}}@media(max-width:640px){.bulk-operations-page{padding:16px}.export-cards{grid-template-columns:1fr}.export-card{min-height:auto}.import-cards{grid-template-columns:1fr}.export-date-range{flex-direction:column;width:100%}.export-date-range input{width:100%}.import-dropzone{padding:24px 16px}.history-table{font-size:.8125rem}.history-table th,.history-table td{padding:8px}}.departments-page{padding:24px;max-width:1200px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-header h1{font-size:1.5rem;font-weight:600;color:#1a1a2e;margin:0}.empty-icon{width:80px;height:80px;margin:0 auto 20px;background:#e7f1ff;border-radius:50%;display:flex;align-items:center;justify-content:center}.empty-icon svg{width:40px;height:40px;color:#4361ee}.loading-message,.empty-message{text-align:center;padding:40px;color:#666}.dept-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.dept-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:all .2s;border:2px solid transparent}.dept-card:hover{border-color:var(--color-primary, #4361ee);box-shadow:0 4px 12px var(--color-primary-medium)}.dept-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.dept-card-header h3{font-size:1.125rem;font-weight:600;color:#1a1a2e;margin:0}.dept-card-actions{display:flex;gap:4px}.dept-card-desc{font-size:.875rem;color:#666;margin:0 0 16px;line-height:1.4}.dept-card-meta{display:flex;flex-direction:column;gap:8px;padding-top:12px;border-top:1px solid #e9ecef}.dept-meta-item{display:flex;align-items:center;gap:8px;font-size:.875rem;color:#666}.dept-meta-item svg{width:16px;height:16px;color:#999}.btn-icon{width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#666;transition:all .2s}.btn-icon:hover{background:#f1f3f4;color:#4361ee}.btn-icon.btn-danger:hover,.btn-icon.btn-remove:hover{background:#ffebe6;color:#de350b}.btn-icon svg{width:18px;height:18px}.dept-modal{min-width:450px;max-width:500px;max-height:90vh;overflow-y:auto}.dept-modal .modal-header{padding:20px 24px;border-bottom:1px solid #e9ecef}.dept-modal .modal-header h2{font-size:1.25rem;font-weight:600;color:#1a1a2e;margin:0}.dept-modal .modal-close{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:0;line-height:1}.dept-modal .modal-close:hover{color:#333}.dept-modal form{padding:24px}.dept-modal .form-group{margin-bottom:20px}.dept-modal .form-group:last-of-type{margin-bottom:24px}.dept-modal label{display:block;font-size:.875rem;font-weight:500;color:#333;margin-bottom:8px}.dept-modal input,.dept-modal select,.dept-modal textarea{width:100%;padding:12px 14px;border:1px solid #ddd;border-radius:8px;font-size:.9375rem;font-family:inherit;transition:border-color .2s,box-shadow .2s;background:#fff;box-sizing:border-box}.dept-modal input:focus,.dept-modal select:focus,.dept-modal textarea:focus{outline:none;border-color:var(--color-primary, #4361ee);box-shadow:0 0 0 3px var(--color-primary-light)}.dept-modal input::placeholder,.dept-modal textarea::placeholder{color:#999}.dept-modal textarea{resize:vertical;min-height:80px}.dept-modal select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}.dept-modal .modal-actions{display:flex;justify-content:flex-end;gap:12px;border-top:1px solid #e9ecef;margin-top:8px;padding-top:20px}.dept-modal .modal-actions .btn{padding:10px 20px;font-size:.9375rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s}.dept-modal .modal-actions .btn-secondary{background:#fff;border:1px solid #ddd;color:#666}.dept-modal .modal-actions .btn-secondary:hover{background:#f5f5f5;border-color:#ccc}.dept-modal .modal-actions .btn-primary{background:#4361ee;border:1px solid #4361ee;color:#fff}.dept-modal .modal-actions .btn-primary:hover:not(:disabled){background:#3651d4;border-color:#3651d4}.dept-modal .modal-actions .btn-primary:disabled{opacity:.6;cursor:not-allowed}@media(max-width:520px){.dept-modal{min-width:auto;width:calc(100% - 32px);margin:16px}.dept-modal form{padding:20px}.dept-modal .modal-actions{flex-direction:column-reverse}.dept-modal .modal-actions .btn{width:100%}}.add-member-content{padding:24px}.select-all-row{display:flex;align-items:center;gap:20px;padding:12px 0;border-bottom:2px solid #e9ecef;margin-bottom:8px;font-weight:500;color:#1a1a2e;cursor:pointer}.select-all-row:hover{color:#4361ee}.select-all-row input[type=checkbox]{width:18px;height:18px;cursor:pointer}.add-member-list{max-height:300px;overflow-y:auto;margin-bottom:20px}.member-checkbox{display:flex;align-items:center;gap:16px;padding:12px 0;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background .2s}.member-checkbox:last-child{border-bottom:none}.member-checkbox:hover{background:#f8f9fa;margin:0 -12px;padding:12px}.member-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;flex-shrink:0}.member-name{font-weight:500;color:#1a1a2e;min-width:130px;flex-shrink:0}.member-name:after{content:"·";margin-left:12px;color:#ccc}.member-email{flex:1;font-size:.875rem;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:8px}.role-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:500;text-transform:capitalize}.role-owner{background:#e7f1ff;color:#06c}.role-admin{background:#f3e8ff;color:#7c3aed}.role-manager{background:#e6f7ed;color:#00875a}.role-worker{background:#f8f9fa;color:#666}.role-accountant{background:#fff4e5;color:#b86e00}.dept-detail{padding:0}.btn-back{display:flex;align-items:center;gap:8px;padding:8px 0;background:none;border:none;color:#4361ee;font-size:.9375rem;cursor:pointer;margin-bottom:16px}.btn-back:hover{text-decoration:underline}.btn-back svg{width:18px;height:18px}.dept-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e9ecef}.dept-detail-header h1{font-size:1.75rem;font-weight:600;color:#1a1a2e;margin:0 0 8px}.dept-description{font-size:1rem;color:#666;margin:0 0 8px}.dept-manager{font-size:.9375rem;color:#666;margin:0}.dept-manager strong{color:#1a1a2e}.dept-members-section h2{font-size:1.125rem;font-weight:600;color:#1a1a2e;margin:0 0 16px}.members-table{width:100%;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;border-collapse:collapse;overflow:hidden}.members-table th{text-align:left;padding:14px 16px;background:#f8f9fa;font-size:.8125rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e9ecef}.members-table td{padding:14px 16px;border-bottom:1px solid #e9ecef;font-size:.9375rem}.members-table tr:last-child td{border-bottom:none}.members-table tr:hover{background:#f8f9fa}.members-table th:last-child,.members-table td:last-child{text-align:right;width:50px}@media(max-width:768px){.departments-page{padding:16px}.page-header{flex-direction:column;align-items:flex-start;gap:16px}.dept-grid{grid-template-columns:1fr}.dept-detail-header{flex-direction:column;gap:16px}.members-table{font-size:.875rem}.members-table th,.members-table td{padding:10px 12px}}.locations-page{padding:24px;max-width:1200px;margin:0 auto}.locations-page .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.locations-page .page-header h1{font-size:1.5rem;font-weight:600;color:#1a1a2e;margin:0}.locations-page .empty-state{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.locations-page .empty-icon{width:80px;height:80px;margin:0 auto 20px;background:#e7f1ff;border-radius:50%;display:flex;align-items:center;justify-content:center}.locations-page .empty-icon svg{width:40px;height:40px;color:#4361ee}.locations-page .empty-state h2{font-size:1.25rem;font-weight:600;color:#1a1a2e;margin:0 0 8px}.locations-page .empty-state p{color:#666;margin:0 0 24px}.locations-page .loading-message,.locations-page .empty-message{text-align:center;padding:40px;color:#666}.location-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.location-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:all .2s;border:2px solid transparent}.location-card:hover{border-color:var(--color-primary, #4361ee);box-shadow:0 4px 12px var(--color-primary-medium)}.location-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.location-card-header h3{font-size:1.125rem;font-weight:600;color:#1a1a2e;margin:0}.location-card-actions{display:flex;gap:4px}.location-card-meta{display:flex;flex-direction:column;gap:8px;padding-top:12px;border-top:1px solid #e9ecef}.location-meta-item{display:flex;align-items:center;gap:8px;font-size:.875rem;color:#666}.location-meta-item svg{width:16px;height:16px;color:#999;flex-shrink:0}.location-modal{min-width:450px;max-width:550px;max-height:90vh;overflow-y:auto}.location-modal .modal-header{padding:20px 24px;border-bottom:1px solid #e9ecef}.location-modal .modal-header h2{font-size:1.25rem;font-weight:600;color:#1a1a2e;margin:0}.location-modal .modal-close{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:0;line-height:1}.location-modal .modal-close:hover{color:#333}.location-modal form{padding:24px}.location-modal .form-group{margin-bottom:16px}.location-modal .form-group:last-of-type{margin-bottom:24px}.location-modal .form-row{display:flex;gap:16px}.location-modal .form-row .form-group{flex:1}.location-modal label{display:block;font-size:.875rem;font-weight:500;color:#333;margin-bottom:8px}.location-modal input{width:100%;padding:12px 14px;border:1px solid #ddd;border-radius:8px;font-size:.9375rem;font-family:inherit;transition:border-color .2s,box-shadow .2s;background:#fff;box-sizing:border-box}.location-modal input:focus{outline:none;border-color:var(--color-primary, #4361ee);box-shadow:0 0 0 3px var(--color-primary-light)}.location-modal input::placeholder{color:#999}.location-modal .modal-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:20px;border-top:1px solid #e9ecef;margin-top:8px}.location-modal .modal-actions .btn{padding:10px 20px;font-size:.9375rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s}.location-modal .modal-actions .btn-secondary{background:#fff;border:1px solid #ddd;color:#666}.location-modal .modal-actions .btn-secondary:hover{background:#f5f5f5;border-color:#ccc}.location-modal .modal-actions .btn-primary{background:#4361ee;border:1px solid #4361ee;color:#fff}.location-modal .modal-actions .btn-primary:hover:not(:disabled){background:#3651d4;border-color:#3651d4}.location-modal .modal-actions .btn-primary:disabled{opacity:.6;cursor:not-allowed}.location-modal .add-member-content{padding:24px}.location-modal .select-all-row{display:flex;align-items:center;gap:20px;padding:12px 0;border-bottom:2px solid #e9ecef;margin-bottom:8px;font-weight:500;color:#1a1a2e;cursor:pointer}.location-modal .select-all-row:hover{color:#4361ee}.location-modal .select-all-row input[type=checkbox]{width:18px;height:18px;cursor:pointer}.location-modal .add-member-list{max-height:300px;overflow-y:auto;margin-bottom:20px}.location-modal .member-checkbox{display:flex;align-items:center;gap:16px;padding:12px 0;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background .2s}.location-modal .member-checkbox:last-child{border-bottom:none}.location-modal .member-checkbox:hover{background:#f8f9fa;margin:0 -12px;padding:12px}.location-modal .member-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;flex-shrink:0}.location-modal .member-name{font-weight:500;color:#1a1a2e;min-width:130px;flex-shrink:0}.location-modal .member-name:after{content:"·";margin-left:12px;color:#ccc}.location-modal .member-email{flex:1;font-size:.875rem;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:8px}.location-detail{padding:0}.location-detail .btn-back{display:flex;align-items:center;gap:8px;padding:8px 0;background:none;border:none;color:#4361ee;font-size:.9375rem;cursor:pointer;margin-bottom:16px}.location-detail .btn-back:hover{text-decoration:underline}.location-detail .btn-back svg{width:18px;height:18px}.location-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e9ecef}.location-detail-header h1{font-size:1.75rem;font-weight:600;color:#1a1a2e;margin:0 0 8px}.location-address{font-size:1rem;color:#666;margin:0 0 8px;white-space:pre-line}.location-phone{display:flex;align-items:center;gap:8px;font-size:.9375rem;color:#666;margin:0}.location-phone svg{width:16px;height:16px;color:#999}.location-members-section h2{font-size:1.125rem;font-weight:600;color:#1a1a2e;margin:0 0 16px}.location-members-section .members-table{width:100%;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;border-collapse:collapse;overflow:hidden}.location-members-section .members-table th{text-align:left;padding:14px 16px;background:#f8f9fa;font-size:.8125rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e9ecef}.location-members-section .members-table td{padding:14px 16px;border-bottom:1px solid #e9ecef;font-size:.9375rem}.location-members-section .members-table tr:last-child td{border-bottom:none}.location-members-section .members-table tr:hover{background:#f8f9fa}.location-members-section .members-table th:last-child,.location-members-section .members-table td:last-child{text-align:right;width:50px}@media(max-width:768px){.locations-page{padding:16px}.locations-page .page-header{flex-direction:column;align-items:flex-start;gap:16px}.location-grid{grid-template-columns:1fr}.location-detail-header{flex-direction:column;gap:16px}.location-modal{min-width:auto;width:calc(100% - 32px);margin:16px}.location-modal .form-row{flex-direction:column;gap:0}.location-members-section .members-table{font-size:.875rem}.location-members-section .members-table th,.location-members-section .members-table td{padding:10px 12px}}@media(max-width:520px){.location-modal form{padding:20px}.location-modal .modal-actions{flex-direction:column-reverse}.location-modal .modal-actions .btn{width:100%}}.branding-page{padding:24px;max-width:900px;margin:0 auto}.branding-page .page-header{margin-bottom:24px}.branding-page .page-header h1{font-size:1.5rem;font-weight:600;color:#1a1a2e;margin:0 0 4px}.page-subtitle{color:#666;margin:0;font-size:.9375rem}.upgrade-message{text-align:center;padding:60px 40px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;max-width:500px;margin:40px auto}.upgrade-icon{width:80px;height:80px;margin:0 auto 24px;background:#f3f4f6;border-radius:50%;display:flex;align-items:center;justify-content:center}.upgrade-icon svg{width:40px;height:40px;color:#6b7280}.upgrade-message h2{font-size:1.25rem;font-weight:600;color:#1a1a2e;margin:0 0 12px}.upgrade-message p{color:#666;margin:0 0 24px;line-height:1.6}.branding-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:20px 24px;margin-bottom:16px}.branding-card h2{font-size:.9375rem;font-weight:600;color:#1a1a2e;margin:0 0 16px}.branding-row-two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.branding-row-two-col .branding-card{margin-bottom:0}@media(max-width:768px){.branding-row-two-col{grid-template-columns:1fr}}.branding-page .form-group{margin-bottom:0}.branding-page label{display:block;font-size:.875rem;font-weight:500;color:#333;margin-bottom:6px}.branding-page input[type=text]{width:100%;padding:10px 14px;border:1px solid #ddd;border-radius:8px;font-size:.9375rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}.branding-page input[type=text]:focus{outline:none;border-color:var(--color-primary, #4361ee);box-shadow:0 0 0 3px var(--color-primary-light)}.form-hint{display:block;font-size:.8125rem;color:#888;margin-top:6px}.logo-section{display:flex;align-items:flex-start;gap:16px}.logo-preview-box{width:80px;height:80px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.logo-image{max-width:100%;max-height:100%;object-fit:contain}.logo-placeholder-icon{color:#9ca3af}.logo-placeholder-icon svg{width:32px;height:32px}.logo-controls{flex:1;min-width:0}.logo-buttons{display:flex;gap:8px;margin-bottom:6px;flex-wrap:wrap}.upload-btn{cursor:pointer}.preset-row{display:flex;gap:12px;flex-wrap:wrap}.preset-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 16px;background:#f8f9fa;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s;flex:1;min-width:100px}.preset-btn:hover{border-color:var(--color-primary, #4361ee);background:#fff;transform:none;box-shadow:none}.preset-colors{display:flex;gap:4px}.preset-colors span{width:20px;height:20px;border-radius:4px}.preset-name{font-size:.75rem;color:#333;font-weight:500}.color-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}@media(max-width:500px){.color-grid{grid-template-columns:1fr}}.color-picker-group label{display:block;font-size:.875rem;font-weight:500;color:#333;margin-bottom:2px}.color-description{display:block;font-size:.75rem;color:#888;margin-bottom:8px}.color-input-row{display:flex;gap:8px;align-items:center}.color-swatch{width:44px;height:44px;padding:2px;border:1px solid #ddd;border-radius:8px;cursor:pointer;background:#fff;flex-shrink:0}.color-swatch::-webkit-color-swatch-wrapper{padding:0}.color-swatch::-webkit-color-swatch{border-radius:4px;border:none}.color-hex-input{flex:1;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:.875rem;font-family:monospace;min-width:0}.color-hex-input:focus{outline:none;border-color:var(--color-primary, #4361ee);box-shadow:0 0 0 3px var(--color-primary-light)}.color-suggestions{margin-top:16px;padding:14px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:10px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.color-suggestions-header{display:flex;align-items:center;gap:8px;font-size:.8125rem;font-weight:500;color:#0369a1;margin-bottom:10px}.sparkle-icon{width:16px;height:16px;color:#0ea5e9}.color-suggestions-swatches{display:flex;gap:6px;margin-bottom:12px}.color-suggestion-swatch{width:32px;height:32px;border-radius:6px;border:2px solid #fff;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:transform .15s ease}.color-suggestion-swatch:hover{transform:scale(1.1)}.color-suggestions-actions{display:flex;gap:8px}.color-suggestions-actions .btn{padding:6px 12px;font-size:.75rem}.color-suggestions-actions .btn-ghost{background:transparent;color:#64748b;border:none;box-shadow:none}.color-suggestions-actions .btn-ghost:hover{background:#0000000d;color:#334155;transform:none}.branding-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:8px}.branding-page .btn-sm{padding:8px 14px;font-size:.8125rem}.branding-page .btn-ghost{background:transparent;color:#666;box-shadow:none;border:1px solid #ddd}.branding-page .btn-ghost:hover{background:#f3f4f6;color:#333;transform:none;box-shadow:none}.roles-page{padding:24px;max-width:1400px;margin:0 auto}.roles-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;gap:16px;flex-wrap:wrap}.roles-page .page-header h1{font-size:1.5rem;font-weight:600;color:#1a1a2e;margin:0 0 4px}.roles-page .page-subtitle{color:#666;margin:0;font-size:.9375rem}.page-header-actions{display:flex;gap:12px}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.role-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:20px;transition:box-shadow .2s,transform .2s}.role-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.role-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.role-card-title{display:flex;align-items:center;gap:10px}.role-card-title h3{font-size:1.0625rem;font-weight:600;color:#1a1a2e;margin:0}.role-badge{padding:3px 8px;border-radius:4px;font-size:.6875rem;font-weight:600;text-transform:uppercase}.role-badge.system{background:#e0e7ff;color:#4338ca}.role-card-actions{display:flex;gap:4px}.role-card-actions .btn{padding:6px;background:transparent;box-shadow:none}.role-card-actions .btn:hover{background:#f3f4f6}.role-card-actions .btn-danger-hover:hover{background:#fee2e2;color:#dc2626}.role-card-description{color:#666;font-size:.875rem;margin:0 0 16px;line-height:1.5}.role-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid #f0f0f0}.role-user-count{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:#888}.empty-state{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.empty-state-icon{color:#9ca3af;margin-bottom:16px}.empty-state h2{font-size:1.25rem;font-weight:600;color:#1a1a2e;margin:0 0 8px}.empty-state p{color:#666;margin:0 0 24px}.loading-state{text-align:center;padding:60px 20px;color:#666}.role-editor-modal{max-width:700px;width:95%;max-height:90vh;display:flex;flex-direction:column}.role-editor-modal .modal-body{overflow-y:auto;flex:1;padding:24px}.role-editor-form{margin-bottom:24px}.role-editor-form .form-group{margin-bottom:16px}.role-editor-form .form-group:last-child{margin-bottom:0}.role-editor-form label{display:block;font-size:.875rem;font-weight:500;color:#333;margin-bottom:6px}.role-editor-form input[type=text],.role-editor-form textarea{width:100%;padding:10px 14px;border:1px solid #ddd;border-radius:8px;font-size:.9375rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}.role-editor-form input:focus,.role-editor-form textarea:focus{outline:none;border-color:var(--color-primary, #4361ee);box-shadow:0 0 0 3px var(--color-primary-light)}.role-editor-form textarea{resize:vertical;min-height:60px}.permissions-section{background:#f8f9fa;border-radius:10px;padding:16px}.permissions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:8px}.permissions-header h3{font-size:1rem;font-weight:600;color:#1a1a2e;margin:0}.permissions-header-actions{display:flex;align-items:center;gap:12px}.selected-count{font-size:.8125rem;color:#666}.permissions-grid{display:flex;flex-direction:column;gap:8px}.permission-category{background:#fff;border-radius:8px;overflow:hidden;border:1px solid #e9ecef}.permission-category-header{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.permission-category-header:hover{background:#f8f9fa}.permission-category-left{display:flex;align-items:center;gap:10px}.permission-category-header .chevron{transition:transform .2s;color:#666}.permission-category-header .chevron.expanded{transform:rotate(90deg)}.permission-category-label{font-weight:500;color:#1a1a2e}.permission-count{font-size:.75rem;color:#888;background:#f0f0f0;padding:2px 8px;border-radius:10px}.select-all-checkbox{cursor:pointer}.select-all-checkbox input{width:18px;height:18px;cursor:pointer}.permission-list{padding:8px 14px 14px 40px;border-top:1px solid #f0f0f0;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px}.permission-item{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:6px;cursor:pointer;transition:background .15s}.permission-item:hover{background:#f8f9fa}.permission-item input{width:16px;height:16px;cursor:pointer}.permission-item span{font-size:.875rem;color:#333}.assign-role-modal{max-width:500px;width:95%}.assign-role-modal .modal-body{padding:0;max-height:400px;overflow-y:auto}.no-users-message{padding:40px 24px;text-align:center;color:#666}.select-all-row{display:flex;align-items:center;gap:12px;padding:14px 24px;border-bottom:2px solid #e9ecef;font-weight:500;cursor:pointer;background:#f8f9fa}.select-all-row:hover{background:#f0f0f0}.select-all-row input{width:18px;height:18px;cursor:pointer}.assign-user-list{padding:8px 0}.assign-user-item{display:flex;align-items:center;gap:14px;padding:12px 24px;cursor:pointer;transition:background .15s}.assign-user-item:hover{background:#f8f9fa}.assign-user-item input{width:18px;height:18px;cursor:pointer;flex-shrink:0}.assign-user-info{display:flex;flex-wrap:wrap;align-items:center;gap:8px;flex:1;min-width:0}.assign-user-name{font-weight:500;color:#1a1a2e}.assign-user-email{color:#666;font-size:.875rem}.assign-user-current-role{font-size:.75rem;color:#888;background:#f0f0f0;padding:2px 8px;border-radius:10px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0003;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e9ecef}.modal-header h2{font-size:1.125rem;font-weight:600;color:#1a1a2e;margin:0}.modal-close{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:0;line-height:1;box-shadow:none}.modal-close:hover{color:#333;background:none;transform:none}.modal-body{padding:24px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e9ecef;background:#f8f9fa}@media(max-width:768px){.roles-page .page-header{flex-direction:column;align-items:stretch}.page-header-actions{justify-content:flex-end}.roles-grid,.permission-list{grid-template-columns:1fr}.role-editor-modal{max-height:100vh;border-radius:0}}.legal-page{min-height:100vh;position:relative;color:#ffffffe6;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.legal-bg-gradient{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#0f0f1a,#1a1a2e,#16213e);z-index:-1}.legal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 40px;max-width:1200px;margin:0 auto}.legal-back-link{display:flex;align-items:center;gap:8px;color:#ffffffb3;text-decoration:none;font-size:14px;font-weight:500;transition:color .2s}.legal-back-link:hover{color:#fff}.legal-logo{display:flex;align-items:center}.legal-content{max-width:800px;margin:0 auto;padding:40px 40px 80px}.legal-content h1{font-size:2.5rem;font-weight:700;margin:0 0 8px;color:#fff;letter-spacing:-.02em}.legal-updated{font-size:14px;color:#ffffff80;margin:0 0 48px}.legal-content section{margin-bottom:48px}.legal-content h2{font-size:1.5rem;font-weight:600;color:#fff;margin:0 0 16px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.legal-content h3{font-size:1.1rem;font-weight:600;color:#fffffff2;margin:24px 0 12px}.legal-content p{font-size:1rem;line-height:1.7;color:#fffc;margin:0 0 16px}.legal-content ul{margin:0 0 16px;padding-left:24px}.legal-content li{font-size:1rem;line-height:1.7;color:#fffc;margin-bottom:8px}.legal-content li strong{color:#fffffff2}.legal-content a{color:#818cf8;text-decoration:none;transition:color .2s}.legal-content a:hover{color:#a5b4fc;text-decoration:underline}.legal-content .contact-info{list-style:none;background:#ffffff0d;border-radius:12px;padding:20px 24px}.legal-content .contact-info li{margin-bottom:8px}.legal-content .contact-info li:last-child{margin-bottom:0}.legal-footer{padding:32px 40px;border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto}.legal-footer p{font-size:14px;color:#ffffff80;margin:0}.legal-footer-links{display:flex;gap:24px}.legal-footer-links a{font-size:14px;color:#fff9;text-decoration:none;transition:color .2s}.legal-footer-links a:hover{color:#fff}@media(max-width:768px){.legal-header{padding:16px 20px;flex-direction:column;gap:16px}.legal-content{padding:24px 20px 60px}.legal-content h1{font-size:2rem}.legal-content h2{font-size:1.3rem}.legal-footer{padding:24px 20px;flex-direction:column;gap:16px;text-align:center}}@media(max-width:480px){.legal-content h1{font-size:1.75rem}.legal-content{padding:20px 16px 48px}.legal-content p,.legal-content li{font-size:.95rem}}:root{--color-primary: #4361ee;--color-primary-hover: #3651d4;--color-primary-dark: #2a41b8;--color-primary-light: rgba(67, 97, 238, .1);--color-primary-lighter: rgba(67, 97, 238, .05);--color-primary-medium: rgba(67, 97, 238, .2);--color-primary-shadow: rgba(67, 97, 238, .3);--color-secondary: #1a1a2e;--color-secondary-light: #2d2d44;--color-success: #10b981;--color-success-light: #d1fae5;--color-success-dark: #065f46;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-warning-dark: #92400e;--color-danger: #ef4444;--color-danger-light: #fee2e2;--color-danger-dark: #991b1b;--color-info: #3b82f6;--color-info-light: #dbeafe;--color-bg: #f8fafc;--color-bg-card: #ffffff;--color-border: #e2e8f0;--color-border-light: #f1f5f9;--color-text: #1e293b;--color-text-secondary: #64748b;--color-text-muted: #94a3b8;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -1px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -2px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .8125rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.375rem;--font-size-2xl: 1.75rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--color-label: #6b7280;--color-caption: #9ca3af;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3: .75rem;--card-padding: 1.5rem;--card-padding-mobile: 1rem;--section-margin: 2rem;--item-gap: .75rem;--table-cell-x: 1rem;--table-cell-y: .75rem;--form-field-gap: 1rem;--btn-padding: .75rem 1.5rem;--btn-padding-lg: 1rem 2rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{overflow-x:hidden}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;overflow-x:hidden;min-height:100vh}.filter-bar{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);align-items:center;margin-bottom:var(--spacing-lg);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md)}.filter-bar input,.filter-bar select{height:36px;font-size:var(--font-size-sm);padding:0 var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);min-width:140px}.filter-bar input:focus,.filter-bar select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.filter-bar input[type=date]{min-width:150px}.filter-bar .filter-actions{display:flex;gap:var(--spacing-xs);margin-left:auto}@media(max-width:768px){.filter-bar{flex-direction:column;align-items:stretch;gap:var(--spacing-md)}.filter-bar input,.filter-bar select{width:100%;min-height:48px;font-size:16px}.filter-bar .filter-actions{margin-left:0;flex-direction:column;gap:var(--spacing-sm)}.filter-bar .filter-actions button{width:100%;min-height:48px}}.data-table{width:100%;border-collapse:collapse;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.data-table thead{background:var(--color-bg)}.data-table th{padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);white-space:nowrap}.data-table td{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text);border-bottom:1px solid var(--color-border);vertical-align:middle}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--color-bg)}.data-table tbody tr:last-child td{border-bottom:none}.data-table .text-right{text-align:right}.data-table .text-center{text-align:center}.data-table .col-actions{width:120px;text-align:right}.table-responsive{position:relative;overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card)}.table-responsive:after{content:"";position:absolute;top:0;right:0;bottom:0;width:30px;background:linear-gradient(to left,rgba(0,0,0,.06),transparent);pointer-events:none;opacity:1;transition:opacity .2s;border-radius:0 var(--radius-md) var(--radius-md) 0}.table-responsive.scrolled-end:after{opacity:0}.table-responsive .data-table{border:none;border-radius:0;min-width:100%}.data-table .col-name,.data-table th:first-child,.data-table td:first-child{min-width:150px}.data-table .col-status{min-width:100px}.data-table .col-actions{min-width:80px;width:auto}.data-table th,.data-table td{min-width:120px}.table-responsive .data-table th:first-child,.table-responsive .data-table td:first-child{position:sticky;left:0;z-index:2;background:var(--color-bg-card)}.table-responsive .data-table thead th:first-child{background:var(--color-bg);z-index:3}.table-responsive .data-table th:first-child:after,.table-responsive .data-table td:first-child:after{content:"";position:absolute;top:0;right:-8px;bottom:0;width:8px;background:linear-gradient(to right,rgba(0,0,0,.08),transparent);pointer-events:none}.table-responsive .data-table th:first-child,.table-responsive .data-table td:first-child{position:sticky;left:0}.table-wrapper{position:relative;overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--color-border);border-radius:var(--radius-md)}.table-wrapper:after{content:"";position:absolute;top:0;right:0;bottom:0;width:30px;background:linear-gradient(to left,rgba(0,0,0,.06),transparent);pointer-events:none;border-radius:0 var(--radius-md) var(--radius-md) 0}.table-wrapper .data-table{border:none;border-radius:0}.table-wrapper .data-table th:first-child,.table-wrapper .data-table td:first-child{position:sticky;left:0;z-index:2;background:var(--color-bg-card)}.table-wrapper .data-table thead th:first-child{background:var(--color-bg);z-index:3}.table-wrapper .data-table th:first-child:after,.table-wrapper .data-table td:first-child:after{content:"";position:absolute;top:0;right:-8px;bottom:0;width:8px;background:linear-gradient(to right,rgba(0,0,0,.08),transparent);pointer-events:none}@media(max-width:768px){.table-responsive,.table-wrapper{margin:0 calc(-1 * var(--spacing-md));border-radius:0;border-left:none;border-right:none}.table-responsive:after,.table-wrapper:after{border-radius:0}.data-table th,.data-table td{padding:var(--spacing-sm);font-size:var(--font-size-sm)}.table-responsive .data-table th:first-child:after,.table-responsive .data-table td:first-child:after,.table-wrapper .data-table th:first-child:after,.table-wrapper .data-table td:first-child:after{width:10px;background:linear-gradient(to right,rgba(0,0,0,.1),transparent)}}.status-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.status-badge.blue,.status-badge[data-status=submitted],.status-badge[data-status=sent],.status-badge[data-status=info]{background:var(--color-info-light);color:#2563eb}.status-badge.green,.status-badge[data-status=approved],.status-badge[data-status=paid],.status-badge[data-status=active],.status-badge[data-status=placed],.status-badge[data-status=success]{background:var(--color-success-light);color:var(--color-success-dark)}.status-badge.yellow,.status-badge[data-status=pending],.status-badge[data-status=l1_interview],.status-badge[data-status=awaiting]{background:#fef9c3;color:#a16207}.status-badge.orange,.status-badge[data-status=l2_interview],.status-badge[data-status=overdue],.status-badge[data-status=unpaid]{background:#ffedd5;color:#c2410c}.status-badge.red,.status-badge[data-status=rejected],.status-badge[data-status=l1_reject],.status-badge[data-status=l2_reject],.status-badge[data-status=cancelled],.status-badge[data-status=error]{background:var(--color-danger-light);color:var(--color-danger-dark)}.status-badge.gray,.status-badge[data-status=draft],.status-badge[data-status=inactive],.status-badge[data-status=screen_reject]{background:#f1f5f9;color:#64748b}.table-actions{display:flex;align-items:center;gap:var(--spacing-xs);justify-content:flex-end}.table-actions .btn{padding:4px 10px;font-size:var(--font-size-xs)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);color:var(--color-text-secondary)}.loading-spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:var(--spacing-md)}.loading-text{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.btn-spinner{width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite;display:inline-block;margin-right:var(--spacing-xs)}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--color-text-secondary)}.empty-state-icon{font-size:48px;margin-bottom:var(--spacing-md);opacity:.5}.empty-state-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-xs)}.empty-state-text{font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);display:flex;align-items:flex-start;gap:var(--spacing-sm);animation:slideInDown .3s ease-out}.alert-danger,.alert-error{background:var(--color-danger-light);border:1px solid var(--color-danger);color:var(--color-danger-dark)}.alert-success{background:var(--color-success-light);border:1px solid var(--color-success);color:var(--color-success-dark)}.alert-warning{background:var(--color-warning-light);border:1px solid var(--color-warning);color:var(--color-warning-dark)}.alert-info{background:var(--color-info-light);border:1px solid var(--color-info);color:#1e40af}.alert-content{flex:1}.alert-title{font-weight:600;margin-bottom:var(--spacing-xs)}.alert-close{background:none;border:none;font-size:18px;cursor:pointer;opacity:.7;padding:0;line-height:1}.error-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) var(--spacing-lg);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center;min-height:200px}.error-card-icon{color:var(--color-danger);margin-bottom:var(--spacing-md)}.error-card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);margin:0 0 var(--spacing-sm) 0}.error-card-message{color:var(--color-text-secondary);margin:0 0 var(--spacing-lg) 0;max-width:400px}.error-card .btn{display:inline-flex;align-items:center;gap:var(--spacing-xs)}.error-card .btn-spinner{width:14px;height:14px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}.inline-error{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-danger-light);border:1px solid var(--color-danger);border-radius:var(--radius-md);color:var(--color-danger-dark)}.inline-error-message{font-size:var(--font-size-sm)}.toast-container{position:fixed;top:var(--spacing-lg);right:var(--spacing-lg);z-index:9999;display:flex;flex-direction:column;gap:var(--spacing-sm);max-width:400px}.toast{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);box-shadow:0 4px 12px #00000026;animation:slideIn .3s ease-out;min-width:280px}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{background:var(--color-success-light);border:1px solid var(--color-success);color:var(--color-success-dark)}.toast-error{background:var(--color-danger-light);border:1px solid var(--color-danger);color:var(--color-danger-dark)}.toast-warning{background:var(--color-warning-light);border:1px solid var(--color-warning);color:var(--color-warning-dark)}.toast-info{background:var(--color-info-light);border:1px solid var(--color-info);color:#1e40af}.toast-icon{flex-shrink:0;margin-top:2px}.toast-message{flex:1;font-size:var(--font-size-sm);line-height:1.4}.toast-close{flex-shrink:0;background:none;border:none;padding:0;cursor:pointer;opacity:.6;transition:opacity .2s}@media(max-width:480px){.toast-container{top:auto;bottom:var(--spacing-lg);left:var(--spacing-md);right:var(--spacing-md);max-width:none}.toast{min-width:auto}}.alert-close:hover{opacity:1}.alert-actions{margin-top:var(--spacing-sm)}.toast-container{position:fixed;top:var(--spacing-lg);right:var(--spacing-lg);z-index:9999;display:flex;flex-direction:column;gap:var(--spacing-sm)}.toast{padding:var(--spacing-md);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--spacing-sm);min-width:280px;max-width:400px;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-success{background:var(--color-success);color:#fff}.toast-error{background:var(--color-danger);color:#fff}.toast-warning{background:var(--color-warning);color:#fff}.toast-info{background:var(--color-info);color:#fff}.toast-message{flex:1;font-size:var(--font-size-sm)}.toast-close{background:none;border:none;color:currentColor;opacity:.8;cursor:pointer;padding:0;font-size:16px}.toast-close:hover{opacity:1}.page-container{max-width:100%;padding:0}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-md)}.page-header h1{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text);margin:0}.page-header-actions{display:flex;gap:var(--spacing-sm)}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);margin:0}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.stat-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);position:relative}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--color-primary);border-radius:var(--radius-md) var(--radius-md) 0 0}.stat-card.success:before{background:var(--color-success)}.stat-card.warning:before{background:var(--color-warning)}.stat-card.danger:before{background:var(--color-danger)}.stat-card.info:before{background:var(--color-info)}.stat-value{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-text);line-height:1;margin-bottom:var(--spacing-xs)}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes expandHeight{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.animate-fade-in{animation:fadeIn .3s ease-out forwards}.animate-fade-in-up{animation:fadeInUp .4s ease-out forwards}.animate-fade-in-down{animation:fadeInDown .4s ease-out forwards}.animate-slide-in-left{animation:slideInLeft .4s ease-out forwards}.animate-slide-in-right{animation:slideInRight .4s ease-out forwards}.animate-scale-in{animation:scaleIn .3s ease-out forwards}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-shimmer{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.animate-spin{animation:spin 1s linear infinite}.animate-bounce{animation:bounce .5s ease-in-out}.stagger-1{animation-delay:.05s;opacity:0}.stagger-2{animation-delay:.1s;opacity:0}.stagger-3{animation-delay:.15s;opacity:0}.stagger-4{animation-delay:.2s;opacity:0}.stagger-5{animation-delay:.25s;opacity:0}.stagger-6{animation-delay:.3s;opacity:0}.stagger-7{animation-delay:.35s;opacity:0}.stagger-8{animation-delay:.4s;opacity:0}.stagger-9{animation-delay:.45s;opacity:0}.stagger-10{animation-delay:.5s;opacity:0}.page-content{animation:fadeInUp .4s ease-out}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}h1,h2,h3,h4,h5,h6{line-height:1.3;color:var(--color-text);margin:0}h1,.page-title{font-size:1.75rem;font-weight:700;margin-bottom:8px!important;letter-spacing:-.02em;color:var(--color-text)}h2,.section-heading,.section-title{font-size:1.375rem;font-weight:600;margin-bottom:16px!important;color:var(--color-text)}h3,.card-title{font-size:1.125rem;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--color-text)}h4{font-size:1rem;font-weight:600;margin-bottom:var(--spacing-sm)}h5{font-size:.875rem;font-weight:600;margin-bottom:var(--spacing-xs)}h6{font-size:.8125rem;font-weight:600;margin-bottom:var(--spacing-xs)}label,.label,.form-label{font-size:.875rem;font-weight:500;color:#6b7280;margin-bottom:var(--spacing-xs);display:block}p,.body-text{font-size:1rem;font-weight:400;line-height:1.6;color:var(--color-text);margin-bottom:var(--spacing-md)}small,.small-text,.caption{font-size:.8125rem;font-weight:400;color:#9ca3af}.muted{font-size:.8125rem;color:#9ca3af}.stat-number{font-size:2rem;font-weight:700;line-height:1;color:var(--color-text);margin-bottom:var(--spacing-xs)}.text-primary{color:var(--color-primary)}.text-secondary{color:#6b7280}.text-muted{color:#9ca3af}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-xs{font-size:.75rem}.text-sm{font-size:.8125rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.375rem}.text-2xl{font-size:1.75rem}.text-3xl{font-size:2rem}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover);text-decoration:underline}input,select,textarea{font-family:inherit;font-size:var(--font-size-sm);padding:.625rem .875rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card);color:var(--color-text);width:100%;transition:border-color var(--transition-base),box-shadow var(--transition-base),background-color var(--transition-base),transform var(--transition-fast)}input:hover,select:hover,textarea:hover{border-color:var(--color-text-muted)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light),0 2px 8px var(--color-primary-light);background:#fff}input:disabled,select:disabled,textarea:disabled{background:var(--color-border-light);cursor:not-allowed;opacity:.7}input::placeholder,textarea::placeholder{color:var(--color-text-muted)}label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.form-row{display:flex;gap:16px!important;margin-bottom:16px!important}.form-row>div{flex:1}.form-group{margin-bottom:var(--form-field-gap)}.form-actions{display:flex;gap:8px!important;margin-top:24px!important;margin-bottom:32px!important}button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:inherit;font-size:.875rem;font-weight:500;padding:.75rem 1.5rem;border:none;border-radius:var(--radius-md);cursor:pointer;background:var(--color-primary);color:#fff;transition:all .2s ease;box-shadow:var(--shadow-sm)}button:hover,.btn:hover{background:var(--color-primary-dark);color:#fff;text-decoration:none}button:active,.btn:active{transform:scale(.98);transition-duration:.1s}button:disabled,.btn:disabled{opacity:.6;cursor:not-allowed;transform:none;background:var(--color-border);color:var(--color-text-muted)}.btn-sm{padding:.5rem 1rem;font-size:.8125rem;border-radius:var(--radius-sm)}.btn-lg{padding:1rem 2rem;font-size:1rem}.btn-approve,.btn-submit{background:var(--color-success)}.btn-approve:hover,.btn-submit:hover{background:var(--color-success-dark);color:#fff;text-decoration:none}.btn-reject,.btn-danger{background:var(--color-danger)}.btn-reject:hover,.btn-danger:hover{background:var(--color-danger-dark);color:#fff;text-decoration:none}.btn-secondary{background:var(--color-bg-card);color:var(--color-text);border:1px solid var(--color-border);box-shadow:none}.btn-secondary:hover{background:var(--color-primary-lighter);border-color:var(--color-primary-light);color:var(--color-text);text-decoration:none}.btn-ghost{background:transparent;color:var(--color-primary);box-shadow:none}.btn-ghost:hover{background:var(--color-primary-lighter);color:var(--color-primary);box-shadow:none;text-decoration:none}.btn-back{background:none;color:var(--color-primary);padding:0;margin-bottom:var(--spacing-md);box-shadow:none;font-weight:400}.btn-back:hover{background:none;box-shadow:none;text-decoration:underline;transform:none}.btn-reminder{background:var(--color-primary)}.btn-reminder:hover{background:var(--color-primary-dark);color:#fff;text-decoration:none}.btn-disabled{background:var(--color-border);color:var(--color-text-muted);cursor:not-allowed}.btn-disabled:hover{background:var(--color-border);transform:none}.app-layout{display:flex;min-height:100vh}.sidebar{width:260px;background:linear-gradient(180deg,var(--color-secondary) 0%,var(--color-secondary-light) 100%);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;box-shadow:var(--shadow-lg)}.sidebar-header{padding:var(--spacing-lg) var(--spacing-lg);border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.sidebar-header-actions{flex-shrink:0}.sidebar-header-actions .notification-bell{color:#fffc}.sidebar-header-actions .notification-bell:hover{color:#fff;background:#ffffff1a}.sidebar-header-actions .notification-badge{background:var(--color-danger);color:#fff}.nav-brand{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-xl);font-weight:700;color:#fff;text-decoration:none}.nav-brand-logo{width:36px;height:36px;border-radius:var(--radius-md);object-fit:contain;background:#fff;padding:4px}.nav-brand-text{background:linear-gradient(135deg,#fff,#fffc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-links{display:flex;flex-direction:column;flex:1;padding:var(--spacing-md) 0;overflow-y:auto}.nav-links a{display:flex;align-items:center;gap:var(--spacing-sm);color:#ffffffb3;text-decoration:none;padding:.75rem var(--spacing-lg);font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-base);border-left:3px solid transparent;margin:2px 0;position:relative}.nav-links a:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);width:3px;height:60%;background:var(--color-primary);border-radius:0 2px 2px 0;transition:transform var(--transition-base)}.nav-links a:hover{color:#fff;background:#ffffff14;text-decoration:none;padding-left:calc(var(--spacing-lg) + 4px)}.nav-links a.active{color:#fff;background:#ffffff1f;border-left-color:transparent}.nav-links a.active:before{transform:translateY(-50%) scaleY(1)}.nav-icon{width:20px;height:20px;opacity:.8}.nav-group{margin:2px 0}.nav-group-header{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:.75rem var(--spacing-lg);background:none;border:none;color:#ffffffb3;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-base);text-align:left;box-shadow:none}.nav-group-header:hover{color:#fff;background:#ffffff14;box-shadow:none;transform:none}.nav-group-header .nav-icon{width:18px;height:18px;opacity:.7}.nav-group-label{flex:1}.nav-group-chevron{width:16px;height:16px;opacity:.5;transition:transform var(--transition-base)}.nav-group.expanded .nav-group-chevron{transform:rotate(180deg)}.nav-group.active .nav-group-header{color:#fff}.nav-group-items{max-height:0;overflow:hidden;transition:max-height .25s ease-out}.nav-group.expanded .nav-group-items{max-height:500px;transition:max-height .35s ease-in}.nav-group-items a{padding-left:calc(var(--spacing-lg) + 16px);font-size:13px;font-weight:400;color:#fff9}.nav-group-items a:hover{padding-left:calc(var(--spacing-lg) + 20px)}.nav-group-items .nav-icon{width:16px;height:16px;opacity:.6}.nav-footer{padding:var(--spacing-lg);border-top:1px solid rgba(255,255,255,.1);background:#0000001a}.nav-user{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.nav-user-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:600}.nav-user-info{flex:1;min-width:0}.nav-user-name{font-size:var(--font-size-sm);font-weight:500;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-user-role{font-size:var(--font-size-xs);color:#fff9;text-transform:capitalize}.btn-logout{width:100%;background:transparent;border:1px solid rgba(255,255,255,.2);color:#fffc;padding:.5rem;font-size:var(--font-size-xs);margin-top:var(--spacing-sm);box-shadow:none}.btn-logout:hover{border-color:var(--color-danger);color:var(--color-danger);background:#ef44441a;box-shadow:none;transform:none}.main-content{margin-left:260px;padding:var(--spacing-xl) var(--spacing-2xl);flex:1;min-height:100vh}.main-content>*{animation:fadeInUp .4s ease-out backwards}.main-content>h1{animation-delay:0s}.main-content>.stats-row,.main-content>.page-header{animation-delay:.05s}.main-content>*:nth-child(3){animation-delay:.1s}.main-content>*:nth-child(4){animation-delay:.15s}.main-content>*:nth-child(5){animation-delay:.2s}.top-bar{display:none;position:fixed;top:0;left:0;right:0;height:60px;background:var(--color-bg-card);border-bottom:1px solid var(--color-border);padding:0 var(--spacing-md);align-items:center;justify-content:space-between;z-index:90;box-shadow:var(--shadow-sm)}.hamburger{background:none;border:none;padding:var(--spacing-sm);cursor:pointer;box-shadow:none;color:#333;border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.hamburger:hover{box-shadow:none;background-color:var(--color-border-light)}.hamburger:active{background-color:var(--color-border)}.hamburger svg{display:block;width:24px;height:24px;color:#333;stroke:#333!important}.hamburger svg line{stroke:#333}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px!important;gap:16px}.page-header h1{margin-bottom:0!important}.card{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:16px!important;transition:box-shadow var(--transition-base),transform var(--transition-base),border-color var(--transition-base);border:1px solid transparent;animation:fadeInUp .4s ease-out;display:flex!important;flex-direction:column!important;gap:8px!important}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:var(--color-primary-light)}.card>strong{font-size:var(--font-size-base);color:var(--color-text)}.card>.muted{font-size:var(--font-size-sm)}.card>.badge,.card>.btn{align-self:flex-start;margin-top:var(--spacing-xs)}.card-list{display:flex!important;flex-direction:column!important;gap:12px!important}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border-light)}.card-title{font-size:var(--font-size-lg);font-weight:600;margin:0}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:var(--section-margin)}.stat-card{background:var(--color-bg-card);padding:var(--card-padding);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);position:relative;overflow:hidden;transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base);border:1px solid transparent;animation:fadeInUp .4s ease-out backwards}.stat-card:nth-child(1){animation-delay:.1s}.stat-card:nth-child(2){animation-delay:.15s}.stat-card:nth-child(3){animation-delay:.2s}.stat-card:nth-child(4){animation-delay:.25s}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);transition:height var(--transition-base)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl);border-color:var(--color-primary-light)}.stat-card:hover:before{height:5px}.stat-card.success:before{background:linear-gradient(90deg,var(--color-success) 0%,#059669 100%)}.stat-card.warning:before{background:linear-gradient(90deg,var(--color-warning) 0%,#d97706 100%)}.stat-card.danger:before{background:linear-gradient(90deg,var(--color-danger) 0%,#dc2626 100%)}.stat-label{font-size:.875rem;color:#6b7280;font-weight:500}.stat-icon{position:absolute;top:var(--spacing-md);right:var(--spacing-md);width:40px;height:40px;border-radius:var(--radius-md);background:var(--color-primary-lighter);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.today-checkin-section{margin-bottom:var(--spacing-xl)}.today-checkin-card{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;animation:fadeInUp .4s ease-out}.today-checkin-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);background:var(--color-border-light);border-bottom:1px solid var(--color-border)}.today-checkin-date{font-weight:600;color:var(--color-text)}.today-checkin-details{padding:var(--spacing-lg)}.today-checkin-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border-light);gap:var(--spacing-md)}.today-checkin-row:last-child{border-bottom:none}.today-checkin-label{font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:500;min-width:80px}.today-checkin-row>span:last-child{font-size:var(--font-size-sm);color:var(--color-text);font-weight:500}.today-checkin-actions{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:var(--spacing-sm)}.today-checkin-actions .btn{min-width:80px}.today-checkin-empty{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-xl);text-align:center;animation:fadeInUp .4s ease-out}.leave-balance-card{text-align:center}.leave-balance-card .stat-number{color:var(--color-success)}.leave-balance-exceeded .stat-number,.leave-balance-exceeded .stat-label{color:var(--color-danger)}.leave-breakdown{margin-top:var(--spacing-sm);font-size:var(--font-size-xs)}.recent-timesheets-list{display:flex;flex-direction:column;gap:12px!important}.recent-timesheet-item{display:grid!important;grid-template-columns:150px 80px 120px 60px!important;align-items:center!important;gap:16px!important;background:var(--color-bg-card);padding:16px!important;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base);animation:fadeInUp .3s ease-out backwards}.recent-timesheet-item:nth-child(1){animation-delay:.05s}.recent-timesheet-item:nth-child(2){animation-delay:.1s}.recent-timesheet-item:nth-child(3){animation-delay:.15s}.recent-timesheet-item:nth-child(4){animation-delay:.2s}.recent-timesheet-item:nth-child(5){animation-delay:.25s}.recent-timesheet-item:nth-child(6){animation-delay:.3s}.recent-timesheet-item:nth-child(7){animation-delay:.35s}.recent-timesheet-item:hover{box-shadow:var(--shadow-md)}.recent-timesheet-info{display:flex;align-items:center;justify-content:flex-start!important;width:150px!important;min-width:150px!important}.recent-timesheet-date{font-weight:500;font-size:15px;color:var(--color-text);white-space:nowrap;text-align:left!important}.recent-timesheet-hours{font-size:14px;color:#6b7280;white-space:nowrap;width:80px!important;min-width:80px!important;text-align:left!important}.recent-timesheet-status{display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;width:120px!important;min-width:120px!important;gap:4px!important;text-align:center!important}.rejected-status{display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;width:100%!important;gap:4px!important;text-align:center!important}.rejection-reason{font-size:13px!important;color:var(--color-danger);line-height:1.3;text-align:center!important;width:100%!important}.recent-timesheet-link{font-size:14px;font-weight:500;color:var(--color-primary);white-space:nowrap;width:60px!important;min-width:60px!important;text-align:right!important}.recent-timesheet-link{font-size:.875rem;font-weight:500;color:var(--color-primary);white-space:nowrap;min-width:40px;text-align:right}.recent-timesheet-link:hover{text-decoration:underline}.status-badge svg{vertical-align:middle;margin-right:4px}.table-container{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.table-scroll{overflow-x:auto}table{width:100%;border-collapse:collapse;background:var(--color-bg-card)}th,td{padding:var(--table-cell-y) var(--table-cell-x);text-align:left;font-size:.875rem}th{background:var(--color-border-light);font-weight:600;font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--color-border);white-space:nowrap}td{border-bottom:1px solid var(--color-border-light);vertical-align:middle}td:last-child,th:last-child{text-align:right}td.text-right,th.text-right{text-align:right}td.text-center,th.text-center{text-align:center}tbody tr{transition:background var(--transition-base),transform var(--transition-fast)}tbody tr:hover{background:var(--color-primary-lighter)}tbody tr:hover td{color:var(--color-text)}tbody tr:last-child td{border-bottom:none}.row-checked{background:var(--color-primary-light)!important}.inactive-row{opacity:.5}.th-check,.td-check{width:40px;text-align:center}.entries-table{border-radius:var(--radius-md);overflow:hidden}.entries-table input[type=number]{width:80px;padding:.375rem .5rem}.entries-table input[type=text]{width:200px}.entries-table .weekend td{background:var(--color-border-light)}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.03em}.badge-draft{background:var(--color-border-light);color:var(--color-text-secondary)}.badge-submitted,.badge-pending{background:var(--color-warning-light);color:var(--color-warning-dark)}.badge-approved,.badge-success{background:var(--color-success-light);color:var(--color-success-dark)}.badge-rejected,.badge-error{background:var(--color-danger-light);color:var(--color-danger-dark)}.badge-owner{background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary-medium) 100%);color:var(--color-primary)}.badge-admin{background:var(--color-info-light);color:#1d4ed8}.badge-manager{background:#fef3c7;color:#92400e}.badge-worker{background:var(--color-border-light);color:var(--color-text-secondary)}.badge-leave{background:var(--color-warning-light);color:var(--color-warning-dark)}.status-check{color:var(--color-success);font-size:var(--font-size-lg)}.status-x{color:var(--color-danger);font-size:var(--font-size-lg)}.status-badge{display:inline-flex;align-items:center;padding:.2rem .5rem;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600;text-transform:capitalize}.status-approved{background:var(--color-success-light);color:var(--color-success-dark)}.status-rejected{background:var(--color-danger-light);color:var(--color-danger-dark)}.status-submitted{background:var(--color-warning-light);color:var(--color-warning-dark)}.status-draft{background:var(--color-border-light);color:var(--color-text-secondary)}.reminded-badge{display:inline-flex;align-items:center;padding:.2rem .5rem;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600;background:var(--color-success-light);color:var(--color-success-dark)}.leave-type{display:inline-block;background:var(--color-warning-light);color:var(--color-warning-dark);padding:.25rem .6rem;border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:500;white-space:nowrap}.work-type{display:inline-block;color:var(--color-text-muted);font-size:var(--font-size-xs);font-weight:500;padding:.25rem .6rem;background:var(--color-border-light);border-radius:var(--radius-md)}.leave-row{background:#fffbeb!important}.not-submitted-row{background:var(--color-danger-light)!important}.not-submitted-row td{color:var(--color-danger-dark)}.no-entry-row{background:#f8fafc!important}.no-entry-row td{color:#94a3b8}.no-entry-type{color:#94a3b8;font-style:italic}.weekend-row{background:#f8fafc!important}.weekend-row td{color:#94a3b8}.weekend-label{color:#94a3b8;font-style:italic;font-size:.875rem}.no-entry-label{color:var(--color-danger);font-weight:500;font-size:.875rem}.info-bar{display:flex;flex-wrap:wrap;gap:var(--spacing-lg);background:var(--color-bg-card);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-md);font-size:var(--font-size-sm)}.info-bar span{display:flex;align-items:center;gap:var(--spacing-xs)}.error-msg{background:var(--color-danger-light);color:var(--color-danger-dark);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:var(--font-size-sm);border-left:4px solid var(--color-danger);animation:slideInDown .3s ease-out}.success-msg{background:var(--color-success-light);color:var(--color-success-dark);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:var(--font-size-sm);border-left:4px solid var(--color-success);animation:slideInDown .3s ease-out}.warning-msg{background:var(--color-warning-light);color:var(--color-warning-dark);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:var(--font-size-sm);border-left:4px solid var(--color-warning);animation:slideInDown .3s ease-out}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}.skeleton-text{height:1rem;margin-bottom:.5rem;border-radius:var(--radius-sm)}.skeleton-text.short{width:40%}.skeleton-text.medium{width:70%}.skeleton-avatar{width:40px;height:40px;border-radius:50%}.skeleton-card{height:120px;border-radius:var(--radius-lg)}.skeleton-row{height:48px;margin-bottom:8px}.spinner{width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-lg{width:32px;height:32px;border-width:3px}.spinner-sm{width:14px;height:14px}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fffc;display:flex;align-items:center;justify-content:center;z-index:10;animation:fadeIn .2s ease-out}.pulse-indicator{width:8px;height:8px;background:var(--color-primary);border-radius:50%;animation:pulse 1.5s ease-in-out infinite}.loading-dots{display:inline-flex;gap:4px}.loading-dots span{width:6px;height:6px;background:var(--color-primary);border-radius:50%;animation:bounce 1.4s ease-in-out infinite}.loading-dots span:nth-child(1){animation-delay:0s}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer;transition:transform var(--transition-fast)}input[type=checkbox]:hover{transform:scale(1.1)}input[type=checkbox]:checked{animation:bounce .3s ease}.clickable-row{cursor:pointer;transition:background var(--transition-base),transform var(--transition-fast)}.clickable-row:hover{background:var(--color-primary-lighter)}.clickable-row:active{transform:scale(.995)}.expandable-content{overflow:hidden;transition:max-height var(--transition-slow),opacity var(--transition-base)}.expandable-content.collapsed{max-height:0;opacity:0}.expandable-content.expanded{max-height:1000px;opacity:1}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}a:not(.btn):not(.landing-btn-primary):not(.landing-btn-outline){transition:color var(--transition-fast),opacity var(--transition-fast)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--color-bg) 0%,#e2e8f0 100%)}.login-card{background:var(--color-bg-card);padding:var(--spacing-2xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:420px;animation:fadeInUp .5s ease-out}.login-card h1{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-xs);color:var(--color-primary)}.login-card h2{font-size:var(--font-size-base);font-weight:400;color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}.login-card form{display:flex;flex-direction:column;gap:var(--spacing-md)}.login-card .row{display:flex;gap:var(--spacing-sm)}.login-card .row input{flex:1}.toggle-link{margin-top:var(--spacing-lg);font-size:var(--font-size-sm);text-align:center;color:var(--color-text-secondary)}.toggle-link a{color:var(--color-primary);font-weight:500}.forgot-link{text-align:right;margin:-8px 0 16px;font-size:var(--font-size-sm)}.forgot-link a{color:var(--color-text-secondary);text-decoration:none}.forgot-link a:hover{color:var(--color-primary)}.team-section{margin-bottom:var(--spacing-xl)}.team-section h2{margin-bottom:var(--spacing-md)}.invite-form{display:flex;gap:var(--spacing-sm);align-items:flex-end;flex-wrap:wrap}.invite-form input,.invite-form select{width:auto;min-width:200px}.invite-form select{min-width:130px}.team-table{width:100%;border-collapse:collapse}.table-filters{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:1.25rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:8px;padding:.75rem 1rem}.table-filters input,.table-filters select{font-size:var(--font-size-sm);padding:6px 10px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg)}.table-filters input[type=text]{min-width:160px}.role-select,.worker-type-select,.approval-period-select{width:auto;min-width:110px;padding:.375rem .5rem;font-size:var(--font-size-xs)}.leaves-input{width:70px!important;padding:.375rem .5rem;text-align:center}.approvals-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg)}.approvals-page .page-header h1{margin-bottom:0}.page-header-content{display:flex;flex-direction:column;gap:var(--spacing-xs)}.page-description{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}.header-actions{display:flex;gap:var(--spacing-sm)}.settings-panel{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm)}.settings-panel h3{font-size:var(--font-size-base);margin-bottom:var(--spacing-md)}.settings-panel .form-row{margin-bottom:var(--spacing-md)}.settings-actions{display:flex;gap:var(--spacing-sm)}.period-cards{display:flex;flex-direction:column;gap:var(--item-gap)}.period-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:box-shadow var(--transition-base)}.period-card:hover{box-shadow:var(--shadow-lg)}.period-card-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;transition:background var(--transition-fast)}.period-card-header:hover{background:var(--color-primary-lighter)}.period-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.period-label{font-weight:600;font-size:var(--font-size-base);color:var(--color-text)}.worker-name{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--spacing-sm)}.period-type-badge{font-size:var(--font-size-xs);background:var(--color-info-light);color:#1d4ed8;padding:.15rem .5rem;border-radius:var(--radius-sm);text-transform:capitalize}.period-summary{display:flex;align-items:center;gap:var(--spacing-md)}.summary-item{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.summary-item strong{color:var(--color-text)}.leave-badge{background:var(--color-warning-light);color:var(--color-warning-dark);padding:.2rem .5rem;border-radius:var(--radius-sm);font-size:var(--font-size-xs)}.expand-icon{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-left:var(--spacing-sm)}.period-card-body{border-top:1px solid var(--color-border);padding:var(--spacing-lg);background:var(--color-border-light)}.period-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.review-section{margin-top:var(--spacing-lg)}.review-section textarea{margin-bottom:var(--spacing-md)}.review-section .actions{display:flex;gap:var(--spacing-sm)}.bulk-actions{display:flex;align-items:center;gap:var(--spacing-md);background:var(--color-primary-light);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.bulk-count{font-size:var(--font-size-sm);font-weight:600;color:var(--color-primary)}.bulk-comment{flex:1;max-width:300px}.worker-name-link{color:var(--color-primary);text-decoration:none;font-weight:500}.worker-name-link:hover{text-decoration:underline}.past-timesheets-section{margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:2px solid var(--color-border)}.past-timesheets-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.past-timesheets-section h2{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);margin:0}.status-filter{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);border:1px solid var(--color-border);font-size:var(--font-size-sm)}.past-cards .period-card{border-left:4px solid var(--color-success)}.past-cards .period-card.rejected-card{border-left-color:var(--color-danger)}.status-badge{display:inline-block;padding:.15rem .5rem;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600;text-transform:capitalize;margin-left:var(--spacing-sm)}.status-badge.approved{background:var(--color-success-light);color:var(--color-success-dark)}.status-badge.rejected{background:var(--color-danger-light);color:var(--color-danger-dark)}.timesheet-history-section{padding:var(--spacing-lg) 0}.history-filters{background:var(--color-bg-card);padding:var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl);box-shadow:var(--shadow-sm)}.history-filters .filter-row{display:flex;flex-wrap:wrap;gap:var(--spacing-md);align-items:flex-end}.history-filters .filter-field{flex:1;min-width:140px}.history-filters .filter-field label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.history-filters .filter-field input,.history-filters .filter-field select{width:100%;padding:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.history-filters .btn{align-self:flex-end}@media(max-width:768px){.history-filters .filter-row{flex-direction:column;align-items:stretch}.history-filters .filter-field{min-width:100%}}.employee-timesheets-page .page-header{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl)}.employee-timesheets-page .page-header h1{margin:0}.employee-info-card{background:var(--color-bg-card);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-lg)}.employee-details{display:flex;flex-wrap:wrap;gap:var(--spacing-lg)}.employee-details .detail-item{display:flex;gap:var(--spacing-sm)}.employee-details .label{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.employee-details .value{font-weight:500;text-transform:capitalize}.section-title{font-size:var(--font-size-lg);margin-bottom:var(--spacing-md);color:var(--color-text)}.upcoming-leaves-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.upcoming-leave-item{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);transition:all .2s ease}.upcoming-leave-item:hover{box-shadow:var(--shadow-md);border-color:var(--color-border)}.upcoming-leave-date{font-weight:600;color:var(--color-text);font-size:var(--font-size-sm);min-width:120px}.leave-type-badge{display:inline-flex;align-items:center;padding:.3rem .85rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;white-space:nowrap;background:var(--color-border-light);color:var(--color-text-secondary)}.leave-type-badge.leave-type-vacation{background:#dbeafe;color:#1e40af}.leave-type-badge.leave-type-sick-leave{background:#fef3c7;color:#92400e}.leave-type-badge.leave-type-pto{background:#d1fae5;color:#065f46}.leave-type-badge.leave-type-leave{background:var(--color-border-light);color:var(--color-text-secondary)}.btn-schedule-leave{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:var(--color-primary);color:#fff;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);transition:all .2s ease;border:none;cursor:pointer}.btn-schedule-leave:hover{background:var(--color-primary-dark)!important;color:#fff!important;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-schedule-leave:active{transform:translateY(0)}.btn-schedule-leave svg{flex-shrink:0}.btn-cancel{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:500;cursor:pointer;transition:all .2s ease}.btn-cancel:hover{border-color:var(--color-danger);color:var(--color-danger);background:var(--color-danger-light)}.empty-state-card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--spacing-xl);text-align:center;box-shadow:var(--shadow-sm);border:1px dashed var(--color-border)}.empty-state-card .muted{margin-bottom:var(--spacing-md)}.empty-state-card .btn-schedule-leave{margin-top:var(--spacing-sm)}.download-dropdown-container{position:relative}.download-dropdown{position:absolute;bottom:100%;left:0;margin-bottom:var(--spacing-xs);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;min-width:140px;overflow:hidden}.download-dropdown button{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);text-align:left;background:none;border:none;font-size:var(--font-size-sm);color:var(--color-text);cursor:pointer;transition:background var(--transition-fast)}.download-dropdown button:hover{background:var(--color-primary-light);color:var(--color-primary)}.download-dropdown button:not(:last-child){border-bottom:1px solid var(--color-border-light)}.modal-content.timesheet-preview-modal{width:95vw!important;max-width:1400px!important;height:90vh!important;max-height:90vh!important;display:flex;flex-direction:column;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 25px 50px #00000040;padding:0}.modal-content.timesheet-preview-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 32px;border-bottom:1px solid var(--color-border);flex-shrink:0}.modal-content.timesheet-preview-modal .modal-header h2{margin:0;font-size:var(--font-size-lg)}.modal-content.timesheet-preview-modal .modal-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;border:none;background:var(--color-border-light);color:var(--color-text);font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:10}.modal-content.timesheet-preview-modal .modal-close:hover{background:var(--color-error);color:#fff}.modal-content.timesheet-preview-modal .modal-body{flex:1;overflow-y:auto;overflow-x:auto;padding:24px 32px}.modal-content.timesheet-preview-modal .modal-footer{display:flex;justify-content:space-between;align-items:center;padding:16px 32px;border-top:1px solid var(--color-border);background:var(--color-bg);flex-shrink:0}.modal-content.timesheet-preview-modal .modal-footer .download-buttons{display:flex;gap:var(--spacing-sm)}.timesheet-document{background:#fff;padding:0;min-width:600px}.timesheet-branded-header{padding:var(--spacing-lg) var(--spacing-xl);color:#fff;margin-bottom:0}.branded-header-content{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-lg)}.company-logo{max-height:50px;max-width:180px;object-fit:contain}.company-name-text{font-size:var(--font-size-xl);font-weight:700;letter-spacing:1px}.timesheet-title{font-size:var(--font-size-lg);font-weight:600;letter-spacing:3px;text-transform:uppercase;opacity:.9}.timesheet-header{text-align:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-secondary)}.timesheet-header h3{font-size:var(--font-size-xl);font-weight:700;letter-spacing:2px;color:var(--color-secondary);margin-bottom:var(--spacing-lg)}.timesheet-meta{display:flex;justify-content:flex-start;gap:var(--spacing-2xl);flex-wrap:wrap;padding:var(--spacing-lg) var(--spacing-xl);margin-bottom:var(--spacing-md);background:#f8fafc;border-bottom:1px solid var(--color-border)}.timesheet-meta .meta-row{display:flex;gap:var(--spacing-sm);align-items:center}.timesheet-meta .meta-label{font-weight:600;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.timesheet-meta .meta-value{font-weight:500;font-size:var(--font-size-base);color:var(--color-text)}.timesheet-footer{text-align:center;padding:var(--spacing-lg) var(--spacing-xl);margin-top:var(--spacing-lg);border-top:1px solid var(--color-border);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.timesheet-table-container{padding:0 var(--spacing-xl);overflow-x:auto}.timesheet-table{width:100%;margin:0 0 var(--spacing-lg);border-collapse:collapse;font-size:var(--font-size-base);table-layout:auto}.timesheet-table th,.timesheet-table td{padding:var(--spacing-md) var(--spacing-lg);text-align:left;border:1px solid var(--color-border);white-space:nowrap}.timesheet-table th{background:var(--color-secondary);color:#fff;font-weight:600;text-transform:uppercase;font-size:var(--font-size-sm);letter-spacing:.5px;position:sticky;top:0;z-index:1}.timesheet-table th:nth-child(1),.timesheet-table td:nth-child(1){width:30%;min-width:140px}.timesheet-table th:nth-child(2),.timesheet-table td:nth-child(2){width:15%;min-width:80px}.timesheet-table th:nth-child(3),.timesheet-table td:nth-child(3){width:20%;min-width:100px;text-align:right}.timesheet-table th:nth-child(4),.timesheet-table td:nth-child(4){width:35%;min-width:120px}.timesheet-table tbody tr:nth-child(odd){background:#fff}.timesheet-table tbody tr:nth-child(2n){background:#f8fafc}.timesheet-table tbody tr:hover{background:var(--color-primary-lighter)}.timesheet-table .leave-row{background:var(--color-warning-light)!important}.timesheet-table .weekend-row{background:#f1f5f9;color:var(--color-text-secondary)}.timesheet-table .weekend-type{color:var(--color-text-muted);font-style:italic}.timesheet-table .no-entry{color:var(--color-text-muted)}.timesheet-table tfoot .summary-row{background:var(--color-secondary)!important;color:#fff}.timesheet-table tfoot .summary-row td{border-color:var(--color-secondary);font-size:var(--font-size-base)}.timesheet-summary-box{background:var(--color-border-light);border-radius:var(--radius-md);padding:var(--spacing-lg) var(--spacing-xl);border:2px solid var(--color-primary);margin:var(--spacing-lg) var(--spacing-xl)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--spacing-md)}.summary-stat{text-align:center;padding:var(--spacing-sm)}.summary-stat .stat-label{display:block;font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-xs)}.summary-stat .stat-value{display:block;font-size:var(--font-size-lg);font-weight:700;color:var(--color-text)}.summary-stat.leave-stat .stat-value{color:var(--color-warning-dark)}.modal-footer{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border);background:var(--color-border-light)}.download-buttons{display:flex;gap:var(--spacing-sm)}@media(max-width:768px){.modal-content.timesheet-preview-modal{width:100vw!important;height:100vh!important;max-width:100vw!important;max-height:100vh!important;border-radius:0}.modal-content.timesheet-preview-modal .modal-header{padding:12px 16px}.modal-content.timesheet-preview-modal .modal-header h2{font-size:var(--font-size-base)}.modal-content.timesheet-preview-modal .modal-close{width:32px;height:32px;font-size:20px;top:8px;right:8px}.modal-content.timesheet-preview-modal .modal-body{-webkit-overflow-scrolling:touch;padding:16px}.modal-content.timesheet-preview-modal .modal-footer{padding:12px 16px;flex-wrap:wrap;gap:var(--spacing-sm)}.modal-content.timesheet-preview-modal .modal-footer .download-buttons{flex:1}.timesheet-document{min-width:500px}.timesheet-branded-header{padding:var(--spacing-md)}.branded-header-content{flex-direction:column;text-align:center;gap:var(--spacing-sm)}.timesheet-title{font-size:var(--font-size-base)}.timesheet-meta{padding:var(--spacing-md);gap:var(--spacing-md);flex-direction:column}.timesheet-table{font-size:var(--font-size-sm)}.timesheet-table th,.timesheet-table td{padding:var(--spacing-sm)}.timesheet-summary-box{margin:var(--spacing-md);padding:var(--spacing-md)}.summary-grid{grid-template-columns:repeat(2,1fr)}}.analytics-page .page-header{margin-bottom:var(--spacing-lg)}.analytics-page .page-header h1{margin-bottom:0}.dashboard-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:2px solid #e5e7eb}.dashboard-tabs button{padding:12px 24px;background:none;border:none;font-size:15px;font-weight:500;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}.dashboard-tabs button:hover{color:#111827}.dashboard-tabs button.active{color:#4f46e5;border-bottom-color:#4f46e5}.dashboard-section-divider{margin-top:var(--spacing-lg);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-border)}.dashboard-section-divider:first-child{margin-top:0}.section-title-large{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);margin:0}.analytics-tabs{display:flex!important;gap:12px!important;margin-bottom:24px!important;flex-wrap:wrap}.analytics-tabs button{padding:12px 24px!important;font-size:14px!important;font-weight:500!important;border-radius:var(--radius-md)!important;background:var(--color-bg-card)!important;border:1px solid var(--color-border)!important;color:var(--color-text-secondary)!important;cursor:pointer;transition:all var(--transition-base);box-shadow:none!important}.analytics-tabs button:hover{background:var(--color-border-light)!important;color:var(--color-text)!important;transform:none!important}.analytics-tabs button.active{background:var(--color-primary)!important;border-color:var(--color-primary)!important;color:#fff!important}.report-form{background:var(--color-bg-card);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-top:var(--spacing-md)}.radio-group{display:flex;gap:var(--spacing-lg);padding-top:var(--spacing-sm)}.radio-label{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);font-weight:400;color:var(--color-text);cursor:pointer}.radio-label input[type=radio]{width:auto;margin:0;cursor:pointer}.custom-reports-section{display:flex;flex-direction:column;gap:24px}.saved-reports-section{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.saved-reports-section h3{font-size:1rem;font-weight:600;margin:0 0 16px;color:var(--color-text)}.saved-reports-grid{display:flex;flex-wrap:wrap;gap:12px}.saved-report-card{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 16px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:200px}.saved-report-info{display:flex;flex-direction:column;gap:2px}.saved-report-name{font-weight:500;font-size:14px;color:var(--color-text)}.saved-report-type{font-size:12px;color:var(--color-text-muted)}.saved-report-actions{display:flex;gap:8px;align-items:center}.saved-report-actions .btn-ghost{padding:6px;color:var(--color-text-muted)}.saved-report-actions .btn-ghost:hover{color:var(--color-danger)}.custom-reports-layout{display:grid;grid-template-columns:280px 1fr;gap:24px;min-height:500px}@media(max-width:900px){.custom-reports-layout{grid-template-columns:1fr}}.report-templates-sidebar{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);height:fit-content}.report-templates-sidebar h3{font-size:1rem;font-weight:600;margin:0 0 16px;color:var(--color-text)}.template-list{display:flex;flex-direction:column;gap:8px}.template-card{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:var(--radius-md);background:var(--color-bg);border:2px solid transparent;cursor:pointer;transition:all .2s}.template-card:hover{border-color:var(--color-primary-light);background:var(--color-primary-lighter)}.template-card.selected{border-color:var(--color-primary);background:var(--color-primary-lighter)}.template-icon-wrapper{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-light);border-radius:var(--radius-md);flex-shrink:0}.template-icon{width:20px;height:20px;color:var(--color-primary)}.template-info{display:flex;flex-direction:column;gap:2px;min-width:0}.template-name{font-weight:600;font-size:14px;color:var(--color-text)}.template-description{font-size:12px;color:var(--color-text-muted);line-height:1.4}.report-content{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.report-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 20px;color:var(--color-text-muted)}.report-empty-state svg{color:var(--color-border);margin-bottom:16px}.report-empty-state h3{margin:0 0 8px;font-size:1.1rem;font-weight:600;color:var(--color-text)}.report-empty-state p{margin:0;font-size:14px}.report-header{margin-bottom:20px}.report-header h3{margin:0 0 4px;font-size:1.25rem;font-weight:600;color:var(--color-text)}.report-header p{margin:0;font-size:14px;color:var(--color-text-muted)}.report-filters{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;padding:16px;background:var(--color-bg);border-radius:var(--radius-md);margin-bottom:20px}.report-filters .filter-field{display:flex;flex-direction:column;gap:4px;min-width:140px}.report-filters .filter-field label{font-size:12px;font-weight:500;color:var(--color-text-muted)}.report-filters .filter-field input,.report-filters .filter-field select{padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:13px;background:#fff}.report-filters .filter-field input:focus,.report-filters .filter-field select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.report-filters .filter-actions{margin-left:auto}.report-results{display:flex;flex-direction:column;gap:20px}.report-summary-cards{display:flex;flex-wrap:wrap;gap:12px}.report-summary-cards .summary-card{flex:1;min-width:120px;max-width:180px;padding:16px;background:linear-gradient(135deg,var(--color-primary-lighter) 0%,var(--color-bg) 100%);border:1px solid var(--color-primary-light);border-radius:var(--radius-md)}.report-summary-cards .summary-card-label{font-size:11px;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.report-summary-cards .summary-card-value{font-size:1.25rem;font-weight:700;color:var(--color-primary)}.report-table{width:100%;font-size:13px}.report-table th{background:var(--color-bg);padding:10px 12px;font-weight:600;color:var(--color-text);border-bottom:2px solid var(--color-border)}.report-table td{padding:10px 12px;border-bottom:1px solid var(--color-border-light)}.report-table tbody tr:hover{background:var(--color-primary-lighter)}.report-pagination{display:flex;align-items:center;justify-content:center;gap:16px;padding-top:16px;border-top:1px solid var(--color-border-light)}.pagination-info{font-size:13px;color:var(--color-text-muted)}.report-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:16px;border-top:1px solid var(--color-border-light)}.report-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--color-text-muted)}.report-loading .spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}.checkin-page{max-width:800px}.checkin-form{background:var(--color-bg-card);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;background:var(--color-border);border-radius:var(--radius-md);overflow:hidden;margin-bottom:var(--spacing-lg)}.calendar-header{background:var(--color-secondary);color:#fff;padding:var(--spacing-sm);text-align:center;font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase}.calendar-day{background:var(--color-bg-card);padding:var(--spacing-sm);min-height:80px;cursor:pointer;transition:background var(--transition-fast)}.calendar-day:hover{background:var(--color-primary-lighter)}.calendar-day.today{background:var(--color-primary-light)}.calendar-day.submitted{background:var(--color-success-light)}.calendar-day.approved{background:#bbf7d0}.calendar-day.rejected{background:var(--color-danger-light)}.calendar-day.disabled{background:var(--color-border-light);cursor:not-allowed;opacity:.5}.day-number{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text)}.day-status{font-size:var(--font-size-xs);margin-top:var(--spacing-xs)}.preview-card{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-xl);max-width:500px;margin:0 auto}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.preview-header h2{margin:0;font-size:1.25rem;font-weight:600}.preview-worker{background:var(--color-bg);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md)}.preview-worker-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.preview-worker-name{font-weight:600;color:var(--color-text)}.preview-details{display:flex;flex-direction:column;gap:0;margin-bottom:var(--spacing-lg)}.preview-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) 0;border-bottom:1px solid var(--color-border-light)}.preview-row:last-child{border-bottom:none}.preview-label{font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:500;min-width:80px}.preview-value{font-size:var(--font-size-sm);color:var(--color-text);text-align:right}.preview-value.highlight{font-weight:600;font-size:1rem;color:var(--color-primary)}.leave-indicator{background:var(--color-warning-light);color:var(--color-warning-dark);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500}.preview-review-section{background:var(--color-bg);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);border:1px solid var(--color-border)}.preview-review-section h3{margin:0 0 var(--spacing-md) 0;font-size:1rem;font-weight:600;color:var(--color-text)}.preview-review-form textarea{width:100%;padding:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);resize:vertical;margin-bottom:var(--spacing-md)}.preview-review-form textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.preview-review-actions{display:flex;gap:var(--spacing-sm)}.btn-approve{background:var(--color-success);color:#fff}.btn-approve:hover{background:var(--color-success-dark);color:#fff;text-decoration:none}.btn-reject{background:var(--color-danger);color:#fff}.btn-reject:hover{background:var(--color-danger-dark);color:#fff;text-decoration:none}.btn-cancel-leave{background:transparent;border:1px solid var(--color-danger);color:var(--color-danger)}.btn-cancel-leave:hover{background:var(--color-danger-light)}.preview-footer{padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.preview-footer .btn{width:100%}.preview-approval-note{background:var(--color-primary-lighter);border:1px solid var(--color-primary-light);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.preview-approval-note p{margin:0;font-size:var(--font-size-sm);color:var(--color-text)}.preview-approval-note a{color:var(--color-primary);font-weight:500}.checkin-note{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.checkin-note a{color:var(--color-primary);font-weight:500}.settings-page{max-width:800px}.settings-section{background:var(--color-bg-card);padding:24px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:24px}.settings-section h2{margin-bottom:20px!important;padding-bottom:12px;border-bottom:1px solid var(--color-border-light)}.settings-field{margin-bottom:24px}.settings-field:last-child{margin-bottom:0}.settings-field>label{display:block;font-weight:600;color:var(--color-text);margin-bottom:4px}.settings-field .field-description{font-size:13px;color:var(--color-text-secondary);margin-bottom:12px;margin-top:0}.settings-field select,.settings-field input[type=number],.settings-field input[type=time]{min-height:40px}.settings-actions{margin-top:8px}.checkbox-group{display:flex;flex-wrap:wrap;gap:12px}.checkbox-label{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--color-border-light);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-weight:500;color:var(--color-text-secondary)}.checkbox-label:hover{background:var(--color-primary-light)}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-label:has(input:checked){background:var(--color-primary-light);color:var(--color-primary)}.toggle-switch{display:flex;align-items:center;gap:12px;cursor:pointer}.toggle-switch input{display:none}.toggle-slider{position:relative;width:48px;height:26px;background:var(--color-border);border-radius:13px;transition:background var(--transition-fast)}.toggle-slider:before{content:"";position:absolute;width:20px;height:20px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform var(--transition-fast);box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-slider{background:var(--color-primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}.toggle-label{font-weight:500;color:var(--color-text-secondary)}.toggle-switch input:checked~.toggle-label{color:var(--color-primary)}.settings-field-toggle{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg)}.settings-field-toggle .settings-field-info{flex:1}.settings-field-toggle .settings-field-info label{display:block;margin-bottom:var(--spacing-xs)}.toggle-wrapper{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.toggle-status{font-weight:500;font-size:var(--font-size-sm);color:var(--color-text-secondary);min-width:60px}.branding-section{background:var(--color-bg-card);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-xl)}.branding-section h2{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border-light)}.branding-preview{background:var(--color-border-light);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-top:var(--spacing-lg)}.branding-preview-header{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.color-input-wrapper{display:flex;align-items:center;gap:var(--spacing-sm)}.color-swatch{width:40px;height:40px;border-radius:var(--radius-md);border:2px solid var(--color-border);cursor:pointer}.color-input{width:120px}.logo-preview{width:100px;height:100px;border-radius:var(--radius-md);border:2px dashed var(--color-border);display:flex;align-items:center;justify-content:center;background:var(--color-border-light);overflow:hidden}.logo-preview img{max-width:100%;max-height:100%;object-fit:contain}.logo-preview-placeholder{color:var(--color-text-muted);font-size:var(--font-size-xs);text-align:center}.muted{color:var(--color-text-muted);font-size:var(--font-size-sm)}.section{margin-bottom:32px!important}.section>h2{margin-bottom:16px!important}.section+.section{margin-top:32px!important}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.section-header h2,.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mt-0{margin-top:0}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.page-subtitle,.welcome-text{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.text-center{text-align:center}.text-right{text-align:right}.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.mt-md{margin-top:var(--spacing-md)}.mb-md{margin-bottom:var(--spacing-md)}.notif-container{position:relative}.notif-bell{background:none;border:none;padding:var(--spacing-sm);cursor:pointer;position:relative;box-shadow:none;color:inherit;border-radius:var(--radius-md);transition:all .2s ease}.notif-bell:hover{box-shadow:none;background:#ffffff1a}.notif-badge{position:absolute;top:2px;right:2px;background:var(--color-danger);color:#fff;font-size:10px;font-weight:600;min-width:16px;height:16px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;line-height:1}.notif-dropdown{position:absolute;top:100%;left:0;width:320px;max-height:400px;overflow-y:auto;background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);border:1px solid var(--color-border);z-index:1000;margin-top:var(--spacing-xs)}.sidebar-header-actions .notif-dropdown{left:0;right:auto}.top-bar .notif-dropdown{left:auto;right:0}.notif-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid var(--color-border);font-weight:600;color:var(--color-text)}.notif-mark-all{background:none;border:none;color:var(--color-primary);font-size:var(--font-size-xs);cursor:pointer;padding:0;box-shadow:none}.notif-mark-all:hover{text-decoration:underline;box-shadow:none}.notif-list{max-height:320px;overflow-y:auto}.notif-empty{padding:var(--spacing-xl);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}.notif-item{padding:var(--spacing-md);border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background var(--transition-fast)}.notif-item:hover{background:var(--color-primary-lighter)}.notif-unread{background:var(--color-primary-light)}.notif-unread:hover{background:var(--color-primary-medium)}.notif-item:last-child{border-bottom:none}.notif-message{font-size:var(--font-size-sm);color:var(--color-text);line-height:1.4;margin-bottom:var(--spacing-xs)}.notif-time{font-size:var(--font-size-xs);color:var(--color-text-muted)}.notif-clickable{cursor:pointer;position:relative}.notif-clickable:after{content:"→";position:absolute;right:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--color-text-muted);font-size:var(--font-size-sm);opacity:0;transition:opacity var(--transition-fast)}.notif-clickable:hover:after{opacity:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000;display:flex;align-items:center;justify-content:center;z-index:300;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);animation:modalOverlayIn .25s ease-out forwards}@keyframes modalOverlayIn{0%{background:#0000;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}}.modal-content{background:var(--color-bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:modalContentIn .3s ease-out}@keyframes modalContentIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.modal-header h2{margin:0}.modal-close{background:none;border:none;padding:var(--spacing-xs);cursor:pointer;color:var(--color-text-muted);box-shadow:none}.modal-close:hover{color:var(--color-text);box-shadow:none}.modal-body{padding:var(--spacing-lg)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid var(--color-border)}.confirm-modal{max-width:400px;padding:var(--spacing-xl)}.modal-title{margin:0 0 var(--spacing-md) 0;font-size:1.25rem;font-weight:600;color:var(--color-text)}.modal-message{margin:0 0 var(--spacing-xl) 0;color:var(--color-text-muted);line-height:1.5}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm)}.schedule-leave-modal{max-width:480px;padding:0}.schedule-leave-modal .modal-header{padding:var(--spacing-lg) var(--spacing-xl)}.schedule-leave-modal .checkin-field{padding:0 var(--spacing-xl);margin-bottom:var(--spacing-lg)}.schedule-leave-modal .checkin-field:first-of-type{margin-top:var(--spacing-lg)}.schedule-leave-modal .checkin-field label{display:block;font-weight:500;color:var(--color-text);margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm)}.schedule-leave-modal .checkin-field label .muted{font-weight:400;font-size:var(--font-size-xs)}.schedule-leave-modal .error-msg,.schedule-leave-modal .success-msg{margin:0 var(--spacing-xl) var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.schedule-leave-modal .error-msg{background:var(--color-danger-light);color:var(--color-danger)}.schedule-leave-modal .success-msg{background:var(--color-success-light);color:var(--color-success)}.schedule-leave-modal .selected-count{margin:0 var(--spacing-xl) var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-primary-lighter);color:var(--color-primary);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500}.schedule-leave-modal .checkin-submit-btn{margin:var(--spacing-md) var(--spacing-xl) var(--spacing-xl);width:calc(100% - var(--spacing-xl) * 2)}.leave-options{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.leave-btn{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .2s ease}.leave-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-lighter)}.leave-btn-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.leave-btn-active:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);color:#fff}.mini-calendar{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md)}.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.cal-nav{background:none;border:1px solid var(--color-border);border-radius:var(--radius-md);width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text);font-size:1.25rem;transition:all .2s ease;box-shadow:none}.cal-nav:hover{background:var(--color-border-light);border-color:var(--color-primary);color:var(--color-primary);box-shadow:none}.cal-month-label{font-weight:600;color:var(--color-text);font-size:var(--font-size-base)}.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:var(--spacing-xs)}.cal-weekday{text-align:center;font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);padding:var(--spacing-xs) 0}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);font-size:var(--font-size-sm);transition:all .15s ease}.cal-day-empty{background:transparent}.cal-day-past{color:var(--color-text-lighter);cursor:not-allowed}.cal-day-today{border:2px solid var(--color-primary);font-weight:600}.cal-day-selectable{cursor:pointer;color:var(--color-text)}.cal-day-selectable:hover{background:var(--color-primary-lighter);color:var(--color-primary)}.cal-day-selected{background:var(--color-primary)!important;color:#fff!important;font-weight:600}.cal-day-selected:hover{background:var(--color-primary-dark)!important}.cal-day-num{pointer-events:none}.cal-day-manager-leave{background:#e5e7eb!important;position:relative}.cal-day-manager-leave.cal-day-selectable:hover{background:#d1d5db!important}.cal-day-manager-leave-pending{background:repeating-linear-gradient(45deg,#f3f4f6,#f3f4f6 3px,#d1d5db 3px,#d1d5db 6px)!important;position:relative}.cal-day-manager-leave-pending.cal-day-selectable:hover{background:repeating-linear-gradient(45deg,#e5e7eb,#e5e7eb 3px,#9ca3af 3px,#9ca3af 6px)!important}.cal-day-manager-indicator{position:absolute;bottom:2px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:#6b7280}.cal-day-selected .cal-day-manager-indicator{background:#ffffffb3}.checkin-container{max-width:540px;margin:0 auto;padding:var(--spacing-lg)}.checkin-header{margin-bottom:var(--spacing-lg)}.checkin-header h1{margin:0 0 var(--spacing-xs) 0;font-size:1.5rem;font-weight:600}.checkin-header .muted{margin:0}.checkin-steps{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl);padding:var(--spacing-md) 0}.checkin-step{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:500}.checkin-step.active{color:var(--color-primary)}.checkin-step.active .step-dot{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.step-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:600;background:var(--color-bg);color:var(--color-text-muted)}.step-line{width:40px;height:2px;background:var(--color-border)}.checkin-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl)}.checkin-calendar{max-width:320px;margin:0 auto var(--spacing-lg);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md)}.checkin-calendar .cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm)}.checkin-calendar .cal-nav{width:28px;height:28px;padding:0;font-size:1rem;background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:none}.checkin-calendar .cal-nav:hover{background:var(--color-border-light);border-color:var(--color-primary);box-shadow:none}.checkin-calendar .cal-month-label{font-size:var(--font-size-sm);font-weight:600}.checkin-calendar .cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:var(--spacing-xs)}.checkin-calendar .cal-weekday{text-align:center;font-size:11px;font-weight:600;color:var(--color-text-muted);padding:4px 0}.checkin-calendar .cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.checkin-calendar .cal-day{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:13px;cursor:pointer;position:relative;transition:all .15s ease}.checkin-calendar .cal-day-empty{cursor:default}.checkin-calendar .cal-day-selectable:hover{background:var(--color-primary-lighter)}.checkin-calendar .cal-day-today{border:2px solid var(--color-primary);font-weight:600}.checkin-calendar .cal-day-selected{background:var(--color-primary)!important;color:#fff!important;font-weight:600}.checkin-calendar .cal-day-has-entry{background:var(--color-border-light)}.checkin-calendar .cal-dot{position:absolute;bottom:3px;left:50%;transform:translate(-50%);width:5px;height:5px;border-radius:50%}.checkin-calendar .cal-dot-submitted{background:var(--color-warning)}.checkin-calendar .cal-dot-approved{background:var(--color-success)}.checkin-calendar .cal-dot-rejected{background:var(--color-danger)}.checkin-calendar .cal-day-disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.checkin-calendar .cal-hint{text-align:center;font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--spacing-sm);margin-bottom:0}.edit-mode-notice{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);background:var(--color-warning-light, #fef3c7);border:1px solid var(--color-warning, #f59e0b);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);font-size:var(--font-size-sm);color:var(--color-warning-dark, #92400e)}.edit-mode-notice .btn{flex-shrink:0}.edit-date-display{padding:var(--spacing-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);color:var(--color-text)}.btn-back-link{display:block;width:100%;padding:var(--spacing-md);margin-top:var(--spacing-md);background:none;border:none;color:var(--color-text-muted);font-size:var(--font-size-sm);cursor:pointer;text-align:center;transition:color .2s ease;box-shadow:none}.btn-back-link:hover{color:var(--color-primary);box-shadow:none}.checkin-field{margin-bottom:var(--spacing-lg)}.checkin-field label{display:block;font-weight:500;font-size:var(--font-size-sm);color:var(--color-text);margin-bottom:var(--spacing-sm)}.checkin-field select,.checkin-field input[type=date],.checkin-field input[type=text]{width:100%;padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);background:var(--color-bg);color:var(--color-text)}.checkin-field select:focus,.checkin-field input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-lighter)}.checkin-row{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.checkin-row .checkin-field{flex:1;margin-bottom:0}.checkin-hours{display:flex;justify-content:space-between;align-items:center;background:var(--color-primary-lighter);border-radius:var(--radius-md);padding:var(--spacing-md) var(--spacing-lg);margin-bottom:var(--spacing-lg)}.hours-label{font-weight:500;color:var(--color-text);font-size:var(--font-size-sm)}.hours-value{font-weight:700;font-size:1.25rem;color:var(--color-primary)}.lunch-options{display:flex;gap:var(--spacing-sm)}.lunch-btn{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .2s ease}.lunch-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.lunch-btn-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.lunch-btn-active:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);color:#fff}.client-chips{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.client-chip{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text);font-size:var(--font-size-sm);cursor:pointer;transition:all .2s ease}.client-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.client-chip-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.candidate-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.candidate-entry{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md)}.candidate-entry-row{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.candidate-entry-row:last-child{margin-bottom:0}.candidate-entry-row input,.candidate-entry-row select{flex:1;padding:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.candidate-remove-btn{background:none;border:1px solid var(--color-danger-light);color:var(--color-danger);border-radius:var(--radius-sm);width:32px;min-width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.25rem;box-shadow:none}.candidate-remove-btn:hover{background:var(--color-danger-light);box-shadow:none}.candidate-add-btn{background:none;border:1px dashed var(--color-border);color:var(--color-text-muted);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);transition:all .2s ease;width:100%;margin-top:var(--spacing-sm);box-shadow:none}.candidate-add-btn:hover{border-color:var(--color-primary);color:var(--color-primary);box-shadow:none}.checkin-next-btn,.checkin-submit-btn{width:100%;padding:var(--spacing-md) var(--spacing-lg);margin-top:var(--spacing-md)}.btn-back{background:none;border:none;color:var(--color-text-muted);font-size:var(--font-size-sm);cursor:pointer;padding:0;margin-bottom:var(--spacing-lg);display:inline-flex;align-items:center;gap:var(--spacing-xs);box-shadow:none}.btn-back:hover{color:var(--color-primary);box-shadow:none}.cal-day-has-entry{position:relative}.cal-dot{position:absolute;bottom:4px;left:50%;transform:translate(-50%);width:6px;height:6px;border-radius:50%}.cal-dot-submitted{background:var(--color-warning)}.cal-dot-approved{background:var(--color-success)}.cal-dot-rejected{background:var(--color-danger)}.cal-day{position:relative;flex-direction:column}.inline-edit-actions{display:flex;gap:var(--spacing-xs);align-items:center}.inline-edit-actions button{padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem}.row-modified{background:var(--color-primary-lighter)!important}.row-modified td{background:inherit}.team-page{max-width:100%}.team-invite-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.team-invite-card h3{margin:0 0 var(--spacing-md) 0;font-size:1.1rem}.team-filters{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md);flex-wrap:wrap}.search-box{flex:1;min-width:200px}.search-box input{width:100%}.filter-group{display:flex;gap:var(--spacing-sm)}.filter-group select{min-width:120px}.team-results-info{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}.team-cards{display:flex;flex-direction:column;gap:var(--item-gap)}.team-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow var(--transition-fast)}.team-card:hover{box-shadow:var(--shadow-sm)}.team-card-inactive{opacity:.7;background:var(--color-bg)}.team-card-modified{border-color:var(--color-primary);background:var(--color-primary-lighter)}.team-card-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);cursor:pointer;-webkit-user-select:none;user-select:none}.team-card-header:hover{background:var(--color-bg)}.team-card-avatar{width:40px;height:40px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--font-size-sm);flex-shrink:0}.team-card-info{flex:1;min-width:0}.team-card-name{font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.team-card-email{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.team-card-badges{display:flex;align-items:center;gap:var(--spacing-xs);flex-shrink:0}.team-card-expand{color:var(--color-text-muted);font-size:.75rem;flex-shrink:0}.team-card-body{padding:var(--spacing-md);padding-top:0;border-top:1px solid var(--color-border);margin-top:0;padding-top:var(--spacing-md)}.team-card-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.team-card-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.team-card-field label{font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.team-card-field select,.team-card-field input{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm)}.team-card-field .field-value{padding:var(--spacing-xs) 0;font-size:var(--font-size-sm);color:var(--color-text);text-transform:capitalize}.team-card-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.status-dot-success{background:var(--color-success)}.status-dot-warning{background:var(--color-warning)}.badge-inactive{background:var(--color-text-muted);color:#fff}.badge-period{background:#e0e7ff;color:#4338ca;font-size:.7rem}.badge-department{background:#fef3c7;color:#92400e;font-size:.7rem}.badge-location{background:#dbeafe;color:#1e40af;font-size:.7rem}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.pagination-info{color:var(--color-text-muted);font-size:var(--font-size-sm)}.invitations-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.invitation-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-sm)}.invitation-info{display:flex;align-items:center;gap:var(--spacing-sm)}.invitation-email{font-weight:500}.invitation-meta{display:flex;gap:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-muted)}@media(max-width:1024px){.main-content{max-width:100%;padding:var(--spacing-lg)}}@media(max-width:768px){.sidebar{transform:translate(-100%);transition:transform var(--transition-slow) cubic-bezier(.4,0,.2,1)}.sidebar.open{transform:translate(0)}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:90;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.main-content{margin-left:0;padding-top:80px}.top-bar{display:flex}.stats-row{grid-template-columns:repeat(2,1fr)}.form-row{flex-direction:column}.invite-form{flex-direction:column;align-items:stretch}.invite-form input,.invite-form select{width:100%;min-width:0}.approvals-page .page-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.period-card-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.period-summary{flex-wrap:wrap;gap:var(--spacing-sm)}.bulk-actions{flex-wrap:wrap}.notifications-dropdown{width:calc(100vw - 32px);right:-100px}.table-scroll{margin:0 calc(-1 * var(--spacing-md));padding:0 var(--spacing-md)}.team-filters{flex-direction:column}.filter-group{width:100%}.filter-group select{flex:1;min-width:0}.team-card-header{flex-wrap:wrap}.team-card-info{flex:1 1 calc(100% - 60px);order:1}.team-card-avatar{order:0}.team-card-badges{order:3;width:100%;margin-top:var(--spacing-xs)}.team-card-expand{order:2;margin-left:auto}.team-card-fields{grid-template-columns:1fr 1fr}.invitation-card{flex-direction:column;align-items:flex-start}}@media(max-width:480px){.stats-row{grid-template-columns:1fr}.login-card{padding:var(--spacing-lg);margin:var(--spacing-md)}.modal-content{margin:var(--spacing-md);max-width:calc(100% - 32px)}.team-card-fields{grid-template-columns:1fr}.team-card-actions{flex-direction:column}.team-card-actions button{width:100%}.pagination{flex-direction:column;gap:var(--spacing-sm)}}@media(max-width:768px){body{-webkit-text-size-adjust:100%}h1,.page-title{font-size:1.5rem;margin-bottom:var(--spacing-md)}h2,.section-heading,.section-title{font-size:1.125rem;margin-bottom:var(--spacing-sm)}h3,.card-title{font-size:1rem}h4{font-size:.9375rem}label,.label,.form-label{font-size:.8125rem}p,.body-text{font-size:.9375rem}small,.small-text,.caption,.muted{font-size:.75rem}.stat-number{font-size:1.75rem}.text-xs{font-size:.6875rem}.text-sm{font-size:.75rem}.text-base{font-size:.9375rem}.text-lg{font-size:1rem}.text-xl{font-size:1.125rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.75rem}input,select,textarea{font-size:16px!important;min-height:48px;padding:.75rem 1rem}textarea{min-height:100px}label{font-size:var(--font-size-base);margin-bottom:var(--spacing-sm)}button,.btn{min-height:44px;padding:.75rem 1.25rem;font-size:var(--font-size-base)}.btn-sm{min-height:40px;padding:.5rem 1rem}.form-actions{flex-direction:column;gap:var(--spacing-md)}.form-actions button{width:100%}.nav-links a{padding:1rem var(--spacing-lg);font-size:var(--font-size-base)}.sidebar.open{width:280px}.hamburger{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.top-bar{height:64px}.main-content{padding:var(--spacing-md);padding-top:80px}.notification-bell{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.page-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.page-header .header-actions{width:100%;display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.page-header .header-actions button{flex:1;min-width:120px}}@media(max-width:768px){.modal-overlay{align-items:flex-end}.modal-content{max-width:100%;max-height:90vh;margin:0;border-radius:var(--radius-xl) var(--radius-xl) 0 0;animation:modalSlideUp .3s ease-out;overflow-y:auto}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal-header{position:sticky;top:0;background:var(--color-bg-card);z-index:10;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border-light)}.modal-header h2{font-size:var(--font-size-lg)}.modal-close{min-width:44px;min-height:44px;font-size:1.5rem}.modal-body{padding:var(--spacing-lg)}.modal-footer{position:sticky;bottom:0;background:var(--color-bg-card);padding:var(--spacing-lg);border-top:1px solid var(--color-border-light)}.modal-actions{flex-direction:column-reverse;gap:var(--spacing-md)}.modal-actions button{width:100%;min-height:48px}.confirm-modal{padding:var(--spacing-xl) var(--spacing-lg)}.modal-title{font-size:var(--font-size-lg)}.modal-message{font-size:var(--font-size-base);line-height:1.6}.schedule-leave-modal{max-height:95vh}.schedule-leave-modal .modal-header{padding:var(--spacing-md) var(--spacing-lg)}}@media(max-width:768px){.stat-card{padding:var(--spacing-md)}.today-checkin-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md)}.today-checkin-details{padding:var(--spacing-md)}.today-checkin-row{padding:var(--spacing-sm) 0}.recent-timesheet-item{display:flex;flex-direction:column;align-items:stretch;gap:.75rem;padding:var(--card-padding-mobile)}.recent-timesheet-info{display:flex;flex-direction:row;justify-content:space-between;align-items:center;width:100%}.recent-timesheet-hours{text-align:right;min-width:auto}.recent-timesheet-status{display:flex;flex-direction:row;align-items:center;justify-content:space-between;width:100%;padding-top:.5rem;border-top:1px solid var(--color-border-light)}.rejection-reason{max-width:none;flex:1;margin-right:.5rem}.leave-balance-card{padding:var(--spacing-md)}.upcoming-leave-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.checkin-grouped-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.checkin-grouped-table table{min-width:600px}.leave-requests-section table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.leave-requests-section table{min-width:500px}}@media(max-width:768px){.checkin-container,.checkin-card{padding:var(--spacing-md)}.mini-calendar{padding:var(--spacing-sm)}.cal-grid{gap:var(--spacing-xs)}.cal-day{min-height:44px;min-width:44px;font-size:var(--font-size-base)}.cal-weekday{font-size:.7rem;padding:var(--spacing-xs) 0}.cal-nav{min-width:40px;min-height:40px}.cal-month{font-size:var(--font-size-base)}.leave-options{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.leave-btn{flex:1 1 calc(50% - var(--spacing-sm) / 2);min-height:48px;padding:var(--spacing-md);font-size:var(--font-size-base)}.checkin-row{flex-direction:column;gap:var(--spacing-md)}.checkin-field,.checkin-field select,.checkin-field input{width:100%}.lunch-options{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.lunch-btn{flex:1;min-height:48px;padding:var(--spacing-md)}.client-chips{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.client-chip{min-height:44px;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base)}.client-chip-remove{min-width:24px;min-height:24px}.submissions-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.submissions-table table{min-width:400px}.submissions-table input{min-width:100px}.candidate-entry{background:var(--color-bg);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.candidate-entry-row{flex-direction:column;gap:var(--spacing-sm)}.candidate-entry-row input,.candidate-entry-row select{width:100%}.candidate-remove-btn{align-self:flex-end;min-width:44px;min-height:44px}.candidate-add-btn{width:100%;min-height:48px;margin-top:var(--spacing-md)}.checkin-submit-btn,.checkin-next-btn,.checkin-actions button{width:100%;min-height:52px;font-size:var(--font-size-base)}.checkin-actions{flex-direction:column;gap:var(--spacing-md)}.preview-card{padding:var(--spacing-md)}.preview-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.preview-details{gap:var(--spacing-sm)}.preview-row{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.preview-actions{flex-direction:column;gap:var(--spacing-md)}.preview-actions button{width:100%;min-height:48px}}@media(max-width:768px){.approvals-page .page-header{flex-direction:column;align-items:stretch}.period-card{padding:var(--spacing-md)}.period-card-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.period-info{width:100%}.period-summary{flex-wrap:wrap;gap:var(--spacing-xs);width:100%}.summary-item{font-size:var(--font-size-sm)}.period-expand{min-width:44px;min-height:44px;align-self:flex-end}.period-card-body{padding:var(--spacing-md)}.entries-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.entries-table table{min-width:400px}.entries-table th,.entries-table td{padding:var(--spacing-sm);font-size:var(--font-size-sm)}.review-section{padding:var(--spacing-md)}.review-section textarea{min-height:80px}.review-actions{flex-direction:column;gap:var(--spacing-md)}.review-actions button{width:100%;min-height:48px}.bulk-actions{flex-direction:column;align-items:stretch;gap:var(--spacing-md);padding:var(--spacing-md)}.bulk-actions .bulk-comment{width:100%}.bulk-actions button{width:100%;min-height:48px}.approvals-filters{flex-direction:column;gap:var(--spacing-md)}.approvals-filters select,.approvals-filters input{width:100%}}@media(max-width:768px){.team-filters{flex-direction:column;gap:var(--spacing-md)}.team-filters .search-box{width:100%}.team-filters .filter-group{width:100%;flex-direction:column;gap:var(--spacing-sm)}.team-filters select{width:100%}.team-card{padding:var(--spacing-md)}.team-card-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.team-card-avatar{width:48px;height:48px;font-size:var(--font-size-lg)}.team-card-info{width:100%}.team-card-badges{width:100%;flex-wrap:wrap;gap:var(--spacing-xs)}.team-card-expand{min-width:44px;min-height:44px;position:absolute;top:var(--spacing-md);right:var(--spacing-md)}.team-card{position:relative}.team-card-fields{grid-template-columns:1fr;gap:var(--spacing-md)}.team-card-field input,.team-card-field select{min-height:48px}.team-card-actions{flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.team-card-actions button{width:100%;min-height:48px}.invite-form{flex-direction:column;gap:var(--spacing-md)}.invite-form input,.invite-form select,.invite-form button{width:100%}.invite-form button{min-height:48px}.invitation-card{flex-direction:column;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md)}.invitation-actions{width:100%;display:flex;gap:var(--spacing-sm)}.invitation-actions button{flex:1;min-height:44px}}@media(max-width:768px){.history-filters,.history-filters .filter-row{flex-direction:column;gap:var(--spacing-md)}.history-filters .filter-field,.history-filters input,.history-filters select{width:100%}.history-filters button{width:100%;min-height:48px}.chart-container{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.chart-wrapper{min-width:300px}.leaderboard-section{flex-direction:column;gap:var(--spacing-lg)}.leaderboard-card{width:100%}.download-dropdown{position:fixed;bottom:0;left:0;right:0;top:auto;border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:50vh;overflow-y:auto;animation:modalSlideUp .2s ease-out}.download-dropdown button{width:100%;min-height:48px;justify-content:flex-start}}@media(max-width:768px){.settings-section{padding:var(--spacing-md)}.settings-row{flex-direction:column;gap:var(--spacing-md)}.settings-row label,.settings-row input,.settings-row select{width:100%}.profile-form{padding:var(--spacing-md)}.profile-avatar-section{flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-md)}.profile-avatar{width:80px;height:80px;font-size:var(--font-size-2xl)}}@media(max-width:480px){.main-content{padding:var(--spacing-sm);padding-top:72px}.stats-row{gap:var(--spacing-sm)}.stat-card{padding:var(--spacing-sm) var(--spacing-md)}.stat-number{font-size:1.5rem}.stat-label{font-size:.75rem}.leave-btn{flex:1 1 100%}.today-checkin-row{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.card,.stat-card{padding:var(--card-padding-mobile)}.period-card{padding:var(--spacing-sm) var(--spacing-md)}.period-card-body{padding:var(--spacing-sm)}.cal-day{min-height:40px;min-width:40px;font-size:var(--font-size-sm)}.cal-weekday{font-size:.6rem}.modal-content{max-height:100vh;border-radius:0;min-height:100vh}.schedule-leave-modal{min-height:100vh}.info-bar{flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md)}.recent-timesheet-item{padding:.75rem 1rem}.rejection-reason{font-size:.75rem}}@media(max-width:375px){.main-content{padding:var(--spacing-xs);padding-top:68px}h1,.page-title{font-size:1.25rem}h2,.section-heading,.section-title{font-size:1rem}.stat-card{padding:var(--spacing-sm)}.stat-number{font-size:1.375rem}.mini-calendar{padding:var(--spacing-xs)}.cal-day{min-height:36px;min-width:36px;font-size:var(--font-size-sm)}.cal-nav{min-width:36px;min-height:36px}button,.btn{min-height:44px}}.mobile-cards,.mobile-list{display:none}.desktop-table{display:block}@media(max-width:768px){.mobile-cards{display:flex;flex-direction:column;gap:var(--spacing-md)}.mobile-list{display:flex;flex-direction:column}.desktop-table{display:none}.mobile-checkin-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);transition:box-shadow var(--transition-base)}.mobile-checkin-card:hover{box-shadow:var(--shadow-md)}.mobile-checkin-card.not-submitted{border-color:var(--color-danger);background:var(--color-danger-light)}.mobile-checkin-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-sm);gap:var(--spacing-sm)}.mobile-checkin-card-name{font-weight:600;color:var(--color-text);font-size:var(--font-size-base)}.mobile-checkin-card-details{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.mobile-checkin-card-detail{display:flex;flex-direction:column;gap:var(--spacing-xs)}.mobile-checkin-card-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.mobile-checkin-card-value{font-size:var(--font-size-sm);color:var(--color-text);font-weight:500}.mobile-checkin-card-actions{display:flex;gap:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border-light)}.mobile-checkin-card-actions button,.mobile-checkin-card-actions a{flex:1;min-height:44px;display:flex;align-items:center;justify-content:center}.mobile-leave-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md)}.mobile-leave-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-sm);gap:var(--spacing-sm)}.mobile-leave-card-name{font-weight:600;color:var(--color-text)}.mobile-leave-card-info{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);align-items:center}.mobile-leave-card-date{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.mobile-leave-card-actions{display:flex;gap:var(--spacing-sm)}.mobile-leave-card-actions button{flex:1;min-height:44px}}@media(hover:none)and (pointer:coarse){button:hover,.btn:hover,.card:hover,.stat-card:hover,.recent-timesheet-item:hover,.team-card:hover{transform:none}button:active,.btn:active{transform:scale(.98);opacity:.9}.card:active{transform:scale(.99)}.table-scroll,.entries-table,.checkin-grouped-table,.submissions-table{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}}.top-bar-brand{display:none}.top-bar-logo{width:28px;height:28px;border-radius:6px;object-fit:contain}.top-bar-logo-icon{width:28px;height:28px}.top-bar-title{font-size:17px;font-weight:600;color:var(--color-text);white-space:nowrap}@media(max-width:768px){.top-bar{height:56px;padding:0 16px;display:flex;gap:12px;background:#fff;border-bottom:1px solid #E5E7EB;box-shadow:0 1px 3px #0000000d}.top-bar-brand{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.hamburger{width:44px;height:44px;min-width:44px;min-height:44px;padding:10px;border-radius:8px;color:#374151;flex-shrink:0}.hamburger svg{width:22px;height:22px;stroke:#374151}.notification-bell{width:44px;height:44px;min-width:44px;flex-shrink:0}.sidebar{position:fixed;top:0;left:0;width:280px;height:100vh;height:100dvh;z-index:100;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);background:#1a1a2e;overflow-y:auto}.sidebar.open{transform:translate(0)}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:95;animation:fadeIn .2s ease-out}.main-content{margin-left:0;padding:72px 16px 16px;min-height:100vh;min-height:100dvh;background:#f9fafb}.page-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:16px!important}.page-header h1,.page-title{font-size:20px!important;font-weight:700;color:#111827;margin-bottom:0!important}.stats-row{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}.stat-card{padding:12px;border-radius:8px;background:#fff;border:1px solid #E5E7EB;box-shadow:0 1px 3px #00000014}.stat-number{font-size:24px!important;font-weight:700;color:#111827;line-height:1.2}.stat-label{font-size:12px!important;color:#6b7280;margin-top:4px}.section h2+div[style*="display: flex"][style*=gap]{display:flex!important;flex-wrap:wrap!important;gap:8px!important}.section h2+div[style*="display: flex"][style*=gap] .btn{padding:10px 16px;font-size:13px;border-radius:20px;flex:0 0 auto;white-space:nowrap}.section{margin-bottom:16px;background:#fff;border-radius:8px;padding:16px;border:1px solid #E5E7EB;box-shadow:0 1px 3px #0000000d}.section h2,.section-header h2{font-size:16px!important;font-weight:600;color:#111827;margin-bottom:12px}.section-header{flex-direction:column;align-items:flex-start!important;gap:12px;margin-bottom:12px}.section-header .header-actions{width:100%;display:flex;flex-wrap:wrap;gap:8px}.mobile-cards{display:flex;flex-direction:column;gap:12px}.mobile-checkin-card{background:#fff;border:1px solid #E5E7EB;border-radius:8px;padding:12px;box-shadow:0 1px 2px #0000000d}.mobile-checkin-card.not-submitted{border-color:#fca5a5;background:#fef2f2}.mobile-checkin-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.mobile-checkin-card-name{font-size:15px;font-weight:600;color:#111827}.mobile-checkin-card-details{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #F3F4F6}.mobile-checkin-card-detail{display:flex;flex-direction:column;gap:2px}.mobile-checkin-card-label{font-size:11px;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.mobile-checkin-card-value{font-size:14px;color:#374151;font-weight:500}.mobile-checkin-card-actions{display:flex;gap:8px;padding-top:0;border-top:none}.mobile-checkin-card-actions .btn,.mobile-checkin-card-actions a.btn{flex:0 0 auto;min-height:36px;padding:6px 14px;font-size:12px;border-radius:6px}.btn-reminder{padding:6px 14px!important;font-size:12px!important;border-radius:20px!important;min-height:32px!important;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;font-weight:500}.btn-reminder.btn-sm{padding:5px 12px!important;font-size:11px!important;min-height:28px!important}button,.btn{min-height:44px;padding:10px 20px;font-size:14px;border-radius:8px;font-weight:500}.btn-sm{min-height:36px;padding:6px 14px;font-size:12px;border-radius:6px}.header-actions,.modal-actions,.form-actions,.inline-edit-actions{display:flex;flex-wrap:wrap;gap:8px}.form-row{flex-direction:column;gap:12px}.filter-group{width:100%}.filter-group select,.filter-group input{width:100%;height:40px;font-size:14px;border-radius:8px;border:1px solid #E5E7EB}h1,.page-title{font-size:20px;font-weight:700}h2,.section-heading{font-size:16px;font-weight:600}h3,.card-title{font-size:15px;font-weight:600}p,.body-text{font-size:14px}small,.small-text,.muted{font-size:12px}th{font-size:11px;text-transform:uppercase;letter-spacing:.5px;font-weight:600;color:#6b7280}.status-badge,.badge{padding:4px 10px;font-size:11px;border-radius:20px;font-weight:500}.mobile-leave-card{background:#fff;border:1px solid #E5E7EB;border-radius:8px;padding:12px;box-shadow:0 1px 2px #0000000d}.mobile-leave-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.mobile-leave-card-name{font-size:15px;font-weight:600}.mobile-leave-card-info{display:flex;align-items:center;gap:12px;margin-bottom:12px}.mobile-leave-card-actions{display:flex;gap:8px}.mobile-leave-card-actions .btn{flex:1;min-height:36px;padding:6px 14px;font-size:12px}.mobile-invoice-card{background:#fff;border:1px solid #E5E7EB;border-radius:8px;padding:12px;box-shadow:0 1px 2px #0000000d}.mobile-invoice-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.mobile-invoice-number{font-size:14px;font-weight:600;color:var(--color-primary);text-decoration:none}.mobile-invoice-client{font-size:15px;font-weight:600;color:#111827;margin-bottom:12px}.mobile-invoice-details{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #F3F4F6}.mobile-invoice-detail{display:flex;flex-direction:column;gap:2px}.mobile-invoice-label{font-size:11px;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.mobile-invoice-value{font-size:13px;color:#374151}.mobile-invoice-amount{font-size:16px;font-weight:700;color:#111827}.mobile-invoice-actions{display:flex;flex-wrap:wrap;gap:8px}.mobile-invoice-actions .btn{flex:0 0 auto;min-height:34px;padding:6px 12px;font-size:12px}.modal-overlay{align-items:flex-end}.modal-content{width:100%;max-width:100%;max-height:90vh;max-height:90dvh;margin:0;border-radius:16px 16px 0 0;padding:20px 16px;animation:modalSlideUp .3s cubic-bezier(.4,0,.2,1);overflow-y:auto}.modal-header{padding-bottom:16px;margin-bottom:16px;border-bottom:1px solid #E5E7EB}.modal-header h2{font-size:18px}.modal-actions{flex-direction:column;gap:8px;margin-top:16px}.modal-actions button{width:100%;min-height:48px}}@media(max-width:480px){.stats-row{grid-template-columns:1fr 1fr}.stat-card{padding:10px}.stat-number{font-size:20px!important}.stat-label{font-size:11px!important}.page-header h1,.page-title{font-size:18px!important}.btn-reminder{padding:5px 12px!important;font-size:11px!important}.mobile-checkin-card-actions{flex-wrap:wrap}.mobile-checkin-card-actions .btn{flex:1 1 auto;min-width:80px}}@media(max-width:768px){.approvals-page .page-header{flex-direction:column;align-items:flex-start;gap:12px}.period-card{padding:12px;border-radius:8px}.period-card-header{flex-direction:column;align-items:flex-start;gap:8px}.period-summary{display:flex;flex-wrap:wrap;gap:8px}.bulk-actions{flex-wrap:wrap;gap:8px}.bulk-actions button{flex:1;min-width:100px}.approval-mobile-card{background:#fff;border:1px solid #E5E7EB;border-radius:8px;padding:12px;margin-bottom:12px}.approval-mobile-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.approval-mobile-card-name{font-size:15px;font-weight:600;color:#111827}.approval-mobile-card-details{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:12px;font-size:13px;color:#6b7280}.approval-mobile-card-actions{display:flex;gap:8px;padding-top:12px;border-top:1px solid #F3F4F6}.approval-mobile-card-actions .btn{flex:1;min-height:36px;padding:6px 12px;font-size:12px}}@media(max-width:768px){.invoices-page .filter-row,.invoice-filters{flex-direction:column;gap:8px}.invoices-page .filter-row select,.invoices-page .filter-row input{width:100%}.invoice-summary-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.invoice-summary-card{padding:12px;border-radius:8px}.invoice-mobile-card{background:#fff;border:1px solid #E5E7EB;border-radius:8px;padding:12px;margin-bottom:12px}.invoice-mobile-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.invoice-mobile-card-number{font-size:14px;font-weight:600;color:var(--color-primary)}.invoice-mobile-card-client{font-size:15px;font-weight:600;color:#111827;margin-bottom:8px}.invoice-mobile-card-details{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:12px;font-size:13px;color:#6b7280}.invoice-mobile-card-amount{font-size:18px;font-weight:700;color:#111827}.invoice-mobile-card-actions{display:flex;gap:8px;padding-top:12px;border-top:1px solid #F3F4F6}}@media(max-width:768px){.team-filters{flex-direction:column;gap:8px}.team-filters select,.team-filters input{width:100%;height:40px}.team-card{padding:12px;border-radius:8px}.team-card-header{flex-wrap:wrap;gap:8px}.team-card-avatar{width:40px;height:40px;font-size:14px}.team-card-info{flex:1;min-width:0}.team-card-name{font-size:15px;font-weight:600}.team-card-email{font-size:13px;color:#6b7280;word-break:break-all}.team-card-badges{width:100%;display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.team-card-fields{grid-template-columns:1fr;gap:8px;margin-top:12px}.team-card-actions{flex-direction:column;gap:8px;margin-top:12px}.team-card-actions button{width:100%}}@media(max-width:768px){.pipeline-filters{flex-direction:column;gap:8px}.pipeline-card,.candidate-card{padding:12px;border-radius:8px}.candidate-card-header{flex-direction:column;align-items:flex-start;gap:8px}.candidate-card-name{font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px}.candidate-card-status{margin-left:0}.candidate-card-details{font-size:13px;color:#6b7280}.candidate-card-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.candidate-card-actions button{flex:1;min-width:100px}}@media(max-width:768px){.audit-filters{flex-direction:column;gap:8px}.audit-log-mobile-card{background:#fff;border:1px solid #E5E7EB;border-radius:8px;padding:12px;margin-bottom:12px}.audit-log-mobile-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.audit-log-mobile-card-action{font-size:14px;font-weight:600;color:#111827}.audit-log-mobile-card-details{font-size:13px;color:#6b7280;line-height:1.5}.audit-log-mobile-card-time{font-size:12px;color:#9ca3af;margin-top:8px}}@media(max-width:768px){.section-header>div[style*="display: flex"][style*="align-items: baseline"]{flex-direction:column;align-items:flex-start!important;gap:4px}.section-header .header-actions{width:100%}.section-header .header-actions .btn{flex:1;min-width:0;white-space:nowrap;font-size:12px;padding:8px 12px}}@media(max-width:768px){.table-scroll{position:relative;overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -16px;padding:0 16px}.table-scroll:after{content:"";position:absolute;top:0;right:0;bottom:0;width:24px;background:linear-gradient(to right,transparent,rgba(255,255,255,.9));pointer-events:none;opacity:0;transition:opacity .2s}.table-scroll:not(:hover):after{opacity:1}}@media(max-width:768px){.page-container{padding:0}.section+.section{margin-top:16px}.empty-state-card{padding:24px 16px;text-align:center}.empty-state-card p{font-size:14px;color:#6b7280}.card-list{gap:12px}.card-list .card{padding:12px;border-radius:8px}.dashboard-section-divider{margin:24px 0 16px;padding:0}.section-title-large{font-size:18px;font-weight:700;color:#111827}.today-checkin-section .btn-primary{width:100%;margin-top:8px}.today-checkin-empty{padding:24px 16px;text-align:center;background:#f9fafb;border-radius:8px}.today-checkin-empty p{margin-bottom:16px}.upcoming-leaves-list{display:flex;flex-direction:column;gap:8px}.upcoming-leave-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#f9fafb;border-radius:8px;flex-wrap:wrap}.upcoming-leave-date{font-size:14px;font-weight:500;flex:1;min-width:100px}.upcoming-leave-item .btn-cancel{padding:5px 10px;font-size:11px;min-height:28px}.leave-balance-card{padding:16px;text-align:center}.leave-balance-card .stat-number{font-size:32px!important}.leave-breakdown{margin-top:8px;font-size:12px}}.landing-modern{--landing-dark: #0f172a;--landing-darker: #020617;--landing-navy: #1e293b;--landing-cyan: #06b6d4;--landing-purple: #8b5cf6;--landing-teal: #14b8a6;--landing-text: #f8fafc;--landing-text-muted: #94a3b8;--landing-border: rgba(148, 163, 184, .1);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;scroll-behavior:smooth}.landing-modern section[id]{scroll-margin-top:80px}.landing-bg-gradient{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#0f172a,#1e1b4b,#0f172a,#134e4a,#0f172a);background-size:400% 400%;animation:gradientShift 15s ease infinite;z-index:-2}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.landing-bg-shapes{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;z-index:-1;pointer-events:none}.shape{position:absolute;border-radius:50%;opacity:.1;filter:blur(60px)}.shape-1{width:600px;height:600px;background:var(--landing-cyan);top:-200px;right:-200px;animation:float1 20s ease-in-out infinite}.shape-2{width:400px;height:400px;background:var(--landing-purple);bottom:-100px;left:-100px;animation:float2 25s ease-in-out infinite}.shape-3{width:300px;height:300px;background:var(--landing-teal);top:40%;left:20%;animation:float3 18s ease-in-out infinite}.shape-4{width:200px;height:200px;background:var(--landing-cyan);bottom:30%;right:10%;animation:float1 22s ease-in-out infinite reverse}.shape-5{width:150px;height:150px;background:var(--landing-purple);top:20%;left:60%;animation:float2 15s ease-in-out infinite}@keyframes float1{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(30px,-30px) rotate(120deg)}66%{transform:translate(-20px,20px) rotate(240deg)}}@keyframes float2{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-40px,-20px) scale(1.1)}}@keyframes float3{0%,to{transform:translate(0)}25%{transform:translate(20px,-30px)}50%{transform:translate(-10px,-50px)}75%{transform:translate(-30px,-20px)}}.landing-header-modern{position:fixed;top:0;left:0;right:0;z-index:100;background:#0f172acc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--landing-border)}.landing-header-modern .landing-header-inner{max-width:1280px;margin:0 auto;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between}.landing-logo-modern{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:700;color:var(--landing-text);cursor:pointer;text-decoration:none}.landing-logo-modern span{background:linear-gradient(135deg,var(--landing-cyan),var(--landing-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-nav-modern{display:flex;align-items:center;gap:1.5rem}.landing-nav-modern a{color:var(--landing-text-muted);font-size:1rem;font-weight:500;text-decoration:none;transition:color .2s;padding:.5rem 0}.landing-nav-modern a:hover{color:var(--landing-text)}.landing-btn-ghost{background:transparent;color:var(--landing-text);border:1px solid var(--landing-border);padding:.75rem 1.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;min-height:44px}.landing-btn-ghost:hover{background:#ffffff1a;border-color:var(--landing-cyan)}.landing-btn-glow{background:linear-gradient(135deg,var(--landing-cyan),var(--landing-purple));color:#fff;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;border-radius:8px;transition:all .3s;box-shadow:0 0 20px #06b6d44d;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:44px}.landing-btn-glow:hover{transform:translateY(-2px);box-shadow:0 0 30px #06b6d480}.landing-btn-outline-modern{background:transparent;color:var(--landing-text);border:1px solid var(--landing-border);padding:.65rem 1.5rem;font-size:.9rem;font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none}.landing-btn-outline-modern:hover{background:#ffffff0d;border-color:var(--landing-cyan)}.landing-btn-lg{padding:1rem 2rem;font-size:1rem}.landing-hero-modern{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;max-width:1280px;margin:0 auto;padding:120px 2rem 80px}.landing-hero-content{opacity:0;transform:translateY(30px)}.landing-hero-content.animate-in{animation:fadeSlideUp .8s ease forwards}.hero-title{margin-bottom:1.5rem}.title-line{display:block;font-size:3.5rem;font-weight:800;line-height:1.1;color:var(--landing-text)}.title-gradient{background:linear-gradient(135deg,var(--landing-cyan),var(--landing-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.25rem;color:var(--landing-text-muted);line-height:1.7;margin-bottom:2rem;max-width:500px}.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}.landing-hero-visual{opacity:0;transform:translate(50px)}.landing-hero-visual.animate-in{animation:fadeSlideLeft .8s ease .3s forwards}.dashboard-mockup{perspective:1000px}.mockup-browser{background:var(--landing-navy);border-radius:12px;overflow:hidden;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff1a;transform:rotateY(-5deg) rotateX(2deg);transition:transform .3s}.mockup-browser:hover{transform:rotateY(0) rotateX(0)}.browser-header{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--landing-darker);border-bottom:1px solid var(--landing-border)}.browser-dots{display:flex;gap:6px}.browser-dots .dot{width:12px;height:12px;border-radius:50%}.dot.red{background:#ef4444}.dot.yellow{background:#eab308}.dot.green{background:#22c55e}.browser-address{flex:1;background:#ffffff0d;padding:.4rem 1rem;border-radius:6px;font-size:.75rem;color:var(--landing-text-muted)}.browser-content{display:flex;min-height:300px}.mock-sidebar{width:60px;background:var(--landing-darker);padding:1rem .5rem;display:flex;flex-direction:column;gap:.5rem}.mock-nav-item{height:36px;background:#ffffff0d;border-radius:8px}.mock-nav-item.active{background:linear-gradient(135deg,var(--landing-cyan),var(--landing-purple))}.mock-main{flex:1;padding:1.5rem}.mock-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.mock-stat-card{background:#ffffff08;border-radius:8px;padding:1rem;display:flex;align-items:center;gap:.75rem;border:1px solid var(--landing-border)}.mock-stat-icon{width:40px;height:40px;border-radius:8px}.mock-stat-icon.cyan{background:linear-gradient(135deg,#06b6d4,#0891b2)}.mock-stat-icon.purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.mock-stat-icon.green{background:linear-gradient(135deg,#22c55e,#16a34a)}.mock-stat-value{font-size:1.25rem;font-weight:700;color:var(--landing-text)}.mock-stat-label{font-size:.7rem;color:var(--landing-text-muted)}.mock-chart{background:#ffffff08;border-radius:8px;padding:1rem;border:1px solid var(--landing-border)}.chart-bars{display:flex;align-items:flex-end;gap:.5rem;height:100px}.chart-bar{flex:1;background:linear-gradient(180deg,var(--landing-cyan),var(--landing-purple));border-radius:4px 4px 0 0;animation:growBar 1s ease forwards;transform-origin:bottom}@keyframes growBar{0%{transform:scaleY(0)}to{transform:scaleY(1)}}.landing-stats{padding:5rem 2rem;background:linear-gradient(135deg,#06b6d41a,#8b5cf61a);border-top:1px solid var(--landing-border);border-bottom:1px solid var(--landing-border)}.stats-container{max-width:1280px;margin:0 auto;display:flex;justify-content:center;align-items:center;gap:4rem;flex-wrap:wrap;opacity:0;transform:translateY(20px)}.stats-container.animate-in{animation:fadeSlideUp .6s ease forwards}.landing-page .stat-item{text-align:center;min-width:180px}.landing-page .stat-number{font-size:3rem;font-weight:700;color:#fff!important;-webkit-text-fill-color:#FFFFFF!important;background:none!important;line-height:1.1}.landing-page .stat-label{font-size:.95rem;color:#ffffffd9!important;margin-top:.5rem;font-weight:500}.stat-divider{width:1px;height:60px;background:linear-gradient(180deg,transparent,var(--landing-border),transparent)}.landing-page .section-header{display:flex;flex-direction:column;align-items:center;text-align:center;width:100%;margin-bottom:4rem}.section-badge{display:inline-block;background:#06b6d41a;color:var(--landing-cyan);padding:.4rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600;margin-bottom:1rem;border:1px solid rgba(6,182,212,.2)}.section-title{font-size:2.5rem;font-weight:800;color:var(--landing-text);margin-bottom:1rem;opacity:0;transform:translateY(20px);text-align:center;width:100%}.section-title.animate-in{animation:fadeSlideUp .6s ease forwards}.section-subtitle{font-size:1.1rem;color:var(--landing-text-muted);max-width:600px;margin:0 auto;opacity:0;transform:translateY(20px);text-align:center}.section-subtitle.animate-in{animation:fadeSlideUp .6s ease .1s forwards}.landing-features-modern{padding:100px 2rem;max-width:1280px;margin:0 auto}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.feature-card-modern{background:#ffffff05;border:1px solid var(--landing-border);border-radius:16px;padding:2rem;transition:all .3s;opacity:0;transform:translateY(30px)}.feature-card-modern.animate-in{animation:fadeSlideUp .5s ease forwards}.feature-card-modern:hover{background:#ffffff0d;border-color:#06b6d44d;transform:translateY(-5px);box-shadow:0 20px 40px #0000004d}.feature-icon-modern{width:56px;height:56px;background:linear-gradient(135deg,#06b6d433,#8b5cf633);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}.feature-icon-modern svg{width:28px;height:28px;stroke:var(--landing-cyan)}.feature-card-modern h3{font-size:1.25rem;font-weight:700;color:var(--landing-text);margin-bottom:.75rem}.feature-card-modern p{color:var(--landing-text-muted);font-size:.95rem;line-height:1.6;margin:0}.landing-how-modern{padding:100px 2rem;background:#0003}.landing-how-modern .section-header{max-width:1280px;margin-left:auto;margin-right:auto;margin-bottom:4rem}.how-steps-container{max-width:1000px;margin:0 auto;position:relative}.steps-line{position:absolute;top:50px;left:60px;right:60px;height:2px;background:var(--landing-border)}.line-progress{height:100%;width:0;background:linear-gradient(90deg,var(--landing-cyan),var(--landing-purple))}.line-progress.animate-line{animation:lineGrow 2s ease forwards}@keyframes lineGrow{to{width:100%}}.how-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;position:relative}.how-step{text-align:center;opacity:0;transform:translateY(30px)}.how-step.animate-in{animation:fadeSlideUp .5s ease forwards}.step-number{width:60px;height:60px;background:linear-gradient(135deg,var(--landing-cyan),var(--landing-purple));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:#fff;margin:0 auto 1.5rem;position:relative;z-index:1;box-shadow:0 0 30px #06b6d44d}.how-step h3{font-size:1.25rem;font-weight:700;color:var(--landing-text);margin-bottom:.5rem}.how-step p{color:var(--landing-text-muted);font-size:.9rem;line-height:1.5;margin:0}.landing-preview{padding:100px 2rem;max-width:1280px;margin:0 auto}.preview-container{opacity:0;transform:translateY(40px)}.preview-container.animate-in{animation:fadeSlideUp .8s ease forwards}.preview-window{background:var(--landing-navy);border-radius:16px;overflow:hidden;box-shadow:0 50px 100px -20px #00000080,0 0 0 1px #ffffff1a}.preview-header{padding:.75rem 1rem;background:var(--landing-darker);border-bottom:1px solid var(--landing-border)}.preview-dots{display:flex;gap:6px}.preview-dots span{width:12px;height:12px;border-radius:50%}.preview-dots span:nth-child(1){background:#ef4444}.preview-dots span:nth-child(2){background:#eab308}.preview-dots span:nth-child(3){background:#22c55e}.preview-content{display:flex;min-height:400px}.preview-sidebar{width:220px;background:var(--landing-darker);padding:1.5rem 1rem;border-right:1px solid var(--landing-border)}.preview-logo{display:flex;align-items:center;gap:.5rem;margin-bottom:2rem}.preview-logo .logo-icon{width:28px;height:28px;background:linear-gradient(135deg,var(--landing-cyan),var(--landing-purple));border-radius:6px}.preview-logo span{color:var(--landing-text);font-weight:600}.preview-menu{display:flex;flex-direction:column;gap:.5rem}.menu-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px;color:var(--landing-text-muted);font-size:.9rem}.menu-item.active{background:#06b6d41a;color:var(--landing-cyan)}.menu-icon{width:20px;height:20px;background:currentColor;border-radius:4px;opacity:.5}.menu-item.active .menu-icon{opacity:1}.preview-main{flex:1;padding:1.5rem}.preview-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.search-bar{width:300px;height:40px;background:#ffffff0d;border-radius:8px;border:1px solid var(--landing-border)}.user-avatar{width:40px;height:40px;background:linear-gradient(135deg,var(--landing-cyan),var(--landing-purple));border-radius:50%}.preview-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.preview-card{padding:1.25rem;border-radius:12px;border:1px solid var(--landing-border)}.preview-card.cyan{background:linear-gradient(135deg,#06b6d41a,#06b6d40d)}.preview-card.purple{background:linear-gradient(135deg,#8b5cf61a,#8b5cf60d)}.preview-card.green{background:linear-gradient(135deg,#22c55e1a,#22c55e0d)}.card-value{font-size:1.75rem;font-weight:800;color:var(--landing-text)}.card-label{font-size:.8rem;color:var(--landing-text-muted);margin-top:.25rem}.preview-table{background:#ffffff05;border-radius:12px;border:1px solid var(--landing-border);overflow:hidden}.preview-table .table-header{padding:1rem 1.25rem;border-bottom:1px solid var(--landing-border);font-weight:600;color:var(--landing-text)}.table-rows{padding:.5rem}.table-row{height:48px;background:#ffffff05;margin-bottom:.5rem;border-radius:6px}.table-row:last-child{margin-bottom:0}.landing-pricing-modern{padding:100px 2rem;background:#0003}.landing-pricing-modern .section-header{max-width:1280px;margin-left:auto;margin-right:auto;margin-bottom:4rem}.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1100px;margin:0 auto}.pricing-card-modern{background:#ffffff05;border:1px solid var(--landing-border);border-radius:20px;padding:2.5rem;position:relative;transition:all .3s;opacity:0;transform:translateY(30px)}.pricing-card-modern.animate-in{animation:fadeSlideUp .5s ease forwards}.pricing-card-modern:hover{transform:translateY(-5px);border-color:#06b6d44d}.pricing-card-modern.featured{background:linear-gradient(135deg,#06b6d41a,#8b5cf61a);border-color:var(--landing-cyan);transform:scale(1.05)}.pricing-card-modern.featured:hover{transform:scale(1.05) translateY(-5px)}.pricing-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,var(--landing-cyan),var(--landing-purple));color:#fff;padding:.4rem 1rem;border-radius:20px;font-size:.8rem;font-weight:600}.pricing-header{text-align:center;margin-bottom:2rem}.pricing-header h3{font-size:1.5rem;font-weight:700;color:var(--landing-text);margin-bottom:1rem}.pricing-price{margin-bottom:.5rem}.price-amount{font-size:3rem;font-weight:800;background:linear-gradient(135deg,var(--landing-cyan),var(--landing-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.price-period{color:var(--landing-text-muted);font-size:.9rem}.pricing-desc{color:var(--landing-text-muted);font-size:.9rem;margin:0}.pricing-features{list-style:none;padding:0;margin:0 0 2rem}.pricing-features li{display:flex;align-items:center;gap:.75rem;color:var(--landing-text-muted);font-size:.95rem;padding:.6rem 0;border-bottom:1px solid var(--landing-border)}.pricing-features li:last-child{border-bottom:none}.pricing-features li.coming-soon{opacity:.7;font-style:italic}.pricing-features .soon-tag{font-size:.7rem;font-style:italic;color:var(--landing-purple);background:#8b5cf61a;padding:2px 8px;border-radius:10px;margin-left:auto;font-weight:500}.check-icon{width:20px;height:20px;background:linear-gradient(135deg,var(--landing-cyan),var(--landing-purple));border-radius:50%;flex-shrink:0;position:relative}.check-icon:after{content:"";position:absolute;top:5px;left:7px;width:5px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.pricing-card-modern .landing-btn-glow,.pricing-card-modern .landing-btn-outline-modern{width:100%;justify-content:center}.pricing-grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;max-width:1400px;margin:0 auto}.pricing-card-compact{background:#ffffff05;border:1px solid var(--landing-border);border-radius:16px;padding:1.5rem;position:relative;transition:all .3s;opacity:0;transform:translateY(30px);display:flex;flex-direction:column}.pricing-card-compact.animate-in{animation:fadeSlideUp .5s ease forwards}.pricing-card-compact:hover{transform:translateY(-5px);border-color:#06b6d44d}.pricing-card-compact.featured{background:linear-gradient(135deg,#06b6d41a,#8b5cf61a);border-color:var(--landing-cyan);transform:scale(1.02)}.pricing-card-compact.featured:hover{transform:scale(1.02) translateY(-5px)}.pricing-card-compact .pricing-header{text-align:center;margin-bottom:1.25rem}.pricing-card-compact .pricing-header h3{font-size:1.1rem;font-weight:700;color:var(--landing-text);margin-bottom:.75rem}.pricing-card-compact .pricing-price .amount{font-size:2rem}.pricing-card-compact .pricing-desc{font-size:.85rem;min-height:2.5rem}.pricing-card-compact .pricing-features{margin:0 0 1.5rem;flex:1}.pricing-card-compact .pricing-features li{font-size:.85rem;padding:.5rem 0}.pricing-card-compact .landing-btn-glow,.pricing-card-compact .landing-btn-outline-modern{width:100%;justify-content:center;padding:.625rem 1rem;font-size:.9rem}.landing-testimonials-modern{padding:100px 2rem;max-width:1280px;margin:0 auto}.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.testimonial-card-modern{background:#ffffff05;border:1px solid var(--landing-border);border-radius:16px;padding:2rem;transition:all .3s;opacity:0;transform:translateY(30px)}.testimonial-card-modern.animate-in{animation:fadeSlideUp .5s ease forwards}.testimonial-card-modern:hover{background:#ffffff0d;border-color:#06b6d44d}.testimonial-quote{color:var(--landing-text);font-size:1rem;line-height:1.7;margin-bottom:1.5rem;font-style:italic}.testimonial-author{display:flex;align-items:center;gap:1rem}.author-avatar{width:48px;height:48px;background:linear-gradient(135deg,var(--landing-cyan),var(--landing-purple));border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.9rem}.author-info strong{display:block;color:var(--landing-text);font-size:1rem}.author-info span{color:var(--landing-text-muted);font-size:.85rem}.landing-cta{padding:100px 2rem;background:linear-gradient(135deg,#06b6d41a,#8b5cf61a);border-top:1px solid var(--landing-border);border-bottom:1px solid var(--landing-border)}.cta-content{max-width:700px;margin:0 auto;text-align:center}.cta-content h2{font-size:2.5rem;font-weight:800;color:var(--landing-text);margin-bottom:1rem}.cta-content>p{color:var(--landing-text-muted);font-size:1.1rem;margin-bottom:2rem}.cta-actions{margin-bottom:1rem}.cta-note{color:var(--landing-text-muted);font-size:.9rem}.landing-footer-modern{background:var(--landing-darker);padding:60px 2rem 30px;border-top:1px solid var(--landing-border)}.footer-content{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.5fr 2fr;gap:4rem;margin-bottom:3rem}.footer-brand p{color:var(--landing-text-muted);font-size:.95rem;line-height:1.6;margin-top:1rem;max-width:300px}.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}.footer-col h4{color:var(--landing-text);font-size:.95rem;font-weight:600;margin-bottom:1.25rem}.footer-col a{display:block;color:var(--landing-text-muted);font-size:.9rem;padding:.4rem 0;text-decoration:none;transition:color .2s}.footer-col a:hover{color:var(--landing-cyan)}.footer-bottom{max-width:1280px;margin:0 auto;padding-top:2rem;border-top:1px solid var(--landing-border);display:flex;justify-content:space-between;align-items:center}.footer-bottom p{color:var(--landing-text-muted);font-size:.85rem;margin:0}.footer-legal{display:flex;gap:2rem}.footer-legal a{color:var(--landing-text-muted);font-size:.85rem;text-decoration:none;transition:color .2s}.footer-legal a:hover{color:var(--landing-cyan)}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeSlideLeft{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}.mobile-menu-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;width:44px;height:44px;background:transparent;border:none;cursor:pointer;padding:8px;gap:5px;z-index:101}.mobile-menu-toggle span{display:block;width:24px;height:2px;background:var(--landing-text);border-radius:2px;transition:all .3s ease}.mobile-menu-toggle.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.mobile-menu-toggle.open span:nth-child(2){opacity:0}.mobile-menu-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.mobile-nav-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172afa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:99;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.mobile-nav-overlay.open{opacity:1;visibility:visible}.mobile-nav-content{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem;padding:2rem}.mobile-nav-content a{color:var(--landing-text);font-size:1.125rem;font-weight:500;text-decoration:none;padding:.875rem 1.5rem;transition:color .2s;min-height:44px;display:flex;align-items:center;justify-content:center}.mobile-nav-content a:hover{color:var(--landing-cyan)}.mobile-nav-buttons{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:280px;margin-top:.5rem}.mobile-nav-buttons .landing-btn-ghost,.mobile-nav-buttons .landing-btn-glow{width:100%;justify-content:center;padding:.875rem 1.5rem;font-size:1.125rem;font-weight:500;min-height:44px}.mobile-nav-buttons .landing-btn-glow{font-weight:600}@media(max-width:1200px){.pricing-grid-5{grid-template-columns:repeat(3,1fr);max-width:900px}}@media(max-width:1024px){.landing-hero-modern{grid-template-columns:1fr;text-align:center;gap:3rem}.hero-subtitle{max-width:100%;margin-left:auto;margin-right:auto}.hero-actions{justify-content:center}.landing-hero-visual{order:1}.mockup-browser{transform:none}.features-grid,.testimonials-grid{grid-template-columns:repeat(2,1fr)}.how-steps{grid-template-columns:repeat(2,1fr);gap:3rem}.steps-line{display:none}.pricing-grid{grid-template-columns:1fr;max-width:400px}.pricing-grid-5{grid-template-columns:repeat(2,1fr);max-width:700px}.pricing-card-compact.featured{transform:none}.pricing-card-compact.featured:hover{transform:translateY(-5px)}.pricing-card-modern.featured{transform:none}.pricing-card-modern.featured:hover{transform:translateY(-5px)}.footer-content{grid-template-columns:1fr;gap:3rem}}@media(max-width:768px){.mobile-menu-toggle{display:flex}.mobile-nav-overlay{display:block}.landing-nav-modern{display:none}.landing-hero-modern{padding:100px 1.25rem 60px;min-height:auto;text-align:center}.hero-content{text-align:center}.title-line{font-size:2rem;line-height:1.2}.hero-subtitle{font-size:1rem;line-height:1.6;padding:0;max-width:100%;color:#ffffffd9}.hero-actions{flex-direction:column;gap:.75rem;padding:0;max-width:320px;margin:0 auto}.hero-actions .landing-btn-lg{width:100%}.mockup-browser{margin:0 -1rem;border-radius:0}.browser-content{flex-direction:column}.mock-sidebar{display:none}.mock-stats-row{grid-template-columns:1fr;gap:.75rem}.mock-stat-card{padding:.75rem}.mock-stat-value{font-size:1rem}.mock-stat-label{font-size:.65rem}.chart-bars{height:60px}.section-header{margin-bottom:2.5rem;text-align:center}.section-badge{display:inline-block;margin-left:auto;margin-right:auto}.section-title{font-size:1.75rem;padding:0 .5rem;text-align:center}.section-subtitle{font-size:1rem;padding:0 .5rem;text-align:center;max-width:100%}.landing-features-modern{padding:60px 1.25rem}.features-grid{grid-template-columns:1fr;gap:1rem;max-width:400px;margin:0 auto}.feature-card-modern{padding:1.5rem;text-align:center}.feature-icon-modern{margin:0 auto 1rem}.feature-card-modern h3{font-size:1.1rem}.feature-card-modern p{font-size:.9rem;line-height:1.6}.landing-how-modern{padding:60px 1.25rem}.how-steps{grid-template-columns:1fr;gap:2rem}.how-steps-container{position:relative;padding-left:50px;max-width:400px;margin:0 auto}.how-steps-container:before{content:"";position:absolute;left:22px;top:30px;bottom:30px;width:2px;background:linear-gradient(180deg,var(--landing-cyan),var(--landing-purple))}.how-step{text-align:left;position:relative;padding-left:.5rem}.step-number{position:absolute;left:-50px;margin:0;width:44px;height:44px;font-size:1.1rem}.how-step h3{font-size:1.1rem}.how-step p{font-size:.9rem;line-height:1.6}.landing-stats{padding:3rem 1.25rem}.stats-container{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem 1rem;max-width:400px;margin:0 auto}.stat-item{text-align:center}.stat-divider{display:none}.landing-page .stat-number{font-size:2rem;color:#fff!important;-webkit-text-fill-color:#FFFFFF!important;background:none!important}.landing-page .stat-label{font-size:.85rem;color:#ffffffe6!important;margin-top:.25rem}.landing-preview{padding:60px 1.25rem}.preview-sidebar{display:none}.preview-cards{grid-template-columns:1fr;gap:.75rem}.preview-main{padding:1rem}.preview-topbar{flex-direction:column;gap:.75rem;align-items:stretch}.search-bar{width:100%}.user-avatar{display:none}.card-value{font-size:1.5rem}.landing-pricing-modern{padding:60px 1.25rem}.pricing-grid-5{grid-template-columns:1fr;gap:1rem;max-width:400px;margin:0 auto}.pricing-card-compact{padding:1.5rem}.pricing-card-compact .pricing-price .amount{font-size:2rem}.pricing-card-modern{padding:1.75rem}.price-amount{font-size:2.5rem}.landing-testimonials-modern{padding:60px 1.25rem}.testimonials-grid{grid-template-columns:1fr;gap:1rem;max-width:400px;margin:0 auto}.testimonial-card-modern{padding:1.5rem}.testimonial-quote{font-size:.95rem;line-height:1.6}.landing-cta{padding:60px 1.25rem}.cta-content{text-align:center;padding:0 .5rem}.cta-content h2{font-size:1.75rem;line-height:1.3;text-align:center}.cta-content>p{font-size:1rem;text-align:center}.cta-actions{flex-direction:column;gap:.75rem;align-items:center;width:100%;max-width:320px;margin:0 auto}.cta-actions .landing-btn-lg{width:100%}.landing-footer-modern{padding:40px 1.25rem 24px}.footer-content{gap:2.5rem}.footer-brand{text-align:center}.footer-brand p{max-width:100%;margin-left:auto;margin-right:auto}.footer-links{grid-template-columns:repeat(2,1fr);gap:1.5rem;text-align:center}.footer-col h4{margin-bottom:1rem}.footer-bottom{flex-direction:column;gap:1rem;text-align:center}.footer-legal{justify-content:center}}@media(max-width:480px){.landing-header-modern .landing-header-inner{padding:.75rem 1rem}.landing-logo-modern{font-size:1.25rem}.landing-logo-modern svg{width:28px;height:28px}.landing-hero-modern{padding:90px 1rem 50px}.title-line{font-size:1.75rem}.hero-subtitle{font-size:.95rem}.landing-btn-lg{padding:.875rem 1.5rem;font-size:.95rem}.landing-features-modern,.landing-how-modern,.landing-pricing-modern,.landing-testimonials-modern,.landing-preview{padding:50px 1rem}.landing-stats{padding:2.5rem 1rem}.stats-container{gap:1.25rem .75rem;max-width:320px}.landing-page .stat-number{font-size:1.75rem}.landing-page .stat-label{font-size:.8rem}.section-title{font-size:1.5rem}.section-subtitle{font-size:.9rem}.section-badge{font-size:.75rem;padding:.35rem .75rem}.feature-card-modern{padding:1.25rem}.feature-icon-modern{width:48px;height:48px}.feature-icon-modern svg{width:24px;height:24px}.how-steps-container{padding-left:45px}.how-steps-container:before{left:19px}.step-number{left:-45px;width:38px;height:38px;font-size:1rem}.pricing-card-modern{padding:1.5rem}.pricing-grid-5{max-width:320px}.pricing-card-compact{padding:1.25rem}.pricing-card-compact .pricing-header h3{font-size:1rem}.pricing-card-compact .pricing-price .amount{font-size:1.75rem}.pricing-header h3{font-size:1.25rem}.price-amount{font-size:2.25rem}.pricing-features li{font-size:.9rem;padding:.5rem 0}.testimonial-card-modern{padding:1.25rem}.author-avatar{width:40px;height:40px;font-size:.8rem}.author-info strong{font-size:.9rem}.author-info span{font-size:.8rem}.cta-content h2{font-size:1.5rem}.cta-content>p{font-size:.9rem}.cta-note{font-size:.8rem}.footer-links{grid-template-columns:1fr;gap:1.5rem}.footer-col{text-align:center}.footer-legal{flex-direction:column;gap:.75rem}}.landing-modern{overflow-x:hidden}.landing-modern img{max-width:100%;height:auto}@media(max-width:768px){.landing-btn-glow,.landing-btn-ghost,.landing-btn-outline-modern{min-height:44px}}@media print{.sidebar,.top-bar,.btn,button{display:none!important}.main-content{margin-left:0;padding:0;max-width:100%}.card,.stat-card,table{box-shadow:none;border:1px solid #ddd}}.chat-toggle-btn{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:var(--color-primary);color:#fff;border:none;cursor:pointer;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s;z-index:1000}.chat-toggle-btn:hover{transform:scale(1.05);box-shadow:0 6px 16px #0003}.chat-toggle-btn.open{background:var(--color-text-secondary)}.chat-toggle-btn svg{width:24px;height:24px}.chat-window{position:fixed;bottom:96px;right:24px;width:380px;height:500px;background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:0 8px 32px #00000026;display:flex;flex-direction:column;z-index:1000;overflow:hidden;animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);background:var(--color-primary);color:#fff}.chat-header-title{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:600}.chat-header-title .chat-icon{width:20px;height:20px}.chat-close-btn{background:none;border:none;color:#fff;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;opacity:.8;transition:opacity .2s}.chat-close-btn:hover{opacity:1}.chat-close-btn svg{width:18px;height:18px}.chat-messages{flex:1;overflow-y:auto;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-md)}.chat-message{display:flex;max-width:85%}.chat-message.user{margin-left:auto}.chat-message.assistant{margin-right:auto}.message-content{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);line-height:1.5}.chat-message.user .message-content{background:var(--color-primary);color:#fff;border-bottom-right-radius:4px}.chat-message.assistant .message-content{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);border-bottom-left-radius:4px}.message-content.typing{display:flex;gap:4px;padding:var(--spacing-md)}.message-content.typing .dot{width:8px;height:8px;background:var(--color-text-muted);border-radius:50%;animation:bounce 1.4s infinite}.message-content.typing .dot:nth-child(2){animation-delay:.2s}.message-content.typing .dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-4px)}}.message-actions{margin-top:var(--spacing-sm);display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.action-btn{background:var(--color-primary);color:#fff;border:none;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);cursor:pointer;transition:background .2s}.action-btn:hover{background:var(--color-primary-hover)}.message-list{margin:var(--spacing-sm) 0 0 0;padding-left:var(--spacing-md);font-size:var(--font-size-sm)}.message-list li{margin-bottom:var(--spacing-xs)}.chat-input-form{display:flex;padding:var(--spacing-md);border-top:1px solid var(--color-border);gap:var(--spacing-sm)}.chat-input-form input{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);outline:none;transition:border-color .2s}.chat-input-form input:focus{border-color:var(--color-primary)}.chat-input-form button{background:var(--color-primary);color:#fff;border:none;padding:var(--spacing-sm);border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.chat-input-form button:hover:not(:disabled){background:var(--color-primary-hover)}.chat-input-form button:disabled{opacity:.5;cursor:not-allowed}.chat-input-form button svg{width:18px;height:18px}@media(max-width:480px){.chat-toggle-btn{bottom:16px;right:16px;width:48px;height:48px}.chat-toggle-btn svg{width:20px;height:20px}.chat-window{bottom:0;right:0;left:0;width:100%;height:100%;border-radius:0}}.platform-admin-layout{display:flex;min-height:100vh}.platform-sidebar{width:260px;background:linear-gradient(180deg,#1e3a5f,#0f1f33);display:flex;flex-direction:column;position:fixed;height:100vh;left:0;top:0;z-index:100;transition:transform var(--transition-base)}.platform-brand{display:flex;align-items:center;gap:12px;padding:20px;color:#fff}.platform-brand-icon{width:32px;height:32px;color:#60a5fa}.platform-brand-text{font-size:18px;font-weight:700}.platform-sidebar .nav-links{flex:1;padding:16px 12px}.platform-sidebar .nav-links a{color:#ffffffb3;display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;text-decoration:none;margin-bottom:4px;transition:all var(--transition-fast)}.platform-sidebar .nav-links a:hover,.platform-sidebar .nav-links a.active{background:#ffffff1a;color:#fff}.platform-sidebar .nav-links a.active{background:#60a5fa33;color:#60a5fa}.nav-link-back{margin-top:auto;opacity:.7}.nav-link-back:hover{opacity:1}.nav-divider{height:1px;background:#ffffff1a;margin:16px 0}.platform-sidebar .nav-footer{padding:16px;border-top:1px solid rgba(255,255,255,.1)}.platform-avatar{background:linear-gradient(135deg,#60a5fa,#3b82f6)!important}.platform-main-content{flex:1;margin-left:260px;padding:24px 32px;background:var(--color-bg);min-height:100vh}.platform-top-bar{display:none}.platform-badge{background:linear-gradient(135deg,#1e3a5f,#0f1f33);color:#fff;padding:4px 12px;border-radius:4px;font-size:12px;font-weight:600}.platform-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:32px}.platform-stat-card{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #0000000f;border:1px solid var(--color-border-light)}.platform-stat-card.highlight{background:linear-gradient(135deg,#1e3a5f,#0f1f33);border:none}.platform-stat-card.highlight .platform-stat-number,.platform-stat-card.highlight .platform-stat-label{color:#fff}.platform-stat-number{font-size:36px;font-weight:700;color:var(--color-text);line-height:1;margin-bottom:8px}.platform-stat-label{font-size:14px;color:var(--color-text-secondary)}.platform-section{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #0000000f;margin-bottom:24px}.platform-section h2{margin-bottom:20px}.platform-table-container{overflow-x:auto}.platform-table{width:100%;border-collapse:collapse}.platform-table th,.platform-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--color-border-light)}.platform-table th{font-weight:600;color:var(--color-text-secondary);font-size:13px;text-transform:uppercase;letter-spacing:.5px}.platform-table tbody tr:hover{background:var(--color-border-light)}.tier-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;text-transform:capitalize}.tier-basic{background:#f1f5f9;color:#475569}.tier-professional{background:#dbeafe;color:#1d4ed8}.tier-enterprise{background:#fef3c7;color:#b45309}.platform-filters{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap}.platform-filters .search-form{display:flex;gap:8px;flex:1;min-width:250px}.platform-filters .search-form input{flex:1}.platform-filters select{min-width:150px}.platform-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-bottom:32px}.platform-detail-card{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #0000000f}.platform-detail-card h3{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--color-border-light)}.detail-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--color-border-light)}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--color-text-secondary);font-size:14px}.platform-mini-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;text-align:center}.mini-stat{padding:16px;background:var(--color-border-light);border-radius:8px}.mini-stat-number{font-size:28px;font-weight:700;color:var(--color-primary)}.mini-stat-label{font-size:12px;color:var(--color-text-secondary);margin-top:4px}.tier-select{padding:6px 12px;border:1px solid var(--color-border);border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.tier-select:focus{outline:none;border-color:var(--color-primary)}.tier-features{margin-top:16px;padding-top:16px;border-top:1px solid var(--color-border-light)}.tier-feature-header{font-size:12px;color:var(--color-text-secondary);margin-bottom:8px;font-weight:600;text-transform:uppercase}.tier-feature-list{list-style:none;padding:0;margin:0}.tier-feature-list li{font-size:13px;padding:4px 0;color:var(--color-text);display:flex;align-items:center;gap:8px}.tier-feature-list li.included:before{content:"✓";color:var(--color-success);font-weight:600}.branding-preview-mini{margin-top:12px}.brand-preview-bar{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:8px;margin-bottom:12px}.brand-preview-logo{width:28px;height:28px;border-radius:4px;object-fit:contain;background:#fff;padding:2px}.brand-colors{display:flex;gap:16px}.brand-color-swatch{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--color-text-secondary)}.back-link{color:var(--color-text-secondary);font-size:14px;text-decoration:none;display:inline-block;margin-bottom:8px}.back-link:hover{color:var(--color-primary)}.platform-admin-link{color:#60a5fa!important}.platform-admin-link:hover,.platform-admin-link.active{background:#60a5fa1a!important}@media(max-width:1024px){.platform-sidebar{transform:translate(-100%)}.platform-sidebar.open{transform:translate(0)}.platform-main-content{margin-left:0}.platform-top-bar{display:flex;align-items:center;gap:16px;padding:12px 0;margin-bottom:16px}}@media(max-width:768px){.platform-stats-grid{grid-template-columns:1fr 1fr}.platform-detail-grid,.platform-mini-stats{grid-template-columns:1fr}.platform-main-content{padding:16px}}@media(max-width:480px){.platform-stats-grid{grid-template-columns:1fr}}.allocation-progress{width:100%;height:8px;background:var(--color-border);border-radius:4px;overflow:hidden;margin-bottom:4px}.allocation-progress-bar{height:100%;border-radius:4px;transition:width .3s ease,background .3s ease}.allocation-progress-label{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:12px}.job-allocation-list{display:flex;flex-direction:column;gap:8px}.job-allocation-row{display:flex;align-items:center;gap:10px}.job-allocation-label{flex:1;font-size:.9rem;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.job-allocation-input{width:80px;padding:6px 8px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.9rem;text-align:right}.job-allocation-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.job-allocation-unit{font-size:.85rem;color:var(--color-text-secondary);width:24px}.preview-job-breakdown{padding:16px 0;border-top:1px solid var(--color-border)}.preview-job-breakdown h3{font-size:.9rem;font-weight:600;color:var(--color-text-secondary);margin:0 0 10px;text-transform:uppercase;letter-spacing:.5px}.job-breakdown-list{display:flex;flex-direction:column;gap:6px}.job-breakdown-row{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:var(--color-bg);border-radius:var(--radius-sm)}.job-breakdown-label{font-size:.9rem;color:var(--color-text-primary)}.job-breakdown-hours{font-size:.9rem;font-weight:600;color:var(--color-primary);white-space:nowrap}.chart-filters{display:flex;flex-wrap:wrap;align-items:center;gap:8px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px 16px;margin-bottom:1.5rem}.chart-filters select,.chart-filters input[type=date]{font-size:.82rem;padding:5px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm, 4px);background:var(--color-bg, #fff);min-width:0}.chart-filters select{max-width:170px}.chart-filters .btn-sm{margin-left:auto;font-size:.82rem;padding:5px 14px}.analytics-summary-cards{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.summary-card{flex:1;min-width:140px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px;display:flex;flex-direction:column;gap:4px}.summary-card-label{font-size:.8rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.summary-card-value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.chart-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-bottom:1.5rem}.chart-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px}.chart-card h3{font-size:.9rem;font-weight:600;color:var(--color-text-secondary);margin:0 0 12px}.chart-card-wide{grid-column:1 / -1}.chart-container{height:260px;position:relative}.leaderboard-list{list-style:none;padding:0;margin:0;counter-reset:lb}.leaderboard-list li{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--color-border);counter-increment:lb}.leaderboard-list li:last-child{border-bottom:none}.leaderboard-list li:before{content:counter(lb) ".";font-weight:600;color:var(--color-text-secondary);min-width:24px;font-size:.85rem}.lb-name{flex:1;font-size:.9rem;color:var(--color-text-primary);margin-left:8px}.lb-value{font-size:.9rem;font-weight:600;color:var(--color-primary);white-space:nowrap}@media(max-width:768px){.chart-grid{grid-template-columns:1fr}.chart-card-wide{grid-column:1}}.revenue-table{width:100%;border-collapse:collapse;font-size:.9rem}.revenue-table th,.revenue-table td{padding:10px 12px;border-bottom:1px solid var(--color-border)}.revenue-table th{font-weight:600;background:var(--color-bg);font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary)}.revenue-table td.positive{color:var(--color-success);font-weight:600}.revenue-table td.negative{color:var(--color-danger);font-weight:600}.export-btn{background:none;border:1px solid var(--color-border, #d1d5db);border-radius:4px;cursor:pointer;font-size:1rem;padding:2px 6px;margin-left:8px;vertical-align:middle;color:var(--color-text-secondary, #6b7280);line-height:1}.export-btn:hover{background:var(--color-bg-hover, #f3f4f6);color:var(--color-primary, #2563eb)}.workflows-page{max-width:1000px}.workflows-list{display:flex;flex-direction:column;gap:1rem}.workflow-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem}.workflow-card.workflow-inactive{opacity:.6}.workflow-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.workflow-card-header h3{margin:0 0 .25rem;display:flex;align-items:center;gap:.5rem;font-size:1rem}.workflow-description{color:var(--color-text-secondary);margin:0;font-size:.85rem}.workflow-actions{display:flex;gap:.5rem;flex-shrink:0}.workflow-steps-preview{margin-top:.75rem}.workflow-steps-preview ol{margin:0;padding-left:1.25rem}.workflow-steps-preview li{margin-bottom:.25rem;font-size:.875rem}.workflow-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.5rem;max-width:700px}.workflow-form h2{margin-top:0}.workflow-steps-editor{margin-top:1.5rem}.workflow-steps-editor h3{margin-bottom:.75rem}.step-card{background:var(--color-bg, #f9fafb);border:1px solid var(--color-border);border-radius:var(--radius-sm, 6px);padding:1rem;margin-bottom:.75rem}.step-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.step-number{font-weight:600;color:var(--color-primary, #4361ee)}.step-actions{display:flex;gap:4px}.step-fields{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}@media(max-width:600px){.step-fields{grid-template-columns:1fr}}.btn-icon{background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px}.btn-icon:hover:not(:disabled){background:var(--color-bg-hover, #f3f4f6)}.btn-icon:disabled{opacity:.35;cursor:not-allowed}.btn-icon-danger{color:#dc2626}.btn-icon-danger:hover:not(:disabled){background:#fef2f2}.settings-card-link{text-decoration:none;color:inherit;display:block;margin-bottom:1.5rem}.settings-card-nav{display:flex;justify-content:space-between;align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem;transition:border-color .15s}.settings-card-nav:hover{border-color:var(--color-primary, #4361ee)}.settings-card-nav h3{margin:0 0 .25rem;font-size:1rem}.settings-card-nav p{margin:0;font-size:.85rem;color:var(--color-text-secondary)}.link-arrow{font-size:1.25rem;color:var(--color-primary, #4361ee)}.workflow-step-progress{display:flex;gap:.5rem;flex-wrap:wrap;padding:.75rem;background:var(--color-bg, #f9fafb);border:1px solid var(--color-border);border-radius:var(--radius-sm, 6px);margin-bottom:1rem}.wf-step{display:flex;align-items:center;gap:.5rem;padding:.35rem .75rem;border-radius:4px;font-size:.8rem;border-left:3px solid transparent}.wf-step-pending{background:#fef3c7;border-left-color:#f59e0b}.wf-step-approved{background:#d1fae5;border-left-color:#10b981}.wf-step-rejected{background:#fee2e2;border-left-color:#ef4444}.wf-step-num{font-weight:700;min-width:16px}.wf-step-name{font-weight:500}.wf-step-status{text-transform:capitalize;font-size:.72rem;opacity:.8}.wf-step-reviewer{font-size:.72rem;color:var(--color-text-secondary)}.pipeline-filters{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:1.25rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:8px;padding:.75rem 1rem}.pipeline-filters input,.pipeline-filters select{font-size:var(--font-size-sm);padding:6px 10px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg)}.pipeline-filters input[type=text]{min-width:160px}.job-allocation-item{margin-bottom:.5rem}.job-candidates{margin:4px 0 8px;padding-left:8px;border-left:2px solid var(--color-border)}.job-candidate-row{display:flex;align-items:center;gap:4px;margin-bottom:4px}.job-candidate-input{flex:1;padding:4px 8px;font-size:var(--font-size-sm);border:1px solid var(--color-border);border-radius:4px}.job-candidate-add{background:none;border:none;color:var(--color-primary);font-size:var(--font-size-xs);cursor:pointer;padding:2px 0}.job-candidate-add:hover{text-decoration:underline}.badge-pipeline-blue{background:var(--color-info-light);color:#2563eb}.badge-pipeline-gray{background:#f1f5f9;color:#64748b}.badge-pipeline-yellow{background:#fef9c3;color:#a16207}.badge-pipeline-orange{background:#ffedd5;color:#c2410c}.badge-pipeline-red{background:var(--color-danger-light);color:var(--color-danger-dark)}.badge-pipeline-green{background:var(--color-success-light);color:var(--color-success-dark)}.pipeline-status-select{font-size:var(--font-size-xs);padding:4px 6px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg);cursor:pointer}.invoice-form-modal,.invoice-detail-modal{max-width:900px;padding:var(--spacing-xl) var(--spacing-2xl)}.invoice-form-title{margin:0 0 var(--spacing-lg) 0;font-size:var(--font-size-xl);font-weight:700;color:var(--color-text)}.invoice-section{padding:var(--spacing-lg) 0;border-bottom:1px solid var(--color-border-light)}.invoice-section:last-of-type{border-bottom:none}.invoice-section-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--spacing-md) 0}.invoice-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg) var(--spacing-xl)}.invoice-placements-chips{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.invoice-line-items-table{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.invoice-li-header{display:grid;grid-template-columns:3fr 1fr 1fr 1fr 36px;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg);border-bottom:1px solid var(--color-border);font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em}.invoice-li-row{display:grid;grid-template-columns:3fr 1fr 1fr 1fr 36px;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);align-items:center;border-bottom:1px solid var(--color-border-light)}.invoice-li-row:last-child{border-bottom:none}.invoice-li-row input{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--color-bg-card);transition:border-color .15s}.invoice-li-row input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px var(--color-primary-light)}.invoice-li-col-desc{min-width:0}.invoice-li-col-num{text-align:right}.invoice-li-col-action{width:36px;display:flex;align-items:center;justify-content:center}.invoice-li-remove{color:var(--color-danger);background:none;border:none;cursor:pointer;font-size:1.4rem;line-height:1;padding:0;border-radius:var(--radius-sm);width:32px;height:32px;transition:background .15s}.invoice-li-remove:hover{background:var(--color-danger-light)}.invoice-totals{display:flex;flex-direction:column;align-items:flex-end;padding:var(--spacing-lg) 0;gap:var(--spacing-xs)}.invoice-totals-row{display:flex;justify-content:space-between;width:240px;font-size:var(--font-size-sm);color:var(--color-text-secondary);padding:var(--spacing-xs) 0}.invoice-totals-row span:last-child{font-weight:600;color:var(--color-text)}.invoice-totals-total{border-top:2px solid var(--color-border);margin-top:var(--spacing-xs);padding-top:var(--spacing-sm);font-size:var(--font-size-lg)}.invoice-totals-total span:last-child{color:var(--color-primary);font-weight:700}.invoice-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.invoice-detail-header h2{margin:0;font-size:var(--font-size-xl);font-weight:700}.invoice-detail-meta{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md) var(--spacing-xl);padding:var(--spacing-lg);background:var(--color-bg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg)}.invoice-meta-item{display:flex;flex-direction:column;gap:2px}.invoice-meta-label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em}.invoice-meta-value{font-size:var(--font-size-base);color:var(--color-text);font-weight:500}.invoice-notes{padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg);border-radius:var(--radius-lg);margin-top:var(--spacing-md)}.invoice-notes p{margin:var(--spacing-xs) 0 0 0;font-size:var(--font-size-sm);color:var(--color-text);line-height:1.5}.invoice-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;padding-top:var(--spacing-lg);border-top:1px solid var(--color-border-light);margin-top:var(--spacing-md)}.invoice-status-badge{display:inline-block;background-color:var(--badge-color);color:#fff;padding:3px 12px;border-radius:12px;font-size:var(--font-size-xs);font-weight:600;text-transform:capitalize}@media(max-width:768px){.invoice-form-modal,.invoice-detail-modal{max-width:100%;padding:var(--spacing-lg)}.invoice-form-grid,.invoice-detail-meta{grid-template-columns:1fr}.invoice-li-header,.invoice-li-row{grid-template-columns:2fr 1fr 1fr 1fr 32px;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm)}.invoice-li-header{display:none}.invoice-li-row{grid-template-columns:1fr;gap:var(--spacing-xs);padding:var(--spacing-md);border:1px solid var(--color-border-light);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm)}.invoice-li-row input{width:100%}.invoice-li-col-action{justify-content:flex-end;width:100%}.invoice-totals-row{width:100%}}.candidate-section{margin-bottom:var(--spacing-xl)}.candidate-section-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);margin:0 0 var(--spacing-md) 0}.candidate-placements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-md)}.candidate-placement-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:box-shadow .15s}.candidate-placement-card:hover{box-shadow:var(--shadow-md)}.candidate-placement-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-text);margin-bottom:4px}.candidate-placement-client{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.candidate-placement-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-muted);align-items:center}.portal-tab{background:none;border:none;padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.portal-tab:hover{color:var(--color-text)}.portal-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}@media(max-width:768px){.candidate-placements-grid{grid-template-columns:1fr}.portal-tab{flex:1;text-align:center;padding:var(--spacing-md) var(--spacing-sm);min-height:48px;font-size:var(--font-size-sm)}.candidate-section{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}.candidate-section .table-responsive{margin:0;padding:0}.candidate-section .data-table{min-width:450px}}.invoice-builder{min-height:100vh;background:var(--color-bg);padding:var(--spacing-lg)}.invoice-builder-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.invoice-builder-header h1{font-size:var(--font-size-2xl);font-weight:600;color:var(--color-text);margin:0}.invoice-builder-content{max-width:900px;margin:0 auto}.invoice-card{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-xl)}.invoice-title-section{margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border-light);padding-bottom:var(--spacing-lg)}.invoice-main-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text);border:none;background:transparent;width:100%;outline:none;padding:var(--spacing-xs) 0}.invoice-main-title:focus{border-bottom:2px solid var(--color-primary)}.invoice-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);border:none;background:transparent;width:100%;outline:none;padding:var(--spacing-xs) 0;margin-top:var(--spacing-xs)}.add-link{background:none;border:none;color:var(--color-primary);font-size:var(--font-size-sm);cursor:pointer;padding:var(--spacing-xs) 0;display:inline-block}.add-link:hover{text-decoration:underline}.invoice-details-row{display:flex;gap:var(--spacing-xl);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.invoice-detail-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.invoice-detail-item label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500}.invoice-detail-item input{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);min-width:160px}.invoice-parties-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl);margin-bottom:var(--spacing-lg);padding:var(--spacing-lg) 0;border-top:1px solid var(--color-border-light);border-bottom:1px solid var(--color-border-light)}.invoice-party-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.party-header{display:flex;justify-content:space-between;align-items:center}.party-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.edit-link{background:none;border:none;color:var(--color-primary);font-size:var(--font-size-sm);cursor:pointer;padding:var(--spacing-xs)}.edit-link:hover{text-decoration:underline}.party-edit-form{display:flex;flex-direction:column;gap:var(--spacing-sm)}.party-edit-form input,.party-edit-form textarea{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-family:inherit}.party-details{margin-top:var(--spacing-sm)}.party-name{font-weight:600;color:var(--color-text);font-size:var(--font-size-base)}.party-address,.party-contact,.party-email,.party-phone{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.client-select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);background:var(--color-bg-card);width:100%;max-width:300px}.invoice-currency-row{display:flex;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.currency-select-wrapper{display:flex;align-items:center;gap:var(--spacing-sm)}.currency-select-wrapper label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.currency-select-wrapper select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--color-bg-card)}.invoice-line-items{margin-bottom:var(--spacing-lg)}.line-items-header{display:grid;grid-template-columns:1fr 100px 100px 120px 70px;gap:var(--spacing-sm);background:var(--color-primary);color:#fff;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md) var(--radius-md) 0 0;font-size:var(--font-size-sm);font-weight:600}.line-item-row{display:grid;grid-template-columns:1fr 100px 100px 120px 70px;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-top:none;align-items:center}.line-item-row:nth-child(2n){background:var(--color-bg)}.line-item-row input{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);width:100%}.line-item-row input:focus{outline:none;border-color:var(--color-primary)}.li-col-actions{display:flex;gap:var(--spacing-xs);justify-content:center}.li-action-btn{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:var(--spacing-xs);font-size:var(--font-size-base);border-radius:var(--radius-sm)}.li-action-btn:hover{background:var(--color-bg);color:var(--color-primary)}.li-action-btn.li-delete:hover{color:var(--color-danger)}.li-action-btn:disabled{opacity:.3;cursor:not-allowed}.add-line-btn{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px dashed var(--color-border);border-top:none;background:var(--color-bg);color:var(--color-primary);font-size:var(--font-size-sm);cursor:pointer;border-radius:0 0 var(--radius-md) var(--radius-md);transition:background .15s}.add-line-btn:hover{background:var(--color-primary-light)}.invoice-totals-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border-light)}.totals-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;font-size:var(--font-size-base)}.totals-row>span:first-child{color:var(--color-text-secondary)}.discount-row,.tax-row,.additional-charges-row{background:var(--color-bg);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);margin:var(--spacing-xs) 0}.discount-inputs,.tax-inputs,.additional-inputs{display:flex;align-items:center;gap:var(--spacing-sm)}.discount-inputs input,.tax-inputs input,.additional-inputs input{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);width:80px}.discount-inputs select,.tax-inputs select{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);background:var(--color-bg-card)}.remove-modifier{background:none;border:none;color:var(--color-danger);font-size:var(--font-size-lg);cursor:pointer;padding:0 var(--spacing-xs)}.discount-amount{color:var(--color-danger)}.add-modifier-row{justify-content:flex-start;padding:var(--spacing-xs) 0}.grand-total-row{font-size:var(--font-size-lg);font-weight:700;padding:var(--spacing-md) 0;border-top:2px solid var(--color-border);margin-top:var(--spacing-sm)}.grand-total-row>span:first-child{color:var(--color-text)}.grand-total-amount{color:var(--color-primary);font-size:var(--font-size-xl)}.total-in-words{background:var(--color-bg);padding:var(--spacing-md);border-radius:var(--radius-md);margin-top:var(--spacing-md)}.words-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:block;margin-bottom:var(--spacing-xs)}.words-value{font-style:italic;color:var(--color-text)}.invoice-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border-light)}.invoice-section h3{font-size:var(--font-size-base);font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-md)}.attachments-section .attachment-controls{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--spacing-md)}.attachments-section .attachment-badge{display:inline-block;background:var(--color-primary-light);color:var(--color-primary);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500}.attachments-section .attachment-actions{display:flex;gap:var(--spacing-sm)}.attachments-section .attachment-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-xs)}.attachments-section .attachment-btn .btn-icon{font-size:14px}.notes-section textarea{width:100%;padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-family:inherit;resize:vertical}.notes-section textarea:focus{outline:none;border-color:var(--color-primary)}.terms-list{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.term-row{display:flex;align-items:center;gap:var(--spacing-sm)}.term-number{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500;min-width:30px}.term-row input{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.term-row input:focus{outline:none;border-color:var(--color-primary)}.term-delete{background:none;border:none;color:var(--color-danger);font-size:var(--font-size-lg);cursor:pointer;padding:var(--spacing-xs)}.recurring-toggle{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.recurring-toggle input{width:18px;height:18px;accent-color:var(--color-primary)}.recurring-options{margin-top:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius-md)}.recurring-options select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--color-bg-card);margin-bottom:var(--spacing-sm)}.recurring-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.invoice-builder-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg)}.btn-outline{background:var(--color-bg-card);border:2px solid var(--color-border);color:var(--color-text);box-shadow:none}.btn-outline:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-lighter)}@media(max-width:768px){.invoice-builder,.invoice-card{padding:var(--spacing-md)}.invoice-parties-row{grid-template-columns:1fr}.invoice-details-row{flex-direction:column;gap:var(--spacing-md)}.line-items-header,.line-item-row{grid-template-columns:1fr;gap:var(--spacing-xs)}.line-items-header{display:none}.line-item-row{padding:var(--spacing-md);border:1px solid var(--color-border);margin-bottom:var(--spacing-sm);border-radius:var(--radius-md)}.line-item-row input{padding:var(--spacing-sm) var(--spacing-md)}.li-col-actions{justify-content:flex-start;margin-top:var(--spacing-sm)}.invoice-builder-actions{flex-direction:column}.invoice-builder-actions .btn{width:100%}}.invoices-dashboard{max-width:1400px}.invoice-tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border);margin-bottom:var(--spacing-lg)}.invoice-tab{padding:var(--spacing-md) var(--spacing-xl);background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:var(--font-size-base);font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.invoice-tab:hover{color:var(--color-primary)}.invoice-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.invoice-tab-badge{margin-left:var(--spacing-xs);background:var(--color-primary);color:#fff;border-radius:10px;padding:2px 8px;font-size:var(--font-size-xs)}.invoice-tab-count{font-weight:500;color:inherit;opacity:.8}.invoice-dropdown-menu-fixed button:hover{background:var(--color-bg-secondary)}.invoice-section-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);overflow:hidden}.invoice-section-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast)}.invoice-section-header:hover{background:var(--color-bg-secondary)}.invoice-section-chevron{font-size:10px;color:var(--color-text-secondary);width:16px}.invoice-section-title{font-weight:600;font-size:var(--font-size-base)}.invoice-filters-content{padding:var(--spacing-lg);border-top:1px solid var(--color-border)}.invoice-filters-row{display:flex;flex-wrap:wrap;gap:var(--spacing-lg);margin-bottom:var(--spacing-md)}.invoice-filter-group{display:flex;flex-direction:column;gap:var(--spacing-xs);min-width:200px}.invoice-filter-group label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.invoice-filter-group select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--color-bg)}.invoice-status-multiselect{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.invoice-status-checkbox{display:flex;align-items:center;gap:var(--spacing-xs);cursor:pointer}.invoice-status-checkbox input{accent-color:var(--color-primary)}.invoice-status-label{font-size:var(--font-size-sm);padding:2px 8px;border-radius:var(--radius-sm);background:color-mix(in srgb,var(--status-color) 15%,white);color:var(--status-color);font-weight:500}.invoice-date-range{display:flex;align-items:center;gap:var(--spacing-sm)}.invoice-date-range input{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.invoice-date-range span{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.invoice-applied-filters{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.invoice-applied-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.invoice-filter-tag{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:4px 10px;background:color-mix(in srgb,var(--tag-color, var(--color-primary)) 15%,white);color:var(--tag-color, var(--color-primary));border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500}.invoice-filter-tag button{background:none;border:none;font-size:14px;line-height:1;cursor:pointer;color:inherit;opacity:.7}.invoice-filter-tag button:hover{opacity:1}.invoice-filters-actions{display:flex;align-items:center;gap:var(--spacing-md)}.btn-link{background:none;border:none;color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;text-decoration:underline;box-shadow:none}.btn-link:hover{color:var(--color-primary);transform:none;box-shadow:none}.invoice-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-md);padding:var(--spacing-lg)}.invoice-summary-card{background:var(--color-bg);border-radius:var(--radius-md);padding:var(--spacing-lg);border-left:4px solid var(--color-border);box-shadow:var(--shadow-sm)}.invoice-summary-total{border-left-color:var(--color-primary)}.invoice-summary-paid{border-left-color:#10b981}.invoice-summary-unpaid{border-left-color:#f59e0b}.invoice-summary-overdue{border-left-color:#ef4444}.invoice-summary-draft{border-left-color:#94a3b8}.invoice-summary-count{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text)}.invoice-summary-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.invoice-summary-amount{font-size:var(--font-size-base);font-weight:600;color:var(--color-text)}.invoice-chart-container{padding:var(--spacing-lg)}.invoice-chart-empty{padding:var(--spacing-xl);text-align:center;color:var(--color-text-secondary)}.invoice-table-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.invoice-table-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border);background:var(--color-bg)}.invoice-table-info{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.invoice-table-controls{display:flex;align-items:center;gap:var(--spacing-md)}.invoice-table-controls select{padding:var(--spacing-xs) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--color-bg-card)}.invoice-column-menu-wrapper{position:relative}.invoice-column-menu{position:absolute;top:100%;right:0;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--spacing-sm);z-index:100;min-width:180px}.invoice-column-option{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm);cursor:pointer}.invoice-column-option:hover{background:var(--color-bg);border-radius:var(--radius-sm)}.invoice-table-responsive{overflow-x:auto}.invoice-data-table{width:100%;border-collapse:collapse}.invoice-data-table thead{background:var(--color-bg)}.invoice-data-table th{padding:var(--spacing-md);text-align:left;font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border)}.invoice-data-table td{padding:var(--spacing-md);font-size:var(--font-size-sm);border-bottom:1px solid var(--color-border);vertical-align:middle}.invoice-row{transition:background var(--transition-fast)}.invoice-row:hover{background:var(--color-bg)}.invoice-row:nth-child(2n){background:var(--color-bg-secondary)}.invoice-row:nth-child(2n):hover{background:var(--color-bg)}.invoice-row-selected{background:color-mix(in srgb,var(--color-primary) 10%,white)!important}.invoice-empty-row{text-align:center;color:var(--color-text-secondary);padding:var(--spacing-xl)!important}.invoice-loading{text-align:center;padding:var(--spacing-xl);color:var(--color-text-secondary)}.invoice-col-checkbox{width:40px;text-align:center}.invoice-col-num{width:50px;color:var(--color-text-secondary)}.invoice-col-date{white-space:nowrap}.invoice-col-expand{width:40px}.invoice-col-invoice{font-weight:500}.invoice-col-amount{font-weight:600;white-space:nowrap}.invoice-col-status{min-width:120px}.invoice-col-actions{width:140px}.invoice-link{color:var(--color-primary);text-decoration:none;font-weight:500}.invoice-link:hover{text-decoration:underline}.invoice-expand-btn{width:24px;height:24px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);cursor:pointer;font-size:14px;font-weight:600;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.invoice-expand-btn:hover,.invoice-expand-btn.expanded{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.invoice-status-pill{display:inline-block;padding:4px 12px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;text-transform:capitalize;background:color-mix(in srgb,var(--pill-color) 15%,white);color:var(--pill-color)}.invoice-due-hint,.invoice-paid-hint{font-size:10px;color:var(--color-text-secondary);margin-top:2px}.invoice-email-sent{color:#10b981;font-size:var(--font-size-xs)}.invoice-email-not-sent{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-text-secondary);font-size:var(--font-size-xs)}.invoice-send-link{background:none;border:none;color:var(--color-primary);font-size:var(--font-size-xs);cursor:pointer;text-decoration:underline}.invoice-action-buttons{display:flex;align-items:center;gap:var(--spacing-xs)}.invoice-action-btn{width:28px;height:28px;border:none;background:transparent;cursor:pointer;font-size:14px;color:var(--color-text-secondary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.invoice-action-btn:hover{background:var(--color-bg);color:var(--color-text)}.invoice-action-paid:hover{background:#10b981;color:#fff}.invoice-more-menu-wrapper{position:relative}.invoice-more-menu{position:absolute;top:100%;right:0;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;min-width:150px;overflow:hidden}.invoice-more-menu button{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;text-align:left;font-size:var(--font-size-sm);cursor:pointer;transition:background var(--transition-fast)}.invoice-more-menu button:hover{background:var(--color-bg)}.invoice-menu-danger{color:var(--color-danger)}.invoice-menu-danger:hover{background:color-mix(in srgb,var(--color-danger) 10%,white)!important}.invoice-expanded-row,.invoice-expanded-row:hover{background:var(--color-bg)!important}.invoice-line-items-expanded{padding:var(--spacing-md) var(--spacing-lg) var(--spacing-md) 80px}.invoice-line-items-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.invoice-line-items-table th{padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border)}.invoice-line-items-table td{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border)}.invoice-pagination{display:flex;justify-content:center;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-lg);border-top:1px solid var(--color-border)}.invoice-page-btn{min-width:36px;height:36px;border:1px solid var(--color-border);background:var(--color-bg-card);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);transition:all var(--transition-fast)}.invoice-page-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.invoice-page-btn:disabled{opacity:.5;cursor:not-allowed}.invoice-page-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.invoice-bulk-actions{position:fixed;bottom:var(--spacing-xl);left:50%;transform:translate(-50%);background:var(--color-text);color:#fff;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);display:flex;align-items:center;gap:var(--spacing-xl);z-index:1000;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translate(-50%) translateY(100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.invoice-bulk-count{font-weight:500;white-space:nowrap}.invoice-bulk-buttons{display:flex;gap:var(--spacing-sm)}.invoice-bulk-buttons .btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff}.invoice-bulk-buttons .btn:hover{background:#fff3}.invoice-bulk-buttons .btn-danger{background:var(--color-danger);border-color:var(--color-danger)}.invoice-bulk-close{background:none;border:none;color:#ffffffb3;font-size:20px;cursor:pointer;padding:0 var(--spacing-sm)}.invoice-bulk-close:hover{color:#fff}.invoice-summary-row{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.invoice-summary-row .invoice-summary-card{flex:1;min-width:150px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md) var(--spacing-lg);border-left:4px solid var(--color-border)}.invoice-summary-row .invoice-summary-card.invoice-summary-paid{border-left-color:#10b981}.invoice-summary-row .invoice-summary-card.invoice-summary-unpaid{border-left-color:#f59e0b}.invoice-summary-row .invoice-summary-card.invoice-summary-overdue{border-left-color:#ef4444}.invoice-summary-row .invoice-summary-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text);line-height:1}.invoice-summary-row .invoice-summary-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:var(--spacing-xs) 0}.invoice-summary-row .invoice-summary-amount{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text)}.invoice-actions-cell{display:flex;align-items:center;gap:var(--spacing-xs)}.invoice-actions-cell .btn-sm{padding:4px 10px;font-size:var(--font-size-xs)}.invoice-more-wrapper{position:relative;display:inline-block}.invoice-dropdown-menu{position:absolute;top:100%;right:0;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;min-width:150px;overflow:hidden}.invoice-dropdown-menu button{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;text-align:left;font-size:var(--font-size-sm);cursor:pointer;color:var(--color-text)}.invoice-dropdown-menu button:hover{background:var(--color-bg)}.invoice-dropdown-menu button.text-danger{color:var(--color-danger)}.invoice-dropdown-menu button.text-danger:hover{background:var(--color-danger-light)}@media(max-width:1024px){.invoice-filters-row{flex-direction:column}.invoice-filter-group{width:100%}.invoice-summary-cards{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.invoice-table-header{flex-direction:column;gap:var(--spacing-md);align-items:flex-start}.invoice-summary-cards{grid-template-columns:1fr}.invoice-bulk-actions{left:var(--spacing-md);right:var(--spacing-md);transform:none;flex-wrap:wrap;justify-content:center}.invoice-tabs{width:100%}.invoice-tab{flex:1;text-align:center;padding:var(--spacing-md) var(--spacing-sm);min-height:48px;font-size:var(--font-size-sm)}.invoice-summary-row{display:grid!important;grid-template-columns:repeat(2,1fr);gap:12px}.invoice-summary-row .invoice-summary-card{min-width:0;padding:12px}.invoice-summary-row .invoice-summary-value{font-size:20px}.invoice-summary-row .invoice-summary-label{font-size:11px}.invoice-summary-row .invoice-summary-amount{font-size:12px}.invoice-filters-compact{flex-direction:column!important;align-items:stretch!important}.invoice-filters-compact select,.invoice-filters-compact input{width:100%!important;max-width:100%!important;min-width:0!important;height:40px!important}.invoice-filters-compact>div{flex-direction:column!important;width:100%}.invoice-filters-compact>div input{width:100%!important}.table-actions{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.table-actions .btn-sm{min-height:40px}.invoice-dropdown-menu{position:fixed;bottom:0;left:0;right:0;top:auto;border-radius:var(--radius-xl) var(--radius-xl) 0 0;min-width:100%;max-height:50vh;padding-bottom:env(safe-area-inset-bottom)}.invoice-dropdown-menu button{min-height:48px;padding:var(--spacing-md);font-size:var(--font-size-base)}}.signup-page-modern{display:flex;min-height:100vh;background:#0f172a}.signup-branding{flex:1;display:flex;align-items:center;justify-content:center;padding:3rem;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);position:relative;overflow:hidden}.signup-branding-content{max-width:480px;position:relative;z-index:2}.signup-logo{display:flex;align-items:center;gap:12px;margin-bottom:3rem;cursor:pointer;transition:opacity .2s}.signup-logo:hover{opacity:.9}.signup-logo span{font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,#06b6d4,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.signup-tagline{font-size:2.5rem;font-weight:700;color:#f8fafc;line-height:1.2;margin-bottom:1rem}.signup-tagline-sub{font-size:1.125rem;color:#94a3b8;line-height:1.6;margin-bottom:2.5rem}.signup-features{display:flex;flex-direction:column;gap:1rem}.signup-feature{display:flex;align-items:center;gap:12px;color:#f8fafc;font-size:1rem}.signup-feature svg{flex-shrink:0;stroke:#06b6d4}.signup-decorative{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;overflow:hidden}.signup-circle{position:absolute;border-radius:50%;opacity:.1}.signup-circle-1{width:400px;height:400px;background:linear-gradient(135deg,#06b6d4,#8b5cf6);top:-150px;right:-100px;animation:float 20s ease-in-out infinite}.signup-circle-2{width:300px;height:300px;background:linear-gradient(135deg,#8b5cf6,#06b6d4);bottom:-100px;left:-50px;animation:float 25s ease-in-out infinite reverse}.signup-circle-3{width:200px;height:200px;background:#14b8a6;top:50%;left:60%;animation:float 15s ease-in-out infinite}@keyframes float{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(10px,-20px) rotate(5deg)}50%{transform:translate(-10px,10px) rotate(-5deg)}75%{transform:translate(20px,10px) rotate(3deg)}}.signup-form-side{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;background:#f8fafc}.signup-form-container{width:100%;max-width:440px}.signup-form-card{background:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.signup-form-title{font-size:1.75rem;font-weight:700;color:#0f172a;margin-bottom:.5rem}.signup-form-subtitle{font-size:.95rem;color:#64748b;margin-bottom:1.75rem}.signup-error{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.875rem;margin-bottom:1.5rem}.signup-error svg{flex-shrink:0}.signup-form{display:flex;flex-direction:column;gap:1rem}.signup-field{flex:1}.signup-field-row{display:flex;gap:1rem}.signup-input-wrapper{position:relative;display:flex;align-items:center}.signup-input-icon{position:absolute;left:14px;stroke:#94a3b8;pointer-events:none;transition:stroke .2s}.signup-input{width:100%;padding:14px 14px 14px 44px;border:1px solid #e2e8f0;border-radius:10px;font-size:.95rem;color:#0f172a;background:#f8fafc;transition:border-color .2s,box-shadow .2s,background .2s}.signup-input::placeholder{color:#94a3b8}.signup-input:focus{outline:none;border-color:#06b6d4;box-shadow:0 0 0 3px #06b6d426;background:#fff}.signup-input:focus+.signup-input-icon,.signup-input-wrapper:focus-within .signup-input-icon{stroke:#06b6d4}.signup-input-password{padding-right:44px}.signup-password-toggle{position:absolute;right:12px;background:none;border:none;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center}.signup-password-toggle svg{stroke:#94a3b8;transition:stroke .2s}.signup-password-toggle:hover svg{stroke:#64748b}.signup-submit-btn{width:100%;padding:14px 24px;margin-top:.5rem;background:linear-gradient(135deg,#06b6d4,#8b5cf6);border:none;border-radius:10px;font-size:1rem;font-weight:600;color:#fff;cursor:pointer;transition:transform .2s,box-shadow .2s,opacity .2s;display:flex;align-items:center;justify-content:center;gap:8px}.signup-submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 25px -5px #06b6d466}.signup-submit-btn:active:not(:disabled){transform:translateY(0)}.signup-submit-btn:disabled{opacity:.7;cursor:not-allowed}.signup-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.signup-login-link{text-align:center;margin-top:1.5rem;font-size:.9rem;color:#64748b}.signup-login-link a{color:#06b6d4;font-weight:500;text-decoration:none;transition:color .2s}.signup-login-link a:hover{color:#0891b2;text-decoration:underline}.signup-terms{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e2e8f0;font-size:.8rem;color:#94a3b8;line-height:1.5}.signup-terms a{color:#64748b;text-decoration:none;transition:color .2s}.signup-terms a:hover{color:#06b6d4;text-decoration:underline}@media(max-width:1024px){.signup-branding{padding:2rem}.signup-tagline{font-size:2rem}}@media(max-width:768px){.signup-page-modern{flex-direction:column}.signup-branding{flex:none;padding:2rem 1.5rem;min-height:auto}.signup-branding-content{max-width:100%}.signup-logo{margin-bottom:1.5rem}.signup-logo span{font-size:1.5rem}.signup-tagline{font-size:1.5rem;margin-bottom:.75rem}.signup-tagline-sub{font-size:1rem;margin-bottom:1.5rem}.signup-features{display:none}.signup-circle-1{width:200px;height:200px;top:-50px;right:-50px}.signup-circle-2{width:150px;height:150px;bottom:-50px;left:-30px}.signup-circle-3{display:none}.signup-form-side{padding:1.5rem;flex:1}.signup-form-card{padding:1.5rem;border-radius:12px}.signup-form-title{font-size:1.5rem}.signup-field-row{flex-direction:column;gap:1rem}.signup-input{padding:12px 12px 12px 40px}.signup-input-icon{left:12px}}@media(max-width:380px){.signup-branding{padding:1.5rem 1rem}.signup-form-side{padding:1rem}.signup-form-card{padding:1.25rem}.signup-form-title{font-size:1.25rem}.signup-form-subtitle{font-size:.875rem}}.mobile-sheet-overlay{display:none}@media(max-width:768px){.mobile-sheet-overlay{display:flex;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:9999;align-items:flex-end;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-sheet{background:var(--color-bg);width:100%;max-height:85vh;border-radius:16px 16px 0 0;display:flex;flex-direction:column;animation:slideUp .3s ease-out;transition:transform .1s ease-out}.mobile-sheet-dragging{transition:none}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-sheet-handle{display:flex;justify-content:center;padding:12px 0 8px;cursor:grab}.mobile-sheet-handle-bar{width:40px;height:4px;background:#d1d5db;border-radius:2px}.mobile-sheet-header{display:flex;justify-content:space-between;align-items:center;padding:0 20px 16px;border-bottom:1px solid var(--color-border)}.mobile-sheet-title{font-size:18px;font-weight:600;margin:0;color:var(--color-text)}.mobile-sheet-close{width:32px;height:32px;border:none;background:var(--color-bg-secondary);border-radius:50%;font-size:20px;color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.mobile-sheet-close:hover,.mobile-sheet-close:active{background:var(--color-bg-tertiary);color:var(--color-text)}.mobile-sheet-content{padding:20px;overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}.mobile-sheet-row{display:flex;justify-content:space-between;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--color-border-light)}.mobile-sheet-row:last-child{border-bottom:none}.mobile-sheet-label{font-size:14px;color:var(--color-text-secondary);flex-shrink:0}.mobile-sheet-value{font-size:14px;color:var(--color-text);font-weight:500;text-align:right;word-break:break-word}.mobile-sheet-value-large{font-size:24px;font-weight:700;color:var(--color-text)}.mobile-sheet-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px;padding-top:20px;border-top:1px solid var(--color-border)}.mobile-sheet-actions-row{display:flex;gap:10px}.mobile-sheet-actions .btn{flex:1;min-height:48px;font-size:15px;justify-content:center}.mobile-list-item{display:flex;align-items:center;padding:14px 16px;background:#fff;border-bottom:1px solid #F0F0F0;cursor:pointer;transition:background .15s ease;-webkit-tap-highlight-color:transparent}.mobile-list-item:first-child{border-top:1px solid #F0F0F0}.mobile-list-item:active{background:#f9fafb}.mobile-list-item-content{flex:1;min-width:0}.mobile-list-item-primary{display:flex;justify-content:space-between;align-items:center;gap:12px}.mobile-list-item-name{font-size:15px;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-list-item-secondary{font-size:13px;color:#6b7280;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-list-item-chevron{font-size:12px;color:#d1d5db;margin-left:8px;flex-shrink:0}.mobile-list-header{display:flex;justify-content:space-between;align-items:center;padding:16px 0}.mobile-list-title{font-size:20px;font-weight:700;margin:0}.mobile-list-actions{display:flex;gap:8px}.mobile-filter-btn{width:40px;height:40px;border:1px solid var(--color-border);background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer}.team-cards.desktop-table,.period-cards.desktop-table{display:none!important}.mobile-checkin-card.not-submitted{border-color:var(--color-border);background:#fff}.section-header .header-actions{display:flex;flex-wrap:wrap;gap:6px}.section-header .header-actions .btn{padding:8px 12px;font-size:13px;white-space:nowrap}.section-header .header-actions .btn-sm{padding:6px 10px;font-size:12px}.filter-bar{flex-wrap:wrap;gap:8px;padding:12px}.filter-bar input,.filter-bar select{flex:1;min-width:120px;font-size:14px}.filter-bar .filter-actions{width:100%;display:flex;gap:8px}.filter-bar .filter-actions .btn{flex:1}.invoice-filters-compact{flex-wrap:wrap!important;gap:8px!important}.invoice-filters-compact select,.invoice-filters-compact input{flex:1;min-width:100px!important;max-width:none!important}.team-filters{flex-direction:column;gap:10px}.team-filters .search-box{width:100%}.team-filters .filter-group{display:flex;flex-wrap:wrap;gap:8px;width:100%}.team-filters .filter-group select{flex:1;min-width:120px}.audit-logs-filters{flex-wrap:wrap;gap:8px}.audit-logs-filters select,.audit-logs-filters input{flex:1;min-width:120px}.page-header{flex-wrap:wrap;gap:12px}.page-header .btn{padding:10px 16px;font-size:14px}.filter-bar.desktop-table{display:none!important}.mobile-filter-bar{display:flex!important;padding:0 0 12px}.mobile-filter-toggle{display:flex;align-items:center;gap:8px;width:100%;justify-content:center;min-height:44px;font-size:14px}.mobile-filter-badge{background:var(--color-primary);color:#fff;font-size:11px;padding:2px 8px;border-radius:10px;font-weight:600}.mobile-filter-content{display:flex;flex-direction:column;gap:16px}.mobile-filter-field{display:flex;flex-direction:column;gap:6px}.mobile-filter-field label{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.mobile-filter-field input,.mobile-filter-field select{width:100%;min-height:44px;padding:0 12px;font-size:14px;border:1px solid var(--color-border);border-radius:8px;background:#fff}.mobile-filter-field input:focus,.mobile-filter-field select:focus{outline:none;border-color:var(--color-primary)}.section-header .header-actions{display:flex!important;flex-direction:column!important;width:100%!important;gap:8px!important}.section-header .header-actions .btn,.section-header .header-actions .btn-sm,.section-header .header-actions a.btn,.section-header .header-actions a.btn-sm,.section-header .header-actions .btn-reminder,.section-header .header-actions .btn-disabled{width:100%!important;height:44px!important;min-height:44px!important;max-height:44px!important;padding:12px 16px!important;font-size:13px!important;line-height:1!important;white-space:nowrap!important;text-align:center!important;display:flex!important;align-items:center!important;justify-content:center!important;border-radius:8px!important;box-sizing:border-box!important}.section-header .header-actions .btn-reminder{background:var(--color-primary)!important;color:#fff!important;border:none!important;order:1}.section-header .header-actions a.btn:not(.btn-reminder){background:transparent!important;color:var(--color-primary)!important;border:1px solid var(--color-primary)!important;order:2}.section-header .header-actions .btn-disabled{background:#e5e7eb!important;color:#9ca3af!important;border:none!important;cursor:not-allowed!important}.section-header{flex-direction:column;align-items:stretch;gap:12px}.section-header>div:first-child{margin-bottom:0}.analytics-tabs{display:flex!important;gap:4px!important;overflow-x:auto!important;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:8px;margin:0 -16px;padding-left:16px;padding-right:16px}.analytics-tabs::-webkit-scrollbar{display:none}.analytics-tabs button{flex-shrink:0;white-space:nowrap;padding:8px 14px;font-size:13px;min-height:36px}.chart-filters.desktop-table,.history-filters.desktop-table,.report-filters.desktop-table{display:none!important}.chart-grid{display:flex!important;flex-direction:column!important;gap:16px!important}.chart-card,.chart-card-wide{min-width:100%!important;width:100%!important}.chart-container{min-height:250px;overflow-x:auto;-webkit-overflow-scrolling:touch}.chart-container canvas{min-width:300px}.analytics-summary-cards{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:12px!important}.analytics-summary-cards .summary-card{padding:12px!important}.analytics-summary-cards .summary-card-label{font-size:11px!important}.analytics-summary-cards .summary-card-value{font-size:18px!important}.report-summary-cards{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:12px!important}.custom-reports-layout{display:flex!important;flex-direction:column!important;gap:16px!important}.report-templates-sidebar{width:100%!important;max-width:none!important;order:1}.report-templates-sidebar h3{font-size:14px;margin-bottom:12px}.template-list{display:flex!important;flex-direction:row!important;overflow-x:auto!important;-webkit-overflow-scrolling:touch;gap:10px!important;padding-bottom:8px;margin:0 -16px;padding-left:16px;padding-right:16px}.template-list::-webkit-scrollbar{display:none}.template-card{flex-shrink:0!important;width:140px!important;min-width:140px!important;padding:12px!important}.template-card .template-name{font-size:12px!important}.template-card .template-description{font-size:10px!important;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.report-content{width:100%!important;order:2}.report-header h3{font-size:16px}.report-header p{font-size:13px}.saved-reports-grid{display:flex!important;flex-direction:column!important;gap:10px!important}.saved-report-card{padding:12px!important}.report-results .table-responsive{margin:0 -16px;padding:0 16px;overflow-x:auto;-webkit-overflow-scrolling:touch}.leaderboard-list{font-size:13px}.leaderboard-list li{padding:8px 0}.revenue-table{font-size:12px}.revenue-table th,.revenue-table td{padding:8px 6px;white-space:nowrap}.period-cards{gap:12px}.period-card-header{flex-direction:column;gap:8px}.period-summary{flex-wrap:wrap;gap:6px}.period-summary .summary-item{font-size:12px}.report-form{padding:0}.report-form .form-row{flex-direction:column;gap:12px}.report-form .form-field{width:100%}.report-empty-state{padding:40px 20px}.report-empty-state svg{width:48px;height:48px}.report-empty-state h3{font-size:16px}.report-empty-state p{font-size:13px}.report-pagination{flex-wrap:wrap;gap:8px;justify-content:center}.report-actions{flex-direction:column;gap:8px}.report-actions .btn{width:100%}}
