/* Космос + анимации, с твоими текущими цветами блока цитаты */
:root{
  --glow: 0 0 16px rgba(121,180,255,.35), 0 0 42px rgba(121,180,255,.22);
  --shadow: 0 10px 30px rgba(0,0,0,.25);
}

/* Обёртка (опционально) */
.quote-cosmos{
  position:relative;
  width:100%;
  max-width: 960px;
  margin-inline:auto;
  border-radius:16px;
  overflow:visible;
  isolation:isolate;
}

/* ----- ТВОЙ БЛОК ЦИТАТЫ (цвета как у тебя) ----- */
.quote-box{
  position:relative;
  isolation:isolate;
  margin-bottom:20px;
  border-radius:16px;      /* если нужен 9px — скажи */
  padding:24px 26px;       /* если нужно 12px 16px — скажи */
  text-align:center;
  line-height:1.4;
  backdrop-filter: blur(8px) saturate(120%);
  border:1px solid rgba(255,255,255,.08);

  /* тайминги анимаций */
  --in-dur: .75s;
  --out-dur: .50s;
  --stagger: .022s;
  --movie-offset: .12s;    /* базовая задержка начала анимации фильма */
}

/* Тёмная/светлая — как у тебя */
body[data-theme="dark"] .quote-box,
body.dt .quote-box{
  background:#2a2d34;
  color:#e9eef5;
  border-color:rgba(255,255,255,.06);
}
body:not([data-theme="dark"]) .quote-box,
body.lt .quote-box{
  background-color: var(--bg, #fff);
  color:#1f232b;
  border-color:rgba(0,0,0,.06);
}

/* Текст поверх фонов */
.quote-box .q-text,
.quote-box .q-movie{
  position:relative;
  z-index:1;
}

/* Цитата */
.quote-box .q-text{
  font-size: clamp(16px, 2.2vw, 26px);
  line-height:1.35;
  letter-spacing:.2px;
  font-weight:600;
  font-style: oblique;
  opacity:.95;
  text-shadow:0 1px 0 rgba(255,255,255,.05), 0 0 20px rgba(121,180,255,.12);
  word-break: normal; overflow-wrap: normal; hyphens: none;
}

/* Фильм */
.quote-box .q-movie{
  font-size: clamp(13px, 1.6vw, 16px);
  margin-top:8px;
  word-break: normal; overflow-wrap: normal; hyphens: none;
}

/* Слова не ломаем по буквам */
.q-text .w, .q-movie .w{
  display:inline-block;
  white-space:nowrap;
}

/* По-буквенная анимация (и для .q-movie тоже) */
.q-text span, .q-movie span{
  opacity:0; display:inline-block;
  filter:blur(6px);
  transform:translateY(10px) scale(.98);
}
.quote-box.in .q-text span,
.quote-box.in .q-movie span{
  animation: letter-in var(--in-dur) cubic-bezier(.22,.8,.22,1) forwards;
}
.quote-box.out .q-text span,
.quote-box.out .q-movie span{
  animation: letter-out var(--out-dur) ease-in forwards;
}

@keyframes letter-in{
  0%{ opacity:0; filter:blur(6px); transform:translateY(10px) scale(.98) rotate(-.3deg); text-shadow:none; }
  70%{ opacity:1; filter:blur(0); transform:translateY(0) scale(1.005); text-shadow:var(--glow); }
  100%{ opacity:1; filter:blur(0); transform:translateY(0) scale(1); text-shadow:0 0 0 transparent; }
}
@keyframes letter-out{
  0%{ opacity:1; filter:blur(0); transform:translateY(0) scale(1); }
  100%{ opacity:0; filter:blur(8px); transform:translateY(-10px) scale(.985); }
}

/* Единственный фон — мягкая «туманность» */
.quote-box > .nebula{
  position:absolute;
  inset:auto;
  width:140vmax; height:140vmax;
  left:50%; top:50%;
  translate:-50% -50%;
  filter:blur(60px);
  opacity:.32;
  z-index:0;
  pointer-events:none;
  background:conic-gradient(from 210deg at 50% 50%,
    rgba(121,180,255,.25), rgba(137,96,255,.25),
    rgba(18,16,45,.1), rgba(121,180,255,.25)
  );
  animation:nebula-rotate 60s linear infinite;
  border-radius: inherit;
}
@keyframes nebula-rotate { to { transform:rotate(360deg); } }

/* Доступность */
@media (prefers-reduced-motion: reduce){
  .quote-box > .nebula{ animation:none; }
  .q-text span, .q-movie span{
    animation:none !important; opacity:1 !important; filter:none !important; transform:none !important;
  }
}



