@import "https://fonts.googleapis.com/css2?family=Inter:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&display=swap";:root{--primary:#2563eb;--primary-dark:#1d4ed8;--primary-mid:#3b82f6;--primary-light:#eff6ff;--success:#10b981;--success-bg:#ecfdf5;--success-text:#065f46;--warning:#f59e0b;--warning-bg:#fffbeb;--warning-text:#92400e;--danger:#ef4444;--danger-bg:#fef2f2;--danger-text:#991b1b;--bg:#f2f5fb;--surface:#fff;--surface-2:#f7f9fc;--border:#e3e8f0;--border-strong:#c8d4e4;--text:#0d1526;--text-secondary:#2d3e58;--text-muted:#6b7a99;--text-faint:#9aaabf;--sidebar-w:236px;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000d, 0 2px 8px #00000008;--shadow-md:0 4px 16px #00000012, 0 2px 6px #0000000a;--shadow-lg:0 24px 56px #00000026, 0 8px 24px #0000000f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}.shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);color:#adc3d8;inset-block:0;z-index:50;background:linear-gradient(#121f34 0%,#0e1a2e 60%,#0a1525 100%);border-right:1px solid #ffffff0d;flex-direction:column;display:flex;position:fixed;left:0;overflow-y:auto}.sidebar-logo{border-bottom:1px solid #ffffff0f;align-items:center;gap:11px;padding:18px 16px 16px;text-decoration:none;display:flex}.sidebar-logo-mark{color:#fff;letter-spacing:-.5px;background:linear-gradient(135deg,#2563eb 0%,#38bdf8 100%);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:15px;font-weight:800;display:flex;box-shadow:0 4px 16px #2563eb80,0 0 0 1px #60a5fa33}.sidebar-logo-text{flex-direction:column;gap:1px;min-width:0;display:flex}.sidebar-logo-name{color:#fff;letter-spacing:-.3px;white-space:nowrap;font-size:15px;font-weight:700;line-height:1.1}.sidebar-logo-name span{color:#7dd3fc}.sidebar-logo-portal{letter-spacing:.1em;color:#ffffff52;text-transform:uppercase;font-size:9.5px;font-weight:600}.sidebar-label{text-transform:uppercase;letter-spacing:.12em;color:#ffffff59;padding:18px 16px 5px;font-size:9px;font-weight:700}.sidebar-nav{flex:1;padding:6px 8px}.sidebar-nav a{color:#adc3d8;border-radius:8px;align-items:center;gap:9px;margin-bottom:1px;padding:8px 10px 8px 12px;font-size:13.5px;font-weight:500;text-decoration:none;transition:background .14s,color .14s;display:flex;position:relative}.sidebar-nav a:hover{color:#daeaf8;background:#ffffff17}.sidebar-nav a.active{color:#c4dcfa;background:linear-gradient(90deg,#2563eb52 0%,#2563eb1f 100%);font-weight:600}.sidebar-nav a.active:before{content:"";background:linear-gradient(#7dd3fc,#3b82f6);border-radius:0 3px 3px 0;width:3px;position:absolute;top:7px;bottom:7px;left:0;box-shadow:0 0 8px #60a5fa8c}.sidebar-footer{border-top:1px solid #ffffff0f;padding:12px}.sidebar-user-row{align-items:center;gap:10px;padding:6px 4px 10px;display:flex}.sidebar-user-avatar{color:#fff;background:linear-gradient(135deg,#1d4ed8,#60a5fa);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:11.5px;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:#c0d4ea;white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;font-weight:600;overflow:hidden}.sidebar-user-email{color:#ffffff45;white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.sidebar-user{color:#ffffff59;white-space:nowrap;text-overflow:ellipsis;margin-bottom:8px;padding:0 4px;font-size:12px;overflow:hidden}.sidebar-footer button{color:#adc3d8;cursor:pointer;background:0 0;border:1px solid #ffffff1a;border-radius:8px;width:100%;padding:7px;font-family:inherit;font-size:12.5px;font-weight:500;transition:all .14s}.sidebar-footer button:hover{color:#daeaf8;background:#ffffff14;border-color:#ffffff2e}.main{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:40;flex-shrink:0;justify-content:flex-end;align-items:center;height:54px;padding:0 36px;display:flex;position:sticky;top:0}.topbar-user{border:1.5px solid var(--border);cursor:pointer;color:inherit;background:var(--surface);border-radius:40px;align-items:center;gap:9px;padding:5px 14px 5px 5px;text-decoration:none;transition:border-color .15s,background .15s,box-shadow .15s;display:flex}.topbar-user:hover{border-color:var(--primary);background:var(--primary-light);box-shadow:0 2px 8px #2563eb1f}.topbar-avatar{background:linear-gradient(135deg, var(--primary), #60a5fa);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.topbar-user-name{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:13px;font-weight:600;overflow:hidden}.page-head{background:var(--surface);border-bottom:1px solid var(--border);padding:28px 36px 24px}.page-head h1{letter-spacing:-.4px;color:var(--text);font-size:21px;font-weight:700}.page-head p{color:var(--text-muted);margin-top:3px;font-size:13.5px}.page-body{flex:1;padding:28px 36px 44px}.stats{grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:16px;margin-bottom:28px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:14px;padding:22px 22px 18px;position:relative;overflow:hidden}.stat-card:before{content:"";background:linear-gradient(90deg, var(--primary), var(--primary-mid));border-radius:14px 14px 0 0;height:3px;position:absolute;top:0;left:0;right:0}.stat-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:10px;font-size:10.5px;font-weight:700}.stat-value{letter-spacing:-1.5px;color:var(--text);font-size:34px;font-weight:800;line-height:1}.stat-link{color:var(--primary);margin-top:12px;font-size:12px;font-weight:500;text-decoration:none;display:inline-block}.stat-link:hover{text-decoration:underline}.table-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:14px;overflow:hidden}.table-toolbar{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 22px;display:flex}.table-toolbar h2{color:var(--text);font-size:14px;font-weight:600}table{border-collapse:collapse;width:100%}thead th{text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);background:var(--surface-2);border-bottom:1px solid var(--border);padding:10px 22px;font-size:10.5px;font-weight:700}tbody td{vertical-align:middle;color:var(--text-secondary);border-bottom:1px solid #edf1f7;padding:13px 22px;font-size:13.5px}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:#f5f8ff}.mono{letter-spacing:-.2px;color:var(--text-secondary);font-family:SF Mono,Fira Code,Menlo,monospace;font-size:12px}.sub-text{color:var(--text-muted);margin-top:2px;font-size:11.5px;display:block}.badge{border-radius:20px;align-items:center;padding:3px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.badge-pending{color:#92400e;background:#fef3c7}.badge-processing{color:#1e40af;background:#dbeafe}.badge-fulfilled{color:#065f46;background:#d1fae5}.badge-cancelled{color:#991b1b;background:#fee2e2}.badge-connected{color:#065f46;background:#d1fae5}.btn{cursor:pointer;white-space:nowrap;letter-spacing:-.1px;border:none;border-radius:8px;align-items:center;gap:6px;padding:8.5px 16px;font-family:inherit;font-size:13px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 1px 3px #2563eb40}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb59}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 3px #2563eb33}.btn-outline{background:var(--surface);border:1px solid var(--border);color:var(--text-secondary)}.btn-outline:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.btn-danger{background:var(--danger-bg);color:#b91c1c;border:1px solid #fecaca}.btn-danger:hover:not(:disabled){background:#fee2e2;border-color:#fca5a5}.btn-sm{border-radius:6px;padding:5px 11px;font-size:12px}.btn-full{justify-content:center;width:100%}.form-group{margin-bottom:16px}label{color:var(--text-secondary);margin-bottom:6px;font-size:12.5px;font-weight:600;display:block}input,select{border:1.5px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:8px;outline:none;padding:9px 12px;font-family:inherit;font-size:13.5px;transition:border-color .15s,box-shadow .15s}input:hover:not(:focus),select:hover:not(:focus){border-color:var(--border-strong)}input:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}input::placeholder{color:var(--text-faint)}.backdrop{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:200;background:#060e1c9e;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);width:450px;max-width:100%;box-shadow:var(--shadow-lg), 0 0 0 1px #0000000a;border-radius:18px;max-height:92vh;padding:30px;animation:.2s cubic-bezier(.34,1.16,.64,1) modal-in;overflow-y:auto}@keyframes modal-in{0%{opacity:0;transform:scale(.94)translateY(14px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-title{letter-spacing:-.3px;margin-bottom:22px;font-size:17px;font-weight:700}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;margin-top:22px;padding-top:18px;display:flex}.modal-wide{width:740px}.empty{text-align:center;color:var(--text-muted);padding:56px 24px}.empty strong{color:var(--text-secondary);margin-bottom:6px;font-size:15px;font-weight:600;display:block}.error-box{background:var(--danger-bg);color:#b91c1c;border:1px solid #fecaca;border-radius:8px;margin-bottom:16px;padding:11px 14px;font-size:13px;font-weight:500}.login-wrap{background:linear-gradient(145deg,#091424 0%,#0d1e38 55%,#091424 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-wrap:before{content:"";pointer-events:none;background:radial-gradient(circle,#2563eb29 0%,#0000 65%);width:800px;height:800px;position:absolute;top:-280px;right:-200px}.login-wrap:after{content:"";pointer-events:none;background:radial-gradient(circle,#60a5fa17 0%,#0000 65%);width:500px;height:500px;position:absolute;bottom:-100px;left:-150px}.login-card{z-index:1;background:#fff;border-radius:22px;width:420px;max-width:94vw;padding:50px 44px 44px;position:relative;box-shadow:0 50px 100px #00000073,0 0 0 1px #ffffff0d}.login-logo{text-align:center;margin-bottom:38px}.login-logo-mark{background:linear-gradient(135deg, var(--primary), #60a5fa);color:#fff;border-radius:16px;justify-content:center;align-items:center;width:54px;height:54px;margin:0 auto 18px;font-size:24px;font-weight:800;display:flex;box-shadow:0 10px 30px #2563eb61}.login-logo h1{letter-spacing:-.8px;color:var(--text);font-size:27px;font-weight:800}.login-logo h1 span{color:var(--primary)}.login-logo p{color:var(--text-muted);margin-top:6px;font-size:14px}.empty-cta{background:var(--surface);border:1px solid var(--border);text-align:center;box-shadow:var(--shadow-xs);border-radius:14px;padding:40px 28px}.empty-cta p{color:var(--text-muted);margin-bottom:18px;font-size:14px}.commodity-tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:22px;display:flex}.commodity-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-family:inherit;font-size:13.5px;font-weight:600;transition:color .14s,border-color .14s}.commodity-tab:hover{color:var(--text)}.commodity-tab-active{color:var(--primary);border-bottom-color:var(--primary)}.tab-count{color:var(--text-muted);background:#e6ecf5;border-radius:20px;justify-content:center;align-items:center;margin-left:6px;padding:1px 7px;font-size:11px;font-weight:700;display:inline-flex}.commodity-tab-active .tab-count{color:var(--primary);background:#dbeafe}.badge-ing-active{color:#1e40af;background:#dbeafe}.badge-ing-inactive{color:#475569;background:#f0f4f8}tbody tr.row-clickable{cursor:pointer}tbody tr.row-clickable:hover td{background:#f0f6ff}.detail-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.detail-full{grid-column:1/-1}.detail-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:4px;font-size:11px;font-weight:700}.detail-meta{color:var(--text-muted);gap:16px;margin:8px 0 0;font-size:13px;display:flex}.detail-meta span:before{content:"·";margin-right:16px}.detail-meta span:first-child:before{content:"";margin-right:0}.timeline{align-items:flex-start;display:flex}.timeline-step{flex-direction:column;flex:1;align-items:center;display:flex;position:relative}.timeline-dot{border:2px solid var(--border);z-index:1;background:#fff;border-radius:50%;flex-shrink:0;width:14px;height:14px}.timeline-line{background:var(--border);z-index:0;width:100%;height:2px;position:absolute;top:7px;left:50%}.timeline-label{color:var(--text-muted);text-align:center;margin-top:8px;font-size:12px;font-weight:500}.timeline-done .timeline-dot{background:var(--success);border-color:var(--success)}.timeline-done .timeline-line{background:var(--success)}.timeline-done .timeline-label{color:var(--success);font-weight:600}.timeline-cancelled{justify-content:center;padding:8px 0;display:flex}.badge-formula-active{color:#065f46;background:#d1fae5}.badge-formula-coming_soon{color:#92400e;background:#fef3c7}.badge-formula-discontinued{color:#64748b;background:#f0f4f8}.cat-filter{flex-wrap:wrap;gap:8px;margin-bottom:22px;display:flex}.cat-pill{border:1.5px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;border-radius:20px;padding:5px 16px;font-family:inherit;font-size:12.5px;font-weight:600;transition:all .14s}.cat-pill:hover{border-color:var(--primary);color:var(--primary)}.cat-pill-active{background:var(--primary);border-color:var(--primary);color:#fff}.formula-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.formula-card{background:var(--surface);border:1.5px solid var(--border);cursor:pointer;border-radius:14px;padding:22px;transition:box-shadow .18s,border-color .18s,transform .18s}.formula-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 8px 28px #0000001a}.formula-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.formula-category{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-size:10.5px;font-weight:700}.formula-name{letter-spacing:-.2px;margin-bottom:2px;font-size:15px;font-weight:700}.formula-sku{color:var(--text-muted);margin-bottom:10px;font-family:monospace;font-size:11px}.formula-desc{color:var(--text-muted);margin-bottom:10px;font-size:12.5px;line-height:1.55}.formula-serving{color:var(--text-muted);border-top:1px solid var(--border);margin-bottom:14px;padding-top:10px;font-size:12px}.formula-price{align-items:baseline;gap:8px;display:flex}.formula-price-label{color:var(--text-muted);font-size:11px}.formula-price-value{color:var(--text);font-size:18px;font-weight:700}.formula-price-retail{color:var(--text-muted);font-size:12px;text-decoration:line-through}.ingredient-list{flex-direction:column;gap:4px;list-style:none;display:flex}.ingredient-list li{background:var(--surface-2);border-left:3px solid var(--primary);border-radius:7px;padding:7px 12px;font-size:13px}.formula-price-detail{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;gap:28px;margin-bottom:8px;padding:16px 20px;display:flex}.formula-price-big{margin-top:4px;font-size:22px;font-weight:700}.modal-lg{width:620px;max-height:90vh;overflow-y:auto}.form-row-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-row-3{grid-template-columns:1fr 1fr 1fr;gap:12px;display:grid}.textarea{border:1.5px solid var(--border);width:100%;color:var(--text);resize:vertical;background:#fff;border-radius:8px;outline:none;padding:9px 12px;font-family:inherit;font-size:13.5px;transition:border-color .15s,box-shadow .15s}.textarea:hover:not(:focus){border-color:var(--border-strong)}.textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.label-hint{color:var(--text-muted);font-size:11px;font-weight:400}.assign-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:8px;font-size:10.5px;font-weight:700}.assign-chips{background:var(--surface-2);border:1.5px solid var(--border);border-radius:8px;flex-wrap:wrap;gap:6px;min-height:40px;margin-bottom:6px;padding:8px 10px;display:flex}.assign-chip{background:var(--primary);color:#fff;border-radius:20px;align-items:center;gap:5px;padding:3px 10px 3px 12px;font-size:12.5px;font-weight:500;display:inline-flex}.assign-chip-remove{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:14px;line-height:1;transition:background .12s;display:inline-flex}.assign-chip-remove:hover{background:#fff6}.assign-results{border:1.5px solid var(--border);border-radius:8px;max-height:220px;margin-bottom:6px;overflow-y:auto}.assign-result-row{border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;background:0 0;justify-content:space-between;align-items:center;width:100%;padding:10px 14px;font-family:inherit;font-size:13.5px;transition:background .12s;display:flex}.assign-result-row:last-child{border-bottom:none}.assign-result-row:hover{background:#f0f6ff}.assign-add-badge{color:var(--primary);background:var(--primary-light);white-space:nowrap;border-radius:20px;flex-shrink:0;padding:2px 10px;font-size:11.5px;font-weight:600}.version-badge{color:#93c5fd;background:#1e3a5f;border-radius:4px;padding:2px 7px;font-family:SF Mono,Menlo,monospace;font-size:11px;font-weight:700;display:inline-block}.modal-xl{width:800px;max-height:90vh;overflow-y:auto}.version-layout{grid-template-columns:200px 1fr;gap:16px;min-height:320px;display:grid}.version-list{flex-direction:column;gap:6px;display:flex}.version-list-item{text-align:left;border:1.5px solid var(--border);background:var(--surface);cursor:pointer;border-radius:9px;width:100%;padding:10px 12px;font-family:inherit;transition:all .12s}.version-list-item:hover{background:var(--surface-2);border-color:var(--primary)}.version-list-item-active{background:var(--primary-light);border-color:var(--primary)}.version-detail{border:1.5px solid var(--border);border-radius:10px;padding:16px 20px}.version-detail-title{margin-bottom:14px;font-size:13px;font-weight:600}.version-editor-header{margin-bottom:4px}.ing-editor{border:1.5px solid var(--border);border-radius:8px;overflow:hidden}.ing-editor-head{background:var(--surface-2);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:8px 12px;font-size:10.5px;font-weight:700;display:flex}.ing-row{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:7px 12px;display:flex}.ing-row:last-of-type{border-bottom:none}.ing-cell{border:1.5px solid var(--border);color:var(--text);background:#fff;border-radius:6px;outline:none;padding:5px 8px;font-family:inherit;font-size:13px;transition:border-color .12s}.ing-cell:focus{border-color:var(--primary)}.ing-remove{border:1px solid var(--border);width:26px;height:26px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;font-family:inherit;font-size:16px;line-height:1;transition:all .12s;display:flex}.ing-remove:hover:not(:disabled){background:var(--danger-bg);color:var(--danger);border-color:#fca5a5}.ing-remove:disabled{opacity:.3;cursor:not-allowed}.ing-editor>.btn{margin:10px 12px}.ing-table{flex-direction:column;gap:4px;display:flex}.ing-table-section{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:4px;font-size:10.5px;font-weight:700}.ing-table-row{background:var(--surface-2);border-radius:6px;align-items:center;gap:10px;padding:6px 10px;display:flex}.ing-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.ing-dot-active{background:var(--primary)}.ing-dot-inactive{background:#cbd5e1}.ing-table-name{flex:1;font-size:13px}.ing-table-amount{color:var(--text-muted);white-space:nowrap;font-size:12.5px;font-weight:600}
