@tailwind base;@tailwind components;@tailwind utilities;*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#f4f7fc;color:#1e293b;min-height:100vh;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-container{display:flex;flex-direction:column;min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px;transition:background .2s ease}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}input:focus,select:focus,textarea:focus{outline:none}table{border-collapse:collapse}.navbar{background:#fff;padding:0 2rem;height:70px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:100}.navbar-brand{display:flex;align-items:center;gap:12px;font-weight:700;font-size:1.2rem;color:#0f172a}.navbar-brand .brand-icon{width:40px;height:40px;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;box-shadow:0 4px 8px #2563eb40}.navbar-brand .brand-icon.admin{background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 4px 10px #7c3aed4d}.navbar-brand .brand-sub{font-weight:700;font-size:1.2rem;color:#0f172a;margin-left:8px}.navbar-right{display:flex;align-items:center;gap:20px}.navbar-right .notif{position:relative;font-size:1.2rem;color:#475569;cursor:pointer;transition:color .2s}.navbar-right .notif:hover{color:#2563eb}.navbar-right .notif.admin-hover:hover{color:#7c3aed}.navbar-right .notif .badge{position:absolute;top:-6px;right:-8px;background:#ef4444;color:#fff;font-size:.6rem;font-weight:600;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid #fff}.user-profile{display:flex;align-items:center;gap:10px;cursor:pointer;padding:6px 12px 6px 6px;border-radius:40px;transition:background .2s}.user-profile:hover{background:#f1f5f9}.user-profile .avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#8b5cf6,#6d28d9);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.9rem}.user-profile .user-name{font-weight:500;font-size:.9rem}.user-profile .user-role{font-size:.7rem;color:#94a3b8}.main-wrapper{display:flex;flex:1;max-width:1440px;margin:0 auto;padding:1.5rem 2rem;gap:1.5rem;width:100%}.sidebar{width:240px;flex-shrink:0;background:#fff;border-radius:20px;padding:1.2rem .8rem;border:1px solid #eef2f6;height:fit-content;position:sticky;top:90px;box-shadow:0 1px 3px #00000008}.sidebar .nav-section{font-size:.65rem;text-transform:uppercase;letter-spacing:.5px;color:#94a3b8;font-weight:600;padding:0 .8rem .6rem;border-bottom:1px solid #f1f5f9;margin-bottom:.6rem}.sidebar-nav{display:flex;flex-direction:column;gap:2px}.sidebar-nav a,.sidebar-nav button{display:flex;align-items:center;gap:14px;padding:.7rem .9rem;border-radius:12px;color:#475569;text-decoration:none;font-weight:500;font-size:.9rem;transition:all .2s;cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:inherit}.sidebar-nav a i,.sidebar-nav button i{width:22px;font-size:1rem;text-align:center;color:#94a3b8;transition:color .2s}.sidebar-nav a:hover,.sidebar-nav button:hover{background:#f1f5f9;color:#0f172a}.sidebar-nav a:hover i,.sidebar-nav button:hover i{color:#2563eb}.sidebar-nav a.active,.sidebar-nav button.active{background:#eff6ff;color:#1d4ed8;font-weight:600;box-shadow:inset 0 0 0 1px #2563eb26}.sidebar-nav a.active i,.sidebar-nav button.active i{color:#2563eb}.sidebar-nav a.admin-active,.sidebar-nav button.admin-active{background:#f5f3ff;color:#6d28d9;font-weight:600;box-shadow:inset 0 0 0 1px #7c3aed26}.sidebar-nav a.admin-active i,.sidebar-nav button.admin-active i,.sidebar-nav a.admin-hover:hover i,.sidebar-nav button.admin-hover:hover i{color:#7c3aed}.nav-badge{margin-left:auto;background:#e2e8f0;color:#475569;font-size:.65rem;font-weight:600;padding:1px 10px;border-radius:20px}.sidebar-nav a.active .nav-badge,.sidebar-nav button.active .nav-badge{background:#bfdbfe;color:#1d4ed8}.sidebar-nav a.admin-active .nav-badge,.sidebar-nav button.admin-active .nav-badge{background:#ede9fe;color:#6d28d9}.sidebar-divider{height:1px;background:#f1f5f9;margin:.5rem}.content{flex:1;min-width:0}.content-inner{padding:0}.header-actions{display:flex;gap:10px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.page-header h1{font-size:1.6rem;font-weight:700;color:#0f172a}.page-header h1 small{font-weight:400;font-size:.85rem;color:#64748b;margin-left:10px}.page-header .actions{display:flex;gap:10px}.btn{padding:.5rem 1.2rem;border-radius:40px;font-weight:500;font-size:.85rem;border:none;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px;font-family:inherit}.btn-outline{background:transparent;border:1px solid #e2e8f0;color:#475569}.btn-outline:hover{background:#f1f5f9;border-color:#cbd5e1}.btn-primary{background:#2563eb;color:#fff;box-shadow:0 4px 10px #2563eb40}.btn-primary:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 6px 16px #2563eb59}.btn-admin{background:#7c3aed;color:#fff;box-shadow:0 4px 10px #7c3aed40}.btn-admin:hover{background:#6d28d9;transform:translateY(-1px);box-shadow:0 6px 16px #7c3aed59}.btn-success{background:#16a34a;color:#fff}.btn-success:hover{background:#15803d}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover{background:#b91c1c}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover{background:#d97706}.btn-sm{padding:.2rem .8rem;font-size:.75rem;border-radius:30px;border:none;cursor:pointer;font-weight:500;font-family:inherit}.btn-sm.primary{background:#dbeafe;color:#1d4ed8}.btn-sm.primary:hover{background:#bfdbfe}.btn-sm.admin-primary{background:#ede9fe;color:#6d28d9}.btn-sm.admin-primary:hover{background:#ddd6fe}.btn-sm.danger{background:#fee2e2;color:#dc2626}.btn-sm.danger:hover{background:#fecaca}.btn-sm.success{background:#dcfce7;color:#16a34a}.btn-sm.success:hover{background:#bbf7d0}.card{background:#fff;border-radius:18px;padding:1.5rem 1.8rem;border:1px solid #eef2f6;box-shadow:0 1px 3px #00000008;transition:box-shadow .2s}.card:hover{box-shadow:0 4px 12px #0000000d}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}.card-header h3{font-size:1.05rem;font-weight:600;color:#0f172a}.card-header .card-action{font-size:.8rem;color:#2563eb;font-weight:500;cursor:pointer;background:none;border:none;transition:color .2s;font-family:inherit}.card-header .card-action:hover{color:#1d4ed8;text-decoration:underline}.card-header .card-action.admin-action{color:#7c3aed}.card-header .card-action.admin-action:hover{color:#6d28d9}.module-section{display:none;animation:fadeIn .3s ease}.module-section.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-bottom:1.8rem}.overview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:16px;padding:1.2rem 1.5rem;border:1px solid #eef2f6;transition:transform .2s}.stat-card:hover{transform:translateY(-3px);box-shadow:0 8px 20px #0000000d}.stat-card .stat-icon{float:right;width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem}.stat-icon.blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-icon.green{background:linear-gradient(135deg,#22c55e,#16a34a)}.stat-icon.purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-icon.orange{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-icon.pink{background:linear-gradient(135deg,#ec4899,#db2777)}.stat-icon.cyan{background:linear-gradient(135deg,#06b6d4,#0891b2)}.stat-icon.admin-purple{background:linear-gradient(135deg,#7c3aed,#6d28d9)}.stat-icon.admin-blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-card .stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.3px;color:#94a3b8;font-weight:600}.stat-card .stat-number{font-size:1.8rem;font-weight:700;color:#0f172a;margin:4px 0 2px}.stat-card .stat-change{font-size:.7rem;font-weight:500;display:inline-flex;align-items:center;gap:4px;padding:1px 10px;border-radius:30px;background:#dcfce7;color:#16a34a}.stat-card .stat-change.down{background:#fee2e2;color:#dc2626}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.9rem}table th{text-align:left;padding:.8rem .5rem .8rem 0;border-bottom:2px solid #eef2f6;font-weight:600;color:#475569;font-size:.8rem;text-transform:uppercase;letter-spacing:.3px}table td{padding:.7rem .5rem .7rem 0;border-bottom:1px solid #f1f5f9;color:#1e293b}table tr:last-child td{border-bottom:none}.status-badge{display:inline-block;padding:2px 12px;border-radius:30px;font-size:.7rem;font-weight:500}.status-badge.active{background:#dcfce7;color:#16a34a}.status-badge.inactive{background:#fee2e2;color:#dc2626}.status-badge.pending{background:#fef3c7;color:#d97706}.status-badge.verified{background:#dbeafe;color:#2563eb}.table-actions{display:flex;align-items:center;gap:6px}.table-actions .btn-icon{background:#f8fafc;border:1px solid #e2e8f0;color:#64748b;cursor:pointer;font-size:.85rem;padding:.4rem .7rem;margin:0 2px;border-radius:8px;transition:all .2s;font-family:inherit;display:flex;align-items:center;justify-content:center;min-width:28px;height:28px}.table-actions .btn-icon:hover{background:#dbeafe;border-color:#93c5fd;color:#1d4ed8}.table-actions .btn-icon.admin-hover:hover{background:#ede9fe;border-color:#c4b5fd;color:#7c3aed}.table-actions .btn-icon.danger{background:#fef2f2;border-color:#fecaca;color:#dc2626}.table-actions .btn-icon.danger:hover{background:#fee2e2;border-color:#fca5a5}.filter-bar{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:1rem}.filter-bar select,.filter-bar input{padding:.4rem .8rem;border-radius:30px;border:1px solid #e2e8f0;background:#fff;font-size:.85rem;outline:none;transition:border .2s}.filter-bar select:focus,.filter-bar input:focus{border-color:#2563eb}.filter-bar select.admin-focus:focus,.filter-bar input.admin-focus:focus{border-color:#7c3aed}.score-filter{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:1rem}.score-filter select,.score-filter input{padding:.4rem .8rem;border-radius:30px;border:1px solid #e2e8f0;background:#fff;font-size:.85rem;outline:none}.score-filter select:focus,.score-filter input:focus{border-color:#2563eb}.overview-bottom{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem}.activity-item{display:flex;gap:14px;padding:.7rem 0;border-bottom:1px solid #f1f5f9}.activity-item:last-child{border-bottom:none}.activity-item .activity-icon{width:36px;height:36px;border-radius:10px;background:#eff6ff;color:#2563eb;display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-item .activity-text{font-size:.9rem;color:#1e293b}.activity-item .activity-text strong{color:#0f172a}.activity-item .activity-time{font-size:.7rem;color:#94a3b8;margin-top:2px}.quick-stat{background:#f8fafc;border-radius:14px;padding:1rem 1.2rem;margin-bottom:.8rem;display:flex;justify-content:space-between;align-items:center}.quick-stat:last-child{margin-bottom:0}.quick-stat .qs-label{font-weight:500;color:#334155}.quick-stat .qs-value{font-weight:700;color:#2563eb}.quick-stat .qs-value.admin-value{color:#7c3aed}.class-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}.class-card{background:#fff;border-radius:16px;padding:1.2rem 1.5rem;border:1px solid #eef2f6;transition:all .2s;cursor:pointer}.class-card:hover{border-color:#b1d0ff;box-shadow:0 4px 12px #0000000a}.class-card.admin-hover:hover{border-color:#d8c8fc}.class-card .class-title{font-weight:600;font-size:1rem;color:#0f172a}.class-card .class-meta{font-size:.8rem;color:#64748b;margin:4px 0 8px}.class-card .class-stats{display:flex;gap:16px;font-size:.75rem;color:#475569}.class-card .class-stats span i{margin-right:4px;color:#94a3b8}.class-card .class-action{margin-top:10px;display:flex;gap:6px}.training-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}.training-card{background:#fff;border-radius:16px;padding:1.2rem 1.5rem;border:1px solid #eef2f6;transition:all .25s ease;cursor:pointer;position:relative}.training-card:hover{transform:translateY(-4px);box-shadow:0 12px 28px #00000012;border-color:#dbeafe}.training-card .t-badge{display:inline-block;font-size:.6rem;font-weight:600;text-transform:uppercase;padding:2px 12px;border-radius:30px;background:#dbeafe;color:#1d4ed8;margin-bottom:8px}.training-card .t-badge.orange{background:#fef3c7;color:#d97706}.training-card .t-badge.green{background:#dcfce7;color:#16a34a}.training-card .t-badge.purple{background:#ede9fe;color:#7c3aed}.training-card .t-badge.pink{background:#fce7f3;color:#db2777}.training-card h4{font-size:1rem;font-weight:600;color:#0f172a;margin-bottom:4px}.training-card p{font-size:.8rem;color:#64748b;margin-bottom:10px;line-height:1.5}.training-card .t-meta{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:#94a3b8;border-top:1px solid #f1f5f9;padding-top:10px}.training-card .t-meta .t-progress{display:flex;align-items:center;gap:8px}.training-card .t-meta .mini-bar{width:60px;height:4px;background:#f1f5f9;border-radius:10px;overflow:hidden}.training-card .t-meta .mini-bar .fill{height:100%;border-radius:10px;background:#2563eb}.training-card .t-meta .t-status{font-weight:500;color:#2563eb}.training-card .t-meta .t-status.completed{color:#16a34a}.training-list .training-item{display:flex;justify-content:space-between;align-items:center;padding:.8rem 0;border-bottom:1px solid #f1f5f9}.training-list .training-item:last-child{border-bottom:none}.training-item .t-info{display:flex;flex-direction:column}.training-item .t-info .t-name{font-weight:600;color:#0f172a}.training-item .t-info .t-desc{font-size:.8rem;color:#64748b}.training-item .t-status{font-size:.75rem;font-weight:500;padding:2px 12px;border-radius:30px}.t-status.published{background:#dcfce7;color:#16a34a}.t-status.draft{background:#fef3c7;color:#d97706}.t-status.archived{background:#e2e8f0;color:#64748b}.training-item .t-actions .btn-sm{padding:.2rem .8rem;font-size:.7rem;border-radius:30px;border:none;cursor:pointer;font-weight:500;margin-left:6px}.dashboard-grid{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.chart-container{height:200px;display:flex;align-items:flex-end;justify-content:space-around;padding:0 4px;gap:8px}.chart-placeholder{display:flex;align-items:flex-end;justify-content:space-between;height:140px;padding:0 4px;margin-top:6px;gap:6px}.chart-bar{flex:1;border-radius:6px 6px 4px 4px;background:linear-gradient(180deg,#2563eb,#3b82f6);min-height:12px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;position:relative}.chart-bar .bar-label{font-size:.55rem;color:#94a3b8;margin-top:6px;font-weight:500}.chart-bar .bar-value{font-size:.6rem;font-weight:600;color:#1e293b;margin-bottom:3px}.chart-bar.green{background:linear-gradient(180deg,#22c55e,#16a34a)}.chart-bar.purple{background:linear-gradient(180deg,#8b5cf6,#7c3aed)}.chart-bar.orange{background:linear-gradient(180deg,#f59e0b,#d97706)}.chart-bar.pink{background:linear-gradient(180deg,#ec4899,#db2777)}.chart-bar.cyan{background:linear-gradient(180deg,#06b6d4,#0891b2)}.chart-bar.blue{background:linear-gradient(180deg,#3b82f6,#2563eb)}.chart-bar.admin-bar{background:linear-gradient(180deg,#7c3aed,#6d28d9)}.score-rank{list-style:none}.score-rank li{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #f1f5f9;font-size:.9rem}.score-rank li:last-child{border-bottom:none}.score-rank .rank-name{font-weight:500}.score-rank .rank-score{font-weight:600;color:#2563eb}.score-rank .rank-admin-score{font-weight:600;color:#7c3aed}.rank-medal{margin-right:6px}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.setting-group{margin-bottom:1.2rem}.setting-group label{display:block;font-weight:500;font-size:.85rem;color:#334155;margin-bottom:4px}.setting-group .help-text{font-size:.7rem;color:#94a3b8;margin-top:2px}.setting-group input,.setting-group select,.setting-group textarea{width:100%;padding:.5rem .8rem;border:1px solid #e2e8f0;border-radius:10px;font-size:.9rem;background:#fff;outline:none;transition:border .2s}.setting-group input:focus,.setting-group select:focus,.setting-group textarea:focus{border-color:#7c3aed}.setting-group textarea{resize:vertical;min-height:60px}.toggle-switch{display:flex;align-items:center;gap:12px}.toggle-switch .toggle{width:44px;height:24px;background:#cbd5e1;border-radius:30px;position:relative;cursor:pointer;transition:background .3s;flex-shrink:0}.toggle-switch .toggle.active{background:#7c3aed}.toggle-switch .toggle .toggle-knob{width:18px;height:18px;background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;transition:transform .3s;box-shadow:0 1px 3px #00000026}.toggle-switch .toggle.active .toggle-knob{transform:translate(20px)}.settings-actions{display:flex;gap:12px;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #eef2f6}.progress-section{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:2rem}.progress-item{margin-bottom:1.2rem}.progress-item:last-child{margin-bottom:0}.progress-item .progress-meta{display:flex;justify-content:space-between;font-size:.85rem;margin-bottom:5px}.progress-item .progress-meta .label{font-weight:500;color:#334155}.progress-item .progress-meta .value{font-weight:600;color:#2563eb}.progress-track{width:100%;height:8px;background:#f1f5f9;border-radius:20px;overflow:hidden}.progress-track .progress-bar{height:100%;border-radius:20px;background:linear-gradient(90deg,#2563eb,#7c3aed);transition:width .6s ease}.progress-track .progress-bar.green{background:linear-gradient(90deg,#22c55e,#16a34a)}.progress-track .progress-bar.orange{background:linear-gradient(90deg,#f59e0b,#d97706)}.progress-track .progress-bar.pink{background:linear-gradient(90deg,#ec4899,#db2777)}.reminder-card{background:#f8fafc;border-radius:18px;padding:1.25rem 1.5rem;border:1px solid #eef2f6}.reminder-card h4{font-size:.85rem;font-weight:600;color:#0f172a;margin-bottom:.75rem}.reminder-item{display:flex;align-items:flex-start;gap:12px;padding:.6rem 0;border-bottom:1px solid #eef2f6}.reminder-item:last-child{border-bottom:none;padding-bottom:0}.reminder-item .reminder-icon{width:30px;height:30px;border-radius:10px;background:#e0e7ff;color:#2563eb;display:flex;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0}.reminder-item .reminder-text{font-size:.85rem;color:#334155;line-height:1.4}.reminder-item .reminder-text strong{color:#0f172a}.reminder-item .reminder-time{font-size:.65rem;color:#94a3b8;margin-top:2px}.score-section{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:.25rem}.score-overview .score-item{display:flex;justify-content:space-between;align-items:center;padding:.7rem 0;border-bottom:1px solid #f1f5f9}.score-overview .score-item:last-child{border-bottom:none}.score-item .s-left{display:flex;align-items:center;gap:12px}.score-item .s-left .s-icon{width:34px;height:34px;border-radius:10px;background:#eff6ff;display:flex;align-items:center;justify-content:center;color:#2563eb;font-size:.9rem}.score-item .s-left .s-name{font-weight:500;color:#1e293b;font-size:.9rem}.score-item .s-left .s-sub{font-size:.7rem;color:#94a3b8}.score-item .s-score{font-weight:700;font-size:1.05rem;color:#0f172a}.score-item .s-score .s-total{font-weight:400;font-size:.75rem;color:#94a3b8}@media (max-width: 1200px){.stats-grid,.overview-grid,.class-grid,.training-grid{grid-template-columns:repeat(2,1fr)}.settings-grid{grid-template-columns:1fr}}@media (max-width: 992px){.main-wrapper{flex-direction:column;padding:1rem 1.2rem}.sidebar{width:100%;position:static;padding:.8rem;display:flex;flex-wrap:wrap;gap:.2rem}.sidebar .nav-section{width:100%;padding-bottom:.4rem;margin-bottom:.4rem}.sidebar-nav{flex-direction:row;flex-wrap:wrap;gap:2px}.sidebar-nav a,.sidebar-nav button{padding:.4rem 1rem;font-size:.8rem;border-radius:40px}.sidebar-nav a .nav-badge,.sidebar-nav button .nav-badge,.sidebar-divider{display:none}.overview-bottom,.dashboard-grid,.score-section,.progress-section{grid-template-columns:1fr}}@media (max-width: 640px){.navbar{padding:0 1rem;height:60px}.navbar-brand{font-size:1rem}.navbar-brand .brand-sub,.user-profile .user-name,.user-profile .user-role{display:none}.stats-grid,.overview-grid,.class-grid,.training-grid,.settings-grid{grid-template-columns:1fr}.page-header h1{font-size:1.2rem}.page-header h1 small{display:block;margin-left:0;font-size:.7rem}.card{padding:1rem 1.2rem}.stat-card .stat-number{font-size:1.4rem}.chart-container{height:150px}.chart-placeholder{height:100px}.filter-bar{flex-direction:column}.filter-bar select,.filter-bar input,.filter-bar .btn{width:100%}}.mt-2{margin-top:1.8rem}.mb-1{margin-bottom:.8rem}.text-muted{color:#94a3b8}.flex-between{display:flex;justify-content:space-between;align-items:center}.gap-2{gap:.5rem}.inline-flex{display:inline-flex;align-items:center;gap:6px}.w-full{width:100%}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:#fff;border-radius:16px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000026;animation:slideUp .3s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.5rem;border-bottom:1px solid #eef2f6}.modal-header h3{font-size:1.1rem;font-weight:600;color:#0f172a;margin:0}.modal-close{background:none;border:none;font-size:1.2rem;color:#94a3b8;cursor:pointer;padding:.3rem;border-radius:6px;transition:all .2s}.modal-close:hover{background:#f1f5f9;color:#64748b}.modal-body{padding:1.5rem}.modal-body .form-group{margin-bottom:1rem}.modal-body .form-group label{display:block;font-size:.85rem;font-weight:500;color:#334155;margin-bottom:.4rem}.modal-body .form-group input,.modal-body .form-group select{width:100%;padding:.65rem .8rem;border:1px solid #e2e8f0;border-radius:10px;font-size:.9rem;font-family:inherit;transition:border-color .2s;background:#fff}.modal-body .form-group input:focus,.modal-body .form-group select:focus{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a}.modal-body .form-group input::placeholder{color:#94a3b8}.modal-footer{display:flex;justify-content:flex-end;gap:.8rem;padding:1.2rem 1.5rem;border-top:1px solid #eef2f6}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
