/* styles.css — Lowrider operational console. Monkey Theme.
   IBM Plex Mono + Bebas Neue. Mobile-first; breakpoints at 640 / 380. */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root {
  --acc:  #00d4ff;
  --acc2: #ff6b35;
  --acc3: #00ff88;
  --danger: #ff3366;
  --c1: #0a0a0f;
  --c2: #12121a;
  --panel: #16161f;
  --border: #2a2a38;
  --txt:  #e8e8f0;
  --txt2: #8888aa;
  --txt3: #4444aa;
  --radius: 10px;
  --tap: 44px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--c1);
  color: var(--txt);
  font-family: 'IBM Plex Mono', monospace;
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  padding-bottom: env(safe-area-inset-bottom);
}

h1, h2, h3, .logo, .bebas {
  font-family: 'Bebas Neue', sans-serif;
  letter-spacing: 1px;
  font-weight: 400;
}

a { color: var(--acc); }

/* ---- header ---- */
.hdr {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  background: var(--c2);
  position: sticky; top: 0; z-index: 20;
}
.logo { font-size: 28px; color: var(--acc); letter-spacing: 3px; }
.logo span { color: var(--acc2); }
.hdr .who { color: var(--txt2); font-size: 13px; }

/* ---- status dot ---- */
.status-dot {
  display: inline-block; width: 9px; height: 9px; border-radius: 50%;
  background: var(--acc3); margin-right: 6px;
  box-shadow: 0 0 0 0 rgba(0,255,136,.6);
  animation: pulse 2s infinite;
}
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(0,255,136,.5); }
  70% { box-shadow: 0 0 0 8px rgba(0,255,136,0); }
  100% { box-shadow: 0 0 0 0 rgba(0,255,136,0); }
}

/* ---- tabs ---- */
.tabs {
  display: flex; gap: 0; border-bottom: 1px solid var(--border);
  background: var(--c2); overflow-x: auto; position: sticky; top: 57px; z-index: 19;
}
.tab {
  flex: 0 0 auto; padding: 12px 18px; min-height: var(--tap);
  background: none; border: none; color: var(--txt2);
  font-family: 'IBM Plex Mono', monospace; font-size: 13px; cursor: pointer;
  border-bottom: 2px solid transparent;
}
.tab.active { color: var(--acc); border-bottom-color: var(--acc); }

/* ---- panels ---- */
.wrap { max-width: 880px; margin: 0 auto; padding: 16px; }
.panel {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: var(--radius); margin-bottom: 16px; overflow: hidden;
}
.panel-hdr {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px; border-bottom: 1px solid var(--border);
}
.panel-hdr h2 { margin: 0; font-size: 20px; color: var(--txt); letter-spacing: 2px; }
.panel-badge {
  font-size: 11px; color: var(--c1); background: var(--acc);
  padding: 2px 8px; border-radius: 20px; letter-spacing: 1px;
}
.panel-body { padding: 14px; }

/* ---- metrics ---- */
.metric-row { display: flex; gap: 12px; flex-wrap: wrap; }
.metric {
  flex: 1 1 120px; background: var(--c2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 14px;
}
.metric .num { font-family: 'Bebas Neue'; font-size: 34px; color: var(--acc3); line-height: 1; }
.metric .lbl { color: var(--txt2); font-size: 12px; text-transform: uppercase; letter-spacing: 1px; }

/* ---- list rows / cards ---- */
.row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 0; border-bottom: 1px solid var(--border); gap: 10px;
}
.row:last-child { border-bottom: none; }
.row .meta { color: var(--txt2); font-size: 13px; }
.pill {
  font-size: 11px; padding: 2px 8px; border-radius: 20px; letter-spacing: .5px;
  border: 1px solid var(--border); color: var(--txt2);
}
.pill.confirmed { color: var(--acc3); border-color: var(--acc3); }
.pill.pending   { color: var(--acc2); border-color: var(--acc2); }
.pill.completed { color: var(--acc); border-color: var(--acc); }
.pill.cancelled, .pill.no_show { color: var(--danger); border-color: var(--danger); }

/* ---- buttons ---- */
.cmd-btn {
  min-height: var(--tap); padding: 0 16px; border-radius: var(--radius);
  background: var(--acc); color: var(--c1); border: none; cursor: pointer;
  font-family: 'IBM Plex Mono', monospace; font-weight: 600; font-size: 14px;
}
.cmd-btn.ghost { background: transparent; color: var(--acc); border: 1px solid var(--acc); }
.cmd-btn.danger { background: var(--danger); color: #fff; }
.cmd-btn:disabled { opacity: .5; cursor: not-allowed; }

/* ---- forms ---- */
label { display: block; color: var(--txt2); font-size: 12px; margin: 10px 0 4px; text-transform: uppercase; letter-spacing: 1px; }
input, select, textarea {
  width: 100%; min-height: var(--tap); padding: 10px 12px;
  background: var(--c1); border: 1px solid var(--border); border-radius: var(--radius);
  color: var(--txt); font-family: 'IBM Plex Mono', monospace;
  font-size: 16px; /* 16px prevents iOS zoom-on-focus */
}
textarea { min-height: 80px; resize: vertical; }
.field-row { display: flex; gap: 10px; }
.field-row > * { flex: 1; }

/* ---- login ---- */
.login-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 20px; }
.login-card { width: 100%; max-width: 380px; }
.login-card .logo { display: block; text-align: center; font-size: 52px; margin-bottom: 6px; }
.subtitle { text-align: center; color: var(--txt2); margin-bottom: 24px; font-size: 13px; letter-spacing: 2px; }
.err { color: var(--danger); font-size: 13px; min-height: 18px; margin-top: 8px; }
.ok { color: var(--acc3); font-size: 13px; }

/* ---- modal -> full-screen sheet on mobile ---- */
.modal-backdrop {
  position: fixed; inset: 0; background: rgba(0,0,0,.7); z-index: 50;
  display: flex; align-items: flex-end; justify-content: center;
}
.modal {
  width: 100%; max-width: 560px; max-height: 92vh; overflow-y: auto;
  background: var(--panel); border: 1px solid var(--border);
  border-radius: var(--radius) var(--radius) 0 0; padding: 18px;
  padding-bottom: calc(18px + env(safe-area-inset-bottom));
}
.muted { color: var(--txt3); font-size: 12px; }
.hidden { display: none !important; }

@media (min-width: 640px) {
  body { font-size: 15px; }
  .modal-backdrop { align-items: center; }
  .modal { border-radius: var(--radius); }
  .tab { font-size: 14px; }
}
@media (max-width: 380px) {
  .logo { font-size: 24px; }
  .metric .num { font-size: 28px; }
  .field-row { flex-direction: column; }
}
