:root{--brand: #D8222B;--brand-hover: #B91C24;--brand-light: #FEE2E2;--brand-faint: #FFF5F5;--surface-bg: #F5F6FA;--surface-card: #FFFFFF;--surface-sidebar: #1C1C28;--surface-sidebar-hover: #2A2A3A;--surface-sidebar-active: #D8222B;--surface-input: #FFFFFF;--surface-overlay: rgba(0,0,0,.45);--text-primary: #111827;--text-secondary: #6B7280;--text-tertiary: #9CA3AF;--text-inverse: #FFFFFF;--text-sidebar: rgba(255,255,255,.75);--text-sidebar-active: #FFFFFF;--border-default: #E5E7EB;--border-subtle: #F3F4F6;--border-focus: #D8222B;--status-present: #16A34A;--status-present-bg: #DCFCE7;--status-late: #D97706;--status-late-bg: #FEF3C7;--status-absent: #DC2626;--status-absent-bg: #FEE2E2;--status-holiday: #7C3AED;--status-holiday-bg: #EDE9FE;--status-remote: #0891B2;--status-remote-bg: #CFFAFE;--success: #16A34A;--warning: #D97706;--error: #DC2626;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--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-modal: 0 20px 60px rgba(0,0,0,.15);--sidebar-w: 260px;--header-h: 60px;--content-pad: 28px;--font-ui: "Manrope", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--transition: .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-ui);background:var(--surface-bg);color:var(--text-primary);line-height:1.5;min-height:100vh}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.app-layout{display:flex;min-height:100vh}.main-area{margin-left:var(--sidebar-w);display:flex;flex-direction:column;flex:1;min-height:100vh;transition:margin-left .2s ease}.layout-collapsed .main-area{margin-left:60px}.page-content{margin-top:var(--header-h);padding:var(--content-pad);flex:1}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;background:var(--surface-sidebar);display:flex;flex-direction:column;z-index:100;overflow:hidden;transition:width .2s ease}.sidebar.collapsed{width:60px}.sidebar.collapsed .sidebar-brand{padding:18px 12px 16px;justify-content:center}.sidebar.collapsed .sidebar-nav{padding:10px 8px}.sidebar.collapsed .nav-item{padding:9px;justify-content:center;gap:0}.sidebar.collapsed .sidebar-footer{padding:10px 8px}.sidebar.collapsed .nav-group-label{display:none}.sidebar.collapsed .nav-group{margin-bottom:4px}.sidebar-brand{padding:18px 18px 16px;border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0}.sidebar-brand-logo{display:flex;align-items:center;gap:10px}.sidebar-brand-icon{width:34px;height:34px;background:var(--brand);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;color:#fff;flex-shrink:0;box-shadow:0 4px 12px #d8222b66}.sidebar-brand-text{display:flex;flex-direction:column;gap:3}.sidebar-brand-name{font-size:15px;font-weight:700;color:#fff;line-height:1}.sidebar-brand-badge{display:inline-flex;align-items:center;padding:1px 7px;border-radius:var(--radius-full);background:#d8222b40;color:var(--brand);font-size:9.5px;font-weight:700;letter-spacing:.08em;border:1px solid rgba(216,34,43,.3);width:fit-content}.sidebar-nav{flex:1;overflow-y:auto;padding:8px 10px}.nav-group{margin-bottom:6px}.nav-group-label{padding:8px 10px 4px;font-size:9.5px;font-weight:700;letter-spacing:.1em;color:#ffffff40;text-transform:uppercase}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-md);color:#ffffff8c;font-size:13.5px;font-weight:500;cursor:pointer;transition:background var(--transition),color var(--transition);border:none;background:none;width:100%;text-align:left;margin-bottom:1px}.nav-item:hover{background:#ffffff12;color:#ffffffd9}.nav-item.active{background:var(--brand);color:#fff;font-weight:600;box-shadow:0 2px 8px #d8222b59}.nav-item svg{width:17px;height:17px;flex-shrink:0;stroke-width:1.8}.nav-item-label{flex:1}.sidebar-footer{padding:12px 14px;border-top:1px solid rgba(255,255,255,.07);flex-shrink:0;display:flex;flex-direction:column;gap:8px}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-md);background:#ffffff0d}.sidebar-user-collapsed{justify-content:center;padding:8px}.sidebar-user-avatar{width:32px;height:32px;background:var(--brand);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:12.5px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:11px;color:#ffffff59}.sidebar-collapse-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:6px 10px;border-radius:var(--radius-md);background:#ffffff0d;border:none;color:#ffffff59;font-size:12px;font-weight:500;cursor:pointer;transition:background var(--transition),color var(--transition)}.sidebar-collapse-btn:hover{background:#ffffff1a;color:#ffffffb3}.header{position:fixed;top:0;left:var(--sidebar-w);right:0;height:var(--header-h);background:var(--surface-card);border-bottom:1px solid var(--border-default);display:flex;align-items:center;padding:0 24px;gap:16px;z-index:99;transition:left .2s ease}.layout-collapsed .header{left:60px}.header-title{font-size:16px;font-weight:700;color:var(--text-primary)}.header-spacer{flex:1}.header-user{display:flex;align-items:center;gap:8px}.header-avatar{width:30px;height:30px;background:var(--brand);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}.header-user-name{font-size:13px;font-weight:500;color:var(--text-secondary)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.page-header h1{font-size:20px;font-weight:700;color:var(--text-primary);line-height:1.2}.dash-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:20px}.dash-stat-card{background:var(--surface-card);border-radius:var(--radius-lg);border:1px solid var(--border-default);padding:18px 20px;box-shadow:var(--shadow-sm)}.dash-stat-label{font-size:11.5px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.dash-stat-value{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1}.dash-stat-sub{font-size:11px;color:var(--text-tertiary);margin-top:4px}.dash-stat-icon{width:38px;height:38px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dash-stat-bar{height:4px;border-radius:2px;background:var(--border-subtle);margin-top:14px;overflow:hidden}.dash-stat-bar-fill{height:100%;border-radius:2px;transition:width .4s ease}.dash-row{display:flex;gap:16px;align-items:flex-start}.dash-row>*{min-width:0}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--surface-card);border-radius:var(--radius-lg);border:1px solid var(--border-default);padding:18px 20px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px}.stat-card-row{display:flex;align-items:flex-start;justify-content:space-between}.stat-icon{width:38px;height:38px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.stat-value{font-size:30px;font-weight:700;color:var(--text-primary);line-height:1}.stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.card{background:var(--surface-card);border-radius:var(--radius-lg);border:1px solid var(--border-default);box-shadow:var(--shadow-sm);overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border-default)}.card-header h2{font-size:14px;font-weight:700;color:var(--text-primary)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}thead th{padding:10px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);background:var(--surface-bg);border-bottom:1px solid var(--border-default);white-space:nowrap}tbody tr{border-bottom:1px solid var(--border-subtle);transition:background var(--transition)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--surface-bg)}tbody td{padding:11px 14px;vertical-align:middle;font-size:13px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:var(--radius-full);font-size:11.5px;font-weight:600;white-space:nowrap}.badge-green{background:var(--status-present-bg);color:var(--status-present)}.badge-yellow{background:var(--status-late-bg);color:var(--status-late)}.badge-red{background:var(--status-absent-bg);color:var(--status-absent)}.badge-purple{background:var(--status-holiday-bg);color:var(--status-holiday)}.badge-blue{background:var(--status-remote-bg);color:var(--status-remote)}.badge-gray{background:#f3f4f6;color:#6b7280}.badge-brand{background:var(--brand-light);color:var(--brand)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-md);font-size:13.5px;font-weight:600;cursor:pointer;border:none;transition:all var(--transition);white-space:nowrap}.btn:disabled{opacity:.6;pointer-events:none}.btn-primary{background:var(--brand);color:#fff;box-shadow:0 2px 8px #d8222b40}.btn-primary:hover{background:var(--brand-hover)}.btn-secondary{background:var(--surface-bg);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover{background:var(--border-default)}.btn-danger{background:var(--brand-light);color:var(--brand)}.btn-ghost{background:none;color:var(--text-secondary);border:1px solid transparent}.btn-ghost:hover{background:var(--surface-bg);color:var(--text-primary);border-color:var(--border-default)}.btn-sm{padding:5px 11px;font-size:12.5px}.btn-xs{padding:3px 8px;font-size:11.5px}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;border-radius:var(--radius-md);border:1px solid var(--border-default);background:none;color:var(--text-secondary);transition:all var(--transition);cursor:pointer}.btn-icon:hover{background:var(--surface-bg);color:var(--text-primary)}.btn-icon-danger{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;border-radius:var(--radius-md);border:1px solid #FCA5A5;background:none;color:var(--brand);cursor:pointer;transition:all var(--transition)}.btn-icon-danger:hover{background:var(--brand-light)}.btn-icon-success{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;border-radius:var(--radius-md);border:1px solid #86EFAC;background:none;color:var(--status-present);cursor:pointer;transition:all var(--transition)}.btn-icon-success:hover{background:var(--status-present-bg)}.btn-icon svg,.btn-icon-danger svg,.btn-icon-success svg{width:14px;height:14px}.dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 12px;border:none;background:none;font-size:13px;color:var(--text-primary);cursor:pointer;border-radius:6px;transition:background var(--transition)}.dropdown-item:hover{background:var(--surface-bg)}.dropdown-item svg{width:13px;height:13px;color:var(--text-secondary)}.dropdown-item-danger{color:var(--brand)}.dropdown-item-danger svg{color:var(--brand)}.dropdown-item-success{color:var(--status-present)}.dropdown-item-success svg{color:var(--status-present)}.form-group{margin-bottom:14px}.form-label{display:block;font-size:12.5px;font-weight:600;color:var(--text-primary);margin-bottom:5px}.form-input{width:100%;padding:8px 11px;border:1px solid var(--border-default);border-radius:var(--radius-md);font-size:13.5px;background:var(--surface-input);color:var(--text-primary);outline:none;transition:border var(--transition),box-shadow var(--transition)}.form-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #d8222b1a}.form-select{-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 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}.form-hint{font-size:11.5px;color:var(--text-tertiary);margin-top:4px}.error-msg{color:var(--error);font-size:12.5px;background:var(--brand-light);padding:8px 12px;border-radius:var(--radius-md);margin-bottom:14px}.input-icon-wrap{position:relative}.input-icon-left{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none;width:15px;height:15px}.input-with-icon{padding-left:36px}.input-with-icon-right{padding-right:38px}.input-icon-right-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;padding:2px;transition:color var(--transition)}.input-icon-right-btn:hover{color:var(--text-primary)}.filter-row{display:flex;align-items:center;gap:8px;padding:14px 20px;border-bottom:1px solid var(--border-default);flex-wrap:wrap}.summary-pills{display:flex;gap:10px;flex-wrap:wrap;padding:12px 20px;border-bottom:1px solid var(--border-default)}.summary-pill{display:flex;align-items:center;gap:5px;padding:5px 11px;border-radius:var(--radius-full);font-size:12.5px;font-weight:600}.summary-pill .dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.preset-row{display:flex;gap:6px;flex-wrap:wrap}.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--border-default);font-size:12.5px;color:var(--text-secondary);flex-wrap:wrap;gap:8px}.pagination-btns{display:flex;align-items:center;gap:4px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--surface-overlay);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.modal{background:var(--surface-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-modal);width:100%;max-width:520px;max-height:90vh;overflow-y:auto}.modal-lg{max-width:760px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border-default)}.modal-header h3{font-size:15px;font-weight:700}.modal-body{padding:20px 24px}.modal-footer{padding:14px 24px;border-top:1px solid var(--border-default);display:flex;gap:10px;justify-content:flex-end}.close-btn{background:none;border:none;cursor:pointer;color:var(--text-tertiary);padding:4px;border-radius:var(--radius-sm);line-height:0;transition:color var(--transition)}.close-btn:hover{color:var(--text-primary)}.close-btn svg{width:18px;height:18px}.login-page{min-height:100vh;display:flex}.login-left{flex:1;background:var(--surface-sidebar);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 72px;position:relative;overflow:hidden}.login-grid-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:40px 40px;pointer-events:none}.login-grid-bg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 30% 50%,rgba(216,34,43,.12),transparent 65%)}.login-left-content{position:relative;z-index:1;text-align:center;max-width:340px}.login-logo{width:68px;height:68px;background:var(--brand);border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:800;color:#fff;margin:0 auto 20px;box-shadow:0 8px 32px #d8222b66}.login-brand{font-size:28px;font-weight:800;color:#fff;margin-bottom:6px}.login-brand-sub{font-size:13px;color:#fff6;margin-bottom:36px}.login-features{display:flex;flex-direction:column;gap:10px;text-align:left}.login-feature-item{display:flex;align-items:center;gap:10px;font-size:13.5px;color:#ffffffa6}.login-feature-dot{width:6px;height:6px;border-radius:50%;background:var(--brand);flex-shrink:0}.login-right{width:460px;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:48px;background:var(--surface-card)}.login-form-wrap{width:100%;max-width:360px}.login-form-title{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:6px}.login-form-sub{font-size:13px;color:var(--text-secondary);margin-bottom:28px}.login-forgot{font-size:12.5px;color:var(--brand);background:none;border:none;cursor:pointer;font-weight:500;padding:0}.login-forgot:hover{text-decoration:underline}.login-remember{margin-bottom:16px;margin-top:4px}.attendance-summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-bottom:20px}.attendance-summary-card{background:var(--surface-card);border-radius:var(--radius-lg);border:1px solid var(--border-default);padding:16px 18px;box-shadow:var(--shadow-sm)}.att-card-label{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.att-card-value{font-size:26px;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:10px}.att-card-bar{height:5px;border-radius:3px;background:var(--border-subtle);overflow:hidden}.att-card-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}.branch-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.branch-card{background:var(--surface-card);border-radius:var(--radius-lg);border:1px solid var(--border-default);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow var(--transition)}.branch-card:hover{box-shadow:var(--shadow-md)}.branch-card-header{padding:16px;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;border-bottom:1px solid var(--border-subtle)}.branch-card-stats{display:flex;gap:0;border-bottom:1px solid var(--border-subtle)}.branch-stat-item{flex:1;display:flex;align-items:center;gap:10px;padding:12px 16px;border-right:1px solid var(--border-subtle)}.branch-stat-item:last-child{border-right:none}.branch-stat-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.loading{display:flex;align-items:center;justify-content:center;padding:60px 24px;color:var(--text-tertiary);font-size:13px;gap:10px}.empty-state{padding:56px 24px;text-align:center;color:var(--text-tertiary)}.spinner{width:18px;height:18px;border:2px solid var(--border-default);border-top-color:var(--brand);border-radius:50%;animation:spin .6s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.skeleton{background:linear-gradient(90deg,var(--border-subtle) 25%,var(--surface-bg) 50%,var(--border-subtle) 75%);background-size:1200px 100%;animation:shimmer 1.5s infinite linear;border-radius:6px;display:inline-block}.mono{font-family:var(--font-mono);font-size:12px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border-default);padding:0 20px}.tab-btn{padding:10px 16px;font-size:13.5px;font-weight:500;cursor:pointer;border:none;background:none;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all var(--transition)}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--brand);border-bottom-color:var(--brand);font-weight:600}@media (max-width: 900px){.login-left{display:none}.login-right{width:100%}.dash-row{flex-direction:column}}@media (max-width: 640px){.branch-card-grid{grid-template-columns:1fr}.attendance-summary-grid,.dash-stat-grid{grid-template-columns:1fr 1fr}}
