.notification-bell-container{position:relative;display:inline-block}.notification-bell-btn{position:relative;background:none;border:none;cursor:pointer;padding:.3rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.notification-bell-btn:hover{background-color:#0000000d}.notification-icon{width:18px;height:18px;color:currentColor}.notification-badge{position:absolute;top:-4px;right:-4px;background-color:#ef4444;color:#fff;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;border:1.5px solid white;animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #ef4444b3}50%{box-shadow:0 0 0 6px #ef444400}}.notification-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;width:380px;max-height:500px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;display:flex;flex-direction:column;overflow:hidden;animation:slideDown .2s ease-out}.notification-dropdown{width:90vw;right:50%;transform:translate(50%)}@media(min-width:481px){.notification-dropdown{width:380px;right:0;transform:none}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-header{padding:1rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.notification-header h3{margin:0;font-size:1rem;font-weight:600}.unread-badge{background-color:#fca5a5;color:#7f1d1d;padding:.25rem .75rem;border-radius:12px;font-size:12px;font-weight:500}.notification-list{flex:1;overflow-y:auto;max-height:400px}.notification-list::-webkit-scrollbar{width:6px}.notification-list::-webkit-scrollbar-track{background:#f1f5f9}.notification-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.notification-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}.notification-loading,.notification-empty{padding:2rem 1rem;text-align:center;color:#6b7280;font-size:14px}.notification-error{padding:1rem;background-color:#fee2e2;color:#991b1b;font-size:14px;border-bottom:1px solid #fecaca}.notification-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;border-bottom:1px solid #f3f4f6;transition:background-color .2s ease;background-color:#f9fafb}.notification-item:hover{background-color:#f3f4f6}.notification-item.notification-info{border-left:4px solid #3b82f6}.notification-item.notification-success{border-left:4px solid #10b981}.notification-item.notification-warning{border-left:4px solid #f59e0b}.notification-item.notification-error{border-left:4px solid #ef4444}.notification-content{flex:1;min-width:0}.notification-title{font-weight:600;font-size:14px;color:#1f2937;margin-bottom:.25rem}.notification-message{font-size:13px;color:#6b7280;margin-bottom:.5rem;word-wrap:break-word;overflow-wrap:break-word}.notification-time{font-size:12px;color:#9ca3af}.notification-close{flex-shrink:0;background:none;border:none;cursor:pointer;color:#10b981;font-size:16px;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:color .2s ease;border-radius:4px}.notification-close:hover{color:#059669;background-color:#d1fae5}:root{color:#ffffffde;background-color:#242424}a{font-weight:500;color:#6f42c1;text-decoration:inherit}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#6f42c1}button:focus,button:focus-visible{outline:none}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}button{background-color:#f9f9f9}}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;margin:0;padding:0}.admin-dashboard{display:flex;height:100vh;background:#f5f5f5;position:relative}.sidebar{width:240px;background:#2c3e50;color:#fff;padding:1.1rem .85rem;overflow-y:auto;box-shadow:2px 0 12px #0000001f;flex-shrink:0;z-index:20}.sidebar-header{margin-bottom:1rem;padding-bottom:.85rem;border-bottom:1px solid rgba(255,255,255,.14)}.sidebar h2{font-size:1.05rem;margin-bottom:.35rem;color:#6f42c1}.sidebar-profile{font-size:.78rem;color:#ffffffbf}.sidebar-top{display:flex;justify-content:flex-end;margin-bottom:.85rem}.sidebar nav{display:flex;flex-direction:column;gap:.25rem}.sidebar-nav-group{display:flex;flex-direction:column;gap:.2rem}.sidebar-group-toggle{display:flex!important;align-items:center;justify-content:space-between;width:100%;padding:.55rem .75rem;font-weight:600;font-size:.84rem;text-transform:uppercase;letter-spacing:.02em;color:#ffffffe0}.sidebar-group-toggle.active-group{background:#ffffff1f}.sidebar-group-chevron{font-size:.85rem;transition:transform .2s ease}.sidebar-group-chevron.expanded{transform:rotate(180deg)}.sidebar-submenu{display:flex;flex-direction:column;gap:.2rem;padding-left:.45rem}.sidebar a,.sidebar button{display:block;padding:.6rem .75rem;background:none;border:none;color:#fff;text-decoration:none;cursor:pointer;text-align:left;border-radius:6px;transition:background .2s,color .2s;font-size:.9rem}.sidebar a:hover,.sidebar button:hover{background:#ffffff1a}.sidebar a.active{background:#6f42c1;color:#fff}.sidebar-submenu a{font-size:.88rem}.sidebar-logout{margin-top:1rem;background:#ffffff24!important;color:#fff!important}.main-content{flex:1;padding:1.25rem 1.4rem;overflow-y:auto;min-width:0}.mobile-nav-toggle{display:none;margin-bottom:.85rem;background:#6f42c1;color:#fff;border:none;padding:.48rem .75rem;border-radius:6px;font-size:.85rem}.sidebar-overlay{display:none}.page-header{margin-bottom:1.25rem}.page-header h1{font-size:1.5rem;color:#2c3e50;margin-bottom:.35rem}.page-header p{color:#666;font-size:.9rem}.page-header-with-action{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.refresh-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid #d9d9d9;border-radius:50%;background:#fff;color:#2c3e50;cursor:pointer;padding:0}.refresh-icon-btn:hover:not(:disabled){background:#f8f9fa}.refresh-icon-btn:disabled{opacity:.7;cursor:not-allowed}.refresh-icon{font-size:1rem;line-height:1}.refresh-icon.spinning{animation:spin .8s linear infinite}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:1.25rem}.stat-card{background:#fff;padding:1rem;border-radius:10px;box-shadow:0 2px 4px #0000001a;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 18px #0000001f}.stat-card-clickable{cursor:pointer}.stat-card-clickable:focus-visible{outline:2px solid #6F42C1;outline-offset:2px}.stat-card h3{font-size:.8rem;color:#666;margin-bottom:.35rem;text-transform:uppercase}.stat-card .stat-value{font-size:1.5rem;font-weight:700;color:#2c3e50;margin-bottom:.35rem}.dashboard-state{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;border-radius:10px;margin-bottom:1.25rem;font-size:.9rem}.dashboard-state-loading{background:#f8f9fa;border:1px solid #e9ecef;color:#495057}.dashboard-state-error{background:#fdeaea;border:1px solid #f5c2c7;color:#842029}.stat-card .stat-change{font-size:.75rem;color:#28a745}.stat-card .stat-change.negative{color:#dc3545}.content-card{background:#fff;padding:1.25rem;border-radius:10px;box-shadow:0 2px 4px #0000001a;margin-bottom:1.25rem}.content-card h2{font-size:1.1rem;color:#2c3e50;margin-bottom:.9rem}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:.7rem;text-align:left;border-bottom:1px solid #e0e0e0;font-size:.9rem}.data-table th{background:#f8f9fa;font-weight:600;color:#2c3e50}.data-table tbody tr:hover{background:#f8f9fa}.product-thumbnail{width:44px;height:44px;border-radius:8px;object-fit:cover;display:block;border:1px solid #e5e7eb}.product-thumbnail-placeholder{width:44px;height:44px;border-radius:8px;background:#f1f3f5;border:1px dashed #ced4da;color:#6c757d;font-size:.6rem;display:flex;align-items:center;justify-content:center;text-align:center;padding:.25rem}.action-buttons{display:flex;gap:.35rem}.btn{padding:.4rem .8rem;border-radius:6px;border:none;cursor:pointer;font-size:.85rem;transition:opacity .2s}.btn:hover{opacity:.8}.btn-primary{background:#6f42c1;color:#fff}.btn-secondary{background:#6c757d;color:#fff}.btn-success{background:#28a745;color:#fff}.btn-danger{background:#dc3545;color:#fff}.btn-small{padding:.3rem .65rem;font-size:.8rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.35rem;color:#2c3e50;font-weight:500;font-size:.9rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.6rem;border:1px solid #ddd;border-radius:6px;font-size:.9rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#6f42c1}.status-badge{display:inline-block;padding:.2rem .6rem;border-radius:20px;font-size:.75rem;font-weight:500}.status-badge.active,.status-badge.approved{background:#d4edda;color:#155724}.status-badge.pending{background:#fff3cd;color:#856404}.status-badge.inactive,.status-badge.rejected{background:#f8d7da;color:#721c24}.product-view-modal-overlay{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:1100}.product-view-modal{width:100%;max-width:560px;background:#fff;border-radius:10px;box-shadow:0 16px 36px #0000002e;overflow:hidden}.product-view-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e9ecef}.product-view-modal-header h3{margin:0;font-size:1.1rem;color:#2c3e50}.product-view-modal-close{border:none;background:transparent;color:#6c757d;font-size:1.4rem;line-height:1;padding:0;cursor:pointer}.product-view-modal-body{padding:1rem 1.25rem}.product-view-modal-image{width:100%;max-height:260px;border-radius:8px;object-fit:cover;border:1px solid #e5e7eb;margin-bottom:1rem}.product-view-modal-image-placeholder{width:100%;height:180px;border-radius:8px;background:#f1f3f5;border:1px dashed #ced4da;color:#6c757d;font-size:.9rem;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}.product-view-details-grid{margin:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem 1.25rem}.product-view-details-grid div{min-width:0}.product-view-details-grid dt{margin:0;font-size:.75rem;color:#6c757d;text-transform:uppercase;letter-spacing:.02em}.product-view-details-grid dd{margin:.25rem 0 0;font-size:.92rem;color:#2c3e50;word-break:break-word}.product-view-modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:.9rem 1.25rem 1rem;border-top:1px solid #e9ecef}.status-badge.suspended{background:#f8d7da;color:#721c24}@media(max-width:640px){.product-view-details-grid{grid-template-columns:1fr;gap:.75rem}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:#fff;position:relative}.login-page-logo{position:absolute;top:1.5rem;left:1.5rem;width:180px;height:180px;object-fit:contain}.login-card{background:#fff;padding:3rem;border-radius:15px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px}.login-card h1{font-size:2rem;color:#2c3e50;margin-bottom:2rem;text-align:center}@media(max-width:992px){.admin-dashboard{height:auto;min-height:100vh}.sidebar{position:fixed;top:0;left:0;height:100vh;transform:translate(-100%);transition:transform .25s ease}.sidebar.sidebar-open{transform:translate(0)}.main-content{width:100%;padding:1rem}.mobile-nav-toggle{display:inline-block}.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000059;border:none;z-index:10;cursor:pointer}.page-header-with-action{align-items:center}}@media(prefers-color-scheme:light){.page-header h1,.stat-card .stat-value,.content-card h2{color:#2c3e50}}
