/* /configurator — пошаговый конфигуратор */

.configurator-page { padding-top: calc(var(--topbar-h) + var(--header-h)); }
.configurator-page .header { top: var(--topbar-h); }

.cfg-progress {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 0 24px;
  padding: 0;
  list-style: none;
}

.cfg-progress__step {
  flex: 1 1 100px;
  padding: 8px 10px;
  border-radius: var(--radius);
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.02);
  font-size: 11px;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 8px;
}

.cfg-progress__step--active {
  border-color: rgba(255, 107, 44, 0.45);
  color: var(--text);
  background: rgba(255, 107, 44, 0.08);
}

.cfg-progress__step--done { opacity: 0.7; }

.cfg-progress__num {
  font-family: var(--font-mono);
  font-weight: 600;
  color: var(--accent);
}

.cfg-step { margin-bottom: 20px; }

.cfg-step__title {
  font-size: 20px;
  margin: 0 0 16px;
}

.cfg-step[hidden] { display: none; }

.cfg-format-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
}

.cfg-format-card {
  text-align: left;
  padding: 14px;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.03);
  color: inherit;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
}

.cfg-format-card:hover,
.cfg-format-card[aria-pressed="true"] {
  border-color: rgba(255, 107, 44, 0.45);
  background: rgba(255, 107, 44, 0.08);
}

.cfg-format-card__title {
  display: block;
  font-weight: 600;
  font-size: 15px;
  margin-bottom: 4px;
}

.cfg-format-card__desc {
  display: block;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.4;
}

.cfg-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: 420px;
  font-size: 14px;
  color: var(--muted);
}

.cfg-field input,
.cfg-field select,
.cfg-field textarea {
  padding: 10px 12px;
  border-radius: var(--radius);
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: var(--surface);
  color: var(--text);
  font-size: 15px;
}

.cfg-field output {
  font-family: var(--font-mono);
  color: var(--accent);
}

.cfg-budget-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.cfg-budget-btn {
  padding: 12px 20px;
  border-radius: var(--radius);
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: transparent;
  color: var(--muted);
  cursor: pointer;
}

.cfg-budget-btn--active,
.cfg-budget-btn:hover {
  border-color: rgba(255, 107, 44, 0.4);
  color: var(--text);
  background: rgba(255, 107, 44, 0.08);
}

.cfg-wizard__nav {
  display: flex;
  gap: 12px;
  margin-top: 8px;
}

.cfg-result[hidden] { display: none; }

.cfg-result-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 24px;
}

.cfg-result-card {
  padding: 18px;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
}

.cfg-result-card h3 {
  margin: 0 0 8px;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted);
}

.cfg-result-card__value {
  margin: 0;
  font-family: var(--font-mono);
  font-size: clamp(18px, 3vw, 24px);
  font-weight: 600;
  color: var(--accent);
}

.cfg-equipment h3,
.cfg-engineering h3,
.cfg-recommendations h3 {
  font-size: 17px;
  margin: 0 0 12px;
}

.cfg-equipment ul,
.cfg-engineering ul,
.cfg-recommendations ul {
  margin: 0 0 20px;
  padding-left: 20px;
  line-height: 1.55;
  color: var(--muted);
}

.cfg-equipment a { color: var(--accent-2); }

.cfg-integrations {
  margin: 20px 0;
  padding: 16px;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255, 255, 255, 0.08);
  font-size: 14px;
}

.cfg-integrations a { color: var(--accent-2); margin-right: 12px; }

.cfg-export { margin: 24px 0; }

.cfg-export__btns {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 8px;
}

.cfg-export__hint {
  margin: 0;
  font-size: 13px;
  color: var(--muted);
}

.cfg-result-cta { margin-top: 16px; }

.cfg-result-lead {
  margin-top: 28px;
  padding: 20px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--surface);
}

.cfg-result-lead h3 {
  margin: 0 0 8px;
  font-size: 18px;
}

.cfg-result-lead__note {
  margin: 0 0 14px;
  font-size: 14px;
  color: var(--muted);
}

.cfg-result-lead__form {
  display: grid;
  gap: 10px;
  max-width: 420px;
}

.cfg-result-lead__success {
  margin: 0;
  font-size: 15px;
  color: var(--accent);
}

.cfg-links-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 14px;
}

.cfg-links-grid article {
  padding: 16px;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
}

.cfg-links-grid h3 { margin: 0 0 8px; font-size: 16px; }
.cfg-links-grid p { margin: 0; font-size: 13px; color: var(--muted); }

.cfg-faq__list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-width: 800px;
}

.cfg-faq__item {
  padding: 14px 16px;
  border-radius: var(--radius);
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.02);
}

.cfg-faq__item summary { cursor: pointer; font-weight: 600; }
.cfg-faq__item p { margin: 10px 0 0; color: var(--muted); line-height: 1.55; }

@media (max-width: 1024px) {
  .cfg-format-grid { grid-template-columns: repeat(2, 1fr); }
  .cfg-result-grid { grid-template-columns: repeat(2, 1fr); }
  .cfg-links-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  .cfg-format-grid,
  .cfg-result-grid,
  .cfg-links-grid { grid-template-columns: 1fr; }
}
