/* Rideshare Comps — simple, clean, cute.
 * Palette: warm paper background, white cards, taxi-yellow brand accent,
 * near-black primary for contrast. Rounded everything. */

:root {
  --bg: #FFFCF5;
  --paper: #FFFFFF;
  --surface-soft: #FFF7DC;      /* soft yellow tint (unavailable tiles, icon btns) */
  --surface-hover: #FFF1C2;
  --border: #ECE6D3;            /* subtle warm border */
  --border-strong: #1a1a1a;     /* inked outline for cartoon feel on a few bits */
  --text: #1a1a1a;
  --muted: #6d6d74;
  --taxi: #FFD23F;              /* brand yellow */
  --accent: #D4800F;            /* legible amber for links */
  --good: #2aa863;
  --warn: #b56a00;
  --bad:  #c23a3a;
  --radius: 18px;
  --radius-lg: 22px;
  --shadow-sm: 0 1px 2px rgba(22, 20, 10, 0.05);
  --shadow-md: 0 4px 14px rgba(22, 20, 10, 0.06);
  --shadow-lg: 0 10px 30px rgba(22, 20, 10, 0.08);
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--text);
  font: 17px/1.45 "SF Pro Rounded", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}

main {
  max-width: 520px;
  margin: 0 auto;
  padding: max(20px, env(safe-area-inset-top)) 20px max(24px, env(safe-area-inset-bottom));
}

/* ------- Header: taxi, title, tagline ------- */

header {
  text-align: center;
  padding: 12px 0 20px;
}

.taxi {
  display: block;
  width: 150px;
  margin: 0 auto 6px;
  animation: taxi-bob 5.2s ease-in-out infinite;
}
.taxi svg { width: 100%; height: auto; display: block; }

@keyframes taxi-bob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-3px); }
}
@media (prefers-reduced-motion: reduce) {
  .taxi { animation: none; }
}

header h1 {
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 2px 0 2px;
}

.tagline {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  font-weight: 500;
}

/* ------- Inputs ------- */

.inputs {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 18px;
}

.field { display: flex; flex-direction: column; gap: 6px; }

label {
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding-left: 4px;
}

.input-row { display: flex; gap: 8px; align-items: stretch; }
.input-wrap { position: relative; flex: 1; }

input[type="text"] {
  width: 100%;
  background: var(--paper);
  color: var(--text);
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  padding: 14px 16px;
  font-size: 17px;
  outline: none;
  box-shadow: var(--shadow-sm);
  transition: border-color 140ms ease, box-shadow 140ms ease;
}

input[type="text"]::placeholder { color: #b2ac99; }

input[type="text"]:focus {
  border-color: var(--text);
  box-shadow: 0 0 0 3px rgba(255, 210, 63, 0.35);
}

button {
  background: var(--paper);
  color: var(--text);
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  padding: 14px 16px;
  font-size: 17px;
  font-weight: 600;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: background 140ms ease, transform 80ms ease, border-color 140ms ease;
}
button:active { transform: scale(0.98); }

.icon-btn {
  padding: 0 14px;
  font-size: 13px;
  font-weight: 700;
  background: var(--surface-soft);
  color: var(--text);
  border-color: var(--border);
}
.icon-btn:hover { background: var(--surface-hover); }

button.primary {
  background: var(--text);
  color: var(--taxi);
  border: 1.5px solid var(--text);
  font-weight: 800;
  letter-spacing: 0.01em;
  margin-top: 10px;
  padding: 17px;
  font-size: 17px;
  box-shadow: var(--shadow-md);
}
button.primary:hover { background: #2a2a2a; }

/* ------- Autocomplete dropdown ------- */

.suggestions {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: var(--paper);
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  z-index: 10;
  display: none;
  max-height: 60vh;
  overflow-y: auto;
  box-shadow: var(--shadow-lg);
}
.suggestions.open { display: block; }

.suggestion {
  display: block;
  width: 100%;
  background: transparent;
  color: var(--text);
  text-align: left;
  padding: 12px 16px;
  border: 0;
  border-bottom: 1px solid var(--border);
  border-radius: 0;
  cursor: pointer;
  box-shadow: none;
}
.suggestion:last-child { border-bottom: 0; }
.suggestion:hover, .suggestion:focus { background: var(--surface-soft); outline: none; }

.s-title { font-size: 15px; font-weight: 600; }
.s-sub   { font-size: 12px; color: var(--muted); margin-top: 2px; }

/* ------- Results ------- */

.results {
  margin-top: 22px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.fare {
  background: var(--paper);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 16px 18px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 4px 16px;
  align-items: baseline;
  color: var(--text);
  text-decoration: none;
  box-shadow: var(--shadow-sm);
}

a.fare.tappable {
  transition: background 140ms ease, transform 80ms ease, box-shadow 140ms ease, border-color 140ms ease;
  -webkit-tap-highlight-color: transparent;
}
a.fare.tappable:hover {
  background: var(--surface-soft);
  border-color: #d9cfa7;
  box-shadow: var(--shadow-md);
}
a.fare.tappable:active { transform: scale(0.985); }

.open-hint {
  color: var(--accent);
  margin-left: auto;
  font-weight: 700;
}

.fare.cheapest {
  border: 2px solid var(--good);
  background: #F2FBF5;
  box-shadow: 0 6px 18px rgba(42, 168, 99, 0.15);
  position: relative;
}
.fare.cheapest::before {
  content: "Cheapest";
  position: absolute;
  top: -9px;
  left: 14px;
  background: var(--good);
  color: #ffffff;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 999px;
}

.fare .provider { font-weight: 800; font-size: 17px; letter-spacing: -0.01em; }
.fare .product  { color: var(--muted); font-size: 13px; grid-row: 2; }
.fare .price    {
  font-weight: 800;
  font-size: 24px;
  letter-spacing: -0.02em;
  grid-row: span 2;
  font-variant-numeric: tabular-nums;
}
.fare .meta {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 12px;
  margin-top: 8px;
  display: flex;
  gap: 10px;
  align-items: center;
}

.error {
  background: var(--paper);
  border: 1.5px solid var(--border);
  border-left: 4px solid var(--bad);
  padding: 12px 14px;
  border-radius: 12px;
  color: var(--muted);
  font-size: 13px;
}

.fare.unavailable {
  background: var(--surface-soft);
  border: 1.5px dashed #d9cfa7;
  box-shadow: none;
  opacity: 0.95;
}
.fare.unavailable.pending {
  background: #FFF7DC;
}
.fare.unavailable .provider { color: var(--text); }
.fare.unavailable .product  { color: var(--muted); font-size: 12px; }

.unavailable-label {
  color: var(--muted) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.action-link {
  color: var(--accent);
  text-decoration: none;
  margin-top: 4px;
  font-weight: 700;
}

/* ------- Footer / pills ------- */

footer { margin-top: 32px; text-align: center; }
.muted { color: var(--muted); font-size: 12px; }

.pill {
  display: inline-block;
  background: var(--paper);
  border: 1px solid var(--border);
  padding: 2px 10px;
  border-radius: 999px;
  font-size: 11px;
  color: var(--muted);
  font-weight: 600;
  letter-spacing: 0.02em;
}
.pill.working { color: var(--warn); background: #FFF3DB; border-color: #F0D9A7; }
.pill.done    { color: var(--good); background: #EAF8EF; border-color: #C2E8CF; }
.pill.err     { color: var(--bad);  background: #FDEDED; border-color: #F2C5C5; }
