@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=DM+Mono:wght@400;500&display=swap";:root{--bg:#f4f5f7;--surface:#fff;--surface-hover:#f8f9fb;--border:#e2e5ea;--border-light:#eceef2;--text-primary:#111827;--text-secondary:#5c6370;--text-muted:#9ba3ae;--accent:#2563eb;--accent-hover:#1d4ed8;--accent-light:#eff4ff;--accent-border:#bfcfff;--success:#16a34a;--success-bg:#f0fdf4;--success-border:#bbf7d0;--success-hover:#15803d;--error:#dc2626;--error-bg:#fef2f2;--error-border:#fecaca;--warning:#d97706;--warning-bg:#fffbeb;--navbar-height:60px;--sidebar-width:260px;--radius:10px;--radius-sm:6px;--radius-lg:14px;--shadow-sm:0 1px 3px #00000012, 0 1px 2px #0000000a;--shadow:0 4px 12px #00000014, 0 1px 3px #0000000d;--shadow-lg:0 10px 32px #0000001a, 0 2px 8px #0000000f;--font:"DM Sans", -apple-system, sans-serif;--font-mono:"DM Mono", "Fira Code", monospace;--transition:.18s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px}body{font-family:var(--font);background:var(--bg);color:var(--text-primary);min-height:100vh;line-height:1.6}.app-loading{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.loading-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.login-bg{background:linear-gradient(135deg,#e8edf5 0%,#f4f5f7 50%,#eef1f8 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative}.login-bg:before{content:"";pointer-events:none;background-image:radial-gradient(circle at 20% 20%,#2563eb0f 0%,#0000 50%),radial-gradient(circle at 80% 80%,#2563eb0a 0%,#0000 50%);position:absolute;inset:0}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:44px 40px;animation:.4s fadeUp;position:relative}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.login-logo{justify-content:center;align-items:center;margin-bottom:24px;display:flex}.login-logo-mark{background:var(--accent);color:#fff;width:52px;height:52px;font-family:var(--font-mono);letter-spacing:.5px;border-radius:14px;justify-content:center;align-items:center;font-size:1.15rem;font-weight:500;display:inline-flex;box-shadow:0 4px 14px #2563eb4d}.login-title{color:var(--text-primary);text-align:center;letter-spacing:-.3px;margin-bottom:4px;font-size:1.5rem;font-weight:700}.login-subtitle{color:var(--text-secondary);text-align:center;margin-bottom:28px;font-size:.9rem}.login-form{flex-direction:column;gap:16px;display:flex}.navbar{z-index:100;height:var(--navbar-height);background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:0 28px;display:flex;position:sticky;top:0;box-shadow:0 1px 4px #0000000d}.navbar-brand{flex-shrink:0;align-items:center;gap:10px;display:flex}.navbar-logo{background:var(--accent);color:#fff;width:34px;height:34px;font-family:var(--font-mono);border-radius:8px;justify-content:center;align-items:center;font-size:.75rem;font-weight:500;display:inline-flex}.navbar-title{color:var(--text-primary);letter-spacing:-.2px;font-size:.95rem;font-weight:600}.navbar-right{align-items:center;gap:14px;min-width:0;display:flex}.navbar-user{align-items:center;gap:8px;min-width:0;display:flex}.navbar-user-name{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:clamp(70px,25vw,110px);font-size:.875rem;font-weight:500;overflow:hidden}.navbar-user .badge{display:none}.navbar-logout{color:var(--error);border-color:#dc262626;align-items:center;gap:6px;display:inline-flex}.navbar-logout:hover{background:var(--error-bg);color:var(--error)}.navbar-logout-text{display:inline}.page-wrapper{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.main-content{flex-direction:column;flex:1;gap:24px;width:100%;max-width:1200px;margin:0 auto;padding:28px 24px 48px;display:flex}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.page-title{color:var(--text-primary);letter-spacing:-.4px;font-size:1.5rem;font-weight:700;line-height:1.2}.page-subtitle{color:var(--text-secondary);margin-top:3px;font-size:.875rem}.page-header-meta{align-items:center;gap:8px;display:flex}.page-header-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.export-controls{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.export-mode{background:var(--bg);border:1px solid var(--border);border-radius:9px;padding:3px;display:inline-flex}.export-mode-btn{color:var(--text-secondary);font-family:var(--font);cursor:pointer;transition:background var(--transition), color var(--transition), box-shadow var(--transition);background:0 0;border:0;border-radius:6px;padding:6px 10px;font-size:.78rem;font-weight:600}.export-mode-btn:hover{color:var(--text-primary)}.export-mode-btn.active{background:var(--surface);color:var(--accent);box-shadow:var(--shadow-sm)}.export-range{background:var(--surface);border:1px solid var(--border);border-radius:9px;align-items:center;gap:5px;padding:3px 5px;display:flex}.export-month{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:5px;padding-left:5px;font-size:.72rem;font-weight:600;display:flex}.export-month input{background:var(--bg);width:128px;color:var(--text-primary);font-family:var(--font);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;border:0;border-radius:6px;outline:none;padding:4px 5px;font-size:.78rem}.export-month input:focus{box-shadow:0 0 0 2px var(--accent-border)}.export-range-arrow{color:var(--text-muted);font-size:.8rem}.emp-code-tag{font-family:var(--font-mono);background:var(--accent-light);color:var(--accent);border:1px solid var(--accent-border);border-radius:6px;padding:4px 10px;font-size:.8rem;font-weight:500}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.section-card{animation:.35s fadeUp}.card-header{border-bottom:1px solid var(--border-light);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:18px 24px;display:flex}.card-title-group{align-items:center;gap:10px;display:flex}.card-icon{background:var(--accent-light);width:34px;height:34px;color:var(--accent);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.card-title{color:var(--text-primary);letter-spacing:-.2px;font-size:1rem;font-weight:600}.record-count{color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:3px 9px;font-size:.8rem}.filter-active-badge{background:var(--accent-light);color:var(--accent);border:1px solid var(--accent-border);border-radius:20px;padding:2px 8px;font-size:.75rem;font-weight:500}.worklog-form,.login-form{padding:24px}.form-row{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-secondary);letter-spacing:.01em;font-size:.825rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{font-family:var(--font);color:var(--text-primary);background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition), box-shadow var(--transition);outline:none;width:100%;padding:9px 12px;font-size:.9rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1a}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-group select{cursor:pointer;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='%235c6370' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.form-group textarea{resize:vertical;min-height:80px}.form-group.filter-group{min-width:180px}.form-actions{align-items:center;gap:10px;padding-top:4px;display:flex}.filter-section{border-bottom:1px solid var(--border-light);background:var(--surface-hover)}.filter-bar{flex-wrap:wrap;align-items:flex-end;gap:14px;padding:18px 24px;display:flex}.filter-fields{flex-wrap:wrap;flex:1;gap:14px;display:flex}.filter-actions{align-items:flex-end;gap:8px;padding-bottom:0;display:flex}.form-loading{color:var(--text-secondary);align-items:center;gap:10px;padding:24px;font-size:.875rem;display:flex}.btn{font-family:var(--font);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition), color var(--transition), box-shadow var(--transition), opacity var(--transition);white-space:nowrap;border:none;align-items:center;gap:6px;padding:9px 18px;font-size:.875rem;font-weight:500;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 1px 3px #2563eb40}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 2px 8px #2563eb4d}.btn-success{background:var(--success);color:#fff;box-shadow:0 1px 3px #16a34a33}.btn-success:hover:not(:disabled){background:var(--success-hover)}.btn-ghost{color:var(--text-secondary);border:1.5px solid var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg);color:var(--text-primary)}.btn-outline{background:var(--surface);color:var(--text-secondary);border:1.5px solid var(--border)}.btn-outline:hover:not(:disabled){background:var(--bg);border-color:var(--accent);color:var(--accent)}.btn-outline.active{background:var(--accent-light);border-color:var(--accent-border);color:var(--accent)}.btn-sm{padding:7px 13px;font-size:.825rem}.btn-full{justify-content:center;width:100%}.btn-spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}.alert{border-radius:var(--radius-sm);align-items:center;gap:8px;margin:0 24px 16px;padding:10px 14px;font-size:.875rem;font-weight:500;animation:.2s fadeUp;display:flex}.login-form .alert{margin:0}.alert-error{background:var(--error-bg);color:var(--error);border:1px solid var(--error-border)}.alert-success{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.field-error{color:var(--error);font-size:.775rem;font-weight:500}.required{color:var(--error);margin-left:2px}.optional{color:var(--text-muted);margin-left:4px;font-size:.75rem;font-weight:400}.badge{letter-spacing:.02em;text-transform:uppercase;border-radius:20px;align-items:center;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-flex}.badge-admin{color:#92400e;background:#fef3c7;border:1px solid #fde68a}.badge-employee{background:var(--accent-light);color:var(--accent);border:1px solid var(--accent-border)}.badge-submitted{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border);border-radius:20px;padding:3px 10px;font-size:.72rem;font-weight:600}.status-pill{letter-spacing:.01em;white-space:nowrap;border-radius:20px;align-items:center;padding:3px 9px;font-size:.75rem;font-weight:600;display:inline-flex}.status-present{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0}.status-leave{color:#c2410c;background:#fff7ed;border:1px solid #fed7aa}.status-wfh{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.status-onsite{color:#6d28d9;background:#f5f3ff;border:1px solid #ddd6fe}.status-travel{color:#a16207;background:#fefce8;border:1px solid #fef08a}.status-default{background:var(--bg);color:var(--text-muted);border:1px solid var(--border)}.table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.table-wrapper-scroll{overscroll-behavior:contain;overflow:auto}.employee-list-scroll{max-height:500px}.admin-worklogs-scroll{max-height:510px}.table-wrapper-scroll .data-table th{z-index:2;background:var(--surface-hover);box-shadow:0 1px 0 var(--border);position:sticky;top:0}.data-table{border-collapse:collapse;width:100%;font-size:.875rem}.data-table thead{background:var(--surface-hover);border-bottom:2px solid var(--border)}.data-table th{text-align:left;color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;padding:11px 20px;font-size:.775rem;font-weight:600}.data-table td{border-bottom:1px solid var(--border-light);color:var(--text-primary);vertical-align:middle;padding:12px 20px}.data-table tbody tr{transition:background var(--transition)}.data-table tbody tr:hover{background:var(--surface-hover)}.data-table tbody tr:last-child td{border-bottom:none}.td-date{font-family:var(--font-mono);color:var(--text-secondary);white-space:nowrap;font-size:.825rem}.td-code{font-family:var(--font-mono);color:var(--accent);font-size:.825rem;font-weight:500}.td-remarks{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:220px;font-size:.85rem;overflow:hidden}.table-placeholder{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:52px 24px;font-size:.9rem;display:flex}@media (width<=900px){.main-content{gap:18px;padding:20px 16px 40px}.form-row{grid-template-columns:1fr}.navbar{padding:0 10px}.navbar-right{gap:5px}.navbar-user-name{max-width:130px}.navbar-user .badge{display:none}.navbar-logout,.theme-toggle{width:34px;height:34px;color:var(--error);border-color:#dc262626;justify-content:center;padding:0}.navbar-logout:hover{background:var(--error-bg);color:var(--error)}.navbar-logout-text{display:none}.table-wrapper-scroll{max-height:52vh}.page-header{flex-direction:column;align-items:flex-start}.filter-bar{flex-direction:column;align-items:stretch;padding:14px 16px}.filter-fields{flex-direction:column}.filter-actions{justify-content:flex-start}.card-header{padding:14px 16px}.worklog-form{padding:16px}.data-table th,.data-table td{padding:10px 14px}.page-header-actions,.export-controls,.export-range{width:100%}.export-mode,.export-mode-btn{flex:1}.export-range{justify-content:space-between}.login-card{padding:32px 24px}.alert{margin:0 16px 14px}}@media (width<=480px){.navbar-title{display:none}.page-title{font-size:1.25rem}}.inline-modal-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#11182773;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.inline-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:380px;animation:.2s slideUp}.inline-modal--wide{max-width:440px}@keyframes slideUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.inline-modal-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.inline-modal-title-group{align-items:center;gap:10px;display:flex}.inline-modal-title{color:var(--text-primary);letter-spacing:-.2px;font-size:.95rem;font-weight:600}.inline-modal-sub{color:var(--text-secondary);margin-top:1px;font-size:.8rem}.inline-modal-body{flex-direction:column;padding:20px;display:flex}.inline-modal-actions{align-items:center;gap:8px;display:flex}.modal-close-btn{width:28px;height:28px;color:var(--text-muted);cursor:pointer;transition:background var(--transition), color var(--transition);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.modal-close-btn:hover{background:var(--bg);color:var(--text-primary)}.reset-pwd-btn{color:var(--warning);border-color:#fde68a}.reset-pwd-btn:hover:not(:disabled){background:var(--warning-bg);border-color:var(--warning);color:var(--warning)}[data-theme=dark]{--bg:#0f1117;--surface:#1a1d27;--surface-hover:#1e2230;--border:#2e3140;--border-light:#262a38;--text-primary:#f0f2f7;--text-secondary:#8b92a8;--text-muted:#4e5568;--accent:#3b82f6;--accent-hover:#2563eb;--accent-light:#1e2d4a;--accent-border:#2a3f6b;--success:#22c55e;--success-bg:#0d2318;--success-border:#14532d;--success-hover:#16a34a;--error:#f87171;--error-bg:#2d1010;--error-border:#7f1d1d;--warning:#fbbf24;--warning-bg:#2d1f00;--shadow-sm:0 1px 3px #00000059, 0 1px 2px #00000040;--shadow:0 4px 12px #0006, 0 1px 3px #0000004d;--shadow-lg:0 10px 32px #00000080, 0 2px 8px #00000059}[data-theme=dark] .navbar,[data-theme=dark] .card,[data-theme=dark] .inline-modal,[data-theme=dark] .login-card{background:var(--surface)}[data-theme=dark] .data-table thead,[data-theme=dark] .filter-section,[data-theme=dark] .card-header,[data-theme=dark] .data-table tbody tr:hover{background:#1e2230}[data-theme=dark] body{background:var(--bg);color:var(--text-primary)}[data-theme=dark] .login-bg{background:linear-gradient(135deg,#0a0d14 0%,#0f1117 50%,#0d1020 100%)}[data-theme=dark] .login-bg:before{background-image:radial-gradient(circle at 20% 20%,#3b82f61a 0%,#0000 50%),radial-gradient(circle at 80% 80%,#3b82f60f 0%,#0000 50%)}[data-theme=dark] .form-group input,[data-theme=dark] .form-group select,[data-theme=dark] .form-group textarea{border-color:var(--border);color:var(--text-primary);background-color:#13161f}[data-theme=dark] .form-group textarea::placeholder{color:var(--text-muted)}[data-theme=dark] .form-group input::pceholder{color:var(--text-muted)}[data-theme=dark] .form-group input:focus,[data-theme=dark] .form-group select:focus,[data-theme=dark] .form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f626}[data-theme=dark] .form-group select{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='%238b92a8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E")}[data-theme=dark] .export-month input{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}[data-theme=dark] .status-present{color:#4ade80;background:#0d2318;border-color:#14532d}[data-theme=dark] .status-leave{color:#fb923c;background:#2d1206;border-color:#7c2d12}[data-theme=dark] .status-wfh{color:#60a5fa;background:#1e2d4a;border-color:#1e3a6b}[data-theme=dark] .status-onsite{color:#a78bfa;background:#1e1a38;border-color:#3b2f6b}[data-theme=dark] .status-travel{color:#fbbf24;background:#2d1f00;border-color:#78350f}[data-theme=dark] .status-default{color:var(--text-muted);border-color:var(--border);background:#1a1d27}[data-theme=dark] .badge-admin{color:#fbbf24;background:#2d1f00;border-color:#78350f}[data-theme=dark] .badge-employee{background:var(--accent-light);color:#60a5fa;border-color:var(--accent-border)}[data-theme=dark] .badge-submitted{background:var(--success-bg);color:var(--success);border-color:var(--success-border)}[data-theme=dark] .btn-ghost{border-color:var(--border);color:var(--text-secondary)}[data-theme=dark] .btn-ghost:hover:not(:disabled){color:var(--text-primary);background:#20243a}[data-theme=dark] .btn-outline{background:var(--surface);border-color:var(--border);color:var(--text-secondary)}[data-theme=dark] .btn-outline:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:#20243a}[data-theme=dark] .btn-outline.active{background:var(--accent-light);border-color:var(--accent-border);color:#60a5fa}[data-theme=dark] .reset-pwd-btn{color:var(--warning);border-color:#78350f}[data-theme=dark] .reset-pwd-btn:hover:not(:disabled){background:var(--warning-bg);border-color:var(--warning)}[data-theme=dark] .data-table td{border-bottom-color:var(--border-light)}[data-theme=dark] .inline-modal-overlay{background:#000000a6}[data-theme=dark] ::-webkit-scrollbar{width:7px;height:7px}[data-theme=dark] ::-webkit-scrollbar-track{background:var(--bg)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#2e3140;border-radius:4px}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#3b4058}[data-theme=dark] .emp-code-tag{background:var(--accent-light);color:#60a5fa;border-color:var(--accent-border)}[data-theme=dark] .record-count{border-color:var(--border);color:var(--text-muted);background:#13161f}[data-theme=dark] .filter-active-badge{background:var(--accent-light);color:#60a5fa;border-color:var(--accent-border)}html{transition:background-color .25s,color .25s}.theme-toggle{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;padding:0;display:flex}.login-theme-btn{border:1.5px solid var(--border);background:var(--surface);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:background var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition);box-shadow:var(--shadow-sm);z-index:10;border-radius:10px;justify-content:center;align-items:center;padding:0;display:flex;position:absolute;top:20px;right:20px}.login-theme-btn:hover{background:var(--bg);color:var(--text-primary);border-color:var(--accent);box-shadow:var(--shadow)}
