/* ============ VYO User Profile (Modern v2) ============ */
:root{
  --vyo-accent: #15c70c;
}

/* Breiter Content (statt Bootstrap .container max-width) */
.vyo-wrap{
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 16px;
}
@media (max-width: 576px){
  .vyo-wrap{ padding: 0 12px; }
}

/* Full-bleed (100vw) auch wenn du "in einer container-Welt" bist */
.vyo-bleed{
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

/* Glass Card */
.vyo-glass{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  box-shadow: 0 18px 42px rgba(0,0,0,.22);
  backdrop-filter: blur(10px);
}

html[data-theme="light"] .vyo-glass{
  background: rgba(255,255,255,.85);
  border-color: rgba(0,0,0,.08);
  box-shadow: 0 16px 36px rgba(0,0,0,.10);
}

.vyo-profile-top{
  display:flex;
  flex-wrap:wrap;
  align-items:flex-start;
  justify-content:space-between;
  gap: 14px;
}

.vyo-avatar{
  width: 108px;
  height: 108px;
  border-radius: 22px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
}
.vyo-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.vyo-profile-name{
  font-weight: 900;
  letter-spacing: .2px;
  line-height: 1.05;
  margin: 0;
  font-size: clamp(1.4rem, 2vw, 2.1rem);
}

.vyo-profile-sub{
  opacity: .82;
  font-size: .95rem;
  margin-top: 2px;
}

.vyo-actionbar .btn,
.vyo-actionbar .badge{
  border-radius: 999px !important;
}

/* Card-Look auf der Profilseite (ohne überall einzeln anzufassen) */
.vyo-profile-page .card{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.14);
  box-shadow: 0 18px 42px rgba(0,0,0,.18);
}

html[data-theme="light"] .vyo-profile-page .card{
  background: rgba(255,255,255,.92);
  border-color: rgba(0,0,0,.08);
  box-shadow: 0 14px 30px rgba(0,0,0,.10);
}

.vyo-profile-page .list-group-item{
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.10);
  margin-bottom: 10px;
}

html[data-theme="light"] .vyo-profile-page .list-group-item{
  background: rgba(255,255,255,.92);
  border-color: rgba(0,0,0,.08);
}

/* Mini-Reveal Animation */
.vyo-reveal{
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .5s ease, transform .5s ease;
}
.vyo-reveal.is-in{
  opacity: 1;
  transform: none;
}

/* Accent helper */
.vyo-accent{ color: var(--vyo-accent) !important; }

/* ============ VYO Stat Cards ============ */
.vyo-profile-page .card[data-visibility-key]{
  position: relative;
  overflow: hidden;
  /* border/background kommen von .vyo-profile-page .card */
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

/* sehr dezenter "Sheen" – nicht bunt */
.vyo-profile-page .card[data-visibility-key]::before{
  content:"";
  position:absolute;
  inset:-40px;
  background:
    radial-gradient(520px 260px at 20% 15%, rgba(255,255,255,.07), transparent 60%),
    radial-gradient(420px 220px at 80% 10%, rgba(255,255,255,.04), transparent 60%);
  opacity: .55;
  pointer-events:none;
}

/* dünne Accent-Line nur beim Hover (grün, aber subtil) */
.vyo-profile-page .card[data-visibility-key]::after{
  content:"";
  position:absolute;
  left: 12px;
  right: 12px;
  top: 10px;
  height: 2px;
  border-radius: 999px;
  background: rgba(21,199,12,.75);
  opacity: 0;
  filter: blur(.2px);
  transition: opacity .18s ease;
}

.vyo-profile-page .card[data-visibility-key]:hover{
  transform: translateY(-3px);
  box-shadow: 0 22px 60px rgba(0,0,0,.26);
  border-color: rgba(255,255,255,.16);
}
.vyo-profile-page .card[data-visibility-key]:hover::after{
  opacity: .9;
}

/* Zahlen/Überschrift ruhiger & centered */
.vyo-profile-page .card[data-visibility-key] h6{
  text-align: center;
  letter-spacing: .2px;
  opacity: .85;
}
.vyo-profile-page .card[data-visibility-key] .display-6,
.vyo-profile-page .card[data-visibility-key] .fs-3{
  font-weight: 900;
  text-align: center;
  margin-top: 6px;
}
.vyo-profile-page .card[data-visibility-key] small{
  display:block;
  text-align:center;
  opacity: .78;
}

/* ============ RotatingText (Vanilla) ============ */
.vyo-rot{
  display: inline-block;
  position: relative;
  overflow: hidden;
  height: 1.15em;
  vertical-align: -0.12em;
  color: var(--support-accent, #15c70c);
  font-weight: 900;
  letter-spacing: .2px;
}
.vyo-rot-item{
  display: inline-block;
  transform: translateY(0);
  opacity: 1;
  will-change: transform, opacity;
}
.vyo-rot-item.vyo-out{
  transform: translateY(-120%);
  opacity: 0;
  transition: transform .18s ease, opacity .18s ease;
}
.vyo-rot-item.vyo-prep{
  transform: translateY(120%);
  opacity: 0;
}
.vyo-rot-item.vyo-in{
  transform: translateY(0);
  opacity: 1;
  transition: transform .22s cubic-bezier(.2,1,.2,1), opacity .22s ease;
}

.vyo-modal{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.22);
  backdrop-filter: blur(10px);
}

.vyo-cover-preview{
  width: 100%;
  height: 180px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.14);
  overflow: hidden;
  position: relative;
}
.vyo-cover-preview img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
}
.vyo-cover-fallback{
  height: 100%;
  display:flex;
  align-items:center;
  justify-content:center;
}

/* ===== Page BG (für Fade) ===== */
html[data-theme="dark"]{
  --vyo-page-bg: #0b1220;
  --vyo-hero-dim: rgba(0,0,0,.45);
  --vyo-card-glass: rgba(0,0,0,.22);
}
html[data-theme="light"]{
  --vyo-page-bg: #f8fafc;
  --vyo-hero-dim: rgba(0,0,0,.18);
  --vyo-card-glass: rgba(255,255,255,.62);
}

/* ===== Hero: Höhe, Overlap, Fade ===== */
:root{
  --vyo-hero-overlap: 240px;     /* ↑ mehr Overlap => Cards “auf” dem Cover */
  --vyo-hero-minh: 560px;        /* ↑ Hero höher */
  --vyo-hero-fade-start: 84%;    /* Fade erst spät => Cover hinter Cards sichtbar */
}

/* cancelt typisches mt-4/padding-top aus base ohne “hochschieben” */
.vyo-hero--flush{
  margin-top: -1.5rem;
  padding-top: 1.5rem;
}

@keyframes vyoBlob1{
  0%   { transform: translate3d(-92%, -78%, 0) scale(1.05); }
  20%  { transform: translate3d(-25%, -88%, 0) scale(1.18); }
  50%  { transform: translate3d(-65%, -35%, 0) scale(1.10); }
  80%  { transform: translate3d(-98%, -18%, 0) scale(1.22); }
  100% { transform: translate3d(-92%, -78%, 0) scale(1.05); }
}
@keyframes vyoBlob2{
  0%   { transform: translate3d(-10%, -25%, 0) scale(1.10); }
  25%  { transform: translate3d(-78%, -20%, 0) scale(1.22); }
  55%  { transform: translate3d(-30%, -88%, 0) scale(1.14); }
  85%  { transform: translate3d(-5%,  -60%, 0) scale(1.26); }
  100% { transform: translate3d(-10%, -25%, 0) scale(1.10); }
}
@keyframes vyoBlob3{
  0%   { transform: translate3d(-55%, -10%, 0) scale(1.12); }
  30%  { transform: translate3d(-95%, -55%, 0) scale(1.26); }
  60%  { transform: translate3d(-18%, -45%, 0) scale(1.18); }
  90%  { transform: translate3d(-70%, -92%, 0) scale(1.30); }
  100% { transform: translate3d(-55%, -10%, 0) scale(1.12); }
}

/* ===== HERO: Cover stabil + FX separat (kein Shift) ===== */

@keyframes vyoCoverZoom{
  from{ transform: translateZ(0) scale(1.02); }
  to  { transform: translateZ(0) scale(1.06); }
}

/* Lava/Drift nur für FX (nicht für Cover!) */
@keyframes vyoHeroFloat{
  0%   { transform: translate3d(-2%, -1%, 0) scale(1.06); filter: blur(0px) saturate(115%); }
  50%  { transform: translate3d( 2%,  1.5%,0) scale(1.10); filter: blur(1px) saturate(125%); }
  100% { transform: translate3d(-1%,  2%, 0) scale(1.08); filter: blur(0px) saturate(120%); }
}

.vyo-profile-hero{
  position: relative;
  overflow: hidden;
  min-height: var(--vyo-hero-minh);
  padding-bottom: var(--vyo-hero-overlap);
}

/* COVER-ONLY (stabil, kein inset:-40, kein Drift) */
.vyo-profile-hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;

  background:
    linear-gradient(180deg, var(--vyo-hero-dim), var(--vyo-hero-dim)),
    var(--vyo-hero-cover, none);
  background-size: cover;
  background-position: 50% 40%;
  transform-origin: center;
}

/* Cover-Zoom nur wenn Animation an */
.vyo-profile-hero.has-cover[data-hero-anim="1"]::before{
  animation: vyoCoverZoom 18s ease-in-out infinite alternate;
}

/* Hero komplett aus => Cover pur (ohne Dim, ohne Animation) */
.vyo-profile-hero[data-hero-enabled="0"]::before{
  background: var(--vyo-hero-cover, none);
  background-size: cover;
  background-position: 50% 40%;
  animation: none !important;
  filter: none;
}

/* FX-LAYER: Container (Blobs drin) */
.vyo-hero-fx{
  position:absolute;
  inset:-60px;
  z-index:1;
  pointer-events:none;

  opacity: 1;
  transition: opacity .2s ease;

  /* Intensität -> Alpha für Blobs */
  --vyo-blob-a: clamp(0, calc(var(--vyo-hero-i, .18) * 2.8), .72);
}

/* FX komplett aus */
.vyo-profile-hero[data-hero-enabled="0"] .vyo-hero-fx{ opacity: 0; }

.vyo-hero-fx .vyo-blob{
  position:absolute;
  left: 50%;
  top: 50%;
  border-radius: 999px;
  will-change: transform;
  pointer-events:none;

  /* wichtig: kleiner als vorher, sonst „eine Masse“ */
  opacity: var(--vyo-blob-a);
  mix-blend-mode: screen;
  filter: blur(44px) saturate(135%);
}

.vyo-blob-1{ width: 66vmax; height: 66vmax; }
.vyo-blob-2{ width: 56vmax; height: 56vmax; filter: blur(54px) saturate(145%); }
.vyo-blob-3{ width: 48vmax; height: 48vmax; filter: blur(48px) saturate(140%); }

/* Farben */
.vyo-blob-1{
  background: radial-gradient(circle at 30% 30%,
    rgba(var(--vyo-hero-c1-rgb, 21,199,12), 1),
    transparent 62%
  );
}
.vyo-blob-2{
  background: radial-gradient(circle at 70% 35%,
    rgba(var(--vyo-hero-c2-rgb, 40,120,255), 1),
    transparent 62%
  );
}
.vyo-blob-3{
  background: radial-gradient(circle at 40% 70%,
    rgba(var(--vyo-hero-c1-rgb, 21,199,12), 1),
    transparent 66%
  );
}

/* Animation an/aus (wir animieren die einzelnen Blobs) */
.vyo-profile-hero[data-hero-anim="1"] .vyo-blob-1{
  animation: vyoBlob1 var(--vyo-hero-speed, 14s) ease-in-out infinite;
}
.vyo-profile-hero[data-hero-anim="1"] .vyo-blob-2{
  animation: vyoBlob2 calc(var(--vyo-hero-speed, 14s) + 2s) ease-in-out infinite;
}
.vyo-profile-hero[data-hero-anim="1"] .vyo-blob-3{
  animation: vyoBlob3 calc(var(--vyo-hero-speed, 14s) + 5s) ease-in-out infinite;
}

.vyo-profile-hero[data-hero-anim="0"] .vyo-hero-fx .vyo-blob{
  animation: none !important;
}

/* Fade */
.vyo-profile-hero::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0) 0%,
    rgba(0,0,0,0) var(--vyo-hero-fade-start),
    var(--vyo-page-bg) 100%
  );
}

.vyo-profile-hero .container-fluid{
  position: relative;
  z-index: 3;
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce){
  .vyo-profile-hero.has-cover[data-hero-anim="1"]::before{ animation: none !important; }
  .vyo-hero-fx .vyo-blob{ animation: none !important; }
}

.vyo-hero-pad{
  padding-top: 2.25rem;
  padding-bottom: 2.25rem;
}
@media (min-width: 992px){
  .vyo-hero-pad{
    padding-top: 3.25rem;
    padding-bottom: 3.25rem;
  }
}

/* ===== Content “zieht” in den Hero rein ===== */
.vyo-profile-page{
  margin-top: calc(var(--vyo-hero-overlap) * -1);
  position: relative;
  z-index: 5;
}

/* ===== “Statistiken” mittig, größer, mehr Luft ===== */
.vyo-section-head{
  display:flex;
  justify-content:center;
  margin: 52px 0 30px;
}
.vyo-section-title{
  margin: 0;
  font-weight: 900;
  letter-spacing: .35px;
  font-size: clamp(2.0rem, 2.8vw, 3.0rem);
  text-align:center;
}

/* ===== File-Input (Darkmode) besserer Kontrast ===== */
/* Wichtig: modal-content sollte class="vyo-modal" haben */
html[data-theme="dark"] .vyo-modal input[type="file"].form-control{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.14);
  color: rgba(255,255,255,.92);
}
html[data-theme="dark"] .vyo-modal input[type="file"].form-control::file-selector-button{
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.18);
  color: rgba(255,255,255,.92);
  border-radius: 10px;
}
html[data-theme="dark"] .vyo-modal input[type="file"].form-control::-webkit-file-upload-button{
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.18);
  color: rgba(255,255,255,.92);
  border-radius: 10px;
}

/* ===== Info-Modal (Modern) ===== */
.vyo-modal-info{
  overflow: hidden; /* header-gradient sauber clippen */
}

.vyo-modal-info-header{
  border-bottom: 0;
  position: relative;
  padding: 1rem 1rem .9rem;
}

.vyo-modal-info-header::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 240px at 18% 20%, rgba(21,199,12,.18), transparent 60%),
    radial-gradient(900px 240px at 82% 10%, rgba(40,120,255,.18), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(0,0,0,.06));
  pointer-events:none;
  opacity: .9;
}

.vyo-modal-info-header > *{
  position: relative;
  z-index: 1;
}

.vyo-info-avatar{
  width: 56px;
  height: 56px;
  object-fit: cover;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
}

.vyo-info-meta{
  margin-top: .25rem;
  display: flex;
  gap: .4rem;
  flex-wrap: wrap;
}

.vyo-info-pill{
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .2rem .55rem;
  border-radius: 999px;
  font-size: .82rem;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
}

html[data-theme="light"] .vyo-info-pill{
  background: rgba(255,255,255,.65);
  border-color: rgba(0,0,0,.08);
}

.vyo-info-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .65rem;
}

@media (max-width: 576px){
  .vyo-info-grid{ grid-template-columns: 1fr; }
}

.vyo-kv{
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.14);
  border-radius: 14px;
  padding: .65rem .75rem;
}

html[data-theme="light"] .vyo-kv{
  background: rgba(255,255,255,.72);
  border-color: rgba(0,0,0,.08);
}

.vyo-k{
  font-size: .78rem;
  letter-spacing: .02em;
  text-transform: uppercase;
  opacity: .72;
}

.vyo-v{
  margin-top: .15rem;
  font-weight: 700;
  word-break: break-word;
}

.vyo-bio-box{
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.12);
  border-radius: 14px;
  padding: .75rem .85rem;
}

html[data-theme="light"] .vyo-bio-box{
  background: rgba(255,255,255,.72);
  border-color: rgba(0,0,0,.08);
}

.vyo-cropper-stage{
  width: 100%;
  height: 420px;
  background: rgba(0,0,0,.12);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 14px;
  overflow: hidden;
  position: relative;
}
html[data-theme="light"] .vyo-cropper-stage{
  background: rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.08);
}

#vyoCropImage{
  max-width: 100%;
  display: block;
}

.vyo-crop-preview{
  width: 100%;
  height: 180px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.10);
}
html[data-theme="light"] .vyo-crop-preview{
  border-color: rgba(0,0,0,.08);
  background: rgba(0,0,0,.03);
}

/* Avatar-Preview rund (setzt JS automatisch per Klasse) */
.vyo-crop-preview.is-avatar{
  border-radius: 999px;
  height: 220px;
}

/* ===== Cropper: mehr Arbeitsfläche ===== */
#vyoCropModal .modal-dialog{
  max-width: 1200px;
}

.vyo-cropper-stage{
  width: 100%;
  height: min(70vh, 620px);
  min-height: 420px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.25);
}

#vyoCropImage{
  display: block;
  max-width: 100%;
}

/* ===== VYO Collapsible Head (Report-Logs etc.) ===== */
.vyo-collapsible-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  cursor:pointer;
  user-select:none;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.vyo-collapsible-head:hover{
  background: rgba(255,255,255,.03);
}

.vyo-collapsible-icon{
  font-size: 18px;
  line-height: 1;
  opacity: .85;
}

/* dot indicator (z.B. danger) */
.vyo-dot{
  width:8px;
  height:8px;
  border-radius:999px;
  display:inline-block;
  flex: 0 0 auto;
}

.vyo-dot--danger{
  background: #dc3545;
}