*{box-sizing:border-box}
:root{--blue:#2563eb;--dark:#0f172a;--bg:#f4f6f9;--card:#fff;--line:#111;--red:#e60000;--pink:#f7caca;--sum:#fde8d8;--muted:#64748b}
body{margin:0;background:var(--bg);font-family:Arial,"Microsoft JhengHei","Noto Sans TC",sans-serif;color:#111827}
a{text-decoration:none}
.login-body{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#eff6ff,#f8fafc)}
.login-card{width:min(430px,calc(100% - 32px));background:#fff;border-radius:22px;padding:30px;box-shadow:0 18px 50px rgba(15,23,42,.16);border:1px solid #e5e7eb}
.login-logo{width:58px;height:58px;border-radius:18px;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:900;margin:0 auto 12px}
.login-card h1{text-align:center;margin:0 0 6px;font-size:30px}
.login-card p{text-align:center;margin:0 0 20px;color:var(--muted);font-weight:800}
.login-card label{display:grid;gap:7px;margin:14px 0;font-weight:900}
.login-card input{border:1px solid #cbd5e1;border-radius:12px;padding:13px 14px;font-size:17px;outline:none}
.login-card button{width:100%;border:0;border-radius:13px;background:var(--blue);color:#fff;padding:13px;font-size:17px;font-weight:900;cursor:pointer}
.login-error{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca;border-radius:12px;padding:10px;text-align:center;font-weight:900;margin-bottom:12px}
.login-domain{text-align:center;color:var(--muted);font-size:13px;font-weight:800;margin-top:14px}

.app-shell{display:flex;min-height:100vh}
.sidebar{width:270px;background:var(--dark);color:#fff;padding:18px 14px;position:fixed;left:0;top:0;bottom:0;z-index:20}
.brand{display:flex;gap:12px;align-items:center;padding:8px 8px 22px}
.brand-icon{width:46px;height:46px;border-radius:14px;background:var(--blue);display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:900}
.brand-title{font-size:20px;font-weight:900}.brand-sub{font-size:12px;color:#cbd5e1;margin-top:2px}
.nav-link{display:block;color:#fff;padding:14px 16px;border-radius:14px;margin:8px 0;font-weight:900;background:rgba(255,255,255,.07)}
.nav-link.active,.nav-link:hover{background:var(--blue)}
.main{margin-left:270px;width:calc(100% - 270px);padding:18px}
.topbar{height:64px;background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 8px 24px rgba(15,23,42,.08);display:flex;align-items:center;gap:12px;padding:0 14px;margin-bottom:16px}
.menu-btn{display:none;border:0;background:var(--blue);color:#fff;border-radius:12px;width:44px;height:44px;font-size:24px;font-weight:900}
.top-title{flex:1;font-size:22px;font-weight:900}.top-user{display:flex;align-items:center;gap:10px;font-weight:900}.top-user a{background:#475569;color:#fff;border-radius:10px;padding:9px 13px}
.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(15,23,42,.35);z-index:19}
.panel,.dashboard,.invoice-page{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:18px;box-shadow:0 10px 28px rgba(15,23,42,.08)}
.hero-card{display:flex;justify-content:space-between;gap:16px;align-items:center;background:linear-gradient(135deg,#eff6ff,#fff);border:1px solid #dbeafe;border-radius:18px;padding:22px;margin-bottom:16px}
.hero-card h1{margin:0 0 8px;font-size:34px}.hero-card p{margin:0;color:var(--muted);font-weight:800}
.primary-link,.primary-btn{border:0;background:var(--blue);color:#fff;border-radius:13px;padding:12px 18px;font-weight:900;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.secondary-btn{border:0;background:#475569;color:#fff;border-radius:13px;padding:12px 18px;font-weight:900;cursor:pointer}
.dashboard-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.feature-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:18px;color:#111827;box-shadow:0 6px 18px rgba(15,23,42,.06)}
.feature-icon{font-size:34px}.feature-card h3{margin:8px 0}.feature-card p{margin:0;color:var(--muted);font-weight:800}
.panel-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:14px}.panel-head h2{margin:0;font-size:28px}.panel-head p{margin:4px 0 0;color:var(--muted);font-weight:800}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:12px;margin-bottom:14px}
.form-grid label{display:grid;gap:6px;font-weight:900}
.form-grid input,.form-grid select{border:1px solid #cbd5e1;border-radius:12px;padding:11px 13px;font-size:16px;background:#fff}
.title-row{display:grid;grid-template-columns:1fr 150px;gap:10px}.font-size-box{display:grid;gap:4px}.font-size-box span{font-size:13px;color:#ef4444;font-weight:900}
.prs-field select{border-color:#93c5fd;background:linear-gradient(180deg,#fff,#eff6ff);color:#1e3a8a;font-weight:900;box-shadow:0 3px 10px rgba(37,99,235,.08)}
.table-card{overflow:auto;border:1px solid #d1d5db;background:#fff}
.input-table{border-collapse:collapse;width:100%;min-width:900px;table-layout:fixed}
.input-table th,.input-table td{border:1px solid #111;height:42px;text-align:center;font-size:20px;padding:4px}
.input-cell{width:100%;border:0;text-align:center;font-size:20px;outline:none;background:transparent}.input-cell.tan-text,.tan-text{color:var(--red)}.layer-cell{text-align:left!important;font-weight:900}
.sum-row td{background:var(--sum);font-weight:900}.action-row{display:flex;gap:10px;margin-top:14px}
.invoice-actions{display:flex;gap:10px;margin-bottom:14px}.invoice-sheet{background:#fff;padding:28px 36px;border-radius:12px;overflow:hidden}
.doc-title{text-align:center!important;font-size:clamp(26px,4vw,44px)!important;white-space:nowrap!important;margin:0 auto 18px!important;line-height:1!important}
.doc-sub{font-family:Georgia,"Times New Roman",serif;font-size:24px;font-weight:900;margin:0 0 12px}
.summary-scroll{overflow:auto}.mini-table{border-collapse:collapse;width:100%;min-width:780px;margin-bottom:24px}.mini-table th,.mini-table td{height:28px;font-size:15px;border:0;text-align:center;font-weight:900}.mini-table thead th{background:var(--pink);border-bottom:3px solid #111}.mini-table .label{text-align:left;background:#f7f7f7;padding-left:18px}.mini-table .leftblank{background:#efefef;border-right:4px solid #111}.mini-table .total-line td{background:var(--pink);border-top:3px solid #111;border-bottom:3px solid #111}
.mobile-size-cards{display:none}.orientation{display:flex;align-items:flex-end;gap:22px;margin:12px 0 28px;justify-content:center}.face-row{display:flex;align-items:flex-start}.block{display:grid;grid-template-columns:repeat(4,72px);grid-template-rows:repeat(8,36px);transform:skewY(-2deg)}.block.mid{grid-template-columns:repeat(3,88px)}.cell{border:1px solid #777;display:flex;align-items:center;justify-content:center;background:#fff;font-size:20px;font-weight:1000;line-height:1}.cell.tan{color:var(--red)}
.side-piece{height:288px;border:1px solid #444;margin-left:-1px;clip-path:polygon(0 0,100% 10%,100% 90%,0 100%)}.side-brown{width:58px;background:linear-gradient(90deg,#fff1a8 0 14px,#a8835d 14px 100%)}.side-gray{width:26px;background:repeating-linear-gradient(to bottom,rgba(90,90,90,.55) 0 1px,transparent 1px 36px),linear-gradient(90deg,#d1d5db,#9ca3af)}.side-yellow{width:18px;background:#fff2a8}.face-right{transform:translateY(14px)}.legend{text-align:center;font-weight:900;font-size:13px;margin-top:2px}
.cube-title{font-size:28px;font-weight:900;margin:14px 0 14px}.cubes{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}.cube-box-container{background:#fff;display:flex;justify-content:center;align-items:center;min-height:430px;overflow:visible}.invoice-svg{width:100%;max-width:620px;height:auto;background:#fff}.layer-box{max-width:520px}.prs135-title{text-align:center;font-size:28px;font-weight:900;margin:16px 0}.footer-line{font-family:Georgia,"Times New Roman",serif;font-size:26px;font-weight:900;margin-top:16px}.red{color:var(--red)}
.modal-mask{position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:999;display:flex;align-items:center;justify-content:center;padding:18px}.settings-box{width:min(420px,100%);background:#fff;border-radius:16px;box-shadow:0 18px 45px rgba(0,0,0,.22);padding:20px}.settings-box h3{margin:0 0 14px}.settings-box label{display:grid;gap:6px;font-weight:900;margin:12px 0}.settings-box input{border:1px solid #cbd5e1;border-radius:10px;padding:11px 12px}.settings-actions{display:flex;gap:10px}.app-footer{text-align:center;color:#475569;font-weight:800;padding:20px 0 6px}
@media(max-width:900px){.sidebar{transform:translateX(-105%);transition:.22s}.sidebar.active{transform:translateX(0)}.sidebar-backdrop.active{display:block}.main{margin-left:0;width:100%;padding:10px}.menu-btn{display:block}.top-title{font-size:20px}.top-user span{display:none}.form-grid,.dashboard-grid,.cubes{grid-template-columns:1fr}.title-row{grid-template-columns:1fr}.panel,.dashboard,.invoice-page{padding:12px}.invoice-sheet{padding:14px}.summary-scroll{display:none}.mobile-size-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.size-card{border:2px solid #111;border-radius:10px;background:#fff;overflow:hidden}.size-card-title{background:var(--pink);border-bottom:2px solid #111;text-align:center;font-weight:900;padding:8px}.size-card-row{display:flex;justify-content:space-between;padding:8px 10px;border-bottom:1px solid #ddd;font-weight:900}.size-card-row.total{background:var(--sum)}.carton-card{grid-column:1/-1}.orientation{flex-direction:column;align-items:center}.block{grid-template-columns:repeat(4,64px);grid-template-rows:repeat(8,34px)}.block.mid{grid-template-columns:repeat(3,78px)}.cell{font-size:17px}.side-piece{height:272px}.cube-box-container{min-height:360px}.invoice-svg{height:auto}.doc-title{font-size:26px!important}}


.old-card{
  background:#fff !important;
  border-radius:16px !important;
  padding:18px !important;
  box-shadow:0 10px 28px rgba(15,23,42,.10) !important;
  border:1px solid #e5e7eb !important;
}

.old-note{
  color:#6b7280 !important;
  font-size:14px !important;
  margin-bottom:10px !important;
}

.old-meta-grid{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(220px,1fr)) !important;
  gap:10px !important;
  margin:0 0 14px !important;
}

.old-meta-grid label{
  display:grid !important;
  gap:6px !important;
  font-weight:800 !important;
}

.old-meta-grid input,
.old-meta-grid select{
  border:1px solid #cbd5e1 !important;
  border-radius:10px !important;
  padding:10px 12px !important;
  font-size:16px !important;
  background:#fff !important;
  box-shadow:none !important;
}

.old-title-row{
  display:grid !important;
  grid-template-columns:1fr 150px !important;
  gap:10px !important;
  align-items:end !important;
}

.old-font-size-box{
  display:grid !important;
  gap:4px !important;
}

.old-font-size-box span{
  font-size:13px !important;
  color:#ef4444 !important;
  font-weight:900 !important;
}

.old-prs-field select{
  border:1px solid #93c5fd !important;
  background:linear-gradient(180deg,#fff,#eff6ff) !important;
  color:#1e3a8a !important;
  font-weight:900 !important;
}

.old-table-wrap{
  overflow:auto !important;
  background:#fff !important;
  border:1px solid #d1d5db !important;
}

.old-input-table{
  border-collapse:collapse !important;
  width:100% !important;
  min-width:900px !important;
  table-layout:fixed !important;
}

.old-input-table th,
.old-input-table td{
  border:1px solid #111 !important;
  height:42px !important;
  text-align:center !important;
  vertical-align:middle !important;
  font-size:20px !important;
  padding:4px !important;
  background:#fff !important;
}

.old-input-table th{
  font-weight:900 !important;
  background:#f7f7f7 !important;
}

.old-input-table .sum-row td{
  background:#fde8d8 !important;
}

.old-input-table .input-cell{
  width:100% !important;
  border:0 !important;
  text-align:center !important;
  font-size:20px !important;
  outline:none !important;
  background:transparent !important;
  font-family:inherit !important;
}

.old-input-table .input-cell.tan-text,
.old-input-table .tan-text{
  color:#e60000 !important;
}

.old-input-table .input-cell[readonly]{
  font-weight:800 !important;
}

.old-actions{
  display:flex !important;
  gap:10px !important;
  flex-wrap:wrap !important;
  margin-top:14px !important;
}

.old-btn{
  border:0 !important;
  border-radius:12px !important;
  padding:12px 18px !important;
  font-weight:900 !important;
  cursor:pointer !important;
  color:white !important;
  background:#16a34a !important;
}

.old-btn.gray{
  background:#475569 !important;
}

/* invoice old page */
.old-sheet{
  background:white !important;
  padding:28px 36px !important;
  width:1080px !important;
  max-width:100% !important;
  margin:0 auto !important;
  border-radius:8px !important;
  overflow:hidden !important;
}

.old-doc-title{
  font-size:48px !important;
  font-weight:900 !important;
  letter-spacing:1px !important;
  margin:0 auto 22px auto !important;
  color:#111827 !important;
  text-align:center !important;
  white-space:nowrap !important;
  line-height:1 !important;
}

.old-doc-sub{
  font-family:Georgia,"Times New Roman",serif !important;
  font-size:32px !important;
  font-weight:900 !important;
  margin:0 0 8px !important;
}

.old-doc-sub .box{
  font-family:Arial,sans-serif !important;
  font-size:25px !important;
  margin-left:24px !important;
}

.old-mini-table-wrap{
  overflow:auto !important;
}

.old-mini-table{
  width:100% !important;
  min-width:780px !important;
  margin-bottom:28px !important;
  border-collapse:collapse !important;
}

.old-mini-table th,
.old-mini-table td{
  height:28px !important;
  font-size:15px !important;
  border:0 !important;
  font-weight:900 !important;
  text-align:center !important;
}

.old-mini-table thead th{
  background:#f7caca !important;
  border-bottom:3px solid #111 !important;
}

.old-mini-table .leftblank{
  background:#efefef !important;
  border-right:4px solid #111 !important;
}

.old-mini-table .label{
  background:#f7f7f7 !important;
  width:140px !important;
  text-align:left !important;
  padding-left:18px !important;
}

.old-mini-table .total-line td{
  background:#f7caca !important;
  border-top:3px solid #111 !important;
  border-bottom:3px solid #111 !important;
}

.old-orientation{
  display:flex !important;
  align-items:flex-end !important;
  gap:22px !important;
  margin:10px 0 28px !important;
  justify-content:center !important;
}

.old-face-card{
  display:flex !important;
  align-items:flex-end !important;
  overflow:visible !important;
}

.old-face-row{
  display:flex !important;
  align-items:flex-start !important;
  gap:0 !important;
}

.old-face-right{
  transform:translateY(14px) !important;
}

.old-block{
  position:relative !important;
  display:grid !important;
  grid-template-columns:repeat(4,72px) !important;
  grid-template-rows:repeat(8,36px) !important;
  transform:skewY(-2deg) !important;
}

.old-block.old-mid{
  grid-template-columns:repeat(3,88px) !important;
}

.old-cell{
  border:1px solid #777 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  background:white !important;
  font-size:20px !important;
  font-weight:1000 !important;
  line-height:1 !important;
  text-shadow:1px 1px 0 #ddd !important;
}

.old-cell.tan{
  color:#e60000 !important;
  text-shadow:1px 1px 0 #000 !important;
}

.old-side-piece{
  height:288px;
  border:1px solid #444 !important;
  margin-left:-1px !important;
  margin-top:0 !important;
  flex:0 0 auto !important;
  clip-path:polygon(0 0,100% 10%,100% 90%,0 100%) !important;
}

.old-side-brown{
  width:58px !important;
  background:linear-gradient(90deg,#fff1a8 0 14px,#a8835d 14px 100%) !important;
}

.old-side-gray{
  width:26px !important;
  background:
    repeating-linear-gradient(to bottom, rgba(90,90,90,.55) 0 1px, transparent 1px 36px),
    linear-gradient(90deg,#d1d5db 0,#9ca3af 100%) !important;
  border-color:#555 !important;
}

.old-side-yellow{
  width:18px !important;
  background:#fff2a8 !important;
  border-color:#555 !important;
}

.old-legend{
  text-align:center !important;
  font-weight:900 !important;
  margin-top:2px !important;
}

.old-cube-title{
  font-size:32px !important;
  font-weight:900 !important;
  margin:14px 0 24px !important;
}

.old-cubes{
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  gap:36px !important;
  align-items:center !important;
  margin-top:12px !important;
}

.old-cube-box-container{
  background:#fff !important;
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  min-height:430px !important;
  overflow:visible !important;
}

.old-cube-box-container svg{
  width:100% !important;
  max-width:560px !important;
  height:430px !important;
  background:#fff !important;
}

.old-footer-line{
  font-family:Georgia,"Times New Roman",serif !important;
  font-size:30px !important;
  font-weight:900 !important;
  margin-top:18px !important;
}

@media(max-width:900px){
  .old-card{
    padding:10px !important;
    border-radius:12px !important;
  }

  .old-meta-grid{
    grid-template-columns:1fr !important;
  }

  .old-title-row{
    grid-template-columns:1fr !important;
  }

  .old-sheet{
    padding:14px !important;
    overflow:hidden !important;
  }

  .old-doc-title{
    font-size:28px !important;
  }

  .old-doc-sub{
    font-size:22px !important;
    line-height:1.25 !important;
  }

  .old-doc-sub .box{
    display:block !important;
    margin-left:0 !important;
    margin-top:6px !important;
    font-size:20px !important;
  }

  .old-mini-table-wrap{
    display:none !important;
  }

  .old-orientation{
    flex-direction:column !important;
    align-items:center !important;
    gap:22px !important;
  }

  .old-face-card{
    width:100% !important;
    justify-content:center !important;
  }

  .old-block{
    grid-template-columns:repeat(4,64px) !important;
    grid-template-rows:repeat(8,34px) !important;
  }

  .old-block.old-mid{
    grid-template-columns:repeat(3,78px) !important;
  }

  .old-cell{
    font-size:17px !important;
  }

  .old-side-piece{
    height:272px !important;
  }

  .old-cubes{
    grid-template-columns:1fr !important;
    gap:18px !important;
  }

  .old-cube-box-container{
    min-height:360px !important;
  }

  .old-cube-box-container svg{
    height:360px !important;
  }
}




/* Packing system v2 */
.main{
  min-height:100vh !important;
  display:flex !important;
  flex-direction:column !important;
}
.app-footer{
  margin-top:auto !important;
  text-align:center !important;
  color:#475569 !important;
  font-weight:800 !important;
  padding:18px 0 8px !important;
}
.old-actions{
  align-items:center !important;
}


/* Packing system v2.1 */
.reset-top-actions{
  margin-top:0 !important;
  margin-bottom:14px !important;
}
.reset-top-actions .old-btn.gray{
  background:#475569 !important;
}
#generateArea{
  margin-top:14px !important;
}


/* Packing system v2.2 */
.reset-top-actions{
  display:flex !important;
  gap:10px !important;
  flex-wrap:wrap !important;
  align-items:stretch !important;
  margin-bottom:14px !important;
}
.reset-top-actions .old-btn{
  min-width:132px !important;
  height:46px !important;
  padding:0 18px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  line-height:1 !important;
  font-size:15px !important;
  border-radius:12px !important;
}
.app-footer{
  margin-top:auto !important;
  text-align:center !important;
  color:#475569 !important;
  font-weight:400 !important;
  font-size:12px !important;
  line-height:1.4 !important;
  padding:14px 0 6px !important;
}


/* Packing system v2.3 */
.old-input-page{
  width:1220px !important;
  max-width:100% !important;
}
.old-input-page .old-card{
  width:1220px !important;
  max-width:100% !important;
  margin:0 auto !important;
}
.reset-top-actions{
  display:flex !important;
  gap:10px !important;
  flex-wrap:wrap !important;
  align-items:stretch !important;
  margin-bottom:14px !important;
}
.reset-top-actions .old-btn,
.reset-prs-field select{
  min-width:132px !important;
  height:46px !important;
  padding:0 18px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  line-height:1 !important;
  font-size:15px !important;
  border-radius:12px !important;
}
.reset-prs-field{
  display:flex !important;
  align-items:center !important;
  gap:8px !important;
  font-weight:900 !important;
}
.reset-prs-field select{
  border:1px solid #93c5fd !important;
  background:linear-gradient(180deg,#fff,#eff6ff) !important;
  color:#1e3a8a !important;
  font-weight:900 !important;
}
.old-meta-grid{
  width:100% !important;
}
.old-table-wrap{
  width:100% !important;
}
@media(max-width:900px){
  .old-input-page,
  .old-input-page .old-card{
    width:100% !important;
  }
  .reset-prs-field{
    width:100% !important;
  }
  .reset-prs-field select{
    flex:1 !important;
  }
}


/* Packing system v2.4 */
.settings-box select.settings-select{
  border:1px solid #cbd5e1 !important;
  border-radius:10px !important;
  padding:11px 12px !important;
  font-size:16px !important;
  background:#fff !important;
  font-weight:800 !important;
}
.old-input-table{
  min-width:1280px !important;
}
#inputTable{
  min-width:1280px !important;
}
.old-table-wrap{
  max-width:100% !important;
  overflow:auto !important;
}

/* Packing system v3 */
.sidebar{transform:translateX(-105%) !important;transition:transform .28s ease,opacity .28s ease !important;opacity:0 !important}
.sidebar.active{transform:translateX(0) !important;opacity:1 !important}
.sidebar-backdrop{display:block !important;opacity:0 !important;pointer-events:none !important;transition:opacity .28s ease !important}
.sidebar-backdrop.active{opacity:1 !important;pointer-events:auto !important}
.main{margin-left:0 !important;width:100% !important}
.menu-btn{display:inline-flex !important;align-items:center !important;justify-content:center !important}
.v3-control-panel{display:grid !important;grid-template-columns:repeat(4,minmax(160px,1fr)) !important;gap:10px !important;margin:0 0 14px !important}
.v3-control-panel label{display:grid !important;gap:6px !important;font-weight:900 !important}
.v3-control-panel select,.v3-meta-grid input,.v3-meta-grid select{border:1px solid #cbd5e1 !important;border-radius:10px !important;padding:10px 12px !important;font-size:16px !important;background:#fff !important}
.old-input-table,#inputTable{min-width:1280px !important}
@media(max-width:900px){.v3-control-panel{grid-template-columns:1fr !important}}


/* Packing system v3.1 layout fix */
.v3-control-panel{
  grid-template-columns:minmax(160px,1fr) 95px 95px minmax(260px,2fr) !important;
  align-items:end !important;
}

#sizeStartInput,
#sizeEndInput{
  width:95px !important;
  min-width:95px !important;
}

.old-input-page,
.old-input-page .old-card{
  width:100% !important;
  max-width:1220px !important;
}

.old-table-wrap{
  width:100% !important;
  max-width:100% !important;
  overflow-x:hidden !important;
}

.old-input-table,
#inputTable{
  width:100% !important;
  min-width:0 !important;
  table-layout:fixed !important;
}

#inputTable th,
#inputTable td{
  font-size:15px !important;
  padding:3px !important;
}

#inputTable .input-cell{
  font-size:15px !important;
  min-width:0 !important;
}

@media(max-width:900px){
  .v3-control-panel{
    grid-template-columns:1fr 1fr !important;
  }

  .v3-control-panel label:first-child,
  .v3-control-panel label:last-child{
    grid-column:1 / -1 !important;
  }

  #sizeStartInput,
  #sizeEndInput{
    width:100% !important;
    min-width:0 !important;
  }

  .old-table-wrap{
    overflow-x:auto !important;
  }

  .old-input-table,
  #inputTable{
    min-width:980px !important;
    width:980px !important;
  }
}


.settings-wrap{padding:20px}
.settings-box{background:#fff;padding:20px;border-radius:20px}
.settings-top{display:flex;justify-content:space-between;align-items:center}
.settings-top button{padding:10px 20px;border:none;background:#2563eb;color:#fff;border-radius:10px}
.spec-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-top:20px}
.spec-card{background:#f8fafc;border-radius:16px;padding:12px;border:1px solid #ddd;cursor:pointer}
.thumb{width:100%;height:140px;object-fit:cover;border-radius:10px}
.spec-name{font-weight:800;margin-top:8px}
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:9999;align-items:center;justify-content:center}
.modal-box{background:#fff;width:min(700px,95vw);padding:20px;border-radius:20px}
.modal-box form{display:grid;gap:10px}
.modal-box input,.modal-box select{padding:10px;border-radius:10px;border:1px solid #ccc}
.btns{display:flex;gap:10px}


/* Packing system v4.1 - warehouse settings UI */
.warehouse-settings{
  padding:22px;
  max-width:1500px;
  margin:0 auto;
}

.settings-hero{
  background:linear-gradient(135deg,#ffffff 0%,#f5f8fc 55%,#eaf3ff 100%);
  border:1px solid #dbe6f4;
  border-radius:24px;
  padding:24px 28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  box-shadow:0 18px 40px rgba(15,23,42,.08);
}

.settings-hero .eyebrow{
  color:#2563eb;
  font-size:13px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.settings-hero h2{
  margin:6px 0 6px;
  font-size:30px;
  color:#0f172a;
  letter-spacing:.02em;
}

.settings-hero p{
  margin:0;
  color:#64748b;
  font-size:15px;
}

.warehouse-add-btn{
  border:0;
  border-radius:16px;
  background:#2563eb;
  color:#fff;
  padding:14px 24px;
  font-size:16px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 12px 22px rgba(37,99,235,.26);
}

.warehouse-add-btn:hover{
  transform:translateY(-1px);
  background:#1d4ed8;
}

.save-toast{
  margin:16px 0 0;
  background:#ecfdf5;
  color:#047857;
  border:1px solid #a7f3d0;
  border-radius:14px;
  padding:12px 16px;
  font-weight:800;
}

.save-toast.danger{
  background:#fff1f2;
  color:#be123c;
  border-color:#fecdd3;
}

.spec-list-card{
  margin-top:18px;
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:24px;
  box-shadow:0 16px 42px rgba(15,23,42,.08);
  padding:20px;
}

.list-title-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  margin-bottom:14px;
}

.list-title-row h3{
  margin:0;
  color:#0f172a;
  font-size:22px;
}

.list-title-row span{
  color:#64748b;
  font-size:14px;
}

.count-pill{
  background:#eff6ff;
  color:#1d4ed8;
  border:1px solid #bfdbfe;
  padding:8px 14px;
  border-radius:999px;
  font-weight:900;
}

.spec-table-wrap{
  overflow:auto;
  border:1px solid #e2e8f0;
  border-radius:18px;
}

.spec-table{
  width:100%;
  min-width:1120px;
  border-collapse:separate;
  border-spacing:0;
  font-family:Arial,"Microsoft JhengHei",sans-serif;
}

.spec-table th{
  background:#0f172a;
  color:#fff;
  padding:14px 12px;
  font-size:14px;
  text-align:left;
  white-space:nowrap;
}

.spec-table th:first-child{
  border-top-left-radius:16px;
}

.spec-table th:last-child{
  border-top-right-radius:16px;
}

.spec-table td{
  padding:12px;
  border-bottom:1px solid #e5e7eb;
  color:#334155;
  vertical-align:middle;
  font-size:14px;
}

.spec-table tbody tr{
  cursor:pointer;
  transition:.16s ease;
}

.spec-table tbody tr:hover{
  background:#f8fafc;
}

.spec-thumb{
  width:86px;
  height:62px;
  border-radius:12px;
  background:#f1f5f9;
  border:1px dashed #cbd5e1;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#94a3b8;
  font-size:11px;
  font-weight:900;
}

.spec-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.spec-main-name{
  color:#0f172a;
  font-size:16px;
  font-weight:900;
  margin-bottom:4px;
}

.spec-layer-text{
  color:#64748b;
  font-size:13px;
}

.layer-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:78px;
  padding:7px 10px;
  border-radius:999px;
  background:#fef3c7;
  color:#92400e;
  font-weight:900;
}

.modern-modal-bg{
  backdrop-filter:blur(4px);
}

.modern-modal{
  width:min(860px,94vw);
  background:#fff;
  border-radius:24px;
  padding:24px;
  box-shadow:0 24px 70px rgba(2,6,23,.28);
}

.modal-title-row{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  border-bottom:1px solid #e5e7eb;
  padding-bottom:14px;
  margin-bottom:18px;
}

.modal-title-row h3{
  margin:0;
  color:#0f172a;
  font-size:24px;
}

.modal-title-row p{
  margin:5px 0 0;
  color:#64748b;
  font-size:14px;
}

.modal-x{
  width:38px;
  height:38px;
  border:0;
  border-radius:12px;
  background:#f1f5f9;
  color:#0f172a;
  font-size:24px;
  cursor:pointer;
}

.spec-form{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.spec-form label{
  display:grid;
  gap:6px;
  color:#0f172a;
  font-weight:900;
  font-size:14px;
}

.spec-form .full{
  grid-column:1 / -1;
}

.spec-form input,
.spec-form select{
  border:1px solid #cbd5e1;
  border-radius:13px;
  padding:12px 13px;
  font-size:15px;
  outline:none;
  background:#fff;
}

.spec-form input:focus,
.spec-form select:focus{
  border-color:#2563eb;
  box-shadow:0 0 0 4px rgba(37,99,235,.12);
}

.file-field input{
  background:#f8fafc;
}

.modal-actions{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  padding-top:4px;
}

.modal-actions button{
  border:0;
  border-radius:13px;
  padding:12px 20px;
  font-weight:900;
  cursor:pointer;
}

.save-btn{
  background:#16a34a;
  color:#fff;
}

.delete-btn{
  background:#ef4444;
  color:#fff;
}

.cancel-btn{
  background:#475569;
  color:#fff;
}

@media(max-width:800px){
  .warehouse-settings{
    padding:12px;
  }
  .settings-hero{
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
  }
  .warehouse-add-btn{
    width:100%;
  }
  .spec-form{
    grid-template-columns:1fr;
  }
}


/* Packing system v4.3 - system user permissions */
.system-page{
  padding:22px;
  max-width:1500px;
  margin:0 auto;
}

.system-hero{
  background:linear-gradient(135deg,#ffffff 0%,#f8fafc 55%,#eef6ff 100%);
  border:1px solid #dbe6f4;
  border-radius:24px;
  padding:24px 28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  box-shadow:0 18px 40px rgba(15,23,42,.08);
}

.system-hero .eyebrow{
  color:#2563eb;
  font-size:13px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.system-hero h2{
  margin:6px 0 6px;
  font-size:30px;
  color:#0f172a;
}

.system-hero p{
  margin:0;
  color:#64748b;
  font-size:15px;
}

.status-ok{
  display:inline-flex;
  border-radius:999px;
  padding:6px 12px;
  background:#dcfce7;
  color:#166534;
  font-weight:900;
}

.status-stop{
  display:inline-flex;
  border-radius:999px;
  padding:6px 12px;
  background:#fee2e2;
  color:#991b1b;
  font-weight:900;
}

.log-btn{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  min-width:58px;
  padding:8px 12px;
  border-radius:999px;
  background:#0f172a;
  color:#fff !important;
  text-decoration:none;
  font-weight:900;
}

.check-line{
  display:flex !important;
  flex-direction:row !important;
  gap:8px !important;
  align-items:center !important;
  padding:12px;
  border:1px solid #e2e8f0;
  border-radius:13px;
  background:#f8fafc;
}

.permission-box{
  border:1px solid #dbe6f4;
  background:#f8fafc;
  border-radius:16px;
  padding:14px;
  display:grid;
  grid-template-columns:repeat(4,minmax(120px,1fr));
  gap:10px;
}

.permission-box h4{
  grid-column:1 / -1;
  margin:0 0 2px;
  color:#0f172a;
}

.permission-box label{
  display:flex !important;
  flex-direction:row !important;
  align-items:center;
  gap:8px;
  font-weight:800;
}

.log-modal{
  width:min(980px,95vw);
}

.log-list{
  max-height:60vh;
  overflow:auto;
  border:1px solid #e2e8f0;
  border-radius:16px;
}

.log-row{
  display:grid;
  grid-template-columns:170px 130px 1fr;
  gap:10px;
  padding:10px 12px;
  border-bottom:1px solid #e5e7eb;
  font-size:14px;
}

.log-row:nth-child(even){
  background:#f8fafc;
}

.log-time{
  color:#475569;
  font-weight:800;
}

.log-action{
  color:#1d4ed8;
  font-weight:900;
}

.log-detail{
  color:#0f172a;
}

@media(max-width:900px){
  .system-page{padding:12px;}
  .system-hero{flex-direction:column;align-items:flex-start;gap:14px;}
  .permission-box{grid-template-columns:1fr;}
  .log-row{grid-template-columns:1fr;}
}


/* Packing system v4.5 - image file name + preview */
.custom-file-row{
  display:flex;
  align-items:center;
  gap:10px;
  border:1px solid #cbd5e1;
  border-radius:13px;
  padding:8px 10px;
  background:#f8fafc;
}

.custom-file-row input[type="file"]{
  border:0 !important;
  background:transparent !important;
  padding:4px 0 !important;
  width:auto !important;
}

#selectedFileName{
  color:#334155;
  font-weight:800;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.image-preview-box{
  margin-top:4px;
  border:1px solid #dbe6f4;
  border-radius:16px;
  background:linear-gradient(180deg,#ffffff,#f8fafc);
  padding:14px;
  text-align:center;
}

.image-preview-title{
  font-weight:900;
  color:#0f172a;
  margin-bottom:10px;
}

.image-preview-box img{
  max-width:100%;
  max-height:260px;
  object-fit:contain;
  border-radius:14px;
  border:1px solid #e2e8f0;
  background:#fff;
  box-shadow:0 10px 22px rgba(15,23,42,.10);
}


/* Packing system v4.6 - invoice DB uploaded image */
.db-spec-image-wrap{
  width:100%;
  text-align:center;
  margin:28px auto 22px;
  padding:12px;
}

.db-spec-image-wrap img{
  max-width:820px;
  width:100%;
  max-height:520px;
  object-fit:contain;
  border-radius:16px;
  background:#fff;
  box-shadow:0 12px 32px rgba(15,23,42,.10);
}








/* Packing system v4.15 - clean A4 invoice print layout */



/* Packing system v4.16 - print exactly like invoice.php screen */
@media print{
  @page{
    size:A4 portrait;
    margin:8mm;
  }

  html,
  body{
    margin:0 !important;
    padding:0 !important;
    background:#fff !important;
    -webkit-print-color-adjust:exact !important;
    print-color-adjust:exact !important;
  }

  body *{
    visibility:hidden !important;
  }

  .old-sheet,
  .old-sheet *{
    visibility:visible !important;
  }

  .topbar,
  .sidebar,
  .sidebar-backdrop,
  .old-actions,
  .no-print,
  .app-footer{
    display:none !important;
    visibility:hidden !important;
  }

  .app-shell,
  .main,
  .old-page-shell,
  .old-invoice-page,
  .old-card{
    display:block !important;
    width:100% !important;
    max-width:none !important;
    margin:0 !important;
    padding:0 !important;
    background:#fff !important;
    box-shadow:none !important;
    border:0 !important;
    overflow:visible !important;
  }

  .old-sheet{
    position:absolute !important;
    top:0 !important;
    left:50% !important;
    transform:translateX(-50%) scale(.73) !important;
    transform-origin:top center !important;
    width:1000px !important;
    max-width:1000px !important;
    margin:0 auto !important;
    padding:0 !important;
    background:#fff !important;
    box-shadow:none !important;
    border:0 !important;
    overflow:visible !important;
  }

  .old-doc-title{
    white-space:normal !important;
    overflow-wrap:break-word !important;
    word-break:normal !important;
    text-align:center !important;
  }

  .mobile-size-cards{
    display:none !important;
  }

  .old-summary-area,
  .old-mini-table-wrap,
  .old-mini-table{
    display:block !important;
    visibility:visible !important;
    width:100% !important;
    opacity:1 !important;
  }

  .old-mini-table-wrap{
    margin:0 auto 18px !important;
  }

  .old-orientation{
    display:flex !important;
    flex-direction:row !important;
    align-items:flex-start !important;
    justify-content:center !important;
    gap:26px !important;
    width:100% !important;
    margin:34px auto 22px !important;
    padding:0 !important;
    page-break-inside:avoid !important;
    break-inside:avoid !important;
  }

  .old-face-card{
    flex:0 0 auto !important;
    width:auto !important;
    max-width:none !important;
    margin:0 !important;
    padding:0 !important;
    transform:none !important;
  }

  .old-face-row{
    display:flex !important;
    flex-direction:row !important;
    align-items:flex-start !important;
    justify-content:center !important;
    width:auto !important;
  }

  .old-block{
    width:auto !important;
    max-width:none !important;
    min-width:0 !important;
    transform:none !important;
  }

  .old-cell{
    font-size:inherit !important;
  }

  .db-spec-image-wrap{
    display:flex !important;
    justify-content:center !important;
    align-items:center !important;
    width:100% !important;
    margin:24px auto 18px !important;
    padding:0 !important;
    text-align:center !important;
    page-break-inside:avoid !important;
    break-inside:avoid !important;
  }

  .db-spec-image-wrap img{
    display:block !important;
    max-width:820px !important;
    max-height:420px !important;
    width:auto !important;
    height:auto !important;
    object-fit:contain !important;
    margin:0 auto !important;
    border:0 !important;
    box-shadow:none !important;
    background:#fff !important;
  }

  .old-sheet img[src=""],
  .old-sheet img:not([src]){
    display:none !important;
    visibility:hidden !important;
  }

  a[href]:after{
    content:"" !important;
  }
}


/* v4.18 print mini table restore */
@media print{

  .old-summary-area{
    display:block !important;
    visibility:visible !important;
    opacity:1 !important;
    width:100% !important;
    margin:0 auto 18px !important;
    page-break-inside:avoid !important;
  }

  .old-mini-table-wrap{
    display:block !important;
    visibility:visible !important;
    opacity:1 !important;
    width:100% !important;
    margin:0 auto 18px !important;
    overflow:visible !important;
  }

  .old-mini-table{
    display:table !important;
    visibility:visible !important;
    opacity:1 !important;
    width:100% !important;
    border-collapse:collapse !important;
  }

  .old-mini-table thead,
  .old-mini-table tbody,
  .old-mini-table tr,
  .old-mini-table th,
  .old-mini-table td{
    visibility:visible !important;
    opacity:1 !important;
  }

}

/* v4.20 invoice print fixed inline in invoice.php */




/* v7: middle three-face layer rows follow settings.php Layers 7~12 */
.old-block[data-layer-mode]{
  grid-template-rows:repeat(var(--packing-layer-count, 8),36px) !important;
}








/* v7.4 REAL modal-bg/modal-box inner scroll fix */
html.modal-lock,body.modal-lock{overflow:hidden!important;height:100%!important;}
.modal-bg.modern-modal-bg,#modalBg{
  position:fixed!important;
  inset:0!important;
  width:100vw!important;
  height:100vh!important;
  overflow:hidden!important;
  align-items:center!important;
  justify-content:center!important;
  padding:16px!important;
  box-sizing:border-box!important;
}
.modal-box.modern-modal,#modalBg>.modal-box{
  max-height:calc(100vh - 40px)!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  overscroll-behavior:contain!important;
  -webkit-overflow-scrolling:touch!important;
  box-sizing:border-box!important;
}
.modal-box.modern-modal .modal-actions,#modalBg .modal-actions{
  position:sticky!important;
  bottom:0!important;
  z-index:999!important;
  background:#fff!important;
  padding:14px 0 0!important;
  margin-top:16px!important;
  box-shadow:0 -12px 24px rgba(255,255,255,.96)!important;
}
.modal-box.modern-modal img,#modalBg img{
  max-width:100%!important;
  max-height:240px!important;
  object-fit:contain!important;
}


/* v7.7 Color settings button */
.settings-action-stack{
  display:flex !important;
  flex-direction:column !important;
  gap:10px !important;
  align-items:stretch !important;
}
.color-settings-btn{
  border:0 !important;
  border-radius:14px !important;
  padding:12px 18px !important;
  background:#0f172a !important;
  color:#fff !important;
  font-weight:900 !important;
  cursor:pointer !important;
  box-shadow:0 10px 22px rgba(15,23,42,.18) !important;
}
.color-settings-btn:hover{
  filter:brightness(1.08) !important;
}
.color-modal-box{
  max-width:620px !important;
}


/* v9 dynamic PRS columns for invoice three-face layout */
.old-block[data-prs-count]{grid-template-columns:repeat(var(--packing-col-count,4),72px)!important;}
.old-block.old-mid[data-prs-count]{grid-template-columns:repeat(var(--packing-col-count,3),88px)!important;}
.prs-badge{background:#e0f2fe!important;color:#075985!important;}
