/* ============================================
   Общие стили для шагов 1-3 с Container Queries
   ============================================ */

/* Основной контейнер компонента - прозрачный, без фона и скруглений */
.quote-component {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  container-type: inline-size;
  container-name: quote-component;
}

/* ============================================
   Общая структура для экранов 1-3
   ============================================ */

.step-screen {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  container-type: inline-size;
  container-name: step-screen;
  padding-top: var(--quote-screen-padding-top);
  padding-right: var(--quote-screen-padding-sides);
  padding-left: var(--quote-screen-padding-sides);
  padding-bottom: var(--quote-screen-padding-bottom);
  box-sizing: border-box;
}

/* Header: Прогресс-бар + Заголовок */
.step-screen__header {
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: var(--quote-gap-lg);
}

/* Прогресс-бар */
.step-screen__progress {
  width: 100%;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: var(--quote-gap-xs);
}

.step-screen__progress-item {
  flex: 1;
  height: var(--quote-progress-height);
  border-radius: var(--quote-radius-large);
  transition: all var(--quote-transition-duration) var(--quote-transition-timing);
  background-color: var(--quote-bg-progress);
  opacity: var(--quote-progress-opacity-inactive);
  cursor: pointer;
}

.step-screen__progress-item--active {
  opacity: 1;
  border-radius: 50px; /* Активный прогресс-бар имеет другой радиус */
}

.step-screen__progress-item--completed {
  opacity: 1;
  border-radius: 50px; /* Завершенный прогресс-бар имеет другой радиус */
}

/* Заголовок экрана */
.step-screen__title {
  width: 100%;
  max-width: var(--quote-title-max-width);
  text-align: center;
  font-size: var(--quote-font-mono-size);
  color: var(--quote-color-white);
  font-weight: var(--quote-font-mono-weight);
  font-family: var(--quote-font-mono-family);
  font-feature-settings: 'liga' off, 'clig' off;
  text-transform: var(--quote-font-mono-text-transform);
  line-height: var(--quote-font-mono-line-height);
  margin: 0;
}

/* Контейнер контента (flex: 1) */
.step-screen__content {
  flex: 1;
  width: 100%;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  overflow-x: visible;
}

/* Кнопка внизу */
.step-screen__button {
  display: flex;
  width: 100%;
  height: var(--quote-button-height);
  padding: var(--quote-button-padding-y) var(--quote-button-padding-x);
  justify-content: center;
  align-items: center;
  background-color: var(--quote-bg-button);
  backdrop-filter: blur(var(--quote-button-backdrop-blur));
  border: none;
  border-radius: var(--quote-radius-medium);
  cursor: pointer;
  transition: all var(--quote-transition-duration) var(--quote-transition-timing);
  font-family: var(--quote-font-mono-family);
  font-size: var(--quote-font-mono-size);
  font-weight: var(--quote-font-mono-weight);
  text-transform: var(--quote-font-mono-text-transform);
  color: var(--quote-color-white);
  line-height: var(--quote-font-mono-line-height);
}

.step-screen__button:hover:not(:disabled) {
  background-color: var(--quote-bg-button-hover);
}

.step-screen__button:active:not(:disabled) {
  transform: scale(0.98);
}

.step-screen__button:disabled {
  opacity: var(--quote-button-opacity-disabled);
  cursor: not-allowed;
}


/* ============================================
   ThemeSelector - Экран 1: Выбор темы
   ============================================ */

.theme-selector {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  container-type: inline-size;
  container-name: theme-selector;
}

.theme-selector__list {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--quote-gap-xs);
  align-items: center;
  justify-content: center;
  overflow-x: visible;
  overflow-y: visible;
}

.theme-selector__item {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: var(--quote-gap-sm);
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  transition: opacity var(--quote-transition-opacity-duration) var(--quote-transition-timing);
  opacity: var(--quote-theme-opacity-inactive);
  width: 100%;
}

.theme-selector__item--selected {
  opacity: 1;
}

.theme-selector__item:hover {
  opacity: var(--quote-theme-opacity-hover);
}

.theme-selector__item--selected:hover {
  opacity: 1;
}

.theme-selector__text {
  text-align: center;
  font-family: var(--quote-font-heading-family);
  font-size: var(--quote-font-heading-size);
  font-style: normal;
  font-weight: var(--quote-font-heading-weight);
  line-height: var(--quote-font-heading-line-height);
  letter-spacing: var(--quote-font-heading-letter-spacing);
  color: var(--quote-color-white);
  transition: color var(--quote-transition-duration) var(--quote-transition-timing);
  white-space: nowrap;
}

.theme-selector__text--selected {
  color: var(--accent-color);
}

.theme-selector__avatar {
  width: var(--quote-avatar-size-small);
  height: var(--quote-avatar-size-small);
  position: relative;
  border-radius: var(--quote-radius-avatar);
  overflow: hidden;
  flex-shrink: 0;
}

.theme-selector__avatar-image {
  width: var(--quote-avatar-size-small);
  height: var(--quote-avatar-size-small);
  position: absolute;
  left: 0;
  top: 0;
  border-radius: 50%;
  object-fit: cover;
  filter: grayscale(100%);
}

.theme-selector__avatar-image--active {
  filter: grayscale(0%);
}

.theme-selector__avatar-placeholder {
  width: var(--quote-avatar-size-small);
  height: var(--quote-avatar-size-small);
  position: absolute;
  left: 0;
  top: 0;
  background-color: rgba(0, 0, 0, 0.2);
  border-radius: 50%;
}


/* ============================================
   QuoteInput - Экран 2: Ввод цитаты
   ============================================ */

.quote-input {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
}

.quote-input__container {
  width: 100%;
  margin-top: var(--quote-container-margin-top);
  display: flex;
  flex-direction: column;
  gap: var(--quote-gap-md);
  align-items: flex-start;
  box-sizing: border-box;
}

.quote-input__textarea-wrapper {
  flex: 1;
  min-width: 100%;
  position: relative;
  background-color: var(--accent-color, #FFA500);
  border-radius: var(--quote-radius-large);
  padding: var(--quote-input-wrapper-padding);
  min-height: var(--quote-input-wrapper-min-height);
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
}

.quote-input__icon {
  width: var(--quote-icon-size);
  height: var(--quote-icon-size);
  color: var(--quote-color-black);
  margin-bottom: var(--quote-gap-lg);
  flex-shrink: 0;
}

.quote-input__textarea {
  flex: 1;
  width: 100%;
  background: transparent;
  border: none;
  outline: none;
  resize: none;
  font-family: var(--quote-font-input-family);
  font-size: var(--quote-font-input-size);
  font-weight: var(--quote-font-input-weight);
  line-height: var(--quote-font-input-line-height);
  letter-spacing: var(--quote-font-input-letter-spacing);
  color: var(--quote-color-black);
  opacity: var(--quote-text-placeholder-opacity);
}

.quote-input__textarea::placeholder {
  color: var(--quote-color-black);
  opacity: var(--quote-text-placeholder-opacity);
}

.quote-input__textarea:focus {
  opacity: var(--quote-text-filled-opacity);
}

.quote-input__indicators {
  display: flex;
  flex-direction: column;
  gap: var(--quote-input-indicators-gap);
  align-items: flex-start;
  width: var(--quote-input-indicators-width);
  flex-shrink: 0;
  margin-top: 0;
}

.quote-input__indicator {
  width: var(--quote-input-indicator-size-small);
  height: var(--quote-input-indicator-size-small);
  background-color: var(--accent-color);
  border-radius: 50%;
}

.quote-input__indicator:first-child {
  width: var(--quote-icon-size);
  height: var(--quote-icon-size);
  aspect-ratio: 1;
}


/* ============================================
   AvatarSelector - Экран 3: Выбор аватара, имени и handle
   ============================================ */

.avatar-selector {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
}

.avatar-selector__container {
  width: 100%;
  margin-top: var(--quote-container-margin-top);
  display: flex;
  flex-direction: column;
  gap: var(--quote-gap-xxl);
  align-items: center;
}

.avatar-selector__avatar-wrapper {
  position: relative;
  width: var(--quote-avatar-size-large);
  height: var(--quote-avatar-size-large);
  flex-shrink: 0;
}

.avatar-selector__avatar {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  overflow: hidden;
  position: relative;
  background: linear-gradient(90deg, var(--accent-color, #FFA500) 0%, var(--accent-color, #FFA500) 100%);
}

.avatar-selector__avatar-image {
  width: 100%;
  height: 100%;
  position: relative;
  object-fit: cover;
  pointer-events: none;
}

.avatar-selector__avatar-placeholder {
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.2);
}

.avatar-selector__shuffle-button {
  position: absolute;
  left: 50%;
  bottom: var(--quote-shuffle-button-bottom-offset);
  transform: translateX(-50%);
  background-color: white;
  display: flex;
  gap: var(--quote-shuffle-button-gap);
  align-items: center;
  justify-content: center;
  padding: var(--quote-shuffle-button-padding-y) var(--quote-gap-sm);
  border-radius: var(--quote-radius-small);
  border: none;
  cursor: pointer;
  transition: all var(--quote-transition-duration) var(--quote-transition-timing);
  font-family: var(--quote-font-mono-family);
  font-size: var(--quote-font-mono-size);
  font-weight: var(--quote-font-mono-weight);
  text-transform: var(--quote-font-mono-text-transform);
  color: var(--quote-color-black);
  line-height: var(--quote-font-mono-line-height);
}

.avatar-selector__shuffle-button:hover {
  transform: translateX(-50%) scale(1.05);
}

.avatar-selector__shuffle-button:active {
  transform: translateX(-50%) scale(0.95);
}

.avatar-selector__inputs {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--quote-gap-xl);
  align-items: flex-start;
}

.avatar-selector__input-group {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--quote-gap-md);
  align-items: flex-start;
}

.avatar-selector__label {
  font-family: var(--quote-font-mono-family);
  font-size: var(--quote-font-mono-size);
  font-weight: var(--quote-font-mono-weight);
  text-transform: var(--quote-font-mono-text-transform);
  color: var(--quote-color-white);
  line-height: var(--quote-font-mono-line-height);
  margin: 0;
}

.avatar-selector__input {
  width: 100%;
  height: var(--quote-input-height);
  padding: 0 var(--quote-input-padding-x);
  background: transparent;
  border: var(--quote-input-border-width) solid var(--quote-border-input);
  border-radius: var(--quote-radius-medium);
  outline: none;
  font-family: var(--quote-font-input-family);
  font-size: var(--quote-font-input-field-size);
  font-weight: var(--quote-font-input-weight);
  line-height: var(--quote-font-input-line-height);
  letter-spacing: var(--quote-font-input-field-letter-spacing);
  color: rgba(255, 255, 255, var(--quote-text-placeholder-opacity));
  transition: color var(--quote-transition-duration) var(--quote-transition-timing);
  box-sizing: border-box;
}

.avatar-selector__input::placeholder {
  color: rgba(255, 255, 255, var(--quote-text-placeholder-opacity));
}

.avatar-selector__input:focus,
.avatar-selector__input--filled {
  color: rgba(255, 255, 255, var(--quote-text-filled-opacity));
}

.avatar-selector__create-button {
  background-color: var(--accent-color) !important;
  color: var(--quote-color-black) !important;
}

.avatar-selector__create-button:hover:not(:disabled) {
  opacity: 0.9;
}


/* ============================================
   FinalOutput - Экран 4: Финальный результат
   ============================================ */

.final-output {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  padding: 0;
  box-sizing: border-box;
  position: relative;
}

/* Контейнер с цитатой */
.final-output__quote-container {
  width: calc(100% - var(--quote-final-container-width-offset));
  height: var(--quote-final-container-height);
  margin: var(--quote-final-container-margin);
  padding: var(--quote-container-padding);
  border-radius: var(--quote-radius-large);
  background-color: var(--accent-color);
  position: relative;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  box-sizing: border-box;
  overflow: hidden;
}

/* Фоновое изображение */
.final-output__background-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
}

/* Overlay для затемнения фона */
.final-output__background-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
}

/* Затемнение сверху */
.final-output__quote-container::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: var(--quote-final-overlay-height);
  background: linear-gradient(to bottom, rgba(0, 0, 0, var(--quote-final-overlay-opacity)), transparent);
  pointer-events: none;
  z-index: 1;
}

/* Текст цитаты */
.final-output__quote {
  position: relative;
  z-index: 2;
  font-family: var(--quote-font-heading-family);
  font-size: var(--quote-final-size);
  font-weight: var(--quote-final-weight);
  line-height: var(--quote-final-line-height);
  letter-spacing: var(--quote-final-letter-spacing);
  color: var(--quote-color-white);
  margin: 0;
  padding: 0;
  width: 100%;
  word-wrap: break-word;
  overflow-wrap: break-word;
  box-sizing: border-box;
  transition: opacity var(--quote-transition-opacity-duration) var(--quote-transition-timing);
  overflow: hidden;
  max-height: var(--quote-final-quote-max-height);
}

/* Автор (внизу, по центру) */
.final-output__author {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--quote-gap-md);
  padding: 0;
  width: var(--quote-final-author-width);
  flex: 1;
}

/* Аватар */
.final-output__avatar {
  width: var(--quote-avatar-size-small);
  height: var(--quote-avatar-size-small);
  border-radius: var(--quote-radius-avatar);
  overflow: hidden;
  position: relative;
  flex-shrink: 0;
}

.final-output__avatar-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* Информация об авторе */
.final-output__author-info {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--quote-gap-xs);
  text-align: center;
}

.final-output__author-text {
  font-family: var(--quote-font-mono-family);
  font-size: var(--quote-font-mono-size);
  font-weight: var(--quote-font-mono-weight);
  line-height: var(--quote-font-mono-line-height);
  text-transform: var(--quote-font-mono-text-transform);
  color: var(--quote-color-white);
  margin: 0;
}

.final-output__author-handle {
  opacity: var(--quote-author-handle-opacity);
}

/* Кнопка Restart */
.final-output__restart-button {
  position: absolute;
  top: var(--quote-restart-button-top);
  right: var(--quote-restart-button-right);
  background-color: rgba(0, 0, 0, 0.2);
  backdrop-filter: blur(var(--quote-button-backdrop-blur));
  -webkit-backdrop-filter: blur(var(--quote-button-backdrop-blur));
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--quote-shuffle-button-gap);
  padding: 8px 14px;
  border-radius: var(--quote-radius-small);
  border: none;
  cursor: pointer;
  transition: all var(--quote-transition-duration) var(--quote-transition-timing);
  font-family: var(--quote-font-mono-family);
  font-size: var(--quote-font-mono-size);
  font-weight: var(--quote-font-mono-weight);
  text-transform: var(--quote-font-mono-text-transform);
  color: var(--quote-color-white);
  line-height: var(--quote-font-mono-line-height);
  z-index: 10;
}

.final-output__restart-button:hover {
  transform: scale(1.05);
  background-color: rgba(0, 0, 0, 0.25);
}

.final-output__restart-button:active {
  transform: scale(0.95);
}


