:root{--color-primary: #4F46E5;--color-primary-light: #818CF8;--color-primary-dark: #3730A3;--color-accent: #F59E0B;--color-accent-light: #FEF3C7;--color-success: #10B981;--color-success-light: #D1FAE5;--color-danger: #EF4444;--color-danger-light: #FEE2E2;--color-danger-dark: #991B1B;--color-hr: #7C3AED;--color-hr-light: #EDE9FE;--color-hr-dark: #4C1D95;--color-bg: #EEF2FF;--color-surface: #ffffff;--color-surface-2: #F8FAFF;--color-text: #1F2937;--color-text-light: #6B7280;--color-border: #C7D2FE;--color-border-light: #E0E7FF;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--shadow-sm: 0 1px 3px rgba(79, 70, 229, .08);--shadow-md: 0 4px 16px rgba(79, 70, 229, .12);--font-body: "Nunito", sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);min-height:100vh;-webkit-font-smoothing:antialiased}.app-wrapper{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1;max-width:640px;width:100%;margin:0 auto;padding:24px 16px 48px}.splash{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--color-text-light);font-size:1rem}.app-header{background:var(--color-surface);border-bottom:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:10}.header-inner{max-width:640px;margin:0 auto;padding:12px 16px;display:flex;align-items:center;justify-content:space-between}.header-title{font-size:1.2rem;font-weight:800;color:var(--color-primary);letter-spacing:-.5px}.header-role{font-size:.72rem;font-weight:600;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.5px}.header-right{display:flex;align-items:center;gap:10px}.header-name{font-size:.875rem;font-weight:600;color:var(--color-text)}.tab-bar{display:flex;gap:4px;background:var(--color-surface);border-radius:var(--radius-md);padding:4px;margin-bottom:20px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.tab-btn{flex:1;padding:9px 12px;border:none;background:transparent;border-radius:var(--radius-sm);font-family:inherit;font-size:.875rem;font-weight:600;color:var(--color-text-light);cursor:pointer;transition:all .15s}.tab-btn:hover{background:var(--color-border-light);color:var(--color-text)}.tab-active{background:var(--color-primary)!important;color:#fff!important}.filter-bar{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.filter-btn{padding:5px 12px;border:1.5px solid var(--color-border);border-radius:999px;background:var(--color-surface);font-family:inherit;font-size:.78rem;font-weight:600;color:var(--color-text-light);cursor:pointer;transition:all .15s}.filter-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.filter-active{background:var(--color-primary)!important;border-color:var(--color-primary)!important;color:#fff!important}.section{margin-bottom:24px}.section-title{font-size:1.05rem;font-weight:700;color:var(--color-text);margin-bottom:16px}.form-group{margin-bottom:14px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-label{display:block;font-size:.82rem;font-weight:700;color:var(--color-text);margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px}.form-input{width:100%;padding:10px 12px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-family:inherit;font-size:.9rem;color:var(--color-text);background:var(--color-surface);outline:none;transition:border-color .15s;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e51f}.form-textarea{min-height:90px;resize:vertical;line-height:1.5}.leave-form{background:var(--color-surface);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.search-box{margin-bottom:12px}.required{color:var(--color-danger)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border:none;border-radius:var(--radius-sm);font-family:inherit;font-size:.875rem;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-full{width:100%}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){filter:brightness(.9)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){filter:brightness(.9)}.btn-override{background:var(--color-hr);color:#fff}.btn-override:hover:not(:disabled){background:var(--color-hr-dark)}.btn-ghost{background:transparent;color:var(--color-text-light);border:1.5px solid var(--color-border)}.btn-ghost:hover:not(:disabled){background:var(--color-surface-2);color:var(--color-text)}.btn-sm{padding:6px 12px;font-size:.8rem}.leave-list{display:flex;flex-direction:column;gap:12px}.leave-card{background:var(--color-surface);border-radius:var(--radius-md);padding:16px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);transition:box-shadow .15s}.leave-card:hover{box-shadow:var(--shadow-md)}.leave-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:10px}.leave-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.leave-type{font-size:.9rem;font-weight:700;color:var(--color-primary)}.leave-dates{font-size:.78rem;color:var(--color-text-light);font-weight:600;white-space:nowrap}.leave-person,.leave-reason,.leave-comment{font-size:.85rem;color:var(--color-text);margin-bottom:4px;line-height:1.5}.leave-person-label{font-weight:700;color:var(--color-text-light);margin-right:4px}.leave-comment{color:var(--color-text-light);font-style:italic}.leave-comment-hr{color:var(--color-hr)}.leave-actions{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border-light)}.badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.3px;text-transform:uppercase;white-space:nowrap}.badge-pending{background:var(--color-accent-light);color:#92400e}.badge-approved{background:var(--color-success-light);color:#065f46}.badge-rejected{background:var(--color-danger-light);color:var(--color-danger-dark)}.badge-hr-approved{background:var(--color-hr-light);color:var(--color-hr-dark)}.badge-hr-rejected{background:#fce7f3;color:#9d174d}.alert{padding:10px 14px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;margin-bottom:14px}.alert-error{background:var(--color-danger-light);color:var(--color-danger-dark)}.alert-success{background:var(--color-success-light);color:#065f46}.empty-state{text-align:center;padding:40px 20px;color:var(--color-text-light);font-size:.9rem;display:flex;flex-direction:column;align-items:center;gap:12px}.state-msg{color:var(--color-text-light);font-size:.9rem;padding:20px 0;text-align:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1f293780;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.modal-card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:460px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--color-border-light)}.modal-title{font-size:1rem;font-weight:700}.modal-close{background:none;border:none;font-size:1rem;color:var(--color-text-light);cursor:pointer;padding:4px;line-height:1}.modal-body{padding:18px 20px 20px}.modal-leave-summary{background:var(--color-surface-2);border-radius:var(--radius-sm);padding:12px;margin-bottom:16px;border:1px solid var(--color-border-light);font-size:.875rem;line-height:1.6}.modal-reason{color:var(--color-text-light);margin-top:4px}.modal-mgr-note{color:var(--color-text-light);font-style:italic;margin-top:4px}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.toggle-group{display:flex;gap:0;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden;margin-bottom:4px}.toggle-btn{flex:1;padding:9px;border:none;background:var(--color-surface);font-family:inherit;font-size:.85rem;font-weight:700;color:var(--color-text-light);cursor:pointer;transition:all .15s}.toggle-btn+.toggle-btn{border-left:1.5px solid var(--color-border)}.toggle-active-approve{background:var(--color-success)!important;color:#fff!important}.toggle-active-reject{background:var(--color-danger)!important;color:#fff!important}.auth-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--color-bg)}.auth-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:36px 32px;width:100%;max-width:400px;box-shadow:var(--shadow-md);border:1px solid var(--color-border-light)}.auth-logo{text-align:center;margin-bottom:28px}.auth-logo-icon{font-size:2.5rem}.auth-title{font-size:1.6rem;font-weight:800;color:var(--color-primary);letter-spacing:-.5px;margin-top:4px}.auth-subtitle{font-size:.85rem;color:var(--color-text-light);margin-top:2px}.auth-form{margin-bottom:24px}.auth-error{background:var(--color-danger-light);color:var(--color-danger-dark);padding:10px 12px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;margin-bottom:14px}.auth-hint{background:var(--color-surface-2);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);padding:14px}.auth-hint-title{font-size:.75rem;font-weight:700;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.auth-hint-grid{display:grid;grid-template-columns:auto 1fr;gap:3px 10px;font-size:.78rem;color:var(--color-text)}.auth-hint-grid span:nth-child(odd){font-weight:700;color:var(--color-text-light)}
