
:root{
  --bg:#07111f;
  --bg2:#0b1b33;
  --panel:rgba(11,24,43,.78);
  --panel-2:rgba(18,35,59,.9);
  --line:rgba(160,196,255,.16);
  --text:#eef4ff;
  --muted:#b4c0db;
  --accent:#8f7cff;
  --accent2:#46d5ff;
  --good:#37e49b;
  --warn:#ffcf5a;
  --danger:#ff5f7a;
  --shadow:0 18px 50px rgba(0,0,0,.35);
  --radius:20px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,Segoe UI,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 20% 20%, rgba(143,124,255,.20), transparent 30%),
    radial-gradient(circle at 80% 10%, rgba(70,213,255,.18), transparent 28%),
    linear-gradient(160deg, var(--bg), #09162a 40%, var(--bg2));
  min-height:100vh;
}
a{color:inherit;text-decoration:none}
.site-shell{max-width:1450px;margin:0 auto;padding:18px}
.panel{
  background:linear-gradient(180deg, rgba(13,25,45,.82), rgba(7,16,31,.84));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:16px 20px;position:sticky;top:12px;backdrop-filter:blur(12px);z-index:20}
.brand-wrap{display:flex;align-items:center;gap:16px}
.logo-img{width:66px;height:66px;object-fit:contain;border-radius:16px;background:rgba(255,255,255,.03);padding:6px}
h1,h2,h3,h4,p{margin:0}
.eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent2);margin-bottom:4px}
.nav{display:flex;gap:12px;flex-wrap:wrap}
.nav a{padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid transparent;color:var(--muted)}
.nav a.active,.nav a:hover{background:rgba(143,124,255,.14);border-color:rgba(143,124,255,.35);color:var(--text)}
.main-layout{display:grid;grid-template-columns:1.45fr .92fr;gap:18px;margin-top:18px}
.left-column,.right-column{display:flex;flex-direction:column;gap:18px}
.hero-panel{padding:22px;overflow:hidden;position:relative}
.hero-panel::before{
  content:"";position:absolute;inset:0;background:
  linear-gradient(90deg, rgba(4,10,20,.65), rgba(4,10,20,.2)),
  url('assets/images/bg-studio.svg') center/cover no-repeat;opacity:.42;pointer-events:none
}
.hero-panel > *{position:relative;z-index:1}
.hero-top{display:flex;justify-content:space-between;align-items:flex-start;gap:18px}
.state-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(55,228,155,.12);border:1px solid rgba(55,228,155,.24);color:#c4ffe7;font-size:13px;margin-bottom:10px}
.state-pill.off{background:rgba(255,95,122,.08);border-color:rgba(255,95,122,.22);color:#ffc8d3}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px}
.card-soft{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:18px;padding:16px}
.player-head{display:flex;justify-content:space-between;align-items:center}
.muted{color:var(--muted)}
.small{font-size:12px}
.play-btn,.primary,.soft,.join-btn{
  border:none;border-radius:14px;padding:12px 16px;font-weight:700;cursor:pointer
}
.primary{background:linear-gradient(135deg,var(--accent),#6f8dff);color:white;box-shadow:0 12px 24px rgba(111,141,255,.25)}
.primary.large{padding:14px 20px}
.soft{background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--text)}
.blink-btn{animation:blink 1.25s infinite}
@keyframes blink{0%,100%{transform:translateY(0); box-shadow:0 10px 18px rgba(111,141,255,.18)}50%{transform:translateY(-1px); box-shadow:0 0 0 5px rgba(70,213,255,.12)}}
.equalizer{display:flex;gap:6px;align-items:flex-end;height:62px;margin:18px 0}
.equalizer span{display:block;flex:1;min-width:8px;background:linear-gradient(180deg,var(--accent2),var(--accent));border-radius:999px;animation:eq 1.4s ease-in-out infinite}
.equalizer span:nth-child(2){animation-delay:.12s}.equalizer span:nth-child(3){animation-delay:.24s}.equalizer span:nth-child(4){animation-delay:.36s}.equalizer span:nth-child(5){animation-delay:.48s}.equalizer span:nth-child(6){animation-delay:.60s}
@keyframes eq{0%,100%{height:15%}40%{height:95%}70%{height:50%}}
.countdown{font-size:34px;font-weight:800;margin:16px 0 6px}
.player-meta,.count-foot,.chat-toolbar{display:flex;justify-content:space-between;gap:10px;color:var(--muted);font-size:12px}
.cta-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:16px;margin-top:18px}
.cta-box{padding:18px;background:linear-gradient(140deg, rgba(70,213,255,.08), rgba(143,124,255,.08));border:1px solid var(--line);border-radius:18px}
.join-btn{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--accent2),var(--accent));color:#09111f;margin-top:14px}
.banner-box{min-height:170px;display:flex;align-items:flex-end;padding:18px;background:
 linear-gradient(180deg,rgba(6,12,25,.15),rgba(6,12,25,.65)),
 url('assets/images/dedi-ia.svg') center/cover no-repeat;border:1px solid var(--line);border-radius:18px}
.chat-panel,.dedicace-panel,.shortcut-panel,.activity-panel,.ticker-panel{padding:18px}
.section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px}
.head-actions{display:flex;gap:10px}
.chat-toolbar{padding:10px 12px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:999px;margin-bottom:14px}
.chat-shell{display:flex;flex-direction:column;gap:14px}
.chat-list{display:flex;flex-direction:column;gap:12px;min-height:280px;max-height:420px;overflow:auto;padding-right:4px}
.message{display:flex;gap:10px;align-items:flex-start;padding:12px;border-radius:16px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05)}
.message img{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.10)}
.message .meta{font-size:12px;color:var(--muted);display:flex;gap:8px;align-items:center}
.nick{font-weight:800;cursor:pointer}
.badge{font-size:11px;padding:4px 8px;border-radius:999px;background:rgba(70,213,255,.12);color:#bff3ff;border:1px solid rgba(70,213,255,.2)}
.chat-composer{display:flex;gap:10px}
.chat-composer input{flex:1;padding:14px 16px;border-radius:14px;border:1px solid var(--line);background:rgba(0,0,0,.18);color:var(--text)}
.right-column .dedicace-panel{height:100%}
.side-intro{margin-bottom:12px}
.side-list{display:flex;flex-direction:column;gap:10px;max-height:560px;overflow:auto}
.dedi-card{padding:14px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid var(--line);cursor:pointer}
.dedi-card:hover{transform:translateY(-1px);transition:.16s ease}
.rate{color:#ffe38d;font-weight:700}
.shortcut-grid{display:grid;grid-template-columns:1fr;gap:12px}
.shortcut{display:flex;justify-content:space-between;align-items:center}
.ticker-panel{margin-top:18px}
.ticker-title{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent2);margin-bottom:12px}
.ticker-window{overflow:hidden;border-radius:16px;border:1px solid var(--line);background:rgba(255,255,255,.03)}
.ticker-track{display:flex;gap:26px;padding:14px 18px;white-space:nowrap;animation:marq 24s linear infinite}
@keyframes marq{from{transform:translateX(4%)}to{transform:translateX(-40%)}}
.pm-float{position:fixed;bottom:22px;right:22px;width:54px;height:54px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#06111f;font-size:20px;font-weight:900;box-shadow:var(--shadow);cursor:pointer;z-index:22}
.overlay{position:fixed;inset:0;background:rgba(3,8,16,.65);backdrop-filter:blur(4px);z-index:30}
.hidden{display:none!important}
.modal{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:31;padding:18px;width:min(94vw,760px)}
.modal-sm{width:min(94vw,420px)} .modal-md{width:min(94vw,640px)} .modal-lg{width:min(94vw,880px)}
.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.close-modal{border:none;background:transparent;color:var(--text);font-size:28px;cursor:pointer}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-stack{display:grid;gap:12px}
.form-grid label,.form-stack label{display:grid;gap:8px;color:var(--muted);font-size:13px}
.form-grid input,.form-grid select,.form-grid textarea,.form-stack input,.form-stack textarea{
  width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--line);background:rgba(0,0,0,.2);color:var(--text)
}
.form-grid textarea,.form-stack textarea{min-height:110px;resize:vertical}
.form-grid .full{grid-column:1/-1}
.modal-actions{display:flex;justify-content:flex-end;margin-top:14px}
.user-mini{display:grid;grid-template-columns:60px 1fr;gap:12px}
.user-mini img{width:60px;height:60px;border-radius:50%;object-fit:cover}
.activity-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:16px}
.video-card iframe,.video-card .video-placeholder{width:100%;aspect-ratio:16/9;border:none;border-radius:16px;background:#020814}
.text-card,.banner-card{min-height:100%}
.banner-card{background:
 linear-gradient(180deg,rgba(6,12,25,.25),rgba(6,12,25,.55)),
 url('assets/images/bg-studio.svg') center/cover no-repeat;border:1px solid var(--line);border-radius:18px;padding:18px;display:flex;align-items:flex-end;min-height:220px}
.banner-card h3{font-size:28px;max-width:10ch}
.admin-grid{display:grid;grid-template-columns:1.25fr .95fr;gap:18px;margin-top:18px}
.admin-main,.admin-side{padding:18px}
.admin-actions,.stats-row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}
.stat-card{min-width:180px}
.queue-grid,.stack-list{display:grid;gap:12px}
.queue-item{display:grid;grid-template-columns:1fr auto;gap:12px;padding:14px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid var(--line)}
.queue-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.work-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
textarea.code-ish{min-height:120px}
.admin-block{padding:16px;border-radius:18px;background:rgba(255,255,255,.04);border:1px solid var(--line)}
.table-like{display:grid;gap:10px}
.table-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:12px;border-radius:14px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}
.tag-ban{padding:6px 10px;border-radius:999px;background:rgba(255,95,122,.12);color:#ffc9d2;border:1px solid rgba(255,95,122,.25)}
.page-foot-note{margin-top:10px;color:var(--muted);font-size:13px}
@media (max-width:1100px){
  .main-layout,.admin-grid,.activity-grid,.work-grid,.cta-grid{grid-template-columns:1fr}
  .hero-grid{grid-template-columns:1fr}
}
@media (max-width:700px){
  .topbar,.hero-top,.section-head,.player-meta,.count-foot{flex-direction:column;align-items:flex-start}
  .nav{width:100%}
  .form-grid{grid-template-columns:1fr}
  .chat-toolbar{display:none}
}
#themeConfigModal{
  width: min(96vw, 1000px);
  max-height: 88vh;
  overflow-y: auto;
}

#themeConfigModal .form-stack{
  overflow-y: auto;
}

.dedi-thumb-row{
  display:flex;
  align-items:center;
  gap:12px;
}

.dedi-thumb{
  width:60px;
  height:60px;
  border-radius:16px;
  object-fit:cover;
  flex:0 0 60px;
  box-shadow:0 8px 24px rgba(0,0,0,0.25);
}

.dedi-popup-cover-wrap{
  display:flex;
  justify-content:center;
  margin-bottom:14px;
}

.dedi-popup-cover{
  width:160px;
  height:160px;
  border-radius:24px;
  object-fit:cover;
  box-shadow:0 12px 30px rgba(0,0,0,0.30);
}

.dedi-vote{
  display:flex;
  justify-content:center;
  gap:6px;
  margin-top:10px;
}

.dedi-star{
  font-size:22px;
  cursor:pointer;
  opacity:0.5;
  transition: transform 0.1s ease, opacity 0.1s ease;
}

.dedi-star.active{
  opacity:1;
  transform: scale(1.15);
}

.dedi-star:hover{
  opacity:1;
}
.top-dedicace-panel{
  border:1px solid rgba(250,204,21,.22);
  box-shadow:0 18px 50px rgba(0,0,0,.28);
}

#topDedicationBlock{
  min-height:320px;
  padding:18px;
  border-radius:22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)),
    rgba(15,23,42,.72);
  border:1px solid rgba(255,255,255,.08);
}

#topDedicationBlock .dedi-card{
  width:100%;
  max-width:none;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  padding:20px;
  border-radius:22px;
  box-shadow:none;
}

#topDedicationBlock .dedi-thumb-row{
  align-items:flex-start;
  gap:18px;
  width:100%;
}

#topDedicationBlock .dedi-thumb{
  width:92px;
  height:92px;
  border-radius:20px;
  flex:0 0 92px;
}

#topDedicationBlock strong{
  display:block;
  line-height:1.2;
}

#topDedicationBlock iframe,
#topDedicationBlock audio{
  display:block;
  width:100%;
  margin-top:12px;
  border-radius:14px;
  overflow:hidden;
}

#topDedicationBlock .soft{
  margin-top:6px;
}

.top-dedicace-panel .section-head h3{
  font-size:24px;
}

.top-dedi-label{
  color:rgba(255,255,255,.72);
  letter-spacing:.08em;
}

.top-dedi-title{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

.top-dedi-stars{
  font-size:16px;
  color:#facc15;
  letter-spacing:.08em;
}

}
#topDedicationBlock .muted{
  font-size:15px;
}

#topDedicationBlock .dedi-thumb-row > div:last-child{
  width:100%;
}

#topDedicationBlock .soft{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:10px 16px;
  border-radius:14px;
}

#topDedicationBlock a.soft{
  text-decoration:none;
}

#topDedicationBlock > .muted{
  width:100%;
}

#topDedicationBlock{
  display:block !important;
}

#topDedicationBlock .dedi-card strong{
  font-size:17px;
  margin-bottom:6px;
}

#topDedicationBlock audio,
#topDedicationBlock iframe{
  background:rgba(0,0,0,.2);
}
#topDedicationBlock a.soft{
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

#topDedicationBlock a.soft,
#topDedicationBlock button.soft{
  margin-left:auto;
  margin-right:auto;
}

#topDedicationBlock div[style*="background:#111827"]{
  text-align:center !important;
}

#topDedicationBlock div[style*="background:#111827"] a.soft{
  margin-top:10px;
}
.top-dedi-card{
  width:100%;
}

.top-dedi-main{
  display:grid;
  grid-template-columns:minmax(0,1fr) 140px;
  gap:18px;
  align-items:start;
}

.top-dedi-content{
  min-width:0;
}

.top-dedi-cover-wrap{
  display:flex;
  justify-content:flex-end;
  align-items:flex-start;
}

.top-dedi-cover{
  width:130px;
  height:130px;
  object-fit:cover;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 10px 24px rgba(0,0,0,.28);
}

@media (max-width:700px){
  .top-dedi-main{
    grid-template-columns:1fr;
  }

  .top-dedi-cover-wrap{
    justify-content:flex-start;
  }

  .top-dedi-cover{
    width:100%;
    max-width:180px;
    height:auto;
    aspect-ratio:1/1;
  }
}

/* ========= STREAM VISUAL ROOM ========= */
.stream-visual{
  margin-top:18px;
  padding:18px 16px 16px;
  border-radius:20px;
  border:1px solid rgba(143,124,255,.28);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  box-shadow:0 14px 30px rgba(0,0,0,.22), inset 0 0 0 1px rgba(255,255,255,.03);
  backdrop-filter:blur(6px);
  overflow:hidden;
}

.stream-visual-head{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:16px;
  font-size:13px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#f7f8ff;
  text-shadow:0 0 12px rgba(143,124,255,.35);
}

.stream-dot{
  width:12px;
  height:12px;
  border-radius:999px;
  background:#7df9ff;
  box-shadow:0 0 0 0 rgba(125,249,255,.7);
  animation:streamPulse 1.6s infinite;
}

.stream-eq{
  height:190px;
  display:flex;
  align-items:flex-end;
  gap:8px;
  padding:12px 6px 0;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
}

.stream-eq span{
  flex:1;
  min-width:10px;
  border-radius:999px 999px 0 0;
  transform-origin:bottom center;
  animation:streamBounce 1.1s ease-in-out infinite;
  box-shadow:0 0 18px rgba(255,255,255,.08);
}

.stream-eq span:nth-child(1){height:30%;background:linear-gradient(180deg,#36e4ff,#00b7ff);animation-delay:.05s}
.stream-eq span:nth-child(2){height:52%;background:linear-gradient(180deg,#ff67f8,#cc49ff);animation-delay:.18s}
.stream-eq span:nth-child(3){height:38%;background:linear-gradient(180deg,#ffe66d,#ffc947);animation-delay:.31s}
.stream-eq span:nth-child(4){height:68%;background:linear-gradient(180deg,#36e4ff,#00b7ff);animation-delay:.44s}
.stream-eq span:nth-child(5){height:46%;background:linear-gradient(180deg,#ff67f8,#cc49ff);animation-delay:.57s}
.stream-eq span:nth-child(6){height:82%;background:linear-gradient(180deg,#ffe66d,#ffc947);animation-delay:.70s}
.stream-eq span:nth-child(7){height:58%;background:linear-gradient(180deg,#36e4ff,#00b7ff);animation-delay:.83s}
.stream-eq span:nth-child(8){height:74%;background:linear-gradient(180deg,#ff67f8,#cc49ff);animation-delay:.96s}
.stream-eq span:nth-child(9){height:40%;background:linear-gradient(180deg,#ffe66d,#ffc947);animation-delay:1.09s}
.stream-eq span:nth-child(10){height:64%;background:linear-gradient(180deg,#36e4ff,#00b7ff);animation-delay:1.22s}
.stream-eq span:nth-child(11){height:36%;background:linear-gradient(180deg,#ff67f8,#cc49ff);animation-delay:1.35s}
.stream-eq span:nth-child(12){height:56%;background:linear-gradient(180deg,#ffe66d,#ffc947);animation-delay:1.48s}

@keyframes streamBounce{
  0%,100%{transform:scaleY(.45);opacity:.72}
  50%{transform:scaleY(1.05);opacity:1}
}

@keyframes streamPulse{
  0%{box-shadow:0 0 0 0 rgba(125,249,255,.65)}
  70%{box-shadow:0 0 0 14px rgba(125,249,255,0)}
  100%{box-shadow:0 0 0 0 rgba(125,249,255,0)}
}
/* ======== END STREAM VISUAL ROOM ======== */


/* ===== STREAM VISUAL PRO ===== */

.stream-visual{
  margin-top:18px;
  padding:22px 20px 20px;
  border-radius:26px;
  background:
    radial-gradient(circle at top center, rgba(143,124,255,.10), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    0 16px 40px rgba(0,0,0,.34),
    inset 0 1px 0 rgba(255,255,255,.04);
  backdrop-filter:blur(10px);
  overflow:hidden;
}

.stream-visual-head{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  margin-bottom:10px;
}

.stream-dot{
  width:9px;
  height:9px;
  border-radius:999px;
  background:#77f7ff;
  box-shadow:0 0 0 0 rgba(119,247,255,.75);
  animation:livePulsePro 1.8s infinite;
}

.stream-live-badge{
  font-size:11px;
  font-weight:800;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#dff8ff;
  opacity:.95;
}

.stream-visual-title-wrap{
  text-align:center;
  margin-bottom:18px;
}

.stream-visual-title{
  font-size:24px;
  line-height:1.05;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#f8fbff;
  text-shadow:
    0 0 18px rgba(143,124,255,.18),
    0 0 28px rgba(125,249,255,.08);
}

.stream-visual-subtitle{
  margin-top:8px;
  font-size:11px;
  letter-spacing:.20em;
  text-transform:uppercase;
  color:rgba(228,235,255,.62);
}

.stream-wave-shell{
  position:relative;
  min-height:180px;
  padding:18px 18px 14px;
  border-radius:22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.008)),
    radial-gradient(circle at center, rgba(125,249,255,.05), transparent 55%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.03),
    inset 0 -20px 50px rgba(0,0,0,.16);
}

.stream-wave-center-line{
  position:absolute;
  left:18px;
  right:18px;
  top:50%;
  height:1px;
  transform:translateY(-50%);
  background:linear-gradient(
    90deg,
    rgba(255,255,255,0),
    rgba(125,249,255,.12),
    rgba(143,124,255,.18),
    rgba(255,255,255,0)
  );
  pointer-events:none;
}

.stream-eq{
  position:relative;
  z-index:1;
  height:150px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:5px;
}

.stream-eq span{
  width:4px;
  border-radius:999px;
  background:linear-gradient(180deg, #86fbff 0%, #8f7cff 55%, #5bd4ff 100%);
  box-shadow:
    0 0 10px rgba(125,249,255,.14),
    0 0 18px rgba(143,124,255,.10);
  animation:waveStudio 1.45s ease-in-out infinite;
  transform-origin:center;
  opacity:.96;
}

.stream-eq span:nth-child(1){height:16%;animation-delay:.03s}
.stream-eq span:nth-child(2){height:28%;animation-delay:.08s}
.stream-eq span:nth-child(3){height:42%;animation-delay:.13s}
.stream-eq span:nth-child(4){height:58%;animation-delay:.18s}
.stream-eq span:nth-child(5){height:72%;animation-delay:.23s}
.stream-eq span:nth-child(6){height:54%;animation-delay:.28s}
.stream-eq span:nth-child(7){height:34%;animation-delay:.33s}
.stream-eq span:nth-child(8){height:20%;animation-delay:.38s}
.stream-eq span:nth-child(9){height:14%;animation-delay:.43s}
.stream-eq span:nth-child(10){height:24%;animation-delay:.48s}
.stream-eq span:nth-child(11){height:38%;animation-delay:.53s}
.stream-eq span:nth-child(12){height:63%;animation-delay:.58s}
.stream-eq span:nth-child(13){height:80%;animation-delay:.63s}
.stream-eq span:nth-child(14){height:67%;animation-delay:.68s}
.stream-eq span:nth-child(15){height:46%;animation-delay:.73s}
.stream-eq span:nth-child(16){height:25%;animation-delay:.78s}
.stream-eq span:nth-child(17){height:14%;animation-delay:.83s}
.stream-eq span:nth-child(18){height:18%;animation-delay:.88s}
.stream-eq span:nth-child(19){height:30%;animation-delay:.93s}
.stream-eq span:nth-child(20){height:48%;animation-delay:.98s}
.stream-eq span:nth-child(21){height:66%;animation-delay:1.03s}
.stream-eq span:nth-child(22){height:52%;animation-delay:1.08s}
.stream-eq span:nth-child(23){height:34%;animation-delay:1.13s}
.stream-eq span:nth-child(24){height:18%;animation-delay:1.18s}

@keyframes waveStudio{
  0%,100%{
    transform:scaleY(.72);
    opacity:.68;
  }
  50%{
    transform:scaleY(1.18);
    opacity:1;
  }
}

@keyframes livePulsePro{
  0%{box-shadow:0 0 0 0 rgba(119,247,255,.6)}
  70%{box-shadow:0 0 0 12px rgba(119,247,255,0)}
  100%{box-shadow:0 0 0 0 rgba(119,247,255,0)}
}

/* ===== END STREAM VISUAL PRO ===== */


/* ===== WAVEFORM STUDIO PRO ===== */

.stream-visual{
  margin-top:18px;
  padding:26px 24px 24px;
  border-radius:28px;

  background:
    radial-gradient(circle at top, rgba(125,249,255,.08), transparent 40%),
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.01));

  border:1px solid rgba(255,255,255,.08);

  backdrop-filter:blur(10px);

  box-shadow:
    0 18px 40px rgba(0,0,0,.38),
    inset 0 1px 0 rgba(255,255,255,.05);

  overflow:hidden;
}

/* header */

.stream-visual-head{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:12px;
}

.stream-dot{
  width:10px;
  height:10px;
  border-radius:999px;

  background:#7df9ff;

  box-shadow:0 0 0 0 rgba(125,249,255,.7);

  animation:livePulse 1.8s infinite;
}

.stream-live-badge{
  font-size:12px;
  font-weight:800;
  letter-spacing:.25em;

  color:#e9faff;
}

/* titre */

.stream-visual-title{
  margin-top:12px;

  text-align:center;

  font-size:24px;
  font-weight:900;

  letter-spacing:.14em;

  color:#ffffff;

  text-shadow:
    0 0 14px rgba(143,124,255,.25);
}

/* zone waveform */

.stream-wave-shell{

  margin-top:22px;

  position:relative;

  height:160px;

  border-radius:22px;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,.03),
      rgba(255,255,255,.008)
    );

  box-shadow:
    inset 0 0 30px rgba(0,0,0,.35);
}

/* ligne centrale */

.stream-wave-center-line{

  position:absolute;

  left:20px;
  right:20px;

  top:50%;

  height:1px;

  background:
    linear-gradient(
      90deg,
      transparent,
      rgba(125,249,255,.18),
      transparent
    );
}

/* waveform */

.stream-eq{

  height:100%;

  display:flex;

  align-items:center;

  justify-content:center;

  gap:4px;
}

.stream-eq span{

  width:3px;

  border-radius:999px;

  background:

    linear-gradient(
      180deg,
      #7df9ff,
      #8f7cff
    );

  opacity:.95;

  animation:waveMove 1.6s ease-in-out infinite;

  transform-origin:center;
}

/* variations */

.stream-eq span:nth-child(1){height:18%; animation-delay:.05s;}
.stream-eq span:nth-child(2){height:30%; animation-delay:.10s;}
.stream-eq span:nth-child(3){height:45%; animation-delay:.15s;}
.stream-eq span:nth-child(4){height:60%; animation-delay:.20s;}
.stream-eq span:nth-child(5){height:72%; animation-delay:.25s;}
.stream-eq span:nth-child(6){height:52%; animation-delay:.30s;}
.stream-eq span:nth-child(7){height:34%; animation-delay:.35s;}
.stream-eq span:nth-child(8){height:22%; animation-delay:.40s;}
.stream-eq span:nth-child(9){height:15%; animation-delay:.45s;}
.stream-eq span:nth-child(10){height:25%; animation-delay:.50s;}
.stream-eq span:nth-child(11){height:40%; animation-delay:.55s;}
.stream-eq span:nth-child(12){height:63%; animation-delay:.60s;}
.stream-eq span:nth-child(13){height:78%; animation-delay:.65s;}
.stream-eq span:nth-child(14){height:68%; animation-delay:.70s;}
.stream-eq span:nth-child(15){height:48%; animation-delay:.75s;}
.stream-eq span:nth-child(16){height:28%; animation-delay:.80s;}
.stream-eq span:nth-child(17){height:16%; animation-delay:.85s;}
.stream-eq span:nth-child(18){height:20%; animation-delay:.90s;}
.stream-eq span:nth-child(19){height:32%; animation-delay:.95s;}
.stream-eq span:nth-child(20){height:50%; animation-delay:1.00s;}

@keyframes waveMove{

  0%,100%{

    transform:scaleY(.6);
    opacity:.65;

  }

  50%{

    transform:scaleY(1.15);
    opacity:1;

  }

}

@keyframes livePulse{

  0%{
    box-shadow:0 0 0 0 rgba(125,249,255,.7);
  }

  70%{
    box-shadow:0 0 0 14px rgba(125,249,255,0);
  }

  100%{
    box-shadow:0 0 0 0 rgba(125,249,255,0);
  }

}

/* ===== END WAVEFORM STUDIO PRO ===== */


.login-status-box{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
