.spinner{display:inline-block;width:18px;height:18px;border:3px solid #ccc;border-top:3px solid #1976d2;border-radius:50%;animation:spin .8s linear infinite;vertical-align:middle}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.heading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;margin:32px auto 24px;padding:32px 24px 24px;border-radius:18px;max-width:600px}.heading-container h1{font-size:2.5rem;font-weight:800;margin:0 0 12px;letter-spacing:-1px;color:#22223b;text-shadow:0 2px 8px rgba(100,100,150,.04);display:flex;align-items:center;gap:10px}.heading-container .main-heading{font-size:1.15rem;color:#555;margin:0;font-weight:400;text-align:center}*{box-sizing:border-box;font-family:system-ui,-apple-system,sans-serif}body{margin:0;background:#f4f5f7;color:#111}.topbar{background:transparent;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;border:none;flex-wrap:wrap;gap:12px}.analytics-btn{background:#7a77d1;color:#fff;font-weight:500;border:none;border-radius:8px;padding:8px 16px;font-size:15px;box-shadow:0 2px 8px #388e3c14;cursor:pointer;transition:background .2s;margin-top:0}.analytics-btn:hover{background:#256029}.logout-btn{background:#e53935;color:#fff;font-weight:500;border:none;border-radius:8px;padding:8px 16px;font-size:15px;box-shadow:0 2px 8px #e5393514;cursor:pointer;transition:background .2s,border .2s;margin-top:0}.logout-btn:hover{background:#b71c1c;border-color:#0d47a1}.topbar-right{display:flex;gap:10px;flex-wrap:wrap}.cart-btn{background:#1976d2;color:#fff;font-weight:500;border:none;border-radius:8px;padding:8px 16px;font-size:15px;cursor:pointer;transition:background .2s}.cart-btn:hover{background:#1565c0}.analytics-modal{background:#f9f9f9;border-radius:16px;padding:24px;max-width:95vw;max-height:90vh;overflow-y:auto;margin:20px;box-shadow:0 4px 24px #0000001a;position:relative}.analytics-modal .modal-close{position:absolute;top:16px;right:16px;font-size:24px;background:none;border:none;cursor:pointer;z-index:10}.cart-modal{max-width:500px;margin:0 auto 20px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;padding:20px}.cart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.cart-header h3{margin:0;font-size:18px}.cart-close{background:none;border:none;font-size:20px;cursor:pointer;color:#6b7280;padding:4px 8px}.cart-close:hover{color:#111}.cart-items{display:flex;flex-direction:column;gap:12px}.cart-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f9fafb;border-radius:8px}.cart-item-info{flex:1;cursor:pointer}.cart-item-info:hover{opacity:.8}.cart-item-title{font-weight:500;font-size:14px}.cart-item-price{color:#2e7d32;font-weight:700}.cart-item-remove{background:none;border:none;color:#dc2626;font-size:16px;cursor:pointer;padding:4px 8px;margin-left:12px}.cart-item-remove:hover{background:#fee2e2;border-radius:4px}.cart-footer{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;border-top:1px solid #e5e7eb}.cart-total{font-size:16px}.cart-total strong{color:#2e7d32;font-size:18px}.cart-clear-btn{background:#dc2626;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-weight:500;cursor:pointer}.cart-clear-btn:hover{background:#b91c1c}.filters-bar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.filters-bar select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:14px;cursor:pointer}.filters-bar select:focus{outline:none;border-color:#6366f1}.price-input{width:80px;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.price-input:focus{outline:none;border-color:#6366f1}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px;padding-top:16px;border-top:1px solid #e5e7eb}.pagination button{padding:8px 16px;border:1px solid #d1d5db;background:#fff;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s}.pagination button:hover:not(:disabled){background:#6366f1;color:#fff;border-color:#6366f1}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination span{font-size:14px;color:#6b7280}.toast{position:fixed;top:20px;left:50%;transform:translate(-50%);padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;z-index:1000;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.toast-error{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}.toast-success{background:#dcfce7;color:#16a34a;border:1px solid #bbf7d0}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:flex-start;overflow-y:auto;padding:20px 0;z-index:1000}.product-modal{background:#fff;border-radius:12px;padding:24px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;position:relative}.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:20px;cursor:pointer;color:#6b7280}.modal-close:hover{color:#111}.product-modal h2{margin:0 0 12px;font-size:20px;padding-right:30px}.modal-price{font-size:24px;font-weight:700;color:#2e7d32;margin-bottom:12px}.modal-meta{display:flex;gap:16px;margin-bottom:16px;flex-wrap:wrap}.modal-category{background:#e0e7ff;color:#4338ca;padding:4px 10px;border-radius:4px;font-size:13px;font-weight:500}.modal-rating,.modal-popularity{font-size:14px;color:#6b7280}.modal-description{color:#374151;line-height:1.6;margin-bottom:20px}.modal-actions{display:flex;gap:12px}.modal-add-btn{flex:1;padding:12px;background:#6366f1;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.modal-add-btn:hover{background:#4f46e5}.auth-page{min-height:100vh;background:#f4f5f7;display:flex;flex-direction:column;align-items:center;padding-top:120px}.auth-heading{font-size:28px;font-weight:700;margin-bottom:24px;color:#111827}.auth-card{width:420px;background:#fff;padding:28px 32px;border-radius:12px;box-shadow:0 8px 24px #00000014}.auth-card h2{text-align:center;margin-bottom:20px;font-size:20px}.auth-card form{display:flex;flex-direction:column;gap:14px}.auth-card input{padding:12px 14px;font-size:14px;border-radius:8px;border:1px solid #d1d5db;outline:none}.auth-card input:focus{border-color:#6366f1;box-shadow:0 0 0 1px #6366f1}.auth-card button{margin-top:6px;padding:12px;border:none;border-radius:8px;background:#6366f1;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s}.auth-card button:hover{background:#4f46e5}.auth-error{font-size:13px;color:#dc2626;margin-top:4px;text-align:center}.auth-success{font-size:13px;color:#16a34a;margin-top:4px;text-align:center;padding:12px;background:#dcfce7;border-radius:6px}.auth-description{font-size:14px;color:#6b7280;text-align:center;margin-bottom:16px}.auth-loading{text-align:center;color:#6b7280;padding:20px}.forgot-password{margin-top:12px;font-size:14px;text-align:center}.forgot-password span{color:#6366f1;cursor:pointer}.forgot-password span:hover{text-decoration:underline}.auth-toggle{margin-top:16px;font-size:14px;text-align:center;color:#6b7280}.auth-toggle span{color:#6366f1;font-weight:600;cursor:pointer}.auth-toggle span:hover{text-decoration:underline}.search-bar{display:flex;gap:10px;margin-bottom:20px}.search-bar input{flex:1;padding:10px;border:1px solid #d1d5db;border-radius:6px}.search-bar button{padding:10px 16px;border:none;background:#6366f1;color:#fff;border-radius:6px;cursor:pointer}.empty{text-align:center;color:#6b7280;margin-bottom:20px}.loading{text-align:center;color:#6366f1;padding:20px;font-weight:500}button:disabled{opacity:.7;cursor:not-allowed}input:disabled{background:#f3f4f6;cursor:not-allowed}section{margin-bottom:30px}section h3{margin-bottom:14px;font-size:18px}.container{max-width:1200px;margin:0 auto}.container .products{padding:24px;border-radius:12px;background:#fff;box-shadow:0 2px 16px #0000000f}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}.product-card{background:#fff;border-radius:10px;padding:16px;box-shadow:0 4px 14px #00000014;display:flex;flex-direction:column}.pc-title{font-weight:600;font-size:15px;margin-bottom:6px}.pc-price{color:#2e7d32;font-weight:700;font-size:18px;margin-bottom:6px}.pc-meta{font-size:13px;color:#6b7280;margin-bottom:14px}.pc-btn{margin-top:auto;padding:10px;border:none;border-radius:6px;background:#9fa1e8;color:#fff;font-weight:600;cursor:pointer}.pc-btn:disabled{background:#43a047;color:#fff;cursor:not-allowed;transition:background .2s}.quantity-controls{display:flex;align-items:center;justify-content:center;gap:10px;padding:8px}.qty-btn{width:32px;height:32px;border-radius:50%;border:2px solid #4CAF50;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.qty-btn-decrement{background:#fff;color:#4caf50}.qty-btn-increment{background:#4caf50;color:#fff}.qty-value{font-size:16px;font-weight:700;min-width:30px;text-align:center}@media(max-width:768px){.topbar{padding:16px;flex-wrap:wrap;gap:12px}.topbar-right{flex-wrap:wrap;gap:8px}.heading-container{max-width:100%;margin:16px 12px;padding:20px 16px}.heading-container h1{font-size:1.8rem}.heading-container .main-heading{font-size:1rem}.container{padding:0 12px}.container .products{padding:16px}.search-bar{flex-direction:column}.search-bar button{width:100%}.filters-bar{gap:8px}.filters-bar select,.price-input{flex:1;min-width:100px}.grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.cart-modal{max-width:100%;margin:0 12px 16px;padding:16px}.auth-card{width:100%;max-width:380px;margin:0 16px;padding:24px 20px}.auth-page{padding-top:60px;padding-left:16px;padding-right:16px}.product-modal{width:95%;padding:20px;max-height:90vh}.analytics-modal{margin:10px;padding:16px;max-height:95vh}.modal-actions{flex-direction:column}.pagination{flex-wrap:wrap;gap:10px}.pagination button{padding:8px 12px;font-size:13px}}@media(max-width:480px){.topbar{padding:12px}.analytics-btn,.logout-btn,.cart-btn{padding:6px 12px;font-size:13px}.heading-container h1{font-size:1.4rem}.heading-container .main-heading{font-size:.9rem}.grid{grid-template-columns:1fr;gap:12px}.product-card{padding:14px}.pc-title{font-size:14px}.pc-price{font-size:16px}.cart-item{flex-direction:column;align-items:flex-start;gap:8px}.cart-item-remove{margin-left:0}.cart-footer{flex-direction:column;gap:12px;align-items:stretch}.cart-clear-btn{width:100%}.auth-heading{font-size:22px}.auth-card{padding:20px 16px}.filters-bar{flex-direction:column}.filters-bar select,.price-input{width:100%}.toast{width:90%;padding:10px 16px;font-size:13px}}.admin-toggle-btn{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);border:none;font-size:24px;cursor:pointer;box-shadow:0 4px 12px #667eea66;transition:all .3s ease;z-index:999;display:flex;align-items:center;justify-content:center}.admin-toggle-btn:hover{transform:scale(1.1);box-shadow:0 6px 20px #667eea99}.admin-toggle-btn:active{transform:scale(.95)}.admin-cache-modal{background:#fff;border-radius:16px;width:90%;max-width:600px;max-height:85vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.admin-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e5e7eb;position:sticky;top:0;background:#fff;z-index:10}.admin-modal-header h2{margin:0;font-size:20px;color:#111827;font-weight:600}.admin-info-section{padding:20px 24px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.admin-label{margin:0 0 8px;font-size:13px;color:#6b7280;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.admin-user-info{display:flex;flex-direction:column;gap:4px}.admin-username{font-size:16px;font-weight:600;color:#111827}.admin-email{font-size:14px;color:#6b7280}.cache-stats-section{padding:24px;border-bottom:1px solid #e5e7eb}.stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.stats-header h3{margin:0;font-size:16px;color:#111827;font-weight:600}.health-indicator{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:8px;font-size:13px;font-weight:500}.health-indicator.healthy{background:#dcfce7;color:#166534}.health-indicator.warning{background:#fef3c7;color:#92400e}.health-dot{display:inline-block;width:8px;height:8px;border-radius:50%;animation:pulse 2s infinite}.health-indicator.healthy .health-dot{background:#22c55e}.health-indicator.warning .health-dot{background:#f59e0b}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:16px}.stat-card{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);padding:16px;border-radius:12px;text-align:center;border:1px solid #d1d5db;transition:all .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.stat-value{font-size:28px;font-weight:700;margin-bottom:4px}.stat-value.hits{color:#059669}.stat-value.misses{color:#dc2626}.stat-value.hitrate{color:#2563eb}.stat-value.invalidations{color:#ea580c}.stat-label{font-size:12px;color:#6b7280;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.last-updated{font-size:12px;color:#9ca3af;text-align:right}.cache-actions-section{padding:24px;border-bottom:1px solid #e5e7eb}.cache-actions-section h3{margin:0 0 16px;font-size:16px;color:#111827;font-weight:600}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.action-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 12px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;cursor:pointer;transition:all .2s ease;font-size:13px;font-weight:500;color:#374151}.action-btn:hover:not(:disabled){border-color:#d1d5db;background:#f9fafb;transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.action-btn:disabled{opacity:.6;cursor:not-allowed}.action-icon{font-size:20px}.action-btn.invalidate-search{color:#b45309;border-color:#fcd34d;background:#fffbeb}.action-btn.invalidate-search:hover:not(:disabled){background:#fef3c7;border-color:#fbbf24}.action-btn.invalidate-recs{color:#7c3aed;border-color:#e9d5ff;background:#faf5ff}.action-btn.invalidate-recs:hover:not(:disabled){background:#f3e8ff;border-color:#d8b4fe}.action-btn.invalidate-all{color:#dc2626;border-color:#fecaca;background:#fef2f2}.action-btn.invalidate-all:hover:not(:disabled){background:#fee2e2;border-color:#fca5a5}.action-btn.refresh{color:#0891b2;border-color:#a5f3fc;background:#ecfdf5}.action-btn.refresh:hover:not(:disabled){background:#cffafe;border-color:#67e8f9}.action-btn.reset{color:#4b5563;border-color:#d1d5db;background:#f3f4f6}.action-btn.reset:hover:not(:disabled){background:#e5e7eb;border-color:#9ca3af}.admin-modal-footer{padding:16px 24px;background:#f9fafb;border-top:1px solid #e5e7eb;border-radius:0 0 16px 16px}.footer-text{margin:0;font-size:12px;color:#6b7280;font-style:italic}@media(max-width:640px){.admin-toggle-btn{width:48px;height:48px;font-size:20px;bottom:16px;right:16px}.admin-cache-modal{width:95%;max-height:90vh}.admin-modal-header{padding:16px}.admin-modal-header h2{font-size:18px}.stats-grid{grid-template-columns:repeat(2,1fr)}.actions-grid{grid-template-columns:1fr}.action-btn{flex-direction:row;justify-content:flex-start;gap:12px;padding:12px}.admin-info-section,.cache-stats-section,.cache-actions-section{padding:16px}}
