:root{--bg: #f4f5f9;--surface: #ffffff;--surface-raised: #ffffff;--surface-inset: #f0f1f6;--neutral-100: #f4f5f9;--neutral-200: #e8eaef;--neutral-300: #d5d8e0;--neutral-400: #b0b5c0;--neutral-500: #8a8f9c;--neutral-600: #6b7080;--neutral-700: #4b5060;--neutral-800: #2d3140;--neutral-900: #181b28;--text: var(--neutral-900);--text-secondary: var(--neutral-600);--text-muted: var(--neutral-600);--text-disabled: var(--neutral-400);--text-on-color: #ffffff;--border: var(--neutral-200);--border-hover: var(--neutral-300);--border-focus: var(--primary);--primary: #4f6ef7;--primary-hover: #3b5ae0;--primary-active: #2f4bcb;--primary-bg: #edf1fe;--primary-light: #edf1fe;--success: #1a9a56;--success-hover: #158547;--success-bg: #e6f6ee;--warning: #c58b08;--warning-hover: #a87606;--warning-bg: #fdf5e0;--danger: #dc3d3d;--danger-hover: #c33030;--danger-bg: #fdeaea;--fs-caption: .6875rem;--fs-xs: .6875rem;--fs-small: .8125rem;--fs-sm: .8125rem;--fs-body: .875rem;--fs-base: .875rem;--fs-md: 1rem;--fs-h3: 1rem;--fs-lg: 1.125rem;--fs-h2: 1.25rem;--fs-xl: 1.25rem;--fs-h1: 1.5rem;--fs-2xl: 1.5rem;--fs-display: 2rem;--lh-tight: 1.25;--lh-heading: 1.35;--lh-base: 1.55;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-7: 2rem;--space-8: 3rem;--radius-1: 4px;--radius-2: 8px;--radius-3: 12px;--radius: var(--radius-2);--shadow-1: 0 1px 2px rgba(0,0,0,.04), 0 1px 3px rgba(0,0,0,.06);--shadow-2: 0 2px 4px rgba(0,0,0,.03), 0 4px 12px rgba(0,0,0,.06);--shadow-3: 0 4px 8px rgba(0,0,0,.03), 0 12px 32px rgba(0,0,0,.08);--shadow: var(--shadow-2);--z-base: 1;--z-sidebar: 10;--z-topbar: 20;--z-dropdown: 50;--z-popover: 100;--z-modal: 200;--z-toast: 300;--sidebar-w: 240px;--topbar-h: 52px;--mobile-nav-h: 56px;--container-max: 1140px;--ring: 0 0 0 2px var(--primary-bg), 0 0 0 4px var(--primary);--ease-out: cubic-bezier(.2, 0, 0, 1);--dur-fast: .15s;--dur-norm: .2s}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:var(--fs-body);line-height:var(--lh-base);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv02","cv03","cv04","cv11";-webkit-tap-highlight-color:transparent}::selection{background:var(--primary);color:var(--text-on-color)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--neutral-400)}@supports (scrollbar-width: thin){*{scrollbar-width:thin;scrollbar-color:var(--neutral-300) transparent}}a{color:var(--primary);text-decoration:none;transition:color var(--dur-fast)}a:hover{color:var(--primary-hover);text-decoration:underline}a.btn,a.btn:hover{text-decoration:none}a.btn.btn-primary,a.btn.btn-success,a.btn.btn-danger{color:var(--text-on-color)}a.btn.btn-primary:hover:not(:disabled),a.btn.btn-success:hover:not(:disabled),a.btn.btn-danger:hover:not(:disabled){color:var(--text-on-color)}a.btn.btn-outline:hover:not(:disabled){color:var(--text)}a.btn.btn-ghost:hover:not(:disabled){color:var(--text)}img,svg{vertical-align:middle}h1,.h1{font-size:var(--fs-h1);font-weight:700;line-height:var(--lh-tight);letter-spacing:-.015em;color:var(--text)}h2,.h2{font-size:var(--fs-h2);font-weight:600;line-height:var(--lh-heading);letter-spacing:-.01em;color:var(--text)}h3,.h3{font-size:var(--fs-h3);font-weight:600;line-height:var(--lh-heading);color:var(--text)}small,.small{font-size:var(--fs-small);line-height:var(--lh-base)}.caption{font-size:var(--fs-caption);line-height:1.4;letter-spacing:.03em;text-transform:uppercase;color:var(--text-secondary)}strong{font-weight:600}p+p{margin-top:var(--space-3)}:focus-visible{outline:none;box-shadow:var(--ring)}a:focus-visible{border-radius:var(--radius-1)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--neutral-900);color:var(--text-on-color);padding:var(--space-5) 0;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;overflow-y:auto;z-index:var(--z-sidebar);transform:translate(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1)}@media(min-width:1024px){.sidebar{transform:translate(0)}}.sidebar.open{transform:translate(0)}.sidebar-brand{font-size:var(--fs-md);font-weight:700;letter-spacing:-.02em;padding:0 var(--space-4) var(--space-4);border-bottom:1px solid rgba(255,255,255,.12);margin-bottom:var(--space-2)}.sidebar-link,.sidebar-section-title{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);color:#fff9;font-size:var(--fs-small);font-weight:450;text-decoration:none;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast),padding-left var(--dur-fast) var(--ease-out);border-radius:0}.sidebar-link svg{flex-shrink:0;opacity:.65;transition:opacity var(--dur-fast)}.sidebar-link:hover{background:#ffffff12;color:#fffffff2;text-decoration:none}.sidebar-link:hover svg{opacity:.9}.sidebar-link.active{background:#ffffff1a;color:#fff;font-weight:500;text-decoration:none;border-left:3px solid var(--primary);padding-left:calc(var(--space-4) - 3px)}.sidebar-link.active svg{opacity:1}.sidebar-link:focus-visible{box-shadow:inset 0 0 0 2px #ffffff73}.sidebar-section-title{font-size:var(--fs-caption);text-transform:uppercase;letter-spacing:.06em;color:#ffffff59;margin-top:var(--space-3);cursor:default;font-weight:500}.sidebar-group{display:flex;flex-direction:column;gap:0}.sidebar-link--sub{padding-left:calc(var(--space-4) + 18px + var(--space-2));font-size:var(--fs-caption)}.sidebar-link--sub.active{padding-left:calc(var(--space-4) + 18px + var(--space-2) - 3px)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:calc(var(--z-sidebar) - 1);animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}body.drawer-open{overflow:hidden}.main-content{flex:1;min-width:0;padding:var(--space-4);padding-bottom:calc(var(--mobile-nav-h) + var(--space-4));margin-left:0}@media(min-width:768px){.main-content{padding-bottom:var(--space-4)}}@media(min-width:1024px){.main-content{margin-left:var(--sidebar-w);padding:var(--space-6) var(--space-7)}}.container{width:100%;max-width:var(--container-max);margin:0 auto}.content-area{min-width:0}.topbar{display:flex;align-items:center;gap:var(--space-3);height:var(--topbar-h);position:sticky;top:0;z-index:var(--z-topbar);background:var(--surface);border-bottom:1px solid var(--border);padding:0 var(--space-4);margin:0 calc(-1 * var(--space-4));margin-bottom:var(--space-4)}@media(min-width:1024px){.topbar{background:#ffffffe0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:0 var(--space-7);margin:0 calc(-1 * var(--space-7));margin-bottom:var(--space-6)}}.topbar-burger{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:1px solid var(--border);border-radius:var(--radius-2);cursor:pointer;flex-shrink:0;color:var(--text);transition:background var(--dur-fast),border-color var(--dur-fast)}.topbar-burger:hover{background:var(--surface-inset);border-color:var(--border-hover)}@media(min-width:1024px){.topbar-burger{display:none}}.topbar-title{font-size:var(--fs-md);font-weight:600;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(min-width:1024px){.topbar-title{font-size:var(--fs-lg)}}.topbar-actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.topbar-user{font-size:var(--fs-small);color:var(--text-secondary);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:599px){.topbar-user{display:none}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-3);padding:var(--space-5);box-shadow:var(--shadow-1);margin-bottom:var(--space-4);transition:box-shadow var(--dur-norm) var(--ease-out),border-color var(--dur-norm) var(--ease-out)}.card:hover{box-shadow:var(--shadow-2)}.card-title{font-size:var(--fs-md);font-weight:600;line-height:var(--lh-heading);margin-bottom:var(--space-3);letter-spacing:-.01em;color:var(--text)}.page-shell{margin-bottom:var(--space-4)}.breadcrumbs{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-1);margin-bottom:var(--space-3);font-size:var(--fs-small);color:var(--text-secondary)}.breadcrumb-sep{margin:0 var(--space-1);color:var(--neutral-300);-webkit-user-select:none;user-select:none}.breadcrumbs a{color:var(--text-secondary)}.breadcrumbs a:hover{color:var(--primary);text-decoration:underline}.breadcrumb-item:last-child{color:var(--text);font-weight:500}.breadcrumb-item:last-child a{color:var(--text);pointer-events:none}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-6)}.page-header-text{flex:1;min-width:0}.page-header h1{font-size:var(--fs-h1);font-weight:700;line-height:var(--lh-tight);letter-spacing:-.015em}.page-subtitle{font-size:var(--fs-small);color:var(--text-secondary);margin-top:var(--space-1)}.page-header-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0;padding-top:var(--space-1)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:36px;padding:0 var(--space-4);border:1px solid transparent;border-radius:var(--radius-2);font-size:var(--fs-small);font-weight:500;line-height:1;cursor:pointer;transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast),box-shadow var(--dur-fast),transform var(--dur-fast) var(--ease-out),opacity var(--dur-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;font-family:inherit}.btn:focus-visible{box-shadow:var(--ring)}.btn:active:not(:disabled){transform:translateY(1px)}.btn-primary{background:var(--primary);color:var(--text-on-color)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);box-shadow:0 2px 8px #4f6ef74d}.btn-primary:active:not(:disabled){background:var(--primary-active)}.btn-danger{background:var(--danger);color:var(--text-on-color)}.btn-danger:hover:not(:disabled){background:var(--danger-hover);box-shadow:0 2px 8px #dc3d3d40}.btn-success{background:var(--success);color:var(--text-on-color)}.btn-success:hover:not(:disabled){background:var(--success-hover);box-shadow:0 2px 8px #1a9a5640}.btn-outline{background:var(--surface);border-color:var(--border);color:var(--text)}.btn-outline:hover:not(:disabled){background:var(--surface-inset);border-color:var(--border-hover)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--surface-inset);color:var(--text)}.btn-sm{height:28px;padding:0 var(--space-2);font-size:var(--fs-caption);border-radius:var(--radius-1)}.btn-lg{height:44px;padding:0 var(--space-6);font-size:var(--fs-md);border-radius:var(--radius-2)}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none;box-shadow:none}.settings-list .form-group{margin-bottom:var(--space-4)}.settings-toggle{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer}.settings-toggle input{width:18px;height:18px;accent-color:var(--primary)}.form-group{margin-bottom:var(--space-4)}.form-group label{display:block;font-size:var(--fs-small);font-weight:500;margin-bottom:var(--space-1);color:var(--text-secondary)}.form-control{width:100%;height:36px;padding:0 var(--space-3);border:1px solid var(--border);border-radius:var(--radius-2);font-size:var(--fs-body);font-family:inherit;background:var(--surface);color:var(--text);outline:none;transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}.form-control:hover:not(:focus):not(:disabled){border-color:var(--border-hover)}.form-control:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-bg)}.form-control::placeholder{color:var(--neutral-400)}.form-control:focus-visible{outline:none}textarea.form-control{height:auto;min-height:80px;padding:var(--space-2) var(--space-3);resize:vertical}select.form-control{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.form-control:disabled,.form-control[readonly]{background:var(--surface-inset);color:var(--text-disabled);cursor:not-allowed}.form-field{margin-bottom:var(--space-4)}.flex>.form-field{flex:1;min-width:0}.form-field-label{display:block;font-size:var(--fs-small);font-weight:500;margin-bottom:var(--space-1);color:var(--text-secondary)}.form-field-req{color:var(--danger)}.form-field-hint{display:block;font-size:var(--fs-caption);color:var(--text-secondary);margin-top:var(--space-1)}.form-field-error{display:block;font-size:var(--fs-caption);color:var(--danger);margin-top:var(--space-1)}.form-field.has-error .form-control{border-color:var(--danger)}.form-field.has-error .form-control:focus{box-shadow:0 0 0 3px var(--danger-bg)}.form-control.input-error{border-color:var(--danger)}.form-control.input-error:focus{box-shadow:0 0 0 3px var(--danger-bg)}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;font-variant-numeric:tabular-nums}table{width:100%;border-collapse:collapse;font-size:var(--fs-small)}th,td{text-align:left;padding:var(--space-3);border-bottom:1px solid var(--border)}th{font-weight:600;color:var(--text-secondary);font-size:var(--fs-caption);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;background:var(--surface-inset);position:sticky;top:0;z-index:var(--z-base)}tbody tr{transition:background var(--dur-fast) var(--ease-out)}tbody tr:hover{background:var(--primary-bg)}tbody tr:last-child td{border-bottom:none}.copy-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:var(--neutral-400);cursor:pointer;border-radius:var(--radius-1);transition:color var(--dur-fast),background var(--dur-fast);vertical-align:middle;margin-left:var(--space-1);flex-shrink:0}.copy-btn:hover{color:var(--primary);background:var(--primary-bg)}.id-cell{display:inline-flex;align-items:center;font-variant-numeric:tabular-nums}.rtable-mobile{display:none}@media(max-width:767px){.rtable-desktop{display:none}.rtable-mobile{display:flex;flex-direction:column;gap:var(--space-3)}.rtable-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-3);padding:var(--space-3) var(--space-4);box-shadow:var(--shadow-1)}.rtable-row{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3);padding:var(--space-1) 0}.rtable-row+.rtable-row{border-top:1px solid var(--border)}.rtable-label{font-size:var(--fs-caption);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;flex-shrink:0;padding-top:2px}.rtable-value{font-size:var(--fs-small);text-align:right;min-width:0;word-break:break-word}}.badge{display:inline-flex;align-items:center;height:22px;padding:0 var(--space-2);border-radius:99px;font-size:var(--fs-caption);font-weight:600;line-height:1;letter-spacing:.01em;border:1px solid transparent;white-space:nowrap}.badge-green{background:var(--success-bg);color:var(--success);border-color:#b2ddc6}.badge-yellow{background:var(--warning-bg);color:var(--warning);border-color:#ecd89e}.badge-red{background:var(--danger-bg);color:var(--danger);border-color:#f0bdbd}.badge-blue{background:var(--primary-bg);color:var(--primary);border-color:#bfcffa}.badge-gray{background:var(--surface-inset);color:var(--text-secondary);border-color:var(--neutral-300)}.alert{padding:var(--space-3) var(--space-4);border-radius:var(--radius-2);font-size:var(--fs-small);line-height:var(--lh-base);margin-bottom:var(--space-4);border:1px solid transparent}.alert-error{background:var(--danger-bg);color:var(--danger-hover);border-color:#f0bdbd}.alert-success{background:var(--success-bg);color:var(--success);border-color:#b2ddc6}.alert-info{background:var(--primary-bg);color:var(--primary);border-color:#bfcffa}.auth-page{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:var(--space-7);background:linear-gradient(145deg,var(--bg) 0%,#e8ecf4 50%,#dfe5f0 100%)}.auth-card{width:100%;max-width:400px;box-shadow:var(--shadow-3);animation:fade-in-up .3s var(--ease-out) both}.auth-card h1{text-align:center;margin-bottom:var(--space-6);font-size:var(--fs-h2)}.notif-btn{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:1px solid var(--border);border-radius:var(--radius-2);cursor:pointer;color:var(--text);transition:background var(--dur-fast),border-color var(--dur-fast)}.notif-btn:hover{background:var(--surface-inset);border-color:var(--border-hover)}.notif-badge{position:absolute;top:-5px;right:-5px;background:var(--danger);color:var(--text-on-color);font-size:.55rem;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.notif-popover{position:absolute;top:calc(100% + var(--space-2));right:0;width:340px;max-height:400px;overflow-y:auto;background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius-3);box-shadow:var(--shadow-3);z-index:var(--z-popover)}.notif-item{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);font-size:var(--fs-small);cursor:pointer;transition:background var(--dur-fast)}.notif-item:hover{background:var(--surface-inset)}.notif-item.unread{background:var(--primary-bg)}.notif-item-title{font-weight:600;margin-bottom:2px}.notif-item-body{color:var(--text-secondary);line-height:var(--lh-base)}.notif-empty{padding:var(--space-7);text-align:center;color:var(--text-secondary);font-size:var(--fs-small)}.pagination{display:flex;gap:var(--space-2);align-items:center;margin-top:var(--space-4)}.pagination button{min-width:2rem}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.stat-card{text-align:center;padding:var(--space-5);transition:transform var(--dur-norm) var(--ease-out),box-shadow var(--dur-norm) var(--ease-out)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-2)}.stat-card .stat-value{font-size:var(--fs-display);font-weight:700;font-variant-numeric:tabular-nums;color:var(--primary);line-height:var(--lh-tight);letter-spacing:-.02em}.stat-card .stat-label{font-size:var(--fs-small);color:var(--text-secondary);margin-top:var(--space-1)}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-2)}.gap-md{gap:var(--space-4)}.mt-1{margin-top:var(--space-2)}.mt-2{margin-top:var(--space-4)}.mt-3{margin-top:var(--space-6)}.mb-1{margin-bottom:var(--space-2)}.mb-2{margin-bottom:var(--space-4)}.p-1{padding:var(--space-2)}.p-2{padding:var(--space-4)}.text-muted{color:var(--text-secondary)}.text-xs{font-size:var(--fs-caption)}.text-sm{font-size:var(--fs-small)}.text-md{font-size:var(--fs-md)}.text-lg{font-size:var(--fs-lg)}.text-center{text-align:center}.font-semibold{font-weight:600}.font-tabular{font-variant-numeric:tabular-nums}.loading{padding:var(--space-8);text-align:center;color:var(--text-secondary)}.state-box{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-8) var(--space-4);color:var(--text-secondary)}.state-icon{width:56px;height:56px;margin-bottom:var(--space-4);color:var(--neutral-300)}.state-icon svg{width:100%;height:100%}.state-error .state-icon{color:var(--danger)}.state-title{font-size:var(--fs-md);font-weight:600;color:var(--text);margin-bottom:var(--space-1)}.state-error .state-title{color:var(--danger)}.state-desc{font-size:var(--fs-small);max-width:340px;line-height:var(--lh-base)}.state-text{font-size:var(--fs-small);margin-top:var(--space-3)}.state-action{margin-top:var(--space-4)}.spinner{width:28px;height:28px;border:3px solid var(--neutral-200);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.skeleton-wrap{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-2) 0}.skeleton-line{height:14px;border-radius:var(--radius-1);background:linear-gradient(90deg,var(--neutral-200) 25%,var(--neutral-100) 50%,var(--neutral-200) 75%);background-size:200% 100%;animation:shimmer 1.5s ease infinite}.skeleton-line-lg{height:20px;width:45%;margin-bottom:var(--space-1)}.skeleton-line-sm{height:12px}@keyframes fade-in-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.card,.rfq-summary,.onboarding,.product-card,.producer-card,.quote-card,.state-box{animation:fade-in-up .25s var(--ease-out) both}.product-grid .product-card:nth-child(2){animation-delay:.04s}.product-grid .product-card:nth-child(3){animation-delay:.08s}.product-grid .product-card:nth-child(4){animation-delay:.12s}.quote-grid .quote-card:nth-child(2){animation-delay:.04s}.quote-grid .quote-card:nth-child(3){animation-delay:.08s}.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-4);display:flex;flex-direction:column-reverse;gap:var(--space-2);z-index:var(--z-toast);pointer-events:none;max-width:380px;width:100%}@media(max-width:767px){.toast-container{bottom:calc(var(--mobile-nav-h) + var(--space-3));left:var(--space-3);right:var(--space-3);max-width:none}}.toast{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-2);box-shadow:var(--shadow-3);font-size:var(--fs-small);pointer-events:auto;animation:toast-in .25s ease}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast-success{background:var(--success);color:var(--text-on-color)}.toast-error{background:var(--danger-hover);color:var(--text-on-color)}.toast-info{background:var(--primary);color:var(--text-on-color)}.toast-msg{flex:1;line-height:var(--lh-base)}.toast-close{background:none;border:none;color:inherit;opacity:.7;cursor:pointer;font-size:1.1rem;line-height:1;padding:0 0 0 var(--space-2);flex-shrink:0}.toast-close:hover{opacity:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fade-in .15s ease;padding:var(--space-4)}.modal-dialog{background:var(--surface-raised);border-radius:var(--radius-3);box-shadow:var(--shadow-3);width:100%;max-width:420px;animation:modal-pop .2s ease}@keyframes modal-pop{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.modal-title{font-size:var(--fs-lg);font-weight:600;padding:var(--space-5) var(--space-5) 0}.modal-body{padding:var(--space-4) var(--space-5);font-size:var(--fs-small);color:var(--text-secondary);line-height:var(--lh-base)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-2);padding:0 var(--space-5) var(--space-5)}.stack{display:flex;flex-direction:column;gap:var(--space-4)}.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:var(--mobile-nav-h);background:#ffffffeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border);z-index:var(--z-topbar);padding:0 var(--space-1)}@media(min-width:768px){.mobile-nav{display:none}}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--text-secondary);text-decoration:none;font-size:var(--fs-caption);padding:var(--space-1) 0;transition:color var(--dur-fast);-webkit-tap-highlight-color:transparent}.mobile-nav-item:hover{text-decoration:none}.mobile-nav-item.active{color:var(--primary)}.mobile-nav-item.active .mobile-nav-icon{background:var(--primary-bg);border-radius:var(--radius-3)}.mobile-nav-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;padding:3px;border-radius:var(--radius-2);transition:background var(--dur-fast)}.mobile-nav-icon svg{width:22px;height:22px}.mobile-nav-label{line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:64px}.search-bar{display:flex;gap:var(--space-2);margin-bottom:var(--space-3)}.search-input-wrap{flex:1;position:relative}.search-input-wrap svg{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--neutral-400);pointer-events:none}.search-input-wrap .form-control{padding-left:calc(var(--space-3) + 20px + var(--space-2))}.filter-chips{display:flex;gap:var(--space-2);flex-wrap:wrap}.chip{display:inline-flex;align-items:center;gap:var(--space-1);height:32px;padding:0 var(--space-3);border:1px solid var(--border);border-radius:99px;font-size:var(--fs-small);font-weight:500;font-family:inherit;cursor:pointer;background:var(--surface);color:var(--text-secondary);transition:all var(--dur-fast) var(--ease-out)}.chip:hover{border-color:var(--border-hover);color:var(--text)}.chip.active{background:var(--primary);color:var(--text-on-color);border-color:var(--primary)}.chip .chip-count{font-size:var(--fs-caption);opacity:.75}.search-layout{display:grid;grid-template-columns:1fr;gap:var(--space-4);align-items:start}@media(min-width:1024px){.search-layout{grid-template-columns:1fr 320px}}.search-results{min-width:0}.search-results-count{font-size:var(--fs-small);color:var(--text-secondary);margin-bottom:var(--space-3)}.product-grid{display:grid;grid-template-columns:1fr;gap:var(--space-3)}@media(min-width:480px){.product-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}}.product-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-3);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);transition:box-shadow var(--dur-norm) var(--ease-out),border-color var(--dur-norm)}.product-card:hover{box-shadow:var(--shadow-2);border-color:var(--border-hover)}.product-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-2)}.product-card-name{font-size:var(--fs-body);font-weight:600;color:var(--text);line-height:var(--lh-heading)}.product-card-unit{font-size:var(--fs-caption);color:var(--text-secondary);background:var(--surface-inset);padding:2px 6px;border-radius:var(--radius-1);white-space:nowrap;flex-shrink:0}.product-card-price{font-size:var(--fs-lg);font-weight:700;font-variant-numeric:tabular-nums;color:var(--text);letter-spacing:-.01em}.product-card-meta{display:flex;align-items:center;gap:var(--space-1);font-size:var(--fs-small);color:var(--text-secondary)}.product-card-meta svg{flex-shrink:0;color:var(--neutral-400)}.product-card-badges{display:flex;gap:var(--space-1);flex-wrap:wrap}.product-card-footer{margin-top:auto;padding-top:var(--space-2)}.pc-badges-row{display:flex;flex-wrap:wrap;gap:4px;margin-top:var(--space-1)}.badge-outline{background:transparent;border:1px solid var(--primary);color:var(--primary);font-weight:600}.pc-description{font-size:var(--fs-small);color:var(--text-secondary);margin-top:var(--space-1);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.45}.pc-attrs{margin-top:var(--space-2);border-top:1px solid var(--border);padding-top:var(--space-2)}.pc-attrs-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px var(--space-3)}.pc-attr{display:flex;flex-direction:column;min-width:0}.pc-attr-key{font-size:var(--fs-caption);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;line-height:1.2}.pc-attr-val{font-size:var(--fs-small);font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pc-attrs-toggle{display:inline-flex;align-items:center;gap:4px;margin-top:var(--space-1);padding:0;border:none;background:none;color:var(--primary);font-size:var(--fs-caption);font-weight:500;cursor:pointer}.pc-attrs-toggle:hover{text-decoration:underline}.producer-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-3);padding:var(--space-4);display:flex;align-items:center;gap:var(--space-3);transition:box-shadow var(--dur-norm) var(--ease-out)}.producer-card:hover{box-shadow:var(--shadow-2)}.producer-card-avatar{width:44px;height:44px;border-radius:50%;background:var(--primary-bg);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700;font-size:var(--fs-md)}.producer-card-info{flex:1;min-width:0}.producer-card-name{font-weight:600}.producer-card-region{font-size:var(--fs-small);color:var(--text-secondary)}.cart-sidebar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-3);padding:var(--space-4);box-shadow:var(--shadow-1)}@media(min-width:1024px){.cart-sidebar{position:sticky;top:calc(var(--topbar-h) + var(--space-6) + var(--space-4))}}@media(max-width:1023px){.cart-sidebar{display:none}}.cart-sidebar-title{font-size:var(--fs-md);font-weight:600;margin-bottom:var(--space-3);display:flex;align-items:center;justify-content:space-between}.cart-sidebar-count{font-size:var(--fs-caption);background:var(--primary-bg);color:var(--primary);padding:2px 8px;border-radius:99px;font-weight:600}.cart-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;border-bottom:1px solid var(--border)}.cart-item:last-of-type{border-bottom:none}.cart-item-info{flex:1;min-width:0}.cart-item-name{font-size:var(--fs-small);font-weight:500;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cart-item-price{font-size:var(--fs-caption);color:var(--text-secondary)}.cart-item-qty{width:56px;height:28px;text-align:center;border:1px solid var(--border);border-radius:var(--radius-1);font-size:var(--fs-small);font-family:inherit;background:var(--surface);color:var(--text)}.cart-item-qty:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-bg);outline:none}.cart-item-remove{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:var(--radius-1);cursor:pointer;color:var(--text-disabled);transition:color var(--dur-fast),background var(--dur-fast);flex-shrink:0}.cart-item-remove:hover{color:var(--danger);background:var(--danger-bg)}.cart-sidebar-footer{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border)}.cart-sidebar-footer .btn{width:100%}.rfq-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:var(--space-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-3);padding:var(--space-4);margin-bottom:var(--space-4);box-shadow:var(--shadow-1)}.rfq-summary-stat{text-align:center}.rfq-summary-value{font-size:var(--fs-h2);font-weight:700;color:var(--text);line-height:var(--lh-tight)}.rfq-summary-label{font-size:var(--fs-caption);color:var(--text-secondary);margin-top:2px;text-transform:uppercase;letter-spacing:.03em}.rfq-summary-value .badge{font-size:var(--fs-small);height:26px}.rfq-waiting{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--warning-bg);border:1px solid #ecd89e;border-radius:var(--radius-2);font-size:var(--fs-small);color:var(--warning-hover);margin-bottom:var(--space-3)}.rfq-waiting svg{flex-shrink:0}.quote-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-3)}.quote-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-3);padding:var(--space-4);position:relative;display:flex;flex-direction:column;gap:var(--space-2);transition:box-shadow var(--dur-norm) var(--ease-out)}.quote-card:hover{box-shadow:var(--shadow-2)}.quote-card.best-quote{border-color:var(--success);box-shadow:0 0 0 1px var(--success),var(--shadow-1)}.best-quote-tag{position:absolute;top:var(--space-3);right:var(--space-3);display:inline-flex;align-items:center;gap:var(--space-1);background:var(--success);color:var(--text-on-color);font-size:var(--fs-caption);font-weight:600;padding:2px 8px;border-radius:99px}.best-quote-tag svg{width:12px;height:12px}.quote-card-org{font-weight:600;font-size:var(--fs-body);padding-right:80px}.quote-card-region{font-size:var(--fs-caption);color:var(--text-secondary)}.quote-card-price{font-size:var(--fs-h2);font-weight:700;font-variant-numeric:tabular-nums;color:var(--text);letter-spacing:-.01em}.best-quote .quote-card-price{color:var(--success)}.quote-card-delivery{display:flex;align-items:center;gap:var(--space-1);font-size:var(--fs-small);color:var(--text-secondary)}.quote-card-delivery svg{width:14px;height:14px}.quote-card-comment{font-size:var(--fs-small);color:var(--text-secondary);line-height:var(--lh-base);border-top:1px solid var(--border);padding-top:var(--space-2)}.quote-card-pdf{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--fs-small);color:var(--primary);font-weight:500}.quote-card-pdf:hover{text-decoration:underline}.onboarding{padding:var(--space-4) var(--space-5);margin-bottom:var(--space-4)}.onboarding-title{font-size:var(--fs-md);font-weight:600;margin-bottom:var(--space-3)}.onboarding-steps{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-3)}@media(min-width:768px){.onboarding-steps{flex-direction:row;gap:var(--space-4)}}.onboarding-step{display:flex;align-items:center;gap:var(--space-2);font-size:var(--fs-small);color:var(--text-secondary);flex:1;min-width:0}.onboarding-step.done{color:var(--success)}.onboarding-step.active{color:var(--primary);font-weight:600}.onboarding-step-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:var(--fs-small);font-weight:600;border:2px solid var(--border);background:var(--surface);color:var(--text-disabled)}.onboarding-step.done .onboarding-step-num{background:var(--success-bg);border-color:var(--success);color:var(--success)}.onboarding-step.active .onboarding-step-num{background:var(--primary-bg);border-color:var(--primary);color:var(--primary)}.onboarding-step-text{min-width:0}.onboarding-step-label{line-height:var(--lh-heading)}.progress-track{height:6px;background:var(--surface-inset);border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--primary),var(--success));transition:width .4s var(--ease-out)}.progress-label{font-size:var(--fs-caption);color:var(--text-secondary);margin-top:var(--space-1);text-align:right}.profile-section{margin-bottom:0}.profile-section .card-title{display:flex;align-items:center;gap:var(--space-2)}.profile-section .card-title svg{color:var(--primary);flex-shrink:0}.catalog-toolbar{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.catalog-toolbar .search-input-wrap{flex:1;min-width:200px}.catalog-stat{display:flex;align-items:center;gap:var(--space-2);font-size:var(--fs-small);color:var(--text-secondary);white-space:nowrap}.catalog-stat strong{color:var(--text);font-size:var(--fs-md)}@media(min-width:480px){.sm\:flex-row{flex-direction:row}.sm\:show{display:initial}}@media(min-width:768px){.stack{flex-direction:row}.md\:show{display:initial}.md\:hide{display:none}}@media(max-width:1023px){.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.page-header h1{font-size:var(--fs-h2)}.auth-page{padding:var(--space-4)}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}@media(min-width:1024px){.lg\:show{display:initial}.lg\:hide{display:none}}@media(max-width:767px){.btn{min-height:44px}.btn-sm{min-height:36px}.form-control,select.form-control{min-height:44px;height:44px;font-size:16px;padding:0 var(--space-3)}textarea.form-control{height:auto;min-height:80px;padding:var(--space-2) var(--space-3)}.form-group,.form-field{margin-bottom:var(--space-3)}.flex.gap-md{flex-direction:column;gap:0}.content-area{overflow-x:hidden}.page-shell,.card{overflow-x:hidden;word-break:break-word}.sticky-action-bar{position:fixed;bottom:var(--mobile-nav-h);left:0;right:0;padding:var(--space-3) var(--space-4);background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -2px 8px #0000000f;z-index:var(--z-topbar);display:flex;gap:var(--space-2)}.sticky-action-bar .btn{flex:1}.has-sticky-bar{padding-bottom:calc(var(--mobile-nav-h) + 70px)!important}.mobile-hide{display:none!important}.btn:active:not(:disabled),.sidebar-link:active,.mobile-nav-item:active,.chip:active,.product-card:active,.quote-card:active,.ban-card:active,.queue-table tr:active{transform:scale(.97)}.card:active{box-shadow:var(--shadow-1)}.page-shell>.card+.card{margin-top:var(--space-3)}.mobile-nav{padding-bottom:env(safe-area-inset-bottom,0)}.sticky-action-bar{padding-bottom:calc(var(--space-3) + env(safe-area-inset-bottom,0))}}@media(min-width:768px){.sticky-action-bar{display:none}}.queue-controls{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center}.queue-controls .search-input-wrap{flex:1;min-width:180px}.queue-count{font-size:var(--fs-small);color:var(--text-secondary);white-space:nowrap;margin-left:auto}.queue-table tr{cursor:pointer}.queue-table tr:hover{background:var(--primary-bg)}.queue-table .inline-actions{display:flex;gap:var(--space-1);justify-content:flex-end}.vd-grid{display:grid;gap:var(--space-4)}@media(min-width:1024px){.vd-grid{grid-template-columns:1fr 380px}.vd-grid .vd-main{min-width:0}.vd-grid .vd-side{position:sticky;top:calc(var(--topbar-h) + var(--space-4));align-self:start}}.vd-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3) var(--space-6)}.vd-info-item{font-size:var(--fs-body)}.vd-info-item dt{font-size:var(--fs-small);color:var(--text-secondary);margin-bottom:var(--space-1);font-weight:500}.vd-info-item dd{margin:0}.checklist-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-2);margin-bottom:var(--space-2);background:var(--surface);transition:border-color .15s,background .15s;cursor:pointer}.checklist-item:hover{border-color:var(--primary)}.checklist-item.checked{border-color:var(--success);background:var(--success-bg)}.checklist-item.disabled{cursor:default;opacity:.6}.checklist-item input[type=checkbox]{width:18px;height:18px;flex-shrink:0;accent-color:var(--success)}.checklist-label{font-size:var(--fs-body);font-weight:500}.checklist-hint{font-size:var(--fs-small);color:var(--text-secondary)}.decision-box{border:2px solid var(--border);border-radius:var(--radius-2);padding:var(--space-4);background:var(--surface-inset)}.decision-box .card-title{margin-bottom:var(--space-3)}.decision-actions{display:flex;gap:var(--space-2);flex-wrap:wrap}.reason-required{font-size:var(--fs-small);color:var(--danger);margin-top:var(--space-1)}.mini-audit{margin-top:var(--space-4)}.mini-audit .card-title{font-size:var(--fs-body)}.audit-entry{display:flex;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--neutral-100);font-size:var(--fs-small)}.audit-entry:last-child{border-bottom:none}.audit-dot{width:8px;height:8px;border-radius:50%;background:var(--neutral-300);flex-shrink:0;margin-top:5px}.audit-dot.action-VERIFIED{background:var(--success)}.audit-dot.action-REJECTED{background:var(--warning)}.audit-dot.action-BLOCKED{background:var(--danger)}.audit-dot.action-verify_checklist{background:var(--primary)}.audit-meta{display:flex;gap:var(--space-3);color:var(--text-secondary);flex-wrap:wrap}.ban-card{display:flex;gap:var(--space-4);padding:var(--space-4);border-bottom:1px solid var(--neutral-100);align-items:flex-start}.ban-card:last-child{border-bottom:none}.ban-avatar{width:40px;height:40px;border-radius:50%;background:var(--danger-bg);color:var(--danger);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ban-info{flex:1;min-width:0}.ban-email{font-weight:600;font-size:var(--fs-body)}.ban-reason{font-size:var(--fs-small);color:var(--text-secondary);margin-top:var(--space-1);line-height:var(--lh-base)}.ban-meta{display:flex;gap:var(--space-4);margin-top:var(--space-2);font-size:var(--fs-caption);color:var(--text-secondary)}.ban-meta span{display:flex;align-items:center;gap:var(--space-1)}.audit-filters{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center}.audit-filters .search-input-wrap{flex:1;min-width:200px}.audit-filters select{height:38px;padding:0 var(--space-3);border:1px solid var(--border);border-radius:var(--radius-2);background:var(--surface);font-size:var(--fs-body);color:var(--text);cursor:pointer}.audit-row-changes{font-size:var(--fs-small);background:var(--surface-inset);padding:var(--space-2) var(--space-3);border-radius:var(--radius-1);max-width:400px;word-break:break-word}.audit-row-expandable{cursor:pointer}.audit-row-expandable:hover{background:var(--primary-bg)}.admin-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--space-4);margin-bottom:var(--space-4)}.admin-stat{text-align:center;padding:var(--space-5) var(--space-4)}.admin-stat-value{font-size:var(--fs-display);font-weight:700;font-variant-numeric:tabular-nums;color:var(--text);line-height:1}.admin-stat-label{font-size:var(--fs-small);color:var(--text-secondary);margin-top:var(--space-2)}.admin-stat-value.accent-primary{color:var(--primary)}.admin-stat-value.accent-danger{color:var(--danger)}.admin-stat-value.accent-success{color:var(--success)}.admin-stat-value.accent-warning{color:var(--warning)}.recent-activity .activity-item{display:flex;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--neutral-100);font-size:var(--fs-small)}.recent-activity .activity-item:last-child{border-bottom:none}.dt-root{display:flex;flex-direction:column;gap:var(--space-3)}.dt-toolbar{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.dt-toolbar+.fb-root{margin-top:calc(var(--space-3) * -.5)}.dt-search{display:flex;align-items:center;gap:var(--space-2);flex:1;min-width:180px;max-width:360px;position:relative}.dt-search svg{position:absolute;left:var(--space-3);color:var(--neutral-400);pointer-events:none}.dt-search .form-control{padding-left:calc(var(--space-3) + 20px)}.dt-table-card{padding:0}.dt-table-card.dt-sticky th{position:sticky;top:0;z-index:var(--z-base)}.dt-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.dt-sortable:hover{color:var(--text)}.dt-th-inner{display:inline-flex;align-items:center;gap:4px}.dt-sort-icon{flex-shrink:0;transition:transform var(--dur-fast) var(--ease-out)}.dt-sort-idle{opacity:.3}.dt-sortable:hover .dt-sort-idle{opacity:.6}tr.dt-clickable,.dt-card.dt-clickable{cursor:pointer}.dt-mobile{display:none}.dt-desktop{display:block}@media(max-width:767px){.dt-desktop{display:none}.dt-mobile{display:flex;flex-direction:column;gap:var(--space-3)}.dt-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-3);padding:var(--space-3) var(--space-4);box-shadow:var(--shadow-1);transition:border-color var(--dur-fast) var(--ease-out)}.dt-card:active{transform:scale(.97)}.dt-card-row{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3);padding:var(--space-1) 0}.dt-card-row+.dt-card-row{border-top:1px solid var(--border)}.dt-card-label{font-size:var(--fs-caption);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;flex-shrink:0;padding-top:2px}.dt-card-value{font-size:var(--fs-small);text-align:right;min-width:0;word-break:break-word}.dt-search{max-width:none;flex:1 1 100%}}.dt-pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-3) 0;font-size:var(--fs-small)}.dt-page-info{display:flex;align-items:center;gap:var(--space-2);font-variant-numeric:tabular-nums}.dt-page-total{color:var(--text-secondary);margin-left:var(--space-1)}.dt-page-total:before{content:"·";margin-right:var(--space-1)}.dt-expand-icon{color:var(--text-secondary);transition:transform var(--dur-fast) var(--ease-out);flex-shrink:0}tr.dt-expanded-row>td{background:var(--neutral-50);padding:var(--space-3) var(--space-4);border-top:none;font-size:var(--fs-small)}.dt-card-expand-toggle{display:flex;justify-content:center;padding-top:var(--space-2)}.dt-card-expanded{border-top:1px solid var(--border);margin-top:var(--space-2);padding-top:var(--space-2);font-size:var(--fs-small)}.profile-card{max-width:520px}.profile-card-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--border)}.profile-card-avatar{width:56px;height:56px;border-radius:50%;background:var(--neutral-100);display:flex;align-items:center;justify-content:center;color:var(--neutral-400);flex-shrink:0}.profile-card-email{font-size:var(--fs-lg);font-weight:600;margin-bottom:var(--space-1)}.profile-card-badges{display:flex;gap:var(--space-2);flex-wrap:wrap}.profile-card-info{display:flex;flex-direction:column;gap:0;margin:0}.profile-card-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid var(--border);font-size:var(--fs-small)}.profile-card-row:last-child{border-bottom:none}.profile-card-row dt{color:var(--text-secondary);display:flex;align-items:center;gap:var(--space-1);font-weight:400}.profile-card-row dd{margin:0;font-weight:500}.profile-links{max-width:520px}.profile-link-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);text-decoration:none;color:var(--text);transition:background var(--dur-fast) var(--ease-out)}.profile-link-item:last-child{border-bottom:none}.profile-link-item:hover{background:var(--neutral-50)}.profile-link-item svg{color:var(--primary);flex-shrink:0}.profile-link-item span{flex:1;font-weight:500}.profile-link-item .text-sm{color:var(--text-secondary);font-weight:400}.profile-link-arrow{color:var(--text-secondary)}.cat-layout{display:flex;gap:var(--space-4);align-items:flex-start}.cat-filters{width:280px;flex-shrink:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-3);overflow:hidden}.cat-filters-toggle{display:none}.cat-filters-body{padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-3)}.cat-filter-group{display:flex;flex-direction:column;gap:var(--space-1)}.cat-filter-label{font-size:var(--fs-small);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.cat-price-range{display:flex;align-items:center;gap:var(--space-1)}.cat-price-range input{flex:1;min-width:0}.cat-price-range span{color:var(--text-secondary)}.cat-checkboxes{display:flex;flex-direction:column;gap:var(--space-1)}.cat-checkbox{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;font-size:var(--fs-body)}.cat-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary)}.cat-producer-search,.cat-producer-input-wrap{position:relative}.cat-producer-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:2px}.cat-producer-dropdown{position:absolute;z-index:20;left:0;right:0;top:100%;margin-top:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-2);box-shadow:var(--shadow-2);max-height:200px;overflow-y:auto}.cat-producer-option{display:block;width:100%;text-align:left;padding:var(--space-2) var(--space-3);border:none;background:none;cursor:pointer;font-size:var(--fs-body);transition:background var(--dur-fast)}.cat-producer-option:hover{background:var(--neutral-50)}.cat-content{flex:1;min-width:0}.cat-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-3);flex-wrap:wrap}.cat-toolbar-left,.cat-toolbar-right{display:flex;align-items:center;gap:var(--space-2)}.cat-sort-select{padding:var(--space-1) var(--space-2);border-radius:var(--radius-2);border:1px solid var(--border);font-size:var(--fs-small);min-width:150px}.cat-view-toggle{display:flex;border:1px solid var(--border);border-radius:var(--radius-2);overflow:hidden;flex-shrink:0}.cat-view-toggle .btn{display:inline-flex;align-items:center;gap:var(--space-1);border-radius:0;border:none;white-space:nowrap}.cat-view-toggle .btn:first-child{border-right:1px solid var(--border)}.cat-view-label{font-size:var(--fs-small)}.cat-grid{margin-bottom:var(--space-3)}.cat-grid-loading{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-3)}.cat-skeleton{height:180px;background:linear-gradient(90deg,var(--neutral-100) 25%,var(--neutral-50) 50%,var(--neutral-100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-3)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:768px){.cat-layout{flex-direction:column}.cat-filters{width:100%}.cat-filters-toggle{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3);border:none;background:none;cursor:pointer;font-size:var(--fs-body);font-weight:600}.cat-filters-chevron{margin-left:auto;transition:transform var(--dur-norm)}.cat-filters-chevron--open{transform:rotate(180deg)}.cat-filters-body{display:none;border-top:1px solid var(--border)}.cat-filters--open .cat-filters-body{display:flex}.cat-toolbar{gap:var(--space-2)}.cat-sort-select{min-width:130px;font-size:var(--fs-caption)}}@media(max-width:480px){.cat-view-toggle .cat-view-label{display:none}.cat-view-toggle .btn{padding:var(--space-1) var(--space-2)}}.fb-root{width:100%}.fb-mobile-toggle{display:none;width:100%;align-items:center;gap:var(--space-2);padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius-2);background:var(--surface);font-size:var(--fs-body);font-weight:500;font-family:inherit;color:var(--text);cursor:pointer;transition:border-color var(--dur-fast),background var(--dur-fast)}.fb-mobile-toggle:hover{border-color:var(--border-hover);background:var(--neutral-50)}.fb-badge{width:8px;height:8px;border-radius:50%;background:var(--primary);flex-shrink:0}.fb-chevron{margin-left:auto;transition:transform .2s ease;color:var(--text-secondary)}.fb-chevron--open{transform:rotate(180deg)}.fb-fields{display:flex;flex-wrap:wrap;align-items:flex-end;gap:var(--space-3);padding:var(--space-2) 0}.fb-field{display:flex;flex-direction:column;gap:var(--space-1);min-width:0}.fb-field--text{flex:1 1 200px;min-width:180px;max-width:280px}.fb-field--text .search-input-wrap{flex:1;min-width:0}.fb-field--text .form-control{height:36px}.fb-field--select{flex:0 0 auto;min-width:120px}.fb-field--number,.fb-field--date{flex:0 0 auto}.fb-field--checkbox{display:flex;flex-direction:row;align-items:center;gap:var(--space-2);padding:0 var(--space-2);height:36px;white-space:nowrap;cursor:pointer;font-size:var(--fs-small);-webkit-user-select:none;user-select:none;border-radius:var(--radius-2);transition:background var(--dur-fast)}.fb-field--checkbox:hover{background:var(--neutral-50)}.fb-field--checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.fb-field--multicheck{border:none;margin:0;padding:var(--space-1) var(--space-2);background:var(--neutral-50);border-radius:var(--radius-2)}.fb-label{font-size:var(--fs-caption);color:var(--text-secondary);font-weight:500;line-height:1.3;white-space:nowrap}.fb-select{height:36px;min-width:100px;padding:0 var(--space-3);padding-right:calc(var(--space-3) + 16px);border:1px solid var(--border);border-radius:var(--radius-2);background:var(--surface);font-size:var(--fs-body);font-family:inherit;color:var(--text);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-2) center;transition:border-color var(--dur-fast)}.fb-select:hover{border-color:var(--border-hover)}.fb-select:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-bg);outline:none}.fb-number-input{width:100px;height:36px;padding:0 var(--space-2);border:1px solid var(--border);border-radius:var(--radius-2);font-size:var(--fs-body);transition:border-color var(--dur-fast)}.fb-number-input:focus{border-color:var(--primary);outline:none}.fb-date-input{width:140px;height:36px;padding:0 var(--space-2);border:1px solid var(--border);border-radius:var(--radius-2);font-size:var(--fs-body);transition:border-color var(--dur-fast)}.fb-date-input:focus{border-color:var(--primary);outline:none}.fb-multicheck-group{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-4)}.fb-multicheck-item{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--fs-small);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;padding:var(--space-1) 0}.fb-multicheck-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.fb-actions{display:flex;align-items:flex-end;gap:var(--space-2);margin-left:auto;flex-shrink:0}.fb-reset{white-space:nowrap}@media(max-width:767.98px){.fb-mobile-toggle{display:flex}.fb-fields{display:none;flex-direction:column;gap:var(--space-4);padding:var(--space-4);margin-top:var(--space-2);border:1px solid var(--border);border-radius:var(--radius-3);background:var(--surface);box-shadow:var(--shadow-2)}.fb-fields--open{display:flex;animation:fb-slide-down .2s ease}.fb-field{gap:var(--space-2)}.fb-field--text{flex:none;width:100%;max-width:none}.fb-field--text .form-control{width:100%}.fb-field--select,.fb-field--select .fb-select{width:100%;min-width:0}.fb-field--number,.fb-field--number .fb-number-input,.fb-field--date{width:100%}.fb-field--date .fb-date-input{width:100%;max-width:200px}.fb-field--multicheck{padding:var(--space-3)}.fb-multicheck-group{flex-direction:column;gap:var(--space-2)}.fb-multicheck-item{padding:var(--space-2);background:var(--surface);border-radius:var(--radius-2);border:1px solid transparent;transition:background var(--dur-fast),border-color var(--dur-fast)}.fb-multicheck-item:active{background:var(--neutral-100)}.fb-actions{margin-left:0;width:100%;justify-content:flex-end;padding-top:var(--space-3);border-top:1px solid var(--border);margin-top:var(--space-2)}}@keyframes fb-slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.draft-preview-list{list-style:none;margin:0 0 var(--space-4);padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.draft-preview-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-1);cursor:pointer;transition:background var(--dur-fast)}.draft-preview-item:hover{background:var(--surface-inset)}.badge-sm{font-size:var(--fs-caption);padding:2px 6px}.draft-list{display:flex;flex-direction:column;gap:var(--space-2)}.draft-list-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-2);cursor:pointer;transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}.draft-list-item:hover{border-color:var(--border-hover);box-shadow:var(--shadow-1)}.draft-list-main{flex:1;display:flex;align-items:center;gap:var(--space-2);min-width:0}.draft-list-title{font-weight:600}.draft-list-meta{font-size:var(--fs-sm);color:var(--text-muted);margin-right:var(--space-2);flex-shrink:0}.draft-list-actions{display:flex;gap:var(--space-2);flex-shrink:0}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:var(--space-4)}.tabs button{padding:var(--space-2) var(--space-4);font-size:var(--fs-small);font-weight:500;color:var(--text-secondary);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;margin-bottom:-1px;border-radius:0}.tabs button:hover{color:var(--text)}.tabs button.active{color:var(--primary);border-bottom-color:var(--primary)}.tabs-sm button{padding:var(--space-1) var(--space-3);font-size:var(--fs-caption)}.wizard-progress-row{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4)}.wizard-step-indicator{font-size:var(--fs-sm);font-weight:600;color:var(--text-secondary);white-space:nowrap}.wizard-progress-bar{flex:1;height:6px;background:var(--surface-inset);border-radius:3px;overflow:hidden}.wizard-progress-fill{height:100%;background:var(--primary);border-radius:3px;transition:width var(--dur-fast)}.wizard-steps{display:flex;gap:var(--space-2);margin-bottom:var(--space-4);flex-wrap:wrap}.wizard-step{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:1px solid var(--border);border-radius:var(--radius-2);background:var(--surface);font-size:var(--fs-sm);cursor:pointer;transition:border-color var(--dur-fast),background var(--dur-fast)}.wizard-step:hover{border-color:var(--border-hover)}.wizard-step.active{border-color:var(--primary);background:var(--primary-bg);color:var(--primary)}.wizard-save-status{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);font-size:var(--fs-sm);color:var(--text-muted)}.wizard-content{margin-bottom:var(--space-6)}.wizard-content h3{margin-bottom:var(--space-2)}.wizard-content h4{margin:var(--space-4) 0 var(--space-2);font-size:var(--fs-base)}.wizard-nav{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-4)}.wizard-nav-left{display:flex;gap:var(--space-2)}.wizard-shortcuts{margin-top:var(--space-2);font-size:var(--fs-caption)}.wizard-shortcuts-hint{font-weight:500}.review-warnings{background:var(--warning-bg);border:1px solid var(--warning);border-radius:var(--radius-2);padding:var(--space-4);margin-bottom:var(--space-4)}.review-warning-item{display:flex;align-items:center;gap:var(--space-2);margin:0;color:var(--warning);font-weight:500}.review-warning-item+.review-warning-item{margin-top:var(--space-2)}@media(max-width:480px){.rfq-draft-wizard .wizard-progress-row{flex-wrap:wrap;gap:var(--space-2)}.rfq-draft-wizard .wizard-step-indicator{width:100%}.rfq-draft-wizard .wizard-nav{flex-direction:column;align-items:stretch}.rfq-draft-wizard .wizard-nav-left{justify-content:space-between}.rfq-draft-wizard .wizard-shortcuts{font-size:.65rem}.rfq-draft-wizard .wizard-steps .wizard-step{padding:var(--space-1) var(--space-2);font-size:var(--fs-caption)}.rfq-draft-wizard .draft-list-actions{flex-wrap:wrap}}.draft-items-table{overflow-x:auto;margin-bottom:var(--space-4)}.draft-items-table table{width:100%;border-collapse:collapse}.draft-items-table th,.draft-items-table td{padding:var(--space-2);text-align:left;border-bottom:1px solid var(--border)}.draft-items-table th{font-weight:600;font-size:var(--fs-sm);color:var(--text-secondary)}.draft-items-table .form-control{min-width:80px}.supplier-search{margin-bottom:var(--space-4)}.supplier-results{list-style:none;margin-top:var(--space-2);border:1px solid var(--border);border-radius:var(--radius-2);overflow:hidden}.supplier-results li{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3);border-bottom:1px solid var(--border)}.supplier-results li:last-child{border-bottom:none}.selected-suppliers{margin-top:var(--space-4)}.selected-suppliers h4{margin-bottom:var(--space-2)}.supplier-chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);background:var(--neutral-100);border-radius:var(--radius-2);margin-right:var(--space-2);margin-bottom:var(--space-2);font-size:var(--fs-sm)}.supplier-chip .chip-remove{padding:0;background:none;border:none;cursor:pointer;color:var(--text-muted)}.supplier-chip .chip-remove:hover{color:var(--danger)}.review-section{margin-bottom:var(--space-4)}.review-section ul{list-style:disc;margin-left:var(--space-5)}.empty-state{text-align:center;padding:var(--space-8)}.empty-state-icon{color:var(--neutral-400);margin-bottom:var(--space-4)}.empty-state h3{margin-bottom:var(--space-2)}.empty-state p{margin-bottom:var(--space-4);color:var(--text-muted)}.rfq-actions-grid,.rfq-extras-grid{display:grid;gap:var(--space-4);grid-template-columns:1fr}.rfq-attachments-uploader{display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap;margin-bottom:var(--space-3)}.rfq-attachments-list{display:grid;gap:var(--space-2)}.rfq-attachments-item{display:grid;grid-template-columns:1fr auto;gap:var(--space-2);align-items:center;padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius-2);background:var(--surface);text-decoration:none}.rfq-attachments-item:hover{border-color:var(--border-hover);box-shadow:var(--shadow-1);text-decoration:none}.rfq-attachments-name{font-weight:600;color:var(--text)}.rfq-attachments-meta{grid-column:1 / 2;font-size:var(--fs-small)}.rfq-attachments-dl{color:var(--text-secondary)}.rfq-chat-list{display:grid;gap:var(--space-3);margin-top:var(--space-3);margin-bottom:var(--space-3);max-height:360px;overflow:auto;padding-right:var(--space-1)}.rfq-chat-msg{padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius-2);background:var(--surface-inset)}.rfq-chat-meta{display:flex;gap:var(--space-2);align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.rfq-chat-body{white-space:pre-wrap}.rfq-chat-form .form-control{width:100%}.rfq-chat-actions{display:flex;gap:var(--space-2);margin-top:var(--space-2);flex-wrap:wrap}.rfq-timeline-list{list-style:none;display:grid;gap:var(--space-3);margin-top:var(--space-3)}.rfq-timeline-item{display:grid;grid-template-columns:120px 1fr;gap:var(--space-3);padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius-2);background:var(--surface)}.rfq-timeline-time{font-size:var(--fs-small);color:var(--text-secondary)}.rfq-timeline-kind{font-weight:600}.rfq-timeline-body{color:var(--text-secondary);margin-top:var(--space-1)}.attachment-list{display:grid;gap:var(--space-2)}.attachment-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-2);background:var(--surface)}.attachment-item a{font-size:var(--fs-small);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:70%}@media(min-width:1024px){.rfq-actions-grid,.rfq-extras-grid{grid-template-columns:1fr 1fr;align-items:start}}@media(max-width:479px){.rfq-timeline-item{grid-template-columns:1fr}}.kv-grid{display:grid;gap:var(--space-3)}.kv-row{display:grid;grid-template-columns:180px 1fr;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--border)}.kv-row:last-child{border-bottom:none}.kv-label{font-size:var(--fs-small);color:var(--text-secondary)}.kv-value{color:var(--text)}.hr{height:1px;background:var(--border);margin:var(--space-4) 0}@media(max-width:767px){.kv-row{grid-template-columns:1fr;gap:var(--space-1)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
