:root{--color-primary: #ff9724;--color-secondary: #7EBEC5;--color-dark: #353740;--color-success: #057a55;--color-danger: #c81e1e;--color-warning: #c05621;--color-info: #2e8a95;--color-bg: #f5f5f7;--color-border: #e5e7eb;--color-text: #353740;--color-muted: #747d88;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 12px;--shadow-sm: 0 4px 16px rgba(0,0,0,.07);--shadow-md: 0 8px 32px rgba(0,0,0,.15);--shadow-lg: 0 24px 64px rgba(0,0,0,.2);--transition: .12s}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Montserrat,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f5f5f7;color:#353740;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:225px;background:#353740;color:#fff;display:flex;flex-direction:column;flex-shrink:0}.sidebar-logo{padding:22px 18px 18px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo-image{display:block;width:100%;max-width:150px;height:auto}.sidebar-logo p{font-size:10px;color:#9ca3af;margin-top:3px;text-transform:uppercase;letter-spacing:.08em}.sidebar-nav{flex:1;padding:10px 8px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:6px;color:#c1cdcf;font-size:13px;font-weight:500;transition:background .12s,color .12s;margin-bottom:2px}.nav-item:hover{background:#ffffff12;color:#fff}.nav-item.active{background:#ff972426;color:#ff9724;font-weight:600}.nav-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 18px}.nav-icon svg{width:18px;height:18px;display:block}.sidebar-footer{padding:14px 16px;border-top:1px solid rgba(255,255,255,.08)}.user-info{display:flex;align-items:center;gap:10px;margin-bottom:10px}.user-avatar{width:30px;height:30px;border-radius:50%;background:#ff9724;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;color:#fff}.user-name{font-size:13px;font-weight:600;color:#fff}.user-role{font-size:11px;color:#9ca3af}.btn-logout{width:100%;padding:7px;background:transparent;border:1px solid rgba(255,255,255,.15);color:#9ca3af;border-radius:6px;font-size:12px;transition:all .12s;font-family:inherit}.btn-logout:hover{background:#ffffff14;color:#e5e7eb}.main-content{position:relative;flex:1;overflow-y:auto;display:flex;flex-direction:column}.app-shell-actions{position:fixed;top:24px;right:32px;z-index:25;display:flex;align-items:center;gap:10px;pointer-events:none}.app-shell-actions>*{pointer-events:auto}.page-header{padding:24px 140px 20px 32px;background:#fff;border-bottom:1px solid #e5e7eb}.page-title{font-size:20px;font-weight:700;color:#353740}.page-subtitle{font-size:12px;color:#747d88;margin-top:3px}.dashboard-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}.dashboard-page-heading .page-title{font-size:34px;line-height:1;letter-spacing:-.04em}.dashboard-page-heading .page-subtitle{font-size:13px;color:#8b95a7;margin-top:8px}.dashboard-top-actions{display:flex;align-items:center;gap:10px}.dashboard-top-action,.dashboard-top-indicator{position:relative;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:#f8fafc;color:#506079;border:1px solid #dbe5f0;transition:transform .14s ease,background .14s ease,border-color .14s ease,color .14s ease}.dashboard-top-action{cursor:pointer}.dashboard-top-action:hover,.dashboard-top-indicator:hover{transform:translateY(-1px);background:#fff;border-color:#cdd9e8;color:#1f2c3d}.dashboard-top-indicator__dot{width:10px;height:10px;border-radius:50%;background:currentColor;box-shadow:0 0 0 4px #ffffffe6}.dashboard-top-indicator.is-online{color:#14804a}.dashboard-top-indicator.is-offline{color:#c81e1e}.dashboard-top-action:after,.dashboard-top-indicator:after{content:attr(data-tooltip);position:absolute;top:calc(100% + 8px);right:0;padding:7px 10px;border-radius:8px;background:#253246;color:#fff;font-size:11px;font-weight:600;white-space:nowrap;opacity:0;transform:translateY(-4px);pointer-events:none;transition:opacity .14s ease,transform .14s ease;box-shadow:0 10px 24px #0f172a2e;z-index:20}.dashboard-top-action:hover:after,.dashboard-top-indicator:hover:after{opacity:1;transform:translateY(0)}.page-body{padding:24px 32px;flex:1}.card{background:#fff;border-radius:10px;border:1px solid #e5e7eb;padding:20px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:14px;font-weight:600;color:#353740}.dashboard-widget-card{overflow:hidden}.dashboard-widget-header{align-items:flex-start;gap:16px;margin-bottom:0;padding:18px 20px 14px;border-bottom:1px solid #eef2f7}.dashboard-widget-heading{display:flex;flex-direction:column;gap:4px;min-width:0}.dashboard-widget-title{font-size:15px;font-weight:700;line-height:1.1}.dashboard-widget-subtitle{font-size:12px;color:#94a3b8;line-height:1.2}.dashboard-widget-action{margin-left:auto;flex-shrink:0}.dashboard-widget-toggle{width:100%;display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:18px 20px 14px;background:none;border:none;cursor:pointer;font-family:inherit;text-align:left}.dashboard-widget-toggle__meta{display:flex;align-items:center;gap:10px;color:#747d88;flex-shrink:0}.dashboard-widget-toggle__count,.dashboard-widget-toggle__chevron{font-size:12px}.dashboard-widget-scroll{max-height:360px;overflow-y:auto;overscroll-behavior:contain}.import-template-badge-row{display:flex;gap:8px;margin-bottom:10px}.import-pill{display:inline-flex;align-items:center;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.import-pill-success{background:#dcfce7;color:#166534}.import-pill-info{background:#dbeafe;color:#1d4ed8}.import-pill-warning{background:#fef3c7;color:#92400e}.import-pill-danger{background:#fee2e2;color:#b91c1c}.import-pill-muted{background:#e5e7eb;color:#4b5563}.import-section-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:18px;margin-bottom:16px}.import-section-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;flex-wrap:wrap}.import-section-card__title{font-size:14px;font-weight:700;color:#111827}.import-section-card__subtitle{margin-top:4px;font-size:12px;color:#6b7280}.import-actions-bar{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}.import-status-banner{margin-top:14px;border-radius:10px;padding:12px 14px;font-size:12px;font-weight:600}.import-status-banner-success{background:#ecfdf5;color:#166534}.import-status-banner-info{background:#eff6ff;color:#1d4ed8}.import-status-banner-warning{background:#fffbeb;color:#92400e}.import-status-banner-danger{background:#fef2f2;color:#b91c1c}.import-filter-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.import-preview-cell{display:flex;flex-direction:column;gap:6px}.import-kv-item{display:flex;gap:8px;align-items:baseline;flex-wrap:wrap}.import-kv-item__label{font-size:11px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.04em}.import-kv-item__value{font-size:13px;color:#111827}.import-message{display:inline-block;font-size:13px;font-weight:600}.import-message-danger{color:#b91c1c}.import-message-warning{color:#92400e}.import-message-info{color:#1d4ed8}.import-message-success{color:#166534}.import-message-muted{color:#6b7280}.import-detail-list{margin-top:8px;padding-left:18px;color:#6b7280;font-size:12px}.import-detail-list li+li{margin-top:4px}.import-secondary-line{margin-top:4px;font-size:12px;color:#6b7280}.import-dropzone-icon{display:inline-flex;align-items:center;justify-content:center;min-width:78px;padding:6px 12px;border-radius:999px;background:#fff7ed;color:#c2410c;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.import-verification-wrap{margin-top:20px}.dashboard-widget-table-scroll{max-height:360px;overflow:auto;overscroll-behavior:contain}.dashboard-widget-table-scroll thead th{position:sticky;top:0;z-index:1}.dashboard-vigilance-card{overflow:hidden}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:28px}.stat-card{background:linear-gradient(180deg,#fff,#fdfdfd);border-radius:14px;border:1px solid #dde5ef;padding:18px 20px 20px;min-height:128px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 10px 24px #0f172a0a;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.stat-card:hover{box-shadow:0 14px 30px #0f172a14;border-color:#cad5e4}.stat-card--interactive{cursor:pointer}.stat-card-button{width:100%;text-align:left;font:inherit;color:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none}.stat-card--interactive:hover{transform:translateY(-1px)}.stat-card--interactive:focus-visible{outline:2px solid #1d4ed8;outline-offset:2px}.stat-label{font-size:11px;color:#66758a;font-weight:800;text-transform:uppercase;letter-spacing:.1em;line-height:1.45;max-width:11ch}.stat-value{font-size:34px;font-weight:800;margin-top:10px;line-height:.95}.stat-sub{font-size:12px;color:#97a3b6;margin-top:10px;line-height:1.4}.stat-value.danger{color:#c81e1e}.stat-value.success{color:#057a55}.stat-value.primary{color:#ff9724}.stat-value.warning{color:#c05621}.stat-value.muted{color:#9ca3af}.stat-value.teal{color:#2e8a95}.import-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:2px solid #f3f4f6;padding-bottom:0}.import-tab{display:flex;align-items:center;gap:6px;padding:8px 20px;border:none;background:transparent;font-size:13px;font-weight:600;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;border-radius:6px 6px 0 0}.import-tab:hover{color:#111827;background:#f9fafb}.import-tab.active{color:#ff9724;border-bottom-color:#ff9724;background:#fff7ed}.import-layout{display:grid;grid-template-columns:340px 1fr;gap:20px;align-items:flex-start}@media (max-width: 900px){.import-layout{grid-template-columns:1fr}}.import-section-title{font-size:13px;font-weight:700;color:#374151;margin:0 0 12px;text-transform:uppercase;letter-spacing:.05em}.import-template-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:16px;margin-bottom:16px}.import-template-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}.import-template-title{font-size:13px;font-weight:700;color:#111827;margin:0 0 4px}.import-template-desc{font-size:11px;color:#6b7280;margin:0}.import-columns{display:flex;flex-wrap:wrap;gap:6px}.import-col-badge{display:flex;flex-direction:column;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:5px 10px;min-width:80px}.import-col-badge.required{background:#fff7ed;border-color:#fed7aa}.import-col-name{font-size:11px;font-weight:700;color:#374151;font-family:Courier New,monospace}.import-col-badge.required .import-col-name{color:#c05621}.import-col-hint{font-size:10px;color:#9ca3af;margin-top:1px}.import-dropzone{border:2px dashed #d1d5db;border-radius:12px;padding:40px 24px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;cursor:pointer;transition:all .15s;background:#fafafa;text-align:center}.import-dropzone:hover{border-color:#ff9724;background:#fff7ed}.import-dropzone.has-file{border-color:#057a55;border-style:solid;background:#f0fdf4}.import-dropzone.uploading{cursor:default;opacity:.7}.import-dropzone-text{font-size:13px;font-weight:600;color:#374151;margin:0}.import-dropzone-hint{font-size:11px;color:#9ca3af;margin:0}.import-results{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:20px}.import-results-summary{display:flex;gap:12px;margin-bottom:16px}.import-stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:14px 8px;border-radius:8px;background:#f9fafb;border:1px solid #e5e7eb}.import-stat-ok{background:#f0fdf4;border-color:#bbf7d0}.import-stat-skip{background:#fefce8;border-color:#fde68a}.import-stat-num{font-size:28px;font-weight:800;color:#111827;line-height:1}.import-stat-ok .import-stat-num{color:#057a55}.import-stat-skip .import-stat-num{color:#854d0e}.import-stat-lbl{font-size:10px;font-weight:600;color:#6b7280;text-transform:uppercase;margin-top:4px;letter-spacing:.05em}.import-errors{margin-top:12px}.import-errors-title{font-size:12px;font-weight:700;color:#374151;margin:0 0 8px}.import-tips{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:14px 16px}.import-tips-title{font-size:11px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin:0 0 8px}.import-tips-list{margin:0;padding-left:18px}.import-tips-list li{font-size:11px;color:#6b7280;margin-bottom:5px;line-height:1.5}.import-tips-list code{background:#e5e7eb;padding:1px 4px;border-radius:3px;font-size:10px}.import-main{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:20px}.notif-bell{position:relative;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:#ffffff14;border:none;cursor:pointer;color:#e5e7eb;transition:background .15s}.notif-bell svg{display:block}.notif-bell:hover{background:#ffffff29}.dashboard-top-action.notif-bell{width:40px;height:40px;border-radius:12px;background:#f8fafc;color:#506079;border:1px solid #dbe5f0}.dashboard-top-action.notif-bell:hover{background:#fff;color:#1f2c3d;border-color:#cdd9e8}.notif-badge{position:absolute;top:-3px;right:-3px;min-width:16px;height:16px;border-radius:8px;background:#e02424;color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px;border:1.5px solid #252630}.notif-panel{position:absolute;bottom:0;left:calc(100% + 8px);width:320px;background:#fff;border-radius:10px;box-shadow:0 8px 32px #00000038;z-index:1000;overflow:hidden}.notif-panel--header{top:calc(100% + 10px);right:0;left:auto;bottom:auto}@media (max-width: 720px){.notif-panel{left:0;bottom:calc(100% + 8px)}.notif-panel--header{right:0;left:auto;top:calc(100% + 10px);bottom:auto;width:min(320px,calc(100vw - 32px))}}.notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 10px;border-bottom:1px solid #f0f0f0}.notif-panel-header h4{margin:0;font-size:13px;font-weight:700;color:#111827}.notif-list{max-height:320px;overflow-y:auto}.notif-item{display:flex;gap:10px;align-items:flex-start;padding:10px 16px;border-bottom:1px solid #f9fafb;cursor:pointer;transition:background .12s}.notif-item-button{width:100%;background:none;border:none;text-align:left;color:inherit}.notif-item:hover{background:#f9fafb}.notif-item:focus-visible{outline:2px solid #1d4ed8;outline-offset:-2px;background:#f8fafc}.notif-item.notif-read{opacity:.55}.notif-dot{width:7px;height:7px;border-radius:50%;background:#ff9724;margin-top:5px;flex-shrink:0}.notif-item.notif-read .notif-dot{background:transparent}.notif-title{font-size:12px;font-weight:600;color:#111827;margin-bottom:2px}.notif-message{font-size:11px;color:#6b7280;line-height:1.4}.notif-time{font-size:10px;color:#9ca3af;margin-top:3px}.notif-empty{padding:24px 16px;text-align:center;color:#9ca3af;font-size:12px}.notif-wrapper{position:relative}.dashboard-row{display:flex;gap:16px;align-items:flex-start}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:100px;font-size:13px;font-weight:600;border:none;transition:all .15s;white-space:nowrap;letter-spacing:.02em}.btn-primary{background:#ff9724;color:#fff}.btn-primary:hover:not(:disabled){background:#e8850d;box-shadow:0 4px 12px #ff972459}.btn-danger{background:#e02424;color:#fff}.btn-danger:hover:not(:disabled){background:#c81e1e}.btn-success{background:#057a55;color:#fff}.btn-success:hover:not(:disabled){background:#046c4e}.btn-outline{background:transparent;color:#353740;border:1.5px solid #c1cdcf;border-radius:100px}.btn-outline:hover:not(:disabled){background:#f5f5f7;border-color:#747d88}.btn-sm{padding:5px 12px;font-size:12px}.btn:disabled{opacity:.55;cursor:not-allowed}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.badge-ok{background:#def7ec;color:#057a55}.badge-alerta{background:#fde8e8;color:#c81e1e}.badge-pendiente{background:#f3f4f6;color:#6b7280}.badge-info{background:#e0f4f6;color:#2e8a95}.badge-restringido{background:#fff3e0;color:#c05621}.badge-advertencia{background:#fefce8;color:#854d0e}.badge-pendiente-rev{background:#eff6ff;color:#1d4ed8}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}th{padding:10px 16px;text-align:left;font-size:11px;font-weight:700;color:#747d88;text-transform:uppercase;letter-spacing:.06em;border-bottom:2px solid #e5e7eb;background:#fafafa;white-space:nowrap}td{padding:11px 16px;border-bottom:1px solid #f3f4f6;font-size:13px;color:#353740;vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr:hover td{background:#fffbf5}.table-link{color:#ff9724;font-weight:600}.table-link:hover{text-decoration:underline}.ingredient-row.prohibido td{background:#fff5f5}.ingredient-row.prohibido td:first-child{border-left:3px solid #e02424}.ingredient-row.restringido td{background:#fffbf0}.ingredient-row.restringido td:first-child{border-left:3px solid #c05621}.ingredient-row.advertencia td{background:#fefce8}.ingredient-row.advertencia td:first-child{border-left:3px solid #854d0e}.ingredient-row.prohibited td{background:#fff5f5}.ingredient-row.prohibited td:first-child{border-left:3px solid #e02424}.ingredient-ok{color:#057a55;font-weight:600;font-size:12px}.ingredient-prohibited{color:#e02424;font-weight:700;font-size:12px}.badge-category{background:#f0f9ff;color:#0369a1;font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.05em}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:600;color:#353740;margin-bottom:6px}.form-input{width:100%;padding:9px 12px;border:1.5px solid #c1cdcf;border-radius:8px;font-size:13px;color:#353740;background:#fff;transition:border-color .12s,box-shadow .12s}.form-input:focus{outline:none;border-color:#ff9724;box-shadow:0 0 0 3px #ff972426}.form-input.error{border-color:#e02424}.form-textarea{resize:vertical;min-height:100px;border-radius:8px}.form-error{font-size:12px;color:#e02424;margin-top:4px}.form-hint{font-size:12px;color:#747d88;margin-top:4px}.products-filter-summary-pill{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:#fff7ed;color:#b45309;font-size:12px;font-weight:600;border:1px solid #fed7aa}.products-filters-panel{padding:16px 20px;margin-bottom:12px;background:linear-gradient(180deg,#fbfdff,#f8fafc);border:1px solid #e5edf3}.products-filters-panel__header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}.products-filters-panel__title{margin:0;font-size:14px;font-weight:700;color:#353740}.products-filters-panel__subtitle{margin:4px 0 0;font-size:12px;color:#6b7280}.products-filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;align-items:start}.products-filter-field--wide{grid-column:span 2}.products-filters-empty{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:14px 16px;border:1px dashed #cbd5e1;border-radius:12px;background:#ffffffbf;color:#64748b}.products-filter-prefs{display:grid;gap:16px}.products-filter-prefs__hero{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;padding:16px 18px;border-radius:14px;background:linear-gradient(135deg,#fff7ed,#f8fafc);border:1px solid #fde68a}.products-filter-prefs__title{font-size:14px;font-weight:700;color:#2f3542}.products-filter-prefs__subtitle{margin:6px 0 0;font-size:12px;color:#6b7280;max-width:540px}.products-filter-prefs__presets{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.products-filter-prefs__list{display:grid;gap:10px}.products-filter-prefs__item{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:14px 16px;border:1px solid #e5e7eb;border-radius:12px;background:#fff}.products-filter-prefs__item.is-muted{opacity:.65}.products-filter-prefs__check{display:flex;gap:12px;align-items:flex-start;flex:1;cursor:pointer}.products-filter-prefs__label{font-size:13px;font-weight:700;color:#353740}.products-filter-prefs__description{margin-top:4px;font-size:12px;color:#6b7280}.products-filter-prefs__actions{display:flex;gap:8px}.products-sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.products-sortable-header>span:first-child{display:inline-block}.products-sort-indicator{display:inline-flex;align-items:center;justify-content:center;min-width:14px;margin-left:6px;color:#94a3b8;font-size:11px;font-weight:700}.table-toolbar{display:flex;justify-content:flex-end;gap:8px;padding:12px 16px 0}.table-column-config__intro{margin:0 0 14px;font-size:13px;color:#6b7280}.table-column-config__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.table-column-config__item{display:flex;gap:10px;align-items:flex-start;padding:12px 14px;border:1px solid #e5e7eb;border-radius:12px;background:#fff}.table-column-config__item.is-required{background:#f8fafc}.table-column-config__label{display:flex;gap:8px;align-items:center;font-size:13px;font-weight:700;color:#353740}.table-column-config__badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:10px;font-weight:700;text-transform:uppercase;color:#0f766e;background:#ccfbf1}.table-column-config__description{margin-top:4px;font-size:12px;color:#6b7280}.ingredient-modal-row{display:grid;grid-template-columns:minmax(240px,1.8fr) minmax(150px,1fr) minmax(130px,.8fr) auto;gap:10px;align-items:start}.ingredient-modal-row__actions{align-self:end}@media (max-width: 760px){.products-filters-panel__header,.products-filters-empty,.products-filter-prefs__hero,.products-filter-prefs__item{flex-direction:column;align-items:stretch}.products-filter-prefs__presets,.products-filter-prefs__actions{justify-content:flex-start}.products-filter-field--wide{grid-column:span 1}.ingredient-modal-row{grid-template-columns:minmax(0,1fr)}.ingredient-modal-row__actions{justify-self:start}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#353740,#2a2d35 60%,#1e2025);position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:-120px;right:-120px;width:400px;height:400px;border-radius:50%;background:#ff972414;pointer-events:none}.login-container:after{content:"";position:absolute;bottom:-80px;left:-80px;width:300px;height:300px;border-radius:50%;background:#7ebec512;pointer-events:none}.login-card{background:#fff;border-radius:16px;padding:44px 40px;width:100%;max-width:390px;box-shadow:0 24px 64px #0000004d;position:relative;z-index:1}.login-logo{text-align:center;margin-bottom:32px}.login-logo-image{display:block;width:100%;max-width:260px;height:auto;margin:0 auto 14px}.login-logo-tagline{font-size:11px;color:#747d88;text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-bottom:4px}.login-logo-sub{font-size:12px;color:#c1cdcf;margin-top:6px}.login-divider{height:1px;background:#f0f0f0;margin:0 0 24px}.login-error{background:#fde8e8;color:#c81e1e;padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:16px;border-left:3px solid #e02424}.alert-banner{display:flex;align-items:flex-start;gap:12px;padding:16px 18px;border-radius:14px;margin-bottom:24px}.alert-danger{background:#fde8e8;border:1px solid #f8b4b4;color:#c81e1e}.alert-success{background:#def7ec;border:1px solid #84e1bc;color:#046c4e}.alert-info{background:#e0f4f6;border:1px solid #7EBEC5;color:#2e8a95}.alert-warning{background:#fff3e0;border:1px solid #fcd08a;color:#c05621}.alert-advertencia{background:#fefce8;border:1px solid #fde68a;color:#854d0e}.alert-banner-title{font-weight:700;font-size:13px;margin-bottom:4px}.alert-banner-text{font-size:12px;line-height:1.6}.dashboard-alert-banner{background:linear-gradient(180deg,#fff8f7,#fffdfc);border-color:#f3c9c4;color:#a63a33;box-shadow:0 14px 26px #c81e1e0d}.dashboard-alert-banner .alert-banner-title{font-size:14px;color:#8f2d26}.dashboard-alert-banner .alert-banner-text{color:#b25a51}.dashboard-alert-list{display:grid;gap:10px;margin-top:14px;max-height:280px;overflow-y:auto;padding-right:4px;overscroll-behavior:contain}.dashboard-alert-hidden-toggle{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px}.dashboard-alert-list--hidden{margin-top:10px;max-height:220px}.dashboard-alert-item{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;border-radius:12px;background:#ffffffeb;border:1px solid rgba(200,30,30,.12)}.dashboard-alert-item--hidden{border-style:dashed;background:#ffffffb3}.dashboard-alert-item__main{min-width:0}.dashboard-alert-item__title{font-size:14px;font-weight:700;color:#7f1d1d;line-height:1.3}.dashboard-alert-item__meta{margin-top:6px;font-size:11px;color:#9f1239}.dashboard-alert-item__actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.dashboard-alert-item__actions .form-select{min-width:140px;background:#fff}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .12s ease}.modal-box{background:#fff;border-radius:12px;padding:0;width:100%;max-width:520px;max-height:calc(100vh - 48px);display:flex;flex-direction:column;box-shadow:0 24px 64px #0003;animation:slideUp .15s ease;overflow:hidden}.modal-box.modal-lg{max-width:620px}.modal-box.modal-xl{max-width:min(1360px,calc(100vw - 32px))}.modal-box.modal-box-overflow{overflow:visible}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #f3f4f6;flex-shrink:0}.modal-title{margin:0;font-size:15px;font-weight:700;color:#353740}.modal-close{background:none;border:none;font-size:16px;font-weight:700;color:#9ca3af;line-height:1;padding:4px;border-radius:8px}.modal-close:hover{color:#353740}.modal-close:focus-visible,.modal-box:focus-visible{outline:2px solid #1d4ed8;outline-offset:2px}.modal-body{padding:20px 24px;overflow-y:auto;flex:1;min-height:0}.modal-body.modal-body-overflow{overflow:visible}.modal-footer{display:flex;gap:8px;justify-content:flex-end;padding:14px 24px;border-top:1px solid #f3f4f6;flex-shrink:0;background:#f9fafb;border-radius:0 0 12px 12px}.modal-footer--inline{margin:0 -24px -20px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}to{transform:none;opacity:1}}.validation-summary{display:flex;gap:12px;margin-bottom:4px}.summary-item{flex:1;padding:14px;border-radius:8px;text-align:center}.summary-num{font-size:26px;font-weight:800}.summary-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.summary-total{background:#f5f5f7;color:#353740}.summary-ok{background:#def7ec;color:#057a55}.summary-alert{background:#fde8e8;color:#c81e1e}.empty-state{text-align:center;padding:50px 20px;color:#747d88}.empty-state-icon{font-size:44px;margin-bottom:12px}.empty-state h3{font-size:15px;font-weight:600;color:#353740;margin-bottom:6px}.empty-state p{font-size:13px}.spinner{display:inline-block;width:20px;height:20px;border:2px solid #e5e7eb;border-top-color:#ff9724;border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}.spinner-container{display:flex;align-items:center;justify-content:center;padding:60px}@keyframes spin{to{transform:rotate(360deg)}}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-4{gap:16px}.w-full{width:100%}.mb-4{margin-bottom:16px}.mt-4{margin-top:16px}.text-muted{color:#747d88}.text-sm{font-size:12px}.nav-section-label{font-size:10px;font-weight:700;color:#747d88;text-transform:uppercase;letter-spacing:.1em;padding:14px 12px 4px}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:9999}.toast{padding:12px 18px;border-radius:100px;font-size:13px;font-weight:600;max-width:380px;box-shadow:0 4px 24px #0000002e;animation:slideUp .18s ease;letter-spacing:.01em}.toast-success{background:#057a55;color:#fff}.toast-error{background:#c81e1e;color:#fff}.toast-info{background:#7ebec5;color:#fff}.audit-filters{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:16px}.audit-details{margin-top:8px;padding:8px 10px;background:#f5f5f7;border-radius:6px;font-size:11px;line-height:1.5;max-width:300px;overflow-x:auto;white-space:pre-wrap;word-break:break-all}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:16px;padding:8px 0}.pagination-btn{padding:6px 16px;border-radius:100px;border:1.5px solid #c1cdcf;background:#fff;color:#353740;font-size:13px;font-weight:600;cursor:pointer;transition:all .12s;font-family:inherit}.pagination-btn:hover:not(:disabled){background:#f5f5f7;border-color:#747d88}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-info{font-size:13px;color:#747d88}.profile-field{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #f3f4f6}.profile-field:last-child{border-bottom:none}.profile-label{font-size:12px;font-weight:700;color:#747d88;text-transform:uppercase;letter-spacing:.06em;width:110px;flex-shrink:0}.profile-value{font-size:14px;color:#353740;font-weight:500}.user-info-link{display:flex;text-decoration:none;border-radius:8px;padding:4px;margin:-4px;transition:background .12s}.user-info-link:hover{background:#ffffff14}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#c1cdcf;border-radius:3px}.dashboard-customize-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;background:#007aff14;color:#007aff;border:1.5px solid rgba(0,122,255,.2);border-radius:9px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,transform .1s;font-family:inherit}.dashboard-customize-btn:hover{background:#007aff24;border-color:#007aff59;transform:translateY(-1px)}.dashboard-edit-badge{display:inline-flex;align-items:center;gap:7px;padding:6px 14px;background:#007aff1a;color:#007aff;border:1.5px solid rgba(0,122,255,.25);border-radius:9px;font-size:12px;font-weight:700;letter-spacing:.02em}.dashboard-edit-badge:before{content:"";width:7px;height:7px;border-radius:50%;background:#007aff;animation:edit-pulse 1.8s ease-in-out infinite}@keyframes edit-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.page-body--editing{padding-bottom:88px}.widget-edit-ring{border-radius:14px;border:2px dashed rgba(0,122,255,.35);background:#007aff05;transition:border-color .2s,background .2s,box-shadow .2s}.widget-edit-ring:hover{border-color:#007aff99;background:#007aff0a;box-shadow:0 0 0 4px #007aff0f}.widget-dimmed{border-color:#0000001f!important;background:#00000005!important}.widget-edit-bar{display:flex;align-items:center;gap:10px;padding:8px 12px 6px;border-radius:12px 12px 0 0;-webkit-user-select:none;user-select:none}.widget-drag-handle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:7px;color:#9ca3af;cursor:grab;transition:background .15s,color .15s;flex-shrink:0}.widget-drag-handle:hover{background:#0000000f;color:#374151}.widget-drag-handle:active{cursor:grabbing}.widget-edit-label{font-size:12px;font-weight:700;color:#374151;letter-spacing:.01em}.widget-ctrl-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:7px;border:1.5px solid #e5e7eb;background:#fff;color:#6b7280;cursor:pointer;transition:background .15s,border-color .15s,color .15s,transform .1s}.widget-ctrl-btn:hover{background:#f3f4f6;border-color:#d1d5db;color:#374151;transform:scale(1.08)}.widget-ctrl-btn--active{background:#fff0f0;border-color:#fca5a5;color:#c81e1e}.dashboard-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:20px;align-items:start}.dashboard-grid--editing{gap:16px}.widget-size-full{grid-column:span 6}.widget-size-half{grid-column:span 3}.widget-size-third{grid-column:span 2}@media (max-width: 900px){.widget-size-half,.widget-size-third{grid-column:span 6}}@media (max-width: 1200px) and (min-width: 901px){.widget-size-third{grid-column:span 3}}.widget-size-pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;background:#007aff1a;color:#007aff;font-size:10px;font-weight:700;letter-spacing:.02em;white-space:nowrap}.dashboard-edit-bar{position:fixed;bottom:0;left:0;right:0;z-index:300;padding:0 24px;background:#ffffffe0;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-top:1px solid rgba(0,0,0,.08);box-shadow:0 -4px 24px #00000012;animation:editbar-in .25s cubic-bezier(.34,1.56,.64,1)}@keyframes editbar-in{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.dashboard-edit-bar__inner{max-width:1200px;margin:0 auto;height:64px;display:flex;align-items:center;justify-content:space-between}.dashboard-edit-bar__info{display:flex;align-items:center;gap:10px}.dashboard-edit-bar__dot{width:8px;height:8px;border-radius:50%;background:#007aff;animation:edit-pulse 1.8s ease-in-out infinite;flex-shrink:0}::-webkit-scrollbar-thumb:hover{background:#747d88}.grid-stack{background:transparent!important}.grid-stack-item-content{overflow:visible!important;background:transparent!important;border-radius:0!important;box-shadow:none!important}.gs-bar{display:none}body.edit-mode .gs-bar{display:flex;align-items:center;gap:10px;height:36px;padding:0 12px;background:#007aff0f;border:1px solid rgba(0,122,255,.18);border-bottom:none;border-radius:10px 10px 0 0;cursor:grab;-webkit-user-select:none;user-select:none}.gs-bar__grip{display:flex;align-items:center;color:#9ca3af;flex-shrink:0}.gs-bar:hover .gs-bar__grip{color:#374151}.gs-bar:active{cursor:grabbing}.gs-bar__label{font-size:12px;font-weight:700;color:#374151;letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gs-bar__hide{margin-left:auto;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;border:1px solid #e5e7eb;background:#fff;color:#6b7280;font-size:13px;cursor:pointer;transition:background .15s,border-color .15s,color .15s;flex-shrink:0;line-height:1}.gs-bar__hide:hover{background:#fff0f0;border-color:#fca5a5;color:#c81e1e}body.edit-mode .gs-bar+div .card,body.edit-mode .gs-bar+div .dashboard-widget-card,body.edit-mode .gs-bar+[style] .card,body.edit-mode .gs-bar+[style] .dashboard-widget-card{border-top-left-radius:0!important;border-top-right-radius:0!important}body.edit-mode .grid-stack-item>.grid-stack-item-content{border:2px dashed rgba(0,122,255,.3);border-radius:12px;transition:border-color .2s,box-shadow .2s}body.edit-mode .grid-stack-item>.grid-stack-item-content:hover{border-color:#007aff8c;box-shadow:0 0 0 4px #007aff0f}.gs-resizable-handle,.ui-resizable-handle{display:none!important}body.edit-mode .gs-resizable-handle,body.edit-mode .ui-resizable-handle{display:block!important}body.edit-mode .page-body{padding-bottom:88px}.gs-design-toolbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:300;padding:0 24px;background:#ffffffe0;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-top:1px solid rgba(0,0,0,.08);box-shadow:0 -4px 24px #00000012}body.edit-mode .gs-design-toolbar{display:block;animation:editbar-in .25s cubic-bezier(.34,1.56,.64,1)}.gs-design-toolbar__inner{max-width:1200px;margin:0 auto;height:64px;display:flex;align-items:center;justify-content:space-between}.gs-design-toolbar__info{display:flex;align-items:center;gap:10px}.gs-design-toolbar__dot{width:8px;height:8px;border-radius:50%;background:#007aff;animation:edit-pulse 1.8s ease-in-out infinite;flex-shrink:0}.gs-design-toolbar__done{background:#007aff;color:#fff;border:none;border-radius:8px;padding:7px 18px;font-weight:600;font-size:13px;cursor:pointer}.gs-design-toolbar__done:hover{background:#06d}.filters-toolbar-note{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px;padding:10px 12px;border-radius:14px;background:linear-gradient(135deg,#ff97241a,#7ebec529);border:1px solid rgba(126,190,197,.28);color:#475569;font-size:12px}.filters-toolbar-note__badge{display:inline-flex;align-items:center;padding:4px 9px;border-radius:999px;background:#fff;color:#c56b00;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;box-shadow:0 6px 16px #c56b0014}.binary-choice{display:inline-flex;gap:8px;flex-wrap:wrap}.binary-choice__option{position:relative;display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:0 14px;border-radius:999px;border:1px solid #d7dee7;background:#fff;color:#475569;font-size:13px;font-weight:700;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease,background .14s ease,color .14s ease}.binary-choice__option:hover{transform:translateY(-1px);border-color:#7ebec5;box-shadow:0 10px 20px #7ebec524}.binary-choice__option.is-active{border-color:#ff9724;background:linear-gradient(135deg,#ff972429,#ff972414);color:#8a4b00;box-shadow:0 12px 24px #ff972424}.binary-choice__option input{position:absolute;opacity:0;pointer-events:none}.allergen-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:12px}.allergen-summary-card{display:flex;flex-direction:column;gap:4px;padding:12px 14px;border-radius:14px;background:linear-gradient(180deg,#fffdf8,#fff);border:1px solid #f3e3cc}.allergen-summary-card__label{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#8a6a3f}.allergen-summary-card__value{font-size:20px;line-height:1;color:#353740}.products-name-cell{display:flex;flex-direction:column;gap:6px}.products-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.products-obsolete-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;background:#eef2f7;color:#475569;font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.products-meta-row{display:flex;flex-wrap:wrap;gap:6px}.products-meta-chip{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;background:#f8fafc;border:1px solid #e2e8f0;color:#64748b;font-size:11px;line-height:1.2}.products-category-stack{display:flex;flex-direction:column}.products-ingredient-flags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.products-ingredient-flag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700}.products-ingredient-flag.is-danger{background:#c81e1e1a;color:#b91c1c}.products-ingredient-flag.is-warning{background:#c056211f;color:#b45309}@media (max-width: 720px){.app-shell-actions{top:16px;right:16px}.dashboard-page-header{flex-direction:column;align-items:stretch}.page-header{padding-right:32px}.dashboard-page-heading .page-title{font-size:28px}.dashboard-top-actions{justify-content:flex-start}.stats-grid{grid-template-columns:1fr 1fr}.dashboard-vigilance-card__header{flex-direction:column;align-items:stretch}.dashboard-vigilance-card__action,.dashboard-widget-action{margin-left:0;width:100%}.dashboard-widget-toggle{flex-direction:column;align-items:stretch}.dashboard-widget-toggle__meta{justify-content:space-between}.dashboard-alert-item,.dashboard-alert-hidden-toggle{flex-direction:column;align-items:stretch}.dashboard-alert-item__actions{justify-content:stretch}.dashboard-alert-item__actions .btn,.dashboard-alert-item__actions .form-select{width:100%}.dashboard-widget-scroll,.dashboard-widget-table-scroll,.dashboard-alert-list,.dashboard-alert-list--hidden{max-height:none}.allergen-summary-grid{grid-template-columns:1fr}}@media (max-width: 560px){.stats-grid{grid-template-columns:1fr}}
