/* ══════════════════════════════════════════════════
   CIRCUL DESIGN SYSTEM v3 — shared across all dashboards
   ══════════════════════════════════════════════════ */
:root {
  --font: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --accent: #00e676;
  --accent-hover: #33eb8e;
  --accent-muted: rgba(0,230,118,0.1);
  --bg: #0a1a0f;
  --surface: #0d2818;
  --surface-alt: #0c1e0e;
  --nav-bg: rgba(10,26,15,0.95);
  --text-1: #e8f5e9;
  --text-2: #9ab8a0;
  --text-3: #7a9a7a;
  --border: #1a3a1a;
  --border-nav: #1a2e1a;
  --r-sm: 8px;
  --r-md: 12px;
  --gap: 24px;
  /* New semantic tokens — introduced in PR4-B for source-picker error/warning
     states. Prompt listed these in the reuse set but they didn't exist yet. */
  --surface-2: #11331f;
  --danger: #ff6b6b;
  --danger-bg: #3a1818;
  --warning: #ffb74d;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px}
body{font-family:var(--font);background:var(--bg);color:var(--text-1);min-height:100vh;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}

/* ── NAV ── */
nav{display:flex;align-items:center;padding:12px 24px;background:var(--nav-bg);border-bottom:1px solid var(--border-nav);position:sticky;top:0;z-index:100}
.nav-logo{display:flex;align-items:center;gap:8px;font-weight:700;font-size:1.1rem;color:var(--text-1)}
.nav-logo-icon{width:30px;height:30px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#000;font-size:13px;font-weight:900;flex-shrink:0}
.nav-spacer{flex:1}
.nav-right{display:flex;align-items:center;gap:16px}
.nav-pill{font-size:0.65rem;font-weight:700;letter-spacing:0.08em;padding:4px 10px;border-radius:20px;white-space:nowrap}
.nav-name{font-weight:600;font-size:0.9rem}
.nav-id{color:var(--text-3);font-size:0.8rem}
.nav-link{color:var(--text-2);font-size:0.85rem;white-space:nowrap}
.nav-link:hover{color:var(--text-1)}
.nav-logout{background:var(--accent);color:#000;border:none;padding:7px 18px;border-radius:20px;font-family:var(--font);font-size:0.8rem;font-weight:600;cursor:pointer;white-space:nowrap}
.nav-logout:hover{background:var(--accent-hover)}

/* ── PAGE ── */
.page{max-width:1200px;margin:0 auto;padding:var(--gap)}

/* ── HERO ── */
.hero{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--gap);gap:16px}
.hero-info{flex:1;min-width:0}
.hero-name{font-size:1.5rem;font-weight:800;margin-bottom:4px}
.hero-meta{color:var(--text-2);font-size:0.85rem;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.hero-meta .sep{color:var(--text-3)}
.badge{display:inline-block;font-size:0.65rem;font-weight:700;letter-spacing:0.08em;padding:3px 10px;border-radius:20px;background:var(--accent-muted);color:var(--accent)}
.stars{color:#ffd740}

/* ── STAT CARDS ── */
.stats{display:grid;gap:16px;margin-bottom:var(--gap)}
.stats-3{grid-template-columns:repeat(3,1fr)}
.stats-4{grid-template-columns:repeat(4,1fr)}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:14px 18px}
.stat-label{font-size:0.65rem;font-weight:600;letter-spacing:0.08em;color:var(--text-2);text-transform:uppercase;margin-bottom:4px}
.stat-val{font-size:1.4rem;font-weight:700}
.stat-val small{font-size:0.85rem;font-weight:400;color:var(--text-2)}

/* ── SECTION CARD ── */
.section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:20px;margin-bottom:var(--gap)}
.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:12px}
.section-title{font-size:0.95rem;font-weight:700}
.section-sub{font-size:0.75rem;color:var(--text-3);margin-top:2px}
.tabs{display:flex;gap:4px;flex-wrap:wrap}
.tab{padding:5px 12px;border-radius:20px;font-size:0.75rem;font-weight:600;border:1px solid var(--border);background:transparent;color:var(--text-2);cursor:pointer;font-family:var(--font);white-space:nowrap}
.tab.on{background:var(--accent);color:#000;border-color:var(--accent)}
.view-all{color:var(--text-3);font-size:0.8rem;cursor:pointer;white-space:nowrap}
.view-all-btn{background:none;border:none;color:var(--text-3);font-size:0.8rem;cursor:pointer;white-space:nowrap;padding:0;font-family:var(--font)}
.view-all-btn:hover{color:var(--text-1)}

/* ── TWO-COLUMN ── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:var(--gap)}
.two-col .section{margin-bottom:0}

/* ── TABLE ── */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse}
th{font-size:0.65rem;font-weight:600;letter-spacing:0.06em;color:var(--text-3);text-transform:uppercase;text-align:left;padding:8px 10px;border-bottom:1px solid var(--border);white-space:nowrap}
td{padding:10px;font-size:0.8rem;border-bottom:1px solid var(--border);vertical-align:middle}
.td-name{font-weight:600}
.td-green{color:var(--accent);font-weight:600}

/* ── PILLS ── */
.pill{display:inline-block;font-size:0.7rem;font-weight:600;padding:3px 8px;border-radius:10px;white-space:nowrap}
.pill-pet{background:#2196f326;color:#64b5f6}
.pill-hdpe{background:#4caf5026;color:#81c784}
.pill-ldpe{background:#ff980026;color:#ffb74d}
.pill-pp{background:#e91e6326;color:#f06292}
.pill-paid{background:rgba(0,230,118,0.15);color:#00e676}
.pill-sent{background:rgba(255,215,64,0.15);color:#ffd740}
.pill-pending{background:rgba(255,152,0,0.15);color:#ffb74d}

/* ── BUTTONS ── */
.btn{font-family:var(--font);font-size:0.8rem;padding:6px 14px;border-radius:var(--r-sm);border:1px solid var(--border);background:transparent;color:var(--text-2);cursor:pointer}
.btn:hover{border-color:var(--text-3);color:var(--text-1)}
.btn-green{background:var(--accent);color:#000;border:none;font-weight:600}
.btn-green:hover{background:var(--accent-hover)}
.btn-pending-grade{opacity:0.4;cursor:not-allowed}
.btn-ready{opacity:1;cursor:pointer}
.btn-primary{display:inline-flex;align-items:center;gap:6px;background:var(--accent);color:#000;font-family:var(--font);font-size:0.9rem;font-weight:700;padding:10px 20px;border:none;border-radius:var(--r-md);cursor:pointer;white-space:nowrap}
.btn-primary:hover{background:var(--accent-hover)}

/* ── PRICE CARDS ── */
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.price-card{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--r-md);padding:14px}
.pc-label{font-size:0.65rem;font-weight:700;letter-spacing:0.06em;color:var(--text-3);text-transform:uppercase;margin-bottom:4px}
.pc-name{font-weight:700;font-size:0.9rem;margin-bottom:6px}
.pc-row{display:flex;justify-content:space-between;font-size:0.8rem;padding:2px 0}
.pc-val{color:var(--accent);font-weight:600}
.pc-input{display:block;width:100%;margin-top:8px;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-family:var(--font);font-size:0.8rem}
.pc-input::placeholder{color:var(--text-3)}
.pc-input:focus{outline:none;border-color:var(--accent)}
.pc-post{display:block;width:100%;text-align:center;margin-top:6px;padding:8px;background:var(--accent);border:none;border-radius:var(--r-sm);color:#000;font-family:var(--font);font-weight:600;font-size:0.8rem;cursor:pointer}
.pc-post:hover{background:var(--accent-hover)}
.pc-inline{display:flex;gap:8px;margin-top:10px}
.pc-inline .pc-input{flex:1;margin:0}
.pc-inline .pc-post{width:auto;margin:0;padding:8px 16px}
.pc-sell{display:block;width:100%;text-align:center;margin-top:8px;padding:8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-family:var(--font);font-weight:600;font-size:0.8rem;cursor:pointer}
.pc-sell:hover{border-color:var(--text-3)}
.pc-footer{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:0.75rem;color:var(--text-3)}

/* ── FORMS ── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-group{display:flex;flex-direction:column}
.form-label{font-size:0.7rem;font-weight:600;letter-spacing:0.06em;color:var(--text-2);text-transform:uppercase;margin-bottom:5px}
.form-input,.form-select{width:100%;padding:9px 12px;background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-family:var(--font);font-size:0.8rem}
.form-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:32px;background:var(--surface-alt) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%237a9a7a' d='M5 6 0 0h10z'/></svg>") no-repeat right 12px center}
.form-input::placeholder{color:var(--text-3)}
.form-input:focus,.form-select:focus{outline:none;border-color:var(--accent)}
.form-submit{width:100%;padding:12px;background:var(--accent);color:#000;font-family:var(--font);font-size:0.9rem;font-weight:700;border:none;border-radius:var(--r-md);cursor:pointer}
.form-submit:hover{background:var(--accent-hover)}

/* ── EARNINGS / P&L ── */
.pl-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.pl-col-title{font-size:0.65rem;font-weight:600;letter-spacing:0.06em;color:var(--text-3);text-transform:uppercase;margin-bottom:10px}
.pl-row{display:flex;justify-content:space-between;padding:6px 0;font-size:0.8rem;border-bottom:1px solid var(--border)}
.pl-total{margin-top:8px;padding:10px 14px;background:var(--surface-alt);border-radius:var(--r-sm);display:flex;flex-direction:column;align-items:center;text-align:center;font-weight:700}
.pl-total-val{font-size:1.05rem;color:var(--accent);font-weight:800}

/* ── EMPTY STATE ── */
.empty{text-align:center;padding:32px 20px;color:var(--text-3);font-size:0.85rem}
.empty-icon{font-size:2rem;margin-bottom:8px;opacity:0.5}
.empty-action{font-size:0.9rem;color:var(--text-2);margin-bottom:4px}
.empty-hint{font-size:0.85rem;color:var(--text-3)}

/* ── SUBSECTIONS (deliveries) ── */
.sub{margin-bottom:14px}
.sub-title{font-size:0.8rem;font-weight:600;color:var(--text-1);margin-bottom:8px}
.sub-empty{padding:10px 12px;background:var(--surface-alt);border-radius:var(--r-sm);color:var(--text-3);font-size:0.8rem}

/* ── PASSPORT ── */
.passport-id{font-size:1rem;font-weight:700;margin-bottom:6px}
.passport-grid{display:grid;grid-template-columns:repeat(4,auto);gap:20px;margin:12px 0}
.passport-label{font-size:0.65rem;font-weight:600;letter-spacing:0.06em;color:var(--text-3);text-transform:uppercase}
.passport-val{font-size:0.85rem;margin-top:2px}
.passport-link{color:var(--accent);font-weight:600;font-size:0.85rem}

/* ── MOCKUP BANNER ── */
.banner{background:#1a0a2e;border-bottom:2px solid #b388ff;color:#e0c0ff;text-align:center;padding:8px;font-size:0.8rem;font-weight:600;letter-spacing:0.05em}

/* ── RATING CARD ── */
.rate-card{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--r-md);padding:14px}
.rate-name{font-weight:600;font-size:0.9rem}
.rate-stars{color:#ffd740;font-size:1rem;margin:4px 0}
.rate-meta{font-size:0.75rem;color:var(--text-3);margin-bottom:6px}
.rate-row{display:flex;gap:8px}
.rate-row input{flex:1;padding:7px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-family:var(--font);font-size:0.8rem}
.rate-row button{padding:7px 14px;background:var(--accent);color:#000;border:none;border-radius:var(--r-sm);font-family:var(--font);font-weight:600;font-size:0.8rem;cursor:pointer}

/* ══════════════════════════════════════════════════
   RESPONSIVE — Mobile ≤ 768px
   ══════════════════════════════════════════════════ */
@media(max-width:768px){
  nav{padding:10px 16px}
  .nav-name,.nav-id,.nav-pill{display:none}
  .nav-right{gap:12px}
  .page{padding:16px}
  .hero{flex-direction:column;gap:12px}
  .hero-name{font-size:1.25rem}
  .stats-3,.stats-4{grid-template-columns:1fr}
  .stat-val{font-size:1.2rem}
  .two-col{grid-template-columns:1fr}
  .price-grid{grid-template-columns:1fr 1fr}
  .form-grid{grid-template-columns:1fr}
  .pl-grid{grid-template-columns:1fr}
  .passport-grid{grid-template-columns:1fr 1fr}
  .section-head{flex-direction:column;align-items:flex-start;gap:8px}
  th,td{padding:8px 6px;font-size:0.75rem}
}

/* ── UTILITY ── */
.hidden{display:none!important}

/* ── TOAST ── */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--surface);border:1px solid var(--accent);border-radius:var(--r-md);padding:12px 24px;font-size:0.85rem;color:var(--text-1);z-index:300;opacity:0;transition:opacity 0.3s}
.toast.show{opacity:1}

/* ── NAV PILL ROLE COLORS ── */
.nav-pill-collector{background:#0f2a14;color:#00e676}
.nav-pill-aggregator{background:#0a2a28;color:#26c6da}
.nav-pill-processor{background:#0a1e2a;color:#42a5f5}
.nav-pill-recycler{background:#160d2e;color:#b388ff}
.nav-pill-converter{background:#2a0a1a;color:#f48fb1}
.nav-pill-admin{background:#1a1a2e;color:#e0e0e0}

/* ── STATUS PILLS (extend existing .pill) ── */
.pill-arrived{background:rgba(255,183,77,0.15);color:#ffb74d}
.pill-completed{background:rgba(0,230,118,0.15);color:#00e676}
.pill-rejected{background:rgba(239,83,80,0.15);color:#ef5350}
.pill-approved{background:rgba(66,165,245,0.15);color:#42a5f5}

/* ── RATING MODAL ── */
.rating-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);display:none;justify-content:center;align-items:center;z-index:200}
.rating-overlay.show{display:flex}
.rating-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:28px;width:100%;max-width:460px}
.rating-box h3{font-size:1rem;font-weight:700;margin-bottom:4px}
.rating-box .sub{font-size:0.8rem;color:var(--text-2);margin-bottom:16px}
.stars-row{display:flex;gap:8px;margin-bottom:18px}
.star-btn{font-size:1.6rem;cursor:pointer;color:var(--border);background:none;border:none;padding:0;transition:color 0.15s}
.star-btn.active,.star-btn:hover{color:#ffd740}
.rtag{display:inline-block;font-size:0.75rem;padding:5px 12px;border-radius:20px;border:1px solid var(--border);color:var(--text-2);background:transparent;cursor:pointer;font-family:var(--font);margin:0 6px 6px 0}
.rtag.selected{background:var(--accent-muted);border-color:var(--accent);color:var(--accent)}
.rtag.negative.selected{background:rgba(255,183,77,0.1);border-color:#ffb74d;color:#ffb74d}
.rating-note{width:100%;padding:8px 12px;background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-family:var(--font);font-size:0.8rem;resize:vertical;min-height:60px;margin-top:12px}
.rating-note::placeholder{color:var(--text-3)}
.rating-note:focus{outline:none;border-color:var(--accent)}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}
.btn-cancel{padding:8px 16px;border:1px solid var(--border);background:transparent;color:var(--text-2);border-radius:20px;font-family:var(--font);font-size:0.8rem;font-weight:600;cursor:pointer}
.btn-cancel:hover{border-color:var(--text-3);color:var(--text-1)}

/* ── COMPACT SUBMIT (top-right in section-head) ── */
.btn-submit{display:inline-flex;align-items:center;gap:6px;background:var(--accent);color:#000;font-family:var(--font);font-size:0.8rem;font-weight:700;padding:8px 20px;border:none;border-radius:20px;cursor:pointer;white-space:nowrap}
.btn-submit:hover{background:var(--accent-hover)}

/* ── COLLECTOR COUNTER BADGE ── */
.counter-badge{display:inline-flex;align-items:center;gap:6px;font-size:0.8rem;color:var(--text-2);background:var(--surface-alt);border:1px solid var(--border);border-radius:20px;padding:2px 12px 2px 8px}
.counter-badge strong{font-weight:800;color:var(--accent);font-size:0.95rem}

/* ── MESSAGE STATES ── */
.msg-error{color:#ef4444;font-size:0.8rem}
.msg-success{color:var(--accent);font-size:0.8rem}

/* ══════════════════════════════════════════
   PHASE C — JS inline style replacements
   ══════════════════════════════════════════ */

/* ── PLACEHOLDER CELL (loading / empty states in tables and grids) ── */
.placeholder-cell{color:var(--text-3);padding:20px;text-align:center}

/* ── PRICE SUB-SPAN (USD conversion, secondary price info) ── */
.price-sub{font-weight:400;font-size:0.74rem;color:var(--text-3)}

/* ── RATING PILL ── */
.rating-pill{display:inline-flex;align-items:center;gap:6px;background:rgba(255,179,0,0.08);border:1px solid rgba(255,179,0,0.25);border-radius:20px;padding:5px 14px 5px 10px;font-size:0.78rem;color:#ffb300;font-weight:600;cursor:pointer;transition:background 0.15s;text-decoration:none}
.rating-pill:hover{background:rgba(255,179,0,0.14)}
.rating-pill .dot{width:6px;height:6px;border-radius:50%;background:#ffb300;animation:ratingPulse 2s ease-in-out infinite}
@keyframes ratingPulse{0%,100%{opacity:1}50%{opacity:0.3}}

/* ── LABEL HINT (reset text-transform on sub-labels inside uppercase headings) ── */
.label-hint{text-transform:none;letter-spacing:0;font-weight:400}

/* ── GRADE SUB-LABEL (small helper text under grade buttons) ── */
.grade-sub{font-size:0.72rem;font-weight:400;color:var(--text-3)}

/* ── DANGER CONFIRM (red confirm button for rejections) ── */
.di-confirm-danger{padding:6px 14px;background:#ef5350;color:#fff;border:none;border-radius:var(--r-sm);font-family:var(--font);font-size:0.75rem;font-weight:700;cursor:pointer}
.di-confirm-danger:hover{background:#e53935}

/* ── FADE OUT (animation helper) ── */
.fade-out{opacity:0;transition:opacity 0.3s}

/* ══════════════════════════════════════════
   PHASE B — extracted shared components
   ══════════════════════════════════════════ */

/* ── TAB PANEL ── */
.tab-panel{display:none}
.tab-panel.active{display:block}

/* ── TOAST ERROR VARIANT ── */
.toast-error{border-color:#ef5350}

/* ── DELIVERY CARD ── */
.del-card{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--r-md);padding:16px;margin-bottom:12px}
.del-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.del-title{font-size:0.9rem;font-weight:700;color:var(--text-1)}
.del-meta{font-size:0.75rem;color:var(--text-2)}
.del-price{font-size:0.95rem;font-weight:700;color:var(--accent)}
.del-actions{display:flex;gap:8px;margin-top:10px}

/* ── DELIVERY INLINE FORM ── */
.del-inline-form{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}

/* ── ORDER CARD ── */
.order-card{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--r-md);padding:16px;margin-bottom:12px}
.order-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
.order-title{font-size:0.9rem;font-weight:700;color:var(--text-1)}
.order-meta{font-size:0.75rem;color:var(--text-2);margin-bottom:6px}
.order-price{font-size:0.95rem;font-weight:700;color:var(--accent)}
.order-specs{font-size:0.75rem;color:var(--text-2);margin-top:4px}

/* ── DISPATCH INLINE FORM (.di-*) ── */
.di-label{font-size:0.75rem;color:var(--text-2);margin-bottom:6px;display:block}
.di-input{width:100%;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-family:var(--font);font-size:0.8rem}
.di-input:focus{outline:none;border-color:var(--accent)}
.di-textarea{width:100%;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-family:var(--font);font-size:0.8rem;resize:vertical;min-height:48px}
.di-textarea:focus{outline:none;border-color:var(--accent)}
.di-actions{display:flex;gap:8px;margin-top:10px}
.di-confirm{padding:6px 14px;background:var(--accent);color:#000;border:none;border-radius:var(--r-sm);font-family:var(--font);font-size:0.75rem;font-weight:700;cursor:pointer}
.di-confirm:hover{background:var(--accent-hover)}
.di-cancel{padding:6px 14px;background:transparent;color:var(--text-2);border:1px solid var(--border);border-radius:var(--r-sm);font-family:var(--font);font-size:0.75rem;cursor:pointer}
.di-cancel:hover{border-color:var(--text-3);color:var(--text-1)}
.di-msg{font-size:0.75rem;margin-top:6px}

/* ── BADGE COLOURS ── */
.badge-blue{background:rgba(66,165,245,0.15);color:#42a5f5}
.badge-green{background:rgba(0,230,118,0.15);color:#00e676}
.badge-amber{background:rgba(255,183,77,0.15);color:#ffb74d}
.badge-gray{background:rgba(158,158,158,0.15);color:#9e9e9e}

/* ── LOG ARRIVAL BUTTON ── */
.btn-log-arrival{padding:6px 12px;background:rgba(0,230,118,0.12);color:var(--accent);border:1px solid var(--accent);border-radius:var(--r-sm);font-family:var(--font);font-size:0.7rem;font-weight:600;cursor:pointer;white-space:nowrap}
.btn-log-arrival:hover{background:rgba(0,230,118,0.22)}

/* ── LOGIN OVERLAY (shared) ── */
.login-error{color:#ef4444;font-size:0.8rem;display:none;margin-top:8px;text-align:center}
.login-error.visible{display:block}

/* ── SPINNER ── */
.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 0.6s linear infinite;margin:0 auto}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── LOGIN OVERLAY (defensive fallback) ── */
.login-overlay.hidden{display:none}

/* ── RESPONSIVE — Narrow phones ≤ 480px ── */
@media(max-width:480px){
  .price-grid{grid-template-columns:1fr}
  .demo-grid{grid-template-columns:1fr}
  .stats-3,.stats-4{gap:8px}
  .card{padding:12px}
}

/* ── Safety-net: horizontal scroll for any overflowing table ── */
table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}

/* ── Value colour helpers ── */
.val-pos{color:var(--accent)}
.val-neg{color:#ef5350}

/* ── Tab toggle (Month/YTD) ── */
.tab-toggle{display:flex;gap:0;border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden}
.tab-toggle-btn{padding:5px 12px;font-family:var(--font);font-size:.72rem;font-weight:600;background:transparent;border:none;color:var(--text-3);cursor:pointer}
.tab-toggle-btn.active{background:var(--accent);color:var(--bg)}

/* ── P&L accordion ───────────────────── */
.pl-card{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden}
.pl-row{display:flex;justify-content:space-between;align-items:center;padding:11px 14px;border-top:1px solid var(--border);cursor:pointer;transition:background .15s}
.pl-row:first-child{border-top:none}
.pl-row:hover{background:rgba(255,255,255,.02)}
.pl-row-label{font-size:.82rem;color:var(--text-1);display:flex;align-items:center;gap:6px}
.pl-row-right{display:flex;align-items:center;gap:10px}
.pl-row-val{font-size:.85rem;font-weight:600;font-variant-numeric:tabular-nums}
.pl-chev{font-size:.6rem;color:var(--text-3);transition:transform .2s;display:inline-block}
.pl-chev.open{transform:rotate(90deg)}
.pl-row.divider{border-top:2px solid var(--border);cursor:default}
.pl-row.divider .pl-row-label{font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.3px;color:var(--text-2)}
.margin-pct{font-size:.72rem;color:var(--text-3);font-weight:500;font-variant-numeric:tabular-nums}
.trend{font-size:.62rem;font-weight:600;padding:1px 5px;border-radius:4px;white-space:nowrap}
.trend-up{background:rgba(0,230,118,.1);color:var(--accent)}
.trend-down{background:rgba(239,83,80,.1);color:#ef5350}
.trend-flat{background:rgba(255,255,255,.05);color:var(--text-3)}

/* Level 2 — subcategories */
.pl-sub{background:rgba(0,0,0,.15);border-top:1px solid var(--border)}
.pl-sub-row{display:flex;justify-content:space-between;align-items:center;padding:8px 14px 8px 28px;font-size:.78rem;cursor:pointer;transition:background .15s}
.pl-sub-row:hover{background:rgba(255,255,255,.02)}
.pl-sub-label{color:var(--text-2);display:flex;align-items:center;gap:5px}
.pl-sub-val{font-weight:600;font-variant-numeric:tabular-nums}
.pl-sub-total{display:flex;justify-content:space-between;padding:8px 14px 10px 28px;font-size:.75rem;color:var(--text-3);border-top:1px dashed var(--border)}

/* Level 3 — individual entries */
.pl-txns{background:rgba(0,0,0,.1);border-top:1px solid rgba(255,255,255,.04)}
.pl-txn{display:flex;justify-content:space-between;align-items:center;padding:6px 14px 6px 42px;font-size:.72rem}
.pl-txn-info{color:var(--text-3)}
.pl-txn-note{color:var(--text-2)}
.pl-txn-amount{font-weight:600;font-variant-numeric:tabular-nums}
.pl-txn-actions{display:flex;align-items:center;gap:8px}
.pl-txn-del{font-size:.65rem;color:var(--text-3);background:none;border:none;cursor:pointer;padding:2px 4px;opacity:.5}
.pl-txn-del:hover{opacity:1;color:#ef5350}

/* Delete confirmation */
.pl-del-confirm{background:rgba(239,83,80,.1);border-top:1px solid rgba(239,83,80,.15);padding:8px 14px 8px 42px;font-size:.72rem;display:flex;justify-content:space-between;align-items:center}
.pl-del-confirm-text{color:#ef5350}
.pl-del-confirm button{font-size:.68rem;font-family:var(--font);font-weight:600;padding:3px 10px;border-radius:4px;cursor:pointer;border:none}
.pl-del-yes{background:#ef5350;color:#fff}
.pl-del-no{background:transparent;color:var(--text-2);border:1px solid var(--border) !important}

/* P&L header with export */
.pl-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.pl-header-left{display:flex;align-items:center;gap:10px}
.btn-export{font-size:.7rem;font-family:var(--font);font-weight:600;padding:4px 10px;border:1px solid var(--border);border-radius:var(--r-sm);background:transparent;color:var(--text-3);cursor:pointer;display:flex;align-items:center;gap:4px}
.btn-export:hover{color:var(--text-1);border-color:var(--text-3)}

/* Empty state */
.pl-empty{text-align:center;padding:32px 20px}
.pl-empty-icon{font-size:2rem;margin-bottom:12px;opacity:.4}
.pl-empty-title{font-size:.85rem;font-weight:600;margin-bottom:6px}
.pl-empty-text{font-size:.75rem;color:var(--text-3);line-height:1.5;max-width:280px;margin:0 auto 16px}
.pl-empty-cta{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:var(--accent);color:var(--bg);border:none;border-radius:var(--r-sm);font-family:var(--font);font-size:.82rem;font-weight:600;cursor:pointer}

/* Offline indicator */
.pl-offline-bar{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 14px;background:rgba(255,183,77,.1);border-bottom:1px solid rgba(255,183,77,.15);font-size:.7rem;color:#ffb74d;font-weight:600}
.pl-offline-dot{width:6px;height:6px;border-radius:50%;background:#ffb74d;display:inline-block}
.pl-queued-badge{font-size:.6rem;font-weight:600;padding:1px 5px;border-radius:4px;background:rgba(255,183,77,.1);color:#ffb74d;margin-left:6px}

/* Log expense button */
.log-expense-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;margin-top:12px;padding:10px;background:rgba(0,230,118,.1);border:1px dashed var(--accent);border-radius:var(--r-sm);color:var(--accent);font-family:var(--font);font-size:.78rem;font-weight:600;cursor:pointer}

/* ── Log expense form ──────────────────── */
.pl-log-form{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--r-sm);padding:14px;margin-top:12px}
.pl-log-form-title{font-size:.8rem;font-weight:700;margin-bottom:10px}
.pl-form-row{display:flex;gap:10px}
.pl-form-field{margin-bottom:10px;flex:1}
.pl-form-field label{display:block;font-size:.72rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px}
.pl-form-field select,.pl-form-field input,.pl-form-field textarea{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-family:var(--font);font-size:.82rem;padding:8px 10px;box-sizing:border-box}
.pl-form-field input[type="date"]{color-scheme:dark}

/* Photo receipt */
.pl-photo-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--bg);border:1px dashed var(--border);border-radius:var(--r-sm);color:var(--text-2);font-family:var(--font);font-size:.78rem;cursor:pointer;width:100%}
.pl-photo-btn:hover{border-color:var(--text-3)}
.pl-photo-preview{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);font-size:.75rem;color:var(--text-2)}
.pl-photo-preview .remove{margin-left:auto;font-size:.65rem;color:var(--text-3);cursor:pointer;background:none;border:none}

/* Suggest category note */
.pl-suggest-note{font-size:.72rem;color:var(--text-3);margin-bottom:10px;line-height:1.4}

/* ── Admin: expense category approval ──── */
.admin-pending-card{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 14px;margin-bottom:10px}
.admin-pending-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.admin-pending-name{font-size:.85rem;font-weight:600}
.admin-pending-badge{font-size:.65rem;font-weight:600;text-transform:uppercase;padding:2px 8px;border-radius:99px}
.admin-pending-badge.pending{background:rgba(255,183,77,.1);color:#ffb74d}
.admin-pending-badge.approved{background:rgba(0,230,118,.1);color:var(--accent)}
.admin-pending-badge.rejected{background:rgba(239,83,80,.1);color:#ef5350}
.admin-pending-meta{font-size:.72rem;color:var(--text-3);margin-bottom:10px}
.admin-pending-actions{display:flex;gap:8px}
.admin-rename-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.admin-rename-row input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-family:var(--font);font-size:.78rem;padding:6px 10px}
.admin-rename-hint{font-size:.68rem;color:var(--text-3);white-space:nowrap}
.admin-reject-form{margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.admin-reject-form label{display:block;font-size:.72rem;color:#ef4444;margin-bottom:4px}
.admin-reject-form textarea{width:100%;box-sizing:border-box;background:var(--bg);border:1px solid rgba(239,83,80,.3);border-radius:var(--r-sm);color:var(--text-1);font-family:var(--font);font-size:.78rem;padding:8px 10px;resize:vertical;min-height:48px;margin-bottom:8px}
.admin-rejection-reason{font-size:.72rem;color:#ef4444;margin-top:4px;font-style:italic}
.admin-reviewed-card{opacity:.6}

/* ── Discovery ── */

/* Listing card */
.listing-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1rem;margin-bottom:0.75rem;transition:border-color 0.2s}
.listing-card:hover{border-color:var(--accent)}
.listing-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:0.5rem}
.listing-card-meta{display:flex;gap:1rem;font-size:0.85rem;color:var(--text-2);flex-wrap:wrap}
.listing-card-price{font-size:1.25rem;font-weight:700;color:var(--accent)}
.listing-card-price.make-offer{font-style:italic;font-size:0.95rem;color:var(--text-2)}

/* Offer thread */
.offer-thread{border-left:2px solid var(--border);padding-left:1rem;margin:0.75rem 0}
.offer-bubble{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:0.75rem;margin-bottom:0.5rem}
.offer-bubble.mine{border-color:var(--accent)}
.offer-bubble-header{display:flex;justify-content:space-between;font-size:0.8rem;color:var(--text-2);margin-bottom:0.25rem}
.final-offer-tag{display:inline-block;background:#ff980040;color:#ffb74d;font-size:0.7rem;font-weight:700;padding:2px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:0.05em}

/* Offer action buttons */
.offer-actions{display:flex;gap:0.5rem;margin-top:0.5rem}
.offer-actions .btn-accept{background:var(--accent);color:var(--bg);border:none;padding:6px 16px;border-radius:6px;font-weight:600;cursor:pointer;font-size:0.85rem}
.offer-actions .btn-reject{background:transparent;color:#ef5350;border:1px solid #ef5350;padding:6px 16px;border-radius:6px;font-weight:600;cursor:pointer;font-size:0.85rem}
.offer-actions .btn-counter{background:transparent;color:var(--accent);border:1px solid var(--accent);padding:6px 16px;border-radius:6px;font-weight:600;cursor:pointer;font-size:0.85rem}

/* Quantity bar (remaining vs original) */
.qty-bar{height:4px;background:var(--border);border-radius:2px;margin-top:0.5rem;overflow:hidden}
.qty-bar-fill{height:100%;background:var(--accent);border-radius:2px;transition:width 0.3s}

/* Filter bar */
.discovery-filters{display:flex;gap:0.5rem;flex-wrap:wrap;margin-bottom:1rem;align-items:center}
.discovery-filters .pill{cursor:pointer;transition:opacity 0.2s;opacity:0.5}
.discovery-filters .pill.active{opacity:1;box-shadow:0 0 0 2px currentColor}

/* Expiry badge */
.expiry-badge{font-size:0.75rem;padding:2px 8px;border-radius:4px}
.expiry-badge.expiring-soon{background:#ff980030;color:#ffb74d}
.expiry-badge.active{background:rgba(0,230,118,0.15);color:var(--accent)}

/* Offer count badge */
.offer-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;background:var(--accent);color:var(--bg);font-size:0.7rem;font-weight:700;border-radius:10px;padding:0 6px}

/* Discovery toast notifications */
.disc-toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:0.5rem;pointer-events:none}
.disc-toast{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:0.75rem 1rem;min-width:280px;max-width:400px;box-shadow:0 4px 12px rgba(0,0,0,0.3);pointer-events:auto;animation:disc-toast-in 0.3s ease,disc-toast-out 0.3s ease 4.7s forwards;display:flex;align-items:flex-start;gap:0.75rem}
.disc-toast.toast-success{border-color:var(--accent)}
.disc-toast.toast-warning{border-color:#ffb74d}
.disc-toast.toast-info{border-color:#64b5f6}
.disc-toast-icon{font-size:1.2rem;flex-shrink:0}
.disc-toast-body{flex:1}
.disc-toast-title{font-weight:600;font-size:0.85rem;margin-bottom:2px}
.disc-toast-message{font-size:0.8rem;color:var(--text-2)}
@keyframes disc-toast-in{from{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}
@keyframes disc-toast-out{from{opacity:1}to{opacity:0;transform:translateY(-10px)}}

/* ── Name Privacy ── */
.counterparty-code{display:block;font-size:0.65rem;color:var(--text-3);font-weight:500;margin-top:2px;letter-spacing:0.03em}
.counterparty-name-hidden{color:var(--text-3);font-style:italic}

/* ══════════════════════════════════════════════════
   Source Picker (PR4-B) — shared/source-picker.js
   Namespaced .sp-* to avoid collisions with dashboard styles.
   ══════════════════════════════════════════════════ */
.sp-root{display:block;margin-top:16px;padding-top:16px;border-top:1px dashed var(--border)}
.sp-head{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}
.sp-head-title{font-size:0.75rem;text-transform:uppercase;letter-spacing:0.08em;color:var(--text-3);font-weight:600}
.sp-head-sub{font-size:0.85rem;color:var(--text-1)}

.sp-lots{display:flex;flex-direction:column;gap:6px}
.sp-lot{display:grid;grid-template-columns:24px 1fr 140px;gap:12px;align-items:center;padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);transition:border-color 120ms,background 120ms}
.sp-lot:hover{border-color:var(--text-3)}
.sp-lot-picked{border-color:var(--accent);background:#0d3a25}
.sp-lot-error{border-color:var(--danger);background:var(--danger-bg)}
.sp-cb{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}
.sp-cb:disabled{cursor:not-allowed;opacity:0.5}
.sp-lot-meta{min-width:0}
.sp-lot-supplier{font-weight:600;font-size:0.85rem;color:var(--text-1)}
.sp-lot-line2{display:flex;gap:10px;flex-wrap:wrap;margin-top:3px;font-size:0.7rem;color:var(--text-2);align-items:center}
.sp-mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--text-3)}
.sp-tier-pill{display:inline-flex;align-items:center;font-size:0.6rem;padding:2px 7px;border-radius:999px;background:var(--bg);color:var(--text-3);text-transform:uppercase;letter-spacing:0.05em}
.sp-pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:0.65rem;font-weight:600;letter-spacing:0.05em;text-transform:uppercase}
.sp-pill-pet{background:rgba(33,150,243,0.15);color:#64b5f6}
.sp-pill-hdpe{background:rgba(255,152,0,0.15);color:#ffb74d}
.sp-pill-pp{background:rgba(156,39,176,0.15);color:#ce93d8}
.sp-pill-ldpe{background:rgba(76,175,80,0.15);color:#81c784}
.sp-alloc{display:flex;align-items:center;gap:6px;justify-self:end}
.sp-alloc-input{width:74px;text-align:right;background:var(--bg);border:1px solid var(--border);color:var(--text-1);padding:6px 8px;border-radius:var(--r-sm);font-size:0.8rem;font-family:var(--font)}
.sp-alloc-input:focus{outline:none;border-color:var(--accent)}
.sp-alloc-input:disabled{opacity:0.4;cursor:not-allowed}
.sp-alloc-unit{font-size:0.7rem;color:var(--text-3)}
.sp-lot-err{grid-column:1 / -1;font-size:0.7rem;color:var(--danger);margin-top:4px;padding-left:36px}

.sp-totals{margin-top:12px;padding:12px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);display:flex;justify-content:space-between;align-items:center;font-size:0.85rem}
.sp-totals-state{font-size:0.7rem;text-transform:uppercase;letter-spacing:0.08em;font-weight:600}
.sp-totals-num{font-weight:600}
.sp-totals-balanced{border-color:var(--accent)}
.sp-totals-balanced .sp-totals-state{color:var(--accent)}
.sp-totals-over,.sp-totals-under{border-color:var(--warning)}
.sp-totals-over .sp-totals-state,.sp-totals-under .sp-totals-state{color:var(--warning)}
.sp-totals-row_error,.sp-totals-sum_error{border-color:var(--danger)}
.sp-totals-row_error .sp-totals-state,.sp-totals-sum_error .sp-totals-state{color:var(--danger)}

.sp-inline-err{margin-top:10px;padding:10px 14px;background:var(--danger-bg);border:1px solid var(--danger);border-radius:var(--r-sm);font-size:0.8rem;line-height:1.5;color:var(--text-1)}
.sp-inline-err-title{color:var(--danger);font-weight:600;text-transform:uppercase;letter-spacing:0.05em;font-size:0.65rem;margin-bottom:4px}
.sp-inline-err-body{color:var(--text-1)}

.sp-footer{margin-top:12px;display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap}
.sp-footer-left{display:flex;gap:12px}
.sp-btn-link{background:none;border:none;color:var(--text-3);cursor:pointer;font-size:0.75rem;text-decoration:underline;padding:0;font-family:var(--font)}
.sp-btn-link:hover{color:var(--accent)}
.sp-legend{font-size:0.65rem;color:var(--text-3);display:flex;gap:14px;flex-wrap:wrap}
.sp-legend span::before{content:"• ";color:var(--accent)}

.sp-empty{margin-top:10px;padding:24px 18px;background:var(--surface-2);border:1px dashed var(--border);border-radius:var(--r-sm);text-align:center}
.sp-empty-title{font-weight:600;font-size:0.9rem;color:var(--text-1);margin-bottom:6px}
.sp-empty-body{font-size:0.8rem;color:var(--text-2);margin-bottom:12px;line-height:1.5;max-width:460px;margin-left:auto;margin-right:auto}
.sp-empty-cta{display:inline-block}
.sp-btn-cta{background:var(--accent);color:#000;border:none;padding:8px 16px;border-radius:999px;font-size:0.8rem;font-weight:600;cursor:pointer;font-family:var(--font)}
.sp-btn-cta:hover{background:var(--accent-hover)}

/* Loading skeleton */
.sp-skel{display:grid;grid-template-columns:24px 1fr 140px;gap:12px;align-items:center;padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:6px}
.sp-skel-col{display:flex;flex-direction:column;gap:5px;min-width:0}
.sp-skel-box{background:linear-gradient(90deg,var(--surface-2) 0%,var(--border) 50%,var(--surface-2) 100%);background-size:200% 100%;animation:sp-shimmer 1.4s linear infinite;border-radius:3px;height:12px}
.sp-skel-cb{width:16px;height:16px;border-radius:3px}
.sp-skel-md{width:55%;height:12px}
.sp-skel-lg{width:85%;height:9px}
.sp-skel-alloc{width:74px;height:24px;justify-self:end}
@keyframes sp-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Mobile: stack the lot row */
@media (max-width: 640px){
  .sp-lot,.sp-skel{grid-template-columns:24px 1fr}
  .sp-alloc,.sp-skel-alloc{grid-column:1 / -1;justify-self:flex-end;margin-top:6px;padding-left:36px}
  .sp-lot-err{padding-left:0}
}
