:root {
  --bg: var(--tg-theme-bg-color, #ffffff);
  --text: var(--tg-theme-text-color, #111111);
  --hint: var(--tg-theme-hint-color, #888888);
  --btn: var(--tg-theme-button-color, #2ea6ff);
  --btn-text: var(--tg-theme-button-text-color, #ffffff);
  --card: var(--tg-theme-secondary-bg-color, #f3f3f3);
}

* { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0; height: 100%;
  font-family: -apple-system, "Segoe UI", Roboto, "Noto Kufi Arabic", Tahoma, sans-serif;
  color: var(--text); background: var(--bg);
  overflow: hidden;
}

#map { position: absolute; inset: 0; z-index: 1; }

/* Fixed center pin overlay */
.center-pin {
  position: absolute; z-index: 500;
  top: 50%; left: 50%;
  transform: translate(-50%, -100%);
  pointer-events: none;
  display: flex; flex-direction: column; align-items: center;
}
.center-pin .pin-emoji { font-size: 34px; line-height: 1; filter: drop-shadow(0 2px 3px rgba(0,0,0,.4)); }
.center-pin .pin-stick {
  width: 2px; height: 10px; background: rgba(0,0,0,.4);
  margin-top: -2px;
}

.banner {
  position: absolute; z-index: 600;
  top: 12px; left: 12px; right: 12px;
  background: var(--card); color: var(--text);
  padding: 12px 16px; border-radius: 12px;
  font-size: 15px; font-weight: 600; text-align: center;
  box-shadow: 0 2px 10px rgba(0,0,0,.15);
}

.sheet {
  position: absolute; z-index: 600;
  left: 0; right: 0; bottom: 0;
  background: var(--bg);
  padding: 16px 16px calc(16px + env(safe-area-inset-bottom));
  border-radius: 18px 18px 0 0;
  box-shadow: 0 -3px 18px rgba(0,0,0,.18);
}

#sheet-content { margin-bottom: 12px; }

.fare-row { display: flex; justify-content: space-between; padding: 6px 0; font-size: 15px; }
.fare-row .label { color: var(--hint); }
.fare-row .value { font-weight: 700; }
.fare-total { font-size: 20px; font-weight: 800; }
.rough-note { color: #e08600; font-size: 13px; margin-top: 6px; }

.status { text-align: center; padding: 8px 0; }
.status .big { font-size: 17px; font-weight: 700; margin-bottom: 4px; }
.status .sub { color: var(--hint); font-size: 14px; }

.spinner {
  width: 34px; height: 34px; margin: 8px auto;
  border: 3px solid var(--card); border-top-color: var(--btn);
  border-radius: 50%; animation: spin 0.9s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

.action-btn {
  width: 100%; padding: 14px; border: 0; border-radius: 12px;
  background: var(--btn); color: var(--btn-text);
  font-size: 16px; font-weight: 700; cursor: pointer;
}
.action-btn:disabled { opacity: .5; }

.overlay {
  position: absolute; inset: 0; z-index: 900;
  background: var(--bg); color: var(--text);
  display: flex; align-items: center; justify-content: center;
  padding: 24px; text-align: center; font-size: 16px;
}

.hidden { display: none !important; }

/* Emoji div markers */
.emoji-marker { font-size: 26px; text-align: center; filter: drop-shadow(0 1px 2px rgba(0,0,0,.4)); }
