:root{--accent: oklch(.52 .17 145);--accent-hover: oklch(.46 .17 145);--accent-contrast: #fff;--accent-weak: oklch(.97 .03 145);--accent-weak2: oklch(.94 .05 145);--surface: #fff;--surface-2: oklch(.975 .006 145);--surface-3: oklch(.96 .008 145);--border: oklch(.91 .01 145);--border-strong: oklch(.82 .02 145);--text: oklch(.18 .02 145);--text-muted: oklch(.44 .03 145);--text-faint: oklch(.62 .02 145);--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--radius-xl: 20px;--shadow-sm: 0 1px 2px 0 oklch(0 0 0 / .06);--shadow-card: 0 1px 3px 0 oklch(0 0 0 / .07), 0 1px 2px -1px oklch(0 0 0 / .07);--shadow-lg: 0 4px 16px 0 oklch(0 0 0 / .1);--font-body: "Inter", "DM Sans", system-ui, sans-serif;--font-head: "DM Sans", "Inter", system-ui, sans-serif;--tone-amber-bg: oklch(.97 .05 80);--tone-amber-text: oklch(.5 .14 65);--tone-sky-bg: oklch(.96 .04 220);--tone-sky-text: oklch(.46 .13 225);--tone-indigo-bg: oklch(.95 .05 270);--tone-indigo-text:oklch(.44 .14 270);--tone-teal-bg: oklch(.95 .04 195);--tone-teal-text: oklch(.44 .1 200);--tone-green-bg: oklch(.95 .06 150);--tone-green-text: oklch(.44 .12 150);--tone-slate-bg: oklch(.94 .005 240);--tone-slate-text: oklch(.42 .02 240);--tone-rose-bg: oklch(.96 .03 18);--tone-rose-text: oklch(.5 .14 18)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);font-size:14px;line-height:1.6;color:var(--text);background:var(--surface-2);min-height:100vh;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}.app-container{min-height:100vh;display:flex;flex-direction:column}.page-content{max-width:1180px;margin:0 auto;padding:24px 32px 90px;width:100%}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.card-header{display:flex;align-items:center;gap:9px;padding:13px 20px;border-bottom:1px solid var(--border);background:var(--surface-2)}.card-title{font-size:14.5px;font-weight:700}.card-body{padding:18px 20px}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius);font-size:14px;font-weight:600;border:1px solid transparent;transition:background .15s,color .15s,border-color .15s,opacity .15s;white-space:nowrap;line-height:1}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--accent-contrast);border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.btn-outline{background:transparent;color:var(--accent);border-color:var(--accent)}.btn-outline:hover:not(:disabled){background:var(--accent-weak)}.btn-ghost{background:transparent;color:var(--text-muted);border-color:var(--border)}.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.btn-quiet{background:transparent;color:var(--text-muted);border-color:transparent}.btn-quiet:hover:not(:disabled){background:var(--surface-3);color:var(--text)}.btn-sm{padding:6px 12px;font-size:13px;border-radius:var(--radius-sm)}.btn-lg{padding:12px 24px;font-size:15px;border-radius:var(--radius)}.btn-full{width:100%;justify-content:center}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:700;color:var(--text-muted)}.form-label-required:after{content:" *";color:#c43448}.input,.textarea,.select{width:100%;padding:10px 13px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:14px;color:var(--text);background:var(--surface);transition:border-color .15s,box-shadow .15s;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.input:focus,.textarea:focus,.select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0080201f;box-shadow:0 0 0 3px oklch(.52 .17 145 / .12)}.input::placeholder,.textarea::placeholder{color:var(--text-faint)}.textarea{resize:vertical;min-height:80px;line-height:1.6}.input-error{border-color:#d64556}.form-error{font-size:12.5px;color:#c43448;margin-top:2px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:999px;font-size:12px;font-weight:700;white-space:nowrap}.badge-amber{background:var(--tone-amber-bg);color:var(--tone-amber-text)}.badge-sky{background:var(--tone-sky-bg);color:var(--tone-sky-text)}.badge-indigo{background:var(--tone-indigo-bg);color:var(--tone-indigo-text)}.badge-teal{background:var(--tone-teal-bg);color:var(--tone-teal-text)}.badge-green{background:var(--tone-green-bg);color:var(--tone-green-text)}.badge-slate{background:var(--tone-slate-bg);color:var(--tone-slate-text)}.badge-rose{background:var(--tone-rose-bg);color:var(--tone-rose-text)}.badge-lg{padding:5px 13px;font-size:13px;border-radius:999px}.topbar{position:sticky;top:0;z-index:40;background:#ffffffe0;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}.topbar-inner{padding:0 20px 0 16px;height:66px;display:flex;align-items:center;gap:20px}.topbar-logo{display:flex;align-items:center;gap:11px}.topbar-logo-icon{width:36px;height:36px;border-radius:11px;background:var(--accent);color:var(--accent-contrast);display:flex;align-items:center;justify-content:center;flex-shrink:0}.topbar-logo-name{font-size:15.5px;font-weight:800;font-family:var(--font-head);line-height:1.15}.topbar-logo-sub{font-size:11px;color:var(--text-faint);font-weight:600}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:14px}.topbar-menu-btn{border-right:1px solid var(--border);padding-right:14px;margin-right:2px}.topbar-role-switcher{display:flex;align-items:center;gap:9px}.role-switcher-label{font-size:11.5px;color:var(--text-faint);font-weight:700}.role-switcher-tabs{display:flex;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:3px}.role-tab{padding:6px 15px;border-radius:999px;font-size:13px;font-weight:700;border:none;background:transparent;color:var(--text-muted);transition:all .15s}.role-tab-active{background:var(--accent);color:var(--accent-contrast)}.topbar-user{display:flex;align-items:center;gap:9px}.topbar-user-name{font-size:13px;font-weight:700;line-height:1.2}.topbar-user-sub{font-size:11px;color:var(--text-faint)}.avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0;font-family:var(--font-head)}.avatar-company{background:var(--accent-weak2);color:var(--accent)}.avatar-supplier{background:#e0ecff;background:oklch(.94 .04 260);color:#2b4c9f}.avatar-topbar{width:34px;height:34px;font-size:13px}.notif-dropdown{position:absolute;right:0;top:46px;width:340px;z-index:50;overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.notif-header{padding:13px 16px;border-bottom:1px solid var(--border);font-weight:700;font-size:14.5px;display:flex;justify-content:space-between;align-items:center}.notif-count{font-size:12px;color:var(--text-faint);font-weight:600}.notif-list{max-height:360px;overflow-y:auto}.notif-empty{padding:24px;text-align:center;color:var(--text-faint);font-size:13.5px}.notif-item{width:100%;text-align:left;display:flex;gap:11px;padding:12px 16px;border-bottom:1px solid var(--border);border-top:none;border-left:none;border-right:none;background:transparent;transition:background .1s}.notif-item-unread{background:var(--accent-weak)}.notif-item:hover{background:var(--surface-2)}.notif-dot{width:8px;height:8px;border-radius:50%;margin-top:6px;flex-shrink:0}.notif-dot-unread{background:var(--accent)}.notif-dot-read{background:var(--border-strong)}.notif-text{display:block;font-size:13.5px;color:var(--text);font-weight:600;line-height:1.4}.notif-meta{display:block;font-size:11.5px;color:var(--text-faint);margin-top:2px}.notif-badge{position:absolute;top:-3px;right:-3px;min-width:17px;height:17px;padding:0 4px;border-radius:999px;background:#de3b3d;color:#fff;font-size:10.5px;font-weight:800;display:flex;align-items:center;justify-content:center}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#edf9ed,#def5e8);padding:24px}.login-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden}.login-header{padding:36px 36px 28px;text-align:center;border-bottom:1px solid var(--border);background:var(--surface-2)}.login-logo-icon{width:52px;height:52px;border-radius:15px;background:var(--accent);color:var(--accent-contrast);display:flex;align-items:center;justify-content:center;margin:0 auto 14px}.login-title{font-size:20px;font-weight:800;font-family:var(--font-head);color:var(--text)}.login-subtitle{font-size:12.5px;color:var(--text-faint);font-weight:600;margin-top:4px}.login-body{padding:28px 36px 36px;display:flex;flex-direction:column;gap:18px}.login-user-type{display:flex;gap:8px}.user-type-btn{flex:1;padding:10px;border:1.5px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-muted);font-size:13px;font-weight:700;text-align:center;transition:all .15s;cursor:pointer}.user-type-btn-active{border-color:var(--accent);background:var(--accent-weak);color:var(--accent)}.login-error{padding:11px 14px;border-radius:var(--radius);background:#ffecec;background:oklch(.96 .025 18);border:1px solid oklch(.85 .07 18);color:#a4283a;font-size:13.5px;font-weight:600}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;color:var(--text-faint);font-size:14px}.spinner{width:22px;height:22px;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.toast-host{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:9999;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:12px 18px;background:var(--text);color:var(--surface);border-radius:var(--radius);font-size:14px;font-weight:600;box-shadow:var(--shadow-lg);animation:toastIn .25s ease;pointer-events:auto}@keyframes toastIn{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.layout-body{display:flex;min-height:calc(100vh - 66px)}.sidebar{width:220px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);padding:12px 0;position:sticky;top:66px;height:calc(100vh - 66px);overflow-y:auto;overflow-x:hidden;transition:width .25s cubic-bezier(.4,0,.2,1),padding .25s cubic-bezier(.4,0,.2,1),border-color .25s}.sidebar-collapsed{width:0;padding:0;border-color:transparent;overflow:hidden}.sidebar-label{font-size:10.5px;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:.07em;padding:14px 16px 5px}.sidebar-section{padding:0 8px}.sidebar-nav-item{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:var(--radius);font-size:13.5px;font-weight:600;color:var(--text-muted);cursor:pointer;border:none;background:transparent;width:100%;text-align:left;transition:background .12s,color .12s}.sidebar-nav-item:hover:not(.sidebar-nav-item-disabled){background:var(--surface-2);color:var(--text)}.sidebar-nav-item-active{background:var(--accent-weak);color:var(--accent)}.sidebar-nav-item-disabled{opacity:.38;cursor:not-allowed}.sidebar-divider{height:1px;background:var(--border);margin:8px 16px}.main-content{flex:1;min-width:0;padding:28px 32px 80px;position:relative;overflow:hidden}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-title{font-size:22px;font-weight:800;font-family:var(--font-head);color:var(--text)}.filter-bar{display:flex;gap:10px;margin-bottom:14px;align-items:center;flex-wrap:wrap}.status-chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.status-chip{padding:4px 12px;border-radius:20px;border:1px solid var(--border);background:var(--bg-card, #fff);font-size:12px;font-weight:500;cursor:pointer;color:var(--text-muted);line-height:1.4;transition:border-color .15s,color .15s,background .15s}.status-chip:hover{border-color:var(--accent);color:var(--accent)}.status-chip-active{background:var(--accent);color:#fff;border-color:var(--accent)}.quote-amount-row{display:flex;align-items:flex-end;gap:8px}.quote-amount-row .form-group{flex:1;margin-bottom:0}.quote-auto-badge{font-size:11px;padding:3px 8px;border-radius:10px;background:var(--success-weak, #d1fae5);color:var(--success, #059669);font-weight:600;white-space:nowrap;margin-bottom:2px;cursor:default}.quote-manual-badge{font-size:11px;padding:3px 8px;border-radius:10px;background:var(--warning-weak, #fef3c7);color:var(--warning, #d97706);font-weight:600;white-space:nowrap;margin-bottom:2px;cursor:pointer;text-decoration:underline}.input-search{max-width:280px}.detail-section-label{font-size:11px;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em;padding:16px 0 6px;border-bottom:2px solid var(--border);margin-bottom:2px}.detail-section-label-quote{color:var(--accent);border-bottom-color:var(--accent-weak2)}.detail-section-label-order{color:var(--success, #059669);border-bottom-color:#a7f3d0}.detail-section-label-delivery{color:#0891b2;border-bottom-color:#a5f3fc}.detail-section-label-shipment{color:#7c3aed;border-bottom-color:#ddd6fe}.detail-section-label-receipt{color:var(--text-faint);border-bottom-color:var(--border)}.detail-grid{display:grid;grid-template-columns:130px 1fr;gap:2px 0}.detail-label{font-size:12px;font-weight:700;color:var(--text-faint);padding:8px 0;border-bottom:1px solid var(--border)}.detail-value{font-size:14px;color:var(--text);padding:8px 0 8px 12px;border-bottom:1px solid var(--border)}.detail-value-pre{white-space:pre-wrap;line-height:1.65}.select-wrap{position:relative}.select-wrap:after{content:"";position:absolute;right:13px;top:50%;transform:translateY(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid var(--text-faint);pointer-events:none}.select-wrap .select{padding-right:32px;cursor:pointer}.select-filter{width:220px}.modal-lg{max-width:640px}.form-row{display:flex;gap:12px}.form-col-qty{flex:2}.form-col-unit{flex:1}.input-password-wrap{position:relative;display:flex;align-items:center}.input-password-wrap .input{padding-right:44px}.input-password-toggle{position:absolute;right:10px;background:none;border:none;color:var(--text-faint);cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:color .15s}.input-password-toggle:hover{color:var(--text-muted)}.filter-toggle{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;white-space:nowrap;padding:8px 12px;border-radius:var(--radius);border:1.5px solid var(--border);background:var(--surface);transition:border-color .15s,color .15s}.filter-toggle:hover{border-color:var(--accent);color:var(--accent)}.filter-toggle-active{border-color:var(--accent);color:var(--accent);background:var(--accent-weak)}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:13.5px}.data-table th{padding:10px 14px;text-align:left;font-size:11.5px;font-weight:700;color:var(--text-faint);background:var(--surface-2);border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:var(--surface-2)}.data-table tbody tr.tr-clickable{cursor:pointer}.td-actions{text-align:right;white-space:nowrap}.td-code{font-family:Courier New,monospace;font-size:13px;color:var(--text-muted);font-weight:600}.badge-active{background:var(--tone-green-bg);color:var(--tone-green-text)}.badge-inactive{background:var(--tone-slate-bg);color:var(--tone-slate-text)}.badge-admin{background:var(--tone-indigo-bg);color:var(--tone-indigo-text)}.badge-user{background:var(--tone-sky-bg);color:var(--tone-sky-text)}.badge-quote-requested{background:var(--tone-amber-bg);color:var(--tone-amber-text)}.badge-quote-answered{background:var(--tone-sky-bg);color:var(--tone-sky-text)}.badge-ordered{background:var(--tone-indigo-bg);color:var(--tone-indigo-text)}.badge-delivery-answered{background:var(--tone-teal-bg);color:var(--tone-teal-text)}.badge-shipped{background:var(--tone-green-bg);color:var(--tone-green-text)}.badge-received{background:var(--tone-slate-bg);color:var(--tone-slate-text)}.badge-cancelled{background:var(--tone-rose-bg);color:var(--tone-rose-text)}.empty-state{text-align:center;padding:64px 24px}.empty-state-title{font-size:15px;font-weight:700;color:var(--text-muted);margin-bottom:6px}.empty-state-desc{font-size:13.5px;color:var(--text-faint)}.slide-panel{position:absolute;top:0;right:0;bottom:0;left:0;z-index:150;background:var(--surface-2);display:flex;flex-direction:column;transform:translate(100%);transition:transform .28s cubic-bezier(.4,0,.2,1)}.slide-panel.slide-panel-open{transform:translate(0)}.slide-panel-header{display:flex;align-items:center;gap:14px;padding:10px 20px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;flex-wrap:wrap}.slide-panel-title{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.slide-panel-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.slide-panel-body{flex:1;overflow-y:auto}.slide-panel-inner{max-width:760px;margin:0 auto;padding:28px 24px}.panel-form{max-width:520px}.panel-form-actions{display:flex;gap:10px;justify-content:flex-end;padding-top:20px;margin-top:8px;border-top:1px solid var(--border)}.td-chevron{width:32px;text-align:right;color:var(--text-faint);padding-right:12px!important}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000061;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}.modal-backdrop-top{z-index:300}.modal-header-info{display:flex;flex-direction:column;gap:5px}.modal{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:modalIn .18s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-title{font-size:17px;font-weight:800;font-family:var(--font-head)}.modal-body{padding:24px;display:flex;flex-direction:column;gap:18px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border);background:var(--surface-2);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.confirm-dialog{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:400px;padding:32px;animation:modalIn .18s ease}.confirm-title{font-size:16px;font-weight:800;font-family:var(--font-head);margin-bottom:10px;color:var(--text)}.confirm-desc{font-size:13.5px;color:var(--text-muted);line-height:1.65;margin-bottom:24px}.confirm-actions{display:flex;justify-content:flex-end;gap:10px}.btn-danger{background:#c8384b;color:#fff;border-color:#c8384b}.btn-danger:hover:not(:disabled){background:#b3203a}.alert-error{padding:11px 14px;border-radius:var(--radius);background:#ffecec;background:oklch(.96 .025 18);border:1px solid oklch(.85 .07 18);color:#a4283a;font-size:13.5px;font-weight:600}.tabular{font-variant-numeric:tabular-nums}.text-xs{font-size:12px}.text-faint{color:var(--text-faint)}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent)}.font-head{font-family:var(--font-head)}.font-bold{font-weight:700}.font-black{font-weight:800}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
