.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-container{width:100%;max-width:420px}.login-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;padding:40px}.login-header{text-align:center;margin-bottom:30px}.login-header h1{font-size:32px;margin:0 0 8px;color:#333;font-weight:700}.login-header .subtitle{color:#666;font-size:16px;margin:0}.alert{padding:12px 16px;border-radius:8px;margin-bottom:20px;display:flex;align-items:flex-start;gap:12px;font-size:14px;line-height:1.5}.alert-icon{font-size:18px;flex-shrink:0}.alert-error{background-color:#fef2f2;border:1px solid #fca5a5;color:#dc2626}.alert-success{background-color:#f0fdf4;border:1px solid #86efac;color:#16a34a}.login-form{display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-weight:600;color:#333;font-size:14px}.form-input{padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s,box-shadow .2s}.form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input:disabled{background-color:#f9fafb;color:#9ca3af;cursor:not-allowed}.btn{padding:10px 16px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.btn-primary:hover:not(:disabled){background-color:#5568d3}.btn-block{width:100%}.link-button{background:none;border:none;color:#667eea;text-decoration:none;cursor:pointer;font-size:14px;font-weight:600;padding:0;font-family:inherit;transition:color .2s}.link-button:hover:not(:disabled){color:#5568d3;text-decoration:underline}.link-button:disabled{color:#9ca3af;cursor:not-allowed}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{margin-top:20px;text-align:center}.login-footer p{margin:0;font-size:14px;color:#666}.login-help{margin-top:20px;padding-top:20px;border-top:1px solid #e5e7eb}.help-text{font-size:13px;color:#6b7280;margin:0;text-align:center}@media (max-width: 480px){.login-card{padding:24px}.login-header h1{font-size:28px}.login-header .subtitle{font-size:14px}}} .form-group input{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.error-message{background:#fee;color:#c33;padding:12px;border-radius:8px;font-size:14px;text-align:center}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:14px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:30px;padding-top:20px;border-top:1px solid #e0e0e0}.demo-credentials{font-size:12px;color:#666;line-height:1.6;margin:0;text-align:center}.demo-credentials strong{color:#333;display:block;margin-bottom:8px}@media (max-width: 480px){.login-container{padding:30px 20px}.login-header h1{font-size:28px}}.menu-ocr{display:flex;flex-direction:column;gap:20px}.ocr-header{display:flex;align-items:center;gap:16px}.back-button{background:none;border:none;font-size:18px;color:var(--primary-color);cursor:pointer;padding:8px}.ocr-header h2{margin:0;font-size:24px;color:#333}.ocr-content{display:flex;flex-direction:column;gap:24px}.image-preview{width:100%;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.image-preview img{width:100%;height:auto;display:block}.ocr-progress{display:flex;flex-direction:column;gap:12px}.progress-bar{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--primary-dark));transition:width .3s ease}.status-text{text-align:center;color:#666;font-size:14px;margin:0}.extracted-text{background:#f5f5f5;border-radius:8px;padding:16px;max-height:200px;overflow-y:auto}.extracted-text h3{margin:0 0 12px;font-size:16px;color:#333}.extracted-text pre{margin:0;font-size:12px;line-height:1.6;white-space:pre-wrap;word-wrap:break-word;color:#666}.ocr-actions{display:flex;justify-content:center;gap:12px}.menu-editor{display:flex;flex-direction:column;gap:20px;height:100%}.editor-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.editor-header h2{margin:0;font-size:20px;color:#333;flex:1}.add-button{background:var(--secondary-color);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer}.menu-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.menu-item-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:16px}.menu-item-card.hidden-item{background:#f5f5f5;border-color:#ccc;opacity:.7}.item-display{display:flex;justify-content:space-between;align-items:center;gap:16px}.item-info{flex:1}.item-info h3{margin:0 0 4px;font-size:16px;color:#333}.item-details{margin:0;font-size:14px;color:#666}.item-actions{display:flex;gap:8px}.edit-btn,.delete-btn{background:none;border:none;font-size:18px;cursor:pointer;padding:4px 8px}.edit-btn{color:var(--primary-color)}.delete-btn{color:var(--danger-color)}.edit-form{display:flex;flex-direction:column;gap:12px}.edit-form input,.edit-form select{padding:10px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px}.edit-actions{display:flex;gap:8px}.save-btn,.cancel-btn{flex:1;padding:10px;border:none;border-radius:6px;font-size:14px;cursor:pointer}.save-btn{background:var(--secondary-color);color:#fff}.cancel-btn{background:#e0e0e0;color:#666}.editor-footer{display:flex;gap:12px;padding-top:20px;border-top:1px solid #e0e0e0}.editor-footer button{flex:1}.hidden-toggle{display:flex;align-items:center;gap:8px;margin-top:12px;font-size:14px;cursor:pointer}.hidden-toggle input{cursor:pointer}.hidden-display{opacity:.6}.hidden-badge{background:#f44336;color:#fff;padding:2px 8px;border-radius:4px;font-size:12px;margin-left:8px;font-weight:700}.categories-warning{background-color:#fff3cd;color:#856404;border:1px solid #ffeaa7;padding:12px 16px;border-radius:6px;font-size:14px;margin:0 0 10px}.menu-item-card.legacy-category-item{border-left:4px solid #ff9800;background:#fff8f0}.legacy-warning{background-color:#fff3cd;color:#856404;border:1px solid #ffeaa7;padding:12px;border-radius:6px;font-size:12px;margin-bottom:12px;font-weight:500}.legacy-category-indicator{display:inline-block;background-color:#ff9800;color:#fff;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:500;margin-bottom:8px}.setup-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;display:flex;align-items:center;justify-content:center}.setup-container{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0003;padding:40px;width:100%;max-width:600px}.setup-header{text-align:center;margin-bottom:30px}.setup-header h1{font-size:32px;margin:0 0 10px;color:#333}.setup-header p{color:#666;margin:0}.setup-step{display:flex;flex-direction:column;gap:20px}.setup-step h2{font-size:24px;color:#333;margin:0}.setup-step p{color:#666;margin:0}.skip-section{margin-top:20px;text-align:center;padding-top:20px;border-top:1px solid #e0e0e0}@media (max-width: 480px){.setup-container{padding:30px 20px}.setup-header h1{font-size:28px}}.correction-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:16px}.correction-modal{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.correction-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee;background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff}.correction-modal-header h2{margin:0;font-size:18px}.close-button{background:none;border:none;font-size:24px;cursor:pointer;color:#fff;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.close-button:hover{background:#fff3;border-radius:4px}.close-button:disabled{cursor:not-allowed;opacity:.5}.correction-modal-content{flex:1;padding:20px;overflow-y:auto}.correction-item-info{background:#f5f5f5;border-left:4px solid #2196F3;padding:16px;border-radius:4px;margin-bottom:24px}.correction-item-info h3{margin:0 0 12px;font-size:14px;color:#666;text-transform:uppercase}.original-text{background:#fff;padding:12px;border-radius:4px;font-size:16px;font-weight:500;margin-bottom:12px;border:1px solid #ddd}.classified-as{margin:0;font-size:14px;color:#666;background:#fff;padding:8px 12px;border-radius:4px}.correction-form{display:flex;flex-direction:column;gap:16px}.correction-form label{display:flex;flex-direction:column;gap:8px;font-size:14px;color:#333}.correction-form strong{font-weight:600}.correction-form select,.correction-form textarea{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit}.correction-form select:focus,.correction-form textarea:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 2px #2196f31a}.correction-form select:disabled,.correction-form textarea:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.6}.correction-form textarea{resize:vertical;min-height:80px}.correction-error{background:#ffebee;color:#c62828;padding:12px;border-radius:6px;font-size:14px;border-left:4px solid #c62828}.correction-modal-actions{display:flex;gap:12px;padding:16px 20px;border-top:1px solid #eee;background:#fafafa;justify-content:flex-end}.correction-modal-actions button{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.primary-button{background:#2196f3;color:#fff}.primary-button:hover:not(:disabled){background:#1976d2}.primary-button:disabled{background:#ccc;cursor:not-allowed}.secondary-button{background:#fff;color:#333;border:1px solid #ddd}.secondary-button:hover:not(:disabled){background:#f5f5f5;border-color:#999}.secondary-button:disabled{cursor:not-allowed;opacity:.6}.waiter-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.waiter-header{background:#9c27b0;padding:20px 24px;box-shadow:0 2px 8px #00000026;position:sticky;top:0;z-index:100}.waiter-header-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.waiter-title{margin:0;color:#fff;font-size:32px;font-weight:700;letter-spacing:.5px;text-shadow:0 2px 4px rgba(0,0,0,.2)}.connection-status{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:12px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-weight:600;font-size:14px}.status-dot{width:10px;height:10px;border-radius:50%;animation:pulse 2s infinite}.status-connected{background:#4caf50}.status-disconnected{background:#f44336}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.tables-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;padding:24px;max-width:1400px;margin:0 auto}.table-button{width:100px;height:100px;font-size:24px;font-weight:700;color:#fff;border:none;border-radius:16px;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #00000026;position:relative;overflow:hidden}.table-button:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#fff3,#fff0);opacity:0;transition:opacity .3s}.table-button:hover:before{opacity:1}.table-button:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 8px 20px #00000040}.table-button:active{transform:translateY(-2px) scale(1.02)}.order-form{background:#fffffff2;border-radius:20px;padding:32px;max-width:900px;margin:24px auto;box-shadow:0 8px 32px #00000026}.form-header{font-size:28px;font-weight:700;color:#9c27b0;margin-bottom:24px;display:flex;align-items:center;gap:12px}.table-badge{background:#9c27b0;color:#fff;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;box-shadow:0 4px 12px #9c27b04d}.meta-inputs{display:flex;gap:20px;margin-bottom:20px;flex-wrap:wrap}.input-group label{display:flex;align-items:center;gap:10px;font-weight:600;color:#2c3e50}.input-group input[type=number]{width:80px;padding:8px 12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:all .2s}.input-group input[type=number]:focus{outline:none;border-color:#9c27b0;box-shadow:0 0 0 3px #9c27b01a}.order-items-list{background:#f8f9fa;border-radius:12px;padding:16px;margin-bottom:20px;max-height:300px;overflow-y:auto}.order-item{display:flex;justify-content:space-between;padding:12px;border-bottom:2px dashed #e0e0e0;transition:all .2s}.order-item:last-child{border-bottom:none}.order-item:hover{background:#9c27b00d;border-radius:8px}.item-name{font-size:18px;font-weight:600;color:#2c3e50;display:flex;justify-content:space-between;align-items:center;gap:12px}.item-name.struck{text-decoration:line-through;opacity:.6}.correction-link{background:#ff6b6b;color:#fff;border:none;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}.correction-link:hover{background:#ff5252;transform:scale(1.05)}.correction-link:active{transform:scale(.95)}.correction-link:disabled{background:#ccc;cursor:not-allowed}.preview-modal{max-width:720px}.preview-list{display:flex;flex-direction:column;gap:12px;margin-top:12px}.preview-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border:1px solid #eee;border-radius:8px;background:#fafafa}.preview-item-main{display:flex;flex-direction:column;gap:4px}.preview-item-text{font-weight:600;color:#2c3e50}.preview-item-match{font-size:13px;color:#666}.preview-warning{background:#fff3e0;color:#e65100;padding:10px 12px;border-radius:6px;margin-top:12px}.preview-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:16px}.item-details{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.item-status{font-size:13px;font-weight:600;padding:4px 10px;border-radius:6px;color:#fff}.status-pending{background:#e74c3c}.status-done{background:#27ae60}.status-cancelled{background:#95a5a6}.item-price{font-size:13px;color:#7f8c8d}.order-textarea{width:100%;font-size:18px;padding:16px;border:2px solid #e0e0e0;border-radius:12px;font-family:inherit;resize:vertical;transition:all .2s}.order-textarea:focus{outline:none;border-color:#9c27b0;box-shadow:0 0 0 3px #9c27b01a}.action-buttons{display:flex;gap:12px;margin-top:20px;flex-wrap:wrap;align-items:center}.btn{padding:14px 28px;font-size:18px;font-weight:700;border:none;border-radius:12px;cursor:pointer;transition:all .3s;letter-spacing:.5px}.btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0003}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff}.btn-success{background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff}.btn-secondary{background:#e0e0e0;color:#2c3e50}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.total-badge{margin-left:8px;font-size:18px;font-weight:700;color:#fff;background:linear-gradient(135deg,#4a90e2,#357abd);padding:12px 20px;border-radius:12px;box-shadow:0 4px 12px #4a90e24d}.total-note{font-size:12px;color:#f6f6f6;margin-left:8px;font-weight:400}.waiter-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.waiter-modal{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000004d;max-width:500px;width:90%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.waiter-modal-header{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);padding:24px;color:#fff}.waiter-modal-header h2{margin:0;font-size:20px;font-weight:600}.waiter-modal-content{padding:24px;color:#333;overflow-y:auto}.waiter-modal-content p{margin:0 0 12px;line-height:1.5}.hidden-items-list{list-style:none;margin:12px 0;background:#f9f9f9;border-left:4px solid #ff6b6b;border-radius:8px;padding:12px 16px}.hidden-items-list li{padding:6px 0;color:#d32f2f;font-weight:500}.hidden-items-list li:not(:last-child){border-bottom:1px solid #e0e0e0}.waiter-modal-actions{padding:16px 24px;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end;gap:12px}.waiter-modal-actions .primary-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;font-size:16px}.waiter-modal-actions .primary-button:hover{opacity:.9}.menu-reference{margin:16px;padding:12px 16px;background:#fff3cd;border-radius:12px;border:2px solid #ff6b6b}.menu-reference h3{margin:0 0 10px;color:#d32f2f;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.hidden-items-display{display:flex;flex-wrap:wrap;gap:6px}.hidden-item-tag{background:#ff6b6b;color:#fff;padding:6px 12px;border-radius:16px;font-size:12px;font-weight:600;border:1px solid #d32f2f;transition:all .2s ease;white-space:nowrap}.hidden-item-tag:hover{background:#d32f2f;transform:scale(1.05)}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.home-page{min-height:100vh;display:flex;flex-direction:column;background:#f5f5f5}.app-header{background:#fff;padding:16px 20px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center;gap:12px}.header-left h1{margin:0;font-size:24px;color:#333}.header-info{display:flex;flex-direction:column;gap:4px}.user-badge{background:var(--primary-color);color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.role-badge{background:#e8f4f8;color:#0288d1;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.header-right{display:flex;gap:8px}.tab-navigation{background:#fff;display:flex;border-bottom:1px solid #e0e0e0;overflow-x:auto}.tab{flex:1;min-width:100px;padding:16px;background:none;border:none;border-bottom:3px solid transparent;font-size:16px;font-weight:600;color:#666;cursor:pointer;transition:all .3s}.tab.active{color:#333}.tab:hover{background:#f5f5f5}.tab-content{flex:1;overflow-y:auto}.view-container{padding:20px;max-width:1200px;margin:0 auto}.view-container h2{margin:0 0 16px;font-size:24px;color:#333}.view-container p{color:#666;line-height:1.6}.create-user-form{padding:20px}.btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit}.users-page{display:flex;flex-direction:column;gap:20px;height:100%}.users-header{display:flex;justify-content:space-between;align-items:center;gap:16px}.users-header h1{margin:0;font-size:20px;color:#333;flex:1}.btn{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit}.btn-primary{background-color:var(--secondary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:#45a049}.loading{text-align:center;padding:40px;color:#666;font-size:16px}.empty-state{text-align:center;padding:60px 20px;color:#999}.empty-state p{margin:0;font-size:16px}.users-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-x:auto}.users-table{width:100%;border-collapse:collapse;font-size:14px}.users-table thead{background-color:#f5f5f5;border-bottom:2px solid #ddd}.users-table th{padding:16px;text-align:left;font-weight:600;color:#333}.users-table td{padding:16px;border-bottom:1px solid #eee;color:#666}.users-table tbody tr:hover{background-color:#f9f9f9}.username-cell{font-weight:500;color:#333}.roles-cell{min-width:300px}.date-cell{white-space:nowrap;font-size:12px}.actions-cell{min-width:320px;width:320px}.roles-display{display:flex;flex-wrap:wrap;gap:8px}.role-badge{display:inline-block;background-color:#e3f2fd;color:#1976d2;padding:4px 12px;border-radius:16px;font-size:12px;font-weight:500}.no-roles{color:#999;font-style:italic}.roles-edit{display:flex;align-items:center}.role-select{width:100%;padding:10px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;font-family:inherit;background:#fff}.role-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a}.action-buttons{display:flex;flex-wrap:wrap;gap:6px}.action-buttons .btn{padding:6px 10px;font-size:11px;white-space:nowrap}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:flex-start;justify-content:center;z-index:1000;padding-top:2rem;overflow-y:auto}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#333;font-size:14px}.form-group input[type=text],.form-group input[type=password]{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s;box-sizing:border-box}.form-group input[type=text]:focus,.form-group input[type=password]:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error{display:block;color:var(--danger-color);font-size:12px;margin-top:4px}.modal-footer{display:flex;gap:12px;padding:20px;border-top:1px solid #e0e0e0;justify-content:flex-end}@media (max-width: 768px){.users-page{padding:12px}.users-header{flex-direction:column;align-items:flex-start}.users-header h1{font-size:24px}.users-header .btn{width:100%}.users-table{font-size:12px}.users-table th,.users-table td{padding:12px 8px}.username-cell{min-width:120px}.roles-cell{min-width:150px}.actions-cell{min-width:200px;width:200px}.action-buttons{flex-direction:column}.action-buttons .btn{width:100%}.modal-content{width:95%}}@media (max-width: 480px){.users-page{padding:8px}.users-table{font-size:11px}.users-table th,.users-table td{padding:8px 4px}.modal-content{width:100%;border-radius:0;max-height:100vh}}.restaurant-profile{max-width:700px;margin:0 auto;padding:20px}.profile-header{margin-bottom:30px}.profile-header h2{margin:0 0 5px;color:#333;font-size:24px}.last-updated{margin:5px 0 0;color:#999;font-size:12px;font-style:italic}.alert{padding:12px 16px;margin-bottom:15px;border-radius:6px;font-size:14px;animation:slideIn .3s ease-out}.alert-error{background-color:#fee;color:#c33;border-left:4px solid #c33}.alert-success{background-color:#efe;color:#3c3;border-left:4px solid #3c3}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.profile-form{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;padding:20px;margin-bottom:30px}.form-group{margin-bottom:18px}.form-group label{display:block;margin-bottom:5px;font-weight:600;color:#333;font-size:14px}.required{color:#c33}.form-input,.form-textarea{width:100%;padding:10px 12px;border:1px solid #ccc;border-radius:4px;font-family:inherit;font-size:14px;box-sizing:border-box;transition:border-color .2s}.form-input:focus,.form-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input:disabled,.form-textarea:disabled{background-color:#f0f0f0;color:#999;cursor:not-allowed}.form-textarea{resize:vertical;font-family:Courier New,monospace;font-size:12px}.form-hint{display:block;margin-top:5px;color:#999;font-size:12px}.form-actions{display:flex;gap:10px;margin-top:20px}.btn{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;flex:1}.btn-primary{background-color:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background-color:#5568d3;box-shadow:0 2px 8px #667eea4d}.btn-secondary{background-color:#999;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#777}.profile-preview{background:#fff;border:1px solid #ddd;border-radius:8px;padding:20px}.profile-preview h3{margin-top:0;margin-bottom:15px;color:#333;font-size:16px}.preview-item{display:flex;align-items:flex-start;padding:10px 0;border-bottom:1px solid #f0f0f0}.preview-item:last-child{border-bottom:none}.preview-item .label{display:inline-block;width:120px;font-weight:600;color:#666;font-size:13px}.preview-item .value{flex:1;color:#333;font-size:13px;word-wrap:break-word}.preview-item pre{margin:5px 0 0;padding:10px;background:#f5f5f5;border-radius:4px;font-size:11px;overflow-x:auto;color:#666}.profile-loading{text-align:center;padding:40px 20px;color:#999;font-size:14px}@media (max-width: 600px){.restaurant-profile{padding:15px}.profile-header h2{font-size:20px}.form-actions{flex-direction:column}.btn{width:100%}.preview-item{flex-direction:column}.preview-item .label{width:100%;margin-bottom:5px}}.analytics-section{display:flex;flex-direction:column;gap:1.5rem;padding:.25rem 0}.analytics-title{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary, #1a1a1a)}.analytics-controls{display:flex;gap:.75rem;align-items:flex-end;flex-wrap:wrap}.analytics-date-group{display:flex;flex-direction:column;gap:.35rem}.analytics-date-group label{font-size:.8rem;font-weight:600;color:var(--text-secondary, #6b7280)}.analytics-date-group input{border:1px solid var(--border-color, #e5e7eb);border-radius:8px;padding:.45rem .55rem;background:var(--surface-color, #fff);color:var(--text-primary, #1a1a1a)}.analytics-refresh-btn{border:none;border-radius:8px;padding:.5rem .95rem;background:var(--primary-color, #4f46e5);color:#fff;font-size:.88rem;font-weight:600;cursor:pointer;transition:opacity .15s ease}.analytics-refresh-btn:hover{opacity:.88}.analytics-tabs{display:flex;gap:.5rem;flex-wrap:wrap}.analytics-tab{border:1px solid var(--border-color, #e5e7eb);border-radius:999px;background:var(--surface-color, #fff);color:var(--text-secondary, #6b7280);font-size:.88rem;font-weight:600;padding:.45rem .85rem;cursor:pointer;transition:all .15s ease}.analytics-tab:hover{color:var(--text-primary, #1a1a1a);border-color:var(--primary-color, #4f46e5)}.analytics-tab.active{color:#fff;background:var(--primary-color, #4f46e5);border-color:var(--primary-color, #4f46e5)}.analytics-tab-content{display:flex;flex-direction:column;gap:1.2rem}.analytics-kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.analytics-kpi-card{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;padding:1rem 1.1rem;background:var(--surface-color, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:10px;box-shadow:0 1px 3px #0000000f;min-height:110px;transition:box-shadow .15s ease}.analytics-kpi-card:hover{box-shadow:0 3px 8px #0000001a}.analytics-kpi-icon{font-size:1.4rem;line-height:1;margin-bottom:.15rem}.analytics-kpi-label{font-size:.75rem;color:var(--text-secondary, #6b7280);line-height:1.3}.analytics-kpi-value{font-size:1.6rem;font-weight:700;color:var(--primary-color, #4f46e5);line-height:1.1;letter-spacing:-.02em}.analytics-kpi-value--text{font-size:1.1rem;font-weight:600;text-transform:capitalize}.analytics-kpi-change{font-size:.75rem;font-weight:600;padding:.1rem .35rem;border-radius:4px}.analytics-kpi-change.positive{color:#16a34a;background:#dcfce7}.analytics-kpi-change.negative{color:#dc2626;background:#fee2e2}.analytics-top-items{background:var(--surface-color, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:10px;padding:1.1rem 1.25rem}.analytics-top-items-title{margin:0 0 .85rem;font-size:1rem;font-weight:600;color:var(--text-primary, #1a1a1a)}.analytics-top-items-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.analytics-top-item{display:flex;align-items:center;gap:.75rem;padding:.55rem .75rem;background:var(--background-color, #f9fafb);border-radius:7px;font-size:.9rem}.analytics-top-item-rank{font-weight:700;font-size:.75rem;color:var(--text-secondary, #6b7280);min-width:2rem}.analytics-top-item-name{flex:1;font-weight:500;color:var(--text-primary, #1a1a1a)}.analytics-top-item-qty{font-weight:600;color:var(--primary-color, #4f46e5);font-size:.85rem}.analytics-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;text-align:center;gap:.4rem}.analytics-empty-icon{font-size:2.5rem;line-height:1}.analytics-empty-text{margin:0;font-size:.95rem;color:var(--text-primary, #1a1a1a);font-weight:500}.analytics-empty-subtext{margin:0;font-size:.82rem;color:var(--text-secondary, #6b7280)}.alert.alert-error{padding:.75rem 1rem;border-radius:8px;background:#fee2e2;color:#991b1b;font-size:.9rem;font-weight:500}.analytics-retry-btn{align-self:flex-start;padding:.5rem 1.1rem;background:var(--primary-color, #4f46e5);color:#fff;border:none;border-radius:7px;font-size:.875rem;font-weight:500;cursor:pointer;transition:opacity .15s ease}.analytics-retry-btn:hover{opacity:.85}.analytics-table-wrap{background:var(--surface-color, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:10px;overflow:auto}.analytics-chart-wrap{background:var(--surface-color, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:10px;overflow:auto;padding:8px 0 4px}.analytics-table{width:100%;border-collapse:collapse;min-width:420px}.analytics-table th,.analytics-table td{padding:.75rem .9rem;text-align:left;border-bottom:1px solid var(--border-color, #e5e7eb);font-size:.9rem}.analytics-table th{background:#f8fafc;color:var(--text-secondary, #6b7280);font-weight:600}.analytics-table td{color:var(--text-primary, #1a1a1a)}.analytics-tab-loading,.analytics-tab-empty{background:var(--surface-color, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:10px;padding:1rem;color:var(--text-secondary, #6b7280);font-size:.92rem}.analytics-tab-feedback{display:flex;flex-direction:column;gap:.75rem}.analytics-skeleton{border-radius:10px;background:linear-gradient(90deg,var(--border-color, #e5e7eb) 25%,#f3f4f6 50%,var(--border-color, #e5e7eb) 75%);background-size:200% 100%;animation:analytics-shimmer 1.4s infinite}.analytics-kpi-card.analytics-skeleton{min-height:110px;border:none;box-shadow:none}.analytics-skeleton-title{height:1.2rem;width:55%;margin-bottom:.85rem;border-radius:6px}.analytics-skeleton-row{height:2.5rem;width:100%;border-radius:7px;margin-bottom:.5rem}@keyframes analytics-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media (max-width: 480px){.analytics-kpi-grid{grid-template-columns:repeat(2,1fr)}.analytics-kpi-value{font-size:1.3rem}}.admin-page{min-height:100vh;background:#f5f5f5;display:flex;flex-direction:column}.admin-header{background:#fff;padding:20px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:16px}.admin-header h1{margin:0;font-size:24px;color:#333}.admin-navigation{background:#fff;display:flex;border-bottom:1px solid #e0e0e0}.admin-navigation button{flex:1;padding:16px;background:none;border:none;border-bottom:3px solid transparent;font-size:16px;font-weight:600;color:#666;cursor:pointer;transition:all .3s}.admin-navigation button.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.admin-content{flex:1;padding:20px;overflow-y:auto}.section{max-width:800px;margin:0 auto}.section h2{margin:0 0 20px;font-size:24px;color:#333}.user-list,.endpoint-list{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.user-card,.endpoint-card{background:#fff;border-radius:8px;padding:16px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a}.user-info,.endpoint-info{flex:1}.user-info h3,.endpoint-info h3{margin:0 0 4px;font-size:16px;color:#333}.user-info p,.endpoint-info p{margin:0;font-size:14px;color:#666}.endpoint-color{width:40px;height:40px;border-radius:8px;margin-right:16px}.delete-btn{background:var(--danger-color);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer}.delete-btn:disabled{opacity:.5;cursor:not-allowed}.delete-btn:hover:not(:disabled){background:#da190b}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:flex-start;justify-content:center;padding-top:2rem;z-index:1000;overflow-y:auto}.modal-content{background:#fff;border-radius:12px;box-shadow:0 4px 16px #00000026;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:20px;color:#333}.close-btn{background:none;border:none;font-size:28px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.close-btn:hover{color:#333}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px;border-top:1px solid #e0e0e0}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:#333}.form-group input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a}.form-group input[type=color]{padding:4px;height:44px;cursor:pointer}.btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit;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);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.btn-cancel{background-color:#e0e0e0;color:#333}.btn-cancel:hover:not(:disabled){background-color:#d0d0d0}.btn-danger{background-color:var(--danger-color);color:#fff}.btn-danger:hover:not(:disabled){background-color:#da190b}.btn-success{background-color:var(--secondary-color);color:#fff}.btn-success:hover:not(:disabled){background-color:#45a049}.btn-small{padding:6px 12px;font-size:12px}.endpoint-color-edit{margin-right:16px}.endpoint-color-edit input{width:40px;height:40px;border-radius:8px;border:none;cursor:pointer}.alert{padding:12px 16px;border-radius:6px;font-size:14px;margin-bottom:16px;animation:slideInDown .3s ease-out}@keyframes slideInDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.alert-error{background-color:#ffebee;color:#c62828;border:1px solid #ef5350}.alert-success{background-color:#e8f5e9;color:#2e7d32;border:1px solid #66bb6a}.danger-button{background-color:var(--danger-color);color:#fff;padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.danger-button:hover:not(:disabled){background-color:#da190b;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.danger-button:disabled{opacity:.6;cursor:not-allowed}.info-text{color:#666;font-size:14px;font-style:italic}.menu-actions{background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 4px #0000001a}.warning-text{color:var(--danger-color);font-size:14px;margin-top:12px}.menu-editor{padding:24px;max-width:1200px;margin:0 auto}.menu-editor-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.menu-editor-header h1{margin:0}.menu-editor-header p{margin:4px 0 0;color:#666}.menu-editor-body{display:grid;grid-template-columns:240px 1fr;gap:24px;align-items:start}.menu-editor-sidebar{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #00000014}.menu-editor-sidebar h2{margin:0 0 12px;font-size:18px}.menu-editor-sidebar ul{list-style:none;padding:0;margin:0}.menu-editor-sidebar li+li{margin-top:8px}.menu-editor-sidebar button{width:100%;text-align:left;padding:10px 12px;border:1px solid #e0e0e0;border-radius:10px;background:#f9f9f9;cursor:pointer;display:flex;flex-direction:column;gap:4px}.menu-editor-sidebar button.active{border-color:#0070f3;background:#eef5ff}.menu-editor-panel{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #00000014}.menu-editor-info{background:#fff7e6;color:#8a5a00;padding:10px 12px;border-radius:8px;margin-bottom:16px}.menu-add-form{border-bottom:1px solid #eee;padding-bottom:16px;margin-bottom:16px}.menu-add-form h2{margin:0 0 12px}.menu-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:12px}.menu-form-grid input,.menu-form-grid select{padding:8px 10px;border:1px solid #ddd;border-radius:8px}.menu-sections{display:flex;flex-direction:column;gap:16px}.menu-section h3{margin:0 0 8px}.menu-section table{width:100%;border-collapse:collapse}.menu-item-hidden{opacity:.5}.menu-section th,.menu-section td{padding:8px 10px;border-bottom:1px solid #eee;text-align:left}.menu-section-empty{color:#888}.menu-editor-error{background:#ffecec;color:#a10000;padding:10px 12px;border-radius:8px;margin-bottom:12px}.primary-button,.ghost-button,.danger-button{padding:8px 12px;border-radius:8px;border:none;cursor:pointer}.primary-button{background:#0070f3;color:#fff}.ghost-button{background:#f0f0f0;color:#333;margin-right:8px}.danger-button{background:#fbeaea;color:#b00020}.danger-button.delete-button{background:#ffcdd2;color:#c62828;font-weight:600}.menu-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.menu-modal{background:#fff;padding:20px;border-radius:12px;width:min(480px,90vw);display:flex;flex-direction:column;gap:12px}.menu-modal label{display:flex;flex-direction:column;gap:6px;font-size:14px}.menu-modal input,.menu-modal select,.menu-modal textarea{padding:8px 10px;border:1px solid #ddd;border-radius:8px}.menu-modal textarea{min-height:80px}.menu-modal-actions{display:flex;justify-content:flex-end;gap:8px}@media (max-width: 900px){.menu-editor-body{grid-template-columns:1fr}}.nlp-review-page{padding:24px}.nlp-review-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.nlp-review-header h1{margin:0;flex:1}.refresh-button,.back-button{background:#f5f5f5;border:1px solid #ddd;padding:8px 12px;border-radius:6px;cursor:pointer;font-weight:600}.refresh-button:disabled{opacity:.6;cursor:not-allowed}.rules-table-wrapper{overflow-x:auto;background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000d}.rules-table{width:100%;border-collapse:collapse}.rules-table th,.rules-table td{padding:12px 16px;border-bottom:1px solid #eee;text-align:left}.rules-table th{background:#fafafa;font-size:14px;text-transform:uppercase;letter-spacing:.5px;color:#666}.rule-input,.rule-select{width:100%;padding:8px 10px;border:1px solid #ddd;border-radius:6px;font-size:14px}.rule-actions{display:flex;gap:8px}.btn-save,.btn-delete{border:none;padding:8px 12px;border-radius:6px;font-weight:600;cursor:pointer}.btn-save{background:#4caf50;color:#fff}.btn-save:disabled{background:#a5d6a7;cursor:not-allowed}.btn-delete{background:#f44336;color:#fff}.error-text{background:#ffebee;color:#c62828;padding:12px;border-radius:6px;margin-bottom:12px}.info-text{color:#666}.orders-history-page{padding:1rem;max-width:1200px;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.history-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.back-button{background:#6c757d;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background .2s}.history-header h1{margin:0;font-size:1.75rem;color:#333}.history-filters{background:#f8f9fa;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem;display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:.25rem}.filter-group label{font-weight:600;font-size:.875rem;color:#555}.filter-group input{padding:.5rem;border:1px solid #ced4da;border-radius:4px;font-size:1rem;min-width:150px}.filter-actions{display:flex;gap:.5rem;margin-left:auto}.search-button,.clear-button{padding:.5rem 1.5rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .2s}.search-button{background:#007bff;color:#fff}.search-button:hover:not(:disabled){background:#0056b3}.search-button:disabled{background:#6c757d;cursor:not-allowed}.clear-button{background:#6c757d;color:#fff}.clear-button:hover{background:#5a6268}.history-error{background:#f8d7da;color:#721c24;padding:1rem;border-radius:6px;margin-bottom:1rem;border:1px solid #f5c6cb}.history-loading,.history-empty{text-align:center;padding:3rem;font-size:1.125rem;color:#6c757d}.history-list{display:grid;gap:1rem;margin-bottom:2rem}.history-item{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:1rem;cursor:pointer;transition:all .2s}.history-item:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px);border-color:#007bff}.receipt-header{display:flex;justify-content:space-between;margin-bottom:.5rem}.receipt-table{font-weight:700;font-size:1.125rem;color:#333}.receipt-date{font-size:.875rem;color:#6c757d}.receipt-details{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:1rem}.receipt-items{color:#6c757d}.receipt-total{font-weight:700;font-size:1.125rem;color:#28a745}.receipt-id{font-size:.75rem;color:#adb5bd;font-family:Courier New,monospace}.history-pagination{display:flex;justify-content:center;align-items:center;gap:1rem;padding:2rem 0}.page-button{padding:.5rem 1rem;background:#007bff;color:#fff;border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:background .2s}.page-button:hover:not(:disabled){background:#0056b3}.page-button:disabled{background:#6c757d;cursor:not-allowed;opacity:.5}.page-info{font-size:.875rem;color:#6c757d}@media (max-width: 768px){.orders-history-page{padding:.5rem}.history-header h1{font-size:1.25rem}.history-filters{flex-direction:column;align-items:stretch}.filter-group input{min-width:100%}.filter-actions{margin-left:0;flex-direction:column}.search-button,.clear-button{width:100%}.receipt-header,.receipt-details{flex-direction:column;gap:.25rem}.history-pagination{flex-direction:column;gap:.5rem}.page-button{width:100%}}.receipt-view-page{min-height:100vh;background:#f0f0f0;padding:1rem}.receipt-loading,.receipt-error{text-align:center;padding:3rem;font-size:1.125rem;color:#6c757d}.receipt-error{color:#dc3545;background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;margin-bottom:1rem}.receipt-controls{max-width:800px;margin:0 auto 1rem;display:flex;gap:1rem;justify-content:space-between}.back-button,.print-button{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .2s}.back-button{background:#6c757d;color:#fff}.back-button:hover{background:#5a6268}.print-button{background:#007bff;color:#fff}.print-button:hover{background:#0056b3}.receipt-content{max-width:800px;margin:0 auto;background:#fff;padding:2rem;box-shadow:0 2px 8px #0000001a;border-radius:8px;font-family:Courier New,Courier,monospace}.receipt-restaurant{text-align:center;margin-bottom:1.5rem;border-bottom:2px solid #333;padding-bottom:1rem}.receipt-restaurant h1{margin:0 0 .5rem;font-size:2rem;font-weight:700;letter-spacing:2px}.restaurant-details{margin:0;font-size:.875rem;color:#555;line-height:1.6}.receipt-info{margin-bottom:1rem}.receipt-row{display:flex;justify-content:space-between;padding:.25rem 0;font-size:.875rem}.receipt-row .label{font-weight:600;color:#333}.receipt-row .value{color:#555}.receipt-divider{border:none;border-top:1px dashed #999;margin:1rem 0}.receipt-items-table{width:100%;border-collapse:collapse;margin-bottom:1rem;font-size:.875rem}.receipt-items-table th{text-align:left;padding:.5rem .25rem;border-bottom:2px solid #333;font-weight:700;color:#333}.receipt-items-table td{padding:.5rem .25rem;border-bottom:1px solid #ddd;color:#555}.item-name-col{width:50%}.item-qty-col,.item-price-col,.item-total-col{text-align:right;width:16.66%}.item-name{font-weight:500}.item-qty,.item-price,.item-total{text-align:right}.receipt-totals{margin-top:1rem}.receipt-totals .receipt-row{font-size:1rem;padding:.5rem 0}.total-row{border-top:2px solid #333;margin-top:.5rem;padding-top:.75rem!important;font-size:1.25rem!important;font-weight:700}.total-row .label,.total-row .value{font-weight:700;color:#000}.receipt-footer{text-align:center;margin-top:2rem;padding-top:1rem;border-top:2px solid #333}.receipt-footer p{margin:.5rem 0;font-size:1rem;color:#333}.receipt-footer-small{font-size:.75rem!important;color:#999!important}@media print{.receipt-view-page{background:#fff;padding:0}.no-print{display:none!important}.receipt-content{box-shadow:none;border-radius:0;max-width:100%;padding:1rem}.receipt-restaurant h1{font-size:1.5rem}.receipt-items-table,.receipt-row{font-size:.75rem}.total-row{font-size:1rem!important}}@media (max-width: 768px){.receipt-view-page{padding:.5rem}.receipt-content{padding:1rem}.receipt-controls{flex-direction:column}.back-button,.print-button{width:100%}.receipt-restaurant h1{font-size:1.5rem}.receipt-items-table{font-size:.75rem}.receipt-items-table th,.receipt-items-table td{padding:.25rem}.item-name-col{width:40%}.item-qty-col,.item-price-col,.item-total-col{width:20%}}*{box-sizing:border-box;margin:0;padding:0}:root{--primary-color: #667eea;--primary-dark: #764ba2;--secondary-color: #4CAF50;--danger-color: #f44336;--warning-color: #ff9800;--info-color: #2196F3;--text-primary: #333;--text-secondary: #666;--text-light: #999;--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--border-color: #e0e0e0;--shadow: 0 2px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .15)}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}.container{max-width:1200px;margin:0 auto;padding:20px}.card{background:var(--bg-primary);border-radius:12px;padding:20px;box-shadow:var(--shadow)}.button-group{display:flex;gap:12px;flex-wrap:wrap}button{font-family:inherit;font-size:16px;cursor:pointer;transition:all .3s ease}.primary-button{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600}.primary-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.primary-button:disabled{opacity:.6;cursor:not-allowed}.secondary-button{background:#fff;color:var(--primary-color);border:2px solid var(--primary-color);padding:12px 24px;border-radius:8px;font-weight:600}.secondary-button:hover:not(:disabled){background:var(--primary-color);color:#fff}.text-button{background:none;border:none;color:var(--primary-color);text-decoration:underline;padding:8px}.danger-button{background:var(--danger-color);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600}.icon-button{background:none;border:none;padding:8px;color:var(--text-secondary);font-size:20px}.spinner{border:3px solid var(--border-color);border-top:3px solid var(--primary-color);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:20px auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.container,.card{padding:16px}button{font-size:14px}.primary-button,.secondary-button,.danger-button{padding:10px 20px}}@supports (padding: max(0px)){body{padding-top:max(0px,env(safe-area-inset-top));padding-bottom:max(0px,env(safe-area-inset-bottom));padding-left:max(0px,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right))}}
