:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{box-sizing:border-box;flex-direction:column;max-width:100%;min-height:100vh;margin:0;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.app-layout{min-height:100vh;display:flex}.app-sidebar{background:var(--code-bg,#f4f3ec);border-right:1px solid var(--border,#e5e4e7);flex-direction:column;flex-shrink:0;width:240px;display:flex}.sidebar-header{border-bottom:1px solid var(--border,#e5e4e7);padding:20px 16px}.sidebar-logo{color:var(--accent,#aa3bff);margin:0;font-size:20px}.sidebar-nav ul{margin:0;padding:8px 0;list-style:none}.sidebar-nav li{margin:0}.nav-link{color:var(--text,#6b6375);border-left:3px solid #0000;padding:10px 16px;font-size:14px;text-decoration:none;transition:background .15s,color .15s;display:block}.nav-link:hover{background:var(--accent-bg,#aa3bff1a);color:var(--text-h,#08060d)}.nav-link--active{background:var(--accent-bg,#aa3bff1a);color:var(--accent,#aa3bff);border-left-color:var(--accent,#aa3bff);font-weight:600}.app-main{flex-direction:column;flex:1;min-width:0;display:flex}.app-header{border-bottom:1px solid var(--border,#e5e4e7);background:var(--bg,#fff);justify-content:flex-end;align-items:center;height:56px;padding:0 24px;display:flex}.header-user{align-items:center;gap:12px;font-size:14px;display:flex}.header-role-badge{background:var(--accent-bg,#aa3bff1a);color:var(--accent,#aa3bff);text-transform:uppercase;border-radius:4px;padding:2px 8px;font-size:12px;font-weight:600}.header-email{color:var(--text,#6b6375)}.header-signout{border:1px solid var(--border,#e5e4e7);color:var(--text,#6b6375);cursor:pointer;background:0 0;border-radius:4px;padding:4px 12px;font-size:13px}.header-signout:hover{background:var(--accent-bg,#aa3bff1a);color:var(--accent,#aa3bff)}.app-content{flex:1;padding:24px;overflow-y:auto}@media (width<=768px){.app-layout{flex-direction:column}.app-sidebar{border-right:none;border-bottom:1px solid var(--border,#e5e4e7);width:100%}.sidebar-nav ul{padding:0 8px;display:flex;overflow-x:auto}.nav-link{white-space:nowrap;border-bottom:3px solid #0000;border-left:none}.nav-link--active{border-left-color:#0000;border-bottom-color:var(--accent,#aa3bff)}}.leave-status-chip{text-transform:uppercase;letter-spacing:.5px;border-radius:12px;align-items:center;padding:2px 10px;font-size:12px;font-weight:600;display:inline-flex}.chip--pending{color:#92400e;background:#fef3c7}.chip--approved{color:#065f46;background:#d1fae5}.chip--rejected{color:#991b1b;background:#fee2e2}.chip--cancelled{color:#4b5563;background:#e5e7eb}.state-container{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:48px 24px;display:flex}.state-container h3{color:var(--text-h);margin:0}.state-container p{color:var(--text);margin:0}.loading-spinner{border:3px solid var(--border,#e5e4e7);border-top-color:var(--accent,#aa3bff);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.btn{cursor:pointer;border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:6px;justify-content:center;align-items:center;padding:8px 16px;font-size:14px;font-weight:500;transition:background .15s,color .15s;display:inline-flex}.btn:hover{background:var(--accent-bg)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--accent,#aa3bff);color:#fff;border-color:var(--accent,#aa3bff)}.btn--primary:hover{opacity:.9}.btn--secondary{background:var(--code-bg);color:var(--text-h)}.btn--icon{min-width:32px;padding:4px 10px}.form-field{flex-direction:column;gap:4px;margin-bottom:16px;display:flex}.form-field__label{color:var(--text-h);font-size:14px;font-weight:500}.form-field__required{color:#dc2626}.form-field__input{border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:6px;padding:8px 12px;font-family:inherit;font-size:14px}.form-field__input:focus{outline:2px solid var(--accent-border);outline-offset:1px}.form-field--error .form-field__input{border-color:#dc2626}.form-field__error{color:#dc2626;margin:0;font-size:12px}.calendar-grid{width:100%}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:8px;padding:8px 0;display:flex}.calendar-title{color:var(--text-h);font-size:16px;font-weight:600}.calendar-weekdays{grid-template-columns:repeat(7,1fr);gap:1px;display:grid}.calendar-weekday{text-align:center;color:var(--text);padding:4px;font-size:12px;font-weight:600}.calendar-days{grid-template-columns:repeat(7,1fr);gap:1px;display:grid}.calendar-cell{border:1px solid var(--border);min-height:80px;padding:4px;font-size:12px}.calendar-cell--empty{background:var(--code-bg);border-color:#0000}.calendar-day-number{color:var(--text-h);font-weight:600}.calendar-event{color:#fff;text-overflow:ellipsis;white-space:nowrap;border-radius:3px;margin-top:2px;padding:1px 4px;font-size:11px;overflow:hidden}.calendar-event--striped{background-image:repeating-linear-gradient(45deg,#0000,#0000 3px,#ffffff4d 3px 6px)}.calendar-event--dotted{background-image:radial-gradient(circle,#fff6 1px,#0000 1px);background-size:6px 6px}.calendar-event-label{font-size:11px}.data-table-wrapper{width:100%;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--border);padding:10px 12px}.data-table th{color:var(--text-h);background:var(--code-bg);-webkit-user-select:none;user-select:none;font-weight:600}.data-table th.sortable{cursor:pointer}.data-table th.sortable:hover{background:var(--accent-bg)}.data-table td{color:var(--text)}.data-table tbody tr:hover{background:var(--accent-bg)}.data-table-empty{text-align:center;color:var(--text);padding:24px}.data-table-pagination{color:var(--text);justify-content:center;align-items:center;gap:12px;padding:12px 0;font-size:14px;display:flex}.csv-export-btn{gap:6px}.auth-page{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{border:1px solid var(--border);background:var(--bg);width:100%;max-width:400px;box-shadow:var(--shadow);border-radius:12px;padding:32px}.auth-card h1{text-align:center;margin:0 0 8px;font-size:24px}.auth-card p{text-align:center;color:var(--text);margin-bottom:24px;font-size:14px}.auth-card .btn--primary{width:100%;margin-top:8px;padding:10px}.auth-links{justify-content:center;gap:16px;margin-top:16px;font-size:13px;display:flex}.auth-links a{color:var(--accent);text-decoration:none}.auth-links a:hover{text-decoration:underline}.auth-error{color:#991b1b;text-align:center;background:#fee2e2;border-radius:6px;margin-bottom:16px;padding:8px 12px;font-size:13px}.auth-success{color:#065f46;text-align:center;background:#d1fae5;border-radius:6px;margin-bottom:16px;padding:8px 12px;font-size:13px}.access-denied{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:48px;display:flex}.access-denied h1{margin-bottom:8px;font-size:32px}
