.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--border-radius);font-size:14px;font-weight:500;transition:var(--transition);cursor:pointer;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-dark)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background-color:var(--border-color)}.btn-success{background-color:var(--success-color);color:#fff}.btn-danger{background-color:var(--danger-color);color:#fff}.btn-small{padding:6px 12px;font-size:12px}.btn-medium{padding:10px 20px;font-size:14px}.btn-large{padding:14px 28px;font-size:16px}.btn-full-width{width:100%}.btn-loading{position:relative;color:transparent}.btn-spinner{position:absolute;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.btn-icon{display:flex;align-items:center}@keyframes spin{to{transform:rotate(360deg)}}.input-group{margin-bottom:16px}.input-label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:var(--text-primary)}.input-required{color:var(--danger-color);margin-left:4px}.input-wrapper{position:relative}.input-field{width:100%;padding:10px 14px;border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:14px;transition:var(--transition);background-color:var(--bg-primary)}.input-field:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #8b45131a}.input-field.input-error{border-color:var(--danger-color)}.input-with-icon{padding-left:40px}.input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);display:flex;align-items:center}.input-error-message{display:block;margin-top:4px;font-size:12px;color:var(--danger-color)}.textarea{resize:vertical;min-height:80px}.select{cursor:pointer}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background-color:var(--bg-primary);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease}.modal-small{width:100%;max-width:400px}.modal-medium{width:100%;max-width:600px}.modal-large{width:100%;max-width:800px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color)}.modal-title{font-size:20px;font-weight:600}.modal-close{background:none;border:none;padding:8px;cursor:pointer;color:var(--text-secondary);border-radius:var(--border-radius);transition:var(--transition)}.modal-close:hover{background-color:var(--bg-tertiary)}.modal-body{padding:24px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}.loading-text{color:var(--text-secondary);font-size:14px}.badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500;color:#fff}.badge-active{background-color:var(--success-color)}.badge-inactive{background-color:var(--secondary-color)}.badge-category{background-color:var(--info-color)}.badge-status{color:#fff}.badge-success{background-color:var(--success-color)}.badge-danger{background-color:var(--danger-color)}.badge-action{color:#fff;text-transform:uppercase;font-size:10px}.customer-page{min-height:100vh;background-color:var(--bg-secondary)}.customer-header{background-color:var(--bg-primary);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.header-content{max-width:1400px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:20px}.header-left{display:flex;align-items:center;gap:12px}.header-left h1{font-size:24px;color:var(--primary-color)}.header-right{display:flex;align-items:center;gap:16px}.user-info{display:flex;align-items:center;gap:8px;padding:8px 12px;background-color:var(--bg-tertiary);border-radius:var(--border-radius);font-size:14px}.cart-toggle{position:relative;background:none;border:none;padding:8px;color:var(--text-primary);cursor:pointer;border-radius:var(--border-radius);transition:var(--transition)}.cart-toggle:hover{background-color:var(--bg-tertiary)}.cart-badge{position:absolute;top:0;right:0;background-color:var(--danger-color);color:#fff;font-size:10px;font-weight:600;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}.customer-main{max-width:1400px;margin:0 auto;padding:24px;display:grid;grid-template-columns:1fr;gap:24px}@media (min-width: 1024px){.customer-main{grid-template-columns:1fr 380px}}.customer-content{min-width:0}.product-grid-container{background-color:var(--bg-primary);border-radius:var(--border-radius);padding:24px;box-shadow:var(--shadow-sm)}.product-filters{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.search-box{position:relative;display:flex;align-items:center}.search-box svg{position:absolute;left:12px;color:var(--text-muted)}.search-input{width:100%;padding:10px 14px 10px 40px;border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:14px;transition:var(--transition)}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #8b45131a}.category-filter{display:flex;flex-wrap:wrap;gap:8px}.category-btn{padding:8px 16px;border:1px solid var(--border-color);background-color:var(--bg-primary);border-radius:20px;font-size:13px;font-weight:500;color:var(--text-secondary);transition:var(--transition)}.category-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.category-btn.active{background-color:var(--primary-color);border-color:var(--primary-color);color:#fff}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}.product-card{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden;transition:var(--transition);display:flex;flex-direction:column}.product-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.product-image{position:relative;width:100%;height:200px;background-color:var(--bg-tertiary);overflow:hidden}.product-image img{width:100%;height:100%;object-fit:cover}.product-image-placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:13px}.product-badge{position:absolute;top:12px;right:12px;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;color:#fff;text-transform:uppercase}.product-badge-out{background-color:var(--danger-color)}.product-badge-low{background-color:var(--warning-color)}.product-info{padding:16px;display:flex;flex-direction:column;flex-grow:1;gap:12px}.product-name{font-size:16px;font-weight:600;color:var(--text-primary);margin:0;line-height:1.4}.product-description{font-size:13px;color:var(--text-secondary);line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto}.product-price{font-size:18px;font-weight:700;color:var(--primary-color)}.product-stock{font-size:12px;color:var(--text-muted)}.cart-sidebar{background-color:var(--bg-primary);border-radius:var(--border-radius);box-shadow:var(--shadow-sm);padding:24px;position:sticky;top:100px;max-height:calc(100vh - 120px);overflow-y:auto}.cart-empty{text-align:center;padding:40px 20px;color:var(--text-muted)}.cart-title{font-size:18px;font-weight:600;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.cart-items{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}.cart-item{display:flex;flex-direction:column;gap:8px;padding:12px;background-color:var(--bg-secondary);border-radius:var(--border-radius)}.cart-item-info{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.cart-item-name{font-size:14px;font-weight:600;margin:0;flex:1}.cart-item-price{font-size:12px;color:var(--text-secondary);margin:0}.cart-item-actions{display:flex;justify-content:space-between;align-items:center}.quantity-controls{display:flex;align-items:center;gap:8px;background-color:var(--bg-primary);border-radius:var(--border-radius);padding:4px}.qty-btn{width:28px;height:28px;border:none;background-color:var(--bg-tertiary);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:var(--text-primary);transition:var(--transition)}.qty-btn:hover:not(:disabled){background-color:var(--primary-color);color:#fff}.qty-btn:disabled{opacity:.4;cursor:not-allowed}.qty-display{min-width:32px;text-align:center;font-weight:600;font-size:14px}.remove-btn{background:none;border:none;padding:8px;color:var(--danger-color);border-radius:var(--border-radius);transition:var(--transition)}.remove-btn:hover{background-color:#ef44441a}.cart-summary{padding-top:16px;border-top:1px solid var(--border-color)}.cart-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;font-size:16px;font-weight:600}.total-amount{font-size:20px;color:var(--primary-color)}.cart-close{display:block;width:100%;margin-top:12px;padding:10px;background:none;border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-secondary);font-size:13px;transition:var(--transition)}.cart-close:hover{background-color:var(--bg-tertiary)}.checkout-form{display:flex;flex-direction:column;gap:24px}.checkout-summary{background-color:var(--bg-secondary);padding:16px;border-radius:var(--border-radius)}.checkout-summary h4{font-size:16px;margin-bottom:12px}.checkout-items{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.checkout-item{display:flex;justify-content:space-between;font-size:13px}.checkout-total{padding-top:12px;border-top:1px solid var(--border-color);text-align:right;font-size:16px}.form-section{display:flex;flex-direction:column;gap:12px}.form-section h4{font-size:15px;color:var(--text-primary);padding-bottom:8px;border-bottom:1px solid var(--border-color)}.payment-options{display:flex;flex-direction:column;gap:10px}.radio-option{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid var(--border-color);border-radius:var(--border-radius);cursor:pointer;transition:var(--transition)}.radio-option:hover{border-color:var(--primary-color)}.radio-option input[type=radio]{accent-color:var(--primary-color);width:18px;height:18px}.radio-option input[type=radio]:checked+span{font-weight:600;color:var(--primary-color)}.form-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:16px;border-top:1px solid var(--border-color)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.error-container{text-align:center;padding:40px 20px;background-color:var(--bg-primary);border-radius:var(--border-radius);border:1px solid var(--border-color)}.text-small{font-size:12px;color:var(--text-secondary);margin:0}.text-muted{color:var(--text-muted)}@media (max-width: 768px){.header-left h1{font-size:18px}.product-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.cart-sidebar{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:380px;max-height:100vh;border-radius:0;z-index:200}}.admin-dashboard{min-height:100vh;background-color:var(--bg-secondary)}.admin-header{background-color:var(--bg-primary);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.admin-header .header-content{max-width:1400px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between}.admin-header .header-left h1{font-size:20px;margin:0;color:var(--text-primary)}.admin-header .header-left p{font-size:12px;color:var(--text-muted);margin:2px 0 0}.admin-tabs{background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);padding:0 24px;display:flex;gap:4px;overflow-x:auto;max-width:1400px;margin:0 auto}.tab-btn{padding:14px 20px;background:none;border:none;border-bottom:2px solid transparent;font-size:14px;font-weight:500;color:var(--text-secondary);transition:var(--transition);white-space:nowrap}.tab-btn:hover{color:var(--primary-color)}.tab-btn.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.admin-main{max-width:1400px;margin:0 auto;padding:24px}.stats-section{display:flex;flex-direction:column;gap:24px}.stats-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.stats-header h2{font-size:22px;color:var(--text-primary)}.period-select{padding:8px 16px;border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:14px;background-color:var(--bg-primary);cursor:pointer;transition:var(--transition)}.period-select:focus{outline:none;border-color:var(--primary-color)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.stats-card{background-color:var(--bg-primary);border-radius:var(--border-radius);padding:20px;box-shadow:var(--shadow-sm);border-left:4px solid;display:flex;align-items:flex-start;gap:16px;transition:var(--transition)}.stats-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stats-icon{width:56px;height:56px;border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stats-content{flex:1;min-width:0}.stats-title{font-size:13px;font-weight:500;color:var(--text-secondary);margin:0 0 6px;text-transform:uppercase;letter-spacing:.5px}.stats-value{font-size:24px;font-weight:700;color:var(--text-primary);margin:0;line-height:1.2}.stats-subtitle{font-size:12px;color:var(--text-muted);margin:4px 0 0}.top-items-section,.low-stock-section{background-color:var(--bg-primary);border-radius:var(--border-radius);padding:20px;box-shadow:var(--shadow-sm)}.top-items-section h3,.low-stock-section h3{font-size:16px;margin-bottom:16px;color:var(--text-primary)}.top-items-list{display:flex;flex-direction:column;gap:12px}.top-item-card{display:flex;align-items:center;gap:16px;padding:12px;background-color:var(--bg-secondary);border-radius:var(--border-radius)}.rank{width:36px;height:36px;background-color:var(--primary-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.item-info{flex:1}.item-info h4{font-size:14px;margin:0 0 4px}.item-info p{font-size:12px;color:var(--text-secondary);margin:0}.low-stock-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.low-stock-card{display:flex;justify-content:space-between;align-items:center;padding:12px;background-color:var(--bg-secondary);border-radius:var(--border-radius);border-left:3px solid var(--warning-color)}.low-stock-card strong{font-size:13px}.stock-badge{background-color:var(--warning-color);color:#fff;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}.menu-table-container,.transaction-table-container,.audit-log-container{background-color:var(--bg-primary);border-radius:var(--border-radius);padding:20px;box-shadow:var(--shadow-sm)}.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}.table-header h3{font-size:18px;color:var(--text-primary)}.filter-group{display:flex;gap:8px}.filter-select{padding:8px 14px;border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:13px;background-color:var(--bg-primary);cursor:pointer}.table-responsive{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table thead{background-color:var(--bg-secondary)}.data-table th{padding:12px 16px;text-align:left;font-weight:600;color:var(--text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);white-space:nowrap}.data-table td{padding:14px 16px;border-bottom:1px solid var(--border-color);color:var(--text-primary);vertical-align:middle}.data-table tbody tr:hover{background-color:var(--bg-secondary)}.empty-row{text-align:center;padding:40px 20px!important;color:var(--text-muted)}.number-cell{font-weight:600;text-align:right;white-space:nowrap}.menu-name-cell{display:flex;align-items:center;gap:12px}.menu-thumb{width:48px;height:48px;border-radius:var(--border-radius);object-fit:cover;flex-shrink:0}.menu-desc{font-size:12px;color:var(--text-muted);margin:4px 0 0;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.items-list{display:flex;flex-direction:column;gap:4px;font-size:12px;max-width:200px}.item-row{padding:2px 0}.action-buttons{display:flex;gap:6px}.icon-btn{width:32px;height:32px;border:none;border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;transition:var(--transition);cursor:pointer}.edit-btn{background-color:#3b82f61a;color:#3b82f6}.edit-btn:hover{background-color:#3b82f6;color:#fff}.delete-btn{background-color:#ef44441a;color:#ef4444}.delete-btn:hover{background-color:#ef4444;color:#fff}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color)}.pagination button{padding:8px 16px;border:1px solid var(--border-color);background-color:var(--bg-primary);border-radius:var(--border-radius);font-size:13px;transition:var(--transition)}.pagination button:hover:not(:disabled){border-color:var(--primary-color);color:var(--primary-color)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.pagination span{font-size:13px;color:var(--text-secondary)}.menu-form{display:flex;flex-direction:column;gap:20px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.form-grid .full-width{grid-column:1 / -1}.log-description{max-width:400px}.log-details{margin-top:8px;font-size:12px}.log-details summary{cursor:pointer;color:var(--primary-color);font-weight:500}.log-details pre{margin-top:8px;padding:12px;background-color:var(--bg-tertiary);border-radius:var(--border-radius);font-size:11px;overflow-x:auto;max-height:200px}.ip-address{font-family:Courier New,monospace;font-size:12px;background-color:var(--bg-tertiary);padding:4px 8px;border-radius:4px;color:var(--text-primary)}.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px 20px;text-align:center}.access-denied h2{color:var(--danger-color);margin-bottom:12px}.access-denied p{color:var(--text-secondary);margin-bottom:24px}@media (max-width: 768px){.admin-tabs{padding:0 12px}.tab-btn{padding:12px 14px;font-size:13px}.admin-main{padding:16px}.stats-grid{grid-template-columns:1fr}.data-table th,.data-table td{padding:10px 12px;font-size:12px}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#f5f7fa,#e8edf3)}.auth-container{width:100%;max-width:440px;background-color:var(--bg-primary);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);padding:40px}.auth-header{text-align:center;margin-bottom:32px}.auth-header svg{margin-bottom:16px}.auth-header h1{font-size:24px;color:var(--text-primary);margin:0 0 8px}.auth-header p{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.6}.auth-form{display:flex;flex-direction:column;gap:4px}.auth-footer{margin-top:24px;text-align:center;padding-top:20px;border-top:1px solid var(--border-color)}.auth-footer p{font-size:14px;color:var(--text-secondary);margin:0}.auth-footer a{color:var(--primary-color);font-weight:600}.auth-footer a:hover{text-decoration:underline}.link-btn{background:none;border:none;color:var(--primary-color);font-weight:600;cursor:pointer;font-size:14px;padding:0}.link-btn:hover{text-decoration:underline}.otp-input-container{margin-bottom:16px}.otp-input-container .input-field{font-size:24px;text-align:center;letter-spacing:12px;font-weight:600;padding:14px}@media (max-width: 480px){.auth-container{padding:28px 20px}.auth-header h1{font-size:20px}.otp-input-container .input-field{font-size:20px;letter-spacing:8px}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #8B4513;--primary-dark: #654321;--primary-light: #D2691E;--secondary-color: #6b7280;--success-color: #10b981;--danger-color: #ef4444;--warning-color: #f59e0b;--info-color: #3b82f6;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--text-primary: #111827;--text-secondary: #6b7280;--text-muted: #9ca3af;--border-color: #e5e7eb;--border-radius: 8px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--transition: all .2s ease}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-secondary);color:var(--text-primary);line-height:1.6}#root{min-height:100vh}a{color:var(--primary-color);text-decoration:none;transition:var(--transition)}a:hover{color:var(--primary-dark)}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}
