.app-layout{min-height:100vh;display:flex;flex-direction:column}.app-header{background:white;box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:100}.header-content{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;max-width:100%}.header-left{display:flex;align-items:center;gap:12px}.menu-btn{background:none;border:none;cursor:pointer;padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#374151}.menu-btn:hover{background:#f3f4f6}.header-center{display:flex;align-items:center;justify-content:center}.header-logo{max-height:48px;max-width:200px;object-fit:contain}.header-right{width:48px}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:200}.sidebar{position:fixed;top:0;left:0;width:300px;height:100vh;background:white;z-index:201;display:flex;flex-direction:column;box-shadow:4px 0 12px #00000026}.sidebar-header{display:flex;flex-direction:column}.sidebar-logo{padding:16px;display:flex;align-items:center;justify-content:center}.sidebar-logo img{max-height:60px;max-width:180px;object-fit:contain}.sidebar-user{padding:20px;background:#f8fafc;border-bottom:1px solid #e5e7eb}.sidebar-user-info{display:flex;align-items:center;gap:12px}.sidebar-avatar-container{position:relative}.sidebar-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;border:2px solid #2563eb}.sidebar-avatar-placeholder{width:56px;height:56px;border-radius:50%;background:#2563eb;color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;border:2px solid #2563eb}.sidebar-avatar-edit{position:absolute;bottom:0;right:0;width:24px;height:24px;background:white;border:1px solid #e5e7eb;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#6b7280}.sidebar-avatar-edit:hover{background:#f3f4f6;color:#2563eb}.sidebar-user-details h4{font-size:16px;margin-bottom:2px;color:#1f2937}.sidebar-user-details p{font-size:13px;color:#6b7280}.sidebar-nav{flex:1;padding:16px 0;overflow-y:auto}.sidebar-nav-item{display:flex;align-items:center;gap:12px;padding:12px 24px;color:#374151;text-decoration:none;transition:all .2s ease;cursor:pointer;border:none;background:none;width:100%;text-align:left;font-size:14px}.sidebar-nav-item:hover{background:#f3f4f6;color:#2563eb}.sidebar-nav-item.active{background:#eff6ff;color:#2563eb;border-right:3px solid #2563eb}.sidebar-footer{padding:16px;border-top:1px solid #e5e7eb}.logout-btn{display:flex;align-items:center;gap:12px;padding:12px 24px;color:#dc2626;background:none;border:none;width:100%;text-align:left;font-size:14px;cursor:pointer;border-radius:8px}.logout-btn:hover{background:#fef2f2}.main-content{flex:1;padding:24px;width:95%;max-width:1600px;margin:0 auto}.page-title{font-size:28px;font-weight:700;color:#1f2937;margin-bottom:24px}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:20px}.login-card{background:white;border-radius:20px;padding:48px;width:100%;max-width:420px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:32px}.login-logo{max-width:200px;max-height:80px;margin-bottom:16px;object-fit:contain}.login-header h1{font-size:28px;color:#1f2937;margin-bottom:8px}.login-header p{color:#6b7280}.login-form{display:flex;flex-direction:column;gap:16px}.login-form .btn{margin-top:8px;padding:14px;font-size:16px}.forgot-password{text-align:center;margin-top:16px}.forgot-password a{color:#2563eb;text-decoration:none;font-size:14px}.forgot-password a:hover{text-decoration:underline}.error-message{background:#fef2f2;color:#dc2626;padding:12px;border-radius:8px;font-size:14px;text-align:center}.success-message{background:#dcfce7;color:#16a34a;padding:12px;border-radius:8px;font-size:14px;text-align:center}.avatar-dropzone{width:100%;border:2px dashed #d1d5db;border-radius:12px;padding:20px;text-align:center;cursor:pointer;transition:all .3s ease;background:#f9fafb}.avatar-dropzone:hover{border-color:#2563eb;background:#f0f7ff}.avatar-preview{width:80px;height:80px;border-radius:50%;object-fit:cover;margin:0 auto;display:block}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:#f5f7fa;color:#333;min-height:100vh}#root{min-height:100vh}.container{width:95%;max-width:1400px;margin:0 auto;padding:20px}.card{background:white;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;margin-bottom:20px}.btn{padding:10px 20px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.btn-primary{background:#2563eb;color:#fff}.btn-primary:hover{background:#1d4ed8}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover{background:#4b5563}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover{background:#b91c1c}.btn-success{background:#16a34a;color:#fff}.btn-success:hover{background:#15803d}.form-group{margin-bottom:12px}.form-group label{display:block;margin-bottom:4px;font-weight:500;color:#374151;font-size:13px}.form-control{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .3s ease}.form-control:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}textarea.form-control{min-height:120px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:white;border-radius:12px;padding:24px;max-width:800px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h2{margin:0}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#6b7280}.tabs{display:flex;border-bottom:2px solid #e5e7eb;margin-bottom:20px}.tab{padding:12px 24px;cursor:pointer;border:none;background:none;font-size:14px;font-weight:500;color:#6b7280;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .3s ease}.tab.active{color:#2563eb;border-bottom-color:#2563eb}.tab:hover{color:#2563eb}.dropzone{border:2px dashed #d1d5db;border-radius:12px;padding:40px;text-align:center;cursor:pointer;transition:all .3s ease}.dropzone:hover,.dropzone.active{border-color:#2563eb;background:#f0f7ff}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px;text-align:left;border-bottom:1px solid #e5e7eb}.table th{background:#f9fafb;font-weight:600}.table tr:hover{background:#f9fafb}.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:24px}.kpi-card{background:white;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;text-align:center}.kpi-value{font-size:28px;font-weight:700;color:#2563eb;margin-bottom:8px}.kpi-label{font-size:14px;color:#6b7280}.home-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;padding:20px 0}.home-card{background:white;border-radius:16px;padding:32px;box-shadow:0 4px 12px #0000001a;cursor:pointer;transition:all .3s ease;text-align:center;text-decoration:none;color:inherit}.home-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.home-card-icon{width:64px;height:64px;background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:#fff}.home-card h3{font-size:18px;margin-bottom:8px;color:#1f2937}.home-card p{font-size:14px;color:#6b7280}.badge{display:inline-block;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.badge-success{background:#dcfce7;color:#16a34a}.badge-danger{background:#fee2e2;color:#dc2626}.badge-info{background:#dbeafe;color:#2563eb}.avatar-small{width:32px;height:32px;border-radius:50%;object-fit:cover}.avatar-medium{width:48px;height:48px;border-radius:50%;object-fit:cover}.avatar-large{width:80px;height:80px;border-radius:50%;object-fit:cover}.avatar-placeholder{display:flex;align-items:center;justify-content:center;background:#2563eb;color:#fff;font-weight:600}.two-columns{display:grid;grid-template-columns:1fr 1fr;gap:24px}@media (max-width: 768px){.two-columns,.form-row,.kpi-grid{grid-template-columns:1fr}}
