/* studio-hub.css — Glassmorphism / Apple Vision Pro vibe
   Цветовая база: #0a0014 + purple #6366f1 / pink #ec4899 / teal #14b8a6
   Требования: @supports fallback, prefers-reduced-motion, dvh, Inter font
*/

/* ─── Шрифт ──────────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* ─── Базовые переменные ──────────────────────────────────────────────────── */
:root {
  --color-bg:        #0a0014;
  --color-purple:    #6366f1;
  --color-pink:      #ec4899;
  --color-teal:      #14b8a6;
  --glass-bg:        rgba(255, 255, 255, 0.05);
  --glass-bg-strong: rgba(255, 255, 255, 0.08);
  --glass-border:    rgba(255, 255, 255, 0.10);
  --glass-border-strong: rgba(255, 255, 255, 0.15);
}

/* ─── Тело ────────────────────────────────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
}

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: #ffffff;
  background: var(--color-bg);
  min-height: 100dvh;           /* dvh вместо vh — iOS Safari нижний бар */
  margin: 0;
  padding: 0;
}

/* ─── Aurora — анимированный фон ─────────────────────────────────────────── */
.aurora {
  position: fixed;
  inset: 0;
  z-index: -1;
  overflow: hidden;
  background: var(--color-bg);
  pointer-events: none;
}

.aurora::before,
.aurora::after {
  content: '';
  position: absolute;
  width: 800px;
  height: 800px;
  border-radius: 50%;
  filter: blur(140px);
  opacity: 0.6;
}

.aurora::before {
  background: radial-gradient(circle, var(--color-purple), transparent 70%);
  top: -200px;
  left: -200px;
  animation: aurora-move-1 20s ease-in-out infinite;
}

.aurora::after {
  background: radial-gradient(circle, var(--color-pink), transparent 70%);
  bottom: -200px;
  right: -200px;
  animation: aurora-move-2 25s ease-in-out infinite;
}

/* Третий blob (teal) — отдельный элемент .blob-3 */
.blob-3 {
  position: fixed;
  top: 30%;
  right: 20%;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--color-teal), transparent 70%);
  filter: blur(120px);
  opacity: 0.4;
  z-index: -1;
  pointer-events: none;
  animation: aurora-move-3 18s ease-in-out infinite;
}

@keyframes aurora-move-1 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50%       { transform: translate(300px, 200px) scale(1.2); }
}

@keyframes aurora-move-2 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50%       { transform: translate(-300px, -200px) scale(1.3); }
}

@keyframes aurora-move-3 {
  0%, 100% { transform: translate(0, 0); }
  50%       { transform: translate(-200px, 100px); }
}

/* Остановить анимацию blob'ов при prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
  .aurora::before,
  .aurora::after,
  .blob-3 {
    animation: none;
  }
}

/* ─── Glass utilities ─────────────────────────────────────────────────────── */

/* .glass — базовое стекло для карточек */
.glass {
  border: 1px solid var(--glass-border);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.10),
    0 8px 32px rgba(0, 0, 0, 0.30);
}

/* Браузеры с поддержкой backdrop-filter — blur эффект */
@supports (backdrop-filter: blur(1px)) {
  .glass {
    background: var(--glass-bg);
    backdrop-filter: blur(40px) saturate(180%);
    -webkit-backdrop-filter: blur(40px) saturate(180%);
  }
}

/* Fallback для старых браузеров — solid rgba без blur */
@supports not (backdrop-filter: blur(1px)) {
  .glass {
    background: rgba(0, 0, 0, 0.40);
  }
}

/* .glass-strong — более насыщенное стекло для nav и модальных окон */
.glass-strong {
  border: 1px solid var(--glass-border-strong);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 16px 48px rgba(0, 0, 0, 0.40);
}

@supports (backdrop-filter: blur(1px)) {
  .glass-strong {
    background: var(--glass-bg-strong);
    backdrop-filter: blur(60px) saturate(200%);
    -webkit-backdrop-filter: blur(60px) saturate(200%);
  }
}

@supports not (backdrop-filter: blur(1px)) {
  .glass-strong {
    background: rgba(0, 0, 0, 0.55);
  }
}

/* ─── Кнопки ─────────────────────────────────────────────────────────────── */

/* .glass-btn — белая solid кнопка с glow */
.glass-btn {
  background: rgba(255, 255, 255, 0.90);
  color: #000000;
  border: none;
  cursor: pointer;
  box-shadow: 0 4px 24px rgba(255, 255, 255, 0.20);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

@supports (backdrop-filter: blur(1px)) {
  .glass-btn {
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
  }
}

.glass-btn:hover {
  transform: scale(1.05);
  box-shadow: 0 8px 32px rgba(255, 255, 255, 0.40);
}

/* .ghost-btn — полупрозрачная ghost кнопка */
.ghost-btn {
  border: 1px solid rgba(255, 255, 255, 0.15);
  cursor: pointer;
  transition: background 0.3s ease;
}

@supports (backdrop-filter: blur(1px)) {
  .ghost-btn {
    background: rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
  }
}

@supports not (backdrop-filter: blur(1px)) {
  .ghost-btn {
    background: rgba(255, 255, 255, 0.08);
  }
}

.ghost-btn:hover {
  background: rgba(255, 255, 255, 0.12);
}

/* ─── Цветные тени для аватарок каналов ──────────────────────────────────── */
.shadow-color-red {
  box-shadow: 0 8px 24px rgba(239, 68, 68, 0.50);    /* red-500 */
}

.shadow-color-blue {
  box-shadow: 0 8px 24px rgba(59, 130, 246, 0.50);   /* blue-500 */
}

.shadow-color-emerald {
  box-shadow: 0 8px 24px rgba(16, 185, 129, 0.50);   /* emerald-500 */
}

.shadow-color-purple {
  box-shadow: 0 8px 24px rgba(139, 92, 246, 0.50);   /* violet-500 */
}

.shadow-color-pink {
  box-shadow: 0 8px 24px rgba(236, 72, 153, 0.50);   /* pink-500 */
}

.shadow-color-orange {
  box-shadow: 0 8px 24px rgba(249, 115, 22, 0.50);   /* orange-500 */
}

/* ─── Pulse анимация для status-dot ──────────────────────────────────────── */
@keyframes pulse-dot {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.4; }
}

.pulse-dot {
  animation: pulse-dot 2s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {
  .pulse-dot {
    animation: none;
  }
}

/* ─── iOS Safari safe-area для fixed-bottom ──────────────────────────────── */
.pb-safe {
  padding-bottom: env(safe-area-inset-bottom, 0px);
}

/* ─── Утилиты ────────────────────────────────────────────────────────────── */
.text-balance {
  text-wrap: balance;
}

.truncate-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
