: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;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-toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer}.dashboard-toggle input{display:none}.dashboard-toggle-slider{width:42px;height:24px;background:#e5e7eb;border-radius:999px;position:relative;transition:all .2s}.dashboard-toggle-slider:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;box-shadow:0 1px 4px #0003;transition:all .2s}.dashboard-toggle input:checked+.dashboard-toggle-slider{background:var(--color-primary, #D3453C)}.dashboard-toggle input:checked+.dashboard-toggle-slider:after{transform:translate(18px)}.dashboard-toggle-label{font-size:.9rem;color:#555}.dashboard-input-number{width:100%;padding:8px 10px;border:1px solid #e5e7eb;border-radius:8px;font-size:.95rem}.dashboard-input-number:focus{outline:none;border-color:var(--color-primary, #D3453C);box-shadow:0 0 0 3px #d3453c1a}.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}}.dashboard-modal-backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-y:auto}.dashboard-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;position:relative}.dashboard-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:1px solid #e5e7eb;position:sticky;top:0;background:#fff;z-index:10;border-radius:16px 16px 0 0}.dashboard-modal-header h2{margin:0;font-size:1.5rem;font-weight:700;color:var(--color-text-primary, #111827)}.dashboard-modal-close{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.dashboard-modal-close:hover{background:#f3f4f6;color:#111827}.dashboard-modal-content{padding:32px}@media(max-width:768px){.dashboard-modal{max-width:100%;max-height:100vh;border-radius:0}.dashboard-modal-header{border-radius:0}.dashboard-modal-content{padding:20px}}.dashboard-tabs-container{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014;overflow:hidden}.dashboard-tabs-header{display:flex;gap:0;background:#f8f9fa;border-bottom:2px solid #e5e7eb;overflow-x:auto;-webkit-overflow-scrolling:touch}.dashboard-tab-button{padding:16px 24px;background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:.95rem;font-weight:500;color:#6b7280;transition:all .2s;white-space:nowrap;flex-shrink:0}.dashboard-tab-button:hover{background:#ffffffb3;color:#111827}.dashboard-tab-button.active{background:#fff;color:var(--color-primary, #D3453C);border-bottom-color:var(--color-primary, #D3453C);font-weight:600}.dashboard-tabs-content{padding:24px}@media(max-width:768px){.dashboard-tabs-header{gap:0}.dashboard-tab-button{padding:12px 16px;font-size:.875rem}.dashboard-tabs-content{padding:16px}}.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-page{min-height:100vh;display:flex;flex-direction:column;background:#fff}.negocio-login-hero{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px 16px 8px;max-width:960px;margin:0 auto;color:#111827;text-align:center}.negocio-login-logo-wrapper{flex-shrink:0;width:96px;height:96px;border-radius:24px;overflow:hidden;box-shadow:0 10px 30px #00000040;background:#d3453c;display:flex;align-items:center;justify-content:center}.negocio-login-logo{width:100%;height:100%;object-fit:cover}.negocio-login-hero-text h1{margin:0 0 8px;font-size:28px;font-weight:800;color:#111827}.negocio-login-hero-text p{margin:0;font-size:15px;color:#374151;max-width:520px}.negocio-login-container{flex:1;display:flex;justify-content:center;align-items:center;padding:16px 16px 40px}.negocio-login-card{background:#fff;border-radius:18px;padding:32px 28px;box-shadow:0 18px 45px #00000026;width:100%;max-width:420px;border:1px solid rgba(0,0,0,.04)}.negocio-login-card h2{margin:0 0 8px;color:#111827;text-align:left;font-size:22px;font-weight:700}.negocio-login-card>p{margin:0 0 24px;font-size:14px;color:#6b7280}.form-group input{width:100%;padding:12px;border:1px solid #e5e7eb;border-radius:8px;font-size:16px;transition:border-color .2s,box-shadow .2s;box-sizing:border-box;background-color:#f9fafb}.form-group input:focus,.form-group select:focus{outline:none;border-color:#d3453c;box-shadow:0 0 0 3px #d3453c26}.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}@media(max-width:768px){.negocio-login-hero{flex-direction:column;align-items:center;padding:24px 16px 8px}.negocio-login-container{align-items:stretch;padding:8px 16px 32px}.negocio-login-card{padding:24px 20px}}.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)}.negocio-dashboard .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}.negocio-dashboard .dashboard-header h1{margin:0;font-size:1.5rem;font-weight:600;color:#fff}.negocio-header-brand{display:flex;align-items:center;gap:12px}.negocio-header-logo{width:44px;height:44px;border-radius:10px;object-fit:cover;box-shadow:0 4px 12px #00000026}.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}.negocio-dashboard .dashboard-container{display:flex;gap:2rem;padding:2rem;max-width:1400px;margin:0 auto}.negocio-dashboard .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}.negocio-dashboard .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;position:relative}.oferta-image{width:100%;height:100%;object-fit:cover}.flash-badge-overlay{position:absolute;top:.75rem;right:.75rem;background:linear-gradient(135deg,#ff6b6b,#ee5a6f,#ff4757);color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:.75rem;letter-spacing:.5px;box-shadow:0 4px 12px #ff475766;animation:flashPulse 2s ease-in-out infinite;z-index:10}.flash-badge-top{background:linear-gradient(135deg,#ff6b6b,#ee5a6f,#ff4757);color:#fff;padding:.75rem 1rem;text-align:center;font-weight:700;font-size:.875rem;letter-spacing:.5px;box-shadow:0 2px 8px #ff47574d;animation:flashPulse 2s ease-in-out infinite}@keyframes flashPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.05)}}.flash-badge-text{display:inline-flex;align-items:center;gap:.25rem}.flash-deadline-info{background:linear-gradient(135deg,#fff5f5,#ffe5e5);border-left:4px solid #ff4757;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;font-size:.95rem}.flash-deadline-label{font-weight:600;color:#ff4757}.flash-deadline-value{font-weight:700;color:#c92a2a}.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)}.platform-payments-banner{display:flex;align-items:flex-start;gap:12px;background:#fef3c7;border:1px solid #fcd34d;border-radius:10px;padding:12px 14px;margin-bottom:12px}.platform-payments-dot{width:12px;height:12px;border-radius:50%;background:#f59e0b;margin-top:4px;flex-shrink:0}.platform-payments-banner strong{display:block;color:#92400e}.platform-payments-banner p{margin:4px 0 0;color:#b45309;font-size:.9rem}.default-instructions-form textarea{width:100%;padding:12px;border:1px solid #e5e7eb;border-radius:10px;font-size:.95rem;min-height:120px;resize:vertical}.default-instructions-form textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #d3453c1a}.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)}.negocio-dashboard .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){.negocio-dashboard .dashboard-header{padding:1rem}.header-left{flex:1;order:1}.mobile-menu-toggle{display:block;order:2;margin-left:auto}.logout-button{order:3}.negocio-dashboard .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%}.negocio-dashboard .dashboard-container{flex-direction:column;padding:1rem;gap:1rem}.negocio-dashboard .dashboard-sidebar{width:100%;position:relative;top:0;display:none}.negocio-dashboard .dashboard-sidebar.open{display:block}.negocio-dashboard .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}.flash-offer-banner{background:linear-gradient(135deg,#de0000,#c50b27,#ff1d30);color:#fff;padding:1.25rem 1.5rem;border-radius:12px;margin-bottom:1.5rem;box-shadow:0 4px 20px #ff47574d;animation:pulse 2s ease-in-out infinite;position:relative;overflow:hidden}.flash-offer-banner:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 50%,rgba(255,255,255,.1) 50%,transparent 80%);animation:shine 3s infinite}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 4px 20px #ff47574d}50%{transform:scale(1.01);box-shadow:0 6px 25px #ff475766}}@keyframes shine{0%{transform:translate(-100%) translateY(-100%) rotate(45deg)}to{transform:translate(100%) translateY(100%) rotate(45deg)}}.flash-offer-content{display:flex;align-items:center;gap:1rem;position:relative;z-index:1}.flash-offer-icon{font-size:2.5rem;animation:flash 1.5s ease-in-out infinite;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}@keyframes flash{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.flash-offer-text{flex:1}.flash-offer-title{font-size:1.25rem;font-weight:700;letter-spacing:.5px;margin-bottom:.25rem;text-shadow:0 2px 4px rgba(0,0,0,.2)}.flash-offer-deadline{font-size:1.1rem;opacity:.98;font-weight:700}.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:contain;object-position:center;background-color:#f5f5f5;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}.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)}.terms-text{font-size:.8125rem;line-height:1.5;margin-top:1rem;margin-bottom:.75rem}.terms-link{color:var(--primary-color);text-decoration:underline;font-weight:500;transition:color .2s}.terms-link:hover{color:var(--primary-dark);text-decoration:underline}.terms-link:visited{color:var(--primary-color)}.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}.flash-offer-banner{padding:1rem;margin-bottom:1rem}.flash-offer-icon{font-size:2rem}.flash-offer-title{font-size:1rem}.flash-offer-deadline{font-size:.85rem}.flash-offer-content{gap:.75rem}}.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}.confirmacion-qr-container{margin:30px 0;padding:20px;background:#f9f9f9;border-radius:8px;border:2px solid #e0e0e0}.confirmacion-qr-code{max-width:250px;width:100%;height:auto;border:2px solid #f0f0f0;border-radius:8px;padding:10px;background-color:#fff;display:block;margin:0 auto}.scan-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:20px}.scan-container{max-width:800px;margin:0 auto;background:#fff;border-radius:16px;padding:32px;box-shadow:0 10px 40px #0000001a}.scan-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:16px}.scan-header h1{color:#d3453c;margin:0;font-size:2rem;flex:1;text-align:center}.scan-cart-button{padding:10px 20px;background:#d3453c;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;box-shadow:0 2px 8px #d3453c4d}.scan-cart-button:hover{background:#b83830;transform:translateY(-2px);box-shadow:0 4px 12px #d3453c66}.scan-container h1{color:#d3453c;margin:0 0 8px;font-size:2rem;text-align:center}.scan-description{text-align:center;color:#666;margin:0 0 32px;font-size:1rem}.scan-actions{display:flex;flex-direction:column;gap:16px;align-items:center}.scan-button{width:100%;max-width:400px;padding:16px 24px;background:#d3453c;color:#fff;border:none;border-radius:12px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #d3453c4d}.scan-button:hover{background:#b83830;transform:translateY(-2px);box-shadow:0 6px 16px #d3453c66}.scan-button-stop{width:100%;max-width:400px;padding:16px 24px;background:#dc3545;color:#fff;border:none;border-radius:12px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:16px}.scan-button-stop:hover{background:#c82333}.scan-button-secondary{padding:12px 24px;background:#fff;color:#d3453c;border:2px solid #D3453C;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.scan-button-secondary:hover{background:#d3453c;color:#fff}.scan-divider{text-align:center;color:#999;font-weight:500;margin:8px 0}.scan-manual-form{width:100%;max-width:400px;display:flex;gap:8px}.scan-manual-input{flex:1;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s}.scan-manual-input:focus{outline:none;border-color:#d3453c}.scan-scanner{display:flex;flex-direction:column;align-items:center;gap:16px}.scan-reader{width:100%;max-width:400px;min-height:400px;border-radius:12px;overflow:hidden;border:4px solid #D3453C;background:#000;position:relative;display:flex;align-items:center;justify-content:center}.scan-reader #reader{width:100%!important;height:100%!important;min-height:400px}.scan-reader #reader__dashboard{display:none!important}.scan-reader video{width:100%!important;height:100%!important;object-fit:cover}.scan-reader canvas{display:none!important}.scan-loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px}.scan-spinner{width:50px;height:50px;border:4px solid #e5e7eb;border-top-color:#d3453c;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.scan-loading p{color:#666;font-size:1.125rem}.scan-error{text-align:center;padding:24px;background:#fee;border:1px solid #fcc;border-radius:12px;color:#c33}.scan-error p{margin:0 0 16px;font-size:1.125rem}.scan-results{margin-top:32px}.scan-results .scan-button-secondary{display:block;margin:0 auto 32px}.scan-product{text-align:center;padding:24px;background:#f8f9fa;border-radius:12px;margin-bottom:32px}.scan-product h2{color:#d3453c;margin:0 0 16px;font-size:1.5rem}.scan-product-image{max-width:200px;max-height:200px;border-radius:12px;margin:16px 0;box-shadow:0 4px 12px #0000001a}.scan-product h3{margin:16px 0 8px;color:#333;font-size:1.25rem}.scan-product-brand,.scan-product-category{margin:8px 0;color:#666;font-size:.9375rem}.scan-offers h2{color:#d3453c;margin:0 0 24px;font-size:1.5rem}.scan-offers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-bottom:24px}.scan-offer-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:20px;transition:all .2s}.scan-offer-card:hover{border-color:#d3453c;box-shadow:0 4px 12px #d3453c33;transform:translateY(-2px)}.scan-offer-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.scan-offer-header h4{margin:0;color:#333;font-size:1.125rem;flex:1}.scan-offer-supermarket{background:#d3453c;color:#fff;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;white-space:nowrap;margin-left:8px}.scan-offer-price{display:flex;align-items:baseline;gap:12px;margin-bottom:8px;flex-wrap:wrap}.scan-offer-price-old{color:#999;text-decoration:line-through;font-size:.9375rem}.scan-offer-price-new{color:#d3453c;font-size:1.5rem;font-weight:700}.scan-offer-discount{background:#10b981;color:#fff;padding:4px 8px;border-radius:6px;font-size:.875rem;font-weight:600}.scan-offer-category{margin:8px 0;color:#666;font-size:.875rem}.scan-offer-validity{margin:8px 0 0;color:#999;font-size:.8125rem}.scan-offer-add-button{width:100%;margin-top:16px;padding:12px 24px;background:#d3453c;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #d3453c4d}.scan-offer-add-button:hover:not(:disabled){background:#b83830;transform:translateY(-2px);box-shadow:0 4px 12px #d3453c66}.scan-offer-add-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.toast--info{background:linear-gradient(135deg,#3b82f6,#2747a2)}.toast--success{background:linear-gradient(135deg,#d3453c,#b83830)}.toast--error{background:linear-gradient(135deg,#e24b4b,#c82333)}.scan-no-offers{text-align:center;padding:40px;background:#f8f9fa;border-radius:12px;color:#666}.scan-no-offers p{margin:0;font-size:1.125rem}@media(max-width:768px){.scan-container{padding:20px}.scan-header{flex-direction:column;align-items:stretch;gap:12px}.scan-header h1{font-size:1.5rem;text-align:center}.scan-cart-button{width:100%}.scan-manual-form{flex-direction:column}.scan-offers-grid{grid-template-columns:1fr}}.redeem-page{min-height:100vh;background:#f5f5f5;padding:20px}.redeem-container{max-width:800px;margin:0 auto;background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a}.redeem-header{margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #e5e7eb}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.redeem-header h1{margin:0;color:#111827;font-size:24px;font-weight:700}.redeem-header p{margin:0;color:#6b7280;font-size:14px}.btn-logout{padding:8px 16px;background:#ef4444;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.btn-logout:hover{background:#dc2626}.user-info{margin-top:12px;padding:12px;background:#f9fafb;border-radius:8px}.user-info p{margin:4px 0;font-size:14px;color:#374151}.redeem-login-form{max-width:400px;margin:0 auto}.redeem-content{margin-top:24px}.redeem-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:24px}.option-card{padding:20px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.option-card h3{margin:0 0 8px;font-size:18px;color:#111827}.option-card p{margin:0 0 16px;font-size:14px;color:#6b7280}.manual-input-group{display:flex;gap:8px;width:100%;box-sizing:border-box}.code-input{flex:1;min-width:0;padding:12px;border:2px solid #e5e7eb;border-radius:8px;font-size:18px;font-weight:600;text-align:center;letter-spacing:2px;text-transform:uppercase;box-sizing:border-box}.code-input:focus{outline:none;border-color:#d3453c;box-shadow:0 0 0 3px #d3453c26}.scanner-section{margin-bottom:24px;padding:20px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.scanner-modal-backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.scanner-modal{background:#fff;border-radius:12px;padding:20px;max-width:520px;width:100%;box-shadow:0 10px 30px #0003;box-sizing:border-box}.scanner-modal-title{margin:0 0 8px;font-size:18px;font-weight:600;text-align:center;color:#111827}.scanner-modal-subtitle{margin:0 0 16px;font-size:14px;text-align:center;color:#6b7280}#reader{width:100%;max-width:480px;margin:0 auto 16px;border-radius:8px;overflow:hidden;min-height:260px;background:#000;display:block}#reader video{width:100%;height:auto;display:block}#reader canvas{display:none}.scanner-modal-actions{text-align:center;margin-top:8px}.coupon-modal-backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;box-sizing:border-box}.coupon-modal{background:#fff;border-radius:12px;padding:24px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #0003;box-sizing:border-box;position:relative}.coupon-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #e5e7eb}.coupon-modal-header h3{margin:0;font-size:20px;font-weight:600;color:#111827}.coupon-modal-close{background:none;border:none;font-size:32px;color:#6b7280;cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.coupon-modal-close:hover:not(:disabled){background:#f3f4f6;color:#111827}.coupon-modal-close:disabled{opacity:.5;cursor:not-allowed}.coupon-info{background:#f9fafb;border-radius:8px;padding:20px;border:2px solid #e5e7eb}.coupon-status{display:inline-block;padding:8px 16px;border-radius:6px;font-weight:600;font-size:14px;margin-bottom:16px}.coupon-status.redeemed{background:#d1fae5;color:#065f46}.coupon-status.pending{background:#fef3c7;color:#92400e}.coupon-details h3{margin:0 0 8px;color:#111827;font-size:20px}.coupon-description{margin:0 0 16px;color:#6b7280;font-size:14px}.coupon-code{display:flex;align-items:center;gap:12px;padding:16px;background:#fff;border-radius:8px;margin-bottom:16px;border:2px solid #D3453C}.code-label{font-size:14px;color:#6b7280;font-weight:500}.code-value{font-size:24px;font-weight:700;color:#d3453c;letter-spacing:2px;font-family:Courier New,monospace}.coupon-meta{display:flex;flex-direction:column;gap:8px}.meta-item{font-size:14px;color:#374151}.meta-item strong{color:#111827}.validity-dates{font-size:12px;color:#6b7280;margin-top:4px}.valid{color:#059669}.invalid{color:#dc2626}.coupon-actions{display:flex;gap:12px;margin-top:20px}.btn-redeem{flex:1}.loading-message{text-align:center;padding:20px;color:#6b7280}.error-message{background:#fee;color:#c33;padding:12px;border-radius:8px;margin-bottom:16px;text-align:center}.btn-primary,.btn-secondary{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}.btn-primary{background:#d3453c;color:#fff}.btn-primary:hover:not(:disabled){background:#b83830}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#e5e7eb;color:#374151}.btn-secondary:hover{background:#d1d5db}.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:1px solid #e5e7eb;border-radius:8px;font-size:16px;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#d3453c;box-shadow:0 0 0 3px #d3453c26}.quick-actions-section{margin-bottom:24px;padding:20px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.quick-actions-header{margin-bottom:16px}.quick-actions-header h2{margin:0;font-size:18px;color:#111827;font-weight:600}.quick-actions-content{display:flex;flex-direction:column;gap:16px}.quick-action-card{padding:16px;background:#fff;border-radius:8px;border:1px solid #e5e7eb;width:100%;box-sizing:border-box}.quick-action-card h3{margin:0 0 8px;font-size:16px;color:#111827}.quick-action-card p{margin:0 0 12px;font-size:13px;color:#6b7280}.view-controls{margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #e5e7eb}.view-controls .filter-controls{margin-top:0}.view-tabs{display:flex;gap:8px;margin-bottom:16px}.view-tab{flex:1;padding:12px 16px;border:2px solid #e5e7eb;background:#fff;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.view-tab:hover{border-color:#d3453c;background:#fef2f2}.view-tab.active{border-color:#d3453c;background:#d3453c;color:#fff}.filter-controls{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:12px}.filter-controls label{font-size:14px;font-weight:500;color:#374151}.filter-select{padding:8px 12px;border:2px solid #e5e7eb;border-radius:6px;font-size:14px;background:#fff;cursor:pointer;transition:border-color .2s}.filter-select:focus{outline:none;border-color:#d3453c}.filter-info{font-size:14px;color:#6b7280;font-weight:500}.redeem-notice{margin-bottom:16px;padding:12px 16px;border-radius:8px;font-size:14px;border:1px solid transparent}.redeem-notice-success{background:#ecfdf3;border-color:#bbf7d0;color:#166534}.redeem-notice-info{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.redeem-notice-error{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.cupones-list{margin-top:24px}.table-wrapper{overflow-x:auto;background:#fff;border-radius:8px;border:1px solid #e5e7eb;margin-bottom:16px}.cupones-table{width:100%;border-collapse:collapse;font-size:14px}.cupones-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.cupones-table th{padding:12px 16px;text-align:left;font-weight:600;color:#374151;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.cupones-table td{padding:12px 16px;border-bottom:1px solid #f3f4f6;color:#374151}.cupones-table tbody tr:hover{background:#f9fafb}.cupones-table tbody tr:last-child td{border-bottom:none}.status-badge-table{display:inline-block;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:600;white-space:nowrap}.status-badge-table.redeemed{background:#d1fae5;color:#065f46}.status-badge-table.pending{background:#fef3c7;color:#92400e}.code-value-table{font-family:Courier New,monospace;font-weight:700;color:#d3453c;letter-spacing:1px;font-size:15px}.oferta-cell{display:flex;flex-direction:column;gap:4px}.oferta-cell strong{color:#111827;font-size:14px}.oferta-desc{font-size:12px;color:#6b7280;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-redeem-table{padding:6px 12px;font-size:13px;white-space:nowrap}.redeemed-badge-small{display:inline-block;padding:4px 8px;background:#d1fae5;color:#065f46;border-radius:4px;font-size:12px;font-weight:600}.pagination{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#fff;border-radius:8px;border:1px solid #e5e7eb;flex-wrap:wrap;gap:12px}.pagination-btn{padding:8px 16px;border:2px solid #e5e7eb;background:#fff;border-radius:6px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){border-color:#d3453c;color:#d3453c}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:14px;color:#374151}.pagination-count{font-size:12px;color:#6b7280}.empty-state{text-align:center;padding:40px 20px;color:#6b7280}@media(max-width:768px){.redeem-page{padding:12px}.redeem-container{padding:16px}.quick-actions-content,.redeem-options{grid-template-columns:1fr}.btn-redeem{width:100%}.view-tabs{flex-direction:column}.filter-controls,.filter-group{flex-direction:column;align-items:stretch}.filter-select{width:100%}.table-wrapper{overflow-x:scroll}.cupones-table{min-width:800px}.cupones-table th,.cupones-table td{padding:8px 12px;font-size:13px}.pagination{flex-direction:column;gap:12px}.pagination-btn{width:100%}.coupon-modal{max-width:100%;margin:0;max-height:95vh;padding:16px}.coupon-modal-header h3{font-size:18px}.coupon-actions{flex-direction:column}.coupon-actions .btn-primary,.coupon-actions .btn-secondary{width:100%}}.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}.cart-terms{margin:24px 0 0;padding:16px;background-color:#f8f9fa;border-radius:8px;font-size:.875rem;color:#6b7280;text-align:center;line-height:1.5}.cart-terms__link{color:var(--color-primary, #D3453C);text-decoration:underline;font-weight:500;transition:color .2s}.cart-terms__link:hover{color:var(--color-primary-dark, #B71C1C);text-decoration:none}.cart-terms__link:focus{outline:2px solid var(--color-primary, #D3453C);outline-offset:2px;border-radius:2px}@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}}
