:root{--bg: #faf8f5;--surface: #ffffff;--border: #e8e0d4;--text: #1a1a1a;--muted: #6b6560;--accent: #8b7355;--accent-dark: #6d5a44;--success: #2d6a4f;--danger: #9b2226;--warn: #ca6702}*{box-sizing:border-box}body{margin:0;font-family:DM Sans,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}a{color:var(--accent-dark);text-decoration:none}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:.75rem 1rem;min-height:3.5rem;padding:0 1.25rem;background:#ffffffe6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);box-shadow:0 1px #8b73550f;flex-shrink:0;overflow:visible}.app-header__brand{display:flex;flex-direction:column;gap:.05rem;flex-shrink:0;min-width:0}.app-header__title{font-size:1.05rem;font-weight:700;color:var(--accent-dark);text-decoration:none;line-height:1.2;white-space:nowrap}.app-header__title:hover{color:var(--accent)}.app-header__systems-link{font-size:.72rem;color:var(--muted);text-decoration:none}.app-header__systems-link:hover{color:var(--accent-dark)}.app-header__nav{display:flex;align-items:center;gap:.15rem;flex:1;min-width:0;overflow-x:auto;overflow-y:visible;scrollbar-width:thin}.header-nav-group{display:flex;align-items:center;gap:.15rem;flex-shrink:0}.header-nav-group__sep{width:1px;height:1.2rem;margin:0 .25rem;background:var(--border);flex-shrink:0}.app-header__actions{display:flex;align-items:center;gap:.35rem;flex-shrink:0;margin-left:auto}.app-header__menu-btn{display:none;flex-direction:column;justify-content:center;gap:.22rem;width:2.35rem;height:2.35rem;padding:.45rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);cursor:pointer}.header-nav-link{display:inline-flex;align-items:center;padding:.42rem .75rem;border-radius:999px;color:var(--text);font-size:.88rem;font-weight:600;text-decoration:none;white-space:nowrap;transition:background .15s,color .15s}.header-nav-link:hover,.header-nav-link.is-active{background:#f3ede4;color:var(--accent-dark)}.header-nav-dropdown{position:relative;flex-shrink:0}.header-nav-dropdown__trigger{display:inline-flex;align-items:center;gap:.3rem;padding:.42rem .75rem;border:none;border-radius:999px;background:transparent;color:var(--text);font:inherit;font-size:.88rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s}.header-nav-dropdown__trigger:hover,.header-nav-dropdown.is-open .header-nav-dropdown__trigger{background:#f3ede4;color:var(--accent-dark)}.header-nav-dropdown__chevron{font-size:.65rem;color:var(--muted);transition:transform .15s}.header-nav-dropdown.is-open .header-nav-dropdown__chevron{transform:rotate(180deg)}.header-nav-dropdown__menu{position:absolute;top:calc(100% + .35rem);left:0;min-width:11rem;padding:.35rem;border:1px solid var(--border);border-radius:10px;background:var(--surface);box-shadow:0 10px 28px #0000001a;z-index:110}.header-nav-dropdown__item{display:block;padding:.45rem .65rem;border-radius:7px;color:inherit;font-size:.88rem;font-weight:500;text-decoration:none}.header-nav-dropdown__item:hover,.header-nav-dropdown__item.is-active{background:#f3ede4;color:var(--accent-dark)}.app-mobile-nav{position:fixed;top:3.5rem;left:0;right:0;max-height:calc(100vh - 3.5rem);overflow-y:auto;z-index:95;padding:.75rem 1rem 1.25rem;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:0 12px 28px #00000014}.app-mobile-nav__group+.app-mobile-nav__group{margin-top:.85rem;padding-top:.85rem;border-top:1px solid var(--border)}.app-mobile-nav__label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:.35rem}.app-mobile-nav__link{display:block;padding:.5rem .65rem;border-radius:8px;color:var(--text);font-weight:500;text-decoration:none}.app-mobile-nav__link:hover,.app-mobile-nav__link.is-active{background:#f3ede4;color:var(--accent-dark)}.app-main{flex:1;min-width:0}.main{padding:1rem 1.25rem 2rem;max-width:1400px;width:100%;min-width:0;margin:0 auto}.page-lead{color:var(--muted);margin-top:-.75rem;margin-bottom:1rem;font-size:.92rem}.text-muted{color:var(--muted);font-size:.9rem}.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}.page-title{margin:0 0 1.25rem;font-size:1.5rem}.section-heading{font-size:1rem;margin:1.5rem 0 .75rem;color:var(--accent-dark);font-weight:700;letter-spacing:.02em}.toggle-field{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background:#f8f5f0;border:1px solid var(--border);border-radius:10px;min-height:3rem}.toggle-field .toggle-label{font-weight:600;font-size:.9rem}.toggle-field .toggle-hint{display:block;font-weight:400;font-size:.8rem;color:var(--muted);margin-top:.15rem}.toggle-switch{position:relative;width:44px;height:24px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#ccc;border-radius:24px;cursor:pointer;transition:.2s}.toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}.toggle-switch input:checked+.toggle-slider{background:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.price-mode-bar{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}.price-mode-bar button{padding:.45rem .9rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);cursor:pointer;font-weight:600;font-size:.85rem}.price-mode-bar button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.payment-status-bar{display:inline-flex;gap:0;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--surface)}.payment-status-bar button{padding:.4rem .75rem;border:none;background:transparent;cursor:pointer;font-weight:600;font-size:.82rem;color:var(--muted);white-space:nowrap}.payment-status-bar button+button{border-left:1px solid var(--border)}.payment-status-bar button.active-paid{background:#d8f3dc;color:#1b4332}.payment-status-bar button.active-unpaid{background:#ffe5e5;color:#9b2226}.payment-status-bar.compact button{padding:.3rem .55rem;font-size:.75rem}.delivery-status-bar{display:inline-flex;gap:0;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--surface)}.delivery-status-bar button{padding:.4rem .75rem;border:none;background:transparent;cursor:pointer;font-weight:600;font-size:.82rem;color:var(--muted);white-space:nowrap}.delivery-status-bar button+button{border-left:1px solid var(--border)}.delivery-status-bar button.active-delivered{background:#d8f3dc;color:#1b4332}.delivery-status-bar button.active-pending{background:#fff3cd;color:#856404}.delivery-status-bar.compact button{padding:.3rem .55rem;font-size:.75rem}.clickable-cell{cursor:pointer}.clickable-cell:hover{background:#f8f4ee}.cart-line{border:1px solid var(--border);border-radius:10px;padding:1rem;margin-bottom:.75rem;background:#faf8f5}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.25rem;margin-bottom:1rem;overflow:visible}.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.stat-value{font-size:1.75rem;font-weight:700;color:var(--accent-dark)}.stat-label{font-size:.85rem;color:var(--muted)}table{width:100%;border-collapse:collapse;font-size:.9rem}th,td{text-align:left;padding:.6rem .5rem;border-bottom:1px solid var(--border)}th{color:var(--muted);font-weight:600;font-size:.8rem}.btn{border:none;border-radius:8px;padding:.5rem 1rem;font-weight:600;cursor:pointer;font-family:inherit;font-size:.9rem}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-dark)}.btn-ghost{background:transparent;color:var(--accent-dark);border:1px solid var(--border)}.btn-danger{background:var(--danger);color:#fff}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem;margin-bottom:.75rem}label{display:block;font-size:.8rem;font-weight:600;color:var(--muted);margin-bottom:.25rem}input,select,textarea{width:100%;padding:.5rem .6rem;border:1px solid var(--border);border-radius:8px;font-family:inherit;font-size:.9rem}.alert{padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.alert-error{background:#fde8e8;color:var(--danger)}.alert-warn{background:#fff4e6;color:var(--warn);border:1px solid #f4c89a}.alert-success{background:#e8f5e9;color:var(--success)}.badge{display:inline-block;padding:.15rem .5rem;border-radius:999px;font-size:.75rem;font-weight:600;background:#f3ede4;color:var(--accent-dark)}.toolbar{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:1rem}h4{margin:1rem 0 .5rem;font-size:.95rem;color:var(--accent-dark)}.searchable-select{position:relative}.searchable-select-input-row{display:flex;gap:0}.searchable-select-input-row input{flex:1;border-radius:8px 0 0 8px}.searchable-select-toggle{border:1px solid var(--border);border-left:none;background:#f3ede4;border-radius:0 8px 8px 0;padding:0 .65rem;cursor:pointer;color:var(--accent-dark);font-size:.7rem}.searchable-select-list{position:absolute;z-index:50;left:0;right:0;top:calc(100% + 2px);background:var(--surface);border:1px solid var(--border);border-radius:8px;margin:0;padding:0;list-style:none;max-height:180px;overflow:auto;box-shadow:0 6px 16px #0000001a}.searchable-select-list li{padding:.5rem .65rem;cursor:pointer;border-bottom:1px solid var(--border)}.searchable-select-list li:last-child{border-bottom:none}.searchable-select-list li:hover{background:#f3ede4}.searchable-select-hint{color:var(--muted);font-size:.8rem}.searchable-select-empty{position:absolute;z-index:50;left:0;right:0;top:calc(100% + 2px);background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.5rem .65rem;color:var(--muted);font-size:.85rem}.form-row>div{overflow:visible}.table-scroll{overflow-x:auto;margin:0 -.25rem}.catalog-table{min-width:920px}.catalog-table .col-product{min-width:120px;white-space:nowrap}.catalog-table .col-qty{width:4.5rem}.catalog-table .col-qty input{text-align:center;padding:.35rem .25rem}.catalog-table .col-date{width:9.5rem}.catalog-table .col-date input{padding:.35rem .4rem;font-size:.82rem}.catalog-table textarea{min-width:160px;resize:vertical;font-size:.82rem;line-height:1.35}.catalog-table td{vertical-align:top}.catalog-table .col-rich{min-width:200px}.label-template-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;align-items:start}@media(max-width:960px){.label-template-grid{grid-template-columns:1fr}}.code-area{font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:.78rem;line-height:1.4}.label-preview-frame{border:1px solid var(--border);border-radius:10px;background:#e8e0d4;min-height:420px;overflow:hidden}.label-preview-iframe{width:100%;height:420px;border:none;background:#e8e0d4}.dashboard-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.dashboard-header .page-title{margin:0}.period-picker{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.period-picker select{padding:.35rem .5rem;border-radius:6px;border:1px solid var(--border)}.period-label{color:var(--muted);font-size:.85rem}.dashboard-charts{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.25rem}@media(max-width:900px){.dashboard-charts{grid-template-columns:1fr}}.bar-chart--h .bar-chart__row{display:grid;grid-template-columns:minmax(80px,1fr) auto;grid-template-areas:"label value" "track track";gap:.2rem .75rem;margin-bottom:.65rem;align-items:center}.bar-chart__label{grid-area:label;font-size:.82rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-chart__value{grid-area:value;font-size:.8rem;font-weight:600;color:var(--muted);white-space:nowrap}.bar-chart__track{grid-area:track;height:8px;background:#f0ebe3;border-radius:4px;overflow:hidden}.bar-chart__fill{height:100%;border-radius:4px;min-width:2px}.bar-chart__total{display:flex;justify-content:space-between;align-items:center;margin-top:.35rem;padding-top:.65rem;border-top:1px solid var(--border)}.bar-chart__total-label{font-size:.88rem;font-weight:600}.bar-chart__total-value{font-size:.95rem;font-weight:700;color:var(--danger)}.bar-chart--v{display:flex;align-items:flex-end;gap:.5rem;min-height:160px;padding-top:.5rem}.bar-chart__col{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:0}.bar-chart__track-v{width:100%;height:120px;display:flex;align-items:flex-end;background:#f0ebe3;border-radius:4px 4px 0 0}.bar-chart__fill-v{width:100%;border-radius:4px 4px 0 0;min-height:2px}.bar-chart--v .bar-chart__label{font-size:.65rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.profit-target-chart__plot{position:relative}.profit-target-chart__lines{position:absolute;left:0;right:0;top:.5rem;height:120px;z-index:2;pointer-events:none}.profit-target-chart__bars{position:relative;z-index:1}.profit-target-chart__line{position:absolute;left:0;right:0;height:2px}.profit-target-chart__line--min{background:var(--warn);box-shadow:0 0 0 1px #ca670240}.profit-target-chart__line--desired{background:var(--success);box-shadow:0 0 0 1px #2d6a4f40}.profit-target-chart__legend{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.75rem;font-size:.82rem;color:var(--muted)}.profit-target-chart__legend-item{display:inline-flex;align-items:center;gap:.4rem}.profit-target-chart__swatch{width:1.25rem;height:3px;border-radius:2px}.profit-target-chart__swatch--min{background:var(--warn)}.profit-target-chart__swatch--desired{background:var(--success)}.profit-goals-panel{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--border)}.profit-goals-panel h4{margin:0 0 .35rem;font-size:1.05rem}.profit-goals-panel h5{margin:1rem 0 .5rem;font-size:.95rem}.profit-goals-panel__lead{font-size:.9rem;margin:0 0 1rem}.profit-goals-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-bottom:.5rem}.profit-goals-summary__item{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:.65rem .75rem;display:flex;flex-direction:column;gap:.15rem}.profit-goals-summary__item strong{font-size:1.05rem}.profit-goals-summary__item small{color:var(--muted);font-size:.78rem}.profit-goals-table{width:100%;font-size:.88rem}.profit-goals-table th,.profit-goals-table td{padding:.45rem .5rem;text-align:left;vertical-align:top}.text-success{color:var(--success)}.sales-ingredients-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.85rem}.sales-ingredients-elab{display:flex;align-items:center;gap:.4rem;font-size:.88rem;font-weight:600;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none}.sales-ingredients-elab input{accent-color:var(--accent)}tr.row-muted td{color:var(--muted)}tr.row-elaboracion td{background:#f3ede4;color:var(--accent-dark);font-weight:600;border-top:1px solid var(--accent);border-bottom:1px solid var(--accent)}tr.row-elaboracion td:first-child{box-shadow:inset 3px 0 0 var(--accent)}.rich-text-editor{border:1px solid var(--border);border-radius:8px;background:var(--surface);overflow:hidden}.rte-toolbar-compact{position:relative;border-bottom:1px solid var(--border);background:#faf8f5}.rte-format-toggle{border:none;background:transparent;padding:.3rem .5rem;font-size:.78rem;cursor:pointer;font-family:inherit;color:var(--accent-dark);width:auto;text-align:left}.rte-toolbar-popup{display:flex;flex-wrap:wrap;gap:.25rem;padding:.3rem .4rem .4rem;border-top:1px solid var(--border)}.rte-toolbar{display:flex;flex-wrap:wrap;gap:.25rem;padding:.25rem .35rem;border-bottom:1px solid var(--border);background:#faf8f5}.rte-btn{border:1px solid var(--border);background:var(--surface);border-radius:6px;padding:.2rem .45rem;font-size:.78rem;cursor:pointer;font-family:inherit}.rte-btn:hover{background:#f3ede4}.rte-body{padding:.45rem .55rem;font-size:.82rem;line-height:1.4;outline:none;max-height:160px;overflow-y:auto}.rte-body:empty:before{content:attr(data-placeholder);color:var(--muted);pointer-events:none}.nav-toggle{display:none;position:fixed;top:.65rem;left:.65rem;z-index:120;width:2.5rem;height:2.5rem;padding:.45rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);cursor:pointer;flex-direction:column;justify-content:center;gap:.22rem}.nav-toggle-bar{display:block;height:2px;background:var(--accent-dark);border-radius:1px}.nav-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;border:none;background:#00000059;cursor:pointer}.nav-group{margin-bottom:.35rem}.nav-group-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.4rem .5rem;border:none;background:transparent;color:var(--muted);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;font-family:inherit}.nav-group-chevron{font-size:.65rem;transition:transform .2s}.nav-group-trigger[aria-expanded=true] .nav-group-chevron{transform:rotate(180deg)}.nav-group-items{display:none;padding-left:.15rem}.nav-group-items.is-open{display:block}.sidebar-brand h1{font-size:1.1rem;margin:0 0 .25rem;color:var(--accent-dark)}.sidebar-brand p{margin:0 0 1rem;font-size:.8rem;color:var(--muted)}.collapsible{border:1px solid var(--border);border-radius:10px;margin-bottom:.65rem;background:var(--surface);overflow:hidden}.collapsible-trigger{display:flex;align-items:center;gap:.65rem;width:100%;padding:.7rem .85rem;border:none;background:#faf8f5;cursor:pointer;text-align:left;font-family:inherit}.collapsible-title{display:block;font-weight:700;font-size:.92rem;color:var(--text)}.collapsible-subtitle{display:block;font-size:.78rem;color:var(--muted);margin-top:.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.collapsible-trigger-text{flex:1;min-width:0}.collapsible-badge{flex-shrink:0}.collapsible-chevron{flex-shrink:0;color:var(--muted);transition:transform .2s}.collapsible.is-open .collapsible-chevron{transform:rotate(180deg)}.collapsible-panel{padding:.85rem;border-top:1px solid var(--border)}.collapsible-panel[hidden]{display:none}.catalog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.catalog-card{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:#fff;display:flex;flex-direction:column}.catalog-card-media{position:relative;aspect-ratio:4 / 3;background:#f3ede4;overflow:hidden}.catalog-card-media img{width:100%;height:100%;object-fit:cover;display:block}.catalog-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;color:var(--accent);opacity:.45}.catalog-card-body{padding:.85rem 1rem 1rem;flex:1;display:flex;flex-direction:column;gap:.35rem}.catalog-card-body h3{margin:0;font-size:1.05rem;color:var(--accent-dark)}.catalog-card-prices{margin:0;font-weight:600;font-size:.88rem;color:var(--success)}.catalog-card-meta{margin:0;font-size:.8rem;color:var(--muted)}.catalog-card-desc{margin:0;font-size:.85rem;line-height:1.45;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.catalog-detail-block{margin-bottom:.75rem}.catalog-detail-block h4{margin:0 0 .25rem;font-size:.82rem;color:var(--accent-dark)}.catalog-detail-block ul{margin:0;padding-left:1.1rem;font-size:.85rem}.catalog-detail-block p{margin:0;font-size:.85rem}.recipe-photo-upload{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-start}.recipe-photo-upload.compact .recipe-photo-frame{width:88px;height:66px}.recipe-photo-frame{width:140px;height:105px;border:1px dashed var(--border);border-radius:10px;overflow:hidden;background:#f8f5f0;display:flex;align-items:center;justify-content:center}.recipe-photo-frame img{width:100%;height:100%;object-fit:cover}.recipe-photo-placeholder{font-size:.78rem;color:var(--muted)}.recipe-photo-actions{display:flex;flex-direction:column;gap:.35rem;align-items:flex-start}.labels-list{display:block}.labels-compact-list{display:flex;flex-direction:column;gap:.65rem}.label-compact-collapsible.collapsible{margin-bottom:0}.label-compact-collapsible.has-qty{border-color:var(--accent);box-shadow:0 0 0 1px #8b735526}.label-compact-collapsible .collapsible-panel{padding-top:.5rem}.label-compact-fields{display:grid;grid-template-columns:repeat(3,minmax(90px,1fr));gap:.45rem;margin-bottom:.45rem}.label-compact-fields label,.label-compact-texts .field-block{display:flex;flex-direction:column;gap:.2rem}.field-label,.label-compact-fields label{font-size:.72rem;color:var(--muted)}.label-compact-fields input{font-size:.82rem;padding:.3rem .4rem}.label-compact-texts{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.resizable-table{width:100%;table-layout:fixed}.resizable-table td,.resizable-table th{overflow:hidden;text-overflow:ellipsis;vertical-align:top}.resizable-table td>*{max-width:100%}.resizable-th{position:relative;-webkit-user-select:none;user-select:none}.th-label,.th-sort-btn{display:inline-flex;align-items:center;gap:.25rem;max-width:calc(100% - 10px)}.th-sort-btn{border:none;background:transparent;font:inherit;font-weight:600;color:inherit;cursor:pointer;padding:0;text-align:left}.th-sort-btn:hover,.th-sort-btn.active{color:var(--accent-dark)}.sort-indicator{font-size:.65rem;color:var(--muted);flex-shrink:0}.th-sort-btn.active .sort-indicator{color:var(--accent-dark)}.inline-edit-field,.stock-inline{display:flex;align-items:center;gap:.35rem;flex-wrap:nowrap}.inline-edit-field input,.stock-inline input{width:4.5rem;padding:.3rem .45rem;font-size:.85rem;border:1px solid var(--border);border-radius:6px;background:var(--surface)}.inline-edit-field select,.stock-inline select{font-size:.85rem;padding:.28rem .35rem;border:1px solid var(--border);border-radius:6px;background:var(--surface)}.inline-edit-field .btn-icon,.stock-inline .btn-icon{padding:.2rem .45rem;font-size:.8rem;line-height:1;flex-shrink:0}.interactive-td{vertical-align:middle}.th-inner{display:flex;align-items:center;gap:.2rem;max-width:calc(100% - 12px);min-width:0}.col-drag-handle{cursor:grab;color:var(--muted);font-size:.75rem;flex-shrink:0;padding:0 .1rem;-webkit-user-select:none;user-select:none}.resizable-th.th-dragging{opacity:.55}.resizable-th[draggable=true]:hover .col-drag-handle{color:var(--accent-dark)}.col-resize-handle{position:absolute;top:0;right:0;width:10px;height:100%;cursor:col-resize;touch-action:none;background:linear-gradient(90deg,transparent 0%,rgba(139,115,85,.12) 55%,rgba(139,115,85,.28) 100%);border-left:1px solid rgba(139,115,85,.35);z-index:2}@media(max-width:768px){.col-resize-handle{width:22px;right:-4px}.resizable-th .th-inner{max-width:calc(100% - 20px)}}.col-resize-handle:hover{background:linear-gradient(90deg,transparent 0%,rgba(139,115,85,.2) 40%,rgba(139,115,85,.45) 100%);border-left-color:var(--accent)}.clickable-row{cursor:pointer}.clickable-row:hover{background:#f8f4ee}.row-selected{background:#f3ede4!important}.price-history-block{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.price-history-table .row-active{background:#f0faf4}.recipe-photo-grid{display:flex;flex-wrap:wrap;gap:.5rem}.recipe-photo-frame{position:relative;width:96px;height:96px;border-radius:8px;overflow:hidden;border:1px solid var(--border);background:#f3ede4}.recipe-photo-remove{position:absolute;top:2px;right:2px;border:none;background:#9b2226e6;color:#fff;width:1.35rem;height:1.35rem;border-radius:4px;cursor:pointer;font-size:.9rem;line-height:1}.stacked-bar-chart{display:flex;flex-direction:column;gap:.55rem}.stacked-bar-legend{display:flex;flex-wrap:wrap;gap:.75rem 1rem;font-size:.78rem;color:var(--muted);margin-bottom:.15rem}.stacked-bar-legend i{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:.25rem;vertical-align:middle}.stacked-bar-row{display:grid;grid-template-columns:minmax(80px,1fr) 2fr auto;gap:.5rem;align-items:center}.stacked-bar-track-wrap{background:#eee8df;border-radius:5px;height:14px;overflow:hidden}.stacked-bar-track{display:flex;height:100%;min-width:2px}.stacked-bar-segment{height:100%;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;min-width:0}.stacked-bar-segment-value{font-size:.62rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.35);padding:0 3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.chart-toggles{display:flex;flex-wrap:wrap;gap:.65rem 1.25rem;margin-bottom:.75rem}.chart-toggle{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.82rem;-webkit-user-select:none;user-select:none}.chart-toggle-text{color:var(--muted)}.widget-sort-picker{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;margin-top:-.15rem}.widget-sort-label{color:var(--muted)}.widget-sort-picker select{width:auto;min-width:9.5rem;padding:.28rem .5rem;font-size:.82rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:inherit}.top-products-chart h3{margin-top:0}.stacked-bar-label{font-size:.82rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stacked-bar-value{font-size:.78rem;text-align:right;min-width:5rem;font-weight:500}.dual-bar-chart{display:flex;flex-direction:column;gap:.55rem}.dual-bar-legend{display:flex;gap:1rem;font-size:.78rem;color:var(--muted)}.dual-bar-legend i{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:.25rem;vertical-align:middle}.dual-bar-row{display:grid;grid-template-columns:minmax(80px,1fr) 2fr auto;gap:.5rem;align-items:center}.dual-bar-tracks{display:flex;flex-direction:column;gap:3px}.dual-bar-track{height:7px;background:#eee8df;border-radius:4px;overflow:hidden}.dual-bar-fill{height:100%;border-radius:4px;min-width:2px}.dual-bar-value{font-size:.78rem;text-align:right;min-width:5.5rem}.dual-bar-value small{display:block;color:var(--muted)}.dashboard-widgets{container-type:inline-size;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}@container (min-width: 720px){.dashboard-widgets{grid-template-columns:repeat(3,minmax(0,1fr))}}.dashboard-widgets .card{margin-bottom:0;height:100%}.dashboard-widget--stat{min-width:0}.dashboard-stat-card{display:flex;flex-direction:column;justify-content:center;min-height:6.5rem}.dashboard-stat-card .stat-value{font-size:clamp(1.2rem,4cqi,1.75rem);line-height:1.2;word-break:break-word}.dashboard-stat-card .stat-label{line-height:1.3}.dashboard-widget--wide{grid-column:1 / -1}.drag-sort-item{position:relative;min-width:0}.drag-sort-item.dragging{opacity:.65}.drag-handle{position:absolute;top:.5rem;right:.5rem;cursor:grab;color:var(--muted);font-size:1rem;z-index:2;padding:.2rem .35rem;border-radius:4px;background:#ffffffd9}.catalog-grid--animated .catalog-card--animated{animation:catalogFadeIn .45s ease both}@keyframes catalogFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.catalog-card--animated:hover{transform:translateY(-3px);box-shadow:0 8px 22px #8b73552e;transition:transform .2s ease,box-shadow .2s ease}.catalog-photo-count{position:absolute;bottom:6px;right:6px;background:#0000008c;color:#fff;font-size:.72rem;padding:.15rem .4rem;border-radius:6px}.catalog-card-ingredients{font-size:.78rem;color:var(--muted);margin:.35rem 0 0}.changelog-viewer__toolbar{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}.changelog-viewer__pre{margin:0;padding:1rem 1.1rem;max-height:min(70vh,32rem);overflow:auto;border:1px solid var(--border);border-radius:10px;background:#faf8f5;font-family:JetBrains Mono,Cascadia Code,Consolas,monospace;font-size:.78rem;line-height:1.45;white-space:pre-wrap;word-break:break-word}@media print{.app-header,.app-mobile-nav,.nav-backdrop,.app-header__menu-btn,.toolbar input,.toolbar button{display:none!important}.main{padding:0;max-width:none}.catalog-card--animated{break-inside:avoid;animation:none;box-shadow:none}}.portal-page{min-height:100vh;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem 3rem;background:var(--bg)}.portal-card{width:100%;max-width:420px}.portal-card--wide{max-width:960px}.system-picker-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.system-picker-card{display:flex;flex-direction:column;gap:.5rem;padding:1.25rem;border:1px solid var(--border);border-radius:var(--radius, 12px);background:var(--surface);color:inherit;text-decoration:none;transition:border-color .15s,box-shadow .15s}.system-picker-card:hover{border-color:var(--accent);box-shadow:0 4px 20px #0000000f}.system-picker-card h3{margin:0;color:var(--accent-dark)}.system-picker-card p{margin:0;flex:1;color:var(--muted);font-size:.92rem}.sidebar-footer{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}.btn-sm{padding:.3rem .55rem;font-size:.78rem}.user-avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;object-fit:cover;color:#fff;font-weight:700;flex-shrink:0;overflow:hidden}.user-avatar--sm{--avatar-size: 2rem;width:var(--avatar-size);height:var(--avatar-size)}.user-avatar--md{--avatar-size: 2.5rem;width:var(--avatar-size);height:var(--avatar-size)}.user-avatar--lg{--avatar-size: 3.25rem;width:var(--avatar-size);height:var(--avatar-size)}.user-avatar--xl{--avatar-size: 6.5rem;width:var(--avatar-size);height:var(--avatar-size);box-shadow:0 8px 24px #0000001f}.user-avatar__letter{display:block;font-size:calc(var(--avatar-size) * .8);line-height:1;font-weight:700;-webkit-user-select:none;user-select:none}.user-menu{position:relative;flex-shrink:0}.user-menu__trigger{display:inline-flex;align-items:center;justify-content:center;width:2.35rem;height:2.35rem;padding:0;border:2px solid transparent;border-radius:50%;background:transparent;color:inherit;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .12s}.user-menu__trigger:hover{border-color:var(--border)}.user-menu.is-open .user-menu__trigger{border-color:var(--accent);box-shadow:0 0 0 3px #8b73552e}.user-menu__panel{position:absolute;top:calc(100% + .5rem);right:0;min-width:9.5rem;padding:.35rem;border:1px solid var(--border);border-radius:10px;background:var(--surface);box-shadow:0 8px 28px #0000001f;z-index:120}.user-menu__sep{margin:.3rem 0;border:none;border-top:1px solid var(--border)}.user-menu__item{display:block;width:100%;padding:.45rem .65rem;border:none;border-radius:7px;background:transparent;color:inherit;font:inherit;font-size:.88rem;text-align:left;text-decoration:none;cursor:pointer;white-space:nowrap}.user-menu__item:hover{background:#f3ede4;color:var(--accent-dark)}.user-menu__item--danger{color:var(--danger)}.user-menu__item--danger:hover{background:#fdf0f0;color:var(--danger)}.password-field label{display:block;margin-bottom:.35rem}.password-field__row{display:flex;align-items:stretch;gap:0;border-radius:8px;overflow:hidden;border:1px solid var(--border);background:var(--surface);transition:border-color .15s,box-shadow .15s}.password-field__row:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #8b73551f}.password-field__row.is-visible{border-color:var(--accent)}.password-field__input{flex:1;min-width:0;border:none!important;border-radius:0!important;box-shadow:none!important;background:transparent}.password-field__input:focus{outline:none}.password-field__toggle{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:2.65rem;padding:0;border:none;border-left:1px solid var(--border);background:#f3ede4;color:var(--accent-dark);cursor:pointer;transition:background .15s,color .15s}.password-field__toggle:hover{background:#ebe3d6;color:var(--accent)}.password-field__row.is-visible .password-field__toggle{background:var(--accent);color:#fff;border-left-color:var(--accent-dark)}.profile-field-label{display:block;margin-bottom:.35rem;font-size:.9rem}.profile-readonly-value{padding:.5rem .6rem;border:1px solid var(--border);border-radius:8px;background:#f8f5f0;color:var(--muted);font-size:.9rem}.portal-shell{width:100%;max-width:420px;display:flex;flex-direction:column;gap:1rem}.portal-shell--wide{max-width:960px}.portal-user-banner{display:flex;align-items:center;gap:1rem;padding:1.1rem 1.25rem;color:inherit;text-decoration:none;transition:border-color .15s,box-shadow .15s}.portal-user-banner:hover{border-color:var(--accent);box-shadow:0 4px 20px #0000000f}.portal-user-banner__text{display:flex;flex-direction:column;gap:.1rem;min-width:0}.portal-user-banner__greeting{font-size:.82rem;color:var(--muted)}.portal-user-banner__name{font-size:1.2rem;font-weight:700;color:var(--accent-dark)}.portal-user-banner__hint{font-size:.8rem;color:var(--muted)}.profile-page{align-items:center}.profile-shell{width:100%;max-width:880px;display:flex;flex-direction:column;gap:1rem}.profile-hero{display:flex;align-items:center;gap:1.5rem;padding:1.5rem}.profile-hero__avatar-wrap{display:flex;flex-direction:column;align-items:center;gap:.65rem;flex-shrink:0}.profile-hero__avatar-actions{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:center}.profile-hero__title{margin:0;font-size:1.65rem;color:var(--accent-dark)}.profile-hero__meta{margin:.25rem 0 .5rem;color:var(--muted)}.profile-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.profile-section h2{margin:0 0 1rem;font-size:1.05rem;color:var(--accent-dark)}.profile-section--wide{grid-column:1 / -1}.profile-form{display:flex;flex-direction:column;gap:.85rem}.profile-form small{display:block;margin-top:.25rem}.profile-meta-list{margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem 1.5rem}.profile-meta-list dt{margin:0 0 .2rem;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.profile-meta-list dd{margin:0;font-weight:600}.profile-chip-row{display:flex;flex-wrap:wrap;gap:.35rem}.profile-footer-actions{display:flex;justify-content:space-between;gap:.75rem}@media(max-width:720px){.profile-hero{flex-direction:column;text-align:center}.profile-grid{grid-template-columns:1fr}}.sidebar-system-link{color:var(--muted);font-size:.8rem}.module-visibility-editor h4{margin:0 0 .5rem;font-size:.95rem;color:var(--accent-dark)}.module-visibility-group{margin-bottom:.85rem}.module-visibility-group h4{margin:0 0 .4rem;font-size:.88rem;font-weight:600;color:var(--muted)}.module-visibility-grid{display:flex;flex-wrap:wrap;gap:.45rem}.module-visibility-toggle{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .65rem;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--muted);font:inherit;font-size:.85rem;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.module-visibility-toggle:hover{border-color:var(--accent);color:var(--text)}.module-visibility-toggle.is-on{background:#f3ede4;border-color:var(--accent);color:var(--accent-dark);font-weight:600}.module-visibility-dot{width:.55rem;height:.55rem;border-radius:50%;background:var(--border);flex-shrink:0}.module-visibility-toggle.is-on .module-visibility-dot{background:var(--success)}.admin-user-edit-card{margin-bottom:1.25rem;background:var(--bg);padding:1.1rem 1.15rem}.admin-user-edit-card__title{margin:0 0 1rem;font-size:1rem;color:var(--accent-dark)}.admin-user-form{display:flex;flex-direction:column;gap:1rem;margin-bottom:.25rem}.admin-user-form__toggles{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:.65rem}.admin-user-form__groups{display:flex;flex-direction:column;gap:1rem;padding-top:.15rem}.admin-user-form__actions{margin-top:.25rem;padding-top:.75rem;border-top:1px solid var(--border)}.table-toggle-cell{text-align:center;vertical-align:middle;width:5.5rem;padding:.55rem .5rem}.table-toggle-cell .toggle-switch{display:inline-block;vertical-align:middle}.sales-history-filters{padding:.75rem;border-radius:var(--radius);background:var(--surface-2, rgba(0, 0, 0, .03));border:1px solid var(--border)}.sales-history-filters .form-row{margin-bottom:0}.sales-history-mobile{display:none}.cart-line-collapsible.collapsible{margin-bottom:.75rem}.cart-line-collapsible .cart-line{border:none;padding:0;margin:0;background:transparent}.badge-warn{background:#ffe5e5;color:#9b2226}.template-editor-embedded{padding:0}.mobile-only{display:none}@media(max-width:1100px){.main{padding:1rem}.form-row{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}}@media(max-width:900px){.app-header{padding:0 .85rem;min-height:3rem;gap:.5rem}.app-header__menu-btn.mobile-only{display:flex}.desktop-only{display:none!important}.app-shell.mobile-nav-open .nav-backdrop{display:block}.app-mobile-nav{top:3rem;max-height:calc(100vh - 3rem)}.main{padding:.85rem .85rem 1.5rem}.labels-list,.sales-history-mobile{display:block}th,td{padding:.45rem .35rem;font-size:.82rem}.card{padding:1rem}.btn{font-size:.85rem;padding:.45rem .75rem}}@media(max-width:520px){.page-title{font-size:1.25rem}.catalog-grid{grid-template-columns:1fr}.payment-status-bar,.delivery-status-bar{flex-wrap:wrap}.toolbar{flex-direction:column;align-items:stretch}}
