:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;background:#fff}h1{font-size:3.2em;line-height:1.1}@media (prefers-color-scheme: light){a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-page{min-height:100vh;width:100vw;display:grid;place-items:center;background:#fff}.login-card{width:520px;background:#fff;border-radius:16px;box-shadow:0 20px 60px #1018281f,0 4px 10px #1018280a;padding:32px}.login-title{margin:0 0 20px;color:#0b3b2e;font-size:32px;font-weight:800;letter-spacing:.2px}.login-form{display:flex;flex-direction:column;gap:16px}.login-label span{display:block;margin-bottom:8px;color:#1f2937;font-size:14px;font-weight:600}.login-input{width:100%;box-sizing:border-box;height:48px;padding:10px 14px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;color:#111827;outline:none;transition:box-shadow .16s ease,border-color .16s ease}.login-input:focus{border-color:#7c3aed;box-shadow:0 0 0 4px #7c3aed33}.login-button{margin-top:8px;height:52px;border:none;border-radius:12px;color:#fff;font-size:16px;font-weight:700;cursor:pointer;background:linear-gradient(90deg,#16a34a,#0ea5e9);box-shadow:0 10px 20px #22c55e40}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-error{color:#dc2626;font-size:14px;font-weight:600}.login-success{background-color:#d4edda;color:#155724;padding:12px;border-radius:4px;margin-bottom:16px;border:1px solid #c3e6cb;text-align:center}.login-back-button{background-color:#6c757d;color:#fff;border:none;padding:12px 24px;border-radius:4px;cursor:pointer;font-size:16px;width:100%;margin-top:16px;transition:background-color .3s}.login-back-button:hover{background-color:#5a6268}.login-back-button:disabled{background-color:#6c757d;opacity:.6;cursor:not-allowed}.signup-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.signup-card{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000001a;padding:40px;width:100%;max-width:450px;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.signup-header{text-align:center;margin-bottom:30px}.signup-header h1{color:#333;font-size:28px;font-weight:600;margin-bottom:10px}.signup-header p{color:#666;font-size:16px;line-height:1.5}.message{padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px;text-align:center}.message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.signup-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:500;color:#333;margin-bottom:8px;font-size:14px}.form-group input{padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;transition:border-color .3s ease;background-color:#fafbfc}.form-group input:focus{outline:none;border-color:#667eea;background-color:#fff}.form-group input.error{border-color:#dc3545;background-color:#fff5f5}.form-group input::placeholder{color:#999}.error-text{color:#dc3545;font-size:12px;margin-top:5px;font-weight:500}.signup-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:14px 20px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px}.signup-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea4d}.signup-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.signup-footer{text-align:center;margin-top:25px;padding-top:20px;border-top:1px solid #e1e5e9}.signup-footer p{color:#666;font-size:13px;line-height:1.4}@media (max-width: 480px){.signup-card{padding:30px 20px;margin:10px}.signup-header h1{font-size:24px}.signup-header p{font-size:14px}.form-group input{padding:10px 14px;font-size:15px}.signup-btn{padding:12px 18px;font-size:15px}}.dashboard-sidebar{width:250px;background:#fff;border-right:1px solid #eef0f4;padding:20px 0;height:100vh;overflow-y:auto;position:relative;z-index:1000;display:flex;flex-direction:column}.sidebar-section{padding:0 20px;margin-bottom:20px}.sidebar-section-title{margin:12px 0 8px 8px;color:#6b7280;font-size:12px;text-transform:uppercase;font-weight:600;letter-spacing:.5px}.sidebar-item{display:flex;align-items:center;padding:12px 16px;margin:4px 0;border-radius:8px;cursor:pointer;transition:all .2s ease;color:#111827;font-weight:500;font-size:14px;text-decoration:none}.sidebar-item:hover{background-color:#f0fdf4;color:#065f46}.sidebar-item.active{background-color:#f0fdf4;color:#065f46;font-weight:600}.sidebar-item.active:hover{background-color:#f0fdf4}.sidebar-icon{margin-right:12px;font-size:16px;width:20px;text-align:center}.sidebar-badge{margin-left:auto;font-size:11px;padding:2px 6px;border-radius:999px;font-weight:500}.sidebar-badge.new{background:#ecfeff;color:#0284c7}.sidebar-badge.coming-soon{background:#fff7ed;color:#c2410c}.sidebar-logout-section{margin-top:auto;padding:20px;border-top:1px solid #eef0f4}.logout-btn{width:100%;background:#fee2e2;color:#991b1b;border:none;padding:12px 16px;border-radius:8px;cursor:pointer;font-weight:500;font-size:14px;transition:all .2s ease}.logout-btn:hover{background:#fecaca;color:#7f1d1d}@media (max-width: 768px){.dashboard-sidebar{width:200px;padding:15px 0}.sidebar-section{padding:0 15px}.sidebar-item{padding:10px 12px;font-size:13px}.sidebar-icon{margin-right:10px;font-size:14px}}@media (max-width: 480px){.dashboard-sidebar{width:180px;padding:10px 0}.sidebar-section{padding:0 10px}.sidebar-item{padding:8px 10px;font-size:12px}.sidebar-icon{margin-right:8px;font-size:12px}}.products-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.products-header h2{margin:0}.products-panel{background:#fff;border:1px solid #eef0f4;border-radius:12px;padding:16px}.toolbar{display:flex;gap:12px;margin-bottom:12px}.table-wrap{overflow:auto}.products-table{width:100%;border-collapse:collapse}.products-table th,.products-table td{text-align:left;padding:10px;border-bottom:1px solid #eef0f4}.products-table th{color:#6b7280;font-weight:600}.prod{display:flex;align-items:center;gap:10px}.prod img{width:40px;height:40px;border-radius:8px;object-fit:cover}.prod-name{font-weight:600}.prod-sku{color:#6b7280;font-size:12px}.badge{padding:4px 8px;border-radius:999px;font-size:12px}.badge-active{background:#ecfdf5;color:#065f46}.badge-muted{background:#f3f4f6;color:#374151}.ghost{border:none;background:transparent;cursor:pointer;font-size:18px}.search{padding:8px 12px;border:1px solid #e5e7eb;border-radius:6px;font-size:14px;width:300px}.status-filter{padding:8px 12px;border:1px solid #e5e7eb;border-radius:6px;font-size:14px;background:#fff}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#6b7280}.loading-spinner{width:32px;height:32px;border:3px solid #f3f4f6;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.price-info{display:flex;flex-direction:column;gap:2px}.regular-price{font-weight:600;color:#374151}.sale-price{font-size:12px;color:#ef4444;text-decoration:line-through}.action-buttons{display:flex;gap:8px;align-items:center}.edit-btn,.status-btn,.delete-btn{padding:4px 8px;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.edit-btn{background:#3b82f6;color:#fff}.edit-btn:hover{background:#2563eb}.activate-btn{background:#10b981;color:#fff}.activate-btn:hover{background:#059669}.deactivate-btn{background:#ef4444;color:#fff}.deactivate-btn:hover{background:#dc2626}.delete-btn{background:#6b7280;color:#fff}.delete-btn:hover{background:#4b5563}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1rem;padding:1rem 0}.pagination-btn{padding:8px 16px;border:1px solid #e5e7eb;background:#fff;border-radius:6px;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db}.pagination-info{color:#6b7280;font-size:14px}@media (max-width: 768px){.toolbar{flex-direction:column}.search{width:100%}.action-buttons{flex-direction:column;gap:4px}.edit-btn,.status-btn,.delete-btn{font-size:10px;padding:2px 6px}}.dashboard{background:#f6f7fb;min-height:100vh}.dashboard-layout{display:grid;grid-template-columns:250px 1fr;min-height:100vh}.dashboard-main{padding:20px 24px;margin-left:0}.welcome-banner{display:grid;grid-template-columns:1fr auto;gap:20px;background:#fff;border:1px solid #eef0f4;border-radius:12px;padding:20px;margin-bottom:16px}.welcome-content h1{margin:0 0 6px}.welcome-content p{margin:0 0 10px;color:#6b7280}.create-product-btn{display:inline-block;height:40px;padding:0 14px;border-radius:10px;border:none;color:#fff;background:linear-gradient(90deg,#16a34a,#0ea5e9);cursor:pointer}.welcome-image img{width:200px;height:120px;object-fit:cover;border-radius:10px}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.stat-card{background:#fff;border:1px solid #eef0f4;border-radius:12px;padding:16px;display:flex;gap:12px;align-items:center}.stat-icon{width:44px;height:44px;display:grid;place-items:center;border-radius:10px}.stat-icon.earnings{background:#ecfdf5;color:#065f46}.stat-icon.orders{background:#eff6ff;color:#1d4ed8}.stat-icon.customers{background:#f5f3ff;color:#6d28d9}.stat-content h3{margin:0;font-size:14px;color:#6b7280}.stat-value{font-size:22px;font-weight:800}.stat-subtitle{color:#6b7280;font-size:12px}.charts-section{display:grid;grid-template-columns:2fr 1fr;gap:12px;margin-top:12px}.revenue-chart,.total-sales-chart{background:#fff;border:1px solid #eef0f4;border-radius:12px;padding:16px}.chart-header{display:flex;gap:12px;align-items:baseline}.year-select{margin-left:auto;border:1px solid #e5e7eb;border-radius:8px;padding:4px 8px}.chart-legend{display:flex;gap:12px;margin-bottom:8px}.legend-item{display:flex;align-items:center;gap:6px;color:#6b7280;font-size:12px}.legend-color{width:10px;height:10px;border-radius:999px;display:inline-block}.legend-color.total-income{background:#198754}.legend-color.total-expense{background:#ffc107}.chart-area{margin-top:8px}.chart-labels{display:grid;grid-template-columns:repeat(7,1fr);color:#6b7280;font-size:12px;margin-top:6px}.donut-chart{display:grid;place-items:center}.donut-svg text{fill:#111827;font-weight:700}.donut-title{font-size:12px}.donut-value{font-size:18px}.sales-breakdown{margin-top:10px;display:grid;gap:6px}.breakdown-item{display:flex;align-items:center;gap:8px;color:#6b7280;font-size:14px}.breakdown-color{width:10px;height:10px;border-radius:2px;display:inline-block}.breakdown-color.shipping{background:#22c55e}.breakdown-color.refunds{background:#f97316}.breakdown-color.order{background:#ef4444}.breakdown-color.income{background:#0ea5e9}.sales-overview{margin-top:12px;background:#fff;border:1px solid #eef0f4;border-radius:12px;padding:16px}.overview-bars{display:grid;gap:10px}.overview-item{display:grid;grid-template-columns:140px 1fr auto;align-items:center;gap:12px}.overview-label{color:#6b7280;font-size:14px}.progress-bar{height:8px;background:#eef2f7;border-radius:6px;overflow:hidden}.progress-fill{height:100%;border-radius:6px}.progress-fill.profit{background:#16a34a}.progress-fill.income{background:#0ea5e9}.progress-fill.expenses{background:#ef4444}.overview-value{color:#6b7280;font-size:14px}.notifications-section{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}.notification-card{background:#fff;border:1px solid #eef0f4;border-radius:12px;padding:14px;display:flex;gap:10px;align-items:center}.notif-icon{font-size:18px}.recent-orders{margin-top:12px;background:#fff;border:1px solid #eef0f4;border-radius:12px;padding:16px}.orders-table table{width:100%;border-collapse:collapse}.orders-table th,.orders-table td{text-align:left;padding:10px;border-bottom:1px solid #eef0f4}.orders-table th{color:#6b7280;font-weight:600}.status{padding:6px 10px;border-radius:999px;font-size:12px}.status-shipped{background:#ecfdf5;color:#065f46}.status-pending{background:#fffbeb;color:#92400e}.status-cancel{background:#fef2f2;color:#991b1b}.status-processing{background:#eef2ff;color:#3730a3}.status-active{background:#f0fdf4;color:#166534}.status-inactive{background:#fef2f2;color:#991b1b}.loading-state,.error-state,.empty-state{text-align:center;padding:40px 20px;color:#6b7280}.loading-spinner{width:32px;height:32px;border:3px solid #e5e7eb;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.retry-btn,.link-btn{background:#3b82f6;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;margin-top:8px}.retry-btn:hover,.link-btn:hover{background:#2563eb}.link-btn{background:transparent;color:#3b82f6;text-decoration:underline;padding:0;margin:0}.product-info{display:flex;align-items:center;gap:12px}.product-thumb{width:40px;height:40px;object-fit:cover;border-radius:6px;border:1px solid #e5e7eb}.product-name{font-weight:500;color:#111827}.stat-icon.products{background:#dbeafe;color:#1d4ed8}.stat-icon.active{background:#dcfce7;color:#166534}.stat-icon.suppliers{background:#fef3c7;color:#d97706}.stat-icon.categories{background:#e0e7ff;color:#7c3aed}.required-asterisk{color:#dc2626!important;font-weight:700!important}.field-hint{font-size:12px;color:#6b7280;margin-top:4px;font-style:italic}.existing-images-section{margin-bottom:1.5rem}.existing-images-section h5{margin:0 0 .75rem;color:#374151;font-size:14px;font-weight:600}.new-images-section{margin-top:1.5rem}.new-images-section h5{margin:0 0 .75rem;color:#374151;font-size:14px;font-weight:600}.add-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.add-head h2{margin:0}.secondary{height:36px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;padding:0 12px;cursor:pointer}.add-grid{display:grid;grid-template-columns:2fr 1fr;gap:12px}.panel{background:#fff;border:1px solid #eef0f4;border-radius:12px;padding:16px}.section-title{margin-top:0}.form-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}.field{display:grid;gap:8px}.field label{color:#374151;font-weight:500;font-size:14px}.field label .required-asterisk{color:#dc2626;font-weight:700}.field input,.field select{height:44px;border:2px solid #e5e7eb;border-radius:10px;padding:0 16px;font-size:14px;color:#374151;background:#fff;transition:all .2s ease;box-sizing:border-box}.field input:focus,.field select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;background:#fafbfc}.field input:hover,.field select:hover{border-color:#d1d5db;background:#f9fafb}.field input::placeholder{color:#9ca3af}.upload-block h4,.desc-block h4{margin:0 0 8px}.upload-block h4 .required-asterisk{color:#dc2626;font-weight:700}.dropzone{display:grid;place-items:center;height:160px;border:2px dashed #e5e7eb;border-radius:12px;color:#6b7280}.dropicon{font-size:22px;margin-bottom:6px}.side-panel .side-group{margin-bottom:20px}.side-panel .side-group h4{margin:0 0 12px;color:#374151;font-weight:600;font-size:14px}.side-panel label{display:block;margin:8px 0 6px;color:#374151;font-weight:500;font-size:13px}.side-panel label .required-asterisk{color:#dc2626;font-weight:700}.radio{display:flex;gap:8px;align-items:center}.side-panel input,.side-panel textarea{width:100%;border:2px solid #e5e7eb;border-radius:8px;padding:12px 16px;font-size:14px;color:#374151;background:#fff;transition:all .2s ease;box-sizing:border-box;margin-bottom:8px}.side-panel input{height:44px}.side-panel textarea{min-height:80px;resize:vertical;line-height:1.5}.side-panel input:focus,.side-panel textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;background:#fafbfc}.side-panel input:hover,.side-panel textarea:hover{border-color:#d1d5db;background:#f9fafb}.side-panel input::placeholder,.side-panel textarea::placeholder{color:#9ca3af}.row.between{display:flex;justify-content:flex-end}.toggle{display:flex;align-items:center;gap:8px;margin-bottom:8px}.toggle input[type=checkbox]{width:18px;height:18px;accent-color:#3b82f6;cursor:pointer}.toggle label{margin:0;cursor:pointer;font-weight:500}.radio input[type=radio]{width:16px;height:16px;accent-color:#3b82f6;cursor:pointer}.radio label{margin:0;cursor:pointer;font-weight:500}.primary{height:40px;border:none;border-radius:10px;padding:0 14px;color:#fff;background:linear-gradient(90deg,#16a34a,#0ea5e9);cursor:pointer}.primary.wide{width:100%}.primary:disabled{opacity:.6;cursor:not-allowed}.alert{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-weight:500}.alert-error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.alert-success{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.image-upload-area{margin-bottom:16px}.dropzone{display:grid;place-items:center;height:160px;border:2px dashed #e5e7eb;border-radius:12px;color:#6b7280;cursor:pointer;transition:all .2s}.dropzone:hover{border-color:#3b82f6;background:#f8fafc}.upload-hint{font-size:12px;color:#9ca3af;margin-top:4px}.desc-block{margin-bottom:24px}.desc-block h4{margin:0 0 12px;color:#374151;font-weight:600;font-size:14px}.desc-block h4 .required-asterisk{color:#dc2626;font-weight:700}.desc-block textarea{width:100%;min-height:120px;padding:16px;border:2px solid #e5e7eb;border-radius:12px;font-family:inherit;font-size:14px;line-height:1.5;color:#374151;background:#fff;resize:vertical;transition:all .2s ease;box-sizing:border-box}.desc-block textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;background:#fafbfc}.desc-block textarea::placeholder{color:#9ca3af;font-style:italic}.desc-block textarea:hover{border-color:#d1d5db;background:#f9fafb}.url-upload-section{margin-top:20px;padding:16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px}.url-upload-section h5{margin:0 0 12px;color:#374151;font-size:14px;font-weight:600}.url-input-group{display:flex;gap:8px;align-items:center}.url-input{flex:1;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;color:#374151;background:#fff;transition:all .2s ease}.url-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.url-input::placeholder{color:#9ca3af}.add-url-btn{padding:10px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.add-url-btn:hover:not(:disabled){background:#2563eb}.add-url-btn:disabled{background:#9ca3af;cursor:not-allowed}.image-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;margin-top:16px}.image-preview-item{position:relative;border-radius:8px;overflow:hidden}.preview-image{width:100%;height:120px;object-fit:cover;border-radius:8px}.remove-image-btn{position:absolute;top:4px;right:4px;background:#dc2626;color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center}.remove-image-btn:hover{background:#b91c1c}.banners-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.banners-header h2{margin:0}.banner-image{display:flex;align-items:center}.banner-image img{width:64px;height:64px;object-fit:cover;border-radius:8px;border:1px solid #e9ecef}.action-buttons{display:flex;gap:8px}.banner-card .action-buttons{display:flex;justify-content:space-between;align-items:center;gap:0;margin-top:6px;width:100%}.banner-card .edit-btn,.banner-card .delete-btn{flex-shrink:0}.edit-btn,.delete-btn{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s ease}.edit-btn{background-color:#0d6efd;color:#fff}.edit-btn:hover{background-color:#0b5ed7}.delete-btn{background-color:#dc3545;color:#fff}.delete-btn:hover{background-color:#bb2d3b}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px;padding:16px 0}.page-numbers{display:flex;gap:8px}.pagination-btn{padding:8px 12px;border:1px solid #dee2e6;background-color:#fff;color:#6c757d;cursor:pointer;border-radius:4px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background-color:#e9ecef;border-color:#adb5bd}.pagination-btn.active{background-color:#0d6efd;border-color:#0d6efd;color:#fff}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background-color:#fff;padding:24px;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-width:400px;width:90%}.modal h3{margin:0 0 16px;color:#212529}.modal p{margin:0 0 24px;color:#6c757d;line-height:1.5}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.cancel-btn,.delete-confirm-btn{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s ease}.delete-confirm-btn{background-color:#dc3545;color:#fff}.delete-confirm-btn:hover{background-color:#bb2d3b}.banner-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-top:20px}.banner-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;overflow:hidden;box-shadow:0 1px 2px #0000000a;display:flex;flex-direction:column}.banner-card-image{position:relative;width:100%;padding-top:56.25%;background:#f8f9fa}.banner-card-image img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.status-badge{position:absolute;top:12px;left:12px}.banner-card-content{padding:14px 14px 16px;display:flex;flex-direction:column;gap:10px}.banner-title{margin:0;font-size:16px;text-align:center;color:#212529}.banner-subtitle{margin:0;font-size:13px;line-height:1.4;color:#6c757d;text-align:center}@media (max-width: 768px){.action-buttons{flex-direction:column;gap:4px}.edit-btn,.delete-btn{padding:4px 8px;font-size:11px}.pagination{flex-direction:column;gap:12px}.page-numbers{order:-1}}.add-banner-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.add-banner-form{background-color:#fff;padding:24px;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-width:600px}.image-source-toggle{display:flex;gap:8px;margin-bottom:16px}.toggle-btn{padding:8px 16px;border:2px solid #e9ecef;background:#fff;color:#6c757d;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;flex:1}.toggle-btn:hover{border-color:#0d6efd;color:#0d6efd}.toggle-btn.active{background:#0d6efd;color:#fff;border-color:#0d6efd}.url-input-container{margin-bottom:16px}.url-input-container .form-input{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:4px;font-size:14px;transition:border-color .2s ease}.url-input-container .form-input:focus{outline:none;border-color:#0d6efd;box-shadow:0 0 0 2px #0d6efd40}.file-upload-container{margin-bottom:16px}.upload-notice{background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;padding:12px;margin-bottom:16px;text-align:center}.upload-notice p{margin:0 0 8px;color:#856404;font-size:14px;line-height:1.4}.upload-notice p:last-child{margin-bottom:0;font-size:13px;color:#6c757d}.file-input{width:100%;padding:10px 12px;border:2px dashed #ced4da;border-radius:4px;background:#f8f9fa;cursor:pointer;transition:all .2s ease}.file-input:hover{border-color:#0d6efd;background:#e7f3ff}.file-input:focus{outline:none;border-color:#0d6efd;box-shadow:0 0 0 2px #0d6efd40}.file-input:disabled{opacity:.6;cursor:not-allowed;background:#e9ecef}.image-preview-container{margin-top:16px;text-align:center}.image-preview{max-width:100%;max-height:200px;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:12px}.remove-image-btn{padding:6px 12px;background:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:background-color .2s ease}.remove-image-btn:hover{background:#c82333}@media (max-width: 768px){.add-banner-header{flex-direction:column;gap:16px;align-items:flex-start}.add-banner-form{padding:16px}.form-actions{flex-direction:column}.cancel-btn,.submit-btn{width:100%}.image-source-toggle{flex-direction:column;gap:8px}.toggle-btn{width:100%}}.edit-banner-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.back-button{padding:8px 16px;background-color:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:background-color .2s ease}.back-button:hover{background-color:#5a6268}.edit-banner-form{background-color:#fff;padding:24px;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-width:600px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#212529}.form-group input,.form-group select{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:4px;font-size:14px;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#0d6efd;box-shadow:0 0 0 2px #0d6efd40}.form-group small{display:block;margin-top:4px;color:#6c757d;font-size:12px}.error-message{background-color:#f8d7da;color:#721c24;padding:12px;border-radius:4px;margin-bottom:20px;border:1px solid #f5c6cb}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid #e9ecef}.cancel-btn,.submit-btn{padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s ease}.cancel-btn{background-color:#6c757d;color:#fff}.cancel-btn:hover{background-color:#5a6268}.submit-btn{background-color:#0d6efd;color:#fff}.submit-btn:hover:not(:disabled){background-color:#0b5ed7}.submit-btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.edit-banner-header{flex-direction:column;gap:16px;align-items:flex-start}.edit-banner-form{padding:16px}.form-actions{flex-direction:column}.cancel-btn,.submit-btn{width:100%}}.categories-container{padding:20px;max-width:1400px;margin:0 auto}.categories-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e1e5e9}.categories-header h1{color:#2c3e50;margin:0;font-size:2.5rem;font-weight:600}.btn-toggle-view{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.btn-toggle-view:hover{background:#5a6268;transform:translateY(-2px)}.btn-expand-all{background:#28a745;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;margin-right:10px}.btn-expand-all:hover{background:#218838;transform:translateY(-2px)}.btn-collapse-all{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;margin-right:10px}.btn-collapse-all:hover{background:#5a6268;transform:translateY(-2px)}.add-button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background:linear-gradient(90deg,#16a34a,#0ea5e9);color:#fff;cursor:pointer;transition:border-color .25s}.add-button:hover{opacity:.9}.btn-dashboard{background:#17a2b8;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.btn-logout{background:#dc3545;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.bulk-actions{background:#e3f2fd;padding:15px 20px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:15px;border:1px solid #bbdefb}.bulk-actions span{color:#1976d2;font-weight:500}.btn-bulk-activate{background:#28a745;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .3s ease}.btn-bulk-activate:hover{background:#218838}.btn-bulk-deactivate{background:#dc3545;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .3s ease}.btn-bulk-deactivate:hover{background:#c82333}.category-tree{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 10px #0000001a}.category-tree-item{margin-bottom:15px}.category-tree-content{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:15px;margin-bottom:10px;transition:all .3s ease}.category-tree-content:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.category-tree-header{display:flex;align-items:center;gap:15px;margin-bottom:10px;flex-wrap:wrap}.category-name{font-weight:600;color:#2c3e50;font-size:16px;display:flex;align-items:center}.level-indicator{color:#6c757d;font-weight:700;margin-right:8px;font-size:14px}.category-level{background:#6c757d;color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.category-status{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.status-1{background:#d4edda;color:#155724}.status-2{background:#f8d7da;color:#721c24}.category-actions{display:flex;gap:8px;margin-left:auto}.btn-edit{background:#17a2b8;color:#fff;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;transition:all .3s ease}.btn-edit:hover{background:#138496}.btn-view{background:#28a745;color:#fff;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;transition:all .3s ease;margin-right:4px;position:relative}.btn-view:hover{background:#218838;transform:translateY(-1px)}.btn-view.expanded{background:#6c757d}.btn-view.expanded:hover{background:#5a6268}.btn-view:before{content:"▶";margin-right:4px;font-size:10px;transition:transform .3s ease}.btn-view.expanded:before{transform:rotate(90deg)}.btn-delete{background:#dc3545;color:#fff;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;transition:all .3s ease}.category-description{color:#6c757d;font-size:14px;line-height:1.5;margin-bottom:10px}.category-children{margin-top:15px;border-left:2px solid #e9ecef;padding-left:20px;transition:all .3s ease}.category-children .category-tree-item{position:relative}.category-children .category-tree-item:before{content:"";position:absolute;left:-22px;top:20px;width:20px;height:2px;background:#e9ecef}.category-tree-item{transition:all .3s ease}.no-categories{text-align:center;color:#6c757d;font-size:18px;padding:40px}.category-list{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 10px #0000001a}.category-table{width:100%;border-collapse:collapse}.category-table th,.category-table td{padding:15px;text-align:left;border-bottom:1px solid #e9ecef}.category-table th{background:#f8f9fa;font-weight:600;color:#495057;font-size:14px}.category-table td{color:#495057;font-size:14px}.category-table tbody tr:hover,.category-table tbody tr.subcategory{background:#f8f9fa}.category-table tbody tr.subcategory:hover{background:#e9ecef}.category-table tbody tr.subcategory td:first-child{border-left:4px solid #28a745}.status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.pagination{display:flex;justify-content:center;align-items:center;gap:10px;margin-top:30px;padding:20px}.btn-page{background:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.btn-page:hover:not(:disabled){background:#5a6268}.btn-page.active{background:#007bff}.btn-page:disabled{background:#dee2e6;color:#6c757d;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid #e9ecef}.modal-header h2{margin:0;color:#2c3e50;font-size:1.5rem}.btn-close{background:none;border:none;font-size:24px;color:#6c757d;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s ease}.modal-form{padding:25px}.modal-info{background:#e7f3ff;border:1px solid #b3d9ff;border-radius:8px;padding:15px;margin-bottom:20px}.modal-info p{margin:0;color:#0056b3;font-size:14px;line-height:1.5}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#495057;font-weight:500;font-size:14px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:14px;transition:all .3s ease;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.form-group textarea{resize:vertical;min-height:80px}.modal-actions{display:flex;justify-content:flex-end;gap:15px;margin-top:30px;padding-top:20px;border-top:1px solid #e9ecef}.btn-submit{background:#007bff;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease}.btn-submit:hover{background:#0056b3;transform:translateY(-2px);box-shadow:0 4px 12px #007bff4d}.loading{text-align:center;padding:60px;color:#6c757d;font-size:18px}@media (max-width: 768px){.categories-container{padding:15px}.categories-header{flex-direction:column;gap:20px;align-items:stretch}.header-actions{justify-content:center}.category-tree-header{flex-direction:column;align-items:flex-start;gap:10px}.category-actions{margin-left:0;width:100%;justify-content:flex-end}.form-row{grid-template-columns:1fr;gap:0}.modal{width:95%;margin:20px}.category-table{font-size:12px}.category-table th,.category-table td{padding:10px 8px}}@media (max-width: 480px){.categories-header h1{font-size:2rem}.header-actions{flex-direction:column;gap:10px}.bulk-actions{flex-direction:column;align-items:stretch;gap:10px}.modal-form{padding:20px}}.add-category-container{padding:20px;max-width:1400px;margin:0 auto;min-height:100vh;background:#f8f9fa}.add-category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:25px 30px;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a}.header-content h1{color:#2c3e50;margin:0 0 8px;font-size:2.5rem;font-weight:600}.header-content p{color:#6c757d;margin:0;font-size:16px}.header-actions{display:flex;gap:15px;align-items:center}.btn-back{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.btn-back:hover{background:#5a6268;transform:translateY(-2px)}.btn-dashboard{background:#17a2b8;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.btn-dashboard:hover{background:#138496;transform:translateY(-2px)}.btn-logout{background:#dc3545;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.btn-logout:hover{background:#c82333;transform:translateY(-2px)}.form-info{background:#e7f3ff;border:1px solid #b3d9ff;border-radius:8px;padding:15px;margin-bottom:20px}.form-info p{margin:0;color:#0056b3;font-size:14px;line-height:1.5}.form-help{color:#6c757d;font-size:12px;margin-top:5px;display:block;font-style:italic;line-height:1.4}.error-message{background:#f8d7da;color:#721c24;padding:15px 20px;border-radius:8px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;border:1px solid #f5c6cb}.success-message{background:#d4edda;color:#155724;padding:15px 20px;border-radius:8px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;border:1px solid #c3e6cb}.success-message span{color:#0f5132;font-size:14px}.btn-close-error{background:none;border:none;color:#721c24;font-size:20px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.btn-close-error:hover{color:#491217}.add-category-content{display:grid;grid-template-columns:1fr 300px;gap:30px}.form-container{background:#fff;border-radius:12px;padding:30px;box-shadow:0 2px 10px #0000001a}.form-section{margin-bottom:40px;padding-bottom:30px;border-bottom:1px solid #e9ecef}.form-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.form-section h3{color:#2c3e50;margin:0 0 25px;font-size:1.3rem;font-weight:600;display:flex;align-items:center;gap:10px}.form-section h3:before{content:"";width:4px;height:20px;background:#007bff;border-radius:2px}.form-group{margin-bottom:25px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group label{display:block;margin-bottom:8px;color:#495057;font-weight:600;font-size:14px}.form-group small{display:block;margin-top:5px;color:#6c757d;font-size:12px;font-style:italic}.form-input,.form-select,.form-textarea{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:14px;transition:all .3s ease;box-sizing:border-box;background:#fff}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.form-textarea{resize:vertical;min-height:100px}.form-select{cursor:pointer}.form-actions{display:flex;justify-content:flex-end;gap:15px;margin-top:40px;padding-top:30px;border-top:1px solid #e9ecef}.btn-cancel{background:#6c757d;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.btn-submit{background:#28a745;color:#fff;border:none;padding:12px 30px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease}.btn-submit:hover:not(:disabled){background:#218838;transform:translateY(-2px);box-shadow:0 4px 12px #28a7454d}.btn-submit:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.form-sidebar{display:flex;flex-direction:column;gap:20px}.sidebar-card{background:#fff;border-radius:12px;padding:25px;box-shadow:0 2px 10px #0000001a}.sidebar-card h4{color:#2c3e50;margin:0 0 20px;font-size:1.1rem;font-weight:600}.sidebar-card ul{margin:0;padding:0;list-style:none}.sidebar-card li{color:#6c757d;margin-bottom:12px;padding-left:20px;position:relative;line-height:1.5}.sidebar-card li:before{content:"•";color:#007bff;font-weight:700;position:absolute;left:0}.btn-quick-action{background:#007bff;color:#fff;border:none;padding:10px 16px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .3s ease;width:100%;margin-bottom:10px}.btn-quick-action:hover{background:#0056b3;transform:translateY(-1px)}.btn-quick-action:last-child{margin-bottom:0}@media (max-width: 1024px){.add-category-content{grid-template-columns:1fr;gap:20px}.form-sidebar{order:-1}}@media (max-width: 768px){.add-category-container{padding:15px}.add-category-header{flex-direction:column;gap:20px;align-items:stretch;padding:20px}.header-content h1{font-size:2rem}.header-actions{justify-content:center;flex-wrap:wrap}.form-container{padding:20px}.form-row{grid-template-columns:1fr;gap:0}.form-actions{flex-direction:column}.btn-cancel,.btn-submit{width:100%}}@media (max-width: 480px){.header-content h1{font-size:1.8rem}.header-actions{flex-direction:column;gap:10px}.form-container{padding:15px}.sidebar-card{padding:20px}}.suppliers-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1rem 0}.suppliers-header h1{font-size:2rem;font-weight:600;color:#333;margin:0}.add-button{background:#198754;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .2s}.add-button:hover{background:#157347}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:.75rem;padding:1.5rem;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;gap:1rem}.stat-icon{font-size:2rem;width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center}.stat-icon.total{background:#e3f2fd;color:#1976d2}.stat-icon.active{background:#e8f5e8;color:#2e7d32}.stat-icon.inactive{background:#fff3e0;color:#f57c00}.stat-icon.deleted{background:#ffebee;color:#d32f2f}.stat-content h3{margin:0 0 .5rem;font-size:.9rem;font-weight:500;color:#666}.stat-value{font-size:1.5rem;font-weight:600;color:#333}.filters-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1rem 0}.filter-controls{display:flex;gap:1rem;align-items:center}.status-filter{padding:.5rem 1rem;border:1px solid #ddd;border-radius:.5rem;font-size:.9rem;background:#fff}.bulk-actions{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#f8f9fa;border-radius:.5rem;border:1px solid #e9ecef}.bulk-actions span{font-weight:500;color:#666}.btn-bulk-activate,.btn-bulk-deactivate,.btn-bulk-delete{padding:.5rem 1rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-bulk-activate{background:#198754;color:#fff}.btn-bulk-activate:hover{background:#157347}.btn-bulk-deactivate{background:#6c757d;color:#fff}.btn-bulk-deactivate:hover{background:#5a6268}.btn-bulk-delete{background:#dc3545;color:#fff}.btn-bulk-delete:hover{background:#c82333}.error-message{background:#f8d7da;color:#721c24;padding:1rem;border-radius:.5rem;margin-bottom:1.5rem;border:1px solid #f5c6cb;display:flex;justify-content:space-between;align-items:center}.btn-close-error{background:none;border:none;color:#721c24;font-size:1.2rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.btn-close-error:hover{background:#721c241a;border-radius:50%}.suppliers-panel{background:#fff;border-radius:.75rem;box-shadow:0 2px 4px #0000001a;overflow:hidden}.suppliers-table{overflow-x:auto}.suppliers-table table{width:100%;border-collapse:collapse}.suppliers-table th,.suppliers-table td{padding:1rem;text-align:left;border-bottom:1px solid #e9ecef}.suppliers-table th{background:#f8f9fa;font-weight:600;color:#495057;font-size:.875rem}.suppliers-table th:first-child{width:50px}.suppliers-table th:nth-child(2){width:80px}.suppliers-table th:nth-child(4){width:120px;text-align:right;padding-right:35px}.suppliers-table th:last-child{width:150px;padding-left:65px}.suppliers-table tbody tr:hover{background:#f8f9fa}.supplier-logo{width:50px;height:50px;border-radius:.5rem;object-fit:cover;border:1px solid #e9ecef}.no-logo{width:50px;height:50px;border-radius:.5rem;background:#f8f9fa;border:1px solid #e9ecef;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#6c757d}.supplier-info{display:flex;flex-direction:column;gap:.25rem}.supplier-name{font-weight:600;color:#333}.supplier-address{font-size:.875rem;color:#6c757d;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-section{display:flex;flex-direction:column;gap:.5rem;align-items:flex-end}.badge{padding:.375rem .75rem;border-radius:.375rem;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.025em}.status-badge.badge-active{background:#d1e7dd;color:#0f5132}.status-badge.badge-muted{background:#e2e3e5;color:#41464b}.status-badge.badge-deleted{background:#f8d7da;color:#721c24}.status-toggle-btn{padding:.375rem .75rem;border:none;border-radius:.375rem;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.activate-btn{background:#198754;color:#fff}.activate-btn:hover{background:#157347}.deactivate-btn{background:#dc3545;color:#fff}.deactivate-btn:hover{background:#c82333}.action-buttons{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;gap:.5rem;flex-wrap:nowrap}.view-btn,.edit-btn,.delete-btn{padding:.375rem .75rem;border:none;border-radius:.375rem;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s}.view-btn{background:#6c757d;color:#fff}.view-btn:hover{background:#5a6268}.edit-btn{background:#0d6efd;color:#fff}.edit-btn:hover{background:#0b5ed7}.delete-btn{background:#dc3545;color:#fff}.delete-btn:hover{background:#c82333}.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;padding:1.5rem;border-top:1px solid #e9ecef}.pagination-btn{padding:.5rem .75rem;border:1px solid #dee2e6;background:#fff;color:#6c757d;border-radius:.375rem;cursor:pointer;transition:all .2s;font-size:.875rem}.pagination-btn:hover:not(:disabled){background:#e9ecef;border-color:#adb5bd}.pagination-btn.active{background:#0d6efd;border-color:#0d6efd;color:#fff}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.page-numbers{display:flex;gap:.25rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:.75rem;box-shadow:0 10px 25px #0003;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{padding:1.5rem 1.5rem 1rem;border-bottom:1px solid #e9ecef}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#333}.modal-body{padding:1rem 1.5rem}.modal-body p{margin:0 0 .5rem;color:#666}.modal-footer{padding:1rem 1.5rem 1.5rem;border-top:1px solid #e9ecef;display:flex;justify-content:flex-end;gap:.75rem}.btn-cancel,.btn-delete{padding:.5rem 1rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-cancel{background:#6c757d;color:#fff}.btn-cancel:hover{background:#5a6268}.btn-delete{background:#dc3545;color:#fff}.btn-delete:hover{background:#c82333}.supplier-details-modal{max-width:800px;width:95%}.modal-header{display:flex;justify-content:space-between;align-items:center}.btn-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6c757d;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.btn-close:hover{background:#f8f9fa;color:#495057}.supplier-details-content{padding:0}.supplier-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #e9ecef}.supplier-logo-large{width:80px;height:80px;border-radius:.75rem;overflow:hidden;border:2px solid #e9ecef;display:flex;align-items:center;justify-content:center;background:#f8f9fa}.supplier-logo-image{width:100%;height:100%;object-fit:cover}.no-logo-large{font-size:.75rem;color:#6c757d;text-align:center;padding:.5rem}.supplier-basic-info{flex:1}.supplier-basic-info h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:#333}.supplier-details-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.detail-section{background:#f8f9fa;padding:1.5rem;border-radius:.5rem;border:1px solid #e9ecef}.detail-section.full-width{grid-column:1 / -1}.detail-section h4{margin:0 0 1rem;font-size:1rem;font-weight:600;color:#495057;border-bottom:1px solid #dee2e6;padding-bottom:.5rem}.detail-item{display:flex;margin-bottom:.75rem;align-items:flex-start}.detail-item:last-child{margin-bottom:0}.detail-item label{font-weight:500;color:#6c757d;min-width:100px;margin-right:1rem;flex-shrink:0}.detail-item span{color:#333;flex:1;word-break:break-word}.supplier-photo{text-align:center}.supplier-photo-image{max-width:200px;max-height:200px;border-radius:.5rem;border:1px solid #e9ecef;object-fit:cover}.no-photo{color:#6c757d;font-style:italic;padding:2rem;background:#f8f9fa;border-radius:.5rem;border:1px solid #e9ecef}.about-content{background:#fff;padding:1rem;border-radius:.375rem;border:1px solid #e9ecef;line-height:1.6;color:#495057}@media (max-width: 768px){.suppliers-header{flex-direction:column;gap:1rem;align-items:flex-start}.stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.filters-section{flex-direction:column;gap:1rem;align-items:stretch}.bulk-actions{flex-direction:column;gap:.75rem}.status-section{align-items:center}.action-buttons{flex-direction:column;gap:.25rem}.suppliers-table th,.suppliers-table td{padding:.75rem .5rem}.supplier-address{max-width:150px}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.suppliers-table{font-size:.875rem}.suppliers-table th,.suppliers-table td{padding:.5rem .25rem}.modal{width:95%;margin:1rem}}.add-supplier-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1rem 0}.add-supplier-header h1{font-size:2rem;font-weight:600;color:#333;margin:0}.add-supplier-content{background:#fff;border-radius:.75rem;box-shadow:0 2px 4px #0000001a;overflow:hidden}.form-input,.form-textarea{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:.375rem;font-size:.875rem;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-input:focus,.form-textarea:focus{outline:none;border-color:#0d6efd;box-shadow:0 0 0 .2rem #0d6efd40}select.form-input{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem;appearance:none;cursor:pointer}select.form-input:focus{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%230d6efd' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e")}.form-textarea{resize:vertical;min-height:80px}@media (max-width: 768px){.add-supplier-header{flex-direction:column;gap:1rem;align-items:flex-start}.form-grid,.file-upload-grid{grid-template-columns:1fr;gap:1rem}.form-actions{flex-direction:column;gap:.75rem}.btn{width:100%}.supplier-form{padding:1.5rem}}@media (max-width: 480px){.add-supplier-header h1{font-size:1.5rem}.supplier-form{padding:1rem}.form-section h3{font-size:1rem}}.edit-supplier-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1rem 0}.edit-supplier-header h1{font-size:2rem;font-weight:600;color:#333;margin:0}.back-button{background:#6c757d;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .2s}.back-button:hover{background:#5a6268}.success-message{background:#d1e7dd;border:1px solid #badbcc;color:#0f5132;padding:1rem;border-radius:.5rem;margin-bottom:1.5rem;font-weight:500}.error-message{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24;padding:1rem;border-radius:.5rem;margin-bottom:1.5rem}.edit-supplier-content{background:#fff;border-radius:.75rem;box-shadow:0 2px 4px #0000001a;overflow:hidden}.supplier-form{padding:2rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:1.5rem}.form-section{margin-bottom:2rem}.form-section h3{margin:0 0 1.25rem;font-size:1.125rem;font-weight:600;color:#333;padding-bottom:.5rem;border-bottom:2px solid #e9ecef}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#495057;font-size:.875rem}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:.375rem;font-size:.875rem;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#0d6efd;box-shadow:0 0 0 .2rem #0d6efd40}select.form-input{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem;appearance:none;cursor:pointer}select.form-input:focus{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%230d6efd' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e")}.form-group textarea{resize:vertical;min-height:80px;font-family:inherit}.form-group small{display:block;margin-top:.375rem;color:#6b7280;font-size:.75rem}.file-upload-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.file-upload-group{margin-bottom:1rem}.file-upload-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#495057;font-size:.875rem}.file-upload-area{border:2px dashed #dee2e6;border-radius:.5rem;padding:1.5rem;text-align:center;transition:border-color .2s,background-color .2s;position:relative;min-height:120px;display:flex;align-items:center;justify-content:center}.file-upload-area:hover{border-color:#0d6efd;background-color:#f8f9fa}.file-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#6c757d}.upload-placeholder span{font-size:2rem}.upload-placeholder p{margin:0;font-weight:500;color:#495057}.upload-placeholder small{font-size:.75rem;color:#6c757d}.file-preview{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.file-preview img{max-width:100%;max-height:100px;border-radius:.375rem;object-fit:cover}.remove-file{position:absolute;top:-.5rem;right:-.5rem;background:#dc3545;color:#fff;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;font-weight:700;transition:background-color .2s}.remove-file:hover{background:#c82333}.existing-file{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.existing-file img{max-width:100%;max-height:100px;border-radius:.375rem;object-fit:cover}.file-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;border-radius:.375rem;opacity:0;transition:opacity .2s;cursor:pointer}.file-overlay:hover{opacity:1}.file-overlay span{color:#fff;font-size:.875rem;font-weight:500}.form-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem;border-top:1px solid #e9ecef}.btn{padding:.75rem 1.5rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;min-width:100px}.btn-primary{background:#0d6efd;color:#fff}.btn-primary:hover:not(:disabled){background:#0b5ed7}.btn-primary:disabled{background:#6c757d;cursor:not-allowed}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#5a6268}.btn-secondary:disabled{background:#adb5bd;cursor:not-allowed}@media (max-width: 768px){.edit-supplier-header{flex-direction:column;gap:1rem;align-items:flex-start}.form-grid,.file-upload-grid{grid-template-columns:1fr;gap:1rem}.form-actions{flex-direction:column;gap:.75rem}.btn{width:100%}.supplier-form{padding:1.5rem}}@media (max-width: 480px){.edit-supplier-header h1{font-size:1.5rem}.supplier-form{padding:1rem}.form-section h3{font-size:1rem}}.orders-container{padding:20px}.customer-info{display:flex;flex-direction:column;gap:2px}.customer-name{font-weight:600;color:#333}.customer-email{font-size:.9em;color:#666}.items-info{display:flex;flex-direction:column;gap:4px}.items-preview{display:flex;flex-direction:column;gap:2px}.item-name{font-size:.85em;color:#666;background:#f5f5f5;padding:2px 6px;border-radius:3px;display:inline-block;margin-right:4px;margin-bottom:2px}.more-items{font-size:.8em;color:#999;font-style:italic}.status-badge{padding:4px 8px;border-radius:12px;font-size:.8em;font-weight:600;text-transform:capitalize}.status-pending{background-color:#fff3cd;color:#856404;border:1px solid #ffeaa7}.status-confirmed{background-color:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.status-processing{background-color:#cce5ff;color:#004085;border:1px solid #b3d7ff}.status-shipped{background-color:#e2e3e5;color:#383d41;border:1px solid #d6d8db}.status-delivered{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.status-cancelled,.status-refunded{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.payment-badge{padding:4px 8px;border-radius:12px;font-size:.8em;font-weight:600;text-transform:capitalize}.payment-pending{background-color:#fff3cd;color:#856404;border:1px solid #ffeaa7}.payment-paid{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.payment-failed,.payment-refunded{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.payment-partial{background-color:#ffeaa7;color:#856404;border:1px solid #fdcb6e}.action-buttons{display:flex;flex-direction:column;gap:4px;align-items:flex-start}.status-select,.payment-select{padding:4px 6px;border:1px solid #ddd;border-radius:4px;font-size:.8em;background:#fff;min-width:100px}.status-select:focus,.payment-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.btn-sm{padding:4px 8px;font-size:.8em;border-radius:4px}.filters-section{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.filters-row{display:flex;gap:20px;align-items:end;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-group label{font-weight:600;color:#333;font-size:.9em}.filter-group select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;min-width:150px}.search-group{display:flex;gap:10px;align-items:end;flex:1;min-width:300px}.search-group input{flex:1;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:.9em}.search-group input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;gap:15px}.stat-icon{font-size:2em;opacity:.7}.stat-content h3{margin:0;font-size:1.8em;font-weight:700;color:#333}.stat-content p{margin:0;color:#666;font-size:.9em}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.data-table th{background:#f8f9fa;padding:12px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6}.data-table td{padding:12px;border-bottom:1px solid #dee2e6;vertical-align:top}.data-table tr:hover{background-color:#f8f9fa}.data-table tr:last-child td{border-bottom:none}@media (max-width: 768px){.filters-row{flex-direction:column;align-items:stretch}.search-group{min-width:auto}.action-buttons{flex-direction:row;gap:8px}.status-select,.payment-select{min-width:80px}.data-table{font-size:.9em}.data-table th,.data-table td{padding:8px}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.stat-card{padding:15px}.stat-content h3{font-size:1.5em}}
