/* Typography: markdown output from Atom Lead-Magnit Studio */
* { box-sizing: border-box; }

body {
  font-family: "Segoe UI", ui-sans-serif, system-ui, -apple-system, Roboto, sans-serif;
}

/* Контейнер статьи — удобная колонка и отступы */
.prose-out-wrap {
  color: #e2e8f0;
  font-size: 1rem;
  line-height: 1.65;
  max-width: 52rem;
  margin-left: auto;
  margin-right: auto;
}

.prose-out-wrap :first-child { margin-top: 0; }

.prose-out-wrap h1 {
  font-size: 1.5rem;
  font-weight: 700;
  color: #f8fafc;
  margin: 1.5rem 0 0.75rem;
  line-height: 1.3;
  letter-spacing: -0.02em;
}

.prose-out-wrap h2 {
  font-size: 1.2rem;
  font-weight: 700;
  color: #f1f5f9;
  margin: 1.35rem 0 0.5rem;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid rgba(51, 65, 85, 0.6);
  line-height: 1.35;
}

.prose-out-wrap h3 {
  font-size: 1.05rem;
  font-weight: 600;
  color: #cbd5e1;
  margin: 1rem 0 0.4rem;
}

.prose-out-wrap h4 {
  font-size: 0.95rem;
  font-weight: 600;
  color: #94a3b8;
  margin: 0.85rem 0 0.35rem;
}

.prose-out-wrap p {
  margin: 0.65rem 0;
  color: #cbd5e1;
}

.prose-out-wrap strong {
  color: #f1f5f9;
  font-weight: 600;
}

.prose-out-wrap em {
  color: #e2e8f0;
}

.prose-out-wrap ul,
.prose-out-wrap ol {
  margin: 0.6rem 0 0.6rem 0;
  padding-left: 1.35rem;
  color: #cbd5e1;
}

.prose-out-wrap li {
  margin: 0.35rem 0;
  padding-left: 0.15rem;
}

.prose-out-wrap li::marker {
  color: #64748b;
}

.prose-out-wrap blockquote {
  margin: 0.85rem 0;
  padding: 0.65rem 1rem;
  border-left: 3px solid #38bdf8;
  background: rgba(15, 23, 42, 0.55);
  border-radius: 0 0.5rem 0.5rem 0;
  color: #e2e8f0;
}

.prose-out-wrap hr {
  margin: 1.25rem 0;
  border: none;
  border-top: 1px solid rgba(71, 85, 105, 0.5);
}

.prose-out-wrap a {
  color: #7dd3fc;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.prose-out-wrap a:hover {
  color: #bae6fd;
}

.prose-out-wrap code {
  font-family: ui-monospace, "Cascadia Code", Consolas, monospace;
  font-size: 0.88em;
  background: rgba(15, 23, 42, 0.9);
  color: #fde68a;
  padding: 0.12rem 0.35rem;
  border-radius: 0.25rem;
  border: 1px solid rgba(51, 65, 85, 0.6);
}

.prose-out-wrap pre {
  background: #0a0f1a;
  color: #e2e8f0;
  padding: 1rem 1.1rem;
  border-radius: 0.6rem;
  overflow-x: auto;
  font-size: 0.82rem;
  line-height: 1.5;
  border: 1px solid rgba(51, 65, 85, 0.7);
  margin: 0.85rem 0;
}

.prose-out-wrap pre code {
  background: none;
  border: none;
  padding: 0;
  color: inherit;
  font-size: inherit;
}

/* Таблицы, если модель их вернёт */
.prose-out-wrap table {
  width: 100%;
  border-collapse: collapse;
  margin: 0.85rem 0;
  font-size: 0.9rem;
}

.prose-out-wrap th,
.prose-out-wrap td {
  border: 1px solid rgba(51, 65, 85, 0.8);
  padding: 0.45rem 0.65rem;
  text-align: left;
}

.prose-out-wrap th {
  background: rgba(15, 23, 42, 0.8);
  color: #e2e8f0;
  font-weight: 600;
}

[x-cloak] {
  display: none !important;
}

/* Компактная типографика в чат-интервью */
.prose-chat h1 { font-size: 1.15rem; margin: 0.75rem 0 0.35rem; }
.prose-chat h2 { font-size: 1.05rem; margin: 0.65rem 0 0.3rem; }
.prose-chat h3 { font-size: 0.95rem; margin: 0.5rem 0 0.25rem; }
.prose-chat p { margin: 0.4rem 0; font-size: 0.95rem; }
.prose-chat ul, .prose-chat ol { margin: 0.4rem 0; padding-left: 1.2rem; font-size: 0.95rem; }

/* Прогресс визарда */
.wizard-progress {
  height: 6px;
  border-radius: 9999px;
  background: rgba(51, 65, 85, 0.6);
  overflow: hidden;
}
.wizard-progress-bar {
  height: 100%;
  border-radius: 9999px;
  background: linear-gradient(90deg, #d97706, #fbbf24);
  transition: width 0.25s ease;
}

/* Скелетон загрузки */
.skeleton {
  background: linear-gradient(
    90deg,
    rgba(51, 65, 85, 0.35) 25%,
    rgba(71, 85, 105, 0.5) 50%,
    rgba(51, 65, 85, 0.35) 75%
  );
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.2s ease-in-out infinite;
}
@keyframes skeleton-shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.typing-cursor {
  display: inline-block;
  animation: blink 0.9s step-end infinite;
  margin-left: 1px;
}
@keyframes blink {
  50% { opacity: 0; }
}

.toast-item {
  animation: toast-in 0.22s ease-out;
}
@keyframes toast-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

button:focus-visible,
a:focus-visible,
summary:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline: 2px solid #38bdf8;
  outline-offset: 2px;
}

/* Горизонтальный скролл тулбара на узких экранах */
.lm-toolbar-scroll {
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}
