:root {
  --bg: var(--tg-theme-bg-color, #ffffff);
  --text: var(--tg-theme-text-color, #0a0a0a);
  --muted: var(--tg-theme-hint-color, #6b7280);
  --link: var(--tg-theme-link-color, #0ea5e9);
  --btn-bg: var(--tg-theme-button-color, #0ea5e9);
  --btn-text: var(--tg-theme-button-text-color, #ffffff);
  --accent: var(--tg-theme-secondary-bg-color, #f3f4f6);
  --shadow-md: 0 6px 24px rgba(0,0,0,.08);
  --shadow-sm: 0 2px 10px rgba(0,0,0,.06);
}

* { box-sizing: border-box; }
html, body, #app { height: 100%; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font: 14px/1.45 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial;
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: transparent;
}

.hidden { display: none !important; }

.view { display: none; }
.view.active { display: block; }

.section { padding: 16px; display: grid; gap: 12px; }
.section-title { font-size: 18px; font-weight: 700; }
.small { font-size: 12px; }
.muted { color: var(--muted); }

/* Верхняя панель (на карте скрывается JS-ом) */
.topbar { position: sticky; top: 0; z-index: 10; background: var(--bg); padding: 12px 16px; }
.title { font-weight: 800; font-size: 20px; }

/* Профиль */
.profile-card { display: grid; grid-template-columns: auto 1fr; gap: 16px; align-items: start; }
.avatar { position: relative; width: 96px; height: 96px; }
.avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; border: 3px solid #fff; box-shadow: var(--shadow-sm); background:#eee; }
.avatar-edit { position: absolute; left: 50%; bottom: 6px; transform: translateX(-50%); background: rgba(0,0,0,.55); color:#fff; padding:2px 6px; border-radius: 999px; font-size:12px; }
.profile-meta { display: grid; gap: 8px; }
.profile-name-row { display:flex; gap:8px; align-items:center; }
.profile-name-row input { flex:1; padding:10px 12px; border-radius:12px; border:1px solid var(--accent); }
.profile-stats { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:6px; }

.progress-wrap { display: grid; gap: 6px; }
.progress-info { display:flex; align-items:center; gap:10px; color:var(--muted); font-size:13px; }
.rank { background: var(--accent); padding:2px 8px; border-radius:999px; font-weight:600; color: var(--text); }
.tokens-badge { margin-left:auto; background:#fff7ed; border:1px solid #fed7aa; color:#c2410c; border-radius:999px; padding:2px 8px; }
.progress-bar { height: 8px; background: var(--accent); border-radius: 999px; overflow: hidden; }
.progress-fill { height: 8px; background: var(--btn-bg); }

.profile-actions { display:flex; gap:8px; }

/* ===== Карта во весь экран (под таббар), без белых полос) ===== */
#view-map { position: fixed; inset: 0; z-index: 1; }
#map { position: absolute; inset: 0; }

/* Временная надпись "Карта" (fade) */
.map-title-fade {
  position: absolute;
  left: 50%; transform: translateX(-50%);
  top: 14px;
  z-index: 12;
  background: rgba(0,0,0,.65);
  color: #fff;
  padding: 10px 14px;
  border-radius: 12px;
  font-weight: 700;
  font-size: 18px;
  opacity: 0;
  transition: opacity .4s ease;
  pointer-events: none;
}
.map-title-fade.show { opacity: 1; }

/* Поиск/фильтр — только на карте, поверх карты, над таббаром */
.map-searchbar {
  position: absolute; left: 0; right: 0;
  bottom: calc(72px + env(safe-area-inset-bottom));
  display: grid; grid-template-columns: 1fr auto; gap: 8px;
  z-index: 12; padding: 10px 16px;
}
.map-searchbar input, .map-searchbar select {
  width: 100%; padding: 10px 12px; border-radius: 12px;
  border: 1px solid var(--accent); background: var(--bg); color: var(--text);
}

/* ===== Лист ===== */
.sheet { position: fixed; inset: 0; z-index: 1500; background: rgba(0,0,0,.15); }
.sheet__inner {
  margin: auto 8px calc(env(safe-area-inset-bottom) + 8px);
  padding: 12px; background: var(--bg); color: var(--text); border-radius: 16px;
  box-shadow: var(--shadow-md);
  display:flex; flex-direction:column; gap:8px;
  max-height: min(88svh, 88dvh);
  overflow-y:auto; -webkit-overflow-scrolling: touch;
}
.sheet__header { display:flex; align-items:center; gap:8px; }
.sheet__title { font-size:16px; font-weight:700; flex:1; }
.sheet__close { appearance:none; border:0; width:32px; height:32px; border-radius:8px; background: var(--accent); color: var(--text); font-weight:700; }
.sheet__img { width:100%; aspect-ratio:1/1; object-fit:cover; border-radius:12px; background:#e5e7eb; }
.sheet__desc { color: var(--muted); font-size:14px; white-space:pre-wrap; }
.sheet__actions { display:flex; gap:8px; }
.primary { background: var(--btn-bg); color: var(--btn-text); border:0; border-radius:12px; padding: 10px 16px; font-weight:700; }
.pill { border-radius: 999px; }

/* ===== Контролы карты (левый верх): кнопка + статус справа ===== */
.map-controls {
  position: fixed; left: 12px; top: calc(env(safe-area-inset-top) + 12px);
  z-index: 920; display:flex; align-items:center; gap:8px; pointer-events:none;
}
.icon-btn, .geo-hint { pointer-events:auto; }
.icon-btn {
  position: relative;
  width:44px; height:44px; display:inline-flex; align-items:center; justify-content:center;
  border:0; border-radius:999px; background:var(--bg); color:var(--text); box-shadow:var(--shadow-sm);
}
.icon-btn.loading::after {
  content:""; position:absolute; inset:-3px;
  border:2px solid rgba(0,0,0,.18); border-top-color: var(--text);
  border-radius:50%; animation:spin .8s linear infinite;
}
.geo-hint {
  /* ТОЛЬКО чёрный текст без фона */
  background: transparent; color: var(--text);
  padding: 0; border-radius: 0; font-size: 13px; white-space: nowrap;
  opacity:0; transform: translateX(6px); transition: opacity .2s, transform .2s;
}
.geo-hint.show { opacity:1; transform: translateX(0); }
@keyframes spin { to { transform: rotate(360deg); } }

/* Токены (2 в ряд) */
.token-grid { display:grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.token-card { background:#fff; border:1px solid #e5e7eb; border-radius:12px; overflow:hidden; box-shadow: var(--shadow-sm); cursor:pointer; }
.token-card img { width:100%; aspect-ratio:1/1; object-fit:cover; display:block; }
.token-card .t-name { padding:6px; font-size:12px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* Рейтинг */
.lb-search { display:flex; gap:8px; padding: 12px 16px; }
.leaderboard { list-style:none; margin:0; padding:16px; display:grid; gap:8px; }
.leaderboard li { display:grid; grid-template-columns: 32px 1fr auto auto; gap:10px; background: var(--accent); border-radius: 12px; padding: 10px 12px; }
.search-result { margin-top:0; padding-top:0; }

/* Таббар поверх карты */
.tabbar {
  position: fixed; left: 0; right: 0; bottom: 0;
  z-index: 900; background: var(--bg);
  padding: 12px 12px calc(env(safe-area-inset-bottom) + 12px);
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px;
  box-shadow: 0 -6px 20px rgba(0,0,0,.06);
}
.tab-btn { appearance:none; border:0; border-radius:14px; background: var(--accent); color: var(--text); display:flex; align-items:center; justify-content:center; gap:8px; padding: 10px 12px; font-weight:700; box-shadow: var(--shadow-sm); }
.tab-btn.active { background: var(--btn-bg); color: var(--btn-text); }
.tab-btn img { width:18px; height:18px; }

/* Онбординг */
.onboarding { position: fixed; inset:0; z-index:1400; display:none; align-items:center; justify-content:center; padding:16px; }
.onboarding.show { display:flex; }
.onboarding > .onb__card { background: var(--bg); color: var(--text); border-radius: 16px; padding: 16px; box-shadow: var(--shadow-md); display:grid; gap:10px; max-width:480px; width:100%; }

/* Тост */
.toast { position: fixed; left: 50%; transform: translateX(-50%); bottom: calc(72px + env(safe-area-inset-bottom)); z-index: 1600; background: rgba(0,0,0,.85); color:#fff; padding: 10px 12px; border-radius: 10px; opacity:0; transition: opacity .2s ease, transform .2s ease; }
.toast.show { opacity:1; transform: translate(-50%, -6px); }

/* Маркеры */
.pin-marker { width: 28px; height: 28px; }
.pin-marker svg { display:block; width:100%; height:100%; }
