/* RoadCommand — style.css */

:root {
  --bg: #111312;
  --surface: #1c1f1c;
  --surface2: #252825;
  --border: rgba(255,255,255,0.16);
  --green: #5edc82;
  --green-dim: rgba(94,220,130,0.18);
  --green-border: rgba(94,220,130,0.45);
  --amber: #ffd04d;
  --amber-dim: rgba(255,208,77,0.16);
  --red: #ff7e7e;
  --red-dim: rgba(255,126,126,0.16);
  --blue: #7ab8ff;
  --blue-dim: rgba(122,184,255,0.16);
  --text: #f0f5f0;
  --muted: #a8b8a8;
  --font-body: 'Georgia', serif;
}
* { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html,body { height:100%; background:var(--bg); color:var(--text); font-family:var(--font-body); font-size:15px; overscroll-behavior:none; }

.app-header {
  background:var(--surface); border-bottom:1px solid var(--border);
  padding:.9rem 1.2rem; display:flex; justify-content:space-between; align-items:center;
  position:sticky; top:0; z-index:100;
}
.app-logo { font-size:1rem; font-weight:bold; color:var(--green); letter-spacing:.05em; }
.app-logo span { color:var(--text); font-weight:normal; font-size:.82rem; margin-left:.4rem; opacity:.5; }
.header-truck { font-size:.82rem; color:#b8c8b8; text-align:right; }
.header-truck strong { color:var(--amber); display:block; font-size:.82rem; }

.bottom-nav {
  position:fixed; bottom:0; left:0; right:0;
  background:var(--surface); border-top:1px solid var(--border);
  display:flex; z-index:100;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding-bottom:env(safe-area-inset-bottom);
  padding-right:10px;
}
.bottom-nav::-webkit-scrollbar { display:none; }
.bottom-nav::after {
  content:'';
  display:block;
  min-width:15px;
  flex-shrink:0;
}
.nav-btn {
  flex:0 0 auto;
  min-width:76px;
  display:flex; flex-direction:column; align-items:center;
  padding:.6rem .5rem; background:none; border:none; color:#ffd04d;
  font-size:.75rem; letter-spacing:.03em; text-transform:uppercase;
  cursor:pointer; gap:.28rem; font-family:var(--font-body); transition:color .15s;
  white-space:nowrap; font-weight:600;
  opacity:.7;
}
.nav-btn .nav-icon { font-size:1.25rem; line-height:1; }
.nav-btn.active { color:#ffd04d; border-top:2px solid #ffd04d; opacity:1; }
.nav-scroll-hint {
  position:fixed; bottom:0; right:0;
  width:28px;
  background:linear-gradient(to right, transparent, var(--surface));
  height:60px;
  z-index:101;
  pointer-events:none;
}

.main { padding:1rem 1rem 5.5rem; max-width:600px; margin:0 auto; }
.screen { display:none; }
.screen.active { display:block; }

.card { background:var(--surface); border:1px solid rgba(255,255,255,0.18); border-radius:4px; margin-bottom:.8rem; overflow:hidden; }
.card-header { padding:.9rem 1rem .6rem; display:flex; justify-content:space-between; align-items:center; border-bottom:1px solid var(--border); }
.card-title { font-size:.85rem; letter-spacing:.12em; text-transform:uppercase; color:var(--green); }
.card-body { padding:1rem; }

.dash-grid { display:grid; grid-template-columns:1fr 1fr; gap:.7rem; margin-bottom:.8rem; }
.metric { background:var(--surface); border:1px solid rgba(255,255,255,0.18); border-radius:4px; padding:.9rem; }
.metric-val { font-size:1.6rem; font-weight:bold; color:var(--green); line-height:1; margin-bottom:.2rem; }
.metric-val.amber { color:var(--amber); }
.metric-val.red { color:var(--red); }
.metric-label { font-size:.8rem; color:#b8c8b8; text-transform:uppercase; letter-spacing:.08em; }

.status-bar { background:var(--surface); border:1px solid var(--green-border); border-radius:4px; padding:.9rem 1rem; display:flex; justify-content:space-between; align-items:center; margin-bottom:.8rem; }
.status-dot { width:8px; height:8px; border-radius:50%; background:var(--green); margin-right:.5rem; animation:pulse 2s infinite; display:inline-block; }
@keyframes pulse { 0%,100%{opacity:1;}50%{opacity:.4;} }
.status-text { font-size:.82rem; color:var(--text); display:flex; align-items:center; }
.status-right { font-size:.82rem; color:#b8c8b8; }

/* LOAD CARDS */
.load-card { background:var(--surface); border:1px solid rgba(255,255,255,0.18); border-radius:4px; margin-bottom:.7rem; overflow:hidden; transition:border-color .15s; }
.load-card.hot { border-color:var(--green-border); }
.load-card.watch { border-color:rgba(251,191,36,.25); }
.load-card.booked { border-color:rgba(96,165,250,.25); }
.load-top { padding:.8rem 1rem; display:flex; justify-content:space-between; align-items:flex-start; }
.load-route { font-weight:bold; font-size:.95rem; color:var(--text); }
.load-route span { color:var(--green); }
.load-rate { font-size:1.1rem; font-weight:bold; color:var(--green); text-align:right; }
.load-rate-sub { font-size:.8rem; color:#b8c8b8; text-align:right; }
.load-meta { padding:0 1rem .8rem; display:grid; grid-template-columns:1fr 1fr 1fr; gap:.4rem; }
.lm-label { font-size:.68rem; color:#b8c8b8; text-transform:uppercase; letter-spacing:.06em; }
.lm-val { font-size:.8rem; color:var(--text); margin-top:.1rem; }

/* LOAD ACTIONS - now 4 buttons including CALL */
.load-actions { border-top:1px solid var(--border); display:flex; }
.load-action-btn {
  flex:1; padding:.6rem .3rem; background:none; border:none;
  border-right:1px solid var(--border); color:#b8c8b8;
  font-size:.8rem; letter-spacing:.04em; text-transform:uppercase;
  cursor:pointer; font-family:var(--font-body); transition:all .15s;
  display:flex; flex-direction:column; align-items:center; gap:.2rem;
}
.load-action-btn:last-child { border-right:none; }
.load-action-btn .btn-icon { font-size:.95rem; line-height:1; }
.load-action-btn.call-btn { color:var(--green); }
.load-action-btn.call-btn:hover { background:var(--green-dim); }
.load-action-btn.watch-btn:hover { color:var(--amber); }
.load-action-btn.calc-btn:hover { color:var(--blue); }
.load-action-btn.skip-btn:hover { color:var(--red); }
.load-action-btn.skip-btn { color:var(--red); }

.load-tag { font-size:.68rem; padding:.2rem .5rem; border-radius:100px; letter-spacing:.06em; font-weight:bold; text-transform:uppercase; }
.tag-hot { background:var(--green-dim); color:var(--green); border:1px solid var(--green-border); }
.tag-watch { background:var(--amber-dim); color:var(--amber); border:1px solid rgba(251,191,36,.25); }
.tag-booked { background:var(--blue-dim); color:var(--blue); border:1px solid rgba(96,165,250,.25); }

/* BROKER PHONE DISPLAY */
.broker-info { padding:.4rem 1rem .7rem; display:flex; align-items:center; gap:.5rem; }
.broker-phone { font-size:.85rem; color:var(--amber); }
.broker-name { font-size:.8rem; color:#b8c8b8; }

/* FORMS */
.form-group { margin-bottom:1rem; }
.form-label { font-size:.8rem; color:#b8c8b8; text-transform:uppercase; letter-spacing:.08em; margin-bottom:.4rem; display:block; }
.form-input, .form-select, .form-textarea {
  width:100%; background:var(--surface2); border:1px solid rgba(255,255,255,0.18);
  color:var(--text); padding:.7rem .9rem; border-radius:3px;
  font-family:var(--font-body); font-size:.9rem; -webkit-appearance:none;
}
.form-input:focus, .form-select:focus { outline:none; border-color:var(--green-border); }
.form-textarea { min-height:80px; resize:vertical; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:.7rem; }
.form-hint { font-size:.8rem; color:#b8c8b8; margin-top:.3rem; }

.btn { width:100%; padding:.8rem; border:none; border-radius:3px; font-family:var(--font-body); font-size:.85rem; font-weight:bold; letter-spacing:.05em; cursor:pointer; text-transform:uppercase; }
.btn-green { background:var(--green); color:#000; }
.btn-outline { background:transparent; border:1px solid var(--green-border); color:var(--green); }
.btn-sm { padding:.5rem .9rem; font-size:.8rem; width:auto; display:inline-block; }

.section-head { margin-bottom:.8rem; }
.section-label { font-size:.8rem; color:var(--green); letter-spacing:.12em; text-transform:uppercase; margin-bottom:.2rem; }
.section-title { font-size:1.1rem; font-weight:bold; letter-spacing:-.01em; }

/* STATE VOLUME TRACKER */
.state-controls { display:flex; gap:.5rem; margin-bottom:1rem; flex-wrap:wrap; }
.state-filter-btn { padding:.4rem .8rem; border:1px solid rgba(255,255,255,0.18); background:transparent; color:#b8c8b8; font-size:.68rem; letter-spacing:.06em; text-transform:uppercase; cursor:pointer; font-family:var(--font-body); border-radius:2px; }
.state-filter-btn.active { background:var(--green-dim); border-color:var(--green-border); color:var(--green); }

.state-list { display:flex; flex-direction:column; gap:.5rem; }
.state-row { background:var(--surface); border:1px solid rgba(255,255,255,0.18); border-radius:4px; padding:.9rem 1rem; }
.state-row.top-state { border-color:var(--green-border); background:var(--green-dim); }
.state-row.mid-state { border-color:rgba(251,191,36,.2); }
.state-top-line { display:flex; justify-content:space-between; align-items:center; margin-bottom:.5rem; }
.state-name { font-weight:bold; font-size:.95rem; }
.state-rank { font-size:.8rem; color:#b8c8b8; }
.state-rank.rank-1 { color:var(--green); font-weight:bold; }
.state-rank.rank-2 { color:var(--amber); }
.state-bar-wrap { background:var(--surface2); border-radius:100px; height:6px; margin-bottom:.5rem; overflow:hidden; }
.state-bar { height:100%; border-radius:100px; background:var(--green); transition:width .3s; }
.state-bar.amber { background:var(--amber); }
.state-bar.red { background:var(--red); }
.state-stats { display:flex; gap:1.2rem; }
.state-stat { font-size:.8rem; color:#b8c8b8; }
.state-stat strong { color:var(--text); }
.state-trend { font-size:.8rem; padding:.15rem .45rem; border-radius:100px; }
.trend-up { background:var(--green-dim); color:var(--green); }
.trend-down { background:var(--red-dim); color:var(--red); }
.trend-flat { background:var(--amber-dim); color:var(--amber); }

.add-state-form { background:var(--surface); border:1px solid rgba(255,255,255,0.18); border-radius:4px; padding:1rem; margin-top:.8rem; }
.add-state-title { font-size:.85rem; letter-spacing:.1em; text-transform:uppercase; color:var(--green); margin-bottom:.8rem; }

/* CALC */
.calc-result { background:var(--green-dim); border:1px solid var(--green-border); border-radius:4px; padding:1rem; margin-top:.8rem; }
.calc-row { display:flex; justify-content:space-between; margin-bottom:.4rem; font-size:.82rem; }
.calc-row.total { border-top:1px solid var(--green-border); padding-top:.5rem; margin-top:.3rem; font-weight:bold; font-size:.95rem; }
.calc-row .label { color:#b8c8b8; }
.calc-row .val { color:var(--text); }
.calc-row.total .val { color:var(--green); }
.calc-row.total.loss .val { color:var(--red); }

/* PARAMS */
.toggle-row { display:flex; justify-content:space-between; align-items:center; padding:.6rem 0; border-bottom:1px solid var(--border); }
.toggle-row:last-child { border-bottom:none; }
.toggle-label { font-size:.85rem; }
.toggle-sub { font-size:.85rem; color:#b8c8b8; margin-top:.1rem; }
.toggle { width:40px; height:22px; border-radius:11px; background:var(--surface2); border:1px solid rgba(255,255,255,0.18); cursor:pointer; position:relative; flex-shrink:0; transition:background .2s; }
.toggle.on { background:var(--green); border-color:var(--green); }
.toggle::after { content:''; position:absolute; top:2px; left:2px; width:16px; height:16px; border-radius:50%; background:#fff; transition:transform .2s; }
.toggle.on::after { transform:translateX(18px); }

/* LOGBOOK */
.log-item { padding:.9rem 0; border-bottom:1px solid var(--border); }
.log-item:last-child { border-bottom:none; }
.log-top { display:flex; justify-content:space-between; margin-bottom:.3rem; }
.log-route { font-weight:bold; font-size:.9rem; }
.log-date { font-size:.8rem; color:#b8c8b8; }
.log-stats { display:flex; gap:1rem; }
.log-stat { font-size:.82rem; color:#b8c8b8; }
.log-stat strong { color:var(--text); }

.alert { border-radius:4px; padding:.8rem 1rem; margin-bottom:.7rem; font-size:.82rem; line-height:1.6; display:flex; gap:.7rem; align-items:flex-start; }
.alert-green { background:var(--green-dim); border:1px solid var(--green-border); color:var(--text); }
.alert-amber { background:var(--amber-dim); border:1px solid rgba(251,191,36,.25); color:var(--text); }
.alert-icon { font-size:1rem; flex-shrink:0; margin-top:.1rem; }
.divider { height:1px; background:var(--border); margin:.8rem 0; }

/* LOADBACK ACTION BUTTONS */
.lb-actions {
  display:flex; gap:.5rem; margin-top:.6rem; flex-wrap:wrap;
}
.lb-call-btn {
  flex:1; padding:.55rem .8rem; background:var(--amber-dim);
  border:1px solid rgba(255,208,77,.35); color:var(--amber);
  border-radius:3px; font-family:var(--font-body);
  font-size:.78rem; font-weight:bold; cursor:pointer;
  text-align:center;
}
.lb-book-btn {
  flex:1; padding:.55rem .8rem; background:var(--green-dim);
  border:1px solid var(--green-border); color:var(--green);
  border-radius:3px; font-family:var(--font-body);
  font-size:.78rem; font-weight:bold; cursor:pointer;
  text-align:center;
}
/* REOPEN LOADBACK BUTTON on Money tab */
.reopen-loadback-btn {
  width:100%; padding:.8rem; background:var(--surface2);
  border:1px solid var(--green-border); color:var(--green);
  border-radius:3px; font-family:var(--font-body);
  font-size:.85rem; font-weight:bold; cursor:pointer;
  margin-bottom:.8rem; letter-spacing:.03em;
}

/* LOADBACK PANEL */
.loadback-panel {
  position:fixed; inset:0; z-index:500;
  background:rgba(0,0,0,0.88);
  display:flex; align-items:flex-end; justify-content:center;
  display:none;
}
.loadback-panel.open { display:flex; }
.loadback-sheet {
  background:var(--surface);
  border:1px solid var(--green-border);
  border-radius:8px 8px 0 0;
  width:100%; max-width:520px;
  max-height:85vh;
  overflow-y:auto;
  padding:1.2rem;
}
.loadback-header {
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom:1rem;
  border-bottom:1px solid var(--border);
  padding-bottom:.8rem;
}
.loadback-title {
  font-size:1rem; font-weight:bold; color:var(--green);
  letter-spacing:.05em; text-transform:uppercase;
}
.loadback-close {
  background:none; border:none; color:#ffd04d;
  font-size:1.2rem; cursor:pointer; padding:.2rem .4rem;
}
.loadback-summary {
  background:var(--surface2);
  border:1px solid rgba(255,255,255,.12);
  border-radius:4px;
  padding:.9rem 1rem;
  margin-bottom:1rem;
}
.loadback-summary-row {
  display:flex; justify-content:space-between;
  font-size:.82rem; margin-bottom:.35rem;
  color:#ffd04d; opacity:.85;
}
.loadback-summary-row strong { color:var(--text); }
.loadback-summary-row.highlight strong { color:var(--green); font-size:.95rem; }
.loadback-arrival {
  background:var(--green-dim);
  border:1px solid var(--green-border);
  border-radius:4px;
  padding:.7rem 1rem;
  margin-bottom:1rem;
  font-size:.88rem;
  color:var(--text);
}
.loadback-arrival strong { color:var(--green); }
.loadback-section-title {
  font-size:.72rem; color:var(--green); letter-spacing:.1em;
  text-transform:uppercase; margin-bottom:.6rem; margin-top:.8rem;
}
.loadback-card {
  background:var(--surface2);
  border:1px solid rgba(255,255,255,.14);
  border-radius:4px;
  padding:.9rem 1rem;
  margin-bottom:.6rem;
  cursor:pointer;
  transition:border-color .15s;
}
.loadback-card:hover { border-color:var(--green-border); }
.loadback-card.best { border-color:var(--green-border); background:var(--green-dim); }
.loadback-card-top {
  display:flex; justify-content:space-between; align-items:flex-start;
  margin-bottom:.4rem;
}
.loadback-route { font-weight:bold; font-size:.92rem; }
.loadback-rate  { font-size:1rem; font-weight:bold; color:var(--green); }
.loadback-stats { display:flex; gap:1rem; flex-wrap:wrap; }
.loadback-stat  { font-size:.75rem; color:#ffd04d; opacity:.85; }
.loadback-stat strong { color:var(--text); }
.loadback-date  { font-size:.72rem; color:var(--amber); margin-top:.3rem; font-weight:bold; }
.loadback-best-badge {
  font-size:.62rem; background:var(--green); color:#000;
  padding:.15rem .5rem; border-radius:100px; font-weight:bold;
  margin-left:.5rem; vertical-align:middle;
}

/* WEATHER ALERT STRIP */
.weather-strip {
  margin-bottom:.8rem;
  border-radius:4px;
  overflow:hidden;
}
.weather-row {
  display:flex; align-items:center; gap:.7rem;
  padding:.7rem 1rem;
  background:var(--surface);
  border:1px solid rgba(255,255,255,.18);
  border-radius:4px;
  margin-bottom:.4rem;
  cursor:pointer;
}
.weather-row.clear   { border-color:var(--green-border); background:var(--green-dim); }
.weather-row.warning { border-color:rgba(255,208,77,.4);  background:var(--amber-dim); }
.weather-row.alert   { border-color:rgba(255,126,126,.4); background:var(--red-dim); }
.weather-icon { font-size:1.3rem; flex-shrink:0; }
.weather-text { flex:1; }
.weather-title { font-size:.85rem; font-weight:bold; color:var(--text); }
.weather-sub   { font-size:.75rem; color:#ffd04d; opacity:.85; margin-top:.1rem; }
.weather-time  { font-size:.7rem; color:#ffd04d; opacity:.65; flex-shrink:0; }

/* DEADHEAD ALERT */
.deadhead-alert {
  display:none;
  padding:.6rem .9rem;
  border-radius:3px;
  margin:.4rem 1rem .2rem;
  font-size:.8rem;
  font-weight:bold;
}
.deadhead-alert.show { display:block; }
.deadhead-alert.ok     { background:var(--green-dim); color:var(--green); border:1px solid var(--green-border); }
.deadhead-alert.warn   { background:var(--amber-dim); color:var(--amber); border:1px solid rgba(255,208,77,.3); }
.deadhead-alert.danger { background:var(--red-dim);   color:var(--red);   border:1px solid rgba(255,126,126,.3); }

/* MAINTENANCE TRACKER */
.maint-item {
  background:var(--surface);
  border:1px solid rgba(255,255,255,.18);
  border-radius:4px;
  padding:.9rem 1rem;
  margin-bottom:.6rem;
}
.maint-top { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:.5rem; }
.maint-name { font-weight:bold; font-size:.95rem; }
.maint-status { font-size:.72rem; font-weight:bold; padding:.2rem .6rem; border-radius:100px; }
.maint-status.good    { background:var(--green-dim); color:var(--green); border:1px solid var(--green-border); }
.maint-status.soon    { background:var(--amber-dim); color:var(--amber); border:1px solid rgba(255,208,77,.3); }
.maint-status.overdue { background:var(--red-dim);   color:var(--red);   border:1px solid rgba(255,126,126,.3); }
.maint-bar-wrap { background:var(--surface2); border-radius:100px; height:6px; margin-bottom:.5rem; overflow:hidden; }
.maint-bar { height:100%; border-radius:100px; transition:width .4s; }
.maint-bar.green { background:var(--green); }
.maint-bar.amber { background:var(--amber); }
.maint-bar.red   { background:var(--red); }
.maint-stats { display:flex; gap:1.2rem; flex-wrap:wrap; }
.maint-stat  { font-size:.75rem; color:#ffd04d; opacity:.85; }
.maint-stat strong { color:var(--text); }
.maint-cost-banner {
  background:var(--surface2);
  border:1px solid rgba(255,255,255,.12);
  border-radius:4px;
  padding:.8rem 1rem;
  margin-bottom:.8rem;
  display:flex; justify-content:space-between; align-items:center;
}
.maint-cost-label { font-size:.78rem; color:#ffd04d; opacity:.85; }
.maint-cost-val   { font-size:1.1rem; font-weight:bold; color:var(--amber); }

/* EXPAND NOTES */
.expand-notes {
  border-top:1px solid rgba(255,255,255,.08);
  padding:.7rem 0 .2rem;
  margin-top:.4rem;
}
.expand-notes-text {
  font-size:.78rem;
  color:#ffd04d;
  opacity:.7;
  line-height:1.6;
  font-style:italic;
}
.expand-notes-text.has-notes {
  color:var(--text);
  opacity:1;
  font-style:normal;
}

/* EXPANDABLE PROFIT PANEL */
.load-expand-panel {
  display:none;
  background:var(--surface2);
  border-top:1px solid var(--border);
  padding:.9rem 1rem;
  animation: slideDown .2s ease;
}
.load-expand-panel.open { display:block; }
@keyframes slideDown { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }
.expand-profit-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:.5rem; margin-bottom:.7rem;
}
.expand-stat { }
.expand-label { font-size:.68rem; color:#ffd04d; opacity:.8; text-transform:uppercase; letter-spacing:.06em; }
.expand-val { font-size:.95rem; font-weight:bold; color:var(--text); margin-top:.1rem; }
.expand-val.green { color:var(--green); }
.expand-val.amber { color:var(--amber); }
.expand-val.red   { color:var(--red); }
.expand-verdict {
  padding:.6rem .8rem; border-radius:3px;
  font-size:.82rem; font-weight:bold; text-align:center;
  margin-bottom:.6rem;
}
.expand-verdict.strong { background:var(--green-dim); color:var(--green); border:1px solid var(--green-border); }
.expand-verdict.ok     { background:var(--amber-dim); color:var(--amber); border:1px solid rgba(255,208,77,.3); }
.expand-verdict.weak   { background:var(--red-dim);   color:var(--red);   border:1px solid rgba(255,126,126,.3); }
.load-card-clickable { cursor:pointer; }
.expand-arrow {
  font-size:.75rem; color:#ffd04d; opacity:.7;
  float:right; margin-top:.15rem; transition:transform .2s;
}
.expand-arrow.open { transform:rotate(180deg); }

/* BOOKED BUTTON */
.load-action-btn.book-btn { color:var(--blue); }
.load-action-btn.book-btn:hover { background:var(--blue-dim); }

/* SWIPE HINT */
.nav-swipe-hint {
  position:fixed;
  bottom:62px;
  right:0;
  background:linear-gradient(to left, rgba(10,10,10,.95), transparent);
  padding:.35rem .6rem .35rem 1.5rem;
  font-size:.68rem;
  color:#ffd04d;
  opacity:.9;
  z-index:102;
  pointer-events:none;
  border-radius:4px 0 0 4px;
  letter-spacing:.04em;
  animation: hintpulse 2s ease-in-out 2s 3 forwards;
}
@keyframes hintpulse {
  0%   { opacity:.9; }
  50%  { opacity:.3; }
  100% { opacity:.9; }
}

/* TUTORIAL OVERLAY */
.tutorial-overlay {
  position:fixed; inset:0; z-index:1000;
  background:rgba(0,0,0,0.92);
  display:flex; flex-direction:column;
  justify-content:center; align-items:center;
  padding:.8rem;
  overflow-y:auto;
}
.tutorial-overlay { display:none; }
.tutorial-overlay.visible { display:flex; }

.tutorial-card {
  background:var(--surface);
  border:1px solid var(--green-border);
  border-radius:8px;
  width:100%; max-width:420px;
  overflow:hidden;
  max-height:90vh;
  display:flex;
  flex-direction:column;
}
.tutorial-header {
  background:var(--green-dim);
  border-bottom:1px solid var(--green-border);
  padding:.7rem 1rem;
  display:flex; justify-content:space-between; align-items:center;
  flex-shrink:0;
}
.tutorial-title {
  font-size:.88rem; font-weight:bold; color:var(--green);
  letter-spacing:.05em; text-transform:uppercase;
}
.tutorial-step-count {
  font-size:.78rem; color:#ffd04d; opacity:.85;
}
.tutorial-body {
  padding:.9rem 1rem;
  overflow-y:auto;
  flex:1;
}
.tutorial-icon {
  font-size:2rem; text-align:center; margin-bottom:.5rem;
}
.tutorial-screen-title {
  font-size:1rem; font-weight:bold; color:var(--text);
  margin-bottom:.5rem; text-align:center;
}
.tutorial-desc {
  font-size:.85rem; color:#ffd04d; opacity:.9;
  line-height:1.65; margin-bottom:.7rem;
}
.tutorial-tip {
  background:rgba(94,220,130,0.1);
  border:1px solid var(--green-border);
  border-radius:4px; padding:.6rem .8rem;
  font-size:.8rem; color:var(--text);
  line-height:1.55;
}
.tutorial-tip strong { color:var(--green); }
.tutorial-tap-hint {
  text-align:center;
  font-size:.72rem;
  color:#ffd04d;
  opacity:.6;
  padding:.4rem 0 .2rem;
  letter-spacing:.05em;
  flex-shrink:0;
}
.tutorial-footer {
  padding:.7rem 1rem .9rem;
  display:flex; gap:.6rem;
  flex-shrink:0;
  border-top:1px solid rgba(255,255,255,.08);
}
.tutorial-dots {
  display:flex; gap:.35rem; justify-content:center;
  padding:.5rem 0 .2rem; flex-wrap:wrap;
  flex-shrink:0;
}
.t-dot {
  width:8px; height:8px; border-radius:50%;
  background:rgba(255,255,255,.2); transition:background .2s;
}
.t-dot.active { background:var(--green); }
.btn-tutorial-next {
  flex:1; padding:.8rem; background:#ffd04d; color:#000;
  border:none; border-radius:4px; font-family:var(--font-body);
  font-size:.88rem; font-weight:bold; cursor:pointer; letter-spacing:.03em;
}
.btn-tutorial-back {
  flex:1; padding:.8rem; background:#ffd04d; color:#000;
  border:none; border-radius:4px; font-family:var(--font-body);
  font-size:.88rem; font-weight:bold; cursor:pointer; letter-spacing:.03em;
}
.btn-tutorial-skip {
  padding:.8rem 1rem; background:transparent;
  border:1px solid rgba(255,255,255,.15); color:#ffd04d; opacity:.75;
  border-radius:4px; font-family:var(--font-body);
  font-size:.82rem; cursor:pointer;
}

/* TOOL HELP BUTTON */
.tool-help-btn {
  background:none; border:none;
  color:#ffd04d; opacity:.7;
  font-size:.85rem; cursor:pointer;
  padding:.2rem .4rem;
  font-family:var(--font-body);
  letter-spacing:.03em;
}
.tool-help-btn:hover { opacity:1; }

/* HELP MODAL */
.help-modal-overlay {
  position:fixed; inset:0; z-index:900;
  background:rgba(0,0,0,0.85);
  display:flex; align-items:flex-end;
  justify-content:center;
}
.help-modal-overlay.hidden { display:none; }
.help-modal {
  background:var(--surface);
  border:1px solid var(--green-border);
  border-radius:8px 8px 0 0;
  width:100%; max-width:500px;
  padding:1.2rem;
  max-height:75vh; overflow-y:auto;
}
.help-modal-title {
  font-size:1rem; font-weight:bold; color:var(--green);
  margin-bottom:.6rem; display:flex; justify-content:space-between;
  align-items:center;
}
.help-modal-close {
  background:none; border:none; color:#ffd04d; font-size:1.2rem;
  cursor:pointer; padding:.2rem .4rem;
}
.help-step {
  display:flex; gap:.7rem; padding:.6rem 0;
  border-bottom:1px solid rgba(255,255,255,.08);
  font-size:.88rem; color:#ffd04d; opacity:.9; line-height:1.6;
}
.help-step:last-child { border-bottom:none; }
.help-step-num {
  background:var(--green-dim); color:var(--green);
  border:1px solid var(--green-border);
  border-radius:50%; width:22px; height:22px;
  display:flex; align-items:center; justify-content:center;
  font-size:.72rem; font-weight:bold; flex-shrink:0; margin-top:.1rem;
}

/* SETTINGS */
.settings-section { margin-bottom:1rem; }
.settings-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:.9rem 1rem; background:var(--surface);
  border:1px solid rgba(255,255,255,0.18); border-radius:4px;
  margin-bottom:.5rem;
}
.settings-label { font-size:.95rem; font-weight:600; color:var(--text); }
.settings-sub { font-size:.75rem; color:#ffd04d; opacity:.8; margin-top:.15rem; }
.text-size-btns { display:flex; gap:.4rem; }
.text-size-btn {
  padding:.45rem .9rem; border:1px solid rgba(255,255,255,0.18);
  background:transparent; color:#ffd04d; font-size:.82rem;
  font-family:var(--font-body); cursor:pointer; border-radius:3px;
  font-weight:600; transition:all .15s;
}
.text-size-btn.active {
  background:var(--green-dim); border-color:var(--green-border); color:var(--green);
}
.color-scheme-btns { display:flex; gap:.4rem; flex-wrap:wrap; }
.scheme-btn {
  padding:.45rem .9rem; border:1px solid rgba(255,255,255,0.18);
  font-size:.8rem; font-family:var(--font-body); cursor:pointer;
  border-radius:3px; font-weight:600; transition:all .15s;
}
.scheme-btn.active { border-color:var(--green-border); }

/* TEXT SIZE CLASSES applied to body */
body.text-normal  { font-size:15px; }
body.text-large   { font-size:18px; }
body.text-xlarge  { font-size:21px; }
body.text-xxlarge { font-size:24px; }

/* HIGH CONTRAST MODE */
body.high-contrast {
  --bg: #000000;
  --surface: #111111;
  --surface2: #1a1a1a;
  --border: rgba(255,255,255,0.3);
  --text: #ffffff;
  --muted: #cccccc;
}
body.high-contrast .nav-btn { color:#ffdd00; }
body.high-contrast .nav-btn.active { color:#ffdd00; border-top-color:#ffdd00; }

/* NIGHT MODE (default dark already, this is even darker) */
body.night-mode {
  --bg: #050505;
  --surface: #0d0d0d;
  --surface2: #151515;
}

/* BROKER SCORECARD */
.broker-flag { display:flex; gap:.5rem; align-items:center; padding:.5rem 0; border-bottom:1px solid var(--border); font-size:.92rem; }
.broker-flag:last-child { border-bottom:none; }
.flag-icon { font-size:.95rem; flex-shrink:0; }
.flag-good { color:var(--green); }
.flag-warn { color:var(--amber); }
.flag-bad  { color:var(--red); }

/* INVOICE */
.invoice-item { background:var(--surface); border:1px solid rgba(255,255,255,0.18); border-radius:4px; margin-bottom:.6rem; overflow:hidden; }
.invoice-item.overdue { border-color:rgba(255,126,126,.4); }
.invoice-item.paid { border-color:rgba(94,220,130,.3); opacity:.7; }
.inv-top { padding:.8rem 1rem .4rem; display:flex; justify-content:space-between; align-items:flex-start; }
.inv-broker-name { font-weight:bold; font-size:.92rem; }
.inv-amount { font-size:1.05rem; font-weight:bold; color:var(--green); }
.inv-meta { padding:.2rem 1rem .7rem; display:flex; gap:1rem; flex-wrap:wrap; }
.inv-stat { font-size:.75rem; color:#ffd04d; opacity:.8; }
.inv-stat strong { color:var(--text); }
.inv-actions { border-top:1px solid var(--border); display:flex; }
.inv-btn { flex:1; padding:.55rem; background:none; border:none; border-right:1px solid var(--border); color:#b8c8b8; font-size:.72rem; letter-spacing:.04em; text-transform:uppercase; cursor:pointer; font-family:var(--font-body); }
.inv-btn:last-child { border-right:none; }
.inv-btn.green { color:var(--green); }
.inv-btn.call  { color:var(--amber); }
.inv-btn.red   { color:var(--red); }
.overdue-badge { background:var(--red-dim); color:var(--red); border:1px solid rgba(255,126,126,.3); font-size:.6rem; padding:.15rem .5rem; border-radius:100px; font-weight:bold; letter-spacing:.06em; }
.paid-badge    { background:var(--green-dim); color:var(--green); border:1px solid var(--green-border); font-size:.6rem; padding:.15rem .5rem; border-radius:100px; font-weight:bold; letter-spacing:.06em; }
.due-badge     { background:var(--amber-dim); color:var(--amber); border:1px solid rgba(255,208,77,.3); font-size:.6rem; padding:.15rem .5rem; border-radius:100px; font-weight:bold; letter-spacing:.06em; }

/* RETURN LOAD CARDS */
.return-card { background:var(--surface); border:1px solid rgba(255,255,255,0.18); border-radius:4px; padding:.9rem; margin-bottom:.6rem; }
.return-card.good { border-color:var(--green-border); }
.return-top { display:flex; justify-content:space-between; margin-bottom:.4rem; }
.return-route { font-weight:bold; font-size:.9rem; }
.return-rate { color:var(--green); font-weight:bold; }
.return-stats { display:flex; gap:1rem; font-size:.75rem; color:#ffd04d; opacity:.8; }
.return-stats strong { color:var(--text); }

/* HOS RESULT */
.hos-pass { background:var(--green-dim); border:1px solid var(--green-border); border-radius:4px; padding:1rem; }
.hos-fail { background:var(--red-dim); border:1px solid rgba(255,126,126,.35); border-radius:4px; padding:1rem; }
.hos-title { font-weight:bold; font-size:1rem; margin-bottom:.4rem; }
.hos-detail { font-size:.85rem; color:#ffd04d; opacity:.85; line-height:1.7; }

/* DOC LIST */
.doc-item { background:var(--surface); border:1px solid rgba(255,255,255,0.18); border-radius:4px; padding:.9rem 1rem; margin-bottom:.6rem; }
.doc-top { display:flex; justify-content:space-between; margin-bottom:.3rem; }
.doc-bol { font-weight:bold; font-size:.88rem; }
.doc-broker { font-size:.75rem; color:#ffd04d; opacity:.8; }
.doc-stats { display:flex; gap:1rem; font-size:.75rem; color:#ffd04d; opacity:.8; }
.doc-stats strong { color:var(--text); }

/* GPS + FUEL STATUS */
.live-bar {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .6rem;
  margin-bottom: .8rem;
}
.live-box {
  background: var(--surface);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 4px;
  padding: .8rem;
  position: relative;
}
.live-box.connected { border-color: var(--green-border); }
.live-box.loading { border-color: rgba(255,208,77,0.35); }
.live-box.error { border-color: rgba(255,126,126,0.35); }
.live-label {
  font-size: .82rem;
  color: #ffd04d; opacity:.88;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: .3rem;
  display: flex;
  align-items: center;
  gap: .4rem;
}
.live-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--amber);
  animation: pulse 1.5s infinite;
  flex-shrink: 0;
}
.live-dot.green { background: var(--green); animation: none; }
.live-dot.red { background: var(--red); animation: none; }
.live-value {
  font-size: 1.05rem;
  font-weight: bold;
  color: var(--text);
  line-height: 1.3;
}
.live-sub {
  font-size: .75rem;
  color: #ffd04d; opacity:.85;
  margin-top: .15rem;
}

/* GPS + FUEL STATUS */
.live-bar {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .6rem;
  margin-bottom: .8rem;
}
.live-box {
  background: var(--surface);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 4px;
  padding: .8rem;
  position: relative;
}
.live-box.connected { border-color: var(--green-border); }
.live-box.loading { border-color: rgba(255,208,77,0.35); }
.live-box.error { border-color: rgba(255,126,126,0.35); }
.live-label {
  font-size: .68rem;
  color: #b8c8b8;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: .3rem;
  display: flex;
  align-items: center;
  gap: .4rem;
}
.live-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--amber);
  animation: pulse 1.5s infinite;
  flex-shrink: 0;
}
.live-dot.green { background: var(--green); animation: none; }
.live-dot.red { background: var(--red); animation: none; }
.live-value {
  font-size: .95rem;
  font-weight: bold;
  color: var(--text);
  line-height: 1.2;
}
.live-sub {
  font-size: .68rem;
  color: #b8c8b8;
  margin-top: .15rem;
}

/* INLINE PROFIT DISPLAY */
.load-profit {
  margin: 0 1rem .7rem;
  padding: .6rem .8rem;
  border-radius: 3px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.load-profit.strong { background: rgba(94,220,130,0.18); border: 1px solid rgba(94,220,130,0.4); }
.load-profit.ok     { background: rgba(255,208,77,0.16);  border: 1px solid rgba(255,208,77,0.35); }
.load-profit.weak   { background: rgba(255,126,126,0.16); border: 1px solid rgba(255,126,126,0.35); }
.profit-left { }
.profit-net  { font-size: 1rem; font-weight: bold; line-height: 1; }
.profit-net.strong { color: var(--green); }
.profit-net.ok     { color: var(--amber); }
.profit-net.weak   { color: var(--red); }
.profit-detail { font-size: .72rem; color: #b8c8b8; margin-top: .2rem; }
.profit-verdict { font-size: .72rem; font-weight: bold; padding: .25rem .6rem; border-radius: 100px; }
.verdict-strong { background: var(--green-dim); color: var(--green); }
.verdict-ok     { background: var(--amber-dim);  color: var(--amber); }
.verdict-weak   { background: var(--red-dim);    color: var(--red); }


/* AUTH SCREEN — added for Supabase login */
.auth-screen { display:none; min-height:100vh; background:var(--bg); align-items:center; justify-content:center; padding:2rem 1.5rem; }
.auth-screen.active { display:flex; }
.auth-card { background:var(--surface); border:1px solid var(--green-border); border-radius:8px; padding:2rem; width:100%; max-width:380px; }
.auth-logo { text-align:center; margin-bottom:1.5rem; }
.auth-logo-text { font-size:1.5rem; font-weight:bold; color:var(--green); letter-spacing:.05em; }
.auth-logo-sub { font-size:.78rem; color:#b8c8b8; margin-top:.3rem; font-style:italic; }
.auth-title { font-size:1rem; font-weight:bold; color:var(--text); margin-bottom:1.2rem; text-align:center; }
.auth-input { width:100%; background:var(--surface2); border:1px solid rgba(255,255,255,0.18); border-radius:3px; padding:.75rem 1rem; color:var(--text); font-family:var(--font-body); font-size:1rem; margin-bottom:.8rem; }
.auth-input:focus { outline:none; border-color:var(--green-border); }
.auth-btn { width:100%; background:var(--green); color:#111312; border:none; border-radius:3px; padding:.8rem; font-size:.95rem; font-weight:bold; font-family:var(--font-body); cursor:pointer; margin-bottom:.8rem; }
.auth-btn:active { opacity:.85; }
.auth-toggle { text-align:center; font-size:.82rem; color:#b8c8b8; }
.auth-toggle a { color:var(--green); cursor:pointer; text-decoration:none; }
.auth-error { background:var(--red-dim); border:1px solid rgba(255,126,126,.35); border-radius:3px; padding:.6rem .9rem; font-size:.82rem; color:var(--red); margin-bottom:.8rem; display:none; }
.auth-error.show { display:block; }
.auth-beta-badge { background:var(--amber-dim); border:1px solid rgba(255,208,77,.35); color:var(--amber); font-size:.72rem; padding:.3rem .8rem; border-radius:100px; text-align:center; margin-bottom:1rem; font-weight:bold; letter-spacing:.06em; }
