*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#2d6a4f;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#1e4d38}.auth-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-card{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:500px;overflow:hidden;width:100%}.auth-header{background:linear-gradient(135deg,#2d6a4f,#1e4d38);color:#fff;padding:40px 30px;text-align:center}.auth-logo{align-items:center;display:flex;flex-direction:column;gap:10px}.logo-icon{animation:bounce 2s infinite;font-size:60px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.logo-title{font-size:28px;font-weight:700;margin:0}.auth-subtitle{font-size:14px;margin:10px 0 0;opacity:.9}.auth-form{padding:30px}.form-title{color:#333;font-size:24px;font-weight:700;margin:0 0 25px;text-align:center}.alert{align-items:center;border-radius:8px;display:flex;font-size:14px;gap:10px;margin-bottom:20px;padding:12px 16px}.alert-icon{font-size:20px}.alert-error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.alert-success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.form-group label{font-size:14px}.form-group input,.form-group select,.form-group textarea{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:15px;padding:12px 16px;transition:all .3s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#2d6a4f;box-shadow:0 0 0 3px #2d6a4f1a;outline:none}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:#f5f5f5;cursor:not-allowed}.form-actions{justify-content:flex-end;margin-bottom:20px}.forgot-link{color:#2d6a4f;font-size:14px;font-weight:600;text-decoration:none;transition:color .3s ease}.forgot-link:hover{color:#1e4d38;text-decoration:underline}.btn-block{width:100%}.btn-loading{color:#0000!important;position:relative}.spinner-small{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:16px;margin-right:8px;vertical-align:middle;width:16px}.auth-footer{align-items:center;border-top:1px solid #e0e0e0;display:flex;gap:10px;justify-content:center;margin-top:25px;padding-top:20px;text-align:center}.auth-footer p{color:#666;font-size:14px;margin:0}.auth-link{color:#2d6a4f;font-weight:600;text-decoration:none;transition:color .3s ease}.auth-link:hover{color:#1e4d38;text-decoration:underline}.divider{color:#ccc;margin:0 10px}.step-indicators{background:#f8f9fa;padding:30px}.step-indicator,.step-indicators{align-items:center;display:flex;justify-content:center}.step-indicator{background:#e0e0e0;border-radius:50%;color:#666;font-size:16px;font-weight:700;height:40px;transition:all .3s ease;width:40px}.step-indicator.active{background:#2d6a4f;color:#fff;transform:scale(1.1)}.step-line{background:#e0e0e0;height:2px;margin:0 10px;width:60px}.form-buttons{display:flex;gap:12px;margin-top:25px}.form-buttons .btn{flex:1 1}.demo-section{background:#f8f9fa;border-top:1px solid #e0e0e0;padding:20px 30px 30px}.demo-title{color:#666;font-size:14px;font-weight:700;margin:0 0 15px;text-align:center}.demo-buttons{display:flex;flex-direction:column;gap:10px}.demo-btn{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:12px 16px;text-align:left;transition:all .3s ease}.demo-btn:hover:not(:disabled){background:#f0f8f5;border-color:#2d6a4f;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.demo-btn:disabled{cursor:not-allowed;opacity:.6}.demo-icon{font-size:24px}.demo-info{flex:1 1}.demo-label{color:#333;font-size:14px;font-weight:700;margin-bottom:2px}.demo-credentials{color:#666;font-size:12px}.info-box{background:#e3f2fd;border:1px solid #90caf9;border-radius:8px;margin-top:20px;padding:16px}.info-title{color:#1976d2}.info-list{color:#1565c0;font-size:13px;padding-left:20px}.info-list li{line-height:1.4;margin-bottom:6px}@media (max-width:600px){.auth-container{padding:10px}.auth-card{border-radius:16px}.auth-header{padding:30px 20px}.logo-icon{font-size:50px}.logo-title{font-size:24px}.auth-form{padding:20px}.demo-section{padding:15px 20px 20px}.step-indicators{padding:20px}.step-line{width:40px}}.product-card{background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;height:100%;overflow:hidden;transition:all .3s ease}.product-card:hover{box-shadow:0 8px 24px #00000026;transform:translateY(-5px)}.product-image-container{background:#f0f8f5;height:200px;overflow:hidden;position:relative;width:100%}.product-image{height:100%;object-fit:cover;width:100%}.product-image-fallback{align-items:center;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);display:flex;height:100%;justify-content:center;width:100%}.product-emoji{font-size:64px}.product-badge{left:12px;position:absolute;top:12px}.category-badge{background:#fffffff2;border-radius:20px;box-shadow:0 2px 8px #0000001a;font-size:12px;font-weight:700;text-transform:uppercase}.product-info{display:flex;flex:1 1;flex-direction:column;padding:16px}.product-name{font-size:18px;margin:0 0 8px}.product-description{font-size:14px;line-height:1.4;margin:0 0 12px}.product-details{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.price-section{align-items:baseline;display:flex;gap:4px}.product-price{color:#2d6a4f;font-size:24px;font-weight:700}.product-unit{color:#666;font-size:14px}.stock-section{align-items:center;display:flex}.stock-badge{font-size:12px;padding:4px 10px}.product-rating{align-items:center;display:flex;gap:6px;margin-bottom:12px}.rating-stars{font-size:16px}.rating-value{color:#333;font-size:14px;font-weight:600}.add-to-cart-btn{background:#2d6a4f;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:auto;padding:12px;transition:all .3s ease;width:100%}.add-to-cart-btn:hover:not(:disabled){background:#1e4d38;box-shadow:0 4px 12px #2d6a4f4d;transform:translateY(-2px)}.add-to-cart-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.loading-spinner-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px;padding:40px}.loading-message{color:#666;font-size:16px;font-weight:600;margin-top:20px}.user-cart,.user-checkout,.user-edit-profile,.user-home,.user-orders,.user-profile{min-height:calc(100vh - 70px);padding:20px 0}.home-header{margin-bottom:30px;text-align:center}.header-content{margin:0 auto;max-width:600px}.page-title{align-items:center;color:#333;display:flex;font-size:32px;font-weight:700;gap:12px;justify-content:center;margin:0 0 10px}.title-icon{font-size:36px}.page-subtitle{color:#666;font-size:16px;margin:0}.search-section{margin-bottom:20px}.search-container{margin:0 auto;max-width:600px;position:relative}.search-icon{color:#999;font-size:20px;left:16px;position:absolute;top:50%;transform:translateY(-50%)}.search-input{border:2px solid #e0e0e0;border-radius:12px;font-size:16px;padding:14px 50px;transition:all .3s ease;width:100%}.search-input:focus{border-color:#2d6a4f;box-shadow:0 0 0 3px #2d6a4f1a}.search-clear{align-items:center;background:#e0e0e0;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:14px;height:24px;justify-content:center;position:absolute;right:16px;top:50%;transform:translateY(-50%);transition:all .3s ease;width:24px}.search-clear:hover{background:#ccc}.category-section{margin-bottom:30px}.category-buttons{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.category-btn{background:#fff;border:2px solid #e0e0e0;border-radius:25px;color:#666;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .3s ease}.category-btn:hover{background:#f0f8f5;border-color:#2d6a4f;transform:translateY(-2px)}.category-btn.active{background:#2d6a4f;border-color:#2d6a4f;color:#fff}.trending-section{margin-bottom:40px}.section-header{justify-content:space-between;margin-bottom:20px}.section-header,.section-title{align-items:center;display:flex}.section-title{font-size:24px;gap:10px;margin:0}.section-icon{font-size:28px}.loading-badge{background:#f0f8f5;color:#2d6a4f;font-size:12px}.loading-badge,.product-count{border-radius:12px;font-weight:600;padding:6px 12px}.product-count{background:#e0e0e0;color:#666;font-size:14px}.trending-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.empty-trending{color:#999;font-style:italic;padding:40px;text-align:center}.products-section{margin-top:40px}.products-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.toast-notification{align-items:center;background:#2d6a4f;border-radius:12px;bottom:-100px;box-shadow:0 8px 24px #0003;color:#fff;display:flex;font-weight:600;gap:10px;left:50%;padding:16px 24px;position:fixed;transform:translateX(-50%);transition:all .3s ease;z-index:9999}.toast-notification.show{bottom:30px}.toast-icon{font-size:24px}.toast-text{font-size:15px}.cart-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.cart-content{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 380px}.cart-items{display:flex;flex-direction:column}.cart-summary{height:-webkit-fit-content;height:fit-content;position:-webkit-sticky;position:sticky;top:90px}.summary-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:16px;padding:20px}.summary-title{color:#333;font-size:18px;font-weight:700;margin:0 0 16px}.summary-row{align-items:center;display:flex;font-size:15px;justify-content:space-between;padding:10px 0}.summary-value{font-weight:600}.summary-divider{background:#e0e0e0;height:1px;margin:10px 0}.summary-total{font-size:18px;padding:16px 0 0}.summary-total .summary-label{color:#333;font-weight:700}.summary-total .summary-value{color:#2d6a4f;font-size:24px;font-weight:700}.checkout-btn{margin-bottom:12px;margin-top:20px}.info-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:16px;padding:16px}.info-title{color:#333;font-size:14px;font-weight:700;margin:0 0 10px}.info-list{list-style:none;margin:0;padding:0}.info-list li{color:#666;font-size:13px;padding:6px 0}.checkout-content{margin:0 auto;max-width:700px}.checkout-form-section form{display:flex;flex-direction:column;gap:20px}.card-title{margin:0 0 16px}.order-items{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.order-item-row{align-items:center;display:flex;font-size:14px;justify-content:space-between;padding:8px 0}.order-item-row.total-row{padding-top:12px}.grand-total{color:#2d6a4f!important;font-size:20px!important;font-weight:700!important}.payment-options{display:flex;flex-direction:column;gap:12px}.payment-option{align-items:center;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;display:flex;padding:16px;position:relative;transition:all .3s ease}.payment-option input[type=radio]{opacity:0;position:absolute}.payment-option.selected,.payment-option:hover{background:#f0f8f5;border-color:#2d6a4f}.payment-content{align-items:center;display:flex;flex:1 1;gap:12px}.payment-icon{font-size:32px}.payment-info{flex:1 1}.payment-title{color:#333;font-size:15px;font-weight:700;margin-bottom:4px}.payment-subtitle{color:#666;font-size:13px}.payment-check{color:#2d6a4f;font-size:24px;font-weight:700}.orders-header{align-items:center;display:flex;justify-content:space-between}.orders-count,.orders-header{margin-bottom:20px}.count-badge{background:#2d6a4f;border-radius:20px;color:#fff;font-size:14px;font-weight:600;padding:8px 16px}.orders-list{display:flex;flex-direction:column}.profile-header{background:linear-gradient(135deg,#2d6a4f,#1e4d38);border-radius:20px;color:#fff;margin-bottom:30px;padding:40px 20px;text-align:center}.profile-avatar{align-items:center;background:#fff;border:4px solid #ffffff4d;border-radius:50%;color:#2d6a4f;display:flex;font-size:40px;font-weight:700;height:100px;justify-content:center;margin:0 auto 20px;width:100px}.profile-name{font-size:28px;font-weight:700;margin:0 0 8px}.profile-email{font-size:14px;margin:0 0 12px;opacity:.9}.profile-role-badge{background:#fff3;border:1px solid #ffffff4d;border-radius:20px;display:inline-block;font-size:12px;font-weight:700;padding:8px 20px}.profile-menu{display:flex;flex-direction:column;gap:12px;margin-bottom:30px}.profile-menu-item{align-items:center;background:#fff;border:none;border-radius:12px;box-shadow:0 2px 8px #0000001a;cursor:pointer;display:flex;gap:16px;padding:20px;text-align:left;transition:all .3s ease}.profile-menu-item:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.menu-item-icon{align-items:center;background:#f0f8f5;border-radius:12px;display:flex;flex-shrink:0;font-size:24px;height:50px;justify-content:center;width:50px}.menu-item-content{flex:1 1}.menu-item-title{color:#333;font-size:16px;font-weight:700;margin-bottom:4px}.menu-item-subtitle{color:#666;font-size:13px}.menu-item-arrow{color:#ccc;font-size:32px;font-weight:300}.logout-button{margin-bottom:30px;margin-top:20px}.app-info{color:#999;padding:20px;text-align:center}.app-name{color:#2d6a4f;font-size:18px;font-weight:700;margin:0 0 8px}.app-version{font-size:12px;margin:0 0 4px}.app-copyright{font-size:11px;margin:0}.edit-profile-form{display:flex;flex-direction:column;gap:20px;margin:0 auto;max-width:600px}.readonly-field{margin-bottom:16px}.readonly-field label{color:#666;display:block;font-size:12px;font-weight:600;margin-bottom:6px}.readonly-value{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;color:#333;font-weight:600;padding:12px 16px}.form-actions{display:flex;gap:12px;margin-top:10px}.form-actions .btn{flex:1 1}@media (max-width:1024px){.cart-content{grid-template-columns:1fr}.cart-summary{position:static}}@media (max-width:768px){.page-title{font-size:24px}.title-icon{font-size:28px}.section-title{font-size:20px}.products-grid,.trending-grid{gap:16px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.category-buttons{gap:8px}.category-btn{font-size:14px;padding:10px 16px}.form-actions{flex-direction:column}.form-actions .btn{width:100%}}@media (max-width:480px){.products-grid,.trending-grid{grid-template-columns:1fr}}.cart-item{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:16px;margin-bottom:12px;padding:16px;transition:all .3s ease}.cart-item:hover{box-shadow:0 4px 16px #00000026}.cart-item-image{background:#f0f8f5;border-radius:12px;flex-shrink:0;height:80px;overflow:hidden;position:relative;width:80px}.cart-item-image img{height:100%;object-fit:cover;width:100%}.cart-item-emoji{align-items:center;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);display:flex;font-size:40px;height:100%;justify-content:center;width:100%}.cart-item-info{flex:1 1;min-width:0}.cart-item-name{color:#333;font-size:16px;font-weight:700;margin:0 0 6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cart-item-price{color:#2d6a4f;font-size:14px;font-weight:600;margin:0 0 4px}.cart-item-subtotal{color:#666;font-size:13px;margin:0}.cart-item-actions{align-items:flex-end;display:flex;flex-direction:column;gap:12px}.quantity-controls{align-items:center;background:#f5f5f5;border-radius:20px;display:flex;gap:12px;padding:4px}.quantity-btn{align-items:center;background:#2d6a4f;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:18px;font-weight:700;height:32px;justify-content:center;transition:all .3s ease;width:32px}.quantity-btn:hover:not(:disabled){background:#1e4d38;transform:scale(1.1)}.quantity-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.5}.quantity-value{color:#333;font-size:16px;font-weight:700;min-width:30px;text-align:center}.remove-btn{background:none;border:none;cursor:pointer;font-size:24px;padding:4px;transition:transform .3s ease}.remove-btn:hover{transform:scale(1.2)}@media (max-width:768px){.cart-item{align-items:flex-start;flex-direction:column}.cart-item-image{height:150px;width:100%}.cart-item-actions{align-items:center;flex-direction:row;justify-content:space-between;width:100%}}.order-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:16px;padding:20px;transition:all .3s ease}.order-card:hover{box-shadow:0 4px 16px #00000026}.order-header{align-items:flex-start;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:16px}.order-header-left{flex:1 1}.order-number{font-size:18px;margin:0 0 6px}.order-date{font-size:13px;margin:0}.order-status-badge{align-items:center;border-radius:20px;display:flex;font-size:12px;font-weight:700;gap:6px;padding:8px 16px}.order-items{border-bottom:1px solid #f0f0f0;margin-bottom:16px;padding-bottom:16px}.items-title{color:#666;font-size:14px;font-weight:600;margin:0 0 10px}.items-list{list-style:none;margin:0;padding:0}.order-item{align-items:center;display:flex;font-size:14px;justify-content:space-between;padding:6px 0}.item-name{color:#333;flex:1 1}.item-price{color:#2d6a4f;font-weight:600}.no-items{color:#999;font-size:14px;font-style:italic}.order-delivery{border-bottom:1px solid #f0f0f0;margin-bottom:16px;padding-bottom:16px}.delivery-title{color:#666;font-size:14px;font-weight:600;margin:0 0 8px}.delivery-address{color:#333;font-size:14px;margin:4px 0}.delivery-phone{color:#666;font-size:14px;margin:4px 0}.order-footer{align-items:center;display:flex;justify-content:space-between}.payment-method{display:flex;flex-direction:column;gap:4px}.payment-label{color:#666;font-size:12px}.payment-value{color:#333;font-size:14px;font-weight:600}.order-total{align-items:flex-end;display:flex;flex-direction:column;gap:4px}.total-label{color:#666;font-size:12px}.total-amount{color:#2d6a4f;font-size:20px;font-weight:700}@media (max-width:768px){.order-header{flex-direction:column;gap:12px}.order-footer{flex-direction:column;gap:16px}.order-footer,.order-total{align-items:flex-start}}.admin-add-edit-product,.admin-dashboard,.admin-order-management,.admin-product-management,.admin-rider-management{min-height:calc(100vh - 70px);padding:20px 0}.page-header{align-items:flex-start;display:flex;gap:20px;justify-content:space-between;margin-bottom:30px}.header-actions{display:flex;flex-shrink:0;gap:12px}.dashboard-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:30px}.dashboard-section{margin-bottom:40px}.section-title{color:#333;font-size:20px;font-weight:700;margin-bottom:20px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.stats-grid-2{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.stats-grid-3{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.stat-card{align-items:center;background:#fff;border-left:4px solid;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:16px;padding:20px;transition:all .3s ease}.stat-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-4px)}.stat-icon{font-size:40px;line-height:1}.stat-content{flex:1 1}.stat-value{color:#333;font-size:28px;line-height:1.2}.stat-label{font-size:14px}.quick-actions{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.action-card{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:12px;padding:24px;text-align:center;transition:all .3s ease}.action-card:hover{background:#f0f8f5;border-color:#2d6a4f;box-shadow:0 4px 16px #0000001a;transform:translateY(-4px)}.action-icon{font-size:48px}.action-label{color:#333;font-size:16px;font-weight:700}.products-count{margin-bottom:20px}.products-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.products-table{border-collapse:collapse;width:100%}.products-table thead{background:#f8f9fa}.products-table th{border-bottom:2px solid #e0e0e0;color:#333;font-size:14px;font-weight:700;padding:16px;text-align:left}.products-table td{border-bottom:1px solid #f0f0f0;padding:16px;vertical-align:middle}.products-table tbody tr:hover{background:#f8f9fa}.product-image-cell{height:60px;width:60px}.product-thumbnail{border-radius:8px;height:100%;object-fit:cover;width:100%}.product-thumbnail-fallback{align-items:center;background:#f0f8f5;border-radius:8px;display:flex;font-size:28px;height:100%;justify-content:center;width:100%}.product-name-cell{min-width:200px}.product-name{color:#333;font-weight:700;margin-bottom:4px}.product-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#666;display:-webkit-box;font-size:13px;overflow:hidden}.category-badge{background:#f0f8f5;border-radius:12px;color:#2d6a4f;display:inline-block;font-size:13px;font-weight:600;padding:6px 12px}.price-cell{color:#2d6a4f;font-size:16px;font-weight:700}.price-cell .unit{color:#666;font-size:13px;font-weight:600}.stock-badge{background:#d4edda;border-radius:12px;color:#155724;display:inline-block;font-size:13px;font-weight:600;padding:6px 12px}.stock-badge.low-stock{background:#fff3cd;color:#856404}.status-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:700;padding:6px 12px;text-transform:uppercase}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.action-buttons{display:flex;gap:8px}.btn-icon{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:16px;height:36px;justify-content:center;transition:all .3s ease;width:36px}.btn-edit{background:#e3f2fd}.btn-edit:hover{background:#2196f3;transform:scale(1.1)}.btn-delete{background:#ffebee}.btn-delete:hover{background:#f44336;transform:scale(1.1)}.product-form{display:flex;flex-direction:column;gap:24px;margin:0 auto;max-width:800px}.card-title{color:#333;font-size:18px;font-weight:700;margin-bottom:20px}.image-upload-section{align-items:flex-start;display:flex;gap:24px}.image-preview-container{flex-shrink:0}.image-preview{border:2px solid #e0e0e0;border-radius:12px;height:200px;object-fit:cover;width:200px}.image-placeholder{align-items:center;background:#f5f5f5;border:2px dashed #ccc;border-radius:12px;display:flex;flex-direction:column;gap:10px;height:200px;justify-content:center;width:200px}.placeholder-icon{font-size:48px;opacity:.5}.placeholder-text{color:#999;font-size:14px;font-weight:600}.image-upload-controls{display:flex;flex:1 1;flex-direction:column;gap:12px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.checkbox-label{align-items:center;background:#f8f9fa;border-radius:8px;cursor:pointer;display:flex;gap:10px;margin-top:28px;padding:12px}.checkbox-label input[type=checkbox]{cursor:pointer;width:auto}.checkbox-label span{color:#333;font-weight:600}.filter-tabs{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}.filter-tab{background:#fff;border:2px solid #e0e0e0;border-radius:20px;color:#666;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.filter-tab:hover{background:#f0f8f5;border-color:#2d6a4f}.filter-tab.active{background:#2d6a4f;border-color:#2d6a4f;color:#fff}.riders-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.rider-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;transition:all .3s ease}.rider-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-4px)}.rider-header{align-items:flex-start;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:16px}.rider-info{flex:1 1}.rider-name{color:#333;font-size:18px;font-weight:700;margin:0 0 6px}.rider-email{color:#666;font-size:13px;margin:0}.rider-details{margin-bottom:16px}.detail-row{display:flex;font-size:14px;justify-content:space-between;padding:8px 0}.detail-label{color:#666;font-weight:600}.detail-value{color:#333;font-weight:500;text-align:right}.rider-actions{display:flex;flex-wrap:wrap;gap:8px}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:9999}.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px}.modal-title{color:#333;font-size:20px;font-weight:700;margin:0}.modal-close{align-items:center;background:#f5f5f5;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:18px;height:32px;justify-content:center;transition:all .3s ease;width:32px}.modal-close:hover{background:#e0e0e0;transform:rotate(90deg)}.modal-form{padding:20px}.modal-actions{display:flex;gap:12px;margin-top:20px}.modal-actions .btn{flex:1 1}@media (max-width:1024px){.stats-grid,.stats-grid-2,.stats-grid-3{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:768px){.page-header{flex-direction:column}.header-actions{justify-content:space-between;width:100%}.form-row{grid-template-columns:1fr}.image-upload-section{flex-direction:column}.riders-grid{grid-template-columns:1fr}.products-table-container{overflow-x:auto}.products-table{min-width:800px}}.om-page{background:#f5f5f5;display:flex;flex-direction:column;min-height:100vh}.om-header{align-items:center;background:#2d6a4f;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:20px 24px}.om-header-title{color:#fff;font-size:22px;font-weight:700;margin:0}.om-header-subtitle{color:#d4edda;font-size:13px;margin:4px 0 0}.om-refresh-btn{background:#ffffff26;border:1px solid #fff6;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:background .2s;white-space:nowrap}.om-refresh-btn:hover:not(:disabled){background:#ffffff40}.om-refresh-btn:disabled{cursor:not-allowed;opacity:.6}.om-body{flex:1 1;padding:16px}.om-alert{align-items:center;background:#fff3cd;border:1px solid #ffc107;border-radius:8px;color:#856404;font-size:14px;font-weight:500;padding:12px 16px}.om-alert,.om-tabs{display:flex;gap:8px;margin-bottom:16px}.om-tabs{background:#fff;border-radius:12px;box-shadow:0 1px 4px #00000014;flex-wrap:wrap;padding:12px}.om-tab{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:10px;color:#666;cursor:pointer;flex:1 1;font-size:13px;font-weight:700;min-width:80px;padding:10px 8px;text-align:center;transition:all .2s;white-space:nowrap}.om-tab:hover{background:#e8f5e9;border-color:#2d6a4f;color:#2d6a4f}.om-tab.active{background:#2d6a4f;border-color:#2d6a4f;color:#fff}.om-list{display:flex;flex-direction:column;gap:12px}.om-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:16px}.om-card-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:14px}.om-order-no{color:#333;font-size:16px;font-weight:700}.om-status-badge{border-radius:20px;color:#fff;font-size:11px;font-weight:900;letter-spacing:.5px;padding:5px 14px}.om-info-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.om-label{color:#666;font-size:13px;font-weight:600;margin-right:12px;white-space:nowrap}.om-value{color:#333;font-size:13px;font-weight:500;text-align:right}.om-amount{color:#2d6a4f;font-size:15px;font-weight:700}.om-hr{background:#e8e8e8;height:1px;margin:12px 0}.om-section{color:#333;font-size:14px;font-weight:700;margin:0 0 8px}.om-small{color:#555;font-size:13px;line-height:1.5;margin:0 0 5px}.om-empty{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.om-empty-icon{display:block;font-size:64px;margin-bottom:16px}.om-empty h2{color:#333;font-size:20px;font-weight:700;margin:0 0 8px}.om-empty p{color:#999;font-size:14px;margin:0}@media (max-width:600px){.om-header{padding:16px}.om-header-title{font-size:18px}.om-body{padding:12px}.om-tab{font-size:12px;padding:8px 6px}.om-card{padding:14px}.om-order-no{font-size:14px}}.rider-dashboard,.rider-delivered,.rider-orders{min-height:calc(100vh - 70px);padding:20px 0}.rider-stat-card{align-items:center;background:#fff;border-left:4px solid;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:16px;padding:20px;transition:all .3s ease}.rider-stat-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-4px)}.date-filter-section{margin-bottom:30px}.filter-title{color:#333;font-size:16px;font-weight:700;margin-bottom:12px}.date-filters{display:flex;flex-wrap:wrap;gap:10px}.date-filter-btn{background:#fff;border:2px solid #e0e0e0;border-radius:20px;color:#666;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.date-filter-btn:hover{background:#f0f8f5;border-color:#2d6a4f}.date-filter-btn.active{background:#2d6a4f;border-color:#2d6a4f;color:#fff}.earnings-card{align-items:center;background:linear-gradient(135deg,#2d6a4f,#1e4d38);border-radius:16px;box-shadow:0 4px 16px #2d6a4f4d;color:#fff;display:flex;gap:20px;padding:30px}.earnings-icon{font-size:64px;line-height:1}.earnings-content{flex:1 1}.earnings-amount{font-size:40px;font-weight:700;line-height:1;margin-bottom:8px}.earnings-label{font-size:16px;opacity:.9}.orders-preview{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.order-preview-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:16px;transition:all .3s ease}.order-preview-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.order-preview-header{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:12px}.order-preview-number{color:#333;font-size:16px;font-weight:700}.order-preview-status{border-radius:12px;font-size:11px;font-weight:700;padding:4px 10px;text-transform:uppercase}.order-preview-status.status-pending{background:#fff3cd;color:#856404}.order-preview-status.status-accepted,.order-preview-status.status-confirmed,.order-preview-status.status-processing{background:#d4edda;color:#155724}.order-preview-status.status-out-for-delivery{background:#cfe2ff;color:#084298}.order-preview-status.status-delivered{background:#d1e7dd;color:#0f5132}.order-preview-status.status-cancelled{background:#f8d7da;color:#721c24}.order-preview-details{display:flex;flex-direction:column;gap:8px}.order-preview-row{display:flex;font-size:14px;gap:8px}.order-preview-row .label{color:#666;font-weight:600}.order-preview-row .value{color:#333;flex:1 1}.rider-stats-bar{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:16px;margin-bottom:24px;padding:16px}.stat-item{border-right:1px solid #f0f0f0;flex:1 1;padding:12px;text-align:center}.stat-item:last-child{border-right:none}.stat-value{color:#2d6a4f;display:block;font-size:24px;font-weight:700;margin-bottom:4px}.stat-label{color:#666;display:block;font-size:13px;font-weight:600}.rider-orders-list{display:flex;flex-direction:column;gap:16px}.rider-order-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;transition:all .3s ease}.rider-order-card:hover{box-shadow:0 4px 16px #00000026}.order-card-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:16px}.order-number{color:#333;font-size:16px;font-weight:700}.order-status{border-radius:12px;font-size:11px;font-weight:700;padding:6px 12px}.order-status.status-pending{background:#fff3cd;color:#856404}.order-status.status-accepted,.order-status.status-assigned,.order-status.status-confirmed,.order-status.status-processing{background:#d4edda;color:#155724}.order-status.status-out-for-delivery{background:#cfe2ff;color:#084298}.order-status.status-delivered{background:#d1e7dd;color:#0f5132}.order-status.status-cancelled{background:#f8d7da;color:#721c24}.order-card-body{padding:16px}.order-info-row{align-items:flex-start;display:flex;font-size:14px;gap:10px;margin-bottom:10px}.info-icon{flex-shrink:0;font-size:16px}.info-text{color:#555;flex:1 1}.order-card-footer{align-items:center;border-top:1px solid #f0f0f0;display:flex;justify-content:space-between;margin-top:12px;padding-top:12px}.order-amount{color:#2d6a4f;font-size:18px;font-weight:700}.order-date{color:#999;font-size:12px}.order-card-actions{background:#f8f9fa;border-top:1px solid #e0e0e0;display:flex;gap:8px;padding:12px 16px}.action-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:13px;font-weight:600;gap:6px;justify-content:center;padding:10px 12px;transition:all .3s ease}.btn-navigate{background:#e3f2fd;color:#0d47a1}.btn-navigate:hover:not(:disabled){background:#2196f3;color:#fff}.btn-call{background:#e8f5e9;color:#1b5e20}.btn-call:hover:not(:disabled){background:#4caf50;color:#fff}.btn-update{background:#f3e5f5;color:#4a148c}.btn-update:hover:not(:disabled){background:#9c27b0;color:#fff}.btn-update.disabled{cursor:not-allowed;opacity:.5}.action-btn:disabled{cursor:not-allowed;opacity:.6}.delivered-summary{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.summary-item{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:16px;padding:24px}.summary-icon{font-size:48px;line-height:1}.summary-content{flex:1 1}.summary-value{color:#333;font-size:32px;font-weight:700;line-height:1;margin-bottom:4px}.summary-label{color:#666;font-size:14px;font-weight:600}.delivered-orders-list{display:flex;flex-direction:column;gap:16px}.delivered-order-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;transition:all .3s ease}.delivered-order-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.delivered-card-header{align-items:center;background:#f0f8f5;border-bottom:1px solid #d4edda;display:flex;justify-content:space-between;padding:16px}.delivered-order-number{color:#333;font-size:16px;font-weight:700}.delivered-badge{background:#28a745;border-radius:12px;color:#fff;font-size:11px;font-weight:700;padding:6px 12px}.delivered-card-body{padding:16px}.delivered-info-row{align-items:flex-start;display:flex;font-size:14px;gap:10px;margin-bottom:10px}.delivered-card-footer{align-items:center;border-top:1px solid #f0f0f0;display:flex;gap:16px;justify-content:space-between;margin-top:12px;padding-top:12px}.delivered-amount-section,.delivered-earning-section{flex:1 1}.amount-label,.earning-label{color:#666;display:block;font-size:12px;margin-bottom:4px}.amount-value{color:#333;font-size:16px}.amount-value,.earning-value{display:block;font-weight:700}.earning-value{color:#28a745;font-size:18px}@media (max-width:768px){.date-filters{gap:8px}.date-filter-btn{font-size:13px;padding:8px 16px}.rider-stats-bar{flex-direction:column;gap:0}.stat-item{border-bottom:1px solid #f0f0f0;border-right:none;padding:16px 12px}.stat-item:last-child{border-bottom:none}.order-card-actions{flex-direction:column}.action-btn{width:100%}.earnings-card{flex-direction:column;text-align:center}.delivered-card-footer{align-items:flex-start;flex-direction:column;gap:12px}}.navbar{background:linear-gradient(135deg,#2d6a4f,#1e4d38);box-shadow:0 2px 10px #0000001a;box-sizing:border-box;flex-wrap:nowrap;height:64px;justify-content:space-between;padding:0 20px;position:-webkit-sticky;position:sticky;top:0;width:100%;z-index:1000}.navbar,.navbar-logo{align-items:center;display:flex;gap:10px}.navbar-logo{color:#fff;flex-shrink:0;font-size:24px;font-weight:700;text-decoration:none;transition:transform .3s ease;white-space:nowrap}.navbar-logo:hover{transform:scale(1.05)}.logo-icon{font-size:28px}.logo-text{font-size:18px}.navbar-links{display:flex;flex:1 1;flex-wrap:nowrap;gap:4px;justify-content:center;overflow:hidden}.nav-link{align-items:center;border-radius:8px;color:#ffffffe6;display:flex;flex-shrink:0;font-weight:600;gap:6px;padding:8px 14px;position:relative;text-decoration:none;transition:all .3s ease;white-space:nowrap}.nav-link:hover{background:#ffffff1a;color:#fff}.nav-link.active{background:#fff3;color:#fff}.nav-icon{font-size:18px;line-height:1}.nav-label{font-size:13px}.nav-badge{background:#dc3545;border-radius:10px;color:#fff;font-size:10px;font-weight:700;line-height:1.4;min-width:16px;padding:1px 5px;position:absolute;right:4px;text-align:center;top:4px}.navbar-user{flex-shrink:0}.navbar-user,.user-info{align-items:center;display:flex;gap:10px}.user-info{background:#ffffff1a;border-radius:25px;padding:6px 12px;white-space:nowrap}.user-avatar{align-items:center;background:#fff;border-radius:50%;color:#2d6a4f;display:flex;flex-shrink:0;font-size:16px;font-weight:700;height:34px;justify-content:center;width:34px}.user-details{display:flex;flex-direction:column}.user-name{color:#fff;font-size:13px}.user-name,.user-role{font-weight:600;white-space:nowrap}.user-role{color:#fffc;font-size:10px}.logout-btn{background:#dc3545e6;border:none;border-radius:8px;color:#fff;cursor:pointer;flex-shrink:0;font-size:13px;font-weight:600;padding:8px 14px;transition:all .3s ease;white-space:nowrap}.logout-btn:hover{background:#dc3545;box-shadow:0 4px 12px #dc35454d;transform:translateY(-2px)}@media (max-width:1024px){.nav-label{display:none}.nav-link{padding:8px 12px}}@media (max-width:768px){.navbar{height:56px;padding:0 10px}.logo-text,.user-details{display:none}.user-info{padding:5px 8px}.nav-link{padding:7px 10px}.nav-icon{font-size:16px}.logout-btn{font-size:12px;padding:7px 10px}}.app{display:flex;flex-direction:column;min-height:100vh}.container{margin:0 auto;max-width:1200px;padding:20px;width:100%}.btn{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-size:16px;font-weight:600;padding:12px 24px;text-align:center;text-decoration:none;transition:all .3s ease}.btn-primary{background-color:#2d6a4f;color:#fff}.btn-primary:hover{background-color:#1e4d38;box-shadow:0 4px 12px #2d6a4f4d;transform:translateY(-2px)}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#5a6268}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.btn-outline{background-color:initial;border:2px solid #2d6a4f;color:#2d6a4f}.btn-outline:hover{background-color:#2d6a4f;color:#fff}.card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;transition:all .3s ease}.card:hover{box-shadow:0 4px 16px #00000026}input,select,textarea{border:1px solid #ddd;border-radius:8px;font-size:16px;padding:12px;transition:border-color .3s ease;width:100%}input:focus,select:focus,textarea:focus{border-color:#2d6a4f;box-shadow:0 0 0 3px #2d6a4f1a;outline:none}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block;font-weight:600;margin-bottom:8px}.error-text{color:#dc3545}.error-text,.success-text{font-size:14px;margin-top:5px}.success-text{color:#28a745}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#2d6a4f;height:50px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.badge-success{background-color:#d4edda;color:#155724}.badge-danger{background-color:#f8d7da;color:#721c24}.badge-warning{background-color:#fff3cd;color:#856404}.badge-info{background-color:#d1ecf1;color:#0c5460}.empty-state{padding:60px 20px;text-align:center}.empty-state-icon{font-size:64px;margin-bottom:20px}.empty-state-title{color:#333;font-size:24px;font-weight:700;margin-bottom:10px}.empty-state-text{color:#666;font-size:16px}@media (max-width:768px){.container{padding:15px}.btn{font-size:14px;padding:10px 20px}}
/*# sourceMappingURL=main.bb7cb6ed.css.map*/