:root {
  --bg:#eef1f6; --panel:#fff; --border:#d0d5e0;
  --accent:#c07010; --accent2:#a83300;
  --text:#1c2233; --muted:#6b7280;
  --input-bg:#f5f7fa; --success:#1a7a52; --danger:#b93030;
}

*{margin:0;padding:0;box-sizing:border-box;}

body{
  background:var(--bg);
  color:var(--text);
  font-family:'Barlow',sans-serif;
  min-height:100vh;
  -webkit-user-select:none;
  user-select:none;
}

header{
  background:#1c2233;
  border-bottom:3px solid var(--accent);
  padding:0 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:62px;
  position:sticky;
  top:0;
  z-index:100;
  box-shadow:0 2px 10px rgba(0,0,0,.2);
}

.logo{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:25px;letter-spacing:2px;color:#f5a623;text-transform:uppercase;}
.logo span{color:#fff;}
.logo-sub{font-size:10px;letter-spacing:4px;color:#8899aa;text-transform:uppercase;margin-top:1px;}
.badge{background:var(--accent2);color:#fff;font-size:10px;font-weight:700;letter-spacing:2px;padding:4px 10px;text-transform:uppercase;border-radius:2px;}

/* Header Controls */
.header-controls {
  display: flex;
  align-items: center;
  gap: 10px;
}

.country-toggle {
  display: flex;
  gap: 5px;
}

.country-btn {
  padding: 6px 12px;
  background: transparent;
  border: 1px solid #444;
  color: #888;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1px;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.15s;
}

.country-btn.active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.country-btn:hover:not(.active) {
  border-color: var(--accent);
  color: var(--accent);
}

.back-btn {
  padding: 8px 16px;
  background: transparent;
  border: 1px solid #444;
  color: #888;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1px;
  cursor: pointer;
  border-radius: 4px;
  text-decoration: none;
  transition: all 0.15s;
}

.back-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.wrap{max-width:1100px;margin:0 auto;padding:28px 16px;display:flex;flex-direction:column;gap:20px;}

.row2{display:grid;grid-template-columns:340px 1fr;gap:20px;}
@media(max-width:760px){.row2{grid-template-columns:1fr;}}

/* Mode Tabs */
.mode-tabs {
  display: flex;
  gap: 8px;
  background: var(--panel);
  padding: 10px;
  border-radius: 6px;
  border: 1px solid var(--border);
}

.mode-tab {
  flex: 1;
  padding: 12px 16px;
  background: var(--input-bg);
  border: 1px solid var(--border);
  color: var(--muted);
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.15s;
}

.mode-tab.active {
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  border-color: var(--accent);
  color: #fff;
}

.mode-tab:hover:not(.active) {
  border-color: var(--accent);
  color: var(--accent);
}

.card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:6px;
  padding:22px;
  position:relative;
  overflow:hidden;
  box-shadow:0 1px 5px rgba(0,0,0,.06);
}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent2));}

.card-title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:18px;
  display:flex;
  align-items:center;
  gap:7px;
}

.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px;}
.field{display:flex;flex-direction:column;gap:5px;}

label{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);}
label em{font-style:normal;color:var(--accent);}

input[type=number],
input[type=text],
select {
  background:var(--input-bg);
  border:1.5px solid var(--border);
  color:var(--text);
  font-family:'Barlow Condensed',sans-serif;
  font-size:19px;
  font-weight:600;
  padding:9px 12px;
  border-radius:4px;
  width:100%;
  outline:none;
  transition:border-color .2s,box-shadow .2s;
  -moz-appearance:textfield;
}
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;}
input[type=number]:focus,
input[type=text]:focus,
select:focus {
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(192,112,16,.1);
  background:#fff;
}

.readonly-field {
  background: #e8e8e8;
  color: var(--muted);
}

select {
  cursor: pointer;
}

.divider{display:flex;align-items:center;gap:8px;margin:8px 0;color:var(--muted);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--border);}

.go{
  width:100%;
  padding:13px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  border:none;
  color:#fff;
  font-family:'Barlow Condensed',sans-serif;
  font-size:15px;
  font-weight:900;
  letter-spacing:3px;
  text-transform:uppercase;
  cursor:pointer;
  border-radius:4px;
  margin-top:6px;
  box-shadow:0 2px 8px rgba(192,112,16,.25);
  transition:opacity .2s;
}
.go:hover{opacity:.9;}

.btn-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 10px;
}

.view-btn {
  padding: 10px;
  background: linear-gradient(135deg, #1a7a52 0%, #145a3c 100%);
  border: none;
  color: #fff;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 4px;
  transition: opacity 0.2s;
}

.view-btn:hover {
  opacity: 0.9;
}

.rst{
  padding:10px;
  background:transparent;
  border:1px solid var(--border);
  color:var(--muted);
  font-family:'Barlow Condensed',sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  cursor:pointer;
  border-radius:4px;
  transition:all .15s;
}
.rst:hover{border-color:var(--accent);color:var(--accent);}

/* Quote List */
.quote-list {
  max-height: 300px;
  overflow-y: auto;
}

.empty-quote {
  text-align: center;
  padding: 40px 20px;
  color: var(--muted);
  font-size: 13px;
  letter-spacing: 1px;
}

.quote-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: var(--input-bg);
  border: 1px solid var(--border);
  border-radius: 4px;
  margin-bottom: 8px;
}

.quote-item-desc {
  flex: 1;
  font-size: 13px;
  font-weight: 500;
}

.quote-item-vol {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--accent);
}

.quote-item-remove {
  width: 24px;
  height: 24px;
  background: var(--danger);
  border: none;
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  border-radius: 4px;
  line-height: 1;
}

.quote-item-remove:hover {
  opacity: 0.8;
}

/* Quote Totals */
.quote-totals {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}

.total-row {
  display: flex;
  justify-content: space-between;
  padding: 6px 0;
  font-size: 13px;
}

.total-row.grand {
  font-weight: 700;
  font-size: 15px;
  color: var(--accent);
  border-top: 1px solid var(--border);
  margin-top: 8px;
  padding-top: 12px;
}

/* Summary Grid */
.sum-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px;}
.sum-grid-3{grid-template-columns:repeat(3,1fr);}
.sum-grid-5{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));}

@media(max-width:700px){
  .sum-grid{grid-template-columns:repeat(2,1fr);}
  .sum-grid-3{grid-template-columns:repeat(3,1fr);}
  .slabel{font-size:8px;letter-spacing:1px;}
  .sval{font-size:18px;}
  .smm{font-size:10px;}
}

.scard{background:var(--input-bg);border:1px solid var(--border);border-radius:4px;padding:12px 14px;position:relative;}
.scard.hi{border-color:var(--accent);background:#fff8ee;}

.slabel{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:4px;}
.sval{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:700;color:var(--text);line-height:1;}
.sval.ac{color:var(--accent);}
.smm{font-family:'Barlow Condensed',sans-serif;font-size:11px;color:var(--muted);margin-top:2px;}

/* Total Volume Box */
.total-volume-box {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 18px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: #fff;
  border-radius: 4px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 1px;
}

/* Bags Table */
#canadaBagsTable,
#usaBagsTable {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.bags-table {
  width: 100%;
  min-width: 400px;
  border-collapse: collapse;
  font-size: 13px;
}

.bags-table th,
.bags-table td {
  padding: 10px 8px;
  text-align: center;
  border-bottom: 1px solid var(--border);
}

.bags-table th {
  background: var(--input-bg);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--muted);
}

.bags-table td {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 16px;
  font-weight: 600;
}

.bags-table td:first-child {
  text-align: left;
  font-weight: 700;
  color: var(--muted);
}

.bags-table .total-col {
  background: #fff8ee;
  color: var(--accent);
  font-weight: 700;
}

/* Price Rows */
.price-row {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  font-size: 14px;
  border-bottom: 1px solid var(--border);
}

.price-row span:last-child {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700;
  color: var(--accent);
}

/* Grand Total Box */
.grand-total-box {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 20px;
  margin-top: 20px;
  background: linear-gradient(135deg, #1a7a52 0%, #145a3c 100%);
  color: #fff;
  border-radius: 4px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 2px;
}

/* Note */
.note{
  font-size:11px;
  color:var(--muted);
  line-height:1.6;
  padding:10px 14px;
  background:var(--input-bg);
  border-radius:4px;
  border:1px solid var(--border);
}

/* Ad Banners */
.ad-banner {
  background: linear-gradient(135deg, #2a2a2a 0%, #1a1a1a 100%);
  border: 1px dashed #444;
  color: #888;
  text-align: center;
  padding: 12px;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
}

.ad-top {
  margin-bottom: 0;
}

.ad-mid {
  margin: 20px 16px;
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
}

.ad-bottom {
  margin-top: 20px;
  padding: 16px;
  background: linear-gradient(135deg, #1c2233 0%, #0f1219 100%);
  border-color: var(--accent);
}

/* Save Button */
.save-btn {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: 14px;
  background: linear-gradient(135deg, #1a7a52 0%, #145a3c 100%);
  border: none;
  color: #fff;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 4px;
  box-shadow: 0 2px 8px rgba(26, 122, 82, 0.25);
  transition: opacity 0.2s;
  display: block;
}

.save-btn:hover {
  opacity: 0.9;
}

/* Hide mode inputs by default */
.mode-inputs {
  display: block;
}

/* App Footer */
.app-footer {
  background: #1c2233;
  border-top: 2px solid var(--accent);
  padding: 16px 24px;
  text-align: center;
  margin-top: 30px;
}

.footer-brand {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #f5a623;
  margin-bottom: 8px;
}

.footer-links {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.footer-links a {
  color: #8899aa;
  text-decoration: none;
  font-size: 12px;
  letter-spacing: 1px;
  transition: color 0.2s;
}

.footer-links a:hover {
  color: #f5a623;
}

.footer-divider {
  color: #444;
  font-size: 12px;
}

.footer-legal {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  margin-top: 8px;
}

.footer-legal a {
  color: #8899aa;
  text-decoration: none;
  font-size: 11px;
  letter-spacing: 1px;
  transition: color 0.2s;
}

.footer-legal a:hover {
  color: #f5a623;
}

/* ─── PARTNER ADS ─── */
.partner-supplier{background:#fff;border:1px solid #ddd;border-radius:10px;padding:16px;margin:10px 12px;display:none;align-items:center;gap:14px;box-shadow:0 1px 4px rgba(0,0,0,.06);}
.partner-supplier.active{display:flex;}
.partner-supplier img{width:70px;height:70px;object-fit:contain;border-radius:8px;border:1px solid #eee;}
.ps-info{flex:1;min-width:0;}
.ps-label{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#888;margin-bottom:2px;}
.ps-name{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;color:#1a1a1a;}
.ps-tagline{font-size:13px;color:#555;margin-top:2px;}
.ps-contact{font-size:13px;margin-top:6px;}
.ps-contact a{color:#d04a15;text-decoration:none;font-weight:600;}
.view-all-btn{display:none;width:calc(100% - 24px);margin:0 12px 10px;padding:12px;background:#fff;border:1px solid #ddd;border-radius:8px;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;color:#d04a15;cursor:pointer;text-align:center;letter-spacing:1px;}
.ps-all-card{background:#fff;border:1px solid #ddd;border-radius:10px;padding:14px;margin:8px 12px;display:flex;align-items:center;gap:14px;}
.ps-all-card img{width:60px;height:60px;object-fit:contain;border-radius:8px;border:1px solid #eee;}
