@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--primary:#fefcf9;--secondary:#140a02;--accent:#8b5e3c;--accent-hover:#7a4f31;--foreground:#2d1f14;--border:#e7dbcf;--cream:#faf5ef;--muted:#8c7b6b;--primary-light:#f2e7dc;--primary-hover:#7a4f31;--wine:#5a2a20;--destructive:#c0392b;--text-color:#2d1f14;--text-muted:#8c7b6b;--success:#27ae60;--warning:#f39c12;--error:#c0392b;--info:#3498db}*{box-sizing:border-box}body{min-height:100vh;color:var(--text-color);background:var(--primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif}#root{min-height:100vh}html{scroll-behavior:smooth}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--cream)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}.app-container{background:var(--primary);width:100%;min-height:100vh;display:flex}.main-content{flex:1;min-height:100vh;margin-left:240px;padding:2rem}.top-header{border:1px solid var(--border);background:#fff;border-radius:20px;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1.5rem 2rem;display:flex;box-shadow:0 2px 8px #2d1f140a}.company-name{color:var(--secondary);letter-spacing:-.5px;margin:0;font-size:1.5rem;font-weight:700}.current-date{color:var(--muted);background:var(--cream);border-radius:10px;padding:.5rem 1rem;font-size:.9375rem;font-weight:600}.loading-state{flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;min-height:400px;display:flex}.loading-spinner{border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-state h2{color:var(--secondary);margin:0;font-size:1.5rem;font-weight:600}.loading-state p{color:var(--muted);margin:0;font-size:1rem}.empty-state{text-align:center;color:var(--muted);padding:3rem 1rem;font-size:1rem}.primary-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s}.primary-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #8b5e3c4d}.primary-btn:disabled{opacity:.6;cursor:not-allowed}.primary-btn.full-width{width:100%}.status-badge{border-radius:12px;align-items:center;padding:.25rem .75rem;font-size:.875rem;font-weight:600;display:inline-flex}.status-badge.status-present{color:var(--success);background:#27ae601a}.status-badge.status-absent{color:var(--error);background:#c0392b1a}.login-page{background:var(--primary);justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.login-container{justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.login-card{-webkit-backdrop-filter:blur(20px);background:#fffffff2;border:2px solid #8b5e3c26;border-radius:32px;width:min(480px,100%);animation:6s ease-in-out infinite cardFloat;overflow:hidden;box-shadow:0 20px 60px #8b5e3c1f,0 8px 16px #8b5e3c14}@keyframes cardFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-header{background:#8b5e3c08;border-bottom:1px solid #8b5e3c1a;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:3rem 2rem 2rem;display:flex}.login-logo{object-fit:cover;border:3px solid var(--accent);background:#fff;border-radius:50%;width:120px;height:120px;padding:8px;box-shadow:0 8px 24px #8b5e3c26,0 0 0 8px #ffffff80}.login-header h1{color:var(--secondary);margin:0;font-size:1.75rem;font-weight:700}.login-header p{color:var(--muted);margin:0;font-size:1rem}.login-form{flex-direction:column;gap:1.25rem;padding:2.5rem 2rem 3rem;display:flex}.login-error{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--error);background:#c0392b14;border:1px solid #c0392b33;border-radius:12px;margin:0;padding:.75rem 1rem;font-size:.875rem;font-weight:500}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:var(--secondary);align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;display:flex}.form-group label svg{color:var(--accent)}.form-group input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:100%;color:var(--text-color);background:#8b5e3c0a;border:1.5px solid #8b5e3c33;border-radius:16px;padding:1rem;font-size:.95rem;font-weight:500;transition:all .3s;box-shadow:inset 0 1px 3px #8b5e3c14}.form-group input::placeholder{color:#8b5e3c80}.form-group input:focus{border-color:var(--accent);background:#8b5e3c0f;outline:none;box-shadow:inset 0 1px 3px #8b5e3c14,0 0 0 3px #8b5e3c26}.form-options{justify-content:space-between;align-items:center;gap:1rem;margin-top:-.25rem;display:flex}.checkbox-label{color:var(--text-color);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;font-size:.85rem;font-weight:500;display:flex}.checkbox-label input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--accent)}.forgot-password{color:var(--accent);cursor:pointer;white-space:nowrap;background:0 0;border:none;font-size:.85rem;font-weight:500;transition:color .2s}.forgot-password:hover{color:var(--secondary);text-decoration:underline}.login-btn{background:var(--accent);color:#fff;letter-spacing:.5px;cursor:pointer;border:none;border-radius:16px;width:100%;margin-top:.5rem;padding:1rem;font-size:1rem;font-weight:700;transition:all .3s;box-shadow:0 4px 12px #8b5e3c40}.login-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 6px 20px #8b5e3c59}.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (width<=640px){.login-container{padding:1rem}.login-header{padding:2rem 1.5rem 1.5rem}.login-logo{width:100px;height:100px}.login-form{padding:2rem 1.5rem}}.sidebar{background:var(--secondary);z-index:100;border-top-right-radius:32px;border-bottom-right-radius:32px;flex-direction:column;width:240px;height:100vh;display:flex;position:fixed;top:0;left:0}.sidebar-header{flex-shrink:0;justify-content:center;align-items:center;padding:2rem 1.5rem 2.5rem;display:flex}.sidebar-logo{object-fit:contain;border-radius:12px;width:100%;max-width:80px;height:auto}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:.5rem 0;display:flex}.sidebar-nav-item{color:#ffffffb3;text-align:left;cursor:pointer;z-index:1;background:0 0;border:none;align-items:center;gap:1rem;width:100%;margin:0;padding:1rem 1.5rem;font-family:inherit;font-size:.9375rem;font-weight:500;transition:all .35s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.sidebar-nav-item svg{opacity:.85;stroke-width:2px;flex-shrink:0;transition:all .35s cubic-bezier(.4,0,.2,1)}.sidebar-nav-item:hover:not(.active){color:#fffffff2;background:#ffffff0f}.sidebar-nav-item:hover:not(.active) svg{opacity:1}.sidebar-nav-item.active{background:var(--primary);color:var(--accent);border-radius:24px 0 0 24px;margin-right:-28px;padding-right:2.5rem;position:relative;box-shadow:0 10px 24px #2d1f141f}.sidebar-nav-item.active svg{opacity:1;stroke:var(--accent)}.sidebar-nav-item.active:before,.sidebar-nav-item.active:after{content:"";background:0 0;width:28px;height:28px;transition:all .35s cubic-bezier(.4,0,.2,1);position:absolute;right:0}.sidebar-nav-item.active:before{box-shadow:14px 14px 0 14px var(--primary);border-bottom-right-radius:28px;top:-28px}.sidebar-nav-item.active:after{box-shadow:14px -14px 0 14px var(--primary);border-top-right-radius:28px;bottom:-28px}.sidebar-footer{border-top:1px solid #ffffff1a;margin-top:auto;padding:1rem .75rem}.logout-btn{color:#ffffffd9;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;align-items:center;gap:.875rem;width:100%;padding:.875rem 1rem;font-family:inherit;font-size:.9375rem;font-weight:500;transition:all .25s;display:flex}.logout-btn:hover{color:#e74c3c;background:#c0392b26;border-color:#c0392b4d}.logout-btn svg{opacity:.85;flex-shrink:0;transition:opacity .25s}.logout-btn:hover svg{opacity:1;stroke:#e74c3c}.dashboard-kpi-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.dashboard-kpi-card{background:#fff;border:1px solid #0000;border-radius:20px;align-items:center;gap:1.25rem;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 2px 8px #2d1f140a}.dashboard-kpi-card:before{content:"";opacity:0;background:currentColor;width:4px;transition:opacity .3s;position:absolute;top:0;bottom:0;left:0}.dashboard-kpi-card:hover:before{opacity:1}.dashboard-kpi-card:hover{border-color:var(--border);transform:translateY(-4px);box-shadow:0 12px 32px #2d1f1414,0 4px 12px #2d1f140a}.kpi-icon{border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.dashboard-kpi-card:hover .kpi-icon{transform:scale(1.05)rotate(-5deg)}.kpi-primary .kpi-icon{color:var(--accent);background:linear-gradient(135deg,#8b5e3c1a,#8b5e3c0d)}.kpi-primary:before{background:var(--accent)}.kpi-success .kpi-icon{color:var(--success);background:linear-gradient(135deg,#27ae601a,#27ae600d)}.kpi-success:before{background:var(--success)}.kpi-warning .kpi-icon{color:var(--warning);background:linear-gradient(135deg,#f39c121a,#f39c120d)}.kpi-warning:before{background:var(--warning)}.kpi-info .kpi-icon{color:var(--info);background:linear-gradient(135deg,#3498db1a,#3498db0d)}.kpi-info:before{background:var(--info)}.kpi-content{flex-direction:column;flex:1;gap:.375rem;display:flex}.kpi-label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:.875rem;font-weight:600}.kpi-value{color:var(--secondary);font-size:2rem;font-weight:700;line-height:1}.kpi-change{color:var(--muted);font-size:.8125rem;font-weight:500}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;display:grid}.dashboard-card{border:1px solid var(--border);background:#fff;border-radius:20px;padding:1.75rem;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #2d1f140a}.dashboard-card:hover{box-shadow:0 8px 24px #2d1f140f,0 2px 8px #2d1f140a}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:.875rem;display:flex}.card-header h3{color:var(--secondary);flex:1;margin:0;font-size:1.0625rem;font-weight:600}.text-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.875rem;font-weight:600;transition:all .2s}.text-btn:hover{color:var(--accent-hover);background:#8b5e3c14}.attendance-list{flex-direction:column;gap:1rem;display:flex}.attendance-item{background:var(--cream);cursor:pointer;border:1px solid #0000;border-radius:14px;align-items:center;gap:1rem;padding:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.attendance-item:hover{border-color:var(--accent);background:#fff;transform:translate(8px);box-shadow:0 4px 12px #8b5e3c14}.attendance-avatar{background:linear-gradient(135deg, var(--accent), var(--secondary));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1rem;font-weight:700;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 4px 12px #8b5e3c26}.attendance-item:hover .attendance-avatar{transform:scale(1.05)}.attendance-info{flex-direction:column;flex:1;gap:.375rem;display:flex}.attendance-info strong{color:var(--secondary);font-size:.9375rem;font-weight:600}.attendance-position{color:var(--muted);font-size:.8125rem;font-weight:500}.attendance-status{flex-direction:column;align-items:flex-end;gap:.375rem;display:flex}.attendance-time{color:var(--muted);font-size:.8125rem;font-weight:600}.quick-actions{flex-direction:column;gap:1rem;display:flex}.action-card{background:var(--cream);cursor:pointer;text-align:left;border:1px solid #0000;border-radius:14px;align-items:center;gap:1rem;width:100%;padding:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.action-card:hover{border-color:var(--accent);background:#fff;transform:translate(8px);box-shadow:0 4px 12px #8b5e3c14}.action-icon{width:48px;height:48px;color:var(--accent);background:linear-gradient(135deg,#8b5e3c1a,#8b5e3c0d);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.action-card:hover .action-icon{background:linear-gradient(135deg,#8b5e3c26,#8b5e3c14);transform:scale(1.05)rotate(-5deg)}.action-content{flex-direction:column;gap:.375rem;display:flex}.action-content strong{color:var(--secondary);font-size:.9375rem;font-weight:600}.action-content span{color:var(--muted);font-size:.8125rem;font-weight:500}@media (width<=768px){.dashboard-kpi-grid,.dashboard-grid{grid-template-columns:1fr}}.employees-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.employees-filters{gap:.5rem;display:flex}.filter-btn{border:1px solid var(--border);color:var(--secondary);cursor:pointer;background:#fff;border-radius:12px;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s}.filter-btn:hover{border-color:var(--accent);background:var(--cream)}.filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.add-employee-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.add-employee-btn:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #8b5e3c4d}.employees-search-bar{gap:1rem;margin-bottom:1.5rem;display:flex}.search-input-wrapper{flex:1;align-items:center;display:flex;position:relative}.search-input-wrapper svg{color:var(--muted);pointer-events:none;position:absolute;left:1rem}.search-input-wrapper input{border:1px solid var(--border);width:100%;color:var(--text-color);background:#fff;border-radius:12px;padding:.875rem 1rem .875rem 3rem;font-size:.9375rem;transition:all .2s}.search-input-wrapper input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #8b5e3c1a}.clear-search-btn{width:28px;height:28px;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;right:.75rem}.clear-search-btn:hover{background:var(--cream);color:var(--secondary)}.view-toggle{gap:.5rem;display:flex}.view-btn{border:1px solid var(--border);width:40px;height:40px;color:var(--muted);cursor:pointer;background:#fff;border-radius:10px;justify-content:center;align-items:center;transition:all .2s;display:flex}.view-btn:hover{border-color:var(--accent);color:var(--accent)}.view-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.employees-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem;display:grid}.employee-card{cursor:pointer;background:#fff;border:1px solid #0000;border-radius:20px;flex-direction:column;align-items:center;gap:1rem;padding:1.5rem 1.25rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.employee-card:before{content:"";background:linear-gradient(90deg, var(--accent), var(--secondary));transform-origin:0;height:3px;transition:transform .3s cubic-bezier(.4,0,.2,1);position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.employee-card:hover:before{transform:scaleX(1)}.employee-card:hover{border-color:var(--border);transform:translateY(-6px);box-shadow:0 8px 32px #2d1f1414,0 2px 8px #2d1f140a}.employee-card-avatar{background:linear-gradient(135deg, var(--accent), var(--secondary));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;font-size:1.75rem;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden;box-shadow:0 6px 20px #8b5e3c2e,0 0 0 3px #8b5e3c0f}.employee-card-avatar img{object-fit:cover;width:100%;height:100%}.employee-card:hover .employee-card-avatar{transform:scale(1.05);box-shadow:0 8px 24px #8b5e3c38,0 0 0 4px #8b5e3c1a}.employee-card-info{text-align:center;width:100%}.employee-card-info h3{color:var(--secondary);margin:0 0 .375rem;font-size:1rem;font-weight:600;line-height:1.3}.employee-card-position{color:var(--muted);margin-bottom:.875rem;font-size:.8125rem;font-weight:500}.employee-card-status{border-top:1px solid var(--border);justify-content:center;align-items:center;gap:.625rem;width:100%;padding-top:.875rem;display:flex}.status-time{color:var(--muted);font-size:.75rem;font-weight:600}.employees-table-container{border:1px solid var(--border);background:#fff;border-radius:20px;overflow:hidden}.employees-table{border-collapse:collapse;width:100%}.employees-table thead{background:var(--cream)}.employees-table th{text-align:left;color:var(--secondary);border-bottom:1px solid var(--border);padding:1rem 1.5rem;font-size:.875rem;font-weight:600}.employees-table tbody tr{cursor:pointer;transition:background .2s}.employees-table tbody tr:hover{background:var(--cream)}.employees-table tbody tr:not(:last-child){border-bottom:1px solid var(--border)}.employees-table td{color:var(--text-color);padding:1rem 1.5rem;font-size:.9375rem}.table-employee-info{align-items:center;gap:.75rem;display:flex}.table-avatar{background:linear-gradient(135deg, var(--accent), var(--secondary));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;font-weight:700;display:flex;overflow:hidden}.table-avatar img{object-fit:cover;width:100%;height:100%}.back-btn{border:1px solid var(--border);color:var(--secondary);cursor:pointer;background:#fff;border-radius:12px;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.back-btn:hover{border-color:var(--accent);background:var(--cream)}.employee-detail-header{border:1px solid var(--border);background:#fff;border-radius:20px;margin-bottom:1.5rem;padding:2rem}.employee-detail-info{align-items:center;gap:1.5rem;display:flex}.employee-detail-avatar{background:linear-gradient(135deg, var(--accent), var(--secondary));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;font-size:2rem;font-weight:700;display:flex;overflow:hidden;box-shadow:0 4px 16px #8b5e3c33}.employee-detail-avatar img{object-fit:cover;width:100%;height:100%}.employee-detail-info h2{color:var(--secondary);margin:0 0 .25rem;font-size:1.5rem;font-weight:700}.employee-detail-position{color:var(--muted);font-size:1rem}.view-profile-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;align-items:center;gap:.5rem;margin-left:auto;padding:.75rem 1.5rem;font-size:.9375rem;font-weight:600;transition:all .2s;display:flex}.view-profile-btn:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #8b5e3c4d}.employee-records-table-container{border:1px solid var(--border);background:#fff;border-radius:20px;overflow:hidden}.employee-records-table{border-collapse:collapse;width:100%}.employee-records-table thead{background:var(--cream)}.employee-records-table th{text-align:left;color:var(--secondary);border-bottom:1px solid var(--border);padding:1rem 1.5rem;font-size:.875rem;font-weight:600}.employee-records-table tbody tr:not(:last-child){border-bottom:1px solid var(--border)}.employee-records-table td{color:var(--text-color);padding:1rem 1.5rem;font-size:.9375rem}.proof-btn{background:var(--cream);border:1px solid var(--border);color:var(--accent);cursor:pointer;border-radius:8px;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.proof-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}@media (width<=768px){.employees-header{flex-direction:column;align-items:stretch}.employees-filters{justify-content:space-between;width:100%}.employees-search-bar{flex-direction:column}.employees-grid{grid-template-columns:1fr}.employees-table-container{overflow-x:auto}.employee-detail-info{text-align:center;flex-direction:column}.view-profile-btn{width:100%;margin-left:0}}.summary-controls{align-items:stretch;gap:1.25rem;margin-bottom:2rem;display:flex}.export-pdf-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:16px;flex-shrink:0;align-items:center;gap:.5rem;padding:.875rem 1.5rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 2px 8px #2d1f140a}.export-pdf-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #8b5e3c4d}.export-pdf-btn:disabled{background:var(--muted);cursor:not-allowed;opacity:.5}.export-pdf-btn .spinner{animation:1s linear infinite spin}.date-range-picker{border:1px solid var(--border);background:#fff;border-radius:16px;flex-shrink:0;align-items:center;gap:1rem;padding:.5rem .75rem;display:flex;box-shadow:0 2px 8px #2d1f140a}.date-input-group{align-items:center;gap:.75rem;display:flex}.date-input-group label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;font-size:.8125rem;font-weight:600}.date-input-group input[type=date]{background:var(--cream);border:1px solid var(--border);color:var(--text-color);cursor:pointer;white-space:nowrap;border-radius:10px;min-width:150px;padding:.25rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.date-input-group input[type=date]:focus{border-color:var(--accent);background:#fff;outline:none;box-shadow:0 0 0 3px #8b5e3c1a}.date-input-group input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;transition:opacity .2s}.date-input-group input[type=date]:hover::-webkit-calendar-picker-indicator{opacity:1}.summary-search-bar{flex:1;align-items:center;min-width:250px;height:100%;display:flex;position:relative}.summary-search-bar svg{color:var(--muted);pointer-events:none;z-index:1;position:absolute;left:1rem}.summary-search-bar input{border:1px solid var(--border);width:100%;height:100%;color:var(--text-color);background:#fff;border-radius:16px;padding:.875rem 3rem;font-size:.875rem;font-weight:500;transition:all .2s;box-shadow:0 2px 8px #2d1f140a}.summary-search-bar input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #8b5e3c1a}.summary-search-bar input::placeholder{color:var(--muted)}.summary-search-bar .clear-search-btn{width:28px;height:28px;color:var(--muted);cursor:pointer;z-index:1;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;right:.75rem}.summary-search-bar .clear-search-btn:hover{background:var(--cream);color:var(--secondary)}.summary-table-container{border:1px solid var(--border);background:#fff;border-radius:20px;margin-bottom:1.5rem;overflow:hidden;box-shadow:0 2px 8px #2d1f140a}.summary-table{border-collapse:collapse;width:100%}.summary-table thead{background:linear-gradient(to bottom, var(--cream), #fff);border-bottom:2px solid var(--border)}.summary-table th{text-align:left;color:var(--secondary);text-transform:uppercase;letter-spacing:.5px;padding:1rem 1.5rem;font-size:.8125rem;font-weight:600}.summary-table tbody tr{transition:all .2s}.summary-table tbody tr:not(:last-child){border-bottom:1px solid var(--border)}.summary-table tbody tr:hover{background:var(--cream);transform:scale(1.001)}.summary-table td{color:var(--text-color);padding:1rem 1.5rem;font-size:.875rem;font-weight:500}.summary-table td:first-child{color:var(--secondary);font-weight:600}.pagination{border:1px solid var(--border);background:#fff;border-radius:16px;justify-content:center;align-items:center;gap:1rem;padding:1rem;display:flex;box-shadow:0 2px 8px #2d1f140a}.pagination-btn{background:var(--cream);border:1px solid var(--border);color:var(--secondary);cursor:pointer;border-radius:10px;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s}.pagination-btn:hover:not(:disabled){background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #8b5e3c33}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-info{color:var(--secondary);padding:0 .5rem;font-size:.875rem;font-weight:600}@media (width<=768px){.summary-controls{flex-direction:column;align-items:stretch}.export-pdf-btn{justify-content:center;width:100%}.date-range-picker{width:100%}.date-input-group{flex:1}.date-input-group input[type=date],.summary-search-bar{min-width:100%}.summary-table-container{overflow-x:auto}.summary-table th,.summary-table td{padding:.875rem 1rem;font-size:.8125rem}.pagination{flex-wrap:wrap}}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:1000;background:#2d1f1499;justify-content:center;align-items:center;padding:1rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:24px;flex-direction:column;width:min(600px,100%);max-height:90vh;animation:.3s cubic-bezier(.4,0,.2,1) slideUp;display:flex;overflow:hidden;box-shadow:0 24px 48px #2d1f1433}.modal-content:has(.proof-preview-container){width:min(800px,95%)}.modal-body:has(.proof-preview-container){padding:1rem;overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:1.25rem 1.75rem;display:flex}.modal-header h2{color:var(--secondary);margin:0;font-size:1.125rem;font-weight:600}.modal-close-btn{width:32px;height:32px;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.modal-close-btn:hover{background:var(--cream);color:var(--secondary)}.modal-body{flex:1;padding:1.5rem 1.75rem;overflow-y:auto}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-track{background:0 0}.modal-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.modal-body::-webkit-scrollbar-thumb:hover{background:var(--muted)}.modal-form-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.modal-form-grid label{color:var(--secondary);flex-direction:column;gap:.375rem;font-size:.8125rem;font-weight:600;display:flex}.modal-form-grid label.full-width{grid-column:1/-1}.modal-form-grid input{background:var(--cream);border:1px solid var(--border);color:var(--text-color);border-radius:10px;padding:.625rem .875rem;font-size:.875rem;font-weight:500;transition:all .2s}.modal-form-grid input:focus{border-color:var(--accent);background:#fff;outline:none;box-shadow:0 0 0 3px #8b5e3c1a}.modal-actions{gap:1rem;margin-top:1.25rem;display:flex}.profile-avatar-container{flex-direction:column;align-items:center;gap:.875rem;margin-bottom:1.5rem;display:flex}.profile-avatar-xl{background:linear-gradient(135deg, var(--accent), var(--secondary));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:96px;height:96px;font-size:2.5rem;font-weight:700;display:flex;position:relative;overflow:hidden;box-shadow:0 6px 24px #8b5e3c38}.profile-avatar-xl img{object-fit:cover;width:100%;height:100%}.profile-avatar-xl span{justify-content:center;align-items:center;display:flex}.avatar-upload-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.8125rem;font-weight:600;transition:all .2s;display:inline-flex}.avatar-upload-btn:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #8b5e3c4d}.avatar-upload-btn svg{flex-shrink:0}.profile-info-form{flex-direction:column;gap:1rem;margin-bottom:1.5rem;display:flex}.profile-form-row{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.profile-form-field{flex-direction:column;gap:.375rem;display:flex}.profile-field-label{color:var(--secondary);font-size:.8125rem;font-weight:600}.profile-form-field input{background:var(--cream);border:1px solid var(--border);color:var(--text-color);border-radius:10px;padding:.625rem .875rem;font-size:.875rem;font-weight:500;transition:all .2s}.profile-form-field input:focus{border-color:var(--accent);background:#fff;outline:none;box-shadow:0 0 0 3px #8b5e3c1a}.profile-actions{justify-content:space-between;gap:1rem;display:flex}.deactivate-btn{color:var(--error);border:1px solid var(--error);cursor:pointer;background:0 0;border-radius:10px;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s}.deactivate-btn:hover{background:var(--error);color:#fff}.proof-preview-loading,.proof-preview-error{flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:3rem 1rem;display:flex}.proof-preview-container{justify-content:center;align-items:center;max-height:calc(90vh - 120px);padding:0;display:flex;position:relative}.proof-preview-image{object-fit:contain;border-radius:12px;width:auto;max-width:100%;height:auto;max-height:calc(90vh - 120px);box-shadow:0 4px 12px #2d1f141a}.fullscreen-toggle-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;z-index:10;background:#2d1f14cc;border:none;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;transition:all .2s;display:flex;position:absolute;bottom:1rem;right:1rem}.fullscreen-toggle-btn:hover{background:#2d1f14f2;transform:scale(1.05)}.fullscreen-overlay{z-index:2000;cursor:zoom-out;background:#000000f2;justify-content:center;align-items:center;padding:2rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.fullscreen-close-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;z-index:2001;background:#ffffff1a;border:1px solid #fff3;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;transition:all .2s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.fullscreen-close-btn:hover{background:#fff3;transform:scale(1.05)}.fullscreen-image{object-fit:contain;cursor:default;border-radius:8px;width:auto;max-width:100%;height:auto;max-height:100%;box-shadow:0 8px 32px #00000080}@media (width<=640px){.modal-content{width:100%;max-height:95vh}.modal-header{padding:1.25rem 1.5rem}.modal-body{padding:1.5rem}.modal-form-grid,.profile-form-row{grid-template-columns:1fr}.profile-actions{flex-direction:column}}
