:root{--primary:#1e3a5f;--primary-light:#2d5282;--primary-dark:#142a47;--accent:#f5a623;--accent-light:#fbbf24;--accent-dark:#d97706;--success:#16a34a;--success-bg:#f0fdf4;--warning:#d97706;--warning-bg:#fffbeb;--danger:#dc2626;--danger-bg:#fef2f2;--info:#0284c7;--info-bg:#f0f9ff;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--font-sans:"Inter","Segoe UI",system-ui,-apple-system,sans-serif;--font-display:"Poppins",var(--font-sans);--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-sm:6px;--radius:10px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 3px #00000014,0 1px 2px #0000000f;--shadow:0 4px 12px #0000001a;--shadow-lg:0 10px 30px #0000001f;--sidebar-width:260px;--sidebar-collapsed:70px;--topbar-height:64px;--transition:0.2s ease}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;background:#f9fafb;background:var(--gray-50);color:#1f2937;color:var(--gray-800);font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;font-family:var(--font-sans);line-height:1.6;min-height:100vh}a{color:inherit;text-decoration:none}button{background:none;border:none;cursor:pointer}button,input,select,textarea{font-family:inherit}img{display:block;max-width:100%}ol,ul{list-style:none}h1{font-family:Poppins,Inter,Segoe UI,system-ui,-apple-system,sans-serif;font-family:var(--font-display);font-size:2rem;font-weight:700;line-height:1.2}h2{font-size:1.5rem;line-height:1.3}h2,h3{font-weight:600}h3{font-size:1.25rem;line-height:1.4}h4{font-size:1.1rem}h4,h5{font-weight:600}h5,p{font-size:.95rem}p{color:#4b5563;color:var(--gray-600)}.app-layout,.main-content{display:flex;min-height:100vh}.main-content{flex:1 1;flex-direction:column;margin-left:260px;margin-left:var(--sidebar-width);transition:margin-left .2s ease;transition:margin-left var(--transition)}.main-content.collapsed{margin-left:70px;margin-left:var(--sidebar-collapsed)}.page-content{flex:1 1;margin-top:64px;margin-top:var(--topbar-height)}.card,.page-content{padding:24px;padding:var(--space-6)}.card{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:10px;border-radius:var(--radius);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;box-shadow:var(--shadow-sm)}.card-header{align-items:center;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;margin-bottom:20px;margin-bottom:var(--space-5);padding-bottom:16px;padding-bottom:var(--space-4)}.card-title{color:#1f2937;color:var(--gray-800);font-size:1rem;font-weight:600}.stat-card{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:10px;border-radius:var(--radius);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;box-shadow:var(--shadow-sm);display:flex;gap:16px;gap:var(--space-4);padding:20px;padding:var(--space-5);transition:box-shadow .2s ease,transform .2s ease;transition:box-shadow var(--transition),transform var(--transition)}.stat-card:hover{box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow);transform:translateY(-2px)}.stat-icon{align-items:center;border-radius:10px;border-radius:var(--radius);display:flex;flex-shrink:0;font-size:1.5rem;height:52px;justify-content:center;width:52px}.stat-info{flex:1 1;min-width:0}.stat-value{color:#111827;color:var(--gray-900);font-size:1.6rem;font-weight:700;line-height:1}.stat-label{color:#6b7280;color:var(--gray-500);font-size:.8rem;letter-spacing:.04em;margin-top:4px;text-transform:uppercase}.stat-change{font-size:.75rem;font-weight:500;margin-top:4px}.stat-change.up{color:#16a34a;color:var(--success)}.stat-change.down{color:#dc2626;color:var(--danger)}.btn{align-items:center;border:1.5px solid #0000;border-radius:6px;border-radius:var(--radius-sm);display:inline-flex;font-size:.875rem;font-weight:500;gap:8px;gap:var(--space-2);padding:9px 18px;transition:all .2s ease;transition:all var(--transition);white-space:nowrap}.btn-primary{background:#1e3a5f;background:var(--primary);color:#fff}.btn-primary:hover{background:#2d5282;background:var(--primary-light)}.btn-accent{background:#f5a623;background:var(--accent);color:#fff}.btn-accent:hover{background:#d97706;background:var(--accent-dark)}.btn-outline{background:#0000;border-color:#1e3a5f;border-color:var(--primary);color:#1e3a5f;color:var(--primary)}.btn-outline:hover{background:#1e3a5f;background:var(--primary);color:#fff}.btn-danger{background:#dc2626;background:var(--danger);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-ghost{background:#0000;color:#4b5563;color:var(--gray-600)}.btn-ghost:hover{background:#f3f4f6;background:var(--gray-100);color:#1f2937;color:var(--gray-800)}.btn-sm{font-size:.8rem;padding:6px 12px}.btn-lg{font-size:1rem;padding:12px 28px}.btn-icon{border-radius:6px;border-radius:var(--radius-sm);padding:8px}.btn:disabled{cursor:not-allowed;opacity:.55}.form-group{margin-bottom:20px;margin-bottom:var(--space-5)}.form-label{color:#374151;color:var(--gray-700);display:block;font-size:.85rem;font-weight:500;margin-bottom:4px;margin-bottom:var(--space-1)}.form-label .required{color:#dc2626;color:var(--danger);margin-left:2px}.form-input,.form-select,.form-textarea{background:#fff;border:1.5px solid #d1d5db;border:1.5px solid var(--gray-300);border-radius:6px;border-radius:var(--radius-sm);color:#1f2937;color:var(--gray-800);font-size:.9rem;outline:none;padding:9px 12px;transition:border-color .2s ease,box-shadow .2s ease;transition:border-color var(--transition),box-shadow var(--transition);width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#1e3a5f;border-color:var(--primary);box-shadow:0 0 0 3px #1e3a5f1a}.form-input.error,.form-select.error{border-color:#dc2626;border-color:var(--danger)}.form-error{color:#dc2626;color:var(--danger)}.form-error,.form-hint{font-size:.78rem;margin-top:4px}.form-hint{color:#9ca3af;color:var(--gray-400)}.form-grid-2{grid-gap:20px;grid-gap:var(--space-5);grid-template-columns:1fr 1fr}.form-grid-2,.form-grid-3{display:grid;gap:20px;gap:var(--space-5)}.form-grid-3{grid-gap:20px;grid-gap:var(--space-5);grid-template-columns:1fr 1fr 1fr}.table-wrapper{border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:10px;border-radius:var(--radius);overflow-x:auto}table{border-collapse:collapse;font-size:.875rem;width:100%}thead{background:#f9fafb;background:var(--gray-50)}thead th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);color:#6b7280;color:var(--gray-500);font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:12px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}tbody tr{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--gray-100);transition:background .2s ease;transition:background var(--transition)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:#f9fafb;background:var(--gray-50)}tbody td{color:#374151;color:var(--gray-700);padding:12px 16px}.badge{align-items:center;border-radius:999px;display:inline-flex;font-size:.72rem;font-weight:600;letter-spacing:.04em;padding:3px 10px;text-transform:uppercase}.badge-success{background:#f0fdf4;background:var(--success-bg);color:#16a34a;color:var(--success)}.badge-danger{background:#fef2f2;background:var(--danger-bg);color:#dc2626;color:var(--danger)}.badge-warning{background:#fffbeb;background:var(--warning-bg);color:#d97706;color:var(--warning)}.badge-info{background:#f0f9ff;background:var(--info-bg);color:#0284c7;color:var(--info)}.badge-gray{background:#f3f4f6;background:var(--gray-100);color:#4b5563;color:var(--gray-600)}.badge-primary{background:#e8f0fe}.avatar,.badge-primary{color:#1e3a5f;color:var(--primary)}.avatar{align-items:center;background:#e5e7eb;background:var(--gray-200);border-radius:50%;display:flex;flex-shrink:0;font-weight:600;justify-content:center;object-fit:cover}.avatar-sm{font-size:.75rem;height:32px;width:32px}.avatar-md{font-size:.9rem;height:40px;width:40px}.avatar-lg{font-size:1.2rem;height:56px;width:56px}.avatar-xl{font-size:1.6rem;height:80px;width:80px}.progress-bar{background:#e5e7eb;background:var(--gray-200);border-radius:999px;height:8px;overflow:hidden}.progress-fill{background:#1e3a5f;background:var(--primary);border-radius:999px;height:100%;transition:width .6s ease}.progress-fill.success{background:#16a34a;background:var(--success)}.progress-fill.warning{background:#d97706;background:var(--warning)}.progress-fill.danger{background:#dc2626;background:var(--danger)}.modal-backdrop{align-items:center;animation:fadeIn .15s ease;background:#00000073;display:flex;inset:0;justify-content:center;padding:16px;padding:var(--space-4);position:fixed;z-index:1000}.modal{animation:slideUp .2s ease;background:#fff;border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 10px 30px #0000001f;box-shadow:var(--shadow-lg);max-height:90vh;max-width:560px;overflow-y:auto;width:100%}.modal-lg{max-width:760px}.modal-xl{max-width:960px}.modal-header{align-items:center;background:#fff;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;padding:20px 24px;padding:var(--space-5) var(--space-6);position:-webkit-sticky;position:sticky;top:0;z-index:1}.modal-body{padding:24px;padding:var(--space-6)}.modal-footer{border-top:1px solid #f3f4f6;border-top:1px solid var(--gray-100);display:flex;gap:12px;gap:var(--space-3);justify-content:flex-end;padding:16px 24px;padding:var(--space-4) var(--space-6)}.spinner{animation:spin .7s linear infinite;border:2.5px solid #e5e7eb;border-top-color:#1e3a5f;border:2.5px solid var(--gray-200);border-radius:50%;border-top-color:var(--primary);display:inline-block;height:20px;width:20px}.spinner-lg{border-width:4px;height:40px;width:40px}.page-loader{gap:16px;gap:var(--space-4);min-height:300px}.empty-state,.page-loader{align-items:center;color:#9ca3af;color:var(--gray-400);display:flex;flex-direction:column;justify-content:center}.empty-state{padding:48px;padding:var(--space-12);text-align:center}.empty-state-icon{font-size:3rem;margin-bottom:16px;margin-bottom:var(--space-4)}.empty-state h3{color:#4b5563;color:var(--gray-600);margin-bottom:8px;margin-bottom:var(--space-2)}.pagination{gap:8px;gap:var(--space-2);margin-top:24px;margin-top:var(--space-6)}.pagination,.pagination-btn{align-items:center;display:flex;justify-content:center}.pagination-btn{border:1.5px solid #e5e7eb;border:1.5px solid var(--gray-200);border-radius:6px;border-radius:var(--radius-sm);color:#4b5563;color:var(--gray-600);cursor:pointer;font-size:.875rem;font-weight:500;height:36px;transition:all .2s ease;transition:all var(--transition);width:36px}.pagination-btn:hover{color:#1e3a5f;color:var(--primary)}.pagination-btn.active,.pagination-btn:hover{border-color:#1e3a5f;border-color:var(--primary)}.pagination-btn.active{background:#1e3a5f;background:var(--primary);color:#fff}.pagination-btn:disabled{cursor:not-allowed;opacity:.4}.tabs{border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--gray-200);display:flex;gap:0;margin-bottom:24px;margin-bottom:var(--space-6)}.tab-btn{border-bottom:2px solid #0000;color:#6b7280;color:var(--gray-500);cursor:pointer;font-size:.875rem;font-weight:500;margin-bottom:-2px;padding:10px 20px;transition:all .2s ease;transition:all var(--transition)}.tab-btn.active{border-bottom-color:#1e3a5f;border-bottom-color:var(--primary);color:#1e3a5f;color:var(--primary)}.tab-btn:hover{color:#1f2937;color:var(--gray-800)}.search-bar{align-items:center;display:flex;position:relative}.search-bar input{border-radius:10px;border-radius:var(--radius);min-width:220px;padding-left:38px}.search-bar .search-icon{color:#9ca3af;color:var(--gray-400);left:10px;pointer-events:none;position:absolute}.page-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;gap:var(--space-4);justify-content:space-between;margin-bottom:24px;margin-bottom:var(--space-6)}.page-header-left h1{color:#111827;color:var(--gray-900);font-size:1.5rem}.page-header-left p{color:#6b7280;color:var(--gray-500);font-size:.875rem;margin-top:2px}.filter-bar,.page-header-actions{align-items:center;display:flex;gap:12px;gap:var(--space-3)}.filter-bar{flex-wrap:wrap;margin-bottom:20px;margin-bottom:var(--space-5)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.fade-in{animation:fadeIn .3s ease}.slide-up{animation:slideUp .3s ease}@media (max-width:768px){.main-content{margin-left:0!important}.page-content{padding:16px;padding:var(--space-4)}.form-grid-2,.form-grid-3{grid-template-columns:1fr}.stat-card .stat-value{font-size:1.3rem}.page-header{align-items:flex-start;flex-direction:column}h1{font-size:1.5rem}.explore-map-grid{grid-template-columns:1fr!important;grid-template-rows:60vh 40vh!important;height:auto!important}}@media (max-width:480px){.page-content{padding:12px;padding:var(--space-3)}.modal{border-radius:10px 10px 0 0;border-radius:var(--radius) var(--radius) 0 0}.modal-backdrop{align-items:flex-end;padding:0}}.flex{display:flex}.flex-center{justify-content:center}.flex-between,.flex-center{align-items:center;display:flex}.flex-between{justify-content:space-between}.flex-col{display:flex;flex-direction:column}.gap-2{gap:8px;gap:var(--space-2)}.gap-3{gap:12px;gap:var(--space-3)}.gap-4{gap:16px;gap:var(--space-4)}.gap-5{gap:20px;gap:var(--space-5)}.mt-4{margin-top:16px;margin-top:var(--space-4)}.mt-5{margin-top:20px;margin-top:var(--space-5)}.mt-6{margin-top:24px;margin-top:var(--space-6)}.mb-4{margin-bottom:16px;margin-bottom:var(--space-4)}.mb-5{margin-bottom:20px;margin-bottom:var(--space-5)}.text-center{text-align:center}.text-right{text-align:right}.text-sm{font-size:.8rem}.text-xs{font-size:.72rem}.text-muted{color:#9ca3af;color:var(--gray-400)}.text-danger{color:#dc2626;color:var(--danger)}.text-success{color:#16a34a;color:var(--success)}.fw-600{font-weight:600}.w-full{width:100%}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grid-2{grid-gap:20px;grid-gap:var(--space-5);grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3{display:grid;gap:20px;gap:var(--space-5)}.grid-3{grid-gap:20px;grid-gap:var(--space-5);grid-template-columns:repeat(3,1fr)}.grid-4{grid-gap:20px;grid-gap:var(--space-5);display:grid;gap:20px;gap:var(--space-5);grid-template-columns:repeat(4,1fr)}@media(max-width:1024px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:560px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}[data-theme=dark]{--gray-50:#111827;--gray-100:#1f2937;--gray-200:#374151;--gray-300:#4b5563;--gray-400:#6b7280;--gray-500:#9ca3af;--gray-600:#d1d5db;--gray-700:#e5e7eb;--gray-800:#f3f4f6;--gray-900:#f9fafb;--success-bg:#052e16;--warning-bg:#1c1400;--danger-bg:#1c0202;--info-bg:#0a1f2e}[data-theme=dark] body{background:#0f172a;color:#e2e8f0}[data-theme=dark] .card{background:#1e293b;border-color:#334155}[data-theme=dark] .form-input,[data-theme=dark] .form-select,[data-theme=dark] .form-textarea{background:#0f172a;border-color:#334155;color:#e2e8f0}[data-theme=dark] .form-input::placeholder,[data-theme=dark] .form-textarea::placeholder{color:#475569}[data-theme=dark] .table-wrapper table thead th{background:#1e293b;border-color:#334155;color:#94a3b8}[data-theme=dark] .table-wrapper table tbody td{border-color:#1e293b;color:#cbd5e1}[data-theme=dark] .table-wrapper table tbody tr:hover{background:#1e293b}[data-theme=dark] .stat-card{background:#1e293b;border-color:#334155}[data-theme=dark] .main-content{background:#0f172a}[data-theme=dark] .modal-overlay .modal,[data-theme=dark] .topbar{background:#1e293b;border-color:#334155}[data-theme=dark] .modal-footer,[data-theme=dark] .modal-header{border-color:#334155}[data-theme=dark] .btn-ghost{color:#cbd5e1}[data-theme=dark] .btn-ghost:hover{background:#334155}.sidebar{background:var(--primary-dark);display:flex;flex-direction:column;height:100vh;left:0;overflow:hidden;position:fixed;top:0;transition:width var(--transition);width:var(--sidebar-width);z-index:200}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-logo{align-items:center;border-bottom:1px solid #ffffff14;display:flex;gap:var(--space-3);min-height:var(--topbar-height);overflow:hidden;padding:var(--space-5) var(--space-4)}.sidebar-logo-img{align-items:center;background:var(--accent);border-radius:var(--radius-sm);color:#fff;display:flex;flex-shrink:0;font-size:1.2rem;font-weight:800;height:38px;justify-content:center;object-fit:cover;width:38px}.sidebar-logo-text{overflow:hidden}.sidebar-logo-name{color:#fff;font-size:.9rem;font-weight:700;line-height:1.2;white-space:nowrap}.sidebar-logo-sub{color:#ffffff73;font-size:.7rem;white-space:nowrap}.sidebar-nav{flex:1 1;overflow-x:hidden;overflow-y:auto;padding:var(--space-3) 0}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:#0000}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.nav-section-label{color:#ffffff4d;font-size:.65rem;font-weight:700;letter-spacing:.08em;overflow:hidden;padding:var(--space-4) var(--space-4) var(--space-2);text-transform:uppercase;white-space:nowrap}.nav-item{align-items:center;border-radius:0;border-radius:var(--radius-sm);color:#ffffffa6;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:var(--space-3);margin:1px var(--space-2);padding:10px var(--space-4);position:relative;text-decoration:none;transition:all var(--transition);white-space:nowrap}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{background:#ffffff1f;color:#fff}.nav-item.active:before{background:var(--accent);border-radius:0 2px 2px 0;bottom:0;content:"";left:0;position:absolute;top:0;width:3px}.nav-item-icon{align-items:center;display:flex;flex-shrink:0;font-size:1.05rem;height:20px;justify-content:center;width:20px}.nav-item-text{flex:1 1;overflow:hidden;text-overflow:ellipsis}.nav-item-badge{background:var(--accent);border-radius:999px;color:#fff;font-size:.65rem;font-weight:700;min-width:18px;padding:2px 6px;text-align:center}.sidebar-footer{border-top:1px solid #ffffff14;padding:var(--space-3) var(--space-2)}.sidebar-user{align-items:center;border-radius:var(--radius-sm);cursor:pointer;display:flex;gap:var(--space-3);overflow:hidden;padding:var(--space-3);transition:background var(--transition)}.sidebar-user:hover{background:#ffffff14}.sidebar-user-info{flex:1 1;overflow:hidden}.sidebar-user-name{color:#fff;font-size:.85rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-role{color:#fff6;font-size:.7rem;text-transform:capitalize}.sidebar-overlay{background:#00000080;display:none;inset:0;position:fixed;z-index:199}@media (max-width:768px){.sidebar{transform:translateX(-100%);transition:transform var(--transition);width:var(--sidebar-width)!important}.sidebar.mobile-open{transform:translateX(0)}.sidebar-overlay.visible{display:block}}.topbar{align-items:center;background:#fff;border-bottom:1px solid var(--gray-200);display:flex;gap:var(--space-4);height:var(--topbar-height);justify-content:space-between;left:var(--sidebar-width);padding:0 var(--space-6);position:fixed;right:0;top:0;transition:left var(--transition);z-index:100}.topbar.collapsed{left:var(--sidebar-collapsed)}@media (max-width:768px){.topbar{left:0;padding:0 var(--space-4)}}.topbar-left{gap:var(--space-4)}.topbar-left,.topbar-right{align-items:center;display:flex}.topbar-right{gap:var(--space-3)}.topbar-menu-btn{border-radius:var(--radius-sm);color:var(--gray-600);padding:6px;transition:background var(--transition)}.topbar-menu-btn:hover{background:var(--gray-100)}.topbar-breadcrumb{align-items:center;color:var(--gray-500);display:flex;font-size:.875rem;gap:var(--space-2)}.topbar-breadcrumb .current{color:var(--gray-800);font-weight:500}.topbar-school-name{color:var(--gray-800);font-size:.875rem;font-weight:600}.topbar-icon-btn{align-items:center;border-radius:var(--radius-sm);color:var(--gray-600);display:flex;font-size:1.1rem;height:36px;justify-content:center;position:relative;transition:background var(--transition);width:36px}.topbar-icon-btn:hover{background:var(--gray-100);color:var(--gray-800)}.topbar-notif-dot{background:var(--danger);border:2px solid #fff;border-radius:50%;height:8px;position:absolute;right:6px;top:6px;width:8px}.topbar-user{align-items:center;border-radius:var(--radius-sm);cursor:pointer;display:flex;gap:var(--space-2);padding:4px var(--space-2);transition:background var(--transition)}.topbar-user:hover{background:var(--gray-100)}.topbar-user-name{color:var(--gray-700);font-size:.875rem;font-weight:500;max-width:120px}.topbar-role-badge{border-radius:999px;font-size:.65rem;font-weight:700;padding:2px 7px;text-transform:uppercase}.badge-accent{background:#fef3e2;color:var(--accent-dark)}.notif-bell-wrapper{position:relative}.notif-dropdown{animation:fadeIn .15s ease;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-width:calc(100vw - 32px);overflow:hidden;position:absolute;right:0;top:calc(100% + 10px);width:360px;z-index:300}.notif-dropdown-header{align-items:center;border-bottom:1px solid var(--gray-100);color:var(--gray-800);display:flex;font-size:.9rem;font-weight:600;justify-content:space-between;padding:var(--space-3) var(--space-4)}.notif-mark-all{color:var(--primary);font-size:.75rem;font-weight:600;transition:color var(--transition)}.notif-mark-all:hover{color:var(--accent-dark)}.notif-dropdown-body{max-height:380px;overflow-y:auto}.notif-empty{align-items:center;color:var(--gray-400);display:flex;flex-direction:column;font-size:.85rem;gap:var(--space-2);justify-content:center;padding:var(--space-8) var(--space-4);text-align:center}.notif-item{align-items:flex-start;border-bottom:1px solid var(--gray-50);cursor:pointer;display:flex;gap:var(--space-3);padding:var(--space-3) var(--space-4);position:relative;transition:background var(--transition)}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--gray-50)}.notif-item.unread{background:var(--info-bg)}.notif-item.unread:hover{background:#e0f2fe}.notif-item-icon{align-items:center;background:var(--gray-100);border-radius:var(--radius-sm);display:flex;flex-shrink:0;font-size:1rem;height:34px;justify-content:center;width:34px}.notif-icon-primary{background:#e8f0fe}.notif-icon-info{background:var(--info-bg)}.notif-icon-success{background:var(--success-bg)}.notif-icon-warning{background:var(--warning-bg)}.notif-icon-danger{background:var(--danger-bg)}.notif-icon-accent{background:#fef3e2}.notif-icon-gray{background:var(--gray-100)}.notif-item-body{flex:1 1;min-width:0}.notif-item-title{color:var(--gray-800);font-size:.82rem;font-weight:600;margin-bottom:2px}.notif-item-message{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--gray-500);display:-webkit-box;font-size:.78rem;line-height:1.5;overflow:hidden}.notif-item-time{color:var(--gray-400);font-size:.7rem;margin-top:4px}.notif-item-dot{background:var(--info);border-radius:50%;flex-shrink:0;height:8px;margin-top:6px;width:8px}.notif-dropdown-footer{border-top:1px solid var(--gray-100);color:var(--primary);cursor:pointer;font-size:.8rem;font-weight:600;padding:var(--space-3) var(--space-4);text-align:center;transition:background var(--transition)}.notif-dropdown-footer:hover{background:var(--gray-50)}@media (max-width:480px){.notif-dropdown{right:-60px;width:calc(100vw - 24px)}}.notif-list-card{overflow:hidden;padding:0}.notif-new-banner{align-items:center;animation:fadeIn .2s ease;background:var(--info-bg);border-radius:var(--radius-sm);color:var(--info);cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:var(--space-2);justify-content:center;margin-bottom:var(--space-4);padding:var(--space-3);transition:background var(--transition)}.notif-new-banner:hover{background:#d3edfc}.notif-page-item{align-items:flex-start;border-bottom:1px solid var(--gray-100);cursor:pointer;display:flex;gap:var(--space-4);padding:var(--space-4);transition:background var(--transition)}.notif-page-item:last-child{border-bottom:none}.notif-page-item:hover{background:var(--gray-50)}.notif-page-item.unread{background:var(--info-bg)}.notif-page-item.unread:hover{background:#e0f2fe}.notif-page-icon{align-items:center;background:var(--gray-100);border-radius:var(--radius-sm);display:flex;flex-shrink:0;font-size:1.2rem;height:42px;justify-content:center;width:42px}.notif-page-body{flex:1 1;min-width:0}.notif-page-title{color:var(--gray-800);font-size:.9rem;font-weight:600}.notif-page-message{color:var(--gray-600);font-size:.85rem;line-height:1.6;margin-top:4px}.notif-page-meta{align-items:center;color:var(--gray-400);display:flex;font-size:.72rem;gap:var(--space-2);margin-top:8px}
/*# sourceMappingURL=main.f5444f43.css.map*/