@import "https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700&family=DM+Sans:wght@300;400;500;600&family=DM+Mono:wght@400;500&display=swap";@import "https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700&family=DM+Sans:wght@300;400;500;600&family=DM+Mono:wght@400;500&display=swap";@import "https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700&family=Syne:wght@400;500;600;700;800&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,400&family=DM+Mono:wght@400;500&display=swap";.bc{--accent:#c8441b;--accent-h:#b03916;--accent-bg:#fff0eb;--accent-ring:#c8441b21;--green:#16a34a;--green-bg:#f0fdf4;--gold:#a16207;--gold-bg:#fefce8;--border:#e2d5c3;--border-s:#cfc0aa;--surf:#fffcf7;--surf2:#faf4ea;--surf3:#f3e9d8;--bg:#ede4d3;--dark:#28180a;--dark2:#3b2310;--t1:#1e1005;--t2:#5c4228;--t3:#9a7a58;--sh-sm:0 1px 3px #50280514;--sh:0 4px 14px #5028051c;--sh-lg:0 12px 36px #5028052b;--r:7px;--r-lg:10px;--t:.15s cubic-bezier(.4,0,.2,1);--font-d:"Playfair Display", Georgia, serif;--font-b:"DM Sans", system-ui, sans-serif;--font-m:"DM Mono", "Courier New", monospace;font-family:var(--font-b);color:var(--t1);background:var(--bg);box-sizing:border-box;flex-direction:column;gap:7px;height:100%;max-height:100%;padding:8px 12px;display:flex;overflow:hidden}.bc-top{flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.bc-top h1{font-family:var(--font-d);color:var(--t1);font-size:1.1rem;font-weight:700;line-height:1.1}.bc-top p{color:var(--t3);margin-top:1px;font-size:.75rem}.bc-top-right{align-items:center;gap:10px;display:flex}.bc-edit-banner{color:#a16207;background:#fefce8;border:1px solid #fde68a;border-radius:7px;flex-shrink:0;align-items:center;gap:6px;padding:5px 12px;font-size:.76rem;font-weight:600;display:flex}.btn-new-bill{background:var(--green);color:#fff;font-family:var(--font-b);cursor:pointer;transition:background var(--t), transform .1s, box-shadow var(--t);white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:6px;padding:7px 14px;font-size:.79rem;font-weight:600;display:flex;box-shadow:0 2px 8px #16a34a38}.btn-new-bill:hover{background:#15803d;transform:translateY(-1px);box-shadow:0 4px 12px #16a34a4d}.btn-new-bill:active{transform:none}.sale-toggle{background:var(--surf3);border:1px solid var(--border);border-radius:8px;gap:2px;padding:3px;display:flex}.sale-toggle button{font-family:var(--font-b);color:var(--t2);cursor:pointer;transition:background var(--t), color var(--t), box-shadow var(--t);background:0 0;border:none;border-radius:6px;padding:4px 13px;font-size:.77rem;font-weight:500}.sale-toggle button.active{background:var(--surf);color:var(--t1);box-shadow:var(--sh-sm);font-weight:600}.bc-meta{background:var(--surf);border:1px solid var(--border);border-radius:var(--r-lg) var(--r-lg) 0 0;box-shadow:var(--sh-sm);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:5px 8px;padding:5px 12px;display:flex}.m-trn-wrap{position:relative;overflow:visible}.m-trn-in{border:1.5px solid var(--border);font-family:var(--font-b);color:var(--t1);background:var(--surf);box-sizing:border-box;width:150px;transition:border-color var(--t), box-shadow var(--t);border-radius:6px;outline:none;padding:4px 24px 4px 7px;font-size:.8rem}.m-trn-in:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.m-trn-in::placeholder{color:var(--t3)}.m-trn-chevron{color:var(--t3);pointer-events:none;transition:transform var(--t);position:absolute;top:50%;right:7px;transform:translateY(-50%)}.m-trn-chevron.open{transform:translateY(-50%)rotate(180deg)}.m-trn-list{background:var(--surf);border:1.5px solid var(--border-s);border-radius:var(--r);min-width:180px;box-shadow:var(--sh-lg);z-index:9999;max-height:160px;position:absolute;top:calc(100% + 3px);left:0;overflow-y:auto}.m-trn-item{color:var(--t1);cursor:pointer;border-bottom:1px solid var(--border);transition:background var(--t);align-items:center;gap:6px;padding:6px 10px;font-size:.8rem;display:flex}.m-trn-item:last-child{border-bottom:none}.m-trn-item:hover{background:var(--accent-bg)}.m-trn-new-badge{background:var(--accent);color:#fff;border-radius:3px;margin-left:auto;padding:1px 5px;font-size:.62rem;font-weight:600}.mf{flex-shrink:0;align-items:center;gap:5px;display:flex}.mf label{text-transform:uppercase;letter-spacing:.08em;color:var(--t3);white-space:nowrap;font-size:.66rem;font-weight:700}.m-sep{background:var(--border);flex-shrink:0;width:1px;height:18px}.m-in,.m-sel{border:1.5px solid var(--border);font-family:var(--font-b);color:var(--t1);background:var(--surf);transition:border-color var(--t), box-shadow var(--t);appearance:none;border-radius:6px;outline:none;padding:4px 7px;font-size:.8rem}.m-in:focus,.m-sel:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.m-in::placeholder{color:var(--t3)}.m-sel{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%239a7a58' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 7px center;background-repeat:no-repeat;padding-right:24px}.bc-cust{background:var(--surf2);border:1px solid var(--border);border-radius:0 0 var(--r-lg) var(--r-lg);box-shadow:var(--sh-sm);border-top:none;flex-shrink:0;padding:7px 12px 8px}.cust-hdr{text-transform:uppercase;letter-spacing:.09em;color:var(--t3);align-items:center;gap:5px;margin-bottom:5px;font-size:.68rem;font-weight:700;display:flex}.cust-row{grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;align-items:end;gap:7px;display:grid}.c-g{flex-direction:column;gap:2px;display:flex}.c-lbl{text-transform:uppercase;letter-spacing:.07em;color:var(--t2);font-size:.64rem;font-weight:600}.c-lbl-req:after{content:" *";color:var(--accent)}.c-in{border:1.5px solid var(--border);font-family:var(--font-b);color:var(--t1);background:var(--surf);transition:border-color var(--t), box-shadow var(--t);box-sizing:border-box;border-radius:6px;outline:none;width:100%;padding:6px 8px;font-size:.8rem}.c-in:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.c-in::placeholder{color:var(--t3)}.ac-wrap{position:relative}.ac-icon{color:var(--t3);pointer-events:none;position:absolute;top:50%;left:8px;transform:translateY(-50%)}.ac-pad{padding-left:26px!important}.ac-list{background:var(--surf);border:1.5px solid var(--border-s);border-radius:var(--r);box-shadow:var(--sh-lg);z-index:500;max-height:180px;position:absolute;top:calc(100% + 3px);left:0;right:0;overflow-y:auto}.ac-item{cursor:pointer;border-bottom:1px solid var(--border);transition:background var(--t);padding:7px 10px}.ac-item:last-child{border-bottom:none}.ac-item:hover{background:var(--accent-bg)}.ac-name{color:var(--t1);font-size:.81rem;font-weight:500}.ac-meta{color:var(--t3);font-size:.69rem;font-family:var(--font-m);margin-top:1px}.cust-chip{background:var(--green-bg);border:1px solid #bbf7d0;border-radius:6px;flex-wrap:wrap;grid-column:1/-1;align-items:center;gap:14px;padding:6px 10px;animation:.15s fadeIn;display:flex}.cc-g{flex-direction:column;gap:1px;display:flex}.cc-lbl{color:#15803d;text-transform:uppercase;letter-spacing:.07em;font-size:.6rem;font-weight:600}.cc-val{color:var(--t1);font-size:.79rem;font-weight:500}.cc-mono{font-family:var(--font-m);color:var(--gold);font-size:.75rem}.cc-clear{cursor:pointer;color:var(--t3);transition:color var(--t);background:0 0;border:none;border-radius:4px;align-items:center;margin-left:auto;padding:2px;display:flex}.cc-clear:hover{color:#dc2626}.bc-body{flex:1;grid-template-columns:310px 1fr 310px;align-items:stretch;gap:8px;min-height:0;display:grid;overflow:hidden}.crk-panel{background:var(--surf);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);flex-direction:column;height:100%;min-height:0;display:flex;overflow:hidden}.crk-hdr{background:var(--dark);flex-direction:column;flex-shrink:0;gap:6px;padding:8px 10px;display:flex}.crk-title{color:#f0e8da;align-items:center;gap:6px;font-size:.78rem;font-weight:600;display:flex}.crk-count{background:var(--accent);color:#fff;border-radius:10px;margin-left:auto;padding:1px 6px;font-size:.65rem;font-weight:600}.crk-srch{background:var(--dark2);border:1px solid #5a3520;border-radius:6px;align-items:center;gap:6px;padding:5px 8px;display:flex}.crk-srch input{font-family:var(--font-b);color:#e0d0bc;background:0 0;border:none;outline:none;width:100%;font-size:.79rem}.crk-srch input::placeholder{color:#6b4a2a}.crk-list{flex:1;padding:4px;overflow-y:auto}.crk-item{cursor:pointer;transition:background var(--t), border-color var(--t), transform .1s;-webkit-user-select:none;user-select:none;border:1px solid #0000;border-radius:6px;align-items:center;gap:7px;margin-bottom:1px;padding:7px 9px;display:flex}.crk-item:hover{background:var(--accent-bg);border-color:#c8441b40;transform:translate(2px)}.crk-item:active{transform:scale(.99)}.crk-code{font-family:var(--font-m);color:var(--gold);background:var(--gold-bg);text-align:center;border:1px solid #fde68a;border-radius:4px;flex-shrink:0;min-width:30px;padding:1px 5px;font-size:.66rem}.crk-name{color:var(--t1);flex:1;font-size:.78rem;font-weight:500;line-height:1.3}.crk-add-icon{color:var(--accent);opacity:0;transition:opacity var(--t);flex-shrink:0}.crk-item:hover .crk-add-icon{opacity:1}.crk-hint{color:var(--t3);text-align:center;border-top:1px solid var(--border);background:var(--surf2);flex-shrink:0;padding:6px;font-size:.65rem}.mid-col{flex-direction:column;height:100%;min-height:0;display:flex}.bill-card{background:var(--surf);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.bill-card-hdr{background:var(--surf2);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:6px;padding:8px 12px;display:flex}.bill-card-title{color:var(--t1);flex:1;align-items:center;gap:6px;font-size:.81rem;font-weight:600;display:flex}.bill-item-ct{color:var(--t3);margin-left:4px;font-size:.69rem;font-weight:400}.bill-scroll{flex:1;overflow-y:auto}.bill-empty{min-height:200px;color:var(--t3);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:24px;display:flex}.empty-icon{border:2px dashed var(--border-s);border-radius:12px;justify-content:center;align-items:center;width:46px;height:46px;display:flex}.bill-empty p{font-size:.8rem}.bill-empty span{color:#c0a882;font-size:.69rem}.bill-tbl{border-collapse:collapse;width:100%;font-size:.79rem}.bill-tbl thead tr{background:var(--surf3);z-index:2;position:sticky;top:0}.bill-tbl th{text-align:left;color:var(--t2);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border);white-space:nowrap;padding:7px;font-size:.63rem;font-weight:700}.bill-tbl td{border-bottom:1px solid var(--border);vertical-align:middle;padding:5px 6px}.bill-tbl tbody tr:last-child td{border-bottom:none}.bill-tbl tbody tr:hover{background:var(--surf2)}.t-code{background:var(--gold-bg);color:var(--gold);font-family:var(--font-m);white-space:nowrap;border:1px solid #fde68a;border-radius:4px;padding:1px 5px;font-size:.68rem;display:inline-block}.t-name{color:var(--t1);font-size:.79rem;font-weight:500}.t-qty{font-family:var(--font-m);color:var(--t1);text-align:center;font-size:.78rem}.t-rate{font-family:var(--font-m);color:var(--t2);text-align:right;font-size:.78rem}.t-amt{font-family:var(--font-m);color:var(--t1);white-space:nowrap;font-size:.8rem;font-weight:500}.t-del{cursor:pointer;color:var(--t3);transition:color var(--t), background var(--t);background:0 0;border:none;border-radius:4px;align-items:center;padding:3px;display:flex}.t-del:hover{color:#dc2626;background:#fef2f2}.bill-foot{border-top:1px solid var(--border);background:var(--surf2);flex-shrink:0;justify-content:space-between;align-items:center;padding:6px 10px;display:flex}.bill-foot-info{color:var(--t3);font-size:.72rem}.bill-foot-clr{cursor:pointer;color:var(--t3);font-size:.72rem;font-family:var(--font-b);transition:color var(--t), background var(--t);background:0 0;border:none;border-radius:4px;align-items:center;gap:3px;padding:3px 6px;display:flex}.bill-foot-clr:hover{color:#dc2626;background:#fef2f2}.right-col{flex-direction:column;gap:7px;height:100%;min-height:0;display:flex;overflow-y:auto}.r-card{background:var(--surf);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);flex-shrink:0;overflow:visible}.r-card.fill{flex-direction:column;flex:1;display:flex;overflow:hidden}.r-card.fill .sum-body{flex-direction:column;flex:1;display:flex;overflow-y:auto}.r-card-hdr{background:var(--surf2);border-bottom:1px solid var(--border);border-radius:var(--r-lg) var(--r-lg) 0 0;color:var(--t1);align-items:center;gap:6px;padding:8px 11px;font-size:.79rem;font-weight:600;display:flex}.trn-wrap{position:relative;overflow:visible}.trn-in{border:1.5px solid var(--border);width:100%;font-family:var(--font-b);color:var(--t1);background:var(--surf);box-sizing:border-box;transition:border-color var(--t), box-shadow var(--t);border-radius:6px;outline:none;padding:6px 26px 6px 8px;font-size:.8rem}.trn-in:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.trn-in::placeholder{color:var(--t3)}.trn-chevron{color:var(--t3);pointer-events:none;transition:transform var(--t);position:absolute;top:50%;right:7px;transform:translateY(-50%)}.trn-chevron.open{transform:translateY(-50%)rotate(180deg)}.trn-list{background:var(--surf);border:1.5px solid var(--border-s);border-radius:var(--r);box-shadow:var(--sh-lg);z-index:9999;max-height:160px;position:absolute;top:calc(100% + 3px);left:0;right:0;overflow-y:auto}.trn-item{color:var(--t1);cursor:pointer;border-bottom:1px solid var(--border);transition:background var(--t);align-items:center;gap:6px;padding:6px 10px;font-size:.8rem;display:flex}.trn-item:last-child{border-bottom:none}.trn-item:hover{background:var(--accent-bg)}.trn-new-badge{background:var(--accent);color:#fff;border-radius:3px;flex-shrink:0;margin-left:auto;padding:1px 5px;font-size:.62rem;font-weight:600}.del-body{flex-direction:column;gap:7px;padding:9px 11px;display:flex}.del-row2{grid-template-columns:1fr 1fr;gap:7px;display:grid}.d-g{flex-direction:column;gap:3px;display:flex}.d-lbl{text-transform:uppercase;letter-spacing:.07em;color:var(--t2);align-items:center;gap:3px;font-size:.65rem;font-weight:600;display:flex}.d-in{border:1.5px solid var(--border);font-family:var(--font-b);color:var(--t1);background:var(--surf);box-sizing:border-box;width:100%;transition:border-color var(--t), box-shadow var(--t);border-radius:6px;outline:none;padding:6px 8px;font-size:.8rem}.d-in:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.d-in::placeholder{color:var(--t3)}.sum-hdr{background:var(--dark);color:#f0e0c8;border-radius:var(--r-lg) var(--r-lg) 0 0;border:1px solid var(--border);align-items:center;gap:6px;padding:8px 11px;font-size:.79rem;font-weight:600;display:flex}.s-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:5px 11px;font-size:.79rem;display:flex}.s-row:last-child{border-bottom:none}.s-lbl{color:var(--t2)}.s-val{font-family:var(--font-m);color:var(--t1);font-weight:400}.s-val.green{color:var(--green)}.total-tax-row{background:#ea580c0d;border-radius:4px;margin:2px 8px}.s-val.tax-highlight{color:#c2410c;font-weight:600}.ex-grid{background:var(--surf2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);grid-template-columns:1fr 1fr;gap:6px;padding:7px 11px;display:grid}.ex-g{flex-direction:column;gap:3px;display:flex}.ex-lbl{text-transform:uppercase;letter-spacing:.07em;color:var(--t3);font-size:.62rem;font-weight:600}.ex-in{border:1.5px solid var(--border);font-family:var(--font-m);color:var(--t1);background:var(--surf);box-sizing:border-box;width:100%;transition:border-color var(--t);border-radius:5px;outline:none;padding:4px 6px;font-size:.77rem}.ex-in:focus{border-color:var(--accent)}.tax-grid{background:var(--surf2);border-bottom:1px solid var(--border);grid-template-columns:1fr 1fr 1fr;gap:5px;padding:7px 11px;display:grid}.tx-g{flex-direction:column;gap:3px;display:flex}.tx-lbl{text-transform:uppercase;letter-spacing:.07em;color:var(--t3);text-align:center;font-size:.61rem;font-weight:600}.tx-in{border:1.5px solid var(--border);font-family:var(--font-m);color:var(--t1);background:var(--surf);text-align:right;box-sizing:border-box;width:100%;transition:border-color var(--t);border-radius:5px;outline:none;padding:4px;font-size:.75rem}.tx-in:focus{border-color:var(--accent)}.grand-row{background:var(--gold-bg);border-bottom:1px solid #fde68a;justify-content:space-between;align-items:center;padding:8px 11px;display:flex}.grand-lbl{color:var(--t1);font-size:.84rem;font-weight:600}.grand-val{font-family:var(--font-m);color:var(--gold);font-size:1.05rem;font-weight:500}.net-row{background:var(--dark);border-radius:0 0 var(--r-lg) var(--r-lg);justify-content:space-between;align-items:center;padding:9px 11px;display:flex}.net-lbl{color:#9a7a58;font-size:.78rem;font-weight:500}.net-val{font-family:var(--font-m);color:#fdf4e8;font-size:.97rem;font-weight:500}.act-wrap{flex-direction:column;flex-shrink:0;gap:7px;display:flex}.act-row{grid-template-columns:1fr 1.3fr 1fr;gap:6px;display:grid}.btn-p{background:var(--accent);color:#fff;font-family:var(--font-b);cursor:pointer;transition:background var(--t), box-shadow var(--t), transform .1s;white-space:nowrap;border:none;border-radius:7px;justify-content:center;align-items:center;gap:5px;padding:8px 5px;font-size:.79rem;font-weight:600;display:flex;box-shadow:0 2px 8px #c8441b38}.btn-p:hover:not(:disabled){background:var(--accent-h);transform:translateY(-1px)}.btn-p:disabled{opacity:.6;cursor:default}.btn-p.update-mode{background:#a16207;box-shadow:0 2px 8px #a1620747}.btn-p.update-mode:hover:not(:disabled){background:#854d0e}.btn-dl{background:var(--green);color:#fff;font-family:var(--font-b);cursor:pointer;transition:background var(--t), transform .1s;white-space:nowrap;border:none;border-radius:7px;justify-content:center;align-items:center;gap:5px;padding:8px 5px;font-size:.79rem;font-weight:600;display:flex;box-shadow:0 2px 8px #16a34a38}.btn-dl:hover:not(:disabled){background:#15803d;transform:translateY(-1px)}.btn-dl:disabled{opacity:.6;cursor:default}.btn-pr{background:var(--dark);color:#f0e0c8;font-family:var(--font-b);cursor:pointer;transition:background var(--t), transform .1s;white-space:nowrap;border:none;border-radius:7px;justify-content:center;align-items:center;gap:5px;padding:8px 5px;font-size:.79rem;font-weight:600;display:flex;box-shadow:0 2px 8px #28180a38}.btn-pr:hover:not(:disabled){background:var(--dark2);transform:translateY(-1px)}.btn-pr:disabled{opacity:.6;cursor:default}.saved-badge{background:var(--green-bg);color:var(--green);border:1px solid #bbf7d0;border-radius:6px;flex-shrink:0;align-items:center;gap:5px;padding:5px 10px;font-size:.72rem;font-weight:600;display:flex}.qty-overlay{z-index:99998;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a0e1a9e;justify-content:center;align-items:center;animation:.14s fadeIn;display:flex;position:fixed;inset:0}.qty-box{background:#fff;border-radius:16px;width:500px;max-width:calc(100vw - 48px);margin:24px;font-family:DM Sans,system-ui,sans-serif;animation:.2s cubic-bezier(.22,1,.36,1) modalIn;overflow:hidden;box-shadow:0 32px 72px #0a0e1a47,0 8px 24px #0a0e1a1f,0 0 0 1px #0000000f}.qty-header{background:#fff;border-bottom:1.5px solid #f1f5f9;padding:20px 22px 16px;position:relative}.qty-cracker-name{color:#0f172a;letter-spacing:-.01em;margin-bottom:9px;font-family:DM Sans,system-ui,sans-serif;font-size:1.15rem;font-weight:600;line-height:1.35}.qty-header-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.qty-cracker-code{color:#a16207;letter-spacing:.04em;background:#fefce8;border:1px solid #fde68a;border-radius:5px;padding:3px 9px;font-family:DM Mono,Courier New,monospace;font-size:.72rem;font-weight:500}.qty-sale-badge{color:#c8441b;text-transform:uppercase;letter-spacing:.06em;background:#fff0eb;border:1px solid #fbc8b0;border-radius:5px;padding:3px 9px;font-size:.72rem;font-weight:500}.qty-body{padding:20px 22px 22px}.qty-info-strip{background:#f8fafc;border:2px solid #cbd5e1;border-radius:10px;grid-template-columns:1fr auto 1fr auto 1fr;align-items:center;margin-bottom:20px;padding:11px 16px;display:grid}.qty-info-chip{flex-direction:column;gap:3px;display:flex}.qty-info-lbl{text-transform:uppercase;letter-spacing:.09em;color:#0f172a;margin-bottom:2px;font-family:DM Sans,system-ui,sans-serif;font-size:.67rem;font-weight:700}.qty-info-val{color:#1e293b;font-family:DM Sans,system-ui,sans-serif;font-size:.88rem;font-weight:500;line-height:1.2}.qty-base-in{color:#0f172a;box-sizing:border-box;text-align:center;background:#fff;border:2px solid #0f172a;border-radius:7px;outline:none;width:100%;padding:5px 8px;font-family:DM Mono,Courier New,monospace;font-size:1rem;font-weight:700;transition:border-color .15s,box-shadow .15s}.qty-base-in:focus{background:#f8fafc;border-color:#334155;box-shadow:0 0 0 3px #0f172a1a}.qty-info-divider{background:#dde3ea;flex-shrink:0;width:1px;height:32px;margin:0 12px}.qty-fields{grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:20px;display:grid}.qty-g{flex-direction:column;gap:6px;display:flex}.qty-lbl{text-transform:uppercase;letter-spacing:.08em;color:#0f172a;font-family:DM Sans,system-ui,sans-serif;font-size:.7rem;font-weight:700}.qty-field-lbl-note{color:#94a3b8;text-transform:none;letter-spacing:0;margin-left:3px;font-size:.64rem;font-weight:500}.qty-in{color:#0f172a;box-sizing:border-box;text-align:center;background:#fff;border:1.5px solid #dde3ea;border-radius:9px;outline:none;width:100%;padding:11px 13px;font-family:DM Mono,Courier New,monospace;font-size:1.08rem;font-weight:600;transition:border-color .15s,box-shadow .15s,background .15s}.qty-in:focus{background:#fdfcff;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51f}.qty-btns{gap:10px;display:flex}.qty-cancel{color:#475569;cursor:pointer;background:#f1f5f9;border:1.5px solid #e2e8f0;border-radius:9px;flex:1;padding:11px;font-family:DM Sans,system-ui,sans-serif;font-size:.88rem;font-weight:600;transition:background .14s,border-color .14s,color .14s}.qty-cancel:hover{color:#1e293b;background:#e2e8f0;border-color:#cbd5e1}.qty-ok{background:var(--accent);color:#fff;cursor:pointer;letter-spacing:-.01em;border:none;border-radius:9px;flex:1.8;justify-content:center;align-items:center;gap:7px;padding:11px 16px;font-family:DM Sans,system-ui,sans-serif;font-size:.88rem;font-weight:700;transition:background .14s,box-shadow .14s,transform .1s;display:flex;box-shadow:0 4px 14px #c8441b4d}.qty-ok:hover{background:var(--accent-h);transform:translateY(-1px);box-shadow:0 6px 20px #c8441b61}.qty-ok:active{transform:translateY(0)}.modal-box{background:#fff;border:1px solid #e8edf3;border-radius:16px;width:calc(100% - 48px);min-width:320px;max-width:420px;margin:24px;padding:28px 28px 22px;font-family:DM Sans,system-ui,sans-serif;animation:.18s cubic-bezier(.34,1.56,.64,1) modalIn;box-shadow:0 24px 64px #0a0e1a2e,0 0 0 1px #0000000a}@keyframes modalIn{0%{opacity:0;transform:scale(.92)translateY(8px)}to{opacity:1;transform:none}}.modal-icon{border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 14px;display:flex}.modal-icon.warn{color:#d97706;background:#fef9ec;border:1.5px solid #fde68a}.modal-icon.print{color:#0369a1;background:#f0f9ff;border:1.5px solid #bae6fd}.modal-icon.dl{color:#16a34a;background:#f0fdf4;border:1.5px solid #bbf7d0}.modal-title{color:#0f172a;text-align:center;margin-bottom:6px;font-family:DM Sans,system-ui,sans-serif;font-size:1.05rem;font-weight:600}.modal-desc{color:#64748b;text-align:center;margin-bottom:20px;font-size:.83rem;font-weight:400;line-height:1.55}.modal-cancel{color:#475569;cursor:pointer;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:9px;flex:1;padding:10px;font-family:DM Sans,system-ui,sans-serif;font-size:.84rem;font-weight:500;transition:background .14s,border-color .14s,color .14s}.modal-confirm{color:#fff;cursor:pointer;background:#c8441b;border:none;border-radius:9px;flex:1.4;justify-content:center;align-items:center;gap:6px;padding:10px;font-family:DM Sans,system-ui,sans-serif;font-size:.84rem;font-weight:600;transition:background .14s,box-shadow .14s;display:flex;box-shadow:0 2px 8px #c8441b38}.modal-confirm:hover{background:#b03916}.modal-confirm.green{background:#16a34a;box-shadow:0 2px 8px #16a34a38}.modal-confirm.green:hover{background:#15803d}.modal-confirm.dark{background:#1e293b;box-shadow:0 2px 8px #0a0e1a38}.modal-confirm.dark:hover{background:#0f172a}.modal-btns-3{gap:8px;display:flex}.modal-btns-3>button{flex:1}.fmt-row{grid-template-columns:1fr 1fr;gap:9px;margin-bottom:20px;display:grid}.fmt-btn{cursor:pointer;color:#475569;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;flex-direction:column;align-items:center;gap:7px;padding:14px 8px;font-family:DM Sans,system-ui,sans-serif;font-size:.8rem;font-weight:500;transition:border-color .14s,background .14s,color .14s;display:flex}.fmt-btn:hover{color:#c8441b;background:#fff8f5;border-color:#c8441b}.fmt-btn.selected{color:#c8441b;background:#fff8f5;border-color:#c8441b;box-shadow:0 0 0 3px #c8441b1a}.bc-spin{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:13px;height:13px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes rowIn{0%{opacity:0;transform:translate(-4px)}to{opacity:1;transform:none}}.row-in{animation:.15s rowIn}.crk-list::-webkit-scrollbar{width:4px}.bill-scroll::-webkit-scrollbar{width:4px}.right-col::-webkit-scrollbar{width:4px}.crk-list::-webkit-scrollbar-thumb{background:var(--border-s);border-radius:3px}.bill-scroll::-webkit-scrollbar-thumb{background:var(--border-s);border-radius:3px}.right-col::-webkit-scrollbar-thumb{background:var(--border-s);border-radius:3px}.ab{--accent:#c8441b;--accent-h:#b03916;--accent-bg:#fff0eb;--accent-ring:#c8441b21;--green:#16a34a;--green-bg:#f0fdf4;--green-border:#bbf7d0;--gold:#a16207;--gold-bg:#fefce8;--gold-border:#fde68a;--amber:#d97706;--amber-bg:#fffbeb;--amber-border:#fde68a;--blue:#2563eb;--blue-bg:#eff6ff;--blue-border:#bfdbfe;--border:#e2d5c3;--border-s:#cfc0aa;--surf:#fffcf7;--surf2:#faf4ea;--surf3:#f3e9d8;--bg:#ede4d3;--dark:#28180a;--dark2:#3b2310;--t1:#1e1005;--t2:#5c4228;--t3:#9a7a58;--t4:#c0a882;--sh-xs:0 1px 2px #5028050f;--sh-sm:0 1px 3px #50280514;--sh-md:0 4px 14px #5028051c;--sh-lg:0 20px 48px #5028052e, 0 4px 12px #50280517;--r:7px;--r-lg:10px;--r-xl:14px;--t:.15s cubic-bezier(.4,0,.2,1);--font-d:"Playfair Display", Georgia, serif;--font-b:"DM Sans", system-ui, sans-serif;--font-m:"DM Mono", "Courier New", monospace;font-family:var(--font-b);color:var(--t1);background:var(--bg);box-sizing:border-box;min-height:100%;padding:20px 24px 40px}.ab-hdr{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:18px;display:flex}.ab-hdr-title{font-family:var(--font-d);color:var(--t1);letter-spacing:-.01em;font-size:1.4rem;font-weight:700;line-height:1.1}.ab-hdr-sub{color:var(--t3);margin-top:4px;font-size:.75rem;font-weight:400}.ab-stats{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-bottom:16px;display:grid}.ab-stat{background:var(--surf);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-xs);padding:12px 16px}.ab-stat-label{text-transform:uppercase;letter-spacing:.08em;color:var(--t3);margin-bottom:5px;font-size:.65rem;font-weight:700}.ab-stat-value{font-family:var(--font-m);color:var(--t1);font-size:1.1rem;font-weight:500;line-height:1}.ab-stat-value.accent{color:var(--accent)}.ab-stat-value.green{color:var(--green)}.ab-stat-value.gold{color:var(--gold)}.ab-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px;display:flex}.ab-search-box{background:var(--surf);border:1.5px solid var(--border);border-radius:var(--r);min-width:200px;max-width:340px;transition:border-color var(--t), box-shadow var(--t);box-shadow:var(--sh-xs);flex:1;align-items:center;gap:8px;padding:8px 12px;display:flex}.ab-search-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.ab-search-box input{font-family:var(--font-b);color:var(--t1);background:0 0;border:none;outline:none;width:100%;font-size:.82rem}.ab-search-box input::placeholder{color:var(--t4)}.ab-date-strip{background:var(--surf);border:1.5px solid var(--border);border-radius:var(--r);box-shadow:var(--sh-xs);flex-wrap:wrap;align-items:center;gap:8px;padding:7px 12px;display:flex}.ab-strip-lbl{text-transform:uppercase;letter-spacing:.08em;color:var(--t3);white-space:nowrap;align-items:center;gap:4px;font-size:.65rem;font-weight:700;display:flex}.ab-date-input{border:1.5px solid var(--border);font-family:var(--font-m);color:var(--t1);background:var(--surf2);transition:border-color var(--t);cursor:pointer;border-radius:6px;outline:none;padding:4px 8px;font-size:.76rem}.ab-date-input:focus{border-color:var(--accent)}.ab-strip-sep{color:var(--t4);font-size:.8rem}.ab-btn{border-radius:var(--r);font-family:var(--font-b);cursor:pointer;transition:background var(--t), transform .1s, box-shadow var(--t);white-space:nowrap;border:none;align-items:center;gap:5px;padding:7px 13px;font-size:.78rem;font-weight:600;display:inline-flex}.ab-btn:hover:not(:disabled){transform:translateY(-1px)}.ab-btn:disabled{opacity:.45;cursor:default;transform:none!important}.ab-btn.primary{background:var(--accent);color:#fff;box-shadow:0 2px 8px #c8441b38}.ab-btn.primary:hover:not(:disabled){background:var(--accent-h)}.ab-btn.success{background:var(--green);color:#fff;box-shadow:0 2px 8px #16a34a33}.ab-btn.success:hover:not(:disabled){background:#15803d}.ab-btn.ghost{color:var(--t2);border:1.5px solid var(--border);background:0 0}.ab-btn.ghost:hover:not(:disabled){background:var(--surf2);border-color:var(--border-s)}.ab-btn.dark{background:var(--dark);color:#f0e0c8;box-shadow:0 2px 8px #28180a38}.ab-btn.dark:hover:not(:disabled){background:var(--dark2)}.ab-sel-bar{background:var(--accent-bg);border-radius:var(--r);border:1px solid #c8441b40;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px;padding:9px 14px;display:flex}.ab-sel-info{color:var(--accent);flex:1;align-items:center;gap:6px;font-size:.79rem;font-weight:600;display:flex}.ab-sel-total{font-family:var(--font-m);color:var(--t2);font-size:.77rem;font-weight:500}.ab-card{background:var(--surf);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--sh-sm);overflow:hidden}.ab-tbl-wrap{overflow-x:auto}.ab-tbl{border-collapse:collapse;width:100%;font-size:.83rem}.ab-tbl thead tr{background:var(--dark);border-bottom:2px solid var(--dark2)}.ab-tbl th{text-align:left;color:#9a7a58;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;padding:11px 14px;font-size:.63rem;font-weight:700}.ab-tbl td{border-bottom:1px solid var(--border);vertical-align:middle;color:var(--t1);padding:11px 14px}.ab-tbl tbody tr:last-child td{border-bottom:none}.ab-tbl tbody tr{transition:background var(--t);cursor:pointer}.ab-tbl tbody tr:hover{background:var(--surf2)}.ab-tbl tbody tr.active{background:var(--accent-bg)}.ab-chk-cell{width:40px;padding:11px 8px 11px 14px!important}.ab-chk{cursor:pointer;color:var(--t4);transition:color var(--t);background:0 0;border:none;border-radius:4px;align-items:center;padding:2px;display:flex}.ab-chk:hover,.ab-chk.on{color:var(--accent)}.ab-bill-no{font-family:var(--font-m);color:var(--accent);background:var(--accent-bg);border:1px solid #c8441b40;border-radius:20px;padding:3px 9px;font-size:.79rem;font-weight:500;display:inline-block}.ab-cust-name{color:var(--t1);font-size:.83rem;font-weight:600}.ab-cust-mob{font-family:var(--font-m);color:var(--t3);margin-top:2px;font-size:.7rem}.ab-date{font-family:var(--font-m);color:var(--t2);font-size:.78rem}.ab-transport{color:var(--t2);align-items:center;gap:5px;font-size:.79rem;display:inline-flex}.ab-badge{text-transform:capitalize;letter-spacing:.03em;border:1px solid #0000;border-radius:20px;padding:3px 9px;font-size:.66rem;font-weight:600;display:inline-block}.ab-badge.cash{background:var(--green-bg);color:var(--green);border-color:var(--green-border)}.ab-badge.credit{background:var(--amber-bg);color:var(--amber);border-color:var(--amber-border)}.ab-badge.online,.ab-badge.upi{background:var(--blue-bg);color:var(--blue);border-color:var(--blue-border)}.ab-badge.cheque,.ab-badge.retail{background:var(--surf3);color:var(--t2);border-color:var(--border)}.ab-badge.wholesale{background:var(--gold-bg);color:var(--gold);border-color:var(--gold-border)}.ab-amount{font-family:var(--font-m);color:var(--t1);text-align:right;font-size:.87rem;font-weight:500;display:block}.ab-row-arrow{color:var(--t4);transition:transform var(--t), color var(--t);flex-shrink:0}.ab-tbl tbody tr:hover .ab-row-arrow,.ab-tbl tbody tr.active .ab-row-arrow{color:var(--accent);transform:translate(3px)}.ab-empty{color:var(--t3);flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:80px 20px;display:flex}.ab-empty p{font-size:.87rem}.ab-spinner{border:2.5px solid var(--border-s);border-top-color:var(--accent);border-radius:50%;width:22px;height:22px;animation:.7s linear infinite abSpin}@keyframes abSpin{to{transform:rotate(360deg)}}.ab-pager{border-top:1px solid var(--border);background:var(--surf2);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:11px 16px;display:flex}.ab-pager-info{color:var(--t3);font-size:.76rem}.ab-pager-btns{gap:4px;display:flex}.ab-pg{border:1.5px solid var(--border);background:var(--surf);font-family:var(--font-b);color:var(--t2);cursor:pointer;transition:all var(--t);border-radius:6px;padding:5px 11px;font-size:.76rem;font-weight:500}.ab-pg:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.ab-pg:disabled{opacity:.35;cursor:default}.ab-pg.active{background:var(--accent);color:#fff;border-color:var(--accent)}.ab-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#1c0e046b;animation:.18s abFadeIn;position:fixed;inset:0}.ab-panel{background:var(--surf);border-left:1px solid var(--border);width:min(600px,100vw);box-shadow:var(--sh-lg);z-index:201;flex-direction:column;animation:.22s cubic-bezier(.32,.72,0,1) abSlideIn;display:flex;position:fixed;top:0;bottom:0;right:0;overflow:hidden}@keyframes abSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes abFadeIn{0%{opacity:0}to{opacity:1}}.ab-panel-hdr{background:var(--dark);border-bottom:2px solid var(--dark2);flex-shrink:0;align-items:center;gap:10px;padding:14px 18px;display:flex}.ab-panel-title{font-family:var(--font-d);color:#f0e0c8;flex:1;font-size:1rem;font-weight:700}.ab-panel-date{font-family:var(--font-m);color:var(--t3);background:var(--dark2);border:1px solid #5a3520;border-radius:10px;padding:3px 9px;font-size:.72rem}.ab-panel-close{background:var(--dark2);color:var(--t3);cursor:pointer;width:30px;height:30px;transition:background var(--t), color var(--t);border:1px solid #5a3520;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.ab-panel-close:hover{color:var(--accent);background:#c8441b33}.ab-panel-actions{border-bottom:1px solid var(--border);background:var(--surf2);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;padding:10px 16px;display:flex}.ab-panel-body{flex-direction:column;flex:1;gap:14px;padding:18px;display:flex;overflow-y:auto}.ab-panel-body::-webkit-scrollbar{width:4px}.ab-panel-body::-webkit-scrollbar-thumb{background:var(--border-s);border-radius:3px}.ab-sec{background:var(--surf);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-xs);flex-shrink:0;overflow:hidden}.ab-sec-hdr{background:var(--surf3);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.09em;color:var(--t3);align-items:center;gap:6px;padding:8px 14px;font-size:.63rem;font-weight:700;display:flex}.ab-sec-body{padding:14px}.ab-grid{grid-template-columns:1fr 1fr;gap:12px 18px;display:grid}.ab-field{flex-direction:column;gap:3px;display:flex}.ab-field.full{grid-column:1/-1}.ab-field-lbl{text-transform:uppercase;letter-spacing:.08em;color:var(--t3);align-items:center;gap:3px;font-size:.63rem;font-weight:700;display:flex}.ab-field-val{color:var(--t1);font-size:.83rem;font-weight:500;line-height:1.4}.ab-field-val.mono{font-family:var(--font-m);font-size:.79rem}.ab-edit-input{border:1.5px solid var(--border);font-family:var(--font-b);color:var(--t1);background:var(--surf);transition:border-color var(--t), box-shadow var(--t);box-sizing:border-box;border-radius:6px;outline:none;width:100%;padding:6px 9px;font-size:.82rem}.ab-edit-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.ab-edit-select{border:1.5px solid var(--border);font-family:var(--font-b);color:var(--t1);background:var(--surf);transition:border-color var(--t);box-sizing:border-box;cursor:pointer;appearance:auto;border-radius:6px;outline:none;width:100%;padding:6px 9px;font-size:.82rem}.ab-edit-select:focus{border-color:var(--accent)}.ab-itbl-wrap{width:100%;overflow-x:auto}.ab-itbl{border-collapse:collapse;table-layout:auto;width:100%;font-size:.8rem}.ab-itbl thead tr{background:var(--surf3);border-bottom:1px solid var(--border)}.ab-itbl th{text-transform:uppercase;letter-spacing:.08em;color:var(--t3);text-align:left;white-space:nowrap;padding:8px 11px;font-size:.63rem;font-weight:700}.ab-itbl td{border-bottom:1px solid var(--border);color:var(--t1);vertical-align:middle;padding:9px 11px}.ab-itbl tbody{display:table-row-group}.ab-itbl tbody tr{display:table-row}.ab-itbl tbody tr:last-child td{border-bottom:none}.ab-itbl tbody tr:hover{background:var(--surf2)}.ab-icode{font-family:var(--font-m);color:var(--gold);background:var(--gold-bg);border:1px solid var(--gold-border);white-space:nowrap;border-radius:4px;padding:2px 6px;font-size:.68rem;display:inline-block}.ab-itbl-items-count{background:var(--accent);color:#fff;border-radius:10px;margin-left:auto;padding:2px 8px;font-size:.6rem;font-weight:600}.ab-sum-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:7px 0;font-size:.82rem;display:flex}.ab-sum-row:last-child{border-bottom:none}.ab-sum-lbl{color:var(--t2)}.ab-sum-val{font-family:var(--font-m);color:var(--t1);font-weight:500}.ab-sum-val.green{color:var(--green)}.ab-total-band{border-top:2px solid var(--border);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.ab-total-band.grand{background:var(--gold-bg);border-color:var(--gold-border)}.ab-total-band.net{background:var(--dark);border-radius:0 0 var(--r-lg) var(--r-lg)}.ab-total-lbl{font-size:.82rem;font-weight:600}.ab-total-val{font-family:var(--font-m);font-size:1rem;font-weight:500}.ab-total-band.grand .ab-total-lbl,.ab-total-band.grand .ab-total-val{color:var(--gold)}.ab-total-band.net .ab-total-lbl{color:var(--t3);font-size:.76rem;font-weight:500}.ab-total-band.net .ab-total-val{color:#fdf4e8}.ab-panel-loading{color:var(--t3);flex:1;justify-content:center;align-items:center;gap:10px;font-size:.875rem;display:flex}.ab-editing-banner{color:var(--gold);background:var(--gold-bg);border:1px solid var(--gold-border);border-radius:6px;align-items:center;gap:5px;padding:3px 10px;font-size:.76rem;font-weight:600;display:flex}.ab-cust-header{color:var(--t1);font-size:.95rem;font-weight:700;font-family:var(--font-d);margin-bottom:12px}.ab-modal-backdrop{z-index:200;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);box-sizing:border-box;background:#1c0e048c;justify-content:center;align-items:center;padding:16px;animation:.18s abFadeIn;display:flex;position:fixed;inset:0}.ab-modal{background:var(--surf);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--sh-lg);z-index:201;flex-direction:column;width:min(860px,100%);height:min(94vh,960px);animation:.22s cubic-bezier(.32,.72,0,1) abModalIn;display:flex;overflow:hidden}@keyframes abModalIn{0%{opacity:0;transform:scale(.95)translateY(12px)}to{opacity:1;transform:scale(1)translateY(0)}}.ab-modal .ab-panel-hdr{border-radius:var(--r-xl) var(--r-xl) 0 0;flex-shrink:0}.ab-modal .ab-panel-actions{flex-shrink:0}.ab-modal .ab-panel-body{flex-direction:column;flex:1;gap:16px;min-height:0;padding:20px;display:flex;overflow:hidden auto}.ab-modal .ab-panel-body::-webkit-scrollbar{width:5px}.ab-modal .ab-panel-body::-webkit-scrollbar-track{background:var(--surf2)}.ab-modal .ab-panel-body::-webkit-scrollbar-thumb{background:var(--border-s);border-radius:4px}.ab-modal .ab-grid{grid-template-columns:repeat(3,1fr)}.ab-modal .ab-grid .ab-field.full{grid-column:1/-1}.ab-modal .ab-panel-loading{flex-direction:column;gap:10px;padding:60px 20px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}.ac{--accent:#c8441b;--accent-h:#a8380f;--accent-light:#fff2ed;--accent-ring:#c8441b26;--green:#15803d;--green-bg:#f0fdf4;--green-border:#86efac;--red:#b91c1c;--red-bg:#fff1f2;--red-border:#fca5a5;--gold:#92400e;--gold-bg:#fffbeb;--gold-border:#fcd34d;--ink:#0c0a09;--ink2:#1c1917;--ink3:#44403c;--ink4:#78716c;--ink5:#a8a29e;--paper:#fafaf9;--paper2:#f5f5f4;--paper3:#e7e5e4;--white:#fff;--border:#e7e5e4;--border-s:#d6d3d1;--sh-xs:0 1px 2px #0000000d;--sh-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--sh-md:0 4px 6px #0000000d, 0 2px 4px #0000000a;--sh-lg:0 10px 15px #00000012, 0 4px 6px #0000000a;--sh-xl:0 20px 40px #0000001a, 0 8px 16px #0000000f;--r:8px;--r-lg:12px;--r-xl:16px;--t:.16s cubic-bezier(.4,0,.2,1);--font-h:"Syne", system-ui, sans-serif;--font-d:"Playfair Display", Georgia, serif;--font-b:"DM Sans", system-ui, sans-serif;--font-m:"DM Mono", "Courier New", monospace;--w-surf:#fffcf7;--w-surf2:#faf4ea;--w-surf3:#f3e9d8;--w-bg:#ede4d3;--w-border:#e2d5c3;--w-border-s:#cfc0aa;--w-dark:#28180a;--w-dark2:#3b2310;--w-t1:#1e1005;--w-t2:#5c4228;--w-t3:#9a7a58;--w-gold:#a16207;--w-gold-bg:#fefce8;--w-sh:0 4px 14px #5028051c;--w-sh-lg:0 12px 36px #5028052b;font-family:var(--font-b);color:var(--ink);background:var(--paper2);box-sizing:border-box;min-height:100vh;padding:0}.ac-shell{flex-direction:column;height:100vh;display:flex;overflow:hidden}.ac-panels{background:var(--paper3);flex:1;grid-template-columns:340px 1fr 1fr;gap:10px;min-height:0;padding:10px;display:grid;overflow:hidden}.ac-panel{background:var(--white);border-radius:var(--r-lg);height:100%;min-height:0;box-shadow:var(--sh-md);flex-direction:column;display:flex;overflow:hidden}.ac-panel:not(:last-child){border-right:none}.ac-panel-left{background:var(--white)}.ac-panel-mid{background:var(--paper)}.panel-hdr{border-bottom:1px solid var(--border);background:var(--white);flex-shrink:0;padding:16px 20px 14px}.panel-hdr-row{justify-content:space-between;align-items:center;gap:10px;display:flex}.panel-hdr-title{font-family:var(--font-h);color:var(--ink2);letter-spacing:-.01em;align-items:center;gap:8px;font-size:.88rem;font-weight:700;display:flex}.panel-hdr-icon{border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.icon-orange{color:#c8441b;background:#fff2ed}.icon-blue{color:#2563eb;background:#eff6ff}.icon-green{color:#15803d;background:#f0fdf4}.panel-hdr-sub{color:var(--ink5);margin-top:3px;font-size:.7rem;font-weight:400}.panel-count-badge{min-width:22px;height:20px;font-size:.66rem;font-weight:700;font-family:var(--font-m);border-radius:10px;justify-content:center;align-items:center;padding:0 6px;display:inline-flex}.badge-orange{background:var(--accent-light);color:var(--accent)}.badge-blue{color:#1d4ed8;background:#dbeafe}.badge-green{background:var(--green-bg);color:var(--green)}.panel-body{flex:1;padding:18px 20px;overflow:hidden auto}.ac-panel-left .panel-body{flex:none;overflow-y:visible}.panel-body::-webkit-scrollbar{width:4px}.panel-body::-webkit-scrollbar-track{background:0 0}.panel-body::-webkit-scrollbar-thumb{background:var(--paper3);border-radius:4px}.panel-body::-webkit-scrollbar-thumb:hover{background:var(--border-s)}.form-section-label{text-transform:uppercase;letter-spacing:.12em;color:var(--ink5);align-items:center;gap:8px;margin-top:2px;margin-bottom:10px;font-size:.6rem;font-weight:700;display:flex}.form-section-label:after{content:"";background:var(--border);flex:1;height:1px}.form-group{margin-bottom:14px}.form-group:last-child{margin-bottom:0}.form-row2{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px;display:grid}.f-g{flex-direction:column;gap:5px;display:flex}.f-lbl{text-transform:uppercase;letter-spacing:.09em;color:var(--ink3);align-items:center;gap:4px;font-size:.65rem;font-weight:700;display:flex}.f-lbl-req:after{content:" *";color:var(--accent);font-size:.75rem}.f-in{border:1.5px solid var(--border);border-radius:var(--r);font-family:var(--font-b);color:var(--ink);background:var(--white);transition:border-color var(--t), box-shadow var(--t), background var(--t);outline:none;width:100%;padding:9px 11px;font-size:.83rem}.f-in:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring);background:#fffcfb}.f-in::placeholder{color:var(--ink5)}.f-in-mono{font-family:var(--font-m);font-size:.8rem}.f-in.has-err{border-color:var(--red)!important;box-shadow:0 0 0 3px #b91c1c17!important}.f-err{color:var(--red);align-items:center;gap:3px;margin-top:1px;font-size:.64rem;display:flex}.f-hint{color:var(--ink5);margin-top:1px;font-size:.63rem}.disc-wrap{grid-template-columns:1fr 1fr;gap:6px;margin-top:2px;display:grid}.disc-btn{border-radius:var(--r);border:1.5px solid var(--border);background:var(--paper);cursor:pointer;font-family:var(--font-b);color:var(--ink4);transition:all var(--t);text-align:center;padding:10px 12px;font-size:.79rem;font-weight:500;line-height:1.4}.disc-btn small{opacity:.7;margin-top:2px;font-size:.61rem;font-weight:400;display:block}.disc-btn:hover{border-color:var(--border-s);color:var(--ink)}.disc-btn.active-yes{background:var(--green-bg);border-color:var(--green-border);color:var(--green);box-shadow:var(--sh-xs);font-weight:600}.disc-btn.active-no{background:var(--red-bg);border-color:var(--red-border);color:var(--red);box-shadow:var(--sh-xs);font-weight:600}.f-tip{background:var(--gold-bg);border:1px solid var(--gold-border);border-radius:var(--r);color:var(--gold);align-items:flex-start;gap:7px;margin-top:10px;padding:9px 11px;font-size:.7rem;line-height:1.5;display:flex}.form-footer{border-top:1px solid var(--border);background:var(--paper);flex-shrink:0;gap:8px;padding:14px 20px;display:flex}.btn-submit{background:var(--accent);color:#fff;border-radius:var(--r);font-family:var(--font-h);letter-spacing:-.01em;cursor:pointer;transition:background var(--t), box-shadow var(--t), transform .1s;border:none;flex:1.6;justify-content:center;align-items:center;gap:7px;padding:11px 16px;font-size:.84rem;font-weight:700;display:flex;box-shadow:0 2px 8px #c8441b47}.btn-submit:hover:not(:disabled){background:var(--accent-h);transform:translateY(-1px);box-shadow:0 4px 14px #c8441b5c}.btn-submit:active:not(:disabled){transform:translateY(0)}.btn-submit:disabled{opacity:.45;cursor:default;box-shadow:none;transform:none}.btn-ghost{color:var(--ink4);border:1.5px solid var(--border);border-radius:var(--r);font-family:var(--font-b);cursor:pointer;transition:border-color var(--t), color var(--t), background var(--t);background:0 0;flex:1;justify-content:center;align-items:center;gap:6px;padding:11px;font-size:.82rem;font-weight:500;display:flex}.btn-ghost:hover{border-color:var(--border-s);color:var(--ink2);background:var(--paper2)}.session-empty{min-height:280px;color:var(--ink5);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}.session-empty-ring{border:2px dashed var(--border-s);border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:4px;display:flex}.session-empty p{color:var(--ink4);font-size:.83rem;font-weight:500}.session-empty span{color:var(--ink5);font-size:.7rem;line-height:1.5}.session-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-xs);transition:box-shadow var(--t), border-color var(--t);margin-bottom:10px;animation:.2s cubic-bezier(.22,1,.36,1) slideIn;overflow:hidden}.session-card:hover{border-color:var(--border-s);box-shadow:var(--sh-sm)}.session-card:last-child{margin-bottom:0}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.sc-top{align-items:flex-start;gap:10px;padding:11px 14px 10px;display:flex}.sc-num{background:var(--ink2);color:#fff;width:22px;height:22px;font-family:var(--font-m);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;font-size:.62rem;font-weight:500;display:flex}.sc-main{flex:1;min-width:0}.sc-name{font-family:var(--font-h);color:var(--ink2);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:700;line-height:1.3;overflow:hidden}.sc-code{font-family:var(--font-m);color:var(--gold);background:var(--gold-bg);border:1px solid var(--gold-border);border-radius:4px;align-items:center;gap:3px;margin-top:3px;padding:1px 6px;font-size:.66rem;display:inline-flex}.sc-del{cursor:pointer;color:var(--ink5);transition:color var(--t), background var(--t);background:0 0;border:none;border-radius:5px;flex-shrink:0;align-items:center;padding:4px;display:flex}.sc-del:hover{color:var(--red);background:var(--red-bg)}.sc-grid{border-top:1px solid var(--border);grid-template-columns:repeat(2,1fr);display:grid}.sc-cell{border-right:1px solid var(--border);padding:8px 12px}.sc-cell:last-child{border-right:none}.sc-cell-lbl{text-transform:uppercase;letter-spacing:.09em;color:var(--ink5);margin-bottom:3px;font-size:.59rem;font-weight:700}.sc-cell-val{font-family:var(--font-m);color:var(--ink2);font-size:.79rem;font-weight:500}.sc-disc-yes{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border);font-size:.65rem;font-weight:600;font-family:var(--font-b);border-radius:8px;align-items:center;gap:3px;padding:2px 7px;display:inline-flex}.sc-disc-no{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border);font-size:.65rem;font-weight:600;font-family:var(--font-b);border-radius:8px;align-items:center;gap:3px;padding:2px 7px;display:inline-flex}.session-footer{border-top:1px solid var(--border);background:var(--white);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 20px;display:flex}.session-footer-info{color:var(--ink5);font-size:.7rem}.btn-clr-session{color:var(--ink5);border:1.5px solid var(--border);font-family:var(--font-b);cursor:pointer;transition:color var(--t), border-color var(--t), background var(--t);background:0 0;border-radius:6px;align-items:center;gap:5px;padding:5px 12px;font-size:.72rem;font-weight:500;display:flex}.btn-clr-session:hover{color:var(--red);border-color:var(--red-border);background:var(--red-bg)}.ac-panel-right{background:var(--w-bg)!important}.rp-hdr{background:var(--w-dark);flex-direction:column;flex-shrink:0;gap:8px;padding:10px 14px;display:flex}.rp-hdr-row{align-items:center;gap:8px;display:flex}.rp-hdr-title{font-family:var(--font-d);color:#f0e8da;flex:1;align-items:center;gap:7px;font-size:.9rem;font-weight:600;display:flex}.rp-hdr-count{background:var(--accent);color:#fff;font-size:.65rem;font-weight:600;font-family:var(--font-b);border-radius:10px;padding:2px 8px}.rp-refresh-btn{color:#ffffff8c;cursor:pointer;transition:background var(--t), color var(--t);background:#ffffff14;border:1px solid #ffffff1f;border-radius:6px;flex-shrink:0;align-items:center;padding:4px 6px;display:flex}.rp-refresh-btn:hover{color:#fff;background:#ffffff26}.rp-srch-row{align-items:center;gap:6px;display:flex}.rp-srch-box{background:var(--w-dark2);transition:border-color var(--t);border:1px solid #5a3520;border-radius:6px;flex:1;align-items:center;gap:6px;padding:5px 9px;display:flex}.rp-srch-box:focus-within{border-color:var(--accent)}.rp-srch-box input{font-family:var(--font-b);color:#e0d0bc;background:0 0;border:none;outline:none;width:100%;font-size:.79rem}.rp-srch-box input::placeholder{color:#7a5535}.rp-filter-pills{flex-shrink:0;gap:4px;display:flex}.rp-pill{font-family:var(--font-b);color:#ffffff80;cursor:pointer;white-space:nowrap;transition:all var(--t);background:#ffffff0f;border:1px solid #ffffff1a;border-radius:6px;padding:5px 10px;font-size:.68rem;font-weight:500}.rp-pill:hover{color:#fffc;background:#ffffff1f}.rp-pill.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.rp-sort-bar{background:var(--w-surf2);border-bottom:1px solid var(--w-border);flex-shrink:0;align-items:center;gap:4px;padding:7px 14px;display:flex;overflow-x:auto}.rp-sort-lbl{text-transform:uppercase;letter-spacing:.09em;color:var(--w-t3);white-space:nowrap;margin-right:4px;font-size:.6rem;font-weight:700}.rp-sort-btn{border:1px solid var(--w-border);background:var(--w-surf);font-family:var(--font-b);color:var(--w-t2);cursor:pointer;white-space:nowrap;transition:all var(--t);border-radius:5px;align-items:center;gap:3px;padding:4px 9px;font-size:.67rem;font-weight:500;display:flex}.rp-sort-btn:hover{border-color:var(--w-border-s);color:var(--w-t1)}.rp-sort-btn.sorted{border-color:var(--accent);color:var(--accent);background:#fff2ed;font-weight:600}.rp-list{flex:1;min-height:0;padding:6px;overflow:hidden auto}.rp-list::-webkit-scrollbar{width:4px}.rp-list::-webkit-scrollbar-track{background:0 0}.rp-list::-webkit-scrollbar-thumb{background:var(--w-border-s);border-radius:4px}.rp-item{background:var(--w-surf);transition:background var(--t), border-color var(--t), box-shadow var(--t);cursor:pointer;border:1.5px solid #0000;border-radius:7px;align-items:center;gap:8px;margin-bottom:2px;padding:8px 10px;display:flex}.rp-item:last-child{margin-bottom:0}.rp-item:hover{background:#fff4ee;border-color:#c8441b33;box-shadow:0 1px 4px #50280512}.rp-item.rp-item-selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-ring);background:#fff2ed}.rp-idx{font-family:var(--font-m);color:var(--w-t3);text-align:right;flex-shrink:0;width:18px;font-size:.62rem}.rp-code{font-family:var(--font-m);color:var(--w-gold);background:var(--w-gold-bg);text-align:center;white-space:nowrap;border:1px solid #fde68a;border-radius:4px;flex-shrink:0;min-width:32px;padding:1px 6px;font-size:.64rem}.rp-name{color:var(--w-t1);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:.78rem;font-weight:500;line-height:1.3;overflow:hidden}.rp-prices{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:1px;display:flex}.rp-price-r{font-family:var(--font-m);color:var(--w-t2);white-space:nowrap;font-size:.69rem}.rp-price-w{font-family:var(--font-m);color:var(--w-t3);white-space:nowrap;font-size:.63rem}.rp-disc-pill{font-size:.6rem;font-weight:600;font-family:var(--font-b);border-radius:8px;flex-shrink:0;padding:1px 6px}.rp-disc-yes{color:#15803d;background:#f0fdf4;border:1px solid #86efac}.rp-disc-no{color:#b91c1c;background:#fff1f2;border:1px solid #fca5a5}.rp-edit-icon{color:var(--w-t3);opacity:0;transition:opacity var(--t);flex-shrink:0}.rp-item:hover .rp-edit-icon,.rp-item.rp-item-selected .rp-edit-icon{opacity:1}.rp-shimmer-row{background:var(--w-surf);border-radius:7px;align-items:center;gap:8px;margin-bottom:2px;padding:9px 10px;display:flex}.shimmer{background:linear-gradient(90deg, var(--w-surf2) 25%, var(--w-surf3) 50%, var(--w-surf2) 75%);background-size:400% 100%;border-radius:4px;animation:1.4s infinite shimmer;display:inline-block}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.rp-empty{text-align:center;color:var(--w-t3);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:52px 20px;display:flex}.rp-empty p{color:var(--w-t2);font-size:.83rem;font-weight:500}.rp-empty small{font-size:.7rem}.rp-footer{border-top:1px solid var(--w-border);background:var(--w-surf2);color:var(--w-t3);flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 14px;font-size:.68rem;display:flex}.rp-footer-clr{cursor:pointer;color:var(--accent);font-size:.68rem;font-family:var(--font-b);transition:opacity var(--t);background:0 0;border:none;align-items:center;gap:3px;padding:0;font-weight:600;display:flex}.rp-footer-clr:hover{opacity:.75}.edit-drawer{background:var(--white);border-top:2px solid var(--accent);flex-direction:column;flex-shrink:0;max-height:0;transition:max-height .28s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden}.edit-drawer.open{max-height:420px}.edit-drawer-hdr{border-bottom:1px solid var(--border);background:var(--accent-light);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 14px 8px;display:flex}.edit-drawer-title{font-family:var(--font-h);color:var(--accent);letter-spacing:-.01em;align-items:center;gap:6px;min-width:0;font-size:.82rem;font-weight:700;display:flex}.edit-drawer-title span{white-space:nowrap;text-overflow:ellipsis;max-width:180px;font-family:var(--font-d);color:var(--ink2);font-size:.85rem;overflow:hidden}.edit-drawer-close{cursor:pointer;color:var(--ink4);transition:color var(--t), background var(--t);background:0 0;border:none;border-radius:5px;flex-shrink:0;align-items:center;padding:4px;display:flex}.edit-drawer-close:hover{color:var(--red);background:var(--red-bg)}.edit-drawer-body{flex:1;padding:12px 14px;overflow-y:auto}.edit-drawer-body::-webkit-scrollbar{width:4px}.edit-drawer-body::-webkit-scrollbar-thumb{background:var(--paper3);border-radius:4px}.edit-row2{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px;display:grid}.edit-full{margin-bottom:10px}.ef-in{border:1.5px solid var(--border);border-radius:var(--r);font-family:var(--font-b);color:var(--ink);background:var(--white);width:100%;transition:border-color var(--t), box-shadow var(--t);outline:none;padding:7px 10px;font-size:.81rem}.ef-in:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.ef-in-mono{font-family:var(--font-m);font-size:.77rem}.ef-in.has-err{border-color:var(--red)!important}.edit-drawer-footer{border-top:1px solid var(--border);background:var(--paper);flex-shrink:0;align-items:center;gap:8px;padding:10px 14px;display:flex}.btn-save{background:var(--accent);color:#fff;border-radius:var(--r);font-family:var(--font-h);letter-spacing:-.01em;cursor:pointer;transition:background var(--t), box-shadow var(--t), transform .1s;border:none;flex:1.5;justify-content:center;align-items:center;gap:6px;padding:9px 14px;font-size:.81rem;font-weight:700;display:flex;box-shadow:0 2px 8px #c8441b3d}.btn-save:hover:not(:disabled){background:var(--accent-h);transform:translateY(-1px);box-shadow:0 4px 12px #c8441b52}.btn-save:disabled{opacity:.45;cursor:default;box-shadow:none;transform:none}.btn-cancel-edit{color:var(--ink4);border:1.5px solid var(--border);border-radius:var(--r);font-family:var(--font-b);cursor:pointer;transition:border-color var(--t), color var(--t), background var(--t);background:0 0;flex:1;justify-content:center;align-items:center;gap:5px;padding:9px;font-size:.8rem;font-weight:500;display:flex}.btn-cancel-edit:hover{border-color:var(--border-s);color:var(--ink2);background:var(--paper2)}.modal-overlay{z-index:99999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000052;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal-box{width:440px;max-width:calc(100vw - 40px);font-family:var(--font-b);background:#fff;border:1px solid #e5e7eb;border-radius:16px;margin:20px;animation:.22s cubic-bezier(.22,1,.36,1) modalPop;overflow:hidden;box-shadow:0 24px 48px #0000001f,0 8px 16px #0000000f}@keyframes modalPop{0%{opacity:0;transform:scale(.96)translateY(12px)}to{opacity:1;transform:none}}.modal-box:before{content:"";background:linear-gradient(90deg, var(--accent), #e8632e);border-radius:16px 16px 0 0;height:3px;display:block}.modal-inner{padding:28px 28px 24px}.modal-head{margin-bottom:22px}.modal-head-row{align-items:flex-start;gap:14px;display:flex}.modal-icon-ring{color:#ea580c;background:#fff7ed;border:1.5px solid #fed7aa;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.modal-head-text{flex:1;min-width:0;padding-top:2px}.modal-title{font-family:var(--font-h);color:#111827;letter-spacing:-.02em;margin-bottom:4px;font-size:1rem;font-weight:700}.modal-sub{color:#6b7280;font-size:.76rem;line-height:1.55}.modal-summary{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:20px;overflow:hidden}.ms-row{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;display:flex}.ms-row:last-child{border-bottom:none}.ms-row:first-child{background:#fff}.ms-lbl{text-transform:uppercase;letter-spacing:.09em;color:#9ca3af;white-space:nowrap;flex-shrink:0;font-size:.65rem;font-weight:700}.ms-val{font-family:var(--font-m);color:#111827;text-align:right;font-size:.8rem;font-weight:600}.ms-val.name-val{font-family:var(--font-h);color:#111827;font-size:.83rem;font-weight:700}.modal-btns{gap:10px;display:flex}.modal-cancel{color:#374151;font-family:var(--font-b);cursor:pointer;transition:border-color var(--t), background var(--t), color var(--t);letter-spacing:-.01em;background:#fff;border:1.5px solid #d1d5db;border-radius:9px;flex:1;padding:11px 16px;font-size:.84rem;font-weight:600}.modal-cancel:hover{color:#111827;background:#f9fafb;border-color:#9ca3af}.modal-confirm{background:var(--accent);color:#fff;font-family:var(--font-h);cursor:pointer;letter-spacing:-.01em;transition:background var(--t), box-shadow var(--t), transform .1s;border:none;border-radius:9px;flex:1.6;justify-content:center;align-items:center;gap:6px;padding:11px 18px;font-size:.84rem;font-weight:700;display:flex;box-shadow:0 2px 8px #c8441b4d}.modal-confirm:hover{background:var(--accent-h);transform:translateY(-1px);box-shadow:0 5px 16px #c8441b61}.modal-confirm:active{transform:translateY(0);box-shadow:0 2px 6px #c8441b38}.spin{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:13px;height:13px;animation:.7s linear infinite spinning;display:inline-block}@keyframes spinning{to{transform:rotate(360deg)}}.btn-import-excel{color:#fff;border-radius:var(--r);font-family:var(--font-b);cursor:pointer;letter-spacing:.01em;transition:background var(--t), box-shadow var(--t), transform var(--t);background:#166534;border:none;flex-shrink:0;align-items:center;gap:6px;padding:6px 12px;font-size:.72rem;font-weight:600;display:inline-flex;box-shadow:0 2px 6px #16653447}.btn-import-excel:hover{background:#14532d;transform:translateY(-1px);box-shadow:0 4px 12px #1665345c}.btn-import-excel:active{transform:translateY(0)}.xi-overlay{z-index:300;-webkit-backdrop-filter:none;backdrop-filter:none;background:#000000a6;justify-content:center;align-items:center;animation:.18s fadeIn;display:flex;position:fixed;inset:0}.xi-box{border-radius:var(--r-xl);z-index:301;background:#fff;width:440px;max-width:calc(100vw - 32px);position:relative;overflow:hidden;box-shadow:0 24px 60px #0000004d,0 8px 20px #00000026}.xi-head{border-bottom:1px solid var(--border);align-items:flex-start;gap:12px;padding:18px 20px 14px;display:flex}.xi-head-icon{color:#166534;background:#dcfce7;border:1.5px solid #86efac;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.xi-head-text{flex:1}.xi-head-title{font-family:var(--font-h);color:var(--ink2);margin-bottom:3px;font-size:.92rem;font-weight:700}.xi-head-sub{color:var(--ink4);font-size:.73rem;line-height:1.5}.xi-body{flex-direction:column;gap:14px;padding:18px 20px;display:flex}.xi-drop-zone{border:2px dashed var(--border-s);border-radius:var(--r-lg);text-align:center;cursor:pointer;transition:border-color var(--t), background var(--t);background:var(--paper);flex-direction:column;align-items:center;gap:8px;padding:28px 20px;display:flex}.xi-drop-zone:hover,.xi-drop-zone.drag-over,.xi-drop-zone.has-file{background:#f0fdf4;border-color:#166534}.xi-drop-icon{color:var(--ink5);margin-bottom:2px}.xi-drop-zone.has-file .xi-drop-icon{color:#166534}.xi-drop-title{font-family:var(--font-b);color:var(--ink3);font-size:.78rem;font-weight:600}.xi-drop-sub{color:var(--ink5);font-size:.68rem}.xi-drop-zone.has-file .xi-drop-title{color:#166534}.xi-file-name{font-size:.7rem;font-family:var(--font-m);color:#14532d;text-overflow:ellipsis;white-space:nowrap;background:#dcfce7;border-radius:20px;max-width:100%;margin-top:2px;padding:2px 9px;overflow:hidden}.xi-hint{background:var(--gold-bg);border:1px solid var(--gold-border);border-radius:var(--r);color:var(--gold);align-items:flex-start;gap:7px;padding:9px 12px;font-size:.68rem;line-height:1.55;display:flex}.xi-hint strong{font-weight:700}.xi-result{border-radius:var(--r);flex-direction:column;gap:4px;padding:10px 14px;font-size:.73rem;line-height:1.6;display:flex}.xi-result.success{color:#14532d;background:#f0fdf4;border:1px solid #86efac}.xi-result.partial{color:#92400e;background:#fffbeb;border:1px solid #fcd34d}.xi-result.error{color:#b91c1c;background:#fff1f2;border:1px solid #fca5a5}.xi-result-row{justify-content:space-between;display:flex}.xi-result-row strong{font-weight:700}.xi-err-list{opacity:.85;flex-direction:column;gap:2px;max-height:80px;margin-top:4px;font-size:.65rem;display:flex;overflow-y:auto}.xi-foot{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:8px;padding:12px 20px 16px;display:flex}.xi-btn-cancel{background:var(--paper2);border:1px solid var(--border-s);border-radius:var(--r);font-family:var(--font-b);color:var(--ink3);cursor:pointer;transition:background var(--t);padding:7px 16px;font-size:.75rem;font-weight:600}.xi-btn-cancel:hover{background:var(--paper3)}.xi-btn-upload{border-radius:var(--r);color:#fff;font-family:var(--font-b);cursor:pointer;transition:background var(--t), transform var(--t);background:#166534;border:none;align-items:center;gap:6px;padding:7px 18px;font-size:.75rem;font-weight:600;display:flex;box-shadow:0 2px 6px #16653447}.xi-btn-upload:hover:not(:disabled){background:#14532d;transform:translateY(-1px)}.xi-btn-upload:disabled{opacity:.55;cursor:not-allowed;transform:none}
