@import url('https://fonts.googleapis.com/css2?family=Cormorant:ital,wght@0,400;0,500;0,600;1,400&family=Karla:wght@300;400;500;700&display=swap');

/* ───────── Тема: тянем переменные Telegram, с тёплыми fallback'ами для браузера ───────── */
:root {
  --bg:      var(--tg-theme-bg-color, #f7f3ea);
  --surface: var(--tg-theme-secondary-bg-color, #efe9db);
  --text:    var(--tg-theme-text-color, #211d16);
  --hint:    var(--tg-theme-hint-color, #948b78);
  --link:    var(--tg-theme-link-color, #9a7b1f);
  --gold:    #b08d2e;
  --gold-soft: #d8c489;
  --ink:     #211d16;
  --line:    color-mix(in srgb, var(--text) 14%, transparent);
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: 'Karla', -apple-system, sans-serif;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  font-size: 16px;
  line-height: 1.55;
}

#app { max-width: 480px; margin: 0 auto; min-height: 100vh; }

/* ───────── Экран ───────── */
.screen {
  padding: 28px 22px 64px;
  animation: rise .5s cubic-bezier(.16,.84,.44,1) both;
}
@keyframes rise { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }

h1 {
  font-family: 'Cormorant', Georgia, serif;
  font-weight: 500;
  font-size: 2.4rem;
  letter-spacing: .01em;
  line-height: 1.05;
  margin: .1em 0 .7em;
}
h2 {
  font-family: 'Cormorant', Georgia, serif;
  font-weight: 600;
  font-size: 1.5rem;
  margin: 1.8em 0 .5em;
  padding-bottom: .25em;
  border-bottom: 1px solid var(--line);
}
.muted { color: var(--hint); font-style: italic; }

/* ───────── Поля ввода ───────── */
input[type="text"], input[type="date"], input[type="time"], input:not([type]) {
  width: 100%;
  padding: 13px 14px;
  margin: 7px 0;
  background: var(--bg);
  color: var(--text);
  border: 1px solid var(--line);
  border-radius: 12px;
  font: inherit;
  transition: border-color .2s;
}
input:focus { outline: none; border-color: var(--gold); }
input:disabled { opacity: .45; }

.row {
  display: flex; align-items: center; gap: 9px;
  margin: 10px 0; color: var(--hint); font-size: .92rem;
}
.row input[type="checkbox"] { width: auto; accent-color: var(--gold); }

/* ───────── Кнопки ───────── */
button {
  font: inherit; cursor: pointer; border: none;
  border-radius: 12px; transition: transform .12s, opacity .2s, background .2s;
}
button:active { transform: scale(.98); }

.primary {
  display: block; width: 100%;
  margin-top: 18px; padding: 15px;
  background: var(--ink); color: #f7f3ea;
  font-weight: 700; letter-spacing: .03em;
}
.primary:disabled { opacity: .35; cursor: default; }

.ghost {
  display: inline-block; margin-top: 14px; padding: 8px 2px;
  background: none; color: var(--hint);
  font-size: .9rem; letter-spacing: .04em; text-transform: uppercase;
}

/* ───────── Список карт ───────── */
.card-list { display: flex; flex-direction: column; gap: 10px; margin-bottom: 8px; }
.card-row {
  text-align: left; padding: 16px 18px;
  background: var(--surface); color: var(--text);
  font-size: 1.05rem; border: 1px solid transparent;
}
.card-row:hover { border-color: var(--gold-soft); }

/* ───────── Автодополнение города ───────── */
.city-results { display: flex; flex-direction: column; }
.city-opt {
  text-align: left; padding: 11px 14px;
  background: var(--surface); color: var(--text);
  border-radius: 0; border-bottom: 1px solid var(--line);
  font-size: .95rem;
}
.city-opt:first-child { border-radius: 10px 10px 0 0; }
.city-opt:last-child  { border-radius: 0 0 10px 10px; border-bottom: none; }
.city-opt:hover { background: var(--gold-soft); }

/* ───────── Сводка (Тип · Профиль · Авторитет · Определение) ───────── */
.summary {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1px;
  background: var(--line); border: 1px solid var(--line);
  border-radius: 12px; overflow: hidden; margin-bottom: 22px;
}
.summary span {
  background: var(--bg); padding: 13px 15px;
  font-family: 'Cormorant', serif; font-size: 1.25rem; font-weight: 500;
}
.summary span:nth-child(odd) { color: var(--gold); }

/* ───────── Бодиграф ───────── */
#bg-canvas { display: flex; justify-content: center; margin: 6px 0 10px; }
svg.bodygraph {
  width: 100%; max-width: 330px; height: auto;
  filter: drop-shadow(0 6px 20px rgba(33,29,22,.12));
}
svg.bodygraph .center { transition: fill .25s; }
svg.bodygraph .channel { transition: stroke .25s, stroke-width .25s; }

/* ───────── Шторка с трактовкой ───────── */
.sheet {
  position: fixed; left: 0; right: 0; bottom: 0;
  max-width: 480px; margin: 0 auto;
  max-height: 56vh; overflow-y: auto;
  padding: 24px 22px 32px;
  background: var(--surface);
  border-radius: 22px 22px 0 0;
  box-shadow: 0 -12px 40px rgba(33,29,22,.22);
  font-size: 1rem; line-height: 1.65;
  transform: translateY(0); transition: transform .32s cubic-bezier(.16,.84,.44,1);
  visibility: visible; z-index: 50;
}
.sheet.hidden { transform: translateY(110%); visibility: hidden; }
.sheet::before {
  content: ""; display: block; width: 40px; height: 4px;
  background: var(--line); border-radius: 4px; margin: -8px auto 16px;
}

/* ───────── Блоки разбора ───────── */
.block {
  border: 1px solid var(--line); border-radius: 12px;
  margin-bottom: 9px; padding: 4px 16px; background: var(--bg);
}
.block summary {
  cursor: pointer; padding: 11px 0; list-style: none;
  font-weight: 700; text-transform: capitalize;
  letter-spacing: .02em; color: var(--gold);
}
.block summary::-webkit-details-marker { display: none; }
.block summary::after { content: "+"; float: right; color: var(--hint); font-weight: 400; }
.block[open] summary::after { content: "–"; }
.block p { margin: 0 0 14px; }

.synthesis {
  font-family: 'Cormorant', Georgia, serif;
  font-size: 1.2rem; line-height: 1.6;
  white-space: pre-wrap;
}
