:root{color:#18212f;background:#f5f7fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}button,input,select{font:inherit}button{color:#fff;cursor:pointer;background:#174ea6;border:0;border-radius:8px;padding:.6rem 1rem;font-size:.875rem;font-weight:600}button:hover{background:#1a5fc4}button:disabled{cursor:not-allowed;opacity:.45}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{color:#fff;z-index:100;background:#174ea6;align-items:center;gap:1rem;padding:.75rem 1.5rem;display:flex;position:sticky;top:0}.app-header h1{white-space:nowrap;margin:0;font-size:1.25rem}.nav-tabs{flex:1;gap:.25rem;display:flex}.nav-tabs button{background:0 0;border-radius:6px;padding:.5rem 1rem;font-weight:500}.nav-tabs button:hover{background:#ffffff1a}.nav-tabs button.active{background:#fff3;font-weight:700}.header-actions{align-items:center;gap:.5rem;margin-left:auto;display:flex}.lang-select{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff4d;border-radius:6px;padding:.4rem .6rem;font-size:.875rem}.lang-select option{color:#fff;background:#174ea6}.logout-btn{background:#ffffff26}.login-screen{max-width:400px;margin:4rem auto;padding:2rem;position:relative}.login-lang{position:absolute;top:1rem;right:1rem}.login-lang select{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:.4rem .6rem;font-size:.875rem;box-shadow:0 1px 2px #0000000d}.login-screen .hero{text-align:center;margin-bottom:1.5rem}.panel{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin:1rem;padding:1.25rem}.panel-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.panel-header h2{margin:0;font-size:1.25rem}.actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.actions input{max-width:200px}.form-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin-bottom:1rem;display:grid}.form-wide{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}label{color:#40506a;gap:.25rem;font-size:.8rem;font-weight:600;display:grid}.checkbox{flex-direction:row;align-items:center;gap:.5rem;display:flex}input,select{border:1px solid #cbd5e1;border-radius:6px;padding:.5rem .75rem;font-size:.9rem}input:focus,select:focus{border-color:#174ea6;outline:none;box-shadow:0 0 0 3px #174ea61a}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.875rem}th,td{text-align:left;border-bottom:1px solid #e2e8f0;padding:.65rem .75rem}th{color:#64748b;text-transform:uppercase;letter-spacing:.05em;background:#f8fafc;font-size:.75rem;font-weight:600}tr:hover{background:#f8fafc}tr.clickable-row{cursor:pointer;transition:background .15s}tr.clickable-row:hover{background:#eef2ff}tr.clickable-row:active{background:#e0e7ff}td.actions{white-space:nowrap}td.actions button{margin-right:.25rem;padding:.35rem .6rem;font-size:.75rem}.status-badge{text-transform:uppercase;border-radius:4px;padding:.25rem .5rem;font-size:.7rem;font-weight:600;display:inline-block}.status-pending{color:#92400e;background:#fef3c7}.status-confirmed{color:#1e40af;background:#dbeafe}.status-packing{color:#9d174d;background:#fce7f3}.status-packed{color:#065f46;background:#d1fae5}.status-delivered{color:#0e7490;background:#cffafe}.status-cancelled{color:#991b1b;background:#fee2e2}.status-invoiced{color:#3730a3;background:#e0e7ff}.order-form{background:#f8fafc;border-radius:8px;margin-bottom:1rem;padding:1rem}.order-items{grid-column:1/-1}.order-items h4{align-items:center;gap:.5rem;margin:0 0 .5rem;display:flex}.order-items h4 button{padding:.25rem .5rem;font-size:.75rem}.order-item-row{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.order-item-row select{flex:2}.order-item-row input{flex:1;min-width:80px}.order-item-row button{background:#dc2626;padding:.35rem .5rem}.packing-items{gap:.75rem;display:grid}.packing-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem;display:flex}.packing-item.packed{background:#d1fae5;border-color:#a7f3d0}.packing-item-info{flex-direction:column;gap:.25rem;display:flex}.packing-item-info strong{font-size:.95rem}.packing-item-info span{color:#64748b;font-size:.8rem}.packing-item-inputs{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.packing-item-inputs input{width:110px}.packing-item-inputs select{min-width:220px}.packing-item-inputs button{padding:.4rem .75rem}.packing-item-lot-meta{color:#475569;gap:1rem;width:100%;font-size:.8rem;display:flex}.packing-item-lot-meta.warning{color:#b45309}.packed-badge{color:#fff;background:#065f46;border-radius:4px;padding:.3rem .6rem;font-size:.7rem;font-weight:600}.message{background:#e8f1ff;border:1px solid #bfdbfe;border-radius:8px;margin:0 1rem 1rem;padding:.75rem 1rem;font-size:.875rem}.welcome-screen{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.welcome-screen .hero{max-width:600px}.logo-placeholder{margin-bottom:1rem;font-size:4rem;display:inline-block}.welcome-message{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin:2rem 0;padding:2rem;box-shadow:0 4px 6px -1px #0000001a}.welcome-message p{color:#1e293b;margin-bottom:1rem;font-size:1.1rem;line-height:1.6}.role-management-grid{grid-template-columns:300px 1fr;gap:1.5rem;min-height:500px;display:grid}.roles-sidebar{border-right:1px solid #e2e8f0;flex-direction:column;gap:1rem;padding-right:1rem;display:flex}.roles-list-nav{flex:1;overflow-y:auto}.role-nav-item{text-align:left;color:#1e293b;background:0 0;width:100%;margin-bottom:.25rem;padding:.75rem 1rem}.role-nav-item:hover{background:#f1f5f9}.role-nav-item.active{color:#1e40af;background:#dbeafe}.role-permissions-panel{flex-direction:column;gap:1.5rem;display:flex}.permission-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;display:grid}.permission-item{cursor:pointer;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:.75rem;padding:.75rem;font-size:.875rem;transition:all .2s;display:flex}.permission-item:hover{background:#f8fafc;border-color:#cbd5e1}.permission-item input{margin:0}.new-role-form{border-top:1px solid #e2e8f0;flex-direction:column;gap:.75rem;padding-top:1rem;display:flex}.hero{text-align:center;padding:2rem}.hero h1{margin:0 0 .5rem;font-size:2rem}.hero p{color:#64748b;margin:0}.pricing-actions{gap:.75rem}.pricing-actions input,.customer-select{min-width:200px}.pricing-info{background:#dbeafe;border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.pricing-table .rbr{color:#64748b;font-family:monospace}.pricing-table .price-cell{white-space:nowrap}.price-input{text-align:right;width:100px;font-weight:600}.price-input.override{background:#fef3c7;border-color:#fbbf24}.price-status{white-space:nowrap}.reset-btn{color:#dc2626;background:#fee2e2;padding:.25rem .5rem;font-size:.7rem}.reset-btn:hover{background:#fecaca}.base-label{color:#64748b;font-size:.75rem}.category-badge{text-transform:uppercase;border-radius:4px;padding:.2rem .4rem;font-size:.65rem;font-weight:600;display:inline-block}.category-badge.fresh{color:#dc2626;background:#fee2e2}.category-badge.processed{color:#1e40af;background:#dbeafe}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:12px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-header{z-index:10;background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex;position:sticky;top:0}.modal-header h2{margin:0;font-size:1.25rem}.modal-actions{gap:.5rem;display:flex}.close-btn{color:#64748b;background:0 0;padding:.25rem .5rem;font-size:1.5rem;line-height:1}.close-btn:hover{color:#1e293b;background:#f1f5f9}.modal-body{padding:1.5rem}.modal-footer{border-top:1px solid #e2e8f0;justify-content:flex-end;gap:.5rem;padding:1rem 1.5rem;display:flex}.summary-info{background:#f8fafc;border-radius:8px;margin-bottom:1rem;padding:1rem}.summary-info p{margin:.25rem 0;font-size:.875rem}.summary-table{margin-bottom:1rem}.summary-table td.negative{color:#dc2626;font-weight:600}.summary-table td.positive{color:#059669;font-weight:600}.totals-section{background:#f0fdf4;border-radius:8px;padding:1rem}.totals-section p{margin:.25rem 0;font-size:.875rem}.otpremnica-modal{max-width:900px}.otpremnica-content{padding:2rem}.otpremnica-header{border-bottom:2px solid #1e293b;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem;display:flex}.company-info h3{margin:0 0 .5rem;font-size:1.25rem}.company-info p{color:#64748b;margin:.15rem 0;font-size:.875rem}.document-info{text-align:right}.document-info h2{text-transform:uppercase;margin:0 0 .5rem;font-size:1.5rem}.document-info p{margin:.15rem 0;font-size:.875rem}.customer-section{background:#f8fafc;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.customer-section h4{color:#64748b;text-transform:uppercase;margin:0 0 .5rem;font-size:.75rem}.customer-section p{margin:.15rem 0}.otpremnica-table{margin-bottom:1.5rem}.otpremnica-table th{color:#fff;background:#1e293b}.totals-grid{flex-direction:column;align-items:flex-end;margin-bottom:2rem;display:flex}.total-row{border-bottom:1px solid #e2e8f0;justify-content:space-between;width:300px;padding:.5rem 0;font-size:.875rem;display:flex}.total-row.total-final{border-bottom:2px solid #1e293b;font-size:1rem;font-weight:700}.signatures{grid-template-columns:1fr 1fr;gap:4rem;margin-top:3rem;display:grid}.signature-box p{color:#64748b;margin:0 0 .5rem;font-size:.875rem}.signature-line{border-bottom:1px solid #1e293b;height:40px}.signed-by{font-style:italic;margin-top:.5rem!important}.statistics-panel{min-height:80vh}.stats-overview{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.charts-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;display:grid}.chart-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem}.chart-card h3{color:#334155;margin:0 0 1rem;font-size:.95rem}.chart-card.full-width{grid-column:1/-1}.no-data{color:#94a3b8;justify-content:center;align-items:center;height:200px;font-style:italic;display:flex}.loading{color:#64748b;justify-content:center;align-items:center;height:200px;display:flex}.daily-summary-modal{max-width:1000px}.daily-summary-content{padding:2rem}.daily-summary-header{text-align:center;border-bottom:2px solid #1e293b;margin-bottom:2rem;padding-bottom:1rem}.daily-summary-header h2{margin:0 0 .5rem}.summary-date{color:#64748b;font-size:1.25rem;font-weight:600}.summary-stats{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.stat-card{text-align:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:.25rem;padding:1.25rem;display:flex}.stat-value{color:#174ea6;font-size:1.75rem;font-weight:700}.stat-label{text-transform:uppercase;color:#64748b;font-size:.75rem;font-weight:600}.daily-summary-content h3{border-bottom:1px solid #e2e8f0;margin:1.5rem 0 .75rem;padding-bottom:.5rem}.orders-table{margin-top:.5rem}table tfoot tr{background:#f8fafc;font-weight:600}@media print{.no-print{display:none!important}.modal-overlay{background:0 0;padding:0;position:static}.modal{box-shadow:none;border-radius:0;max-height:none}.otpremnica-content{padding:0}body{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.customer-login-screen{background:linear-gradient(135deg,#1e293b 0%,#334155 50%,#1e293b 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.customer-hero{text-align:center;color:#fff;margin-bottom:2rem}.logo-icon{animation:2s infinite bounce;display:inline-block}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.customer-hero h1{margin-bottom:.5rem;font-size:2.5rem;font-weight:700}.customer-hero p{opacity:.8;font-size:1.1rem}.customer-login-panel{background:#fff;border-radius:1.25rem;width:100%;max-width:400px;padding:2.5rem;box-shadow:0 25px 50px #00000040}.customer-login-form{flex-direction:column;gap:1.25rem;display:flex}.customer-login-form label{color:#475569;flex-direction:column;gap:.5rem;font-weight:500;display:flex}.customer-login-form input{border:2px solid #e2e8f0;border-radius:.75rem;padding:.875rem 1rem;font-size:1rem;transition:border-color .2s,box-shadow .2s}.customer-login-btn{color:#fff;cursor:pointer;background:#1e293b;border:none;border-radius:.75rem;padding:1rem;font-size:1.05rem;font-weight:600;transition:transform .2s,box-shadow .2s}.customer-login-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #1e293b4d}.customer-login-btn:disabled{opacity:.7;cursor:not-allowed}.portal-app{background:#f1f5f9;min-height:100vh}.portal-header{color:#fff;z-index:100;background:#1e293b;justify-content:space-between;align-items:center;padding:.875rem 1.5rem;display:flex;position:sticky;top:0}.portal-header-left{align-items:center;gap:1.25rem;display:flex}.portal-header-right{align-items:center;gap:.625rem;display:flex}.portal-brand{align-items:center;gap:.5rem;display:flex}.portal-brand-icon{color:#fff;background:#3b82f6;border-radius:.5rem;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:1rem;font-weight:800;display:flex}.portal-brand-name{letter-spacing:.5px;font-size:1.125rem;font-weight:700}.portal-user-badge{background:#ffffff1a;border-radius:2rem;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.8125rem;display:flex}.portal-user-icon{color:#4ade80;font-size:.5rem}.portal-refresh-btn{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #ffffff26;border-radius:.5rem;justify-content:center;align-items:center;width:2.25rem;height:2.25rem;padding:0;font-size:1.125rem;transition:background .2s;display:flex}.portal-refresh-btn:hover{background:#fff3}.portal-refresh-btn .spin{animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.portal-lang-select{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff4d;border-radius:.375rem;padding:.4rem .625rem;font-size:.8125rem;font-weight:600}.portal-logout-btn{color:#fca5a5;cursor:pointer;background:#ef444426;border:1px solid #ef444466;border-radius:.375rem;padding:.4rem .875rem;font-size:.8125rem;font-weight:500;transition:all .2s}.portal-header-cart{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff4d;border-radius:.5rem;justify-content:center;align-items:center;width:2.25rem;height:2.25rem;font-size:1.125rem;display:flex;position:relative}.portal-header-cart:hover{background:#ffffff40}.portal-header-cart-badge{color:#fff;background:#ef4444;border:2px solid #1e293b;border-radius:999px;justify-content:center;align-items:center;min-width:1.125rem;height:1.125rem;font-size:.625rem;font-weight:700;display:flex;position:absolute;top:-.375rem;right:-.375rem}.portal-nav{background:#fff;border-bottom:1px solid #e2e8f0;gap:0;padding:0 1.5rem;display:flex}.portal-nav-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:0;align-items:center;gap:.5rem;padding:.875rem 1.25rem;font-size:.9375rem;font-weight:500;transition:all .2s;display:flex;position:relative}.portal-nav-btn:hover{color:#1e293b;background:#f8fafc}.portal-nav-btn.active{color:#1e293b;border-bottom-color:#3b82f6;font-weight:600}.portal-nav-icon{font-size:1rem}.portal-nav-badge{color:#fff;background:#ef4444;border-radius:1rem;justify-content:center;align-items:center;min-width:1.25rem;height:1.25rem;padding:0 .375rem;font-size:.6875rem;font-weight:700;display:flex}.portal-toast{z-index:2000;cursor:pointer;border-radius:.75rem;align-items:center;gap:.625rem;padding:.75rem 1.25rem;font-size:.875rem;font-weight:500;animation:.3s ease-out toastIn;display:flex;position:fixed;top:1rem;left:50%;transform:translate(-50%);box-shadow:0 10px 25px #00000026}.portal-toast-success{color:#fff;background:#065f46}.portal-toast-error{color:#fff;background:#991b1b}.portal-toast-info{color:#fff;background:#1e40af}.portal-toast-icon{font-weight:700}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(-1rem)}to{opacity:1;transform:translate(-50%)translateY(0)}}.portal-toolbar{flex-direction:column;gap:.75rem;padding:1rem 0;display:flex}.portal-search-wrap{align-items:center;display:flex;position:relative}.portal-search-icon{color:#94a3b8;pointer-events:none;font-size:1.125rem;position:absolute;left:.875rem}.portal-search-input{background:#fff;border:1px solid #e2e8f0;border-radius:.625rem;width:100%;padding:.75rem 2.5rem;font-size:.9375rem;transition:border-color .2s,box-shadow .2s}.portal-search-input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f614}.portal-search-clear{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:50%;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;padding:0;font-size:.875rem;display:flex;position:absolute;right:.5rem}.portal-category-filter{flex-wrap:wrap;gap:.375rem;display:flex}.portal-cat-btn{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:2rem;padding:.375rem .875rem;font-size:.8125rem;font-weight:500;transition:all .2s}.portal-cat-btn:hover{color:#1e293b;border-color:#cbd5e1}.portal-cat-btn.active{color:#fff;background:#1e293b;border-color:#1e293b}.portal-order-section{padding:0 1.5rem 6rem}.portal-product-card{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;flex-direction:column;gap:.625rem;padding:1rem;transition:all .2s;display:flex}.portal-product-card:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000f}.portal-product-top{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.portal-product-name{color:#1e293b;font-size:.9375rem;font-weight:600}.portal-product-cat{text-transform:uppercase;white-space:nowrap;border-radius:.25rem;padding:.2rem .5rem;font-size:.625rem;font-weight:600}.portal-product-price{color:#1e293b;font-size:1.125rem;font-weight:700}.portal-price-unit{color:#64748b;font-size:.8125rem;font-weight:400}.portal-product-bottom{align-items:center;gap:.5rem;display:flex}.portal-qty-wrap{border:1px solid #e2e8f0;border-radius:.5rem;align-items:center;display:flex;overflow:hidden}.portal-qty-btn{color:#475569;cursor:pointer;background:#f8fafc;border:none;border-radius:0;justify-content:center;align-items:center;width:2rem;height:2rem;padding:0;font-size:1rem;font-weight:600;transition:background .15s;display:flex}.portal-qty-input{text-align:center;-moz-appearance:textfield;border:none;border-left:1px solid #e2e8f0;border-right:1px solid #e2e8f0;border-radius:0;width:3.5rem;height:2rem;padding:0;font-size:.875rem;font-weight:600}.portal-qty-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.portal-qty-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.portal-qty-input:focus{background:#f0f9ff;outline:none}.portal-product-unit{color:#94a3b8;font-size:.8125rem}.portal-item-note{color:#475569;background:#fafafa;border:1px solid #e2e8f0;border-radius:.375rem;width:100%;padding:.5rem .625rem;font-size:.8125rem}.portal-item-note:focus{background:#fff;border-color:#3b82f6;outline:none}.portal-cart-bar{z-index:50;background:#fff;border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:.875rem 1.5rem;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 12px #00000014}.portal-cart-info{align-items:center;gap:1rem;display:flex}.portal-cart-count{color:#64748b;font-size:.875rem}.portal-cart-total{color:#1e293b;font-size:1.125rem;font-weight:700}.portal-cart-actions{gap:.5rem;display:flex}.portal-cart-clear{color:#64748b;cursor:pointer;background:0 0;border:1px solid #e2e8f0;border-radius:.375rem;padding:.5rem .875rem;font-size:.8125rem}.portal-cart-clear:hover{color:#1e293b;background:#f1f5f9}.portal-cart-checkout{color:#fff;cursor:pointer;background:#1e293b;border-radius:.375rem;padding:.5rem 1.25rem;font-size:.875rem;font-weight:600;transition:background .2s}.portal-cart-checkout:hover{background:#334155}.portal-history-section{padding:1rem 1.5rem}.portal-history-toolbar{gap:.75rem;margin-bottom:1rem;display:flex}.portal-status-filter{color:#1e293b;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;min-width:180px;padding:.5rem .875rem;font-size:.875rem}.portal-empty-state{text-align:center;color:#94a3b8;padding:4rem 2rem}.portal-empty-icon{margin-bottom:1rem;font-size:3rem;display:block}.portal-orders-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:.75rem;display:grid}.portal-order-card{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;flex-direction:column;gap:.75rem;padding:1.125rem;transition:all .2s;display:flex}.portal-order-card:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000f}.portal-order-card.cancelled{opacity:.55}.portal-order-top{justify-content:space-between;align-items:center;display:flex}.portal-order-num{color:#1e293b;font-size:1.0625rem;font-weight:700}.portal-order-meta{color:#64748b;flex-direction:column;gap:.25rem;font-size:.8125rem;display:flex}.portal-order-meta strong{color:#1e293b;font-weight:600}.portal-order-items{color:#475569;margin-top:.25rem;font-weight:500}.portal-order-detail-btn{color:#475569;cursor:pointer;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.375rem;padding:.375rem .75rem;font-size:.8125rem;font-weight:500}.portal-order-detail-btn:hover{color:#1e293b;background:#e2e8f0}.portal-order-cancel-btn{color:#dc2626;cursor:pointer;background:#fef2f2;border:1px solid #fecaca;border-radius:.375rem;padding:.375rem .75rem;font-size:.8125rem;font-weight:500}.portal-order-cancel-btn:hover{background:#fee2e2}.portal-order-reorder-btn{color:#16a34a;cursor:pointer;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:.375rem;padding:.375rem .75rem;font-size:.8125rem;font-weight:500}.portal-order-reorder-btn:hover{background:#dcfce7}.portal-cancel-modal{border-radius:1rem;max-width:440px;overflow:hidden}.portal-cancel-header{text-align:center;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 2rem 1rem;display:flex}.portal-cancel-icon{font-size:2.5rem}.portal-cancel-header h2{margin:0;font-size:1.25rem}.portal-cancel-body{text-align:center;padding:0 2rem 1.5rem}.portal-cancel-order-ref{color:#1e293b;margin-bottom:.75rem;font-size:1rem;font-weight:600}.portal-cancel-warning{color:#64748b;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;padding:1rem;font-size:.9375rem;line-height:1.5}.portal-cancel-footer{justify-content:center;gap:.75rem;padding:1rem 2rem 1.5rem;display:flex}.portal-cancel-keep{color:#475569;cursor:pointer;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.5rem;padding:.625rem 1.25rem;font-weight:600}.portal-cancel-keep:hover{background:#e2e8f0}.portal-cancel-confirm{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:.5rem;padding:.625rem 1.25rem;font-weight:600}.portal-cancel-confirm:hover{background:#b91c1c}.portal-detail-modal{max-width:700px}.portal-checkout-modal{max-width:520px}.portal-checkout-row{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:.625rem 0;font-size:.9375rem;display:flex}.portal-checkout-row:last-child{border-bottom:none}.portal-checkout-name{flex:1;font-weight:500}.portal-checkout-qty{color:#64748b;margin:0 .75rem}.portal-checkout-price{font-weight:600}.portal-checkout-total{border-top:2px solid #1e293b;justify-content:space-between;padding:1rem 0;font-size:1.125rem;font-weight:700;display:flex}.portal-submit-btn{color:#fff;cursor:pointer;background:#1e293b;border-radius:.5rem;padding:.625rem 1.5rem;font-weight:600;transition:background .2s}.portal-submit-btn:hover{background:#334155}.portal-add-btn{color:#fff;cursor:pointer;background:#1e293b;border:none;border-radius:.5rem;width:100%;padding:.5rem 1rem;font-size:.8125rem;font-weight:600;transition:all .2s}.portal-add-btn:hover{background:#334155;transform:translateY(-1px)}.portal-add-btn:active{transform:translateY(0)}.portal-cart-section{padding:1rem 1.5rem 6rem}.portal-cart-items{flex-direction:column;gap:.5rem;display:flex}.portal-cart-row{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;flex-direction:column;gap:.5rem;padding:1rem 1.25rem;display:flex}.portal-cart-row-info{justify-content:space-between;align-items:baseline;display:flex}.portal-cart-row-name{color:#1e293b;font-size:.9375rem;font-weight:600}.portal-cart-row-price{color:#64748b;font-size:.8125rem}.portal-cart-row-controls{align-items:center;gap:.75rem;display:flex}.portal-cart-row-total{color:#1e293b;text-align:right;min-width:80px;font-size:1rem;font-weight:700}.portal-cart-remove{color:#dc2626;cursor:pointer;background:0 0;border:1px solid #fecaca;border-radius:.375rem;flex-shrink:0;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:1.125rem;display:flex}.portal-cart-remove:hover{background:#fef2f2}.portal-cart-footer{z-index:50;background:#fff;border-top:1px solid #e2e8f0;padding:1rem 1.5rem;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 16px #0000001a}.portal-cart-footer-total{color:#1e293b;justify-content:space-between;margin-bottom:.75rem;font-size:1.125rem;font-weight:700;display:flex}.portal-cart-footer-actions{justify-content:flex-end;gap:.5rem;display:flex}.portal-checkout-section{max-width:640px;margin:0 auto;padding:1.5rem}.portal-section-title{color:#1e293b;margin-bottom:1.25rem;font-size:1.375rem;font-weight:700}.portal-checkout-items{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;margin-bottom:.5rem;padding:0 1rem}.portal-checkout-form{flex-direction:column;gap:1rem;margin-top:1.5rem;display:flex}.portal-checkout-form label{color:#475569;flex-direction:column;gap:.375rem;font-size:.875rem;font-weight:600;display:flex}.portal-checkout-form input,.portal-checkout-form select,.portal-checkout-form textarea{color:#1e293b;border:1px solid #e2e8f0;border-radius:.5rem;padding:.625rem .875rem;font-size:.9375rem}.portal-checkout-form input:focus,.portal-checkout-form select:focus,.portal-checkout-form textarea:focus{border-color:#3b82f6;outline:none}.portal-checkout-actions{border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;margin-top:1.5rem;padding-top:1.25rem;display:flex}.portal-confirmed-section{justify-content:center;padding:3rem 1.5rem;display:flex}.portal-confirmed-box{text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:1rem;max-width:480px;padding:3rem 2rem}.portal-confirmed-icon{color:#16a34a;background:#dcfce7;border-radius:50%;justify-content:center;align-items:center;width:4rem;height:4rem;margin-bottom:1.25rem;font-size:1.75rem;font-weight:700;display:inline-flex}.portal-confirmed-box h2{color:#1e293b;margin-bottom:.5rem;font-size:1.5rem}.portal-confirmed-box p{color:#64748b;margin-bottom:.5rem;font-size:.9375rem}.portal-confirmed-number{color:#1e293b;margin-top:1rem;font-size:1.125rem}.portal-confirmed-actions{justify-content:center;gap:.75rem;margin-top:1.5rem;display:flex}.portal-empty-hint{color:#94a3b8;margin-bottom:1rem;font-size:.875rem}.portal-nav-badge-info{background:#3b82f6}.portal-order-change-btn{color:#2563eb;cursor:pointer;background:#eff6ff;border:1px solid #bfdbfe;border-radius:.375rem;padding:.375rem .75rem;font-size:.8125rem;font-weight:500}.portal-order-change-btn:hover{background:#dbeafe}.portal-edit-modal{max-width:640px;max-height:90vh;overflow-y:auto}.portal-edit-status{margin-bottom:1rem}.portal-edit-items{flex-direction:column;gap:.5rem;margin-bottom:.5rem;display:flex}.portal-edit-row{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;flex-direction:column;gap:.375rem;padding:.75rem 1rem;display:flex}.portal-edit-row-info{justify-content:space-between;align-items:baseline;display:flex}.portal-edit-row-name{color:#1e293b;font-size:.9375rem;font-weight:600}.portal-edit-row-price{color:#64748b;font-size:.8125rem}.portal-edit-row-controls{align-items:center;gap:.75rem;display:flex}.portal-edit-row-total{color:#1e293b;text-align:right;min-width:80px;font-size:.9375rem;font-weight:700}.portal-edit-total{color:#1e293b;border-top:2px solid #1e293b;justify-content:space-between;margin-bottom:1.5rem;padding:.75rem 0;font-size:1.125rem;font-weight:700;display:flex}.portal-edit-add-section{border-top:1px solid #e2e8f0;padding-top:1rem}.portal-edit-add-section h3{margin-bottom:.75rem}.portal-edit-add-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem;max-height:400px;margin-top:.75rem;display:grid;overflow-y:auto}.portal-edit-add-item{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;flex-direction:column;gap:.375rem;padding:.75rem;display:flex}.portal-edit-add-name{color:#1e293b;font-size:.8125rem;font-weight:500}.portal-edit-add-price{color:#64748b;font-size:.75rem}.portal-edit-add-item .portal-add-btn{padding:.375rem .5rem;font-size:.75rem}.order-alert{border-radius:.5rem;justify-content:space-between;align-items:center;margin:.75rem 0;padding:.75rem 1rem;font-size:.9375rem;font-weight:600;animation:.4s ease-out alertSlideIn;display:flex}.order-alert button{cursor:pointer;background:0 0;border:none;border-radius:.25rem;padding:.25rem .5rem;font-size:1.25rem;line-height:1}.order-alert-modify{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-left:4px solid #2563eb}.order-alert-modify button{color:#2563eb}.order-alert-modify button:hover{background:#dbeafe}.order-alert-cancel{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-left:4px solid #dc2626}.order-alert-cancel button{color:#dc2626}.order-alert-cancel button:hover{background:#fecaca}@keyframes alertSlideIn{0%{opacity:0;transform:translateY(-.5rem)}to{opacity:1;transform:translateY(0)}}.packing-item-removed{opacity:.4;pointer-events:none;background:#f1f5f9;border-left:4px solid #94a3b8;position:relative}.packing-item-removed .removed-label{color:#dc2626;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:700}.delivery-action-bar{border-top:1px solid #e2e8f0;align-items:flex-end;gap:1rem;margin-top:1rem;padding:1.25rem 1rem;display:flex}.delivery-signed-label{color:#475569;flex-direction:column;flex:1;gap:.375rem;max-width:300px;font-size:.875rem;font-weight:600;display:flex}.delivery-signed-input{border:1px solid #cbd5e1;border-radius:.375rem;padding:.5rem .75rem;font-size:.875rem}.delivery-signed-input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f626}.delivery-confirm-btn{white-space:nowrap;padding:.625rem 1.5rem;font-size:.9375rem}.packing-item-new{background-color:#dbeafe;border-left:4px solid #2563eb;transition:background-color .3s,border-color .3s,opacity .3s;position:relative}.packing-item-new:before{content:"NEW";color:#fff;letter-spacing:.05em;background:#2563eb;border-radius:.25rem;padding:.125rem .375rem;font-size:.625rem;font-weight:700;animation:2s ease-in-out 4 badgePulse;position:absolute;top:.5rem;right:.5rem}@keyframes newItemHighlight{0%{background-color:#0000}25%{background-color:#dbeafe}50%{background-color:#eff6ff}75%{background-color:#dbeafe}to{background-color:#0000}}@keyframes badgePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.packing-item-qty-changed{background-color:#fef3c7;border-left:4px solid #f59e0b;transition:background-color .3s,border-color .3s,opacity .3s;position:relative}.packing-item-qty-changed:before{content:"QTY ▲";color:#fff;letter-spacing:.05em;background:#f59e0b;border-radius:.25rem;padding:.125rem .375rem;font-size:.625rem;font-weight:700;animation:2s ease-in-out 4 badgePulse;position:absolute;top:.5rem;right:.5rem}@keyframes qtyChangedHighlight{0%{background-color:#0000}25%{background-color:#fef3c7}50%{background-color:#fffbeb}75%{background-color:#fef3c7}to{background-color:#0000}}.checkout-items{flex-direction:column;gap:.5rem;max-height:250px;margin-bottom:1rem;display:flex;overflow-y:auto}.checkout-options{flex-direction:column;gap:1rem;margin-top:1rem;display:flex}.checkout-options label{color:#475569;flex-direction:column;gap:.375rem;font-weight:500;display:flex}.checkout-options input,.checkout-options select,.checkout-options textarea{border:1px solid #e2e8f0;border-radius:.5rem;padding:.625rem}.credentials-modal{max-width:450px}.credentials-form{flex-direction:column;gap:1rem;display:flex}.credentials-form label{flex-direction:column;gap:.375rem;font-weight:500;display:flex}.credentials-form input{border:1px solid #e2e8f0;border-radius:.5rem;padding:.625rem;font-size:1rem}.credentials-status{background:#f8fafc;border-radius:.5rem;align-items:center;gap:1rem;margin-bottom:.5rem;padding:.75rem;display:flex}.credentials-status .status-badge{text-transform:uppercase;border-radius:1rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.credentials-status .status-badge.active{color:#166534;background:#dcfce7}.credentials-status .status-badge.disabled{color:#991b1b;background:#fee2e2}.credentials-status .last-login{color:#64748b;font-size:.8125rem}.credentials-form .hint{color:#64748b;font-size:.75rem;font-weight:400}.portal-btn{color:#0369a1;background:#f0f9ff;border:1px solid #bae6fd}.portal-btn:hover{background:#e0f2fe}.enable-btn{color:#166534;background:#dcfce7;border:1px solid #86efac}.disable-btn{color:#92400e;background:#fef3c7;border:1px solid #fcd34d}.delete-btn{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}.save-btn{color:#fff;background:#667eea}.forgot-password-link{color:#667eea;cursor:pointer;background:0 0;border:none;padding:.5rem;font-size:.875rem;text-decoration:underline}.back-link{color:#64748b;cursor:pointer;background:0 0;border:none;padding:.5rem;font-size:.875rem}.reset-sent{text-align:center}.reset-sent p{color:#166534;margin-bottom:1.5rem}.login-links{justify-content:space-between;margin-top:.5rem;display:flex}.request-access-link{color:#667eea;cursor:pointer;background:0 0;border:none;padding:.5rem;font-size:.875rem;text-decoration:underline}.access-request-form{width:100%;max-width:500px}.access-request-form label{text-align:left;margin-bottom:1rem;display:block}.access-request-form input{box-sizing:border-box;width:100%}.form-row{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:0;display:grid}.form-row label{margin-bottom:.5rem}.customer-login-panel{width:100%;max-width:520px}.pending-requests{border-top:1px solid #e2e8f0;margin-top:2rem;padding-top:1.5rem}.pending-requests h3{color:#1e293b;align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.pending-badge{color:#92400e;background:#fef3c7;border-radius:9999px;padding:.25rem .5rem;font-size:.75rem;font-weight:500}.request-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;margin-bottom:1rem;padding:1rem}.request-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;display:flex}.request-company{color:#1e293b;font-size:1rem;font-weight:600}.request-date{color:#64748b;font-size:.75rem}.request-details{color:#475569;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.5rem;margin-bottom:1rem;font-size:.875rem;display:grid}.request-detail{flex-direction:column;display:flex}.request-detail-label{color:#94a3b8;font-size:.75rem}.request-actions{gap:.5rem;display:flex}.approve-btn{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500}.approve-btn:hover{background:#059669}.reject-btn{color:#ef4444;cursor:pointer;background:#fff;border:1px solid #ef4444;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500}.reject-btn:hover{background:#fee2e2}@media (width<=768px){.app-header{flex-wrap:wrap}.nav-tabs{order:3;width:100%;overflow-x:auto}.panel{margin:.5rem;padding:1rem}.modal{border-radius:0;max-height:100vh}.otpremnica-header{flex-direction:column;gap:1rem}.document-info{text-align:left}.signatures{grid-template-columns:1fr;gap:2rem}.portal-product-grid,.portal-orders-grid{grid-template-columns:1fr}.customer-hero h1{font-size:1.75rem}.customer-login-panel{padding:1.5rem}.portal-cart-bar{flex-direction:column;gap:.75rem}.portal-header-left{gap:.75rem}.portal-user-badge{display:none}.portal-toast{left:1rem;right:1rem;transform:none}}.order-detail-modal{width:90%;max-width:700px}.order-info-grid{background:#f8fafc;border-radius:.5rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem;padding:1rem;display:grid}.info-item{flex-direction:column;gap:.25rem;display:flex}.info-label{color:#64748b;text-transform:uppercase;font-size:.75rem}.order-note{background:#fef3c7;border-radius:.5rem;margin-bottom:1.5rem;padding:1rem}.order-items-table{margin-bottom:1rem;overflow-x:auto}.order-items-table table{width:100%}.order-items-table tfoot td{border-top:2px solid #e2e8f0;padding-top:1rem}.order-total{background:#f1f5f9;border-radius:.5rem;justify-content:space-between;padding:1rem;font-size:1.125rem;display:flex}.order-details p{color:#64748b;margin:.25rem 0;font-size:.875rem}.declarations-screen{grid-template-columns:280px 1fr;gap:1rem;height:calc(100vh - 60px);padding:1rem;display:grid}.declarations-sidebar{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;display:flex;overflow:hidden}.declarations-sidebar input{width:calc(100% - 2rem);margin:1rem}.declarations-sidebar .item-list{flex-direction:column;flex:1;display:flex;overflow-y:auto}.item-nav-btn{color:#1e293b;text-align:left;background:0 0;border:0;border-bottom:1px solid #f1f5f9;border-radius:0;padding:.75rem 1rem;transition:all .2s}.item-nav-btn:hover{background:#f8fafc}.item-nav-btn.active{color:#1e40af;background:#e0e7ff;border-left:4px solid #174ea6}.item-nav-content{flex-direction:column;gap:.2rem;display:flex}.item-nav-content .sku{color:#64748b;font-family:monospace;font-size:.75rem;font-weight:700}.item-nav-content .name{font-size:.875rem;font-weight:500}.declaration-main{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;display:flex;overflow-y:auto}.declaration-editor{grid-template-columns:1fr 400px;gap:2rem;min-height:100%;padding:2rem;display:grid}.form-panel h3,.preview-panel h3{color:#1e293b;margin:0 0 1.5rem;font-size:1.25rem}.form-panel .form-grid{margin-bottom:2rem}.form-panel label.full-width{grid-column:1/-1}.form-panel textarea{resize:vertical;border:1px solid #cbd5e1;border-radius:6px;padding:.5rem .75rem;font-family:inherit;font-size:.9rem}.preview-panel{border-left:1px solid #e2e8f0;flex-direction:column;align-items:center;padding-left:2rem;display:flex}.label-preview{color:#000;background:#fff;border:1px solid #000;padding:10px;font-family:Courier New,Courier,monospace;position:relative}.label-90x70{flex-direction:column;width:340px;height:265px;display:flex;box-shadow:0 10px 15px -3px #0000001a}.label-header{border-bottom:1.5px solid #000;justify-content:space-between;align-items:flex-start;margin-bottom:5px;padding-bottom:3px;display:flex}.label-title{text-transform:uppercase;max-width:80%;font-size:14px;font-weight:800}.vet-stamp{text-align:center;border:1.5px solid #000;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:8px;font-weight:800;display:flex}.label-body{flex:1;font-size:9px;line-height:1.2}.label-body p{margin:2px 0}.label-footer{border-top:1px solid #000;justify-content:space-between;align-items:flex-end;padding-top:5px;display:flex}.manufacturer-info{font-size:8px;font-weight:700}.barcode-area{justify-content:flex-end;display:flex}.hint{color:#64748b;text-align:center;margin-top:1rem;font-size:.75rem;font-style:italic}.empty-state{color:#94a3b8;justify-content:center;align-items:center;height:100%;font-style:italic;display:flex}:root{--b2b-bone:#faf6f0;--b2b-paper:#f0e8da;--b2b-paper-deep:#e4d9c3;--b2b-oxblood:#8b2c1f;--b2b-oxblood-deep:#6b1f14;--b2b-char:#2a2421;--b2b-char-soft:#4a4239;--b2b-gold:#c9a055;--b2b-gold-soft:#e4c485;--b2b-pink:#e8c8c0;--b2b-moss:#4a5a3e;--b2b-danger:#8b1d2a;--b2b-shadow:0 24px 60px -24px #2a242159}.customer-login-screen{color:var(--b2b-bone);background:radial-gradient(circle at 8% 8%,#c9a05533,#0000 36%),radial-gradient(circle at 95% 90%,#8b2c1f59,#0000 44%),linear-gradient(155deg,#191412,#2b201b 52%,#3a281d 100%);padding:2.2rem 1.2rem;position:relative}.customer-login-screen:before{content:"";pointer-events:none;opacity:.45;background-image:radial-gradient(#ffffff0f .6px,#0000 .6px);background-size:2px 2px;position:absolute;inset:0}.customer-login-screen .login-lang,.customer-login-screen .customer-hero,.customer-login-screen .customer-login-panel{z-index:2;position:relative}.customer-login-screen .login-lang{justify-content:flex-end;width:min(980px,100%);display:flex}.customer-login-screen .login-lang select{color:var(--b2b-bone);background:#faf6f014;border:1px solid #faf6f052;border-radius:999px;padding:.45rem .9rem}.customer-hero h1{letter-spacing:-.02em;margin-bottom:.25rem;font-family:Cormorant Garamond,Georgia,serif;font-size:clamp(2.6rem,5.8vw,4.6rem);line-height:1.02}.customer-logo{margin-bottom:.6rem;font-size:3rem}.logo-icon{filter:drop-shadow(0 10px 30px #2a242173);animation:none}.customer-hero p{color:#faf6f0d6;font-size:1.04rem}.customer-login-panel{max-width:440px;box-shadow:var(--b2b-shadow);background:#faf6f0f2;border:1px solid #ffffff38;border-radius:8px}.customer-login-form label{color:var(--b2b-char-soft)}.customer-login-form input{background:#fffdf8;border-width:1px;border-color:#d7cdc0;border-radius:6px}.customer-login-form input:focus{border-color:var(--b2b-oxblood);box-shadow:0 0 0 3px #8b2c1f1f}.customer-login-btn{background:var(--b2b-oxblood);text-transform:uppercase;letter-spacing:.08em;border-radius:999px;padding:.95rem 1rem;font-size:.84rem}.customer-login-btn:hover:not(:disabled){background:var(--b2b-oxblood-deep);box-shadow:0 10px 28px -14px #6b1f14d1}.portal-app{background:var(--b2b-bone);min-height:100vh;color:var(--b2b-char)}.portal-header{color:var(--b2b-char);-webkit-backdrop-filter:blur(12px)saturate(180%);backdrop-filter:blur(12px)saturate(180%);background:#faf6f0e0;border-bottom:1px solid #2a242114;padding:.65rem 1.1rem}.portal-brand-icon{background:linear-gradient(135deg, var(--b2b-oxblood), #af4a2f);border-radius:999px;width:2.25rem;height:2.25rem;box-shadow:0 10px 24px -14px #8b2c1fcc}.portal-brand-name{letter-spacing:-.01em;font-family:Cormorant Garamond,Georgia,serif;font-size:clamp(1.25rem,2.4vw,1.85rem)}.portal-user-badge{background:var(--b2b-paper);color:var(--b2b-char-soft);border:1px solid var(--b2b-paper-deep)}.portal-header-cart,.portal-refresh-btn,.portal-lang-select,.portal-logout-btn{border-radius:999px}.portal-header-cart,.portal-refresh-btn{color:var(--b2b-char);background:#fff;border:1px solid #d9cfc1}.portal-header-cart:hover,.portal-refresh-btn:hover{background:var(--b2b-paper)}.portal-header-cart-badge{background:var(--b2b-oxblood);border-color:var(--b2b-bone)}.portal-lang-select{color:var(--b2b-char);background:#fff;border:1px solid #d9cfc1}.portal-lang-select option{color:var(--b2b-char);background:#fff}.portal-logout-btn{color:var(--b2b-danger);background:#fff;border:1px solid #e2b3ad}.portal-logout-btn:hover{color:#74212d;background:#fff4f2}.portal-nav{background:0 0;border-bottom:1px solid #2a242114;gap:.4rem;padding:0 1rem}.portal-nav-btn{color:var(--b2b-char-soft);border-bottom:none;border-radius:999px;margin-top:.32rem;padding:.58rem 1rem}.portal-nav-btn:hover{background:var(--b2b-paper);color:var(--b2b-char)}.portal-nav-btn.active{color:#fff;background:var(--b2b-char)}.portal-nav-badge{background:var(--b2b-oxblood)}.portal-order-section,.portal-cart-section,.portal-checkout-section,.portal-confirmed-section,.portal-history-section{max-width:1240px;margin:0 auto;padding:1.35rem 1rem 5.5rem}.portal-toolbar{gap:.85rem;margin-bottom:.3rem}.portal-search-input,.portal-status-filter,.portal-item-note,.portal-checkout-form input,.portal-checkout-form select,.portal-checkout-form textarea{color:var(--b2b-char);background:#fffdf9;border:1px solid #d8cfc0;border-radius:7px}.portal-search-input:focus,.portal-status-filter:focus,.portal-item-note:focus,.portal-checkout-form input:focus,.portal-checkout-form select:focus,.portal-checkout-form textarea:focus{border-color:var(--b2b-oxblood);outline:none;box-shadow:0 0 0 3px #8b2c1f1a}.portal-cat-btn{color:var(--b2b-char-soft);background:#fffcf8;border-color:#d8cfc0}.portal-cat-btn.active{background:var(--b2b-char);border-color:var(--b2b-char)}.portal-product-grid{grid-template-columns:repeat(auto-fill,minmax(285px,1fr));gap:1rem;margin-top:.4rem}.portal-product-card{background:linear-gradient(#faf6f0b3,#faf6f000 34%),#fffdf9;border:1px solid #decebc;border-radius:8px;min-height:175px;padding:1.05rem;transition:transform .32s cubic-bezier(.22,1,.36,1),border-color .2s,background .2s;position:relative}.portal-product-card:hover{background:linear-gradient(#e4d9c3b3,#fffdf9f2 36%),#fffdf9;border-color:#ccb49c;transform:translateY(-4px);box-shadow:0 20px 40px -30px #2a242199}.portal-product-card.in-cart{border-color:var(--b2b-oxblood);background:linear-gradient(#8b2c1f1f,#fffdf9f5 42%),#fffdf9}.portal-product-name{font-family:Cormorant Garamond,Georgia,serif;font-size:1.5rem;font-weight:500;line-height:1.15}.portal-product-cat{letter-spacing:.14em;border-radius:999px;padding:.22rem .58rem;font-size:.59rem}.portal-product-cat.fresh{background:var(--b2b-pink);color:var(--b2b-oxblood-deep)}.portal-product-cat.proc{background:var(--b2b-paper-deep);color:var(--b2b-char-soft)}.portal-product-price,.portal-cart-row-total,.portal-order-total,.portal-checkout-total,.portal-edit-total{font-family:Cormorant Garamond,Georgia,serif}.portal-product-price{color:var(--b2b-char);font-size:1.5rem}.portal-price-unit,.portal-product-unit,.portal-cart-row-price,.portal-order-date,.portal-order-items,.portal-checkout-qty,.portal-checkout-name,.portal-status-filter,.portal-item-note,.portal-checkout-form label{color:var(--b2b-char-soft)}.portal-qty-wrap{background:#fff;border-color:#d8cfc0;border-radius:999px;overflow:hidden}.portal-qty-btn:hover{background:var(--b2b-paper-deep)}.portal-qty-input{color:var(--b2b-char);background:#fffdf9;border-left:1px solid #d8cfc0;border-right:1px solid #d8cfc0}.portal-add-btn,.portal-cart-checkout,.portal-submit-btn,.portal-order-change-btn,.portal-order-reorder-btn,.portal-order-detail-btn,.portal-cancel-keep,.portal-cancel-confirm{letter-spacing:.06em;border-radius:999px}.portal-add-btn,.portal-cart-checkout,.portal-submit-btn,.portal-order-detail-btn,.portal-order-reorder-btn,.portal-cancel-keep{background:var(--b2b-char);color:var(--b2b-bone);border:1px solid var(--b2b-char)}.portal-cart-clear,.portal-order-cancel-btn,.portal-cancel-confirm{color:var(--b2b-danger);background:#fff4f2;border:1px solid #e6b1aa;border-radius:999px}.portal-cart-clear:hover,.portal-order-cancel-btn:hover,.portal-cancel-confirm:hover{background:#fbe2df}.portal-cart-bar,.portal-cart-row,.portal-cart-footer,.portal-checkout-items,.portal-checkout-form,.portal-confirmed-box,.portal-order-card,.portal-edit-row,.portal-edit-add-item,.portal-detail-modal,.portal-cancel-modal,.portal-edit-modal{background:#fffdf9;border:1px solid #decebc;border-radius:8px}.portal-cart-bar{box-shadow:0 16px 40px -32px #2a2421d9}.portal-empty-state{color:var(--b2b-char-soft);background:#f0e8da73;border:1px dashed #c4af97;border-radius:8px}.portal-empty-icon{font-size:1.7rem}.portal-section-title,.portal-confirmed-box h2,.portal-history-section h2,.portal-cancel-header h2,.portal-detail-modal h2,.portal-edit-modal h2,.modal-header h2{color:var(--b2b-char);letter-spacing:-.01em;font-family:Cormorant Garamond,Georgia,serif}.portal-order-card{transition:transform .24s,border-color .2s}.portal-order-card:hover{border-color:#ccb49c;transform:translateY(-2px)}.portal-order-card.cancelled{opacity:.7;border-style:dashed}.portal-order-num,.portal-confirmed-number strong{font-family:JetBrains Mono,SFMono-Regular,Menlo,monospace}.status-badge{letter-spacing:.08em;border:1px solid #0000;border-radius:999px;font-size:.68rem}.status-pending,.status-confirmed,.status-packing,.status-packed{background:var(--b2b-paper);color:var(--b2b-char-soft);border-color:#d7c7b2}.status-delivered{color:var(--b2b-moss);background:#eef5eb;border-color:#b8c9ae}.status-cancelled{color:var(--b2b-danger);background:#fdecea;border-color:#e9b6b0}.portal-toast{border-radius:999px}.portal-order-actions{flex-wrap:wrap;gap:.5rem;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#2a242157}.portal-detail-modal,.portal-cancel-modal,.portal-edit-modal{box-shadow:var(--b2b-shadow)}@media (width<=960px){.portal-header{flex-direction:column;align-items:flex-start;gap:.75rem}.portal-header-right{flex-wrap:wrap;width:100%}.portal-order-section,.portal-cart-section,.portal-checkout-section,.portal-confirmed-section,.portal-history-section{padding-inline:.8rem}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition:none!important;animation:none!important}}.portal-reveal{opacity:0;transition:opacity .52s cubic-bezier(.22,1,.36,1),transform .52s cubic-bezier(.22,1,.36,1);transform:translateY(24px)}.portal-reveal.in{opacity:1;transform:translateY(0)}.portal-nav-btn.pulse{animation:.32s cubic-bezier(.22,1,.36,1) portalTabPulse}.portal-header-cart-badge.portal-bump{animation:.32s cubic-bezier(.22,1,.36,1) portalBadgeBump}.portal-submit-btn.is-submitting{position:relative;overflow:hidden}.portal-submit-btn.is-submitting:after{content:"";background:linear-gradient(120deg,#0000,#ffffff61,#0000);width:42%;height:100%;animation:.88s linear infinite portalSubmitSweep;position:absolute;top:0;left:-42%}.portal-product-card:active,.portal-add-btn:active,.portal-cart-checkout:active,.portal-cart-clear:active,.portal-order-reorder-btn:active,.portal-order-change-btn:active,.portal-order-cancel-btn:active{transform:translateY(0)scale(.985)}@keyframes portalTabPulse{0%{transform:scale(1)}45%{transform:scale(1.06)}to{transform:scale(1)}}@keyframes portalBadgeBump{0%{transform:scale(1)}50%{transform:scale(1.38)}to{transform:scale(1)}}@keyframes portalSubmitSweep{0%{left:-42%}to{left:110%}}:root{--ops-bg:#fcf9f8;--ops-surface:#fff;--ops-surface-muted:#f0eded;--ops-border:#e5e1da;--ops-border-strong:#cfc7bd;--ops-text:#1c1b1b;--ops-muted:#57423e;--ops-primary:#8b2c1f;--ops-primary-deep:#6b150b;--ops-green:#2f5d50;--ops-blue:#35658a;--ops-danger:#ba1a1a}.portal-app{background:var(--ops-bg);color:var(--ops-text);font-family:Hanken Grotesk,"Source Sans 3",Segoe UI,sans-serif}.portal-header{background:var(--ops-surface);color:var(--ops-text);border-bottom:1px solid var(--ops-border);box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;padding:.6rem 1rem}.portal-brand-icon{background:var(--ops-primary);width:2rem;height:2rem;box-shadow:none;border-radius:6px}.portal-brand-name{letter-spacing:0;font-family:inherit;font-size:1.45rem;font-weight:800}.portal-user-badge,.portal-header-cart,.portal-refresh-btn,.portal-lang-select,.portal-logout-btn{border:1px solid var(--ops-border);background:var(--ops-surface);color:var(--ops-text);border-radius:6px}.portal-user-badge{color:var(--ops-muted)}.portal-user-icon{color:var(--ops-green)}.portal-header-cart:hover,.portal-refresh-btn:hover,.portal-lang-select:hover{background:var(--ops-surface-muted)}.portal-logout-btn{color:var(--ops-danger)}.portal-nav{background:var(--ops-surface);border-bottom:1px solid var(--ops-border);justify-content:center;gap:1rem;padding:0 1rem}.portal-nav-btn{color:var(--ops-muted);background:0 0;border-bottom:2px solid #0000;border-radius:0;margin:0;padding:.72rem .25rem;font-size:.86rem}.portal-nav-btn:hover{border-bottom-color:var(--ops-border-strong);background:0 0}.portal-nav-btn.active{color:var(--ops-primary);border-bottom-color:var(--ops-primary);background:0 0}.portal-order-section,.portal-cart-section,.portal-checkout-section,.portal-confirmed-section,.portal-history-section{max-width:1280px;padding:1rem 1rem 5rem}.portal-toolbar{grid-template-columns:minmax(260px,420px) 1fr;align-items:center;gap:1rem;padding:.5rem 0 .85rem;display:grid}.portal-search-wrap{align-items:center;gap:.5rem;display:flex}.portal-filter-toggle{border:1px solid var(--ops-border);background:var(--ops-surface);color:var(--ops-muted);border-radius:6px;padding:.46rem .75rem;font-weight:700}.portal-filter-toggle.active{background:var(--ops-primary);border-color:var(--ops-primary);color:#fff}.portal-search-input,.portal-status-filter,.portal-item-note,.portal-checkout-form input,.portal-checkout-form select,.portal-checkout-form textarea{border-color:var(--ops-border);background:var(--ops-surface);color:var(--ops-text);border-radius:6px}.portal-search-input:focus,.portal-status-filter:focus,.portal-item-note:focus,.portal-checkout-form input:focus,.portal-checkout-form select:focus,.portal-checkout-form textarea:focus{border-color:var(--ops-primary);box-shadow:0 0 0 2px #8b2c1f1f}.portal-category-filter{justify-content:flex-start;overflow:hidden}.portal-category-filter.collapsed{opacity:0;pointer-events:none;max-height:0;margin:0}.portal-category-filter.expanded{opacity:1;max-height:220px;margin-top:.15rem;transition:max-height .22s,opacity .18s}.portal-cat-btn{border-color:var(--ops-border);background:var(--ops-surface);color:var(--ops-muted);border-radius:6px;font-weight:700}.portal-cat-btn.active{background:var(--ops-primary);border-color:var(--ops-primary);color:#fff}.portal-product-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;display:grid}.portal-product-card{border:1px solid var(--ops-border);background:var(--ops-surface);min-height:146px;box-shadow:none;border-radius:8px;padding:.75rem;transition:border-color .16s,box-shadow .16s,transform .16s}.portal-product-photo{aspect-ratio:1.15/.82;border:1px solid var(--ops-border);background:var(--ops-surface-muted);border-radius:7px;margin-bottom:.65rem;overflow:hidden}.portal-product-photo img{object-fit:cover;width:100%;height:100%;transition:transform .28s;display:block;transform:scale(1.01)}.portal-product-photo-empty{width:100%;height:100%;color:var(--ops-muted);text-transform:uppercase;letter-spacing:.05em;place-items:center;font-size:.8rem;font-weight:700;display:grid}.portal-product-card:hover{border-color:var(--ops-border-strong);background:var(--ops-surface);transform:translateY(-2px);box-shadow:0 8px 20px -18px #1c1b1b73}.portal-product-card:hover .portal-product-photo img{transition-delay:.22s;transform:scale(1.045)}.portal-product-card.in-cart{background:#fbfefc;border-color:#2f5d508c}.portal-product-name,.portal-section-title,.portal-confirmed-box h2,.portal-history-section h2,.portal-cancel-header h2,.portal-detail-modal h2,.portal-edit-modal h2,.modal-header h2{letter-spacing:0;font-family:inherit}.portal-product-name{font-size:1rem;font-weight:800;line-height:1.25}.portal-product-price{color:var(--ops-primary);font-family:inherit;font-size:1.05rem;font-weight:800}.portal-price-unit,.portal-product-unit,.portal-cart-row-price,.portal-order-date,.portal-order-items,.portal-checkout-qty,.portal-checkout-name{color:var(--ops-muted)}.portal-product-cat{letter-spacing:0;white-space:nowrap;text-overflow:ellipsis;cursor:pointer;border:1px solid #0000;border-radius:4px;max-width:100%;padding:.18rem .42rem;font-size:.68rem;overflow:hidden}.portal-product-cat.fresh{color:var(--ops-green);background:#e4f2ea}.portal-product-cat.proc{color:var(--ops-blue);background:#eaf1f6}.portal-qty-wrap{border-color:var(--ops-border);border-radius:6px}.portal-qty-btn{background:var(--ops-surface-muted);color:var(--ops-text)}.portal-qty-input{background:var(--ops-surface);border-left-color:var(--ops-border);border-right-color:var(--ops-border)}.portal-add-btn,.portal-cart-checkout,.portal-submit-btn,.portal-order-detail-btn,.portal-order-reorder-btn,.portal-cancel-keep{letter-spacing:0;background:var(--ops-primary);border-color:var(--ops-primary);color:#fff;border-radius:6px;font-weight:800}.portal-add-btn:hover,.portal-cart-checkout:hover,.portal-submit-btn:hover,.portal-order-detail-btn:hover,.portal-order-reorder-btn:hover,.portal-cancel-keep:hover{background:var(--ops-primary-deep);border-color:var(--ops-primary-deep)}.portal-cart-clear,.portal-order-cancel-btn,.portal-cancel-confirm{color:var(--ops-danger);background:#fff6f5;border-color:#f1c6c1;border-radius:6px}.portal-cart-bar,.portal-cart-row,.portal-cart-footer,.portal-checkout-items,.portal-checkout-form,.portal-confirmed-box,.portal-order-card,.portal-edit-row,.portal-edit-add-item,.portal-detail-modal,.portal-cancel-modal,.portal-edit-modal{border-color:var(--ops-border);background:var(--ops-surface);box-shadow:none;border-radius:8px}.portal-cart-bar{z-index:20;position:sticky;bottom:.75rem;box-shadow:0 14px 30px -24px #1c1b1b8c}.portal-empty-state{border-color:var(--ops-border-strong);background:var(--ops-surface);color:var(--ops-muted)}.portal-toast{border-radius:8px;box-shadow:0 14px 30px -22px #1c1b1b80}.portal-toast-success{background:var(--ops-green)}.portal-toast-info{background:var(--ops-text)}.portal-toast-error{background:var(--ops-danger)}.portal-reveal,.portal-reveal.in{opacity:1;transition:none;transform:none}.portal-nav-btn.pulse,.portal-header-cart-badge.portal-bump{animation-duration:.22s}@media (width<=760px){.portal-toolbar{grid-template-columns:1fr}.portal-search-wrap{flex-wrap:wrap}.portal-filter-toggle{margin-left:auto}.portal-nav{justify-content:flex-start;overflow-x:auto}.portal-product-grid{grid-template-columns:1fr}}@media (width<=1200px){.portal-product-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}}@media (width<=920px){.portal-product-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}}
