/* Hambelela Organic — Wholesale Portal Styles */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400&family=DM+Sans:wght@300;400;500;600&display=swap');

:root{
  --ws-white:  #FFFFFF;
  --ws-paper:  #F8F6F1;
  --ws-paper2: #F0EDE6;
  --ws-sage:   #6B8F71;
  --ws-sage-d: #4A6B50;
  --ws-sage-bg:#EEF4EF;
  --ws-amber:  #C4973A;
  --ws-amber-l:#F5EDD8;
  --ws-char:   #2A2A2A;
  --ws-text:   #3A3A3A;
  --ws-muted:  #7A7A72;
  --ws-border: #E0DAD0;
  --ws-red:    #B85450;
  --ws-green:  #4A6B50;
  --ws-ff-d:   'Cormorant Garamond', Georgia, serif;
  --ws-ff:     'DM Sans', system-ui, sans-serif;
}

.ws-page{font-family:var(--ws-ff);color:var(--ws-text);max-width:1100px;margin:0 auto;padding:32px 20px 60px;}

/* ── ALERTS ──────────────────────────────────────────────────── */
.ws-alert{padding:12px 16px;border-radius:6px;font-size:13px;margin-bottom:14px;}
.ws-alert-success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0;}
.ws-alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca;}
.ws-notice{padding:14px 18px;border-radius:6px;font-size:13px;margin:12px 0;}
.ws-notice-warn{background:var(--ws-amber-l);border:1px solid var(--ws-amber);color:var(--ws-char);}
.ws-notice-info{background:var(--ws-sage-bg);border:1px solid var(--ws-sage);color:var(--ws-char);}
.ws-empty{color:var(--ws-muted);font-size:13px;padding:20px 0;}
.ws-loading{color:var(--ws-muted);font-size:13px;padding:20px 0;}

/* ── CARD ────────────────────────────────────────────────────── */
.ws-card{background:var(--ws-white);border:1px solid var(--ws-border);border-radius:10px;padding:32px;}
.ws-card-narrow{max-width:560px;margin:0 auto;}
.ws-card-head{text-align:center;margin-bottom:28px;}
.ws-logo{font-size:40px;margin-bottom:12px;}
.ws-card-head h2{font-family:var(--ws-ff-d);font-size:26px;font-weight:400;color:var(--ws-char);}
.ws-card-head p{font-size:12px;color:var(--ws-muted);margin-top:4px;letter-spacing:.5px;}

/* ── FORM ────────────────────────────────────────────────────── */
.ws-field{margin-bottom:14px;}
.ws-field label{display:block;font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--ws-muted);margin-bottom:5px;}
.ws-field input,.ws-field select,.ws-field textarea,.ws-inp{
  width:100%;border:1px solid var(--ws-border);border-radius:6px;
  padding:10px 13px;font-family:var(--ws-ff);font-size:13px;color:var(--ws-text);
  background:var(--ws-paper);outline:none;transition:border .15s;
}
.ws-field input:focus,.ws-field select:focus,.ws-field textarea:focus,.ws-inp:focus{border-color:var(--ws-sage);}
.ws-field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.ws-form-note{font-size:11px;color:var(--ws-muted);text-align:center;margin-top:14px;line-height:1.5;}
.ws-divider{height:1px;background:var(--ws-border);margin:20px 0;}

/* ── BUTTONS ─────────────────────────────────────────────────── */
.ws-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:10px 18px;border-radius:6px;font-family:var(--ws-ff);
  font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;
  cursor:pointer;border:none;text-decoration:none;transition:all .15s;
}
.ws-btn-primary{background:var(--ws-sage);color:#fff;}
.ws-btn-primary:hover{background:var(--ws-sage-d);}
.ws-btn-ghost{background:transparent;border:1px solid var(--ws-border);color:var(--ws-text);}
.ws-btn-ghost:hover{background:var(--ws-paper2);}
.ws-btn-wa{background:#25D366;color:#fff;}
.ws-btn-wa:hover{background:#1fba5a;}
.ws-btn-full{width:100%;}
.ws-btn-sm{padding:6px 12px;font-size:10px;}

/* ── DASHBOARD ───────────────────────────────────────────────── */
.ws-dash-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 0 24px;border-bottom:1px solid var(--ws-border);margin-bottom:28px;
}
.ws-dash-welcome{display:flex;align-items:center;gap:14px;}
.ws-dash-logo{font-size:32px;}
.ws-dash-welcome h2{font-family:var(--ws-ff-d);font-size:24px;font-weight:400;color:var(--ws-char);}
.ws-dash-welcome p{font-size:11px;color:var(--ws-muted);letter-spacing:1px;text-transform:uppercase;}

.ws-dash-nav{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:32px;}
.ws-nav-card{
  background:var(--ws-white);border:1px solid var(--ws-border);border-radius:10px;
  padding:24px 16px;text-align:center;text-decoration:none;
  transition:all .15s;display:flex;flex-direction:column;align-items:center;gap:10px;
}
.ws-nav-card:hover{border-color:var(--ws-sage);background:var(--ws-sage-bg);transform:translateY(-2px);box-shadow:0 4px 16px rgba(107,143,113,.12);}
.ws-nav-icon{font-size:28px;}
.ws-nav-label{font-size:11px;font-weight:600;letter-spacing:.5px;color:var(--ws-text);}

.ws-section{background:var(--ws-white);border:1px solid var(--ws-border);border-radius:10px;padding:24px;margin-bottom:20px;}
.ws-section-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.ws-section-title{font-family:var(--ws-ff-d);font-size:18px;font-weight:400;color:var(--ws-char);}

.ws-reorder-card{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 0;border-bottom:1px solid var(--ws-border);
}
.ws-reorder-card:last-child{border-bottom:none;}
.ws-reorder-info{font-size:13px;color:var(--ws-text);}

.ws-lists-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.ws-list-card{border:1px solid var(--ws-border);border-radius:8px;padding:16px;background:var(--ws-paper);}
.ws-list-name{font-weight:600;font-size:13px;color:var(--ws-char);margin-bottom:4px;}
.ws-list-meta{font-size:11px;color:var(--ws-muted);margin-bottom:12px;}
.ws-list-actions{display:flex;gap:8px;}

/* ── CATALOGUE PAGE ──────────────────────────────────────────── */
.ws-cat-toolbar{
  display:flex;align-items:flex-start;justify-content:space-between;
  margin-bottom:12px;flex-wrap:wrap;gap:12px;
}
.ws-cat-info h2{font-family:var(--ws-ff-d);font-size:26px;font-weight:400;color:var(--ws-char);}
.ws-cat-note{font-size:11px;color:var(--ws-amber);font-weight:600;margin-top:3px;}
.ws-cat-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.ws-search{
  border:1px solid var(--ws-border);border-radius:6px;
  padding:9px 14px;font-family:var(--ws-ff);font-size:12px;
  background:var(--ws-white);outline:none;width:200px;
}
.ws-search:focus{border-color:var(--ws-sage);}

.ws-terms-banner{
  background:var(--ws-amber-l);border:1px solid var(--ws-amber);border-radius:6px;
  padding:10px 18px;font-size:11px;font-weight:600;color:var(--ws-text);
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px;
}

.ws-cart-bar{
  position:sticky;top:0;z-index:50;
  background:var(--ws-char);color:#fff;
  padding:10px 20px;border-radius:8px;
  display:flex;align-items:center;gap:16px;margin-bottom:16px;
  font-size:12px;font-weight:600;
}
#ws-cart-total{flex:1;}

.ws-cat-section{margin-bottom:24px;}
.ws-cat-hdr{
  display:flex;align-items:baseline;gap:12px;
  padding:12px 0 10px;border-bottom:2px solid var(--ws-border);margin-bottom:0;
}
.ws-cat-line{display:inline-block;width:3px;height:20px;border-radius:2px;background:var(--ws-amber);flex-shrink:0;}
.ws-cat-name{font-family:var(--ws-ff-d);font-size:20px;font-weight:400;color:var(--ws-char);}
.ws-cat-count{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--ws-muted);}

/* Quick order table */
.ws-prod-table{border:1px solid var(--ws-border);border-top:none;}
.ws-prod-thead{
  display:grid;grid-template-columns:3fr 1fr 1.5fr 0.6fr 1.2fr 1fr;
  background:var(--ws-paper2);padding:8px 14px;
  font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--ws-muted);border-bottom:1px solid var(--ws-border);
  gap:10px;
}
.ws-prod-row{
  display:grid;grid-template-columns:3fr 1fr 1.5fr 0.6fr 1.2fr 1fr;
  padding:12px 14px;border-bottom:1px solid var(--ws-border);
  align-items:center;gap:10px;transition:background .1s;
}
.ws-prod-row:hover{background:var(--ws-paper);}
.ws-prod-row:last-child{border-bottom:none;}
.ws-prod-oos{opacity:.55;}
.ws-prod-name{font-weight:600;font-size:13px;color:var(--ws-char);line-height:1.3;}
.ws-prod-desc{font-size:10px;color:var(--ws-muted);margin-top:2px;line-height:1.4;}
.ws-prod-sku{font-size:10px;color:var(--ws-muted);}
.ws-prod-price strong{font-family:var(--ws-ff-d);font-size:15px;font-weight:600;color:var(--ws-char);}
.ws-prod-price-note{font-size:8px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--ws-muted);}
.ws-stock-dot{
  display:inline-block;font-size:9px;font-weight:600;letter-spacing:.5px;
  padding:2px 7px;border-radius:3px;margin-top:4px;
}
.ws-s-in  {background:#ecfdf5;color:#065f46;}
.ws-s-low {background:var(--ws-amber-l);color:#92400e;}
.ws-s-oos {background:#fef2f2;color:#991b1b;}
.ws-suggest{display:inline-block;font-size:9px;color:var(--ws-sage-d);font-weight:600;margin-left:8px;}
.ws-qty-cell{display:flex;align-items:center;}
.ws-qty-row{display:flex;align-items:center;gap:4px;}
.ws-q-btn{
  width:24px;height:24px;border-radius:50%;border:1px solid var(--ws-border);
  background:var(--ws-white);cursor:pointer;font-size:14px;font-weight:700;
  color:var(--ws-char);display:flex;align-items:center;justify-content:center;line-height:1;
}
.ws-q-val{font-size:12px;font-weight:700;min-width:20px;text-align:center;}
.ws-q-suggest{
  background:var(--ws-amber);color:#fff;border:none;border-radius:4px;
  padding:3px 6px;font-size:9px;font-weight:700;cursor:pointer;white-space:nowrap;
}
.ws-oos-label{font-size:11px;color:var(--ws-muted);}
.ws-line-total{font-size:12px;font-weight:600;text-align:right;color:var(--ws-char);}
.ws-status{display:inline-block;font-size:9px;font-weight:700;letter-spacing:.5px;padding:2px 8px;border-radius:3px;text-transform:capitalize;}
.ws-status-completed,.ws-status-processing{background:#ecfdf5;color:#065f46;}
.ws-status-pending{background:var(--ws-amber-l);color:#92400e;}
.ws-status-cancelled{background:#fef2f2;color:#991b1b;}
.ws-status-on-hold{background:#eff6ff;color:#1e40af;}

/* ── MODAL ───────────────────────────────────────────────────── */
.ws-modal{
  position:fixed;inset:0;background:rgba(0,0,0,.4);
  display:flex!important;align-items:center;justify-content:center;z-index:9999;
}
.ws-modal[style*="display:none"]{display:none!important;}
.ws-modal-box{
  background:var(--ws-white);border-radius:12px;
  padding:28px;width:600px;max-width:95vw;max-height:85vh;overflow-y:auto;
  box-shadow:0 20px 60px rgba(0,0,0,.2);
}
.ws-modal-box-sm{width:380px;}
.ws-modal-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;}
.ws-modal-hd h3{font-family:var(--ws-ff-d);font-size:20px;font-weight:400;color:var(--ws-char);}
.ws-modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--ws-muted);padding:2px 6px;}
.ws-order-tbl{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:12px;}
.ws-order-tbl th{text-align:left;font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--ws-muted);padding:6px 8px;border-bottom:1px solid var(--ws-border);}
.ws-order-tbl td{padding:8px 8px;border-bottom:1px solid var(--ws-border);}
.ws-totals-row{display:flex;justify-content:space-between;padding:6px 0;font-size:13px;color:var(--ws-text);border-bottom:1px solid var(--ws-border);}
.ws-totals-grand{font-weight:700;font-size:15px;color:var(--ws-char);border-bottom:none;padding-top:10px;}
.ws-order-msg{font-size:12px;}

/* ── TABLE ───────────────────────────────────────────────────── */
.ws-tbl{width:100%;border-collapse:collapse;font-size:13px;}
.ws-tbl th{text-align:left;font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--ws-muted);padding:10px 12px;border-bottom:2px solid var(--ws-border);background:var(--ws-paper2);}
.ws-tbl td{padding:12px 12px;border-bottom:1px solid var(--ws-border);}
.ws-tbl tr:hover td{background:var(--ws-paper);}

.ws-inv-list{display:flex;flex-direction:column;gap:10px;}
.ws-inv-card{
  display:grid;grid-template-columns:3fr 1.5fr 1.5fr 1fr;
  align-items:center;gap:16px;
  background:var(--ws-white);border:1px solid var(--ws-border);
  border-radius:8px;padding:16px 20px;
}

/* ── INVOICE DOCUMENT ────────────────────────────────────────── */
.ws-inv-actions{display:flex;gap:10px;margin-bottom:20px;}
.ws-inv-doc{
  background:var(--ws-white);border:1px solid var(--ws-border);
  border-radius:8px;padding:40px;max-width:794px;
}
.ws-inv-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid var(--ws-border);}
.ws-inv-brand{display:flex;gap:16px;align-items:flex-start;}
.ws-inv-logo{width:60px;height:60px;object-fit:contain;border-radius:6px;}
.ws-inv-logo-ph{width:60px;height:60px;background:var(--ws-sage-bg);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:24px;}
.ws-inv-company{font-family:var(--ws-ff-d);font-size:20px;font-weight:600;color:var(--ws-char);margin-bottom:4px;}
.ws-inv-addr{font-size:11px;color:var(--ws-muted);line-height:1.7;}
.ws-inv-meta{text-align:right;}
.ws-inv-title{font-family:var(--ws-ff-d);font-size:28px;font-weight:300;color:var(--ws-char);letter-spacing:2px;margin-bottom:16px;}
.ws-inv-meta-tbl td{font-size:12px;padding:3px 8px;color:var(--ws-text);}
.ws-inv-meta-tbl td:first-child{color:var(--ws-muted);padding-left:0;}
.ws-inv-parties{margin-bottom:28px;}
.ws-inv-party{font-size:12px;line-height:1.7;color:var(--ws-text);}
.ws-inv-party-label{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--ws-muted);margin-bottom:6px;}
.ws-inv-tbl{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:16px;}
.ws-inv-tbl th{background:var(--ws-paper2);padding:10px 12px;text-align:left;font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--ws-muted);border-bottom:1px solid var(--ws-border);}
.ws-inv-tbl td{padding:10px 12px;border-bottom:1px solid var(--ws-border);}
.ws-inv-tbl tfoot td{padding:8px 12px;border-bottom:1px solid var(--ws-border);}
.ws-inv-total-row td{font-size:15px;padding-top:12px!important;border-bottom:none!important;}
.ws-inv-footer{text-align:center;margin-top:32px;padding-top:20px;border-top:1px solid var(--ws-border);font-size:10px;color:var(--ws-muted);line-height:1.8;}

/* ── ORDERS / INVOICES PAGE ──────────────────────────────────── */
.ws-page-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;}
.ws-page-hdr h2{font-family:var(--ws-ff-d);font-size:26px;font-weight:400;color:var(--ws-char);}

/* ── PRINT ───────────────────────────────────────────────────── */
@media print{
  .ws-inv-actions,.ws-btn,.ws-dash-header a{display:none!important;}
  .ws-inv-doc{border:none;padding:0;max-width:100%;}
  body{font-size:11px;}
}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media(max-width:768px){
  .ws-dash-nav{grid-template-columns:1fr 1fr;}
  .ws-field-row{grid-template-columns:1fr;}
  .ws-prod-thead{display:none;}
  .ws-prod-row{grid-template-columns:1fr;padding:14px;}
  .ws-inv-head{flex-direction:column;gap:20px;}
  .ws-inv-meta{text-align:left;}
  .ws-lists-grid{grid-template-columns:1fr;}
}
