:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color:#2b1a19;background-color:#f9f3f2;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-primary: #cd3834;--color-primary-dark: #cd3834;--color-primary-darker: #cd3834;--color-primary-light: #e9635b;--color-primary-softer: #fbe1df;--color-primary-contrast: #fff7f6;--color-surface: #ffffff;--color-surface-muted: #fdf1f0;--color-border: rgba(211, 69, 60, .25);--color-border-strong: rgba(211, 69, 60, .4);--color-text-muted: #5b3734;--color-info: #365abf;--color-info-light: #e5ecff;--color-error: #b91c1c;--color-success: #047857}body{margin:0;min-height:100vh;background-color:#f9f3f2}a{color:inherit;text-decoration:none}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);padding:20px}.login-box{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000001a;padding:40px;width:100%;max-width:400px}.login-box h1{margin:0 0 8px;font-size:1.75rem;font-weight:700;color:var(--color-primary, #D3453C);text-align:center}.login-subtitle{margin:0 0 32px;color:var(--color-text-secondary, #6b7280);text-align:center;font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:20px}.login-field{display:flex;flex-direction:column;gap:8px}.login-field label{font-weight:600;color:var(--color-text-primary, #111827);font-size:.9rem}.login-field input{padding:12px 16px;border:2px solid var(--color-border, #e5e7eb);border-radius:8px;font-size:1rem;transition:border-color .2s}.login-field input:focus{outline:none;border-color:var(--color-primary, #D3453C)}.login-field input:disabled{background:#f3f4f6;cursor:not-allowed}.login-error{padding:12px;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.9rem;text-align:center}.login-button{padding:14px 24px;background:var(--color-primary, #D3453C);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.login-button:hover:not(:disabled){background:var(--color-primary-dark, #B71C1C);transform:translateY(-1px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.dashboard-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:24px}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:16px}.dashboard-spinner{width:50px;height:50px;border:4px solid #e5e7eb;border-top-color:#d3453c;border-radius:50%;animation:spin 1s linear infinite}.dashboard-loading p{color:var(--color-text-secondary, #6b7280);font-size:1.1rem}.dashboard-header{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:24px;padding:24px 32px}.dashboard-header-content{display:flex;justify-content:space-between;align-items:center}.dashboard-header h1{margin:0 0 8px;font-size:1.75rem;font-weight:700;color:var(--color-text-primary, #111827);display:flex;align-items:center;gap:8px}.dashboard-user{margin:0;color:var(--color-text-secondary, #6b7280);font-size:.95rem;font-weight:500}.dashboard-header-actions{display:flex;gap:12px;align-items:center}.dashboard-btn-admin{background:#2563eb;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:600;transition:background .2s}.dashboard-btn-admin:hover{background:#1d4ed8}.dashboard-logout{padding:10px 24px;background:var(--color-primary, #D3453C);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #d3453c4d}.dashboard-logout:hover{background:var(--color-primary-dark, #B71C1C);transform:translateY(-2px);box-shadow:0 4px 12px #d3453c66}.dashboard-filters{background:#fff;padding:20px 32px;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:24px;display:flex;align-items:center;gap:16px}.dashboard-filter-icon{margin-right:4px}.dashboard-filters label{font-weight:600;color:var(--color-text-primary, #111827);display:flex;align-items:center}.dashboard-select{padding:12px 20px;border:2px solid var(--color-border, #e5e7eb);border-radius:10px;font-size:1rem;min-width:250px;cursor:pointer;background:#fff;transition:all .2s}.dashboard-select:focus{outline:none;border-color:var(--color-primary, #D3453C);box-shadow:0 0 0 3px #d3453c1a}.dashboard-error{background:#fee2e2;border:1px solid #fecaca;color:#dc2626;padding:16px 24px;border-radius:12px;margin-bottom:24px;display:flex;align-items:center;gap:12px;font-weight:500}.dashboard-error-icon{font-size:1.2rem}.dashboard-content{display:flex;flex-direction:column;gap:24px}.dashboard-section{background:#fff;padding:32px;border-radius:16px;box-shadow:0 4px 20px #00000014}.dashboard-section-title{margin:0 0 24px;font-size:1.5rem;font-weight:700;color:var(--color-text-primary, #111827);display:flex;align-items:center;gap:12px}.dashboard-icon{font-size:1.5rem}.dashboard-overview{padding:32px}.dashboard-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px}.dashboard-metric-card{background:linear-gradient(135deg,#fff,#f8f9fa);padding:24px;border-radius:16px;display:flex;align-items:center;gap:20px;transition:all .3s;border:2px solid transparent;position:relative;overflow:hidden}.dashboard-metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--metric-color, #D3453C)}.dashboard-metric-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:var(--metric-color, #D3453C)}.dashboard-metric-primary{--metric-color: #D3453C}.dashboard-metric-success{--metric-color: #10b981}.dashboard-metric-info{--metric-color: #2563eb}.dashboard-metric-warning{--metric-color: #f59e0b}.dashboard-metric-icon{font-size:3rem;width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--metric-color, #D3453C)15,rgba(211,69,60,.1));border-radius:16px;flex-shrink:0}.dashboard-metric-content{flex:1}.dashboard-metric-label{font-size:.9rem;color:var(--color-text-secondary, #6b7280);font-weight:500;margin-bottom:8px}.dashboard-metric-value{font-size:2.5rem;font-weight:700;color:var(--metric-color, #D3453C);line-height:1;margin-bottom:8px}.dashboard-metric-subtext{font-size:.85rem;color:var(--color-text-secondary, #6b7280)}.dashboard-chart-container{margin-top:16px;padding:16px;background:#fafbfc;border-radius:12px;border:1px solid #e5e7eb}.dashboard-charts-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:24px}.dashboard-section-half{padding:28px}.dashboard-section-full{padding:32px;grid-column:1 / -1}.dashboard-empty{background:#fff;border-radius:16px;padding:80px 32px;text-align:center;box-shadow:0 4px 20px #00000014}.dashboard-empty-icon{font-size:4rem;margin-bottom:16px}.dashboard-empty h3{margin:0 0 8px;color:var(--color-text-primary, #111827);font-size:1.5rem}.dashboard-empty p{margin:0;color:var(--color-text-secondary, #6b7280)}@media(max-width:1200px){.dashboard-charts-row{grid-template-columns:1fr}}@media(max-width:768px){.dashboard-container{padding:16px}.dashboard-header-content{flex-direction:column;align-items:flex-start;gap:16px}.dashboard-header{padding:20px 24px}.dashboard-header h1{font-size:1.5rem}.dashboard-metrics-grid{grid-template-columns:1fr}.dashboard-metric-card{flex-direction:column;text-align:center}.dashboard-metric-icon{width:60px;height:60px;font-size:2rem}.dashboard-metric-value{font-size:2rem}.dashboard-section{padding:20px}.dashboard-filters{flex-direction:column;align-items:stretch;padding:16px 20px}.dashboard-select{width:100%;min-width:unset}.dashboard-chart-container{padding:8px;overflow-x:auto}}.dashboard-table-container{margin-top:16px;overflow-x:auto;border-radius:12px;border:1px solid #e5e7eb;background:#fafbfc}.dashboard-table-detailed{font-size:.95rem;width:100%;border-collapse:collapse;background:#fff}.dashboard-table-detailed th{white-space:nowrap;padding:14px 16px;font-weight:600;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:2px solid var(--color-primary, #D3453C);text-align:left}.dashboard-table-detailed th.dashboard-table-number{text-align:right}.dashboard-table-detailed td{padding:14px 16px;vertical-align:middle;border-bottom:1px solid #e5e7eb}.dashboard-table-product{min-width:200px;max-width:300px}.dashboard-table-product strong{display:block;color:var(--color-text-primary, #111827);margin-bottom:4px;font-size:1rem}.dashboard-table-category{display:inline-block;font-size:.75rem;color:var(--color-text-secondary, #6b7280);background:#f3f4f6;padding:3px 8px;border-radius:6px;margin-top:4px;font-weight:500}.dashboard-table-number{text-align:right;font-weight:600;font-variant-numeric:tabular-nums;font-size:1rem}.dashboard-table-added{color:#10b981}.dashboard-table-removed{color:#ef4444}.dashboard-table-shared{color:#2563eb}.dashboard-table-users{color:var(--color-primary, #D3453C)}.dashboard-table-detailed tbody tr{transition:all .2s}.dashboard-table-detailed tbody tr:hover{background:linear-gradient(90deg,rgba(211,69,60,.05) 0%,transparent 100%);transform:scale(1.002);box-shadow:0 2px 8px #0000000d}@media(max-width:768px){.dashboard-table-detailed{font-size:.85rem}.dashboard-table-detailed th,.dashboard-table-detailed td{padding:10px 8px}.dashboard-table-product{min-width:150px;max-width:200px}.dashboard-table-product strong{font-size:.9rem}}.admin-users-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:24px}.admin-users-header{background:#fff;border-radius:16px;padding:24px 32px;margin-bottom:24px;box-shadow:0 4px 20px #00000014;display:flex;justify-content:space-between;align-items:center}.admin-users-header h1{margin:0;color:var(--color-text-primary, #111827);font-size:2rem;font-weight:700}.logout-button{background:#ef4444;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:600;transition:background .2s}.logout-button:hover{background:#dc2626}.admin-users-error{background:#fee2e2;color:#991b1b;padding:12px 16px;border-radius:8px;margin-bottom:24px;border:1px solid #fecaca}.admin-users-actions{margin-bottom:24px}.btn-primary{background:#d3453c;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;transition:background .2s}.btn-primary:hover{background:#b83830}.btn-secondary{background:#6b7280;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;margin-left:12px;transition:background .2s}.btn-secondary:hover{background:#4b5563}.admin-users-form{background:#fff;border-radius:16px;padding:32px;margin-bottom:24px;box-shadow:0 4px 20px #00000014}.admin-users-form h2{margin:0 0 24px;color:var(--color-text-primary, #111827);font-size:1.5rem}.form-group label{display:block;margin-bottom:8px;color:var(--color-text-primary, #111827);font-weight:500}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password]{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#d3453c}.required{color:#ef4444}.supermarkets-checkboxes{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-top:8px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px;border-radius:6px;transition:background .2s}.checkbox-label:hover{background:#f3f4f6}.checkbox-label input[type=checkbox]{width:auto;margin:0}.form-actions{margin-top:24px;display:flex;gap:12px}.admin-users-loading{text-align:center;padding:40px;color:var(--color-text-secondary, #6b7280)}.admin-users-table-container{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px #00000014;overflow-x:auto}.admin-users-table{width:100%;border-collapse:collapse}.admin-users-table th{text-align:left;padding:12px;background:#f9fafb;border-bottom:2px solid #e5e7eb;font-weight:600;color:var(--color-text-primary, #111827)}.admin-users-table td{padding:12px;border-bottom:1px solid #e5e7eb}.admin-users-table tr:hover{background:#f9fafb}.badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.875rem;font-weight:600}.badge-superadmin{background:#fef3c7;color:#92400e}.badge-admin{background:#dbeafe;color:#1e40af}.badge-active{background:#d1fae5;color:#065f46}.badge-inactive{background:#fee2e2;color:#991b1b}.btn-edit{background:#3b82f6;color:#fff;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:.875rem;margin-right:8px;transition:background .2s}.btn-edit:hover{background:#2563eb}.btn-delete{background:#ef4444;color:#fff;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:.875rem;transition:background .2s}.btn-delete:hover{background:#dc2626}@media(max-width:768px){.admin-users-container{padding:16px}.admin-users-header{flex-direction:column;gap:16px;align-items:flex-start}.admin-users-table-container{overflow-x:auto}.admin-users-table{font-size:.875rem}.supermarkets-checkboxes{grid-template-columns:1fr}}.negocio-login-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:20px}.negocio-login-card{background:#fff;border-radius:12px;padding:40px;box-shadow:0 10px 40px #0000001a;width:100%;max-width:400px}.negocio-login-card h1{margin:0 0 30px;color:#d3453c;text-align:center;font-size:28px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500}.form-group input{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:#d3453c}.form-group select{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s;box-sizing:border-box;background:#fff}.error-message{background:#fee;color:#c33;padding:12px;border-radius:8px;margin-bottom:20px;text-align:center}.success-message{background:#efe;color:#3c3;padding:12px;border-radius:8px;margin-bottom:20px;text-align:center}.submit-button{width:100%;padding:14px;background:#d3453c;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background .3s}.submit-button:hover:not(:disabled){background:#b83830}.submit-button:disabled{opacity:.6;cursor:not-allowed}.register-link{text-align:center;margin-top:20px;color:#666}.register-link a{color:#d3453c;text-decoration:none;font-weight:500}.register-link a:hover{text-decoration:underline}.image-upload{display:flex;flex-direction:column;gap:1rem}.image-upload-preview{width:100%;min-height:200px;border:2px dashed #dee2e6;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#f8f9fa;position:relative;overflow:hidden}.preview-container{position:relative;width:100%;height:100%;min-height:200px}.preview-image{width:100%;height:100%;object-fit:cover;display:block}.remove-button{position:absolute;top:.5rem;right:.5rem;background:#dc3545e6;color:#fff;border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:1.5rem;display:flex;align-items:center;justify-content:center;line-height:1;transition:all .2s;z-index:10}.remove-button:hover{background:#dc3545;transform:scale(1.1)}.remove-button:disabled{opacity:.5;cursor:not-allowed}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#6c757d;padding:2rem}.upload-icon{font-size:3rem}.upload-placeholder p{margin:0;font-size:.875rem}.image-upload-controls{display:flex;gap:.5rem}.file-input{display:none}.upload-button{padding:.625rem 1.25rem;background:#d3453c;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s;text-align:center;display:inline-block}.upload-button:hover:not(:disabled){background:#c03d35;transform:translateY(-1px);box-shadow:0 4px 8px #d3453c4d}.upload-button:disabled{opacity:.6;cursor:not-allowed}.upload-error{background:#f8d7da;color:#721c24;padding:.75rem;border-radius:8px;font-size:.875rem}.upload-progress{margin-top:.5rem}.progress-bar{width:100%;height:4px;background:#e9ecef;border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:#d3453c;animation:progress 1.5s ease-in-out infinite}@keyframes progress{0%{width:0%;transform:translate(0)}50%{width:70%;transform:translate(0)}to{width:100%;transform:translate(100%)}}:root{--primary-color: #D3453C;--primary-dark: #c03d35;--bg-color: #f8f9fa;--card-bg: #ffffff;--text-primary: #212529;--text-secondary: #6c757d;--border-color: #dee2e6;--success-color: #28a745;--danger-color: #dc3545;--warning-color: #ffc107}*{box-sizing:border-box}.negocio-dashboard{min-height:100vh;background:var(--bg-color)}.dashboard-header{background:var(--primary-color);color:#fff;padding:1rem 2rem;box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:100;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center;gap:1rem;flex:1}.mobile-menu-toggle{display:none;background:#fff3;border:none;color:#fff;font-size:1.5rem;padding:.5rem;border-radius:4px;cursor:pointer}.dashboard-header h1{margin:0;font-size:1.5rem;font-weight:600}.logout-button{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.logout-button:hover{background:#ffffff4d}.stripe-banner{background:#fff3cd;border-left:4px solid var(--warning-color);margin:1rem 2rem;border-radius:8px;padding:1.5rem}.banner-content{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.banner-icon{font-size:2rem}.banner-text{flex:1;min-width:200px}.banner-text strong{display:block;margin-bottom:.5rem;color:#856404}.banner-text p{margin:0;color:#856404}.banner-actions{margin-left:auto}.dashboard-container{display:flex;gap:2rem;padding:2rem;max-width:1400px;margin:0 auto}.dashboard-sidebar{width:250px;flex-shrink:0;background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px #00000014;padding:1.5rem;height:fit-content;position:sticky;top:100px}.sidebar-nav{display:flex;flex-direction:column;gap:.5rem}.nav-button{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:transparent;border:none;border-radius:8px;cursor:pointer;text-align:left;transition:all .2s;color:var(--text-secondary);font-size:.9375rem;font-weight:500;width:100%}.nav-button:hover{background:#f8f9fa;color:var(--text-primary)}.nav-button.active{background:var(--primary-color);color:#fff}.nav-icon{font-size:1.25rem}.nav-label{flex:1}.dashboard-main{flex:1;background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px #00000014;padding:2rem;min-height:600px}.tab-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.tab-header h2{margin:0;font-size:1.75rem;color:var(--text-primary)}.btn-primary{background:var(--primary-color);color:#fff;border:none;padding:.625rem 1.25rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 8px #d3453c4d}.btn-secondary{background:#fff;color:var(--text-primary);border:1px solid var(--border-color);padding:.625rem 1.25rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.btn-secondary:hover{background:#f8f9fa;border-color:var(--primary-color);color:var(--primary-color)}.btn-danger{background:var(--danger-color);color:#fff;border:none;padding:.625rem 1.25rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.btn-danger:hover{background:#c82333}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.stat-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all .2s}.stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.stat-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.stat-content{flex:1}.stat-label{margin:0 0 .5rem;font-size:.875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.stat-value{margin:0;font-size:1.75rem;font-weight:700;color:var(--text-primary)}.ofertas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.oferta-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;transition:all .2s}.oferta-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.oferta-image-wrapper{width:100%;height:200px;overflow:hidden;background:#f8f9fa}.oferta-image{width:100%;height:100%;object-fit:cover}.oferta-content{padding:1.5rem}.oferta-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.oferta-header h3{margin:0;font-size:1.25rem;color:var(--text-primary);flex:1}.oferta-descripcion{color:var(--text-secondary);font-size:.9375rem;margin:0 0 1rem}.oferta-precio{display:flex;align-items:baseline;gap:.75rem;margin-bottom:1rem}.precio-oferta{font-size:1.5rem;font-weight:700;color:var(--primary-color)}.precio-original{font-size:1rem;color:var(--text-secondary);text-decoration:line-through}.oferta-stats{display:flex;gap:1.5rem;margin-bottom:.75rem}.stat-item{display:flex;flex-direction:column;gap:.25rem}.stat-item .stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase}.stat-item .stat-value{font-size:1rem;font-weight:600;color:var(--text-primary)}.progress-bar{width:100%;height:8px;background:#e9ecef;border-radius:4px;overflow:hidden;margin-bottom:1rem}.progress-fill{height:100%;background:var(--primary-color);transition:width .3s}.oferta-actions{display:flex;gap:.5rem;flex-wrap:wrap}.oferta-actions button{flex:1;min-width:80px}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.status-badge.completed{background:#d4edda;color:#155724}.ventas-table-wrapper{overflow-x:auto}.ventas-table{width:100%;border-collapse:collapse;margin-top:1rem}.ventas-table thead{background:#f8f9fa}.ventas-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border-color);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.ventas-table td{padding:1rem;border-bottom:1px solid var(--border-color);color:var(--text-secondary)}.ventas-table tbody tr:hover{background:#f8f9fa}.venta-oferta{font-weight:500;color:var(--text-primary)}.venta-monto,.venta-ingreso{font-weight:600;color:var(--text-primary)}.locales-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.local-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;transition:all .2s}.local-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.local-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;background:#f8f9fa;border-bottom:1px solid var(--border-color)}.local-header h3{margin:0;font-size:1.25rem;color:var(--text-primary);flex:1}.local-content{padding:1.5rem}.local-info{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.local-info .info-item{display:flex;align-items:flex-start;gap:.75rem}.local-info .info-icon{font-size:1.25rem;flex-shrink:0;margin-top:.125rem}.local-info .info-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.local-info .info-value{font-size:.9375rem;font-weight:500;color:var(--text-primary)}.local-actions{display:flex;gap:.5rem}.local-actions button{flex:1}.config-sections{display:flex;flex-direction:column;gap:2rem}.config-section{padding:1.5rem;background:#f8f9fa;border-radius:12px;border:1px solid var(--border-color)}.config-section h3{margin:0 0 1.5rem;color:var(--text-primary);font-size:1.25rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.info-item label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.info-item p{margin:0;font-size:1rem;color:var(--text-primary);font-weight:500}.stripe-status,.stripe-setup{display:flex;flex-direction:column;gap:1rem}.status-info{display:flex;align-items:center;gap:.75rem}.status-indicator{width:12px;height:12px;border-radius:50%;background:var(--text-secondary)}.status-indicator.active{background:var(--success-color)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-content{background:var(--card-bg);border-radius:12px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background:#f8f9fa;color:var(--text-primary)}.oferta-form{padding:2rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.form-section{margin-bottom:2rem;padding:1.5rem;background:#f8f9fa;border-radius:12px;border:1px solid var(--border-color)}.form-section-title{margin:0 0 .5rem;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.form-section-description{margin:0 0 1.5rem;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary);font-size:.875rem}.form-hint{display:block;margin-top:.375rem;font-size:.75rem;color:var(--text-secondary);font-style:italic}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9375rem;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #d3453c1a}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.form-error{background:#f8d7da;color:#721c24;padding:1rem;border-radius:8px;margin-bottom:1rem}.empty-state{text-align:center;padding:3rem;color:var(--text-secondary)}.empty-state p{margin:0 0 1.5rem;font-size:1.125rem}.tab-empty{text-align:center;padding:3rem;color:var(--text-secondary)}.dashboard-loading{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.dashboard-header{padding:1rem}.header-left{flex:1;order:1}.mobile-menu-toggle{display:block;order:2;margin-left:auto}.logout-button{order:3}.dashboard-header h1{font-size:1.25rem}.stripe-banner{margin:1rem}.banner-content{flex-direction:column;align-items:flex-start}.banner-actions{margin-left:0;width:100%}.banner-actions button{width:100%}.dashboard-container{flex-direction:column;padding:1rem;gap:1rem}.dashboard-sidebar{width:100%;position:relative;top:0;display:none}.dashboard-sidebar.open{display:block}.dashboard-main{padding:1.5rem}.tab-header{flex-direction:column;align-items:flex-start;gap:1rem}.tab-header button{width:100%}.stats-grid,.ofertas-grid{grid-template-columns:1fr}.oferta-actions{flex-direction:column}.oferta-actions button{width:100%}.ventas-table-wrapper{overflow-x:auto}.ventas-table{font-size:.875rem}.ventas-table th,.ventas-table td{padding:.75rem .5rem}.info-grid{grid-template-columns:1fr}.modal-overlay{padding:1rem}.modal-content{max-height:95vh}.modal-header,.oferta-form{padding:1.5rem}.form-grid{grid-template-columns:1fr}}:root{--primary-color: #D3453C;--primary-dark: #c03d35;--bg-color: #f8f9fa;--text-primary: #212529;--text-secondary: #6c757d;--border-color: #dee2e6;--success-color: #28a745;--danger-color: #dc3545;--warning-color: #ffc107}.compra-page{min-height:100vh;background:var(--bg-color);padding:0}.compra-alert{position:sticky;top:0;z-index:100;padding:1rem 2rem;display:flex;align-items:center;gap:.75rem;font-weight:500;box-shadow:0 2px 8px #0000001a}.compra-alert-warning{background:#fff3cd;color:#856404}.compra-alert-error{background:#f8d7da;color:#721c24}.alert-icon{font-size:1.25rem}.compra-container{max-width:900px;margin:0 auto;background:#fff;box-shadow:0 4px 20px #00000014;overflow:hidden}.compra-hero{position:relative;width:100%;height:400px;overflow:hidden;background:linear-gradient(135deg,#f5f5f5,#e0e0e0)}.compra-image-wrapper{position:relative;width:100%;height:100%}.compra-image{width:100%;height:100%;object-fit:cover;display:block}.compra-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f5f5,#e0e0e0)}.placeholder-icon{font-size:5rem;opacity:.3}.stock-badge-hero{position:absolute;top:1.5rem;right:1.5rem;background:var(--primary-color);color:#fff;padding:.75rem 1.25rem;border-radius:50px;font-weight:600;font-size:1rem;box-shadow:0 4px 12px #d3453c66;z-index:10}.stock-badge-hero.sin-stock{background:var(--danger-color);box-shadow:0 4px 12px #dc354566}.compra-content{padding:2.5rem}.compra-header{margin-bottom:1.5rem}.compra-categoria{display:inline-block;padding:.375rem .875rem;background:#d3453c1a;color:var(--primary-color);border-radius:20px;font-size:.875rem;font-weight:600;text-transform:capitalize;margin-bottom:1rem}.compra-header h1{margin:0 0 1rem;font-size:2rem;font-weight:700;color:var(--text-primary);line-height:1.2}.compra-negocio{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:1rem}.negocio-icon{font-size:1.25rem}.compra-description{margin-bottom:2rem;padding:1.5rem;background:#f8f9fa;border-radius:12px;border-left:4px solid var(--primary-color)}.compra-description p{margin:0;font-size:1.0625rem;line-height:1.6;color:var(--text-primary)}.compra-precio-section{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#f8f9fa;border-radius:12px;margin-bottom:2rem;flex-wrap:wrap}.precio-original{font-size:1.25rem;color:var(--text-secondary);text-decoration:line-through}.precio-oferta{font-size:2rem;font-weight:700;color:var(--primary-color)}.descuento-badge{background:var(--primary-color);color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:1rem}.compra-info-section{margin-bottom:2rem}.section-title{display:flex;align-items:center;gap:.75rem;margin:0 0 1.5rem;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.section-icon{font-size:1.5rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.info-card{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:#f8f9fa;border-radius:12px;border:1px solid var(--border-color);transition:all .2s}.info-card:hover{border-color:var(--primary-color);box-shadow:0 2px 8px #d3453c1a}.info-icon{font-size:1.75rem;flex-shrink:0}.info-content{flex:1}.info-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.info-value-secondary{font-size:.9375rem;font-weight:500;color:var(--text-secondary)}.stock-warning{margin-bottom:2rem;padding:.75rem 1rem;background:#fff3cd;color:#856404;border-radius:8px;font-size:.875rem;font-weight:500;text-align:center}.compra-form-section{margin-top:2rem}.compra-form{background:#f8f9fa;padding:2rem;border-radius:12px;border:1px solid var(--border-color)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-primary);font-weight:500;font-size:.9375rem}.required{color:var(--danger-color)}.form-group input{width:100%;padding:.875rem 1rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;transition:all .2s;box-sizing:border-box;background:#fff}.form-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #d3453c1a}.form-group input:disabled{background:#f8f9fa;cursor:not-allowed}.comprar-button{width:100%;padding:1.125rem 2rem;background:var(--primary-color);color:#fff;border:none;border-radius:12px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1.5rem;box-shadow:0 4px 12px #d3453c4d}.comprar-button:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 6px 16px #d3453c66}.comprar-button:active:not(:disabled){transform:translateY(0)}.comprar-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.button-spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.button-arrow{font-size:1.25rem;transition:transform .2s}.comprar-button:hover:not(:disabled) .button-arrow{transform:translate(4px)}.form-note{margin:1rem 0 0;text-align:center;font-size:.875rem;color:var(--text-secondary)}.compra-sin-stock{text-align:center;padding:3rem 2rem;background:#f8f9fa;border-radius:12px;border:2px dashed var(--border-color)}.sin-stock-icon{font-size:4rem;margin-bottom:1rem}.compra-sin-stock h3{margin:0 0 .5rem;color:var(--text-primary);font-size:1.5rem}.compra-sin-stock p{margin:0;color:var(--text-secondary)}.compra-loading{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1.5rem}.loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.compra-loading p{font-size:1.125rem;color:var(--text-secondary)}.compra-error-container{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2rem;text-align:center}.error-icon{font-size:4rem;margin-bottom:1rem}.compra-error-container h2{margin:0 0 1rem;color:var(--text-primary);font-size:1.75rem}.compra-error-container p{margin:0 0 1.5rem;color:var(--text-secondary);font-size:1.125rem}.error-details{max-width:500px;text-align:left;background:#f8f9fa;padding:1.5rem;border-radius:12px;margin-top:1.5rem}.error-details p{margin:0 0 .75rem;font-weight:600;color:var(--text-primary)}.error-details ul{margin:0;padding-left:1.5rem;color:var(--text-secondary)}.error-details li{margin-bottom:.5rem}@media(max-width:768px){.compra-content{padding:1.5rem}.compra-hero{height:300px}.descuento-badge-hero{top:1rem;right:1rem;padding:.5rem 1rem;font-size:1.25rem}.compra-header h1{font-size:1.5rem}.compra-precio-section{padding:1.25rem}.precio-oferta{font-size:1.75rem}.descuento-badge{margin-left:0}.stock-badge-hero{top:1rem;right:1rem;padding:.625rem 1rem;font-size:.875rem}.info-grid{grid-template-columns:1fr}.compra-form{padding:1.5rem}.compra-alert{padding:1rem;font-size:.875rem}}.confirmacion-page{min-height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:20px}.confirmacion-container{background:#fff;border-radius:12px;padding:40px;box-shadow:0 10px 40px #0000001a;text-align:center;max-width:500px;width:100%}.confirmacion-success-icon{width:80px;height:80px;border-radius:50%;background:#4caf50;color:#fff;display:flex;align-items:center;justify-content:center;font-size:48px;margin:0 auto 20px;font-weight:700}.confirmacion-container h1{color:#d3453c;margin:0 0 20px;font-size:32px}.confirmacion-message{font-size:18px;color:#666;margin-bottom:30px}.confirmacion-codigo{font-size:48px;font-weight:700;color:#d3453c;letter-spacing:8px;margin:30px 0;padding:20px;background:#f9f9f9;border-radius:8px;border:3px dashed #D3453C}.confirmacion-details{margin:30px 0;text-align:left;background:#f9f9f9;padding:20px;border-radius:8px}.detail-item{padding:10px 0;border-bottom:1px solid #eee;font-size:16px}.detail-item:last-child{border-bottom:none}.detail-item strong{color:#333;margin-right:10px}.confirmacion-instructions{font-size:16px;color:#333;margin:20px 0;font-weight:500}.confirmacion-note{font-size:14px;color:#999;margin-top:20px}.confirmacion-loading{text-align:center;padding:40px}.loading-spinner{font-size:48px;margin-bottom:20px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.confirmacion-error{background:#fff;color:#333;padding:40px;border-radius:12px;text-align:center;font-size:18px;max-width:600px;margin:0 auto;box-shadow:0 10px 40px #0000001a}.confirmacion-error-icon{font-size:64px;margin-bottom:20px;color:#ff9800}.confirmacion-error h2{color:#d3453c;margin:0 0 15px;font-size:24px}.confirmacion-error p{color:#666;line-height:1.6;margin:10px 0}.confirmacion-error .error-highlight{background:#fff3cd;border-left:4px solid #ff9800;padding:15px;margin:20px 0;border-radius:4px;text-align:left}.confirmacion-error .error-highlight strong{color:#d3453c;display:block;margin-bottom:8px}.app{max-width:768px;margin:0 auto;padding:0 20px 32px;display:flex;flex-direction:column;gap:24px}.app__header{position:sticky;top:0;left:0;right:0;z-index:900;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:10px 20px;margin:0 -20px;background:#cd3834;color:var(--color-primary-contrast);box-shadow:0 6px 16px #d3453c40}.app__brand{display:flex;align-items:center;gap:12px}.app__brand img{width:56px;height:56px;border-radius:12px;object-fit:cover;box-shadow:0 6px 16px #0000002e}.app__header h1{margin:0;font-size:1.65rem;font-weight:700;letter-spacing:.04em}.app__subtitle{margin:4px 0 0;font-size:.95rem;opacity:.9}.app__summary{font-size:.95rem;font-weight:600;color:var(--color-primary-dark);background:var(--color-primary-softer);padding:10px 16px;border-radius:12px;border:1px solid var(--color-border);box-shadow:inset 0 1px #ffffff73;animation:summary-pulse .45s ease}@keyframes summary-pulse{0%{transform:scale(.98);background:#e3635b59}to{transform:scale(1);background:var(--color-primary-softer)}}.toast{position:fixed;top:0;left:0;right:0;width:100%;padding:16px;border-radius:0 0 18px 18px;font-weight:600;color:#fff;z-index:1000;box-shadow:0 12px 28px #0f172a47;cursor:pointer;text-align:center;animation:toast-slide-in .35s ease-out}.toast--info{background:linear-gradient(135deg,var(--color-info),#2747a2)}.toast--success{background:linear-gradient(135deg,var(--color-primary-light),var(--color-primary))}.toast--error{background:linear-gradient(135deg,#e24b4b,var(--color-error))}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes toast-fade-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-100%)}}@media(min-width:768px){.toast{padding:18px 24px}}.app__status{padding:12px 16px;border-radius:12px;background-color:var(--color-primary-softer);color:var(--color-primary-dark);font-weight:500;border:1px solid var(--color-border)}.app__status--error{background-color:#fde8e8;color:var(--color-error);border-color:#dc26264d}.app__filters{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:12px 14px;background:var(--color-surface);border-radius:14px;border:1px solid var(--color-border);box-shadow:0 6px 18px #d3453c1f}.app__search{margin-top:12px;position:relative;display:flex}.app__search input{flex:1;padding:14px 18px 14px 46px;border-radius:14px;border:1px solid var(--color-border);background:linear-gradient(135deg,#f9e2dff2,#f4c2bdb3);font-size:1rem;color:var(--color-primary-dark);font-weight:500;transition:box-shadow .2s ease,transform .2s ease}.app__search input::placeholder{color:#a6322c8c}.app__search input:focus{outline:none;box-shadow:0 0 0 3px #d3453c40;transform:translateY(-1px)}.app__search:before{content:"🔍";position:absolute;left:18px;top:50%;transform:translateY(-50%);font-size:1rem;color:var(--color-primary)}.app__filter{display:flex;flex-direction:column;gap:6px;font-size:.8rem;color:var(--color-primary);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.app__filter-select-wrapper{position:relative;display:inline-flex;align-items:center;width:fit-content}.app__filter select{appearance:none;-webkit-appearance:none;-moz-appearance:none;position:relative;padding:9px 42px 9px 14px;border-radius:10px;border:1px solid var(--color-border);background:linear-gradient(135deg,#f9e2dfe6,#f4c2bdb3);font-size:.95rem;color:var(--color-primary-dark);min-width:150px;font-weight:600;transition:box-shadow .2s ease,transform .2s ease;cursor:pointer}.app__filter select:hover{transform:translateY(-1px);box-shadow:0 10px 18px #d3453c2e}.app__filter select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #d3453c40}.app__filter-icon{position:absolute;right:12px;pointer-events:none;font-size:.85rem;color:var(--color-primary);font-weight:700}.app__filter select::-ms-expand{display:none}.app__filter select option{font-size:.95rem;font-weight:500;background-color:#fff;color:var(--color-primary-dark)}.app__clear-filters{border:none;background:linear-gradient(135deg,#f3c4bfd9,#eea69fbf);color:var(--color-primary-dark);font-weight:600;cursor:pointer;padding:8px 14px;border-radius:999px;transition:transform .2s ease,box-shadow .2s ease;border:1px solid rgba(211,69,60,.25)}.app__clear-filters:hover{transform:translateY(-1px);box-shadow:0 8px 18px #d3453c26}.app__filters-toggle{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;border:1px solid rgba(255,235,233,.7);background:#fde5e266;color:var(--color-primary-contrast);font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease,border .2s ease}.app__filters-toggle:hover{transform:translateY(-1px);box-shadow:0 8px 18px #d3453c2e}.app__filters-toggle:focus{outline:none;background:#fde5e299;border-color:#d3453c59}.app__filters-toggle-icon{display:inline-flex;font-size:.95rem;line-height:1}.app__filters-toggle-label{text-transform:uppercase;font-size:.75rem;letter-spacing:.08em}.app__loading{text-align:center;color:#6b7280}.cart-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.cart-item{display:flex;justify-content:space-between;align-items:flex-start;padding:16px;border-radius:14px;background-color:#fff;border:1px solid #e5e7eb;box-shadow:0 2px 6px #0f172a0f;gap:16px}.cart-item__info{flex:1;display:flex;flex-direction:column;gap:6px}.cart-item__header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:nowrap}.cart-item__prices-inline{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:4px;min-width:110px;margin-left:auto;text-align:right}.cart-item__title{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.cart-item__product{font-size:1.05rem;font-weight:600;color:#1f2937}.cart-item__supermarket{font-size:.85rem;color:var(--color-primary);font-weight:500}.cart-item__category{font-size:.8rem;font-weight:500;color:var(--color-primary-dark);background-color:var(--color-primary-softer);padding:4px 8px;border-radius:999px;width:fit-content}.cart-item__meta{display:flex;flex-direction:column;align-items:flex-end;gap:12px}.cart-item__prices-inline strong{font-size:1.1rem;color:var(--color-primary-dark)}.cart-item__previous{font-size:.85rem;color:#9ca3af;text-decoration:line-through}.cart-item__savings{display:flex;flex-wrap:wrap;gap:6px}.cart-item__badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background-color:var(--color-primary-softer);color:var(--color-primary-dark);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.cart-item__badge--discount{background-color:#d3453c2e;color:var(--color-primary-dark)}.cart-item__badge--savings{background-color:#e9635b38;color:var(--color-primary-darker)}.cart-item__badge--units{background-color:#365abf2e;color:var(--color-info)}.cart-item__notes{margin:0;font-size:.8rem;color:#4b5563}.cart-item__notes-inline{font-size:.8rem;color:#6b7280}.cart-item__actions{display:flex;gap:10px}.cart-item__share{border:none;background:linear-gradient(135deg,#e9635b38,#d3453c4d);color:var(--color-primary-darker);font-weight:600;padding:6px 12px;border-radius:999px;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:transform .2s ease,box-shadow .2s ease}.cart-item__share:hover{transform:translateY(-1px);box-shadow:0 6px 16px #d3453c33}.cart-item__remove{border:none;background-color:transparent;color:var(--color-error);font-size:1.35rem;cursor:pointer;padding:0;transition:transform .2s ease,color .2s ease}.cart-item__remove:hover{color:#7f2420;transform:scale(1.08)}.cart-empty{text-align:center;padding:60px 20px;border-radius:16px;background-color:var(--color-surface);border:1px dashed rgba(211,69,60,.35);color:var(--color-text-muted)}.cart-groups{display:flex;flex-direction:column;gap:28px}.cart-supermarket{display:flex;flex-direction:column;gap:16px}.cart-supermarket__header{margin:0;font-size:1.25rem;font-weight:700;color:var(--color-primary-contrast);letter-spacing:.05em;text-transform:uppercase;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));padding:12px 18px;border-radius:14px;box-shadow:0 10px 24px #d3453c40}.cart-category{display:flex;flex-direction:column;gap:12px}.cart-category__title{margin:0;font-size:.85rem;font-weight:600;color:var(--color-primary-dark);text-transform:uppercase;letter-spacing:.06em}.cart-category__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.app__footer{display:flex;flex-direction:column;gap:6px;color:#6b7280;font-size:.75rem;text-align:center}.cart-item__validity{margin:0;font-size:.74rem;color:#2b1a19a6;font-weight:500}@media(max-width:640px){.app{padding:0 16px 24px}.app__header{padding:10px 16px;margin:0 -16px}.app__brand img{width:48px;height:48px}.app__filters{flex-direction:column;align-items:stretch;width:100%;gap:10px;padding:12px}.cart-item{flex-direction:column;align-items:flex-start}.app__search{margin-top:16px}.cart-item__header-row{align-items:flex-start}.cart-item__prices-inline{min-width:unset}.cart-item__meta{align-items:flex-start;width:100%}.cart-item__actions{width:100%;justify-content:flex-end}}
