: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)}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: #eff6ff;--primary-100: #dbeafe;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--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 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}body{background-color: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}.main-content{padding:2.5rem;background-color:var(--slate-50);min-height:100vh}.sidebar{background:#fff;border-right:1px solid var(--slate-200);padding:1.5rem 1rem;display:flex;flex-direction:column;gap:2rem;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar__header{padding:0 .75rem}.sidebar__header h2{font-size:1.25rem;font-weight:700;color:var(--slate-900);letter-spacing:-.025em;margin:0}.sidebar__header p{font-size:.875rem;color:var(--slate-500);margin-top:.25rem}.sidebar__nav{display:flex;flex-direction:column;gap:.5rem}.sidebar__link{display:flex;align-items:center;justify-content:space-between;padding:.625rem .875rem;border-radius:8px;color:var(--slate-600);font-weight:500;font-size:.9rem;text-decoration:none;transition:all .2s ease}.sidebar__link:hover{background-color:var(--slate-50);color:var(--slate-900)}.sidebar__link--active{background-color:var(--primary-50);color:var(--primary-700);font-weight:600}.sidebar__sublink{display:block;padding:.5rem .875rem .5rem 2.5rem;font-size:.875rem;color:var(--slate-500);text-decoration:none;border-left:2px solid transparent;margin-left:.875rem;transition:all .2s}.sidebar__sublink:hover{color:var(--slate-900);border-left-color:var(--slate-300)}.sidebar__sublink--active{color:var(--primary-600);border-left-color:var(--primary-600);background-color:transparent}.sidebar__logout{margin-top:auto}.panel{background:#fff;border:1px solid var(--slate-200);border-radius:16px;box-shadow:var(--shadow-sm);transition:box-shadow .2s ease}.panel:hover{box-shadow:var(--shadow-md)}.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;gap:1rem}.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:0 0 0 4px var(--primary-50)}.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;padding:.625rem 1.25rem;border-radius:8px;font-weight:600;font-size:.9rem;transition:all .2s;border:1px solid transparent}.button:disabled{opacity:.5;cursor:not-allowed;pointer-events:auto;filter:grayscale(100%)}.button--primary{background-color:var(--primary-600);color:#fff;box-shadow:var(--shadow-sm)}.button--primary:hover{background-color:var(--primary-700);transform:translateY(-1px);box-shadow:var(--shadow)}.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)}.table-container,.table-wrapper{border:1px solid var(--slate-200);border-radius:12px;overflow:hidden;background:#fff}.table{width:100%;border-collapse:collapse;font-size:.9rem}.table th{background-color:var(--slate-50);padding:1rem 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)}.table td{padding:1rem 1.5rem;border-bottom:1px solid var(--slate-100);color:var(--slate-700);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tr:hover td{background-color:var(--slate-50)}.text-right{text-align:right}.text-center{text-align:center}.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}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem;padding:2rem;background-color:var(--slate-50);border-radius:12px;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)}.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:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;padding:1.5rem;background:#fff;border:1px solid var(--slate-200);border-radius:12px}.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}}.recipes-table{width:100%;border-collapse:collapse}.recipes-table th{background-color:var(--slate-50);padding:.5rem .75rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--slate-500);letter-spacing:.05em;border-bottom:1px solid var(--slate-200);white-space:nowrap}.recipes-table td{padding:.5rem .75rem;font-size:.8rem;color:var(--slate-600);border-bottom:1px solid var(--slate-100);vertical-align:middle}.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))}}.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;gap:.5rem;margin-left:.5rem;padding-left:.5rem;border-left:1px solid var(--slate-200)}.export-button{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center}.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--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;padding:.25rem .625rem;border-radius:999px;font-size:.75rem;font-weight:600;line-height:1}.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}.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)}.vp2-page{padding:1rem;max-width:100%;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.vp2-header-container{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.vp2-page h2{margin:0;font-size:1.4rem;font-weight:700;color:var(--text-primary, #1a1a2e)}.vp2-toolbar{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;margin-bottom:1rem;background:#f8f9fa;padding:.75rem 1rem;border-radius:8px;border:1px solid #e9ecef}.vp2-toolbar .vp2-search{flex:1;min-width:220px;padding:.4rem .6rem;border:1px solid #ced4da;border-radius:4px;font-size:.9rem}.vp2-toolbar select{padding:.4rem .6rem;border:1px solid #ced4da;border-radius:4px;font-size:.85rem;background:#fff}.vp2-column-toggle{position:relative;display:inline-block}.vp2-toggle-btn{padding:.4rem .75rem;background:#fff;border:1px solid #ced4da;border-radius:4px;cursor:pointer;font-size:.85rem;display:flex;align-items:center;gap:.4rem}.vp2-toggle-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:#fff;border:1px solid #e5e7eb;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:.75rem;z-index:10;min-width:200px;display:flex;flex-direction:column;gap:.5rem}.vp2-toggle-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#374151;cursor:pointer}.vp2-toggle-item input{margin:0;cursor:pointer}.vp2-table-wrap{border:1px solid #dee2e6;border-radius:4px;background:#fff}.vp2-table{width:100%;border-collapse:collapse;font-size:.8rem}.vp2-table th,.vp2-table td{padding:.4rem .5rem;text-align:left;border-bottom:1px solid #e9ecef;vertical-align:middle}.vp2-table th{background:#f1f3f5;font-weight:600;font-size:.75rem;color:#495057;text-transform:uppercase;letter-spacing:.5px;position:sticky;top:0;z-index:1}.vp2-table tbody tr{transition:background .1s}.vp2-table tbody tr:hover{background:#f8f9fa}.vp2-table tbody tr.vp2-row-matched td:first-child{border-left:3px solid #28a745}.vp2-table tbody tr.vp2-row-unmatched td:first-child{border-left:3px solid #ffc107}.vp2-input{width:100%;padding:.2rem .3rem;border:1px solid #ced4da;border-radius:4px;font-size:.8rem;box-sizing:border-box}.vp2-input:focus{outline:none;border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40}.vp2-input-number{width:80px;text-align:right}.vp2-select{width:100%;padding:.2rem .3rem;border:1px solid #ced4da;border-radius:4px;font-size:.8rem;background:#fff}.vp2-save-btn{padding:.25rem .5rem;background:#4f46e5;color:#fff;border:none;border-radius:4px;font-size:.75rem;cursor:pointer;font-weight:500;white-space:nowrap}.vp2-save-btn:hover{background:#4338ca}.vp2-save-btn:disabled{opacity:.6;cursor:not-allowed}.vp2-status{font-size:.75rem;font-weight:600;padding:.15rem .4rem;border-radius:4px}.vp2-status-ok{background:#d4edda;color:#155724}.vp2-status-warn{background:#fff3cd;color:#856404}.vp2-pagination{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;font-size:.85rem;color:#6c757d}.vp2-pagination button{padding:.4rem .75rem;border:1px solid #ced4da;border-radius:4px;background:#fff;cursor:pointer;font-size:.85rem}.vp2-pagination button:hover:not(:disabled){background:#e9ecef}.vp2-pagination button:disabled{opacity:.5;cursor:not-allowed}.vp2-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;border:1px solid transparent;cursor:pointer;font-size:.9rem;padding:0;transition:all .2s;line-height:1}.vp2-icon-btn--primary{background:#eef2ff;color:#4f46e5;border-color:#e0e7ff}.vp2-icon-btn--primary:hover{background:#e0e7ff;color:#4338ca}.vp2-icon-btn--danger{background:#fee2e2;color:#dc2626;border-color:#fecaca}.vp2-icon-btn--danger:hover{background:#fecaca;color:#b91c1c}.reports-container{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.reports-header{margin-bottom:1rem}.reports-header h1{font-size:1.75rem;font-weight:700;color:var(--slate-900);display:flex;align-items:center;gap:.75rem;margin:0 0 .5rem}.reports-header p{color:var(--slate-500);font-size:.95rem;margin:0}.reports-container .report-explainer{margin-top:-.25rem}.reports-filter{display:flex;flex-wrap:wrap;align-items:flex-end;gap:1.5rem;padding:1.5rem;background:#fff;border-radius:12px;border:1px solid var(--slate-200);box-shadow:var(--shadow-sm)}.reports-filter__group{display:flex;flex-direction:column;gap:.5rem}.reports-filter__group label{font-size:.875rem;font-weight:500;color:var(--slate-700)}.reports-tree{background:#fff;border:1px solid var(--slate-200);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm)}.reports-tree__header{padding:1rem 1.5rem;background-color:var(--primary-50);border-bottom:1px solid var(--primary-100);display:flex;justify-content:space-between;align-items:center}.reports-tree__title{font-weight:600;color:var(--primary-700)}.reports-tree__meta{font-size:.85rem;color:var(--primary-600);margin-top:.25rem}.reports-tree__actions{display:flex;gap:.75rem}.button--success{background-color:#059669;color:#fff;box-shadow:var(--shadow-sm)}.button--success:hover{background-color:#047857;transform:translateY(-1px);box-shadow:var(--shadow)}.button--success-outline{background-color:transparent;border-color:#059669;color:#059669;box-shadow:var(--shadow-sm)}.button--success-outline:hover{background-color:#ecfdf5;color:#047857;border-color:#047857}.reports-tree__row{display:flex;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--slate-100);transition:background-color .15s;cursor:pointer}.reports-tree__row:hover{background-color:var(--slate-50)}.reports-tree__row--child{background-color:var(--slate-50);padding-left:3rem;font-size:.9rem;border-bottom-color:#f1f5f9}.reports-tree__row--child:hover{background-color:#f8fafc}.reports-tree__toggle{background:none;border:none;padding:.25rem;color:var(--slate-400);cursor:pointer;display:flex;align-items:center;justify-content:center;margin-right:.5rem;border-radius:4px}.reports-tree__toggle:hover{background-color:var(--slate-100);color:var(--slate-600)}.reports-tree__checkbox{margin-right:1rem;width:1.125rem;height:1.125rem;border-radius:4px;cursor:pointer;accent-color:var(--primary-600)}.reports-tree__content{flex:1;display:grid;grid-template-columns:2fr 1fr 1fr;gap:1rem;align-items:center}.reports-tree__name{font-weight:500;color:var(--slate-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reports-tree__count{text-align:right;color:var(--slate-500);font-size:.875rem}.reports-tree__amount{text-align:right;font-weight:600;font-family:SF Mono,Roboto Mono,monospace;color:var(--slate-700)}.reports-tree__row--child .reports-tree__content{grid-template-columns:1fr 2fr 1fr}.reports-tree__date{color:var(--slate-500);font-family:SF Mono,Roboto Mono,monospace}.role-management{display:flex;gap:1.5rem;min-height:70vh}.role-sidebar{width:280px;flex-shrink:0;background:var(--surface-card, #fff);border-radius:12px;box-shadow:0 1px 4px #00000014;padding:1rem;display:flex;flex-direction:column}.role-sidebar__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.role-sidebar__header h2{margin:0;font-size:1.1rem;font-weight:600}.role-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.25rem;overflow-y:auto}.role-list__item{display:flex;align-items:center;justify-content:space-between;padding:.65rem .75rem;border-radius:8px;cursor:pointer;transition:background .15s;border:2px solid transparent}.role-list__item:hover{background:var(--surface-hover, #f1f5f9)}.role-list__item--active{background:var(--primary-light, #eff6ff);border-color:var(--primary, #3b82f6)}.role-list__info{display:flex;flex-direction:column}.role-list__name{font-weight:600;font-size:.9rem}.role-list__code{font-size:.75rem;color:#94a3b8;font-family:monospace}.role-list__badge{font-size:.65rem;font-weight:700;color:#6366f1;background:#eef2ff;padding:2px 8px;border-radius:100px;text-transform:uppercase;letter-spacing:.05em}.role-editor{flex:1;background:var(--surface-card, #fff);border-radius:12px;box-shadow:0 1px 4px #00000014;padding:1.5rem;display:flex;flex-direction:column}.role-editor__empty{display:flex;align-items:center;justify-content:center;height:100%;color:#94a3b8}.role-editor__header{display:flex;gap:.75rem;align-items:center;margin-bottom:1.25rem;flex-wrap:wrap}.role-editor__name-input{font-size:1.15rem;font-weight:600;border:1px solid #e2e8f0;border-radius:8px;padding:.5rem .75rem;flex:0 0 auto;min-width:200px}.role-editor__desc-input{font-size:.9rem;border:1px solid #e2e8f0;border-radius:8px;padding:.5rem .75rem;flex:1;min-width:200px;color:#64748b}.perm-columns{display:flex;gap:1.5rem;flex:1;min-height:0}.perm-column{flex:1;border:2px dashed #e2e8f0;border-radius:12px;padding:1rem;overflow-y:auto;max-height:55vh;background:#fafbfc;transition:border-color .2s}.perm-column--assigned{background:#f0f9ff;border-color:#93c5fd}.perm-column__title{margin:0 0 .25rem;font-size:.95rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.perm-column__count{background:#3b82f6;color:#fff;font-size:.7rem;padding:2px 8px;border-radius:100px;font-weight:700}.perm-column__hint{font-size:.75rem;color:#94a3b8;margin:0 0 .75rem}.perm-column__empty{text-align:center;color:#94a3b8;padding:2rem 0;font-size:.85rem}.perm-group{margin-bottom:.75rem}.perm-group__title{font-size:.7rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.06em;margin:0}.perm-group__header-wrapper{margin-bottom:.35rem}.perm-group__header{display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem;border-radius:6px;background:transparent;transition:background .15s}.perm-group__header--draggable{cursor:grab}.perm-group__header--draggable:hover{background:#e2e8f0}.perm-group__header--draggable:active{cursor:grabbing}.perm-group__header--dragging{background:#e2e8f0;box-shadow:0 4px 16px #3b82f640;transform:rotate(2deg);cursor:grabbing}.perm-group__drag-handle{color:#cbd5e1;font-size:.8rem;-webkit-user-select:none;user-select:none}.perm-group__header:hover .perm-group__drag-handle{color:#94a3b8}.perm-group__count{color:#94a3b8;font-weight:500}.perm-column--over{border-color:#3b82f6;background:#f0f9ff}.perm-chip{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;margin-bottom:.3rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;cursor:grab;-webkit-user-select:none;user-select:none;transition:box-shadow .15s,transform .15s;font-size:.85rem}.perm-chip:hover{box-shadow:0 2px 8px #3b82f61f;border-color:#93c5fd}.perm-chip:active{cursor:grabbing}.perm-chip--dragging{box-shadow:0 4px 16px #3b82f640;border-color:#3b82f6;transform:rotate(2deg)}.perm-chip__label{font-weight:500}.perm-chip__group{font-size:.7rem;color:#94a3b8;margin-left:.5rem}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-card{background:#fff;border-radius:12px;padding:1.5rem;width:400px;max-width:90vw;box-shadow:0 8px 32px #00000026}.modal-card h3{margin:0 0 1rem}.form-label{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem;font-size:.85rem;font-weight:500;color:#334155}.form-input{border:1px solid #e2e8f0;border-radius:8px;padding:.5rem .75rem;font-size:.9rem}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.button--sm{font-size:.8rem;padding:.35rem .75rem}.report-page{display:flex;flex-direction:column;gap:1.5rem}.report-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.report-page__header h1{margin:0 0 .5rem}.report-page__header p{margin:0;color:var(--slate-500);max-width:70ch}.report-page__actions{display:flex;gap:.75rem;flex-wrap:wrap}.report-page__filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.report-page__filters label{display:flex;flex-direction:column;gap:.5rem;color:var(--slate-700);font-size:.875rem;font-weight:500}.report-page__checkbox{display:inline-flex;align-items:center;gap:.5rem;color:var(--slate-700);font-size:.9rem}.report-page__summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.report-page__summary--compact{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-top:1rem}.report-summary-card{background:#fff;border:1px solid var(--slate-200);border-radius:12px;padding:1rem 1.25rem}.report-summary-card__label{color:var(--slate-500);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}.report-summary-card__value{margin-top:.35rem;color:var(--slate-900);font-size:1.35rem;font-weight:700}.report-summary-card__hint{margin-top:.35rem;color:var(--slate-500);font-size:.82rem}.report-page__meta{display:flex;flex-wrap:wrap;gap:.75rem}.report-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .7rem;border-radius:999px;background:var(--slate-100);color:var(--slate-700);font-size:.82rem;font-weight:600}.report-chip--warning{background:#fef3c7;color:#92400e}.report-chip--danger{background:#fee2e2;color:#991b1b}.report-callout{margin:1rem 0 0;border:1px solid var(--slate-200);border-radius:12px;padding:.85rem 1rem;color:var(--slate-700);background:var(--slate-50);font-size:.9rem}.report-callout--warning{border-color:#fde68a;background:#fffbeb;color:#92400e}.report-catalog{display:flex;flex-direction:column;gap:1rem}.report-catalog__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.report-catalog__header h2{margin:0}.report-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.report-card{display:flex;min-height:170px;flex-direction:column;justify-content:space-between;gap:1rem;border:1px solid var(--slate-200);border-radius:14px;padding:1rem;color:inherit;text-decoration:none;background:linear-gradient(180deg,#ffffff 0%,var(--slate-50) 100%);transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.report-card:hover{border-color:var(--primary-500);box-shadow:var(--shadow-md);transform:translateY(-1px)}.report-card h3{margin:0 0 .5rem;color:var(--slate-900);font-size:1rem}.report-card p{margin:0;color:var(--slate-600);font-size:.9rem;line-height:1.45}.report-card__meta{display:flex;flex-direction:column;gap:.35rem;color:var(--slate-500);font-size:.78rem}.report-card__meta strong{width:fit-content;border-radius:999px;background:#fffbeb;color:#92400e;padding:.2rem .5rem;font-size:.72rem}.report-page__empty{padding:2rem;text-align:center;color:var(--slate-500)}.report-page__note{color:var(--slate-500);font-size:.85rem}.report-page__table-actions{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}.report-page__table-actions h2{margin:0;font-size:1.1rem}.report-page__caption{margin:.25rem 0 0;color:var(--slate-500);font-size:.85rem}.report-page__stacked-values{display:flex;flex-direction:column;gap:.35rem;white-space:nowrap}.report-page__empty-cell{padding:1rem;text-align:center;color:var(--slate-500)}.report-explainer{margin-top:1rem;border:1px solid var(--slate-200);border-radius:14px;background:linear-gradient(180deg,#fff,#f8fafc);overflow:hidden}.report-explainer__summary{padding:1rem 1rem .85rem}.report-explainer__summary p,.report-explainer__detail-body p{margin:0;color:var(--slate-700);line-height:1.65;font-size:.92rem}.report-explainer__summary p+p,.report-explainer__detail-body p+p{margin-top:.7rem}.report-explainer__details{border-top:1px solid var(--slate-200);background:#fff}.report-explainer__details summary{list-style:none;cursor:pointer;padding:.9rem 1rem;font-weight:600;color:var(--slate-800)}.report-explainer__details summary::-webkit-details-marker{display:none}.report-explainer__details summary:after{content:"Detaylari goster";float:right;color:var(--primary-700);font-size:.85rem;font-weight:600}.report-explainer__details[open] summary:after{content:"Detaylari gizle"}.report-explainer__detail-body{padding:0 1rem 1rem}@media(max-width:768px){.report-page__header{flex-direction:column}.report-page__table-actions{flex-direction:column;align-items:flex-start}.report-catalog__header{flex-direction:column}}.audit-log-page{display:flex;flex-direction:column;gap:1rem}.audit-log-hero{display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;padding:1.35rem 1.5rem;border:1px solid rgba(148,163,184,.24);border-radius:20px;background:radial-gradient(circle at top right,rgba(59,130,246,.12),transparent 30%),linear-gradient(135deg,#fff,#f8fafc 56%,#eef4ff);box-shadow:0 12px 30px -24px #0f172a47}.audit-log-hero__content{max-width:840px}.audit-log-hero__eyebrow{display:inline-flex;padding:.35rem .7rem;border-radius:999px;background:#0f172a0f;color:var(--slate-700);font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.audit-log-hero h1{margin:.55rem 0 .45rem;color:var(--slate-900);font-size:1.8rem;line-height:1.1;letter-spacing:-.04em}.audit-log-hero p{margin:0;color:var(--slate-600);font-size:.92rem;line-height:1.5}.audit-log-hero__actions{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}.audit-stat-card,.audit-log-toolbar,.audit-entry{border:1px solid var(--slate-200);background:#fff;box-shadow:var(--shadow-sm)}.audit-log-toolbar{display:flex;flex-direction:column;gap:1rem;padding:1rem 1.1rem 1.1rem;border-radius:18px}.audit-log-toolbar__header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.audit-log-toolbar__header h2{margin:0;color:var(--slate-900);font-size:1rem}.audit-log-toolbar__header p{margin:.25rem 0 0;color:var(--slate-500);font-size:.86rem}.audit-log-toolbar__actions{display:flex;gap:.5rem;flex-wrap:wrap}.audit-log-filter-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem;align-items:end}.audit-log-field{display:flex;flex-direction:column;gap:.35rem}.audit-log-field span{color:var(--slate-700);font-size:.8rem;font-weight:600}.audit-log-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.audit-log-summary--compact .audit-stat-card{padding:.95rem 1rem;border-radius:16px}.audit-stat-card{display:flex;flex-direction:column;gap:.25rem;border-radius:18px}.audit-stat-card__label{color:var(--slate-500);font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.audit-stat-card__value{color:var(--slate-900);font-size:1.35rem;line-height:1;letter-spacing:-.04em}.audit-stat-card__value--small{font-size:1rem;line-height:1.3}.audit-log-chip-row{display:flex;flex-wrap:wrap;gap:.5rem}.audit-log-chip{display:inline-flex;align-items:center;padding:.35rem .65rem;border-radius:999px;background:#e0f2fe;color:#075985;font-size:.78rem;font-weight:600}.audit-log-chip--muted{background:var(--slate-100);color:var(--slate-600)}.audit-log-detail-panel{display:flex;flex-direction:column;gap:1rem;padding:1.1rem 1.15rem 1.2rem;border:1px solid rgba(59,130,246,.18);border-radius:18px;background:radial-gradient(circle at top right,rgba(59,130,246,.08),transparent 32%),linear-gradient(180deg,#fff,#f8fbff);box-shadow:0 12px 28px -24px #0f172a47}.audit-log-detail-panel__header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.audit-log-detail-panel__header h2{margin:0;color:var(--slate-900);font-size:1rem}.audit-log-detail-panel__header p{margin:.25rem 0 0;color:var(--slate-500);font-size:.86rem}.audit-log-detail-panel__empty{padding:1rem 1rem .2rem;border:1px dashed var(--slate-300);border-radius:16px;background:#ffffffd1}.audit-log-detail-panel__empty h3{margin:0;color:var(--slate-900);font-size:.96rem}.audit-log-detail-panel__empty p{margin:.35rem 0 0;color:var(--slate-500);line-height:1.55}.audit-log-detail-panel__body{display:flex;flex-direction:column;gap:1rem}.audit-log-detail-panel__headline h3{margin:.45rem 0 0;color:var(--slate-900);font-size:1.02rem;line-height:1.45}.audit-log-detail-panel__headline p{margin:.35rem 0 0;color:var(--slate-500);font-size:.88rem}.audit-log-detail-panel__meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.75rem}.audit-log-detail-panel__meta-card{display:flex;flex-direction:column;gap:.25rem;padding:.85rem .95rem;border-radius:14px;border:1px solid #e5edf7;background:#fff}.audit-log-detail-panel__meta-card span{color:var(--slate-500);font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.audit-log-detail-panel__meta-card strong{color:var(--slate-900);font-size:.92rem;line-height:1.45}.audit-log-detail-panel__actions{display:flex;justify-content:flex-start}.audit-log-detail-panel__details{padding-top:.1rem}.audit-log-feed{display:flex;flex-direction:column;gap:.85rem}.audit-entry{position:relative;display:flex;flex-direction:column;gap:.9rem;padding:1.1rem 1.15rem 1.15rem 1.3rem;border-radius:18px;overflow:hidden}.audit-entry__accent{position:absolute;top:0;left:0;width:6px;height:100%;background:var(--slate-300)}.audit-entry--success .audit-entry__accent{background:linear-gradient(180deg,#22c55e,#15803d)}.audit-entry--warning .audit-entry__accent{background:linear-gradient(180deg,#f59e0b,#b45309)}.audit-entry--danger .audit-entry__accent{background:linear-gradient(180deg,#ef4444,#b91c1c)}.audit-entry--neutral .audit-entry__accent{background:linear-gradient(180deg,#94a3b8,#475569)}.audit-entry__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.25rem}.audit-entry__headline{min-width:0}.audit-entry__badges{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:.55rem}.audit-entry__badge{display:inline-flex;align-items:center;border-radius:999px;padding:.34rem .7rem;font-size:.75rem;font-weight:700;line-height:1}.audit-entry__badge--success{background:#dcfce7;color:#166534}.audit-entry__badge--warning{background:#fef3c7;color:#92400e}.audit-entry__badge--danger{background:#fee2e2;color:#991b1b}.audit-entry__badge--neutral{background:#e2e8f0;color:#334155}.audit-entry__badge--outline{border:1px solid var(--slate-200);background:#fff;color:var(--slate-700)}.audit-entry__badge--interactive{border:1px solid var(--slate-200);background:#fff;color:var(--slate-700);cursor:pointer;font:inherit;text-align:left;transition:border-color .12s ease,background-color .12s ease,box-shadow .12s ease,transform .12s ease}.audit-entry__badge--interactive:hover,.audit-entry__badge--interactive:focus-visible{border-color:#3b82f6;background:#eff6ff;box-shadow:0 0 0 3px #3b82f61f;outline:none;transform:translateY(-1px)}.audit-entry__inline-action-button{border:0;padding:0;background:transparent;color:#1d4ed8;font:inherit;font-weight:800;cursor:pointer;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}.audit-entry__inline-action-button:hover,.audit-entry__inline-action-button:focus-visible{color:#0f172a;outline:none}.audit-entry--selected{border-color:#3b82f657;box-shadow:0 14px 30px -22px #2563eb5c}.audit-entry__badge--ghost{background:var(--slate-100);color:var(--slate-600)}.audit-entry__headline h3{margin:0;color:var(--slate-900);font-size:.98rem;line-height:1.45}.audit-entry__headline p{margin:.3rem 0 0;color:var(--slate-500);font-size:.84rem}.audit-entry__timestamp{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem;min-width:180px;color:var(--slate-500);text-align:right}.audit-entry__timestamp strong{color:var(--slate-800);font-size:.9rem;font-weight:700}.audit-entry__timestamp span{font-size:.82rem}.audit-entry__meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,max-content));justify-content:start;gap:.75rem 1rem;align-items:stretch;padding:.72rem .85rem;border:1px solid var(--slate-200);border-radius:14px;background:linear-gradient(180deg,#ffffff 0%,var(--slate-50) 100%)}.audit-entry__meta-item{position:relative;display:flex;min-width:0;flex-direction:column;gap:.16rem;padding-right:1rem}.audit-entry__meta-item:not(:last-child):after{content:"";position:absolute;top:.12rem;right:0;bottom:.12rem;width:1px;background:var(--slate-200)}.audit-entry__meta-label{color:var(--slate-500);font-size:.68rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.audit-entry__meta-item strong{color:var(--slate-900);font-size:.86rem;line-height:1.3;word-break:break-word}.audit-entry__actions{display:flex;flex-wrap:wrap;gap:.75rem}.audit-entry__link{text-decoration:none}.audit-entry__details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.65rem}.audit-entry__detail-card{display:flex;flex-direction:column;gap:.3rem;padding:.75rem .85rem;border-radius:14px;background:#f8fafc;border:1px solid #e5edf7}.audit-entry__detail-card span{color:var(--slate-500);font-size:.76rem;font-weight:600}.audit-entry__detail-card strong{color:var(--slate-900);font-size:.92rem;line-height:1.45;word-break:break-word}.audit-log-bubble{width:min(360px,calc(100vw - 2rem));border:1px solid rgba(59,130,246,.2);border-radius:16px;box-shadow:0 18px 40px -24px #0f172a59;background:#fff}.audit-log-bubble__content{display:flex;flex-direction:column;gap:.65rem;padding:.9rem 1rem}.audit-log-bubble__header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.audit-log-bubble__label{color:#64748b;font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.audit-log-bubble__title{margin-top:.2rem;color:#0f172a;font-size:.95rem;font-weight:800;line-height:1.35}.audit-log-bubble__description{margin:0;color:#334155;font-size:.88rem;line-height:1.5}.audit-log-bubble__close{border:1px solid #cbd5e1;border-radius:999px;background:#fff;color:#475569;font-size:.78rem;font-weight:700;padding:.22rem .6rem;cursor:pointer}.audit-log-bubble__close:hover,.audit-log-bubble__close:focus-visible{border-color:#94a3b8;outline:none}.audit-entry__empty-detail{color:var(--slate-500);font-size:.9rem}.audit-log-state{display:flex;min-height:220px;flex-direction:column;align-items:center;justify-content:center;gap:1rem;border:1px dashed var(--slate-300);border-radius:20px;background:#ffffffb8;color:var(--slate-600);text-align:center}.audit-log-state--empty h3{margin:0;color:var(--slate-900)}.audit-log-state--empty p{max-width:440px;margin:0;line-height:1.6}.audit-log-load-more{display:flex;justify-content:center;padding-top:.5rem}@media(max-width:1200px){.audit-log-filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:900px){.audit-log-hero{flex-direction:column;align-items:flex-start}.audit-log-hero__actions{width:100%;justify-content:flex-start}.audit-log-toolbar__header{flex-direction:column;align-items:flex-start}.audit-log-toolbar__actions{width:100%}.audit-log-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.audit-entry__header{grid-template-columns:1fr;display:grid}.audit-entry__meta{grid-template-columns:1fr}.audit-entry__timestamp{align-items:flex-start;min-width:0;text-align:left}}@media(max-width:640px){.audit-log-hero{padding:1.35rem;border-radius:20px}.audit-log-hero h1{font-size:1.55rem}.audit-log-filter-grid,.audit-log-summary{grid-template-columns:1fr}.audit-log-toolbar,.audit-entry{padding:1rem;border-radius:18px}.audit-entry__details{grid-template-columns:1fr}}
