
*{box-sizing:border-box}body{margin:0;background:#f3f4f6;color:#111827;font-family:"Microsoft YaHei",Arial,sans-serif;font-size:14px}.layout{display:flex;min-height:100vh}.sidebar{width:210px;background:#111827;color:#fff;padding:16px 12px;position:fixed;top:0;bottom:0;left:0}.logo{display:block;color:#fff;text-decoration:none;font-size:22px;font-weight:800;margin-bottom:18px}.nav a{display:block;color:#d1d5db;text-decoration:none;padding:11px 12px;border-radius:8px;margin:4px 0}.nav a:hover{background:#1f2937;color:#fff}.main{margin-left:210px;flex:1;padding:18px}.topbar{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:12px 16px;margin-bottom:14px}.topbar h1{margin:0;font-size:20px}.userbox a{margin-left:12px}.card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:14px;margin-bottom:14px;box-shadow:0 1px 2px rgba(0,0,0,.03)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center}.login-card{width:360px}.error{background:#fee2e2;color:#991b1b;padding:8px;border-radius:8px;margin:8px 0}.hint{color:#6b7280;font-size:13px}.btn{display:inline-block;border:1px solid #cbd5e1;background:#fff;border-radius:8px;padding:8px 12px;cursor:pointer;text-decoration:none;color:#111827}.btn.primary{background:#2563eb;color:white;border-color:#2563eb}.btn.light{background:#f8fafc}.btn.mini{padding:5px 8px;font-size:12px}.btnbar{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.top-strip{display:grid;grid-template-columns:1fr 1fr;gap:14px}.strip-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:12px}.strip-title{font-weight:700;margin-bottom:8px}.country-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.compliance-mini{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.two-pane{display:grid;grid-template-columns:48% 52%;gap:14px;align-items:start}.left-pane,.right-pane{min-width:0}label{display:block;font-weight:600;margin-top:8px}input,textarea,select{width:100%;border:1px solid #cbd5e1;border-radius:8px;padding:8px;background:#fff}textarea{min-height:70px;resize:vertical}.long{min-height:160px}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.calc-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.image-strip,.tf-images{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-start;margin-top:10px}.img-card{position:relative;width:92px;height:92px;border:1px solid #e5e7eb;border-radius:10px;background:#f8fafc;overflow:hidden;cursor:grab}.img-card img{width:100%;height:100%;object-fit:cover}.img-del{position:absolute;right:3px;top:3px;background:#ef4444;color:#fff;border:0;border-radius:50%;width:20px;height:20px}.badge{position:absolute;left:3px;top:3px;background:#111827;color:#fff;border-radius:4px;padding:1px 4px;font-size:11px}.variant-main-btn{position:absolute;left:3px;bottom:3px;border:0;background:#16a34a;color:white;border-radius:50%;width:22px;height:22px;font-size:11px;cursor:pointer}.upload-tile{width:92px;height:92px;border:1px dashed #94a3b8;border-radius:10px;display:flex;align-items:center;justify-content:center;text-align:center;color:#64748b;cursor:pointer}.tabs{display:flex;gap:6px;flex-wrap:wrap;margin:8px 0}.country-tab{border:1px solid #cbd5e1;background:#f8fafc;border-radius:8px;padding:7px 12px;cursor:pointer}.country-tab.active{background:#2563eb;color:#fff;border-color:#2563eb}.bullet-list{display:grid;gap:8px}.bullet-list div{display:grid;grid-template-columns:70px 1fr 42px;gap:6px;align-items:start}.bullet-list textarea{min-height:65px}.count{color:#6b7280;font-size:12px}.variant-scroll{overflow:auto;max-height:520px;border:1px solid #e5e7eb;border-radius:10px}.tf-row{min-width:1450px;border-bottom:1px solid #e5e7eb;padding:8px}.tf-line{display:flex;gap:8px;align-items:flex-start}.tf-name{width:150px}.tf-cost,.tf-price{width:88px}.tf-cost input,.tf-price input{padding:5px}.clean-img-wrap-v61{width:76px}.clean-img-card-v61{width:70px;height:60px}.erp-table{width:100%;border-collapse:collapse;background:#fff}.erp-table th,.erp-table td{border:1px solid #e5e7eb;padding:8px;text-align:left;vertical-align:top}.erp-table th{background:#f8fafc}.thumb{width:54px;height:54px;object-fit:cover;border-radius:6px}.detail-img{max-width:240px;border:1px solid #e5e7eb;border-radius:8px}.jsonbox{background:#0f172a;color:#e5e7eb;padding:12px;border-radius:8px;white-space:pre-wrap;max-height:520px;overflow:auto}.resultbox{margin-top:12px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:12px}.toolbar{display:flex;justify-content:space-between}.sticky-actions{position:sticky;bottom:0;background:#fff;padding-top:8px}

.calculator-page{display:grid;grid-template-columns:1fr 1.1fr;gap:14px}
.inline-row{display:flex;gap:12px;align-items:center}
.inline-row input{max-width:240px}
.variant-scroll{max-height:620px}

.calc-result-grid p{margin:6px 0}
#calcHistoryTable th,#calcHistoryTable td{white-space:nowrap}

.listing-detail{border:1px solid #e5e7eb;border-radius:8px;padding:10px;margin:8px 0;background:#fff}
.listing-detail summary{font-weight:700;cursor:pointer}

.listing-detail{border:1px solid #e5e7eb;border-radius:8px;padding:10px;margin:8px 0;background:#fff}
.listing-detail summary{font-weight:700;cursor:pointer}

.variant-detail-block{border:1px solid #e5e7eb;border-radius:10px;padding:10px;margin:10px 0;background:#f8fafc}
#imgPreviewModal{display:none;position:fixed;z-index:9999;left:0;top:0;right:0;bottom:0}
.img-preview-mask{position:absolute;left:0;top:0;right:0;bottom:0;background:rgba(0,0,0,.65)}
.img-preview-box{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:#fff;border-radius:10px;padding:12px;max-width:90vw;max-height:90vh}
.img-preview-box img{max-width:86vw;max-height:80vh;display:block}
.img-preview-box button{float:right;margin-bottom:8px}

.filterbar{display:flex;gap:10px;align-items:end;flex-wrap:wrap}
.filterbar input,.filterbar select{min-width:150px}
.filterbar label{margin-top:0}
