/* ───────────────────────────────────────────────────────
   PSY-Калькуляторы — стили страницы-хаба
   Используются только на странице /psy-kalkulyatory/
   ─────────────────────────────────────────────────────── */

/* Категорийные акценты — те же, что в самих калькуляторах */
.psy-calc-hub {
  --cat-zdorove: #4D600E;
  --cat-krasota: #B85C3E;
  --cat-ves: #8B6420;
  --cat-son: #3D5A80;
  --cat-dengi: #7A6F2C;
  --cat-otnosheniya: #A0506E;
  --cat-effectivnost: #2C5F5D;
  --cat-zhelaniya: #C9A227;
  --cat-reseting: #5C53A8;
  --cat-emocii: #7D8B5F;
  --cat-sos: #C5544A;
  --cat-premium: #37411F;
  font-family: 'Raleway', sans-serif;
  color: var(--text-body, #4A4A42);
  line-height: 1.6;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
}

/* === ГЕРОЙ === */
.psy-calc-hub__hero { text-align: center; padding: 12px 0 28px; }
/* Перебиваем правило темы section:first-child { padding-top: 150px } */
section.psy-calc-hub__hero:first-child { padding-top: 12px; }
.psy-calc-hub__hero-badge { display: inline-block; font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--grass, #4D600E); border: 1px solid rgba(77, 96, 14, 0.35); padding: 6px 18px; border-radius: 20px; margin-bottom: 20px; }
.psy-calc-hub__hero-title { font-family: 'Montserrat', sans-serif; font-size: clamp(28px, 4.5vw, 44px); font-weight: 500; line-height: 1.2; color: var(--text-dark, #2C2C28); margin: 0 auto 16px; max-width: 760px; }
.psy-calc-hub__hero-subtitle { font-size: clamp(16px, 1.8vw, 18px); color: var(--text-body, #4A4A42); max-width: 640px; margin: 0 auto; line-height: 1.55; }

/* === ПОЛОСА ПРИНЦИПОВ === */
.psy-calc-hub__principles { background: var(--sage, #E7E9DE); border-radius: 14px; padding: 22px 28px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-bottom: 40px; }
@media (max-width: 768px) { .psy-calc-hub__principles { grid-template-columns: 1fr; gap: 16px; padding: 20px; } }
.psy-calc-hub__principle { display: flex; gap: 14px; align-items: flex-start; }
.psy-calc-hub__principle-icon { width: 36px; height: 36px; border-radius: 50%; background: #FFFFFF; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 16px; color: var(--grass, #4D600E); }
.psy-calc-hub__principle-head { font-family: 'Montserrat', sans-serif; font-size: 14px; font-weight: 600; color: var(--moss-dark, #37411F); margin-bottom: 4px; line-height: 1.3; }
.psy-calc-hub__principle-desc { font-size: 13px; color: var(--text-body, #4A4A42); line-height: 1.5; }

/* === СЕТКА КАРТОЧЕК === */
.psy-calc-hub__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
@media (max-width: 768px) { .psy-calc-hub__grid { grid-template-columns: 1fr; gap: 16px; } }

.psy-calc-hub__card { background: #FFFFFF; border: 1px solid var(--border, #E0DED6); border-radius: 16px; padding: 28px 28px 24px; display: flex; flex-direction: column; transition: all 0.3s; box-shadow: 0 1px 3px rgba(0,0,0,0.04); position: relative; overflow: hidden; cursor: pointer; text-decoration: none; color: inherit; }
.psy-calc-hub__card::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--cat-color, var(--grass, #4D600E)); }
.psy-calc-hub__card:hover { border-color: var(--cat-color, var(--grass, #4D600E)); transform: translateY(-3px); box-shadow: 0 12px 32px rgba(55, 65, 31, 0.10); }
.psy-calc-hub__card--soon { opacity: 0.65; cursor: default; pointer-events: none; }

.psy-calc-hub__card-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 18px; gap: 12px; flex-wrap: wrap; }
.psy-calc-hub__card-category { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--cat-color, var(--grass, #4D600E)); border: 1px solid currentColor; opacity: 0.8; padding: 5px 12px; border-radius: 12px; }
.psy-calc-hub__card-meta { display: flex; gap: 14px; font-size: 12px; color: var(--text-muted, #8A8A7E); }
.psy-calc-hub__card-meta span { display: inline-flex; align-items: center; gap: 4px; }

.psy-calc-hub__card-title { font-family: 'Montserrat', sans-serif; font-size: 22px; font-weight: 500; line-height: 1.3; color: var(--text-dark, #2C2C28); margin-bottom: 14px; min-height: 84px; }
@media (max-width: 768px) { .psy-calc-hub__card-title { min-height: 0; font-size: 20px; } }

.psy-calc-hub__card-desc { font-size: 15px; color: var(--text-body, #4A4A42); line-height: 1.55; margin-bottom: 18px; }

.psy-calc-hub__card-list { margin-bottom: 22px; display: flex; flex-direction: column; gap: 8px; padding: 0; list-style: none; }
.psy-calc-hub__card-list-item { display: flex; gap: 10px; align-items: flex-start; font-size: 14px; color: var(--text-body, #4A4A42); line-height: 1.5; }
.psy-calc-hub__card-list-bullet { width: 6px; height: 6px; border-radius: 50%; background: var(--cat-color, var(--grass, #4D600E)); flex-shrink: 0; margin-top: 8px; }

.psy-calc-hub__card-gift { font-size: 13px; color: var(--text-muted, #8A8A7E); padding: 10px 14px; background: var(--sage, #E7E9DE); border-radius: 8px; margin-bottom: 18px; line-height: 1.4; }
.psy-calc-hub__card-gift strong { color: var(--moss-dark, #37411F); }

.psy-calc-hub__card-footer { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.psy-calc-hub__card-cta { display: inline-flex; align-items: center; gap: 8px; background: var(--btn-blue, #5B7FD6); color: #fff; font-family: 'Raleway', sans-serif; font-size: 14px; font-weight: 600; padding: 12px 22px; border-radius: 8px; transition: all 0.2s; text-decoration: none; }
.psy-calc-hub__card:hover .psy-calc-hub__card-cta { background: var(--btn-blue-hover, #4A6BC4); transform: translateX(3px); }
.psy-calc-hub__card-price { font-size: 13px; color: var(--text-muted, #8A8A7E); }

/* === ПОДВАЛЬНЫЙ CTA === */
.psy-calc-hub__footer { margin-top: 56px; padding: 32px; background: linear-gradient(135deg, var(--grass, #4D600E) 0%, var(--moss-dark, #37411F) 100%); border-radius: 20px; color: #fff; text-align: center; }
.psy-calc-hub__footer-title { font-family: 'Montserrat', sans-serif; font-size: clamp(18px, 2.4vw, 26px); font-weight: 500; margin-bottom: 14px; line-height: 1.3; }
.psy-calc-hub__footer-desc { font-size: 15px; line-height: 1.65; color: rgba(255, 255, 255, 0.88); max-width: 740px; margin: 0 auto 24px; text-align: left; }
@media (max-width: 600px) { .psy-calc-hub__footer-desc { font-size: 14px; } }
.psy-calc-hub__footer-cta { display: inline-block; background: var(--grass-light, #97B261); color: var(--moss-dark, #37411F); font-family: 'Raleway', sans-serif; font-size: 15px; font-weight: 700; padding: 14px 32px; border-radius: 8px; transition: all 0.3s; text-decoration: none; }
.psy-calc-hub__footer-cta:hover { background: var(--sage, #E7E9DE); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(231, 233, 222, 0.3); }

/* === Пустое состояние === */
.psy-calc-hub__empty { text-align: center; padding: 80px 20px; color: var(--text-muted, #8A8A7E); font-size: 16px; }
