:root{--slate-50: #f8fafc;--slate-100: #f1f5f9;--slate-200: #e2e8f0;--slate-300: #cbd5e1;--slate-400: #94a3b8;--slate-500: #64748b;--slate-600: #475569;--slate-700: #334155;--slate-800: #1e293b;--slate-900: #0f172a;--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--red-500: #ef4444;--red-600: #dc2626;--red-700: #b91c1c;--amber-500: #f59e0b;--amber-600: #d97706;--amber-700: #b45309;--green-500: #22c55e;--green-600: #16a34a;--green-700: #15803d;--bg-body: var(--slate-50);--bg-card: #ffffff;--bg-item-hover: var(--slate-50);--bg-header: #ffffff;--text-primary: var(--slate-900);--text-secondary: var(--slate-500);--text-tertiary: var(--slate-400);--text-inverse: #ffffff;--border-default: var(--slate-200);--border-active: var(--slate-300);--pk-primary: var(--primary-600);--pk-success: var(--green-600);--pk-danger: var(--red-600);--pk-warning: var(--amber-600);--pk-warning-text: var(--amber-700);--input-bg: #ffffff;--input-border: var(--slate-300);--radius-xs: 6px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 22px;--radius-pill: 999px;--accent-400: #fb923c;--accent-500: #f97316;--accent-600: #ea580c;--teal-400: #2dd4bf;--teal-500: #14b8a6;--teal-600: #0d9488;--bg-app: #f5f7fb;--sidebar-bg: #0b1220;--sidebar-bg-soft: #111a2e;--sidebar-heading: #f8fafc;--sidebar-text: #aeb9ca;--sidebar-text-strong: #e7ecf3;--sidebar-muted: #707b8f;--sidebar-hover: rgba(255, 255, 255, .06);--sidebar-active-bg: rgba(249, 115, 22, .14);--sidebar-active-text: #ffffff;--sidebar-accent: #f97316;--sidebar-border: rgba(255, 255, 255, .07);--shadow-primary: 0 6px 16px -4px rgba(30, 58, 95, .3);--ring-primary: 0 0 0 4px rgba(30, 58, 95, .15)}body.color-blind{--pk-primary: #0072B2;--pk-success: #0072B2;--pk-danger: #D55E00;--pk-warning: #E69F00;--pk-warning-text: #E69F00;--text-primary: #000000;--text-secondary: #1E293B;--border-default: #475569}:root{font-family:Inter,Segoe UI,system-ui,sans-serif;line-height:1.6;font-weight:400;color:#1e293b;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--pk-success: #16a34a;--pk-danger: #dc2626;--pk-warning: #ca8a04}*{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:#f8fafc}button,input,textarea{font:inherit}body.color-blind{--primary-500: #0072B2 !important;--primary-600: #005FA3 !important;--primary-700: #004C85 !important;--pk-success: #0072B2 !important;--pk-danger: #D55E00 !important;--pk-warning: #E69F00 !important;--slate-500: #1E293B !important;--slate-600: #0F172A !important;--slate-400: #475569 !important;--border-width-active: 2px}body.color-blind .button--primary{background-color:var(--primary-500)!important;border:2px solid #004C85!important;color:#fff!important;font-weight:700!important}body.color-blind .button--secondary{border:2px solid var(--slate-600)!important;color:var(--slate-900)!important}body.color-blind .active-nav-item{background-color:#e1f5fe!important;color:#004c85!important;border-left:4px solid #D55E00!important}body.color-blind .im-btn-group button.active-stock{background-color:var(--primary-500)!important;border-color:var(--primary-700)!important;box-shadow:0 0 0 2px var(--primary-700)!important}body.color-blind .im-save-btn{background-color:var(--pk-success)!important;border:2px solid #004C85!important}body.color-blind .im-suggestion-chip{background-color:#e1f5fe!important;color:#005fa3!important;border:2px solid var(--primary-600)!important}body.color-blind .badge--success{background-color:#e1f5fe!important;color:#0072b2!important;border:1px solid #0072B2!important}body.color-blind .button--success{background-color:#0072b2!important;color:#fff!important;border:2px solid #004C85!important}body.color-blind .button--success:hover{background-color:#005fa3!important}.tabs{display:flex;gap:.5rem;border-bottom:2px solid #e2e8f0;margin-bottom:1.5rem}.tab{padding:.75rem 1.25rem;border:none;background:none;font-weight:500;color:#64748b;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s;font-size:.95rem}.tab:hover{color:#1e293b;background-color:#f1f5f9;border-top-left-radius:6px;border-top-right-radius:6px}.tab--active{color:var(--primary-color, #2563eb);border-bottom-color:var(--primary-color, #2563eb);background-color:transparent!important}.button--warning{background-color:var(--pk-warning);color:#fff;border:none;cursor:pointer;transition:opacity .2s;padding:.5rem 1rem;border-radius:6px;font-weight:500}.button--warning:hover{opacity:.9}.button--warning:active{opacity:.8}:root{font-size:16px;-webkit-text-size-adjust:100%;--primary-50: #eef2f8;--primary-100: #d7e0ee;--primary-500: #2d527e;--primary-600: #1e3a5f;--primary-700: #15293f;--slate-50: #f8fafc;--slate-100: #f1f5f9;--slate-200: #e2e8f0;--slate-300: #cbd5e1;--slate-400: #94a3b8;--slate-500: #64748b;--slate-600: #475569;--slate-700: #334155;--slate-800: #1e293b;--slate-900: #0f172a;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04), 0 1px 1px rgba(15, 23, 42, .03);--shadow: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 6px 16px -6px rgba(15, 23, 42, .12), 0 2px 6px -2px rgba(15, 23, 42, .06);--shadow-lg: 0 16px 36px -12px rgba(15, 23, 42, .16), 0 6px 12px -6px rgba(15, 23, 42, .08)}body{background-color:var(--bg-app, var(--slate-50));color:var(--slate-800);font-family:Inter,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh;align-items:start;width:100%;max-width:100vw;overflow-x:clip}.main-content{padding:2.25rem 2.5rem;background-color:var(--bg-app, var(--slate-50));min-height:100vh;min-width:0;overflow-x:hidden}.sidebar{background:linear-gradient(180deg,var(--sidebar-bg-soft) 0%,var(--sidebar-bg) 100%);border-right:1px solid var(--sidebar-border);padding:.5rem .6rem .9rem;display:flex;flex-direction:column;gap:.6rem;position:sticky;top:0;height:100vh;height:100dvh;overflow-y:auto;color:var(--sidebar-text)}.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#ffffff17;border-radius:8px}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff29}.sidebar-backdrop{position:fixed;inset:0;background:#0f172a73;z-index:1090;animation:sidebar-fade .2s ease}@keyframes sidebar-fade{0%{opacity:0}to{opacity:1}}@media(max-width:768px){.app-shell--mobile{grid-template-columns:1fr!important}.app-shell--mobile .sidebar{position:fixed;top:0;left:0;width:280px;max-width:86vw;height:100vh;height:100dvh;z-index:1100;box-shadow:0 12px 40px #00000059}.main-content{padding:3.25rem 1rem 1.25rem}.sidebar__link,.sidebar__sublink{padding-top:.7rem;padding-bottom:.7rem}}.sidebar__header{padding:.55rem .5rem .45rem;border-bottom:1px solid var(--sidebar-border);margin-bottom:.15rem}.sidebar__nav{display:flex;flex-direction:column;gap:.12rem}.sidebar__link{display:flex;align-items:center;gap:.7rem;padding:.6rem .7rem;border-radius:var(--radius-sm);color:var(--sidebar-text);font-weight:500;font-size:.9rem;text-decoration:none;transition:background .15s ease,color .15s ease;position:relative}.sidebar__link:hover{background:var(--sidebar-hover);color:var(--sidebar-text-strong)}.sidebar__link--active{background:var(--sidebar-active-bg);color:var(--sidebar-active-text);font-weight:600}.sidebar__link--active:before{content:"";position:absolute;left:-.6rem;top:50%;transform:translateY(-50%);width:3px;height:56%;border-radius:0 3px 3px 0;background:var(--sidebar-accent)}.sidebar__icon{display:inline-flex;width:19px;height:19px;flex-shrink:0;align-items:center;justify-content:center;opacity:.8}.sidebar__icon svg{width:18px;height:18px}.sidebar__link:hover .sidebar__icon{opacity:1}.sidebar__link--active .sidebar__icon{color:var(--sidebar-accent);opacity:1}.sidebar__label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__chevron{margin-left:auto;font-size:.62rem;opacity:.45;transition:transform .2s ease}.sidebar__children{margin:.1rem 0 .35rem 1.55rem;padding-left:.45rem;border-left:1px solid var(--sidebar-border);display:flex;flex-direction:column;gap:.05rem}.sidebar__sublink{display:flex;align-items:center;padding:.42rem .6rem;font-size:.84rem;color:var(--sidebar-text);text-decoration:none;border-radius:var(--radius-sm);opacity:.82;transition:background .15s ease,color .15s ease,opacity .15s ease}.sidebar__sublink:hover{color:var(--sidebar-text-strong);background:var(--sidebar-hover);opacity:1}.sidebar__sublink--active{color:var(--sidebar-active-text);background:var(--sidebar-hover);font-weight:600;opacity:1;box-shadow:inset 2px 0 0 var(--sidebar-accent)}.sidebar__logout{margin-top:auto;padding-top:.6rem;border-top:1px solid var(--sidebar-border)}.sidebar .sidebar__logout .button{width:100%;justify-content:flex-start;gap:.65rem;background:transparent!important;border:1px solid transparent!important;color:#94a3b8!important;box-shadow:none!important;filter:none!important;font-weight:500!important;font-size:.92rem;padding:.6rem .7rem!important;border-radius:var(--radius-sm)!important;transition:background-color .15s ease,color .15s ease}.sidebar .sidebar__logout .button svg{flex-shrink:0;opacity:.85}.sidebar .sidebar__logout .button:hover{background:#ef44441f!important;border-color:transparent!important;color:#fca5a5!important}.sidebar__collapse-btn{color:var(--sidebar-muted)!important}.sidebar__collapse-btn:hover{background:var(--sidebar-hover)!important;color:var(--sidebar-text-strong)!important}.main-content select:not([class]),.main-content input:not([class]):not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file]),.main-content textarea:not([class]){padding:.55rem .8rem;border-radius:var(--radius-sm);border:1px solid var(--slate-300);background-color:#fff;color:var(--slate-900);font-size:.9rem;line-height:1.4;transition:border-color .15s ease,box-shadow .15s ease}.main-content select:not([class]):focus,.main-content input:not([class]):not([type=checkbox]):not([type=radio]):focus,.main-content textarea:not([class]):focus{outline:none;border-color:var(--primary-500);box-shadow:var(--ring-primary)}.main-content select:not([class])::placeholder,.main-content input:not([class])::placeholder,.main-content textarea:not([class])::placeholder{color:var(--slate-400)}.main-content select{appearance:none!important;-webkit-appearance:none!important;-moz-appearance:none!important;padding-right:2.1rem!important;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>")!important;background-repeat:no-repeat!important;background-position:right .7rem center!important;cursor:pointer}.panel{background:var(--surface, #ffffff);border:1px solid var(--slate-200);border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:box-shadow .2s ease,border-color .2s ease,transform .2s ease}.panel:hover{box-shadow:var(--shadow-md);border-color:var(--slate-300)}.panel--padded{padding:2rem}.panel__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.panel__header h1{font-size:1.875rem;font-weight:700;color:var(--slate-900);letter-spacing:-.025em;margin:0}.panel__header-actions{display:flex;align-items:center;justify-content:flex-end;gap:.625rem;flex-wrap:wrap;margin-left:auto;flex-shrink:0}.panel__header>:first-child{min-width:0}.input{width:100%;padding:.625rem .875rem;border-radius:8px;border:1px solid var(--slate-300);background:#fff;color:var(--slate-900);font-size:.9rem;transition:all .2s}.input:focus{outline:none;border-color:var(--primary-500);box-shadow:var(--ring-primary)}.input::placeholder{color:var(--slate-400)}.number-input{min-width:0}.number-input.input--small{padding-right:.75rem}.no-spin::-webkit-outer-spin-button,.no-spin::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.no-spin[type=number]{-moz-appearance:textfield}.button{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.6rem 1.15rem;border-radius:var(--radius-sm);font-weight:600;font-size:.9rem;line-height:1.2;white-space:nowrap;transition:background-color .15s ease,color .15s ease,border-color .15s ease,box-shadow .15s ease,transform .1s ease;border:1px solid transparent;cursor:pointer}.button:disabled{opacity:.55;cursor:not-allowed;pointer-events:auto;box-shadow:none!important;transform:none!important}.button--primary{background-color:var(--primary-600);color:#fff;box-shadow:var(--shadow-primary)}.button--primary:hover:not(:disabled){background-color:var(--primary-700);transform:translateY(-1px);box-shadow:0 10px 24px -6px #1e3a5f6b}.button--primary:active:not(:disabled){transform:translateY(0)}.button:not([class*=button--]){background-color:#fff;border-color:var(--slate-300);color:var(--slate-700);box-shadow:var(--shadow-sm)}.button:not([class*=button--]):hover:not(:disabled){background-color:var(--slate-50);border-color:var(--slate-400);color:var(--slate-900)}.button--secondary{background-color:#fff;border-color:var(--slate-300);color:var(--slate-700);box-shadow:var(--shadow-sm)}.button--secondary:hover{background-color:var(--slate-50);border-color:var(--slate-400);color:var(--slate-900)}.button--ghost{background-color:transparent;border-color:transparent;color:var(--slate-600)}.button--ghost:hover:not(:disabled){background-color:var(--slate-100);color:var(--slate-900)}.button--inline{padding:.5rem .875rem;font-size:.85rem}.table-container,.table-wrapper{border:1px solid var(--slate-200);border-radius:12px;overflow-x:auto;overflow-y:hidden;background:#fff}.table{width:100%;border-collapse:collapse;font-size:.9rem}.table th{background-color:var(--slate-50);padding:.7rem 1.25rem;text-align:left;font-weight:600;color:var(--slate-600);text-transform:none;font-size:.8rem;letter-spacing:.01em;border-bottom:2px solid var(--slate-200);position:sticky;top:0;z-index:1;white-space:nowrap;word-break:normal}.table td{word-break:normal;overflow-wrap:normal}.table td.text-right{white-space:nowrap}.table-container,.table-wrapper{overflow-x:auto}.table-container table th,.table-wrapper table th{white-space:nowrap;word-break:normal}.table-container table td,.table-wrapper table td{word-break:normal;overflow-wrap:normal}.table td{padding:.85rem 1.25rem;border-bottom:1px solid var(--slate-100);color:var(--slate-700);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tbody tr{transition:background-color .12s ease}.table tbody tr:nth-child(2n) td{background-color:var(--slate-50)}.table tbody tr:hover td{background-color:var(--primary-50)}.table tbody tr:hover td:first-child{box-shadow:inset 3px 0 0 var(--primary-500)}.main-content .MuiTableHead-root .MuiTableCell-root{background-color:var(--slate-50);font-weight:600;color:var(--slate-600);text-transform:none;font-size:.8rem;letter-spacing:.01em;border-bottom:2px solid var(--slate-200)}.main-content .MuiTableBody-root .MuiTableRow-root:hover>.MuiTableCell-root{background-color:var(--primary-50)}.main-content .MuiTableContainer-root{border-radius:var(--radius-md, 10px)}.production-split{display:flex;flex:1;min-height:0;overflow:hidden}.production-split>div{min-height:0}@media(max-width:880px){.production-split{flex-direction:column;overflow-y:auto}.production-split>div{flex:1 1 auto!important;min-width:0!important;border-right:none!important}}.main-content .panel{overflow-x:auto}.text-right{text-align:right}.text-center{text-align:center}.pick-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.6rem .85rem;border-bottom:1px solid var(--slate-100);transition:background-color .12s ease}.pick-row:last-child{border-bottom:none}.pick-row:hover{background:var(--primary-50)!important}.pick-chip{flex-shrink:0;white-space:nowrap;font-size:.8rem;font-weight:600;padding:.3rem .7rem;border-radius:var(--radius-pill);display:inline-flex;align-items:center;gap:.25rem;transition:background-color .12s ease,color .12s ease,border-color .12s ease}.pick-chip--add{color:var(--primary-700);background:var(--primary-50);border:1px solid var(--primary-100)}.pick-row:hover .pick-chip--add{background:var(--primary-600);color:#fff;border-color:var(--primary-600)}.pick-chip--done{color:var(--green-700);background:#ecfdf5;border:1px solid #d1fae5}.main-content input[type=checkbox],.main-content input[type=radio]{accent-color:var(--primary-600);width:16px;height:16px;cursor:pointer;vertical-align:middle}.panel__header{flex-wrap:wrap;row-gap:.75rem}.toolbar{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.toolbar--end{justify-content:flex-end}.toolbar--between{justify-content:space-between}.segmented{display:inline-flex;padding:3px;background:var(--slate-100);border-radius:var(--radius-md);gap:2px}.segmented__item{padding:.42rem .95rem;border-radius:var(--radius-sm);border:none;background:transparent;font-size:.85rem;font-weight:600;color:var(--slate-600);cursor:pointer;white-space:nowrap;transition:background-color .12s ease,color .12s ease,box-shadow .12s ease}.segmented__item:hover{color:var(--slate-900)}.segmented__item--active{background:#fff;color:var(--primary-700);box-shadow:var(--shadow-sm)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;padding:2.5rem 1.5rem;text-align:center;color:var(--slate-400);font-size:.92rem}.section-title{font-size:1.05rem;font-weight:700;color:var(--slate-900);letter-spacing:-.01em;margin:0 0 .75rem}.field-label{display:block;font-size:.8rem;font-weight:600;color:var(--slate-600);margin-bottom:.3rem}.home-dash{display:flex;flex-direction:column;gap:1.75rem}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.kpi-card{position:relative;display:flex;flex-direction:column;gap:.25rem;padding:1.1rem 1.25rem;background:var(--surface, #fff);border:1px solid var(--slate-200);border-radius:var(--radius-lg, 14px);box-shadow:var(--shadow-sm, 0 1px 2px rgba(15, 23, 42, .04));overflow:hidden}.kpi-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--kpi-accent, var(--primary-600))}.kpi-card__label{font-size:.78rem;font-weight:600;color:var(--slate-500);text-transform:uppercase;letter-spacing:.03em}.kpi-card__value{font-size:1.7rem;font-weight:800;color:var(--slate-900);line-height:1.1}.kpi-card__sub{font-size:.82rem;color:var(--slate-500)}.alert-strip{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem}.alert-strip__title{font-size:.85rem;font-weight:700;color:var(--slate-600);margin-right:.25rem}.alert-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem .8rem;border-radius:var(--radius-pill, 999px);font-size:.85rem;font-weight:600;text-decoration:none;border:1px solid transparent;transition:transform .1s,box-shadow .1s}.alert-chip:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm, 0 2px 6px rgba(15, 23, 42, .08))}.alert-chip__dot{width:8px;height:8px;border-radius:50%;background:currentColor;opacity:.85}.alert-chip__arrow{opacity:.6}.alert-chip--warn{background:#fef3c7;color:#92400e;border-color:#fcd34d}.alert-chip--info{background:#dbeafe;color:#1e40af;border-color:#93c5fd}.brand-compare__row{display:flex;align-items:center;gap:.85rem;padding:.4rem 0}.brand-compare__name{flex:0 0 150px;font-weight:600;color:var(--slate-700);font-size:.9rem}.brand-compare__bar{flex:1;height:12px;background:var(--slate-100);border-radius:999px;overflow:hidden}.brand-compare__fill{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary-500, #14b8a6),var(--accent-500, #f97316));min-width:4px}.brand-compare__val{flex:0 0 110px;text-align:right;font-weight:700;color:var(--slate-800);font-size:.9rem}.trend-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:1rem;margin-bottom:1.1rem}.trend-panel{min-width:0}.trend-panel__hint{font-weight:500;font-size:.78rem;color:var(--slate-500, #64748b)}.trend-chart{width:100%}.trend-chart__legend{display:flex;flex-wrap:wrap;gap:.4rem 1rem;margin-bottom:.5rem}.trend-chart__legend-item{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;color:var(--slate-600, #475569);font-weight:600}.trend-chart__swatch{width:11px;height:11px;border-radius:3px;display:inline-block}.trend-chart__svg{width:100%;height:auto;display:block;overflow:visible}.trend-chart__axis{fill:var(--slate-400, #94a3b8);font-size:11px;font-weight:500}.role-list{display:flex;flex-direction:column;gap:.3rem}.role-list__item{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.6rem .8rem;border:1px solid var(--slate-200);border-radius:var(--radius-md, 10px);background:var(--surface, #fff);cursor:pointer;text-align:left;font-size:.9rem;color:var(--slate-700);transition:background .1s,border-color .1s}.role-list__item:hover{background:var(--slate-50, #f8fafc)}.role-list__item--active{border-color:var(--primary-500, #14b8a6);background:color-mix(in srgb,var(--primary-500, #14b8a6) 10%,#fff);color:var(--slate-900);font-weight:600}.role-list__count{font-size:.72rem;font-weight:700;color:var(--slate-500);background:var(--slate-100);border-radius:999px;padding:.05rem .45rem}.perm-card{border:1px solid var(--slate-200);border-radius:var(--radius-lg, 12px);margin-bottom:.9rem;overflow:hidden}.perm-card__head{display:flex;align-items:center;justify-content:space-between;padding:.55rem .9rem;background:var(--slate-50, #f8fafc);border-bottom:1px solid var(--slate-200)}.perm-card__title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--slate-600)}.perm-card__all{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--slate-600);cursor:pointer}.perm-card__all input{margin:0;cursor:pointer}.perm-card__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.35rem 1rem;padding:.7rem .9rem}.perm-item{display:flex;align-items:center;gap:.5rem;font-size:.86rem;color:var(--slate-700);cursor:pointer}.perm-item input{margin:0;cursor:pointer}.perm-item--locked{color:var(--slate-400);cursor:not-allowed}.home-hero{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.75rem 2rem;border-radius:var(--radius-lg);background:linear-gradient(120deg,#0b1220,#15233f 58%,#1b2c4d);color:#fff;box-shadow:var(--shadow-md);position:relative;overflow:hidden}.home-hero:after{content:"";position:absolute;right:-40px;top:-70px;width:240px;height:240px;pointer-events:none;background:radial-gradient(circle,rgba(249,115,22,.3),transparent 70%)}.home-hero>div{position:relative;z-index:1}.home-hero__eyebrow{margin:0;font-size:.82rem;color:#fb923c;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.home-hero__title{margin:.3rem 0 0;font-size:1.7rem;font-weight:700;letter-spacing:-.02em;color:#fff}.home-hero__sub{margin:.45rem 0 0;color:#aeb9ca;font-size:.95rem}.home-hero__badge{flex-shrink:0;width:54px;height:54px;border-radius:50%;position:relative;z-index:1;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:1px solid rgba(255,255,255,.18);font-size:1.45rem;font-weight:700;color:#fff}.home-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(258px,1fr))}.home-card{display:flex;align-items:center;gap:1rem;padding:1.05rem 1.15rem;background:#fff;border:1px solid var(--slate-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);text-decoration:none;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;position:relative;overflow:hidden}.home-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--card-accent, var(--primary-600));opacity:0;transition:opacity .15s ease}.home-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--card-accent, var(--primary-600))}.home-card:hover:before{opacity:1}.home-card__icon{flex-shrink:0;width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--card-accent, var(--primary-600));background:color-mix(in srgb,var(--card-accent, var(--primary-600)) 11%,#ffffff)}.home-card__icon svg{width:22px;height:22px}.home-card__body{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.home-card__title{font-weight:600;color:var(--slate-900);font-size:.96rem}.home-card__desc{font-size:.82rem;color:var(--slate-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.home-card__arrow{color:var(--slate-300);font-size:1.05rem;transition:transform .15s ease,color .15s ease}.home-card:hover .home-card__arrow{color:var(--card-accent, var(--primary-600));transform:translate(3px)}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--slate-50)}.auth-card{width:100%;max-width:400px;background:#fff;padding:2.5rem;border-radius:24px;box-shadow:var(--shadow-lg);border:1px solid var(--slate-100)}.auth-card h1{text-align:center;font-size:1.75rem;font-weight:700;color:var(--slate-900);margin-bottom:1.5rem}.auth-card__subtitle{text-align:center;color:var(--slate-500);margin-bottom:2rem}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.auth-form__field{display:flex;flex-direction:column;gap:.5rem}.auth-form__field span{font-size:.875rem;font-weight:500;color:var(--slate-700)}.spinner{width:24px;height:24px;border:3px solid var(--slate-200);border-top-color:var(--primary-600);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.export-actions{display:flex;gap:1rem}.column-toggle{position:relative}.column-toggle__menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:#fff;border:1px solid var(--slate-200);border-radius:8px;box-shadow:var(--shadow-lg);padding:.5rem;min-width:200px;z-index:10;display:flex;flex-direction:column;gap:.25rem}.column-toggle__option{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:4px;cursor:pointer;font-size:.875rem;color:var(--slate-700);transition:background-color .2s}.column-toggle__option:hover{background-color:var(--slate-50)}.column-toggle__option input{margin:0}.column-toggle__option--action{justify-content:center;font-weight:600;color:var(--primary-600);border:none;background:none;width:100%}.column-toggle__option--action:hover{background-color:var(--primary-50)}.column-toggle__hint{font-size:.75rem;color:var(--slate-500);padding:.5rem;text-align:center;border-top:1px solid var(--slate-100);margin-top:.25rem}.cost-recalc-split{display:flex}.cost-recalc-split>.button:first-child{border-top-right-radius:0;border-bottom-right-radius:0}.cost-recalc-split__caret{border-top-left-radius:0;border-bottom-left-radius:0;border-left:0;padding-left:.5rem;padding-right:.5rem;font-size:.7rem;line-height:1}.column-toggle__caret{margin-left:.4rem;font-size:.7rem;line-height:1;color:var(--slate-400)}.filters-grid .cost-recalc-split{align-self:start}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem 1.25rem;margin-bottom:1.5rem;padding:1.25rem 1.5rem;background-color:var(--slate-50);border-radius:var(--radius-lg);border:1px solid var(--slate-200)}.filters-grid label{display:flex;flex-direction:column;gap:.5rem}.filters-grid label span{font-size:.875rem;font-weight:500;color:var(--slate-700)}.filters-grid select,.filters-grid input{padding:.625rem;border-radius:6px;border:1px solid var(--slate-300);background:#fff;font-size:.9rem;color:var(--slate-900)}.filters-grid select:focus,.filters-grid input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-50)}.main-content select:disabled,.main-content input:disabled,.input.disabled,.searchable-select.disabled{background-color:var(--slate-50);border-color:var(--slate-200);color:var(--slate-500);cursor:not-allowed;opacity:1;box-shadow:none}@media(max-width:640px){.filters-grid{grid-template-columns:1fr;padding:1rem;gap:.75rem}}.stock-search{position:relative;width:100%;min-width:200px}.stock-search__input-wrapper{position:relative}.stock-search__input{width:100%;padding-right:2rem}.stock-search__clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--slate-400);cursor:pointer;padding:.25rem;font-size:.875rem;line-height:1;border-radius:50%}.stock-search__clear:hover{background-color:var(--slate-100);color:var(--slate-600)}.stock-search__dropdown{position:absolute;top:100%;left:0;right:0;margin-top:.25rem;background:#fff;border:1px solid var(--slate-200);border-radius:8px;box-shadow:var(--shadow-lg);z-index:50;max-height:300px;overflow-y:auto}.stock-search__list{list-style:none;padding:.25rem;margin:0}.stock-search__item{padding:.5rem .75rem;cursor:pointer;border-radius:6px;transition:background-color .2s}.stock-search__item:hover{background-color:var(--slate-50)}.stock-search__item--selected{background-color:var(--primary-50);color:var(--primary-700)}.stock-search__item-name{font-weight:500;font-size:.875rem}.stock-search__item-code{font-size:.75rem;color:var(--slate-500)}.stock-search__message{padding:1rem;text-align:center;color:var(--slate-500);font-size:.875rem}.bulk-save-bar{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);background:var(--slate-900);color:#fff;padding:.5rem 1rem;border-radius:8px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:1rem;font-size:.875rem;z-index:100;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translate(-50%,100%);opacity:0}to{transform:translate(-50%);opacity:1}}.bulk-save-bar__info{font-weight:500}.bulk-save-bar__actions{display:flex;gap:.5rem}.button--inverse{color:#fff;border-color:#ffffff4d}.button--inverse:hover{background-color:#ffffff1a;color:#fff;border-color:#fff}.xml-products{display:flex;flex-direction:column;min-height:calc(100vh - 5rem);padding-bottom:6rem}.xml-products__table-wrapper{flex:1;display:flex;flex-direction:column}.xml-products__table{flex:1}.row--modified td{background-color:var(--primary-50)}.change-indicator{font-size:.75rem;color:var(--primary-700);margin-top:.25rem;font-weight:500}.grid-links{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem;margin-top:2rem}.grid-link-card{display:block;padding:1.5rem;background:#fff;border:1px solid var(--slate-200);border-radius:12px;text-decoration:none;transition:all .2s}.grid-link-card:hover{border-color:var(--primary-500);box-shadow:var(--shadow-md);transform:translateY(-2px)}.grid-link-card h3{margin:0 0 .5rem;font-size:1.1rem;color:var(--slate-900)}.grid-link-card p{margin:0;font-size:.9rem;color:var(--slate-500);line-height:1.4}.xml-upload{display:flex;flex-direction:column;gap:1.25rem}.xml-upload__form{display:grid;gap:1rem}.xml-upload__grid{display:grid;grid-template-columns:2fr 1fr;gap:1rem}.xml-upload__grid--equal{grid-template-columns:1fr 1fr}@media(max-width:1080px){.xml-upload__grid{grid-template-columns:1fr}}.xml-upload__card{border:1px solid var(--slate-200);border-radius:12px;padding:1.5rem;background:#fff;display:flex;flex-direction:column;gap:1rem}.xml-upload__card--sidebar{align-self:start}.xml-upload__card--equal{height:100%}.xml-upload__drop{border:2px dashed var(--slate-300);border-radius:12px;padding:2rem;text-align:center;background:var(--slate-50);color:var(--slate-600);cursor:pointer;transition:all .2s ease}.xml-upload__drop-title{margin:0;font-size:1rem;font-weight:600;color:var(--slate-900)}.xml-upload__drop-hint{margin:.5rem 0 0;color:var(--slate-500);font-size:.875rem}.xml-upload__drop-meta{margin:.5rem 0 0;color:var(--slate-400);font-size:.75rem}.xml-upload__list-wrapper{max-height:300px;overflow-y:auto}.xml-upload__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.xml-upload__item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem;border:1px solid var(--slate-200);border-radius:8px;background:#fff}.xml-upload__item-content{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%}.xml-upload__item--with-match{flex-direction:column;align-items:stretch}.xml-upload__name{margin:0;font-weight:500;color:var(--slate-900);font-size:.9rem}.xml-upload__meta{margin:.25rem 0 0;color:var(--slate-500);font-size:.8rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.xml-upload__drop{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;border:2px dashed var(--slate-300);border-radius:12px;background:var(--slate-50);cursor:pointer;transition:all .2s ease;text-align:center;gap:1rem}.xml-upload__drop:hover{border-color:var(--primary-500);background:var(--primary-50)}.xml-upload__drop-icon{width:48px;height:48px;color:var(--slate-400);margin-bottom:.5rem;transition:color .2s}.xml-upload__drop:hover .xml-upload__drop-icon{color:var(--primary-500)}.xml-upload__drop-button{background:var(--primary-600);color:#fff;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;font-size:.95rem;transition:background .2s;box-shadow:var(--shadow-sm)}.xml-upload__drop:hover .xml-upload__drop-button{background:var(--primary-700);box-shadow:var(--shadow)}.xml-upload__drop-title{font-weight:600;color:var(--slate-700);font-size:1.1rem;margin:0}.xml-upload__drop-hint{color:var(--slate-500);font-size:.9rem;margin:0;max-width:400px;line-height:1.5}.xml-upload__drop-meta{color:var(--slate-400);font-size:.8rem;margin:0}.xml-upload__remove{border:none;background:transparent;color:var(--slate-400);padding:.25rem .5rem;cursor:pointer;font-size:.8rem;transition:color .2s}.xml-upload__remove:hover{color:#ef4444}.xml-upload__actions{display:flex;flex-direction:column;gap:.5rem}.xml-upload__result{margin-top:1rem;padding:1rem;border-radius:8px;border:1px solid var(--primary-100);background:var(--primary-50);display:flex;flex-direction:column;gap:.5rem}.xml-upload__result-title{margin:0;font-weight:600;color:var(--primary-700);font-size:.9rem}.xml-upload__link{color:var(--primary-600);font-weight:500;text-decoration:none}.xml-upload__link:hover{text-decoration:underline}.xml-upload__progress{margin-bottom:1rem}.xml-upload__progress-bar{height:8px;background:var(--slate-200);border-radius:4px;overflow:hidden}.xml-upload__progress-bar-fill{height:100%;background:var(--primary-600);transition:width .2s ease}.xml-upload__progress-label{margin:.5rem 0 0;font-size:.8rem;color:var(--slate-500);text-align:right}.xml-upload__status-log{border:1px solid var(--slate-200);border-radius:8px;padding:1rem;background:var(--slate-50);margin-bottom:1.5rem;font-family:monospace}.xml-upload__status-title{margin:0 0 .5rem;font-weight:600;font-size:.85rem;color:var(--slate-700)}.xml-upload__status-log ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;color:var(--slate-600)}.xml-upload__match-card{width:100%;margin-top:1rem;border:1px solid var(--primary-200);background:var(--primary-50)}.xml-products__filters{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.xml-products__filters-row{display:flex;gap:1rem;align-items:center}.xml-products__search{flex:1;padding:.625rem .875rem;border:1px solid var(--slate-300);border-radius:8px;font-size:.9rem}.xml-products__search:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 4px var(--primary-50)}.xml-products__tabs{display:flex;gap:.5rem;flex-wrap:wrap}.xml-products__tab{border:1px solid var(--slate-200);background:#fff;padding:.5rem 1rem;border-radius:999px;font-size:.875rem;font-weight:500;color:var(--slate-600);cursor:pointer;transition:all .2s}.xml-products__tab:hover{background:var(--slate-50);color:var(--slate-900)}.xml-products__tab.is-active{background:var(--primary-600);border-color:transparent;color:#fff}.xml-products__summary{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;font-size:.875rem;color:var(--slate-500);flex-wrap:wrap;gap:1rem}.xml-products__pagination-controls{display:flex;align-items:center;gap:1rem}.xml-products__pagination{display:flex;gap:.5rem}.xml-products__table-wrapper{overflow-x:auto;border:1px solid var(--slate-200);border-radius:12px;background:#fff}.candidate-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem}.candidate-card{width:100%;text-align:left;border:1px solid #e0e0e0;border-radius:6px;padding:.5rem;background:#fff;box-shadow:0 1px 2px #0000000d;transition:border-color .15s ease,box-shadow .15s ease,transform .1s ease}.candidate-card:hover{border-color:#2c7be5;box-shadow:0 4px 10px #00000014;transform:translateY(-1px)}.candidate-card--selected{border-color:#2c7be5;background:#f5f9ff;box-shadow:0 6px 14px #2c7be526}.candidate-card__title{font-weight:600;margin-bottom:.25rem;font-size:.8rem;line-height:1.3}.candidate-card__meta{font-size:.75rem;color:#4a4a4a}.xml-products__table{width:100%;border-collapse:collapse}.material-issue__form{display:flex;flex-direction:column;gap:2rem;margin-top:1.5rem}.material-issue__dates{display:flex;flex-wrap:wrap;align-items:flex-start;gap:1.25rem 1.5rem;padding:1.5rem;background:#fff;border:1px solid var(--slate-200);border-radius:var(--radius-lg)}.material-issue__dates label{display:flex;flex-direction:column;gap:.5rem}.material-issue__dates select,.material-issue__dates input{padding:.625rem;border:1px solid var(--slate-300);border-radius:6px;font-size:.95rem}.material-issue__panel{display:flex;flex-direction:column;gap:1rem}.material-issue__panel--split{display:grid;grid-template-columns:350px 1fr;gap:2rem;align-items:start}@media(max-width:1024px){.material-issue__panel--split{grid-template-columns:1fr}}.material-issue__title{font-size:1.1rem;font-weight:600;color:var(--slate-800);margin:0;padding-bottom:.5rem;border-bottom:1px solid var(--slate-200)}.material-issue__options{display:flex;gap:1.5rem}.material-issue__options--vertical{flex-direction:column;gap:.75rem}.material-issue__options label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500;color:var(--slate-700)}.material-issue__materials{background:#fff;border:1px solid var(--slate-200);border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;height:600px}.material-issue__filters{display:flex;flex-direction:column;gap:1rem}.material-issue__filters label{display:flex;flex-direction:column;gap:.25rem}.material-issue__filters select,.material-issue__filters input{width:100%;padding:.5rem;border:1px solid var(--slate-300);border-radius:6px}.material-issue__material-table{flex:1;overflow-y:auto;border:1px solid var(--slate-200);border-radius:8px}.material-issue__material-list{width:100%}.material-issue__material-list th{position:sticky;top:0;background:var(--slate-50);z-index:1}.material-issue__material-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem}.material-issue__material-info{display:flex;flex-direction:column;gap:.125rem}.material-issue__item-title{font-weight:500;color:var(--slate-900);font-size:.9rem}.material-issue__item-code{font-size:.75rem;color:var(--slate-500);font-family:monospace}.material-issue__add{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--primary-50);color:var(--primary-600);border:1px solid var(--primary-200);border-radius:6px;cursor:pointer;font-size:1.25rem;line-height:1;transition:all .2s}.material-issue__add:hover{background:var(--primary-600);color:#fff;border-color:var(--primary-600)}.material-issue__selected{background:#fff;border:1px solid var(--slate-200);border-radius:12px;padding:1.5rem;min-height:400px}.material-issue__empty{text-align:center;color:var(--slate-400);padding:3rem 0;font-style:italic}.material-issue__submit{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--slate-200)}.xml-products__table th{background-color:var(--slate-50);padding:.875rem .75rem;text-align:left;font-weight:600;color:var(--slate-600);text-transform:uppercase;font-size:.75rem;letter-spacing:.05em;border-bottom:1px solid var(--slate-200)}.xml-products__table td{padding:1rem .75rem;border-bottom:1px solid var(--slate-100);vertical-align:top}.xml-products__table tr:last-child td{border-bottom:none}.xml-products__name{font-weight:600;color:var(--slate-900);margin:0;font-size:.9rem}.xml-products__meta{margin:.25rem 0 0;font-size:.8rem;color:var(--slate-500)}.xml-products__assign-text-dark{color:var(--slate-900)!important}.input--small{padding:.375rem 2rem .375rem .75rem;font-size:.875rem;width:auto}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{width:100%;padding-right:2.5rem}.password-toggle{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;padding:.25rem;display:flex;align-items:center;justify-content:center;color:var(--slate-400);cursor:pointer;border-radius:4px;transition:color .2s}.password-toggle:hover{color:var(--slate-600);background-color:var(--slate-100)}.password-toggle svg{width:1.25rem;height:1.25rem}.auth-card--twofactor{max-width:480px}.auth-form__actions{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:1rem}.auth-form__actions .button{flex:1}.form-hint{text-align:center;color:var(--slate-600);margin-bottom:1rem;font-size:.95rem;line-height:1.5}.admin-panel{display:flex;flex-direction:column;gap:1.5rem}.filter-card{background:#fff;border:1px solid var(--slate-200);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;transition:all .3s ease}.filter-card--collapsed{padding-bottom:0;border-bottom:none;border-bottom-left-radius:0;border-bottom-right-radius:0;margin-bottom:0}.filter-card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.filter-card--collapsed .filter-card__header{margin-bottom:0;padding-bottom:1.5rem;border-bottom:1px solid var(--slate-200)}.filter-card__title{font-size:1rem;font-weight:600;color:var(--slate-800);margin:0 0 .25rem}.filter-card__hint{font-size:.875rem;color:var(--slate-500);margin:0}.filter-card__actions{display:flex;gap:.5rem}.filters-grid--stock{margin-top:1rem}.filters-grid__item{display:flex;flex-direction:column;gap:.5rem}.filters-grid__item--wide{grid-column:span 2}@media(max-width:768px){.filters-grid__item--wide{grid-column:span 1}}.depot-tree{display:flex;flex-wrap:wrap;gap:.75rem;max-height:168px;overflow-y:auto;padding:.6rem .75rem;border:1px solid var(--slate-200);border-radius:var(--radius-md, 10px);background:var(--slate-50, #f8fafc)}.depot-tree__brand{display:flex;flex-direction:column;gap:.35rem;min-width:150px}.depot-tree__brand-name{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--slate-500, #64748b)}.depot-tree__items{display:flex;flex-direction:column;gap:.25rem}.depot-tree__item{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--slate-700, #334155);cursor:pointer;white-space:nowrap}.depot-tree__item input{width:auto;margin:0;cursor:pointer}.recipes-table{width:100%;border-collapse:collapse;min-width:920px}.recipes-table th{background-color:var(--slate-50);padding:.6rem .85rem;text-align:left;font-size:.72rem;font-weight:600;text-transform:uppercase;color:var(--slate-500);letter-spacing:.04em;border-bottom:1px solid var(--slate-200);white-space:nowrap;word-break:normal}.recipes-table td{padding:.6rem .85rem;font-size:.82rem;color:var(--slate-600);border-bottom:1px solid var(--slate-100);vertical-align:middle;word-break:normal;overflow-wrap:normal}.recipes-table__row:hover td{background-color:var(--slate-50)}.recipes-table__actions-header{width:48px;text-align:center}.recipes-table__actions{text-align:center;padding:.5rem!important}.recipes-table__toggle{width:24px;height:24px;border:1px solid var(--slate-300);border-radius:4px;background:#fff;color:var(--slate-500);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s;padding:0}.recipes-table__toggle:hover{border-color:var(--primary-500);color:var(--primary-600)}.recipes-table__toggle span{display:block;width:8px;height:8px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translate(-1px,-1px);transition:transform .2s}.recipes-table__toggle--open{background:var(--primary-50);border-color:var(--primary-200);color:var(--primary-600)}.recipes-table__toggle--open span{transform:rotate(225deg) translate(-1px,-1px)}.recipes-table__detail td{background-color:var(--slate-50);padding:1.5rem!important;border-bottom:1px solid var(--slate-200)}.recipe-detail-stack{display:grid;gap:1rem}.recipe-process-metric{background:#fff;border:1px solid var(--slate-200);border-radius:12px;padding:1rem 1.25rem}.recipe-process-metric__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.9rem}.recipe-process-metric__header h4{margin:0 0 .25rem;color:var(--slate-900)}.recipe-process-metric__eyebrow{display:inline-block;margin-bottom:.35rem;color:#0f766e;font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.recipe-process-metric__header p{margin:0;color:var(--slate-500);font-size:.9rem}.recipe-process-metric__coverage{color:var(--slate-700);font-size:.85rem;font-weight:600;white-space:nowrap}.recipe-process-metric__coverage--muted{color:var(--slate-400);font-weight:500}.recipe-process-metric__coverage--highlight{color:#0f766e}.recipe-process-metric__coverage-note{margin:0 0 .9rem;color:var(--slate-500);font-size:.9rem}.recipe-process-metric__grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.75rem}.recipe-process-metric__item{background:var(--slate-50);border-radius:10px;padding:.75rem;display:grid;gap:.35rem}.recipe-process-metric__item span{color:var(--slate-500);font-size:.85rem}.recipe-process-metric__item strong{color:var(--slate-900);font-size:1rem}.recipe-process-metric__empty{margin:0;color:var(--slate-500);font-size:.9rem}.recipe-process-metric__footnote{margin:.9rem 0 0;color:var(--slate-500);font-size:.85rem}@media(max-width:900px){.recipe-process-metric__header{flex-direction:column}.recipe-process-metric__coverage{white-space:normal}.recipe-process-metric__grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.recipe-cost-breakdown,.recipe-cost-components{background:#fff;border:1px solid var(--slate-200);border-radius:12px;padding:1rem 1.25rem}.recipe-cost-breakdown__header,.recipe-cost-components__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.9rem}.recipe-cost-breakdown__header h4,.recipe-cost-components__header h4{margin:0 0 .25rem;color:var(--slate-900)}.recipe-cost-breakdown__eyebrow,.recipe-cost-components__eyebrow{display:inline-block;margin-bottom:.35rem;color:#0f766e;font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.recipe-cost-breakdown__header p,.recipe-cost-components__header p,.recipe-cost-breakdown__empty,.recipe-cost-components__empty{margin:0;color:var(--slate-500);font-size:.9rem}.recipe-cost-components__empty{display:flex;align-items:center;gap:1rem}.recipe-cost-breakdown__table,.recipe-cost-components__table{width:100%;border-collapse:collapse}.recipe-cost-breakdown__table th,.recipe-cost-components__table th{text-align:left;color:var(--slate-500);font-size:.8rem;font-weight:600;padding:.4rem .6rem;border-bottom:1px solid var(--slate-200)}.recipe-cost-breakdown__table td,.recipe-cost-components__table td{padding:.5rem .6rem;color:var(--slate-900);font-size:.9rem;border-bottom:1px solid var(--slate-100)}.recipe-cost-breakdown__table th:not(:first-child),.recipe-cost-breakdown__table td:not(:first-child){text-align:right}.recipe-cost-breakdown__total-row td{font-weight:700;border-top:2px solid var(--slate-200);border-bottom:none}.recipe-cost-breakdown--collapsible{padding:0}.recipe-cost-breakdown__toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.55rem 1rem;background:none;border:none;cursor:pointer;font:inherit;text-align:left}.recipe-cost-breakdown__toggle-title{display:inline-flex;align-items:center;gap:.5rem}.recipe-cost-breakdown__toggle .recipe-cost-breakdown__eyebrow{margin-bottom:0}.recipe-cost-breakdown__chevron{color:var(--slate-500);font-size:.75rem}.recipe-cost-breakdown__toggle-total{color:var(--slate-900);font-weight:700;font-size:.9rem}.recipe-cost-breakdown__body{padding:0 1rem 1rem}.recipe-cost-breakdown__body h4{margin:0 0 .25rem;color:var(--slate-900)}.recipe-cost-breakdown__body p{margin:0 0 .75rem;color:var(--slate-500);font-size:.9rem}.recipes-table__detail-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;color:var(--slate-500);padding:2rem;font-size:.9rem}.recipes-table__detail-empty{text-align:center;color:var(--slate-400);font-style:italic;padding:1rem;margin:0}.recipes-pagination{margin-top:1rem;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;color:var(--slate-500);font-size:.9rem}.recipes-pagination__actions{display:flex;gap:.5rem}.ingredients-table{width:100%;background:#fff;border:1px solid var(--slate-200);border-radius:8px;overflow:hidden}.ingredients-table th{background:#fff;border-bottom:2px solid var(--slate-100);padding:.75rem 1rem;font-size:.7rem}.ingredients-table td{padding:.75rem 1rem;font-size:.8rem;border-bottom:1px solid var(--slate-50)}.ingredients-table tr:last-child td{border-bottom:none}.ingredients-table__name{font-weight:500;color:var(--slate-700)}.export-actions{display:flex;align-items:center;gap:.625rem;margin-left:.25rem;padding-left:.75rem;border-left:1px solid var(--slate-200)}.export-actions__buttons{display:flex;gap:.375rem}.export-toggle{display:inline-flex;align-items:center;gap:.4rem;max-width:7.5rem;font-size:.8rem;line-height:1.2;color:var(--slate-600);cursor:pointer}.export-toggle input{margin:0;flex-shrink:0}.export-button{width:38px;height:38px;padding:0;display:flex;align-items:center;justify-content:center;border:1px solid var(--slate-200);border-radius:8px;background:#fff;color:var(--slate-600)}.export-button svg{width:20px;height:20px}.export-button--excel:hover{background-color:#f0fdf4;border-color:#bbf7d0}.export-button--pdf:hover{background-color:#fef2f2;border-color:#fecaca}@keyframes slideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.row--slide-out{animation:slideOutRight .5s ease forwards;pointer-events:none}.row--slide-out td{border-top:1px solid transparent;border-bottom:1px solid transparent}.button--success{background-color:var(--primary-600);color:#fff}.button--success:hover{background-color:var(--primary-700)}.button--danger{background-color:#dc2626;color:#fff;border-color:#dc2626}.button--danger:hover{background-color:#b91c1c;border-color:#b91c1c}.button--icon{padding:.5rem;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.toast-portal{position:fixed;top:1.5rem;right:1.5rem;display:flex;flex-direction:column;align-items:flex-end;z-index:9999;pointer-events:none;gap:1rem}.toast{pointer-events:auto;min-width:300px;max-width:400px;background:#fff;border:1px solid var(--slate-200);border-radius:12px;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;display:flex;flex-direction:column;animation:toastSlideIn .3s cubic-bezier(.16,1,.3,1);transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;transform-origin:top right}.toast__content{padding:1rem;display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}@keyframes toastSlideIn{0%{transform:translateY(100%) scale(.9);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.toast__content span{font-size:.9rem;color:var(--slate-700);line-height:1.5;flex:1}.toast__content button{background:none;border:none;padding:.25rem;cursor:pointer;color:var(--slate-400);border-radius:4px;line-height:1;font-size:1.25rem;display:flex;align-items:center;justify-content:center;transition:all .2s;margin-top:-.25rem;margin-right:-.25rem}.toast__content button:hover{background-color:var(--slate-100);color:var(--slate-600)}.toast__progress{width:100%;height:3px;background-color:var(--slate-100);position:relative}.toast__progress-bar{height:100%;width:100%;background-color:var(--slate-400);transition:width .1s linear}.toast--success .toast__content:before{content:"✓";display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:#d1fae5;color:#059669;border-radius:50%;font-size:.75rem;font-weight:700;flex-shrink:0}.toast--success .toast__progress-bar{background-color:#10b981}.toast--error .toast__content:before{content:"!";display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:#fee2e2;color:#b91c1c;border-radius:50%;font-size:.75rem;font-weight:700;flex-shrink:0}.toast--error .toast__progress-bar{background-color:#ef4444}.toast--info .toast__content:before{content:"i";display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:var(--primary-50);color:var(--primary-700);border-radius:50%;font-size:.75rem;font-weight:700;font-family:serif;flex-shrink:0}.toast--info .toast__progress-bar{background-color:var(--primary-500)}.toast--warning .toast__content:before{content:"!";display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:#fef3c7;color:#b45309;border-radius:50%;font-size:.75rem;font-weight:700;flex-shrink:0}.toast--warning .toast__progress-bar{background-color:#f59e0b}.user-table-wrapper{overflow-x:auto;border:1px solid var(--slate-200);border-radius:12px;background:#fff}.user-table{width:100%;border-collapse:collapse}.user-table th{background-color:var(--slate-50);padding:.875rem 1.5rem;text-align:left;font-weight:600;color:var(--slate-600);text-transform:uppercase;font-size:.75rem;letter-spacing:.05em;border-bottom:1px solid var(--slate-200)}.user-table td{padding:1rem 1.5rem;border-bottom:1px solid var(--slate-100);vertical-align:middle}.user-table tr:last-child td{border-bottom:none}.user-cell{display:flex;flex-direction:column}.user-cell__name{font-weight:600;color:var(--slate-900);font-size:.9rem}.user-cell__email{color:var(--slate-500);font-size:.8rem;margin-top:.125rem}.user-table__date{color:var(--slate-500);font-size:.875rem;white-space:nowrap}.user-table__actions{text-align:right}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .6rem;border-radius:var(--radius-pill);font-size:.74rem;font-weight:600;line-height:1.25;white-space:nowrap}.badge--admin{background-color:#fef3c7;color:#92400e}.badge--user{background-color:#e0f2fe;color:#075985}.badge--success{background-color:#dcfce7;color:#166534}.badge--warning{background-color:#fef9c3;color:#854d0e}.badge--neutral{background-color:#f1f5f9;color:#475569}.badge--danger{background-color:#fef2f2;color:#b91c1c}.badge--info{background-color:var(--primary-50);color:var(--primary-700)}.panel__state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--slate-500);gap:1rem}.panel__state--error{color:#ef4444}.modal-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;animation:modalSlideIn .2s ease-out}.modal--wide{max-width:650px}.modal__header{padding:1.5rem;border-bottom:1px solid var(--slate-200);display:flex;justify-content:space-between;align-items:flex-start}.modal__header h2{font-size:1.25rem;font-weight:600;color:var(--slate-900);margin-bottom:.25rem}.modal__actions{padding:1.5rem;border-top:1px solid var(--slate-200);display:flex;justify-content:flex-end;gap:1rem;background-color:var(--slate-50)}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.user-edit-form{padding:1.5rem}.form-grid{display:grid;gap:1.5rem}.form-grid label{display:flex;flex-direction:column;gap:.5rem}.form-grid label span{font-size:.875rem;font-weight:500;color:var(--slate-700)}.form-grid input,.form-grid select{padding:.625rem .875rem;border:1px solid var(--slate-300);border-radius:8px;font-size:.95rem;color:var(--slate-900);background-color:#fff;transition:all .2s}.form-grid input:focus,.form-grid select:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.form-feedback{margin-top:1rem;padding:.75rem;border-radius:8px;font-size:.875rem;font-weight:500}.form-feedback--error{background-color:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.form-feedback--success{background-color:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .2s ease-out}.modal-content{background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-height:90vh;animation:slideIn .2s ease-out;border:1px solid var(--slate-200)}.modal-header{padding:1.5rem;border-bottom:1px solid var(--slate-100);display:flex;align-items:center;justify-content:space-between}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--slate-900)}.modal-body{padding:1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.modal-footer{padding:1.5rem;border-top:1px solid var(--slate-100);background-color:var(--slate-50);display:flex;justify-content:flex-end;gap:1rem;border-bottom-left-radius:16px;border-bottom-right-radius:16px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.875rem;font-weight:500;color:var(--slate-700)}.form-input{width:100%;padding:.625rem .875rem;border-radius:8px;border:1px solid var(--slate-300);font-size:.9rem;transition:all .2s}.form-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 4px var(--primary-50)}html[data-theme=dark]{color-scheme:dark;--primary-500: #3a6191;--primary-600: #4878b0;--primary-700: #5d8cc2;--slate-50: #1e293b;--slate-100: #233044;--slate-200: #334155;--slate-300: #41506a;--slate-400: #8b97a8 !important;--slate-500: #a6b2c2 !important;--slate-600: #c7d0dc !important;--slate-700: #e2e8f0;--slate-800: #f1f5f9;--slate-900: #f8fafc;--bg-app: #0b1220;--surface: #1e293b;--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow: 0 1px 3px rgba(0,0,0,.38);--shadow-md: 0 6px 16px -6px rgba(0,0,0,.5);--shadow-lg: 0 16px 36px -12px rgba(0,0,0,.55);--primary-50: #1e293b}html[data-theme=dark] body{color:var(--slate-700)}html[data-theme=dark] .panel,html[data-theme=dark] .table-wrapper,html[data-theme=dark] .table-container,html[data-theme=dark] .input,html[data-theme=dark] input,html[data-theme=dark] select,html[data-theme=dark] textarea,html[data-theme=dark] .home-card,html[data-theme=dark] .kpi-card,html[data-theme=dark] .perm-card,html[data-theme=dark] .MuiPaper-root,html[data-theme=dark] .MuiDialog-paper{background:var(--surface);color:var(--slate-700);border-color:var(--slate-200)}html[data-theme=dark] input::placeholder,html[data-theme=dark] textarea::placeholder{color:var(--slate-400)}html[data-theme=dark] .table th,html[data-theme=dark] .table thead{background:#233044;color:var(--slate-600)}html[data-theme=dark] .table td{border-color:var(--slate-200);color:var(--slate-700)}html[data-theme=dark] .table tbody tr:nth-child(2n) td{background:#ffffff05}html[data-theme=dark] .table tbody tr:hover td{background:#ffffff0d}html[data-theme=dark] .badge--neutral{background:#334155;color:var(--slate-700)}html[data-theme=dark] .modal-overlay>div,html[data-theme=dark] .modal-card{background:var(--surface);color:var(--slate-700)}html[data-theme=dark] .MuiTableCell-root{color:var(--slate-700);border-color:var(--slate-200)}html[data-theme=dark] .MuiTableHead-root .MuiTableCell-root{background:#233044}.theme-toggle-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.55rem .7rem;border-radius:10px;cursor:pointer;background:#ffffff0f;color:var(--sidebar-text, #e2e8f0);border:1px solid rgba(255,255,255,.1);font-size:.85rem;font-weight:600;transition:background .15s ease}.theme-toggle-btn:hover{background:#ffffff1f}html[data-theme=dark] body,html[data-theme=dark] body.color-blind{--slate-400: #8b97a8 !important;--slate-500: #a6b2c2 !important;--slate-600: #c7d0dc !important}
