@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Roboto:wght@300;400;500;700&display=swap";*{box-sizing:border-box;margin:0;padding:0}body{color:#2d3748;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fafafa;font-family:Inter,Roboto,system-ui,-apple-system,sans-serif}#root{min-height:100vh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#c4c4c4;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#a0a0a0}.app-layout{min-height:100vh;display:flex}.sidebar{z-index:50;background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;width:250px;min-width:250px;height:100vh;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid #e2e8f0;align-items:center;gap:12px;padding:20px;display:flex}.sidebar-brand h2{color:#730051;margin:0;font-size:1.1rem;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:12px;display:flex}.nav-link{color:#718096;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-link:hover{color:#730051;background:#f8f4f7}.nav-link.active{color:#fff;background:#730051}.nav-link .nav-icon{text-align:center;width:20px;font-size:1.1rem}.main-wrapper{flex-direction:column;flex:1;min-height:100vh;margin-left:250px;display:flex}.topbar{color:#fff;z-index:40;background:#730051;justify-content:space-between;align-items:center;height:60px;padding:0 24px;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #73005133}.topbar-title{font-size:1.1rem;font-weight:600}.topbar-right{align-items:center;gap:12px;display:flex}.user-info{align-items:center;gap:10px;display:flex}.user-avatar{background:#fff3;border-radius:50%;justify-content:center;align-items:center;width:36px;min-width:36px;height:36px;font-size:.9rem;font-weight:700;display:flex}.user-details{flex-direction:column;line-height:1.3;display:flex}.user-name{white-space:nowrap;font-size:.85rem;font-weight:600}.role-badge{opacity:.8;text-transform:capitalize;white-space:nowrap;font-size:.7rem}.topbar .logout-btn{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff4d;border-radius:6px;padding:6px 16px;font-size:.8rem;font-weight:500;transition:all .2s}.topbar .logout-btn:hover{background:#ffffff40}.hamburger-btn{color:#fff;cursor:pointer;background:0 0;border:none;padding:4px;line-height:0;display:none}.topbar-left{align-items:center;gap:12px;display:flex}.sidebar-overlay{display:none}.content-area{background:#fafafa;flex:1;padding:24px}.auth-container{background:#fafafa;justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.auth-card{background:#fff;border-radius:16px;width:100%;max-width:420px;padding:2.5rem;position:relative;overflow:hidden;box-shadow:0 8px 32px #7300511f}.auth-card:before{content:"";background:linear-gradient(90deg,#730051,#a0006e,#730051);height:4px;position:absolute;top:0;left:0;right:0}.auth-card h1{text-align:center;color:#730051;margin:0 0 .25rem;font-size:1.5rem;font-weight:700}.auth-card h2{text-align:center;color:#718096;margin:0 0 1.5rem;font-size:1rem;font-weight:400}.auth-error{color:#d32f2f;text-align:center;background:linear-gradient(135deg,#ffeaea,#ffe0e0);border:1px solid #ffb3b3;border-radius:10px;margin-bottom:1rem;padding:.75rem;font-size:.85rem}.auth-success{color:#2d5a2d;text-align:center;background:linear-gradient(135deg,#e8f5e8,#d4f4d4);border:1px solid #a3d9a3;border-radius:10px;margin-bottom:1rem;padding:.75rem;font-size:.85rem}.form-group{margin-bottom:1rem}.form-group label{color:#2d3748;margin-bottom:.4rem;font-size:.85rem;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{color:#2d3748;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;width:100%;padding:12px 14px;font-family:inherit;font-size:.95rem;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background:#fff;border-color:#730051;outline:none;box-shadow:0 0 0 3px #7300511a}.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23730051' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:40px}.password-wrapper{position:relative}.password-wrapper input{width:100%;padding-right:44px}.password-toggle{cursor:pointer;color:#718096;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.password-toggle:hover{color:#730051}.auth-btn,.btn-primary{color:#fff;cursor:pointer;background:#730051;border:none;border-radius:10px;width:100%;margin-top:.5rem;padding:12px 24px;font-size:.95rem;font-weight:600;transition:all .2s;box-shadow:0 4px 12px #73005140}.auth-btn:hover,.btn-primary:hover{background:#5a0040;transform:translateY(-1px);box-shadow:0 6px 16px #73005159}.auth-btn:disabled,.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{color:#718096;cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;padding:10px 22px;font-size:.9rem;font-weight:500;transition:all .2s}.btn-secondary:hover{color:#730051;background:#f8f4f7;border-color:#730051}.btn-danger{color:#fff;cursor:pointer;background:#e53e3e;border:none;border-radius:10px;padding:10px 22px;font-size:.9rem;font-weight:500;transition:all .2s}.btn-danger:hover{background:#c82333;transform:translateY(-1px)}.btn-sm{width:auto;padding:6px 14px;font-size:.8rem}.data-table .btn-primary,.data-table .btn-danger,.data-table .btn-secondary{width:auto;margin:2px 4px;display:inline-block}.dashboard{animation:.3s fadeIn}.dashboard h2{color:#2d3748;margin:0 0 .25rem;font-size:1.5rem;font-weight:700}.dashboard-subtitle{color:#718096;margin-bottom:24px;font-size:.9rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{color:#fff;text-align:center;background:#730051;border-radius:12px;padding:24px;box-shadow:0 4px 12px #7300514d}.stat-card h3{margin:0 0 4px;font-size:2rem;font-weight:700}.stat-card p{opacity:.9;margin:0;font-size:.85rem}.quick-actions{margin-top:8px}.quick-actions h2{margin-bottom:16px}.actions-grid{flex-wrap:wrap;gap:12px;display:flex}.action-card{color:#fff;cursor:pointer;background:#730051;border:none;border-radius:8px;align-items:center;padding:12px 24px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.action-card:hover{background:#8a0060;transform:translateY(-1px);box-shadow:0 4px 12px #73005159}.action-card .card-icon{margin-bottom:12px;font-size:1.8rem}.action-card h3{color:#2d3748;margin:0 0 6px;font-size:1rem;font-weight:600}.action-card p{color:#718096;margin:0;font-size:.8rem;line-height:1.4}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header h1{margin:0}.page-header h2{color:#2d3748;margin:0;font-size:1.4rem;font-weight:700}.page-header .btn-primary,.page-header .btn-secondary{white-space:nowrap;width:auto;margin-top:0;padding:10px 20px;font-size:.85rem;text-decoration:none}a.btn-primary,a.btn-secondary{text-align:center;width:auto;text-decoration:none;display:inline-block}.data-table-wrapper{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 4px #00000014}.data-table{border-collapse:collapse;width:100%}.data-table th{color:#fff;text-align:left;text-transform:uppercase;letter-spacing:.5px;background:#730051;padding:14px 16px;font-size:.8rem;font-weight:600}.data-table td{color:#2d3748;border-bottom:1px solid #e2e8f0;padding:14px 16px;font-size:.85rem}.data-table tbody tr:hover{background:#f8f9fa}.data-table tbody tr:nth-child(2n){background:#fafafa}.badge{text-transform:uppercase;border-radius:20px;padding:4px 12px;font-size:.7rem;font-weight:600;display:inline-block}.badge-pending{color:#856404;background:#fff3cd}.badge-approved{color:#155724;background:#d4edda}.badge-rejected{color:#721c24;background:#f8d7da}.badge-completed{color:#004085;background:#cce5ff}.badge-good{color:#155724;background:#d4edda}.badge-fair{color:#856404;background:#fff3cd}.badge-poor{color:#721c24;background:#f8d7da}.form-card{background:#fff;border:1px solid #e2e8f0;border-radius:15px;max-width:600px;margin:0 auto;padding:32px;position:relative;overflow:hidden;box-shadow:0 4px 20px #00000014}.form-card:before{content:"";background:linear-gradient(135deg,#730051,#a0006e);height:6px;position:absolute;top:0;left:0;right:0}.form-card h2{color:#730051;margin:0 0 24px;font-size:1.3rem;font-weight:700}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-actions{justify-content:flex-end;gap:12px;margin-top:20px;display:flex}.filter-bar{flex-wrap:wrap;align-items:end;gap:12px;margin-bottom:20px;display:flex}.filter-bar .form-group{min-width:160px;margin:0}.filter-bar .form-group label{font-size:.75rem}.filter-bar .form-group input,.filter-bar .form-group select{padding:8px 12px;font-size:.85rem}.landing{background:#fafafa;flex-direction:column;min-height:100vh;display:flex}.landing-nav{color:#fff;z-index:100;background:#730051;justify-content:space-between;align-items:center;padding:.75rem 2rem;display:flex;position:sticky;top:0;box-shadow:0 4px 16px #0006}.landing-nav-brand{align-items:center;gap:10px;display:flex}.landing-nav-logo{object-fit:contain;background:#fff;border-radius:50%;width:40px;height:40px;padding:2px}.landing-logo{font-size:1.2rem;font-weight:700}.landing-login-btn{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff4d;border-radius:8px;padding:.5rem 1.5rem;font-size:.9rem;font-weight:500;transition:all .2s}.landing-login-btn:hover{background:#ffffff40}.landing-hero{text-align:center;color:#fff;background:#730051;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:6rem 2rem;display:flex}.hero-logo{object-fit:contain;background:#fff;border-radius:50%;width:100px;height:100px;margin-bottom:1.5rem;padding:10px}.landing-hero h1{color:#fff;letter-spacing:-.5px;margin:0 0 1rem;font-size:2.2rem;font-weight:800}.landing-hero p{color:#ffffffd9;max-width:600px;margin:0 auto 2rem;font-size:1.05rem;line-height:1.7}.landing-cta{color:#730051;cursor:pointer;letter-spacing:.3px;background:#fff;border:none;border-radius:25px;padding:.85rem 2.5rem;font-size:1rem;font-weight:600;transition:all .2s;box-shadow:0 4px 12px #4a90a44d}.landing-cta:hover{background:#f0f0f0;transform:translateY(-2px);box-shadow:0 6px 16px #0003}.landing-footer{text-align:center;color:#ffffffb3;background:#5a003e;padding:1.5rem 2rem;font-size:.8rem}.landing-footer p{margin:0}.auth-logo{object-fit:contain;border-radius:50%;width:70px;height:70px;margin:0 auto 1rem;display:block;box-shadow:0 4px 16px #73005133}@media (width<=768px){.landing-hero h1{font-size:1.6rem}.hero-logo{width:80px;height:80px}}.not-found{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.not-found h1{color:#730051;margin:0;font-size:6rem;font-weight:800;line-height:1}.not-found p{color:#718096;margin:1rem 0 2rem;font-size:1.1rem}.empty-state{text-align:center;color:#a0aec0;padding:60px 20px}.empty-state .empty-icon{margin-bottom:16px;font-size:3rem}.empty-state p{font-size:1rem}.loading{color:#718096;justify-content:center;align-items:center;min-height:200px;font-size:1rem;display:flex}.modal-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:15px;width:100%;max-width:500px;padding:32px;position:relative;box-shadow:0 10px 30px #0003}.modal-content h3{color:#2d3748;margin:0 0 20px;font-size:1.2rem}.modal-close{cursor:pointer;color:#a0aec0;background:0 0;border:none;font-size:1.2rem;position:absolute;top:16px;right:16px}.report-section{margin-bottom:24px}.report-section h3{color:#2d3748;margin:0 0 16px;font-size:1.1rem;font-weight:700}.category-chart{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a}.category-row{align-items:center;gap:12px;margin-bottom:12px;display:flex}.category-label{min-width:100px;font-size:.85rem;font-weight:500}.category-bar-bg{background:#f0f0f0;border-radius:4px;flex:1;height:24px}.category-bar-fill{background-color:#730051;border-radius:4px;height:100%;transition:width .3s}.category-amount{text-align:right;min-width:120px;font-size:.85rem;font-weight:500}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.hamburger-btn{display:flex}.sidebar-overlay{z-index:99;background:#0006;display:block;position:fixed;inset:0}.sidebar{z-index:100;transition:transform .3s;position:fixed;transform:translate(-100%);box-shadow:4px 0 20px #00000026}.sidebar.open{transform:translate(0)}.main-wrapper{margin-left:0}.topbar{padding:0 12px}.topbar-title{font-size:.9rem}.user-details{display:none}.topbar .logout-btn{padding:5px 10px;font-size:.75rem}.content-area{padding:16px 12px}.page-header{flex-direction:column;align-items:flex-start;gap:12px}.page-header h1{font-size:1.3rem}.form-row{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.actions-grid,.filter-bar{flex-direction:column}.filter-bar .form-group{min-width:unset;width:100%}.data-table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{min-width:600px;font-size:.75rem}.data-table th,.data-table td{white-space:nowrap;padding:10px 8px}.form-card{max-width:100%;padding:20px 16px}.form-card h2{font-size:1.1rem}.form-actions{flex-direction:column}.form-actions .btn-primary,.form-actions .btn-secondary{text-align:center;width:100%}.modal-backdrop{padding:12px}.modal-content{max-width:100%;padding:20px}.landing-nav{padding:.5rem 1rem}.landing-hero{padding:3rem 1.5rem}.landing-hero p{font-size:.9rem}.category-chart{padding:16px}.category-row{flex-wrap:wrap;gap:4px 8px}.category-label{min-width:unset;width:100%;font-size:.8rem}.category-bar-bg{flex:1;min-width:0;height:20px}.category-amount{min-width:unset;white-space:nowrap;font-size:.8rem}.stat-card h3{font-size:1.3rem}.stat-card p{font-size:.8rem}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}.stat-card{padding:16px}.stat-card h3{font-size:1.5rem}.auth-card{padding:1.5rem 1.25rem}.form-card{padding:16px 12px}.content-area{padding:12px 8px}.page-header h1{font-size:1.1rem}.data-table{min-width:500px;font-size:.7rem}.data-table th,.data-table td{padding:8px 6px}.btn-sm{padding:4px 10px;font-size:.7rem}.badge{padding:3px 8px;font-size:.6rem}.landing-hero h1{font-size:1.3rem}.landing-cta{padding:.7rem 2rem;font-size:.9rem}}
