/* ============================================================
   VSTUPNYK — Навігатор вступника
   ============================================================ */

/* ---- Hero ---- */
.vstup-hero {
  background: var(--color-white);
  border-bottom: 1px solid var(--color-gray-200);
  padding: var(--space-8) 0 var(--space-10);
  margin-top: var(--header-height);
}

.vstup-hero__inner {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: var(--space-10);
  align-items: start;
}

.vstup-hero__title {
  font-size: var(--text-4xl);
  margin-bottom: var(--space-3);
}

.vstup-hero__subtitle {
  font-size: var(--text-base);
  color: var(--color-gray-600);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-6);
  max-width: 560px;
}

/* Stat badges row */
.vstup-hero__badges {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-8);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.vstup-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--color-gray-100);
  border: 1px solid var(--color-gray-200);
  color: var(--color-gray-800);
  font-size: var(--text-sm);
  font-weight: 600;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-full);
  white-space: nowrap;
}

.vstup-hero__badge svg,
.vstup-hero__badge-icon {
  flex-shrink: 0;
  color: var(--color-pink);
  font-weight: 700;
  font-size: var(--text-sm);
  line-height: 1;
}

/* CTA buttons */
.vstup-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
}

/* Right aside: two stacked cards */
.vstup-hero__aside {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

/* Dates card */
.vstup-hero__dates-card {
  background: var(--color-gray-50);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  padding: var(--space-5) var(--space-6);
}

.vstup-hero__dates {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-top: var(--space-3);
}

.vstup-hero__date-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.vstup-hero__date-label {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  color: var(--color-gray-500);
}

.vstup-hero__date-val {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-pink);
}

/* Contact card */
.vstup-hero__contact {
  background: var(--color-gray-50);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  padding: var(--space-5) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.vstup-hero__contact-head {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}

.vstup-hero__contact-icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  background: var(--color-pink);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: Georgia, serif;
  font-size: 1.1rem;
  font-style: italic;
  font-weight: 700;
  line-height: 1;
  user-select: none;
}

.vstup-hero__contact-label {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  color: var(--color-gray-500);
  margin: 0 0 var(--space-1);
}

.vstup-hero__contact-name {
  font-weight: 700;
  font-size: var(--text-base);
  color: var(--color-black);
  margin: 0;
}

.vstup-hero__contact-rows {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.vstup-hero__contact-rows li {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-gray-700);
}

.vstup-hero__contact-rows li svg {
  flex-shrink: 0;
  color: var(--color-pink);
}

.vstup-hero__contact-rows a {
  color: var(--color-gray-700);
  text-decoration: none;
}

.vstup-hero__contact-rows a:hover {
  color: var(--color-pink);
  text-decoration: underline;
}

/* ---- Steps ---- */
.vstup-steps__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  counter-reset: none;
}

.vstup-step {
  display: flex;
  gap: var(--space-5);
  align-items: flex-start;
  padding: var(--space-5) var(--space-6);
  background: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
}

.vstup-step__num {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  background: var(--color-pink);
  color: var(--color-white);
  font-weight: 700;
  font-size: var(--text-lg);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.vstup-step__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.vstup-step__title {
  font-size: var(--text-base);
  font-weight: 700;
}

.vstup-step__hint {
  font-size: var(--text-sm);
  color: var(--color-gray-600);
  margin: 0;
}

/* ---- Dates / Tabs ---- */
.vstup-tabs {
  display: flex;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  border-bottom: 2px solid var(--color-gray-200);
  padding-bottom: 0;
}

.vstup-tab-btn {
  padding: var(--space-3) var(--space-5);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-gray-600);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  transition: color var(--duration-fast), border-color var(--duration-fast);
}

.vstup-tab-btn:hover { color: var(--color-pink); }
.vstup-tab-btn.is-active {
  color: var(--color-pink);
  border-bottom-color: var(--color-pink);
}

.vstup-dates-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.vstup-dates-table th,
.vstup-dates-table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-gray-200);
  text-align: left;
}

.vstup-dates-table th {
  font-weight: 700;
  color: var(--color-gray-500);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  background: var(--color-gray-50);
}

.vstup-dates-table td:first-child {
  font-weight: 600;
  white-space: nowrap;
  width: 240px;
}

.vstup-dates-table__critical td {
  background: #fff8f0;
  color: #c05c00;
  font-weight: 600;
}

/* ---- Documents ---- */
.vstup-docs__tip {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  background: #f0f7ff;
  border: 1px solid #bfd9f7;
  border-radius: var(--radius-lg);
  padding: var(--space-3) var(--space-5);
  font-size: var(--text-sm);
  color: #1a5fa6;
  margin-bottom: var(--space-8);
}

.vstup-docs__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

.vstup-doc-block {
  background: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
}

.vstup-doc-block__title {
  font-size: var(--text-sm);
  font-weight: 700;
  margin-bottom: var(--space-4);
  color: var(--color-black);
}

.vstup-doc-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.vstup-doc-list li {
  font-size: var(--text-sm);
  color: var(--color-gray-700);
  padding-left: var(--space-6);
  position: relative;
}

.vstup-doc-list li::before {
  content: '—';
  position: absolute;
  left: 0;
  color: var(--color-gray-400);
}

/* ---- Accordion ---- */
.vstup-accordion {
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.vstup-accordion__item + .vstup-accordion__item {
  border-top: 1px solid var(--color-gray-200);
}

.vstup-accordion__trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-6);
  font-size: var(--text-base);
  font-weight: 600;
  background: var(--color-white);
  border: none;
  cursor: pointer;
  text-align: left;
  transition: background var(--duration-fast);
}

.vstup-accordion__trigger:hover { background: var(--color-gray-50); }

.vstup-accordion__trigger[aria-expanded="true"] { background: var(--color-gray-50); }

.vstup-accordion__trigger[aria-expanded="true"] .vstup-accordion__icon {
  transform: rotate(180deg);
}

.vstup-accordion__icon {
  flex-shrink: 0;
  transition: transform var(--duration-fast);
}

.vstup-accordion__content {
  padding: var(--space-4) var(--space-6) var(--space-5);
  background: var(--color-gray-50);
  border-top: 1px solid var(--color-gray-200);
}

.vstup-accordion__instruments {
  font-size: var(--text-sm);
  color: var(--color-gray-700);
  margin: 0 0 var(--space-3);
}

.vstup-accordion__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-sm);
  color: var(--color-pink);
  text-decoration: none;
  font-weight: 600;
}

.vstup-accordion__link:hover { text-decoration: underline; }

/* ---- Specialties cards (dept-card override: no count row — smaller collapsed height) ---- */
.vstup-specs .dept-card {
  min-height: 220px;
}
.vstup-specs .dept-card__glass {
  /* collapsed: padding-top + title + padding-bottom */
  height: calc(20px + 1.35rem + 20px);
}
.vstup-specs .dept-card__glass-desc {
  -webkit-line-clamp: 4;
}

/* ---- Exam ---- */
.vstup-exam__parts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
}

.vstup-exam__part {
  background: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
}

.vstup-exam__part-title {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-lg);
  font-weight: 700;
  margin-bottom: var(--space-4);
}

.vstup-exam__part-num {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  background: var(--color-pink);
  color: var(--color-white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-sm);
  font-weight: 700;
}

.vstup-exam__tasks {
  font-size: var(--text-sm);
  color: var(--color-gray-700);
  padding-left: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.vstup-exam__tips {
  margin-top: var(--space-5);
  padding: var(--space-4);
  background: var(--color-gray-50);
  border-radius: var(--radius-lg);
}

.vstup-exam__tips-title {
  font-weight: 700;
  font-size: var(--text-sm);
  margin-bottom: var(--space-2);
}

.vstup-exam__tips ul {
  font-size: var(--text-sm);
  color: var(--color-gray-700);
  padding-left: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

/* ---- Motivation letter ---- */
.vstup-letter__intro {
  font-size: var(--text-lg);
  color: var(--color-gray-600);
  margin-bottom: var(--space-8);
  max-width: 60ch;
}

.vstup-letter-template {
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.vstup-letter-step {
  display: flex;
  gap: var(--space-5);
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--color-gray-200);
}

.vstup-letter-step:last-child { border-bottom: none; }

.vstup-letter-step__num {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border: 2px solid var(--color-pink);
  color: var(--color-pink);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: var(--text-sm);
}

.vstup-letter-step__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  font-size: var(--text-sm);
}

.vstup-letter-step__body strong {
  font-size: var(--text-base);
}

.vstup-letter-step__body p {
  color: var(--color-gray-700);
  margin: 0;
  line-height: var(--lh-relaxed);
}

.vstup-letter-step__example {
  background: var(--color-gray-50);
  border-left: 3px solid var(--color-pink);
  padding: var(--space-3) var(--space-4);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  color: var(--color-gray-600) !important;
}

/* ---- Help / Contact ---- */
.vstup-contact-card {
  background: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-8);
  max-width: 720px;
}

.vstup-contact-card__title {
  grid-column: 1 / -1;
  font-size: var(--text-xl);
  font-weight: 700;
  margin-bottom: 0;
}

.vstup-contact-card__info {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.vstup-contact-card__info p {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-gray-700);
  margin: 0;
}

.vstup-contact-card__info a {
  color: var(--color-pink);
  text-decoration: none;
  font-weight: 600;
}

.vstup-contact-card__services-title {
  font-weight: 700;
  font-size: var(--text-sm);
  margin-bottom: var(--space-2);
}

.vstup-contact-card__services ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  font-size: var(--text-sm);
  color: var(--color-gray-700);
}

.vstup-contact-card__services li::before {
  content: '✓ ';
  color: var(--color-pink);
  font-weight: 700;
}

/* ---- Links ---- */
.vstup-links-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}

.vstup-link-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-6);
  background: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  text-decoration: none;
  transition: border-color var(--duration-fast), box-shadow var(--duration-fast);
}

.vstup-link-card:hover {
  border-color: var(--color-pink);
  box-shadow: 0 4px 16px rgba(0,0,0,.06);
}

.vstup-link-card svg { color: var(--color-pink); }

.vstup-link-card__title {
  font-weight: 700;
  color: var(--color-black);
  font-size: var(--text-base);
  flex: 1;
}

.vstup-link-card__cta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-pink);
}

.vstup-link-card--inactive {
  pointer-events: none;
  opacity: .55;
}

.vstup-link-card--inactive .vstup-link-card__cta {
  color: var(--color-gray-400);
}

/* ---- Help layout ---- */
.vstup-help__layout {
  display: flex;
  gap: var(--space-8);
  align-items: flex-start;
  flex-wrap: wrap;
}

.vstup-help__layout--with-secretary .vstup-contact-card {
  flex: 1 1 400px;
  max-width: none;
}

.vstup-secretary-card {
  flex: 0 0 220px;
}

.vstup-secretary-card .person-card__info {
  text-align: center;
  align-items: center;
}

/* ---- Responsive ---- */
@media (max-width: 1024px) {
  .vstup-hero__inner { grid-template-columns: 1fr; }
  .vstup-hero__aside { flex-direction: row; flex-wrap: wrap; }
  .vstup-hero__dates-card,
  .vstup-hero__contact { flex: 1 1 260px; }
  .vstup-hero__subtitle { max-width: 100%; }
  .vstup-docs__grid { grid-template-columns: 1fr 1fr; }
  .vstup-exam__parts { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .vstup-docs__grid { grid-template-columns: 1fr; }
  .vstup-links-grid { grid-template-columns: 1fr; }
  .vstup-contact-card { grid-template-columns: 1fr; gap: var(--space-5); }
  .vstup-dates-table td:first-child { white-space: normal; width: auto; }
  .vstup-help__layout { flex-direction: column; }
  .vstup-secretary-card { flex: 0 0 auto; width: 100%; max-width: 280px; }
}

@media (max-width: 600px) {
  .vstup-hero { padding: var(--space-10) 0 var(--space-8); }
  .vstup-hero__title { font-size: var(--text-3xl); }
  .vstup-hero__badge { font-size: var(--text-xs); }
  .vstup-hero__aside { flex-direction: column; }
  .vstup-step { flex-direction: column; }
}
