/* ==========================================================================
   /tools/znachenie-imeni — Словарь значений имён
   Наследует hero/seo/faq/author/share/tip из bmi-calculator.css.
   Палитра — тёплые розово-золотые тона раздела «Имена».
   ========================================================================== */
@import url("/assets/css/bmi-calculator.css");
@import url("/assets/css/partners.css");

:root {
  --zn-gold: var(--gold-color, #bda000);
  --zn-pink: #f7cbca;
  --zn-girl: #d98aa0;
  --zn-boy:  #5b8bbf;
  --zn-line: #efc9c8;
}

.zn-page { background: #fdf7f6 !important; }
.zn-seo a, .zn-page .faq-answer-inner p a, .mb-tip a {
  color: var(--zn-gold);
  text-decoration: underline;
  text-decoration-color: rgba(189, 160, 0, 0.35);
  text-underline-offset: 3px;
}
.zn-seo a:hover, .zn-page .faq-answer-inner p a:hover, .mb-tip a:hover { text-decoration-color: var(--zn-gold); }

.zn-hero {
  background:
    radial-gradient(ellipse 60% 70% at 50% 45%, rgba(253,247,246,0.55) 0%, rgba(253,247,246,0) 70%),
    url("/assets/images/znachenie-imeni-hero-bg.webp") center / cover no-repeat,
    linear-gradient(180deg, #ffffff 0%, #f7e6e5 100%) !important;
  border-bottom-color: var(--zn-line) !important;
  padding: 165px 0 84px !important;   /* выше базового (110/56) примерно в 1.5 раза */
}
.zn-hero .mb-hero-title span::after {
  background: linear-gradient(90deg, rgba(247,203,202,0.7), rgba(189,160,0,0.35));
}

/* ---------- поиск ---------- */
.zn-app { margin-top: 0 !important; padding-top: 12px !important; } /* перебиваем глобальный section{padding:30px 0!important} */
.zn-searchbar {
  position: relative;
  display: flex;
  align-items: center;
}
.zn-search-ic {
  position: absolute;
  left: 16px;
  width: 20px; height: 20px;
  color: #a08c8e;
  pointer-events: none;
}
.zn-search {
  width: 100%;
  box-sizing: border-box;
  padding: 15px 44px 15px 46px;
  font-size: 16px;
  font-family: inherit;
  color: #2b2326;
  background: #fff;
  border: 1.5px solid #ecd9d8;
  border-radius: 14px;
  box-shadow: 0 6px 20px rgba(189, 100, 100, 0.06);
  transition: border-color .18s ease, box-shadow .18s ease;
}
.zn-search:focus {
  outline: none;
  border-color: var(--zn-pink);
  box-shadow: 0 0 0 3px rgba(247, 203, 202, 0.35);
}
.zn-clear {
  position: absolute;
  right: 12px;
  width: 28px; height: 28px;
  border: none;
  background: #f3eaea;
  color: #6b5658;
  border-radius: 50%;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
}
.zn-clear:hover { background: #ecd9d8; }
.zn-count {
  margin: 12px 2px 0;
  font-size: 14px;
  font-weight: 600;
  color: #6b5658;
}

/* ---------- алфавит ---------- */
.zn-alpha {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin: 16px 0 8px;
  padding: 10px;
  background: #fff;
  border: 1px solid var(--zn-line);
  border-radius: 12px;
}
.zn-alpha-l {
  min-width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 14px;
  color: #6b5658;
  text-decoration: none;
  border-radius: 7px;
  transition: all .14s ease;
}
.zn-alpha-l:hover { background: var(--zn-gold); color: #fff; }

.zn-disclaimer {
  margin: 18px 2px 0;
  font-size: 12.5px;
  line-height: 1.45;
  color: #a08c8e;
  padding-left: 10px;
  border-left: 2px solid #efdcc0;
}

/* ---------- словарь: сворачиваемые буквы ---------- */
.zn-letter {
  scroll-margin-top: 80px;
  margin: 6px 0 !important;       /* перебиваем глобальное section{margin-bottom:40px!important} */
  padding: 0 !important;          /* и section{padding:30px 0!important} — отсюда была пустота */
  border: 1px solid #f0e2e1;
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
}
.zn-letter-h { margin: 0 !important; }
.zn-letter-toggle {
  width: 100%;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  background: #fff;
  border: none;
  cursor: pointer;
  text-align: left;
  transition: background .16s ease;
}
.zn-letter-toggle:hover { background: #fdf6f5; }
.zn-letter-l {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-head, "Montserrat", sans-serif);
  font-size: 15px;
  font-weight: 800;
  color: #fff;
  background: linear-gradient(135deg, #e9c86a 0%, var(--zn-gold) 100%);
  border-radius: 8px;
}
.zn-letter-count {
  font-size: 13.5px;
  font-weight: 600;
  color: #8a7376;
}
.zn-letter-caret {
  width: 16px; height: 16px;
  margin-left: auto;
  color: #c4a9ab;
  transition: transform .2s ease;
}
/* развёрнутая буква: шапка чуть выделена снизу */
.zn-letter:not(.is-collapsed) > .zn-letter-h .zn-letter-toggle { border-bottom: 1px solid #f3eaea; }
.zn-letter.is-collapsed .zn-letter-caret { transform: rotate(-90deg); }

.zn-collapse {
  overflow: hidden;
}
/* класс добавляется JS после первичного сворачивания — чтобы старт был без анимации */
.zn-collapse.zn-anim { transition: max-height .3s ease; }
.zn-collapse .zn-grid { padding: 14px; }

.zn-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 12px;
}
.zn-name {
  min-width: 0;
  background: #fff;
  border: 1px solid #f0e2e1;
  border-radius: 12px;
  padding: 14px 16px;
  border-left: 3px solid var(--zn-pink);
}
.zn-name--ж { border-left-color: var(--zn-girl); }
.zn-name--м { border-left-color: var(--zn-boy); }
.zn-name-head { display: flex; align-items: center; gap: 8px; }
.zn-gender { font-size: 15px; line-height: 1; flex-shrink: 0; }
.zn-gender--ж { color: var(--zn-girl); }
.zn-gender--м { color: var(--zn-boy); }
.zn-name-t {
  font-family: var(--font-head, "Montserrat", sans-serif);
  font-size: 18px;
  font-weight: 700;
  color: #2b2326;
  margin: 0;
}
.zn-meaning {
  margin: 6px 0 0;
  font-size: 14.5px;
  color: #4f4346;
  line-height: 1.45;
  overflow-wrap: break-word;
}
.zn-extra {
  margin: 8px 0 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.zn-extra-row {
  display: flex;
  gap: 6px;
  font-size: 13px;
  line-height: 1.4;
}
.zn-extra dt {
  flex-shrink: 0;
  font-weight: 700;
  color: #a08c8e;
  margin: 0;
}
.zn-extra dd {
  margin: 0;
  color: #4f4346;
  overflow-wrap: break-word;
}

.zn-meta {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}
.zn-origin { font-size: 12.5px; color: #a08c8e; font-style: italic; }
.zn-tag {
  font-size: 11px;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 6px;
  background: #f3eaea;
  color: #8a7376;
  white-space: nowrap;
}
.zn-tag--popular  { background: #fbf0d6; color: #9a7416; }
.zn-tag--rare     { background: #ece4f5; color: #6f51a0; }
.zn-tag--foreign  { background: #e0eef5; color: #3f7796; }
.zn-tag--orthodox { background: #f3e9df; color: #97703d; }
.zn-tag--old      { background: #eae6df; color: #7a6e54; }
.zn-tag--short    { background: #e6f0e8; color: #4f7d5a; }

.zn-empty {
  text-align: center;
  color: #8a7376;
  padding: 36px 16px;
  font-size: 15.5px;
}

/* ---------- кросс-ссылки ---------- */
.zn-cross {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin: 30px 0 10px;
}
.zn-cross-card {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 16px 18px;
  background: #fff;
  border: 1px solid var(--zn-line);
  border-radius: 12px;
  text-decoration: none;
  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.zn-cross-card:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(180,120,120,0.12); border-color: var(--zn-pink); }
.zn-cross-card strong {
  font-family: var(--font-head, "Montserrat", sans-serif);
  font-size: 15.5px;
  color: #2b2326;
}
.zn-cross-card span { font-size: 13px; color: #7a6466; line-height: 1.4; }

/* ---------- нумерованные списки в SEO ---------- */
.zn-seo ol {
  counter-reset: zn-step;
  list-style: none;
  padding-left: 0;
  margin: 18px 0 22px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.zn-seo ol > li {
  counter-increment: zn-step;
  position: relative;
  padding: 16px 22px 16px 64px;
  background: linear-gradient(135deg, #fdf6f5 0%, #ffffff 60%);
  border: 1px solid #efdcdb;
  border-radius: 14px;
  font-size: 15px;
  line-height: 1.6;
  color: var(--main-bg-color, #222);
}
.zn-seo ol > li::before {
  content: counter(zn-step);
  position: absolute;
  left: 16px;
  top: 14px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #e0908a;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-head, "Montserrat", sans-serif);
  font-weight: 700;
  font-size: 14px;
  box-shadow: 0 2px 6px rgba(224, 144, 138, 0.35);
}
@media (max-width: 480px) {
  .zn-seo ol > li { padding: 14px 16px 14px 54px; font-size: 14.5px; }
  .zn-seo ol > li::before { left: 12px; top: 12px; width: 28px; height: 28px; font-size: 13px; }
}

/* ---------- адаптив ---------- */
@media (max-width: 760px) {
  .zn-hero { padding: 118px 0 30px !important; }
  .zn-app { margin-top: 10px; }
  .zn-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 10px; }
  .zn-cross { grid-template-columns: 1fr; }
  .zn-alpha { top: 56px; }
}
@media (max-width: 600px) {
  /* один столбец — чтобы длинные имена («Александра») не переносились в плашке */
  .zn-grid { grid-template-columns: 1fr; }
  .zn-name { padding: 12px 13px; }
  .zn-name-t { font-size: 16.5px; }
  .zn-alpha-l { min-width: 26px; height: 26px; font-size: 13px; }
}
